@charset "utf-8";

* {box-sizing: border-box;}
.hidden {display: none !important;}
.capitalize {text-transform: uppercase;}

html {overflow-y: scroll;}
body {background-color: var(--warm-sand-light); color: var(--black); font-family: "Poppins", Arial; font-size: 16px; margin: 0; min-height: 100vh; min-width: 320px; gap: 0; align-items: normal; justify-content: normal; flex-direction: column; flex-wrap: nowrap; font-weight: 400; line-height: normal;}

select,option,button,input {background: none; color: var(--black); font-family: "Poppins", Arial; font-size: 16px; cursor: pointer;} /* added background: none; */
select:disabled,option:disabled,input:disabled {color: var(--gray); font-family: "Poppins", Arial; font-size: 16px; cursor: default;}
option:checked {background-color: var(--primary); color: var(--white);}
p {margin: 0; padding: 0;}
a {color: var(--black); text-decoration: none;}
img {border: 0;}
ul {margin: 0;}
table {border: 0; border-spacing: 0; border-collapse: collapse; margin: 0; padding: 0;}
td,form,h1,h2,h3,h4,h5,h6 {margin: 0; padding: 0;}

section {padding-top: clamp(20px, 5.53vw, 80px);}

h1 {font-size: clamp(24px, 4vw, 40px); font-weight: 800; line-height: 1.5em; margin: 0; padding: 0;}
h2 {font-size: clamp(20px, 3vw, 28px); font-weight: 700; line-height: 1.5em; margin: 0; padding: 0;}
h3 {font-size: clamp(18px, 3vw, 22px); font-weight: 700; line-height: 1.5em; margin: 0; padding: 0;}
h4 {font-size: clamp(16px, 2.66vw, 20px); font-weight: 600; line-height: 1.5em; margin: 0; padding: 0;}
h5 {font-size: clamp(14px, 2.33vw, 18px); font-weight: 500; line-height: 1.5em; margin: 0; padding: 0;}
h6 {font-size: clamp(12px, 2vw, 16px); font-weight: 400; line-height: 1.5em; margin: 0; padding: 0;}

.noscript_banner {position:fixed;top:0;left:0;right:0;z-index:9999;background:#c0392b;color:#fff;text-align:center;padding:1em;font-family:sans-serif;}

div.obow_inf {padding: 30px 20px; text-align: center; max-height: max-content; min-width: 320px;}
div.obow_inf .footer_content {max-width: 1200px; margin: 0 auto;}
div.obow_inf p {margin: 0 0 12px 0; font-size: 13px; line-height: 1.5;}
div.obow_inf p:last-child {margin-bottom: 0;}
div.obow_inf .footer_disclaimer {color: var(--tertiary-text-color); font-weight: 300;}
div.obow_inf .footer_copyright {font-weight: 400;}
div.obow_inf a {color: var(--black); text-decoration: underline; transition: color 0.2s ease;}
div.obow_inf a:hover {color: var(--gray);}

.button.primary,
.button.secondary,
.button.tertiary,
.button.quaternary,
.button.icon {
	display: inline-flex; align-items: center; justify-content: center; text-decoration: none; transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease; cursor: pointer; border-radius: 8px;
}

.button.primary {background-color: var(--primary); color: var(--white); border: none; padding: 9px 12px; font-size: 14px; font-weight: 600; text-align: center; }
.button.primary[disabled],
.button.primary.disabled {
	background-color: var(--disabled-surface-color); cursor: default;
}
.button.primary:hover:not([disabled]):not(.disabled) {background-color: var(--primary-hover);}
.button.primary:active:not([disabled]):not(.disabled) {background-color: var(--primary-active);}
.button.primary.wide {padding: 7px 20px;}
.button.primary .icon {background-size: 16px; width: 16px; height: 16px; margin-right: 8px;}

.icon {background-repeat: no-repeat; background-position: center; background-size: 24px; width: 24px; height: 24px; display: inline-block;}

.icon-search {background-image: url('../images/iko-lupa-biala.svg');}
.icon-info {background-image: url('../images/iko-info_bootstrap.svg'); background-size: 16px; width: 16px; height: 16px; filter: invert(39%) sepia(8%) saturate(50%) hue-rotate(190deg) brightness(128%) contrast(85%);}

.button.secondary {display: inline-block; background-color: var(--primary-surface); color: var(--primary); border: 1px solid var(--primary); padding: 9px 12px; font-size: 14px; font-weight: 400; text-align: center; border: 2px solid var(--primary)}
.button.secondary[disabled],
.button.secondary.disabled {
	color: var(--disabled-text-color); border-color: var(--disabled-text-color); cursor: default;
}
.button.secondary:hover:not([disabled]):not(.disabled) {background-color: var(--primary-surface); border-color: var(--primary-hover); color: var(--primary-hover);}
.button.secondary:active:not([disabled]):not(.disabled) {background-color: var(--primary-surface-active); border-color: var(--primary-active); color: var(--primary-active);}
.button.secondary.wide {padding: 7px 20px;}
.button.secondary.shadowed {box-shadow: 0px -3px 10px 0px var(--shadow-primary) inset;}

.button.tertiary {display: inline-block; background-color: var(--primary-surface); color: var(--black); border: 1px solid var(--black-semi-3); padding: 9px 12px; font-size: 14px; font-weight: 200; text-align: center;}
.button.tertiary[disabled],
.button.tertiary.disabled {
	color: var(--disabled-text-color); border-color: var(--gray-light); cursor: default;
}
.button.tertiary.wide {padding: 3px 20px;}

.button.quaternary {background-color: transparent; border: none; padding: 0; color: inherit; justify-content: flex-start; text-align: left;}
.button.quaternary[disabled],
.button.quaternary.disabled {color: var(--disabled-text-color); cursor: default;}

.button.icon {background-color: var(--primary-surface); border: none; padding: 4px; width: 32px; height: 32px; color: var(--gray); font-size: 18px; line-height: 1; font-weight: bold;}
.button.icon.small {width: 24px; height: 24px; padding: 2px;}
.button.icon:hover {color: var(--black); }
.button.icon[disabled],
.button.icon.disabled { color: var(--disabled-text-color); cursor: default; }

.unbreakable {white-space: nowrap; word-break: keep-all;}

.oferta_zdjecie {grid-area: zdjecie; border-radius: 16px; overflow: hidden; position: relative;}
.oferta_zdjecie_bg {filter: blur(18px) saturate(3) contrast(0.15) brightness(1.75); height: 100%; inset: 0; object-fit: cover; object-position: center; position: absolute; transform: scale(1.15); width: 100%; margin: 0 auto; z-index: -1;}
.oferta_zdjecie_img {filter: saturate(1.05) contrast(1.05); height: 100%; width: 100%; object-fit: cover; position: relative; object-position: center; display: block; margin: 0 auto;}

/* STRONA GŁÓWNA */

.ps_glowna {
  display: grid;
  grid-template-areas:
	"regiony"
	"typy_wyjazdow"
	"kraje"
	"co_mowia";
  grid-template-columns: 1fr;
  gap: 10px;
  margin: 0 auto;
  min-width: 320px;
  max-width: 1440px;
  padding: 0;
}
body:not(.al) .ps_glowna > section > h1 {padding-left: clamp(20px, 5.53vw, 80px);}
.hero {background: url("../images/hero-glowna-2880.jpg") var(--primary-active); background-repeat: no-repeat; background-size: cover; background-position: center 50%; flex: 1 0 auto; height: auto;}
.hero_under_menu {padding-top: 100px;}
.regiony {grid-area: regiony;}
.typy_wyjazdow {grid-area: typy_wyjazdow;}
.kraje {grid-area: kraje;}
.co_mowia {grid-area: co_mowia;}

/* PODSTRONA Z LISTĄ OFERT */
.ps_oferty .kontakt_banner {border-radius: 16px; box-sizing: border-box; display: block; object-fit: cover; object-position: center; margin: 0; margin-bottom: clamp(8px, 5.53vw, 40px); padding: 32px; position: relative; overflow: hidden; }
.ps_oferty .kontakt_banner.kontakt_banner-zima {background: url("../images/contact-banner-background.jpg") no-repeat center 40%; background-size: cover; }
.ps_oferty .kontakt_banner.kontakt_banner-lato {background: url("../images/contact-banner-background-lato.jpg") no-repeat center 56%; background-size: auto; }
.ps_oferty .kontakt_banner::before {content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(255, 255, 255, 0.5); z-index: 0;}
.ps_oferty .kontakt_banner>img {bottom: 0; height: 232px; margin-right: clamp(8px, 7.6vw, 100px); position: absolute; right: 0; position: relative;}
.ps_oferty .kontakt_banner>.ps_oferty-kontakt_banner--title {margin: 0; font-weight: 600; font-size: 20px; line-height: 140%; letter-spacing: 0%; position: relative;}
.ps_oferty .kontakt_banner>.ps_oferty-kontakt_banner--message {font-weight: 400; font-size: 16px; line-height: 150%; letter-spacing: 0%; position: relative;}
.ps_oferty .kontakt_banner>.ps_oferty-kontakt_banner--buttons {margin-top: 16px; position: relative; display: flex; flex-wrap: wrap; gap: 16px;}
.ps_oferty .kontakt_banner>.ps_oferty-kontakt_banner--buttons .button {flex: 1 0 175px; max-width: 200px; text-align: center;}
.ps_oferty .kontakt_banner>.ps_oferty-kontakt_banner--buttons .secondary {font-family: Poppins;font-weight: 600;font-size: 16px;line-height: 150%;letter-spacing: 0%;}

.ps_oferty {
  margin: 0 auto;
  min-width: 320px;
  max-width: 1440px;
  padding: 0;
}
.ps_oferty section {padding: clamp(20px, 5.53vw, 40px) clamp(20px, 5.53vw, 64px);}
.hero_oferty.hero_oferty-zima {background: url("../images/hero-oferty-2880.jpg") no-repeat center 31%; background-size: cover; }
.hero_oferty.hero_oferty-lato {background: url("../images/hero-oferty-lato.jpg") no-repeat center 37%; background-size: cover; }
.hero_oferty p {color: var(--white); font-size: clamp(24px, 4vw, 48px); font-weight: bold; line-height: 120%; margin: 0 auto; max-width: 1440px; padding: clamp(30px, 6.38vw, 92px) clamp(20px, 5.53vw, 80px);}

.oferty_naglowek {
  display: grid;
  grid-template-areas:
	"tytul filtry_przycisk";
  grid-template-columns: 1fr;
  gap: 10px;
}
.oferty_naglowek h1 {grid-area: tytul; padding: 0 0 clamp(20px, 5.53vw, 40px) 0;}
.oferty_naglowek button {grid-area: filtry_przycisk; background: url("../images/iko-rozwin-w-dol.svg") no-repeat left center; border: 0; cursor: pointer; display: none; float: right; height: clamp(30px, 3vw, 50px); padding: 0 0 0 25px;}

.oferty_lista {
  display: grid;
  grid-template-areas:
	"filtry lista";
  grid-template-columns: 288px 1fr;
  gap: 64px;
}
.oferty_lista div.filtry {grid-area: filtry}
.oferty_lista div.lista {grid-area: lista}
.oferty_lista div.lista .back-to-top {width: 100%; margin-top: 24px;}

.overlay {
  display: none;
  position: fixed;
  top: 0; left: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.5);
  z-index: 998;
}

.filtry .filters_submit {position: relative; width: 100%; text-align: center; z-index: 1; flex: 1 1 100%;}
.filtry .filters_close {position: relative; top: 0; right: 16px; z-index: 1; display: none;}
.filtry .filters-main_actions_wrapper {display: flex; gap: 16px; justify-content: space-between; align-items: center; position: sticky; top: 0; background: var(--primary-surface); z-index: 100; padding-top: 16px; padding-bottom: 16px;}
.filtry h2 {font-size: 24px; font-weight: bold; width: 49.5%;}
.filtry h3 {font-size: 18px; font-weight: 600; width: 49.5%;}
.filter_group--first {border-top: 0; padding-top: 0; margin-top: 0;}
.filter_group .filter_group-header {align-items: center; display: flex; justify-content: space-between; width: 100%;}
.filter_group .filter_group-header *:nth-child(1) {flex: 0 0 0; white-space: nowrap;}
.filter_group .filter_input-wrapper {margin: 20px 0; width: 100%;}
.filter_group .filter_input-wrapper input {width: 100%;}
.filter_group {border-top: 1px solid var(--gray-light); display: flex; flex-wrap: wrap; padding-top: 20px; padding-bottom: 16px;}
.filter_group>div {margin: 0; width: 100%;}
.filter_group input#znajdz {background: url('../images/iko-lupa-czarna.svg') no-repeat 14px center; border: 1px solid var(--gray-light); border-radius: 8px; padding: 11px 30px 11px 47px; appearance: none; -webkit-appearance: none; -moz-appearance: none;}
.filter_group label {line-height: 175%; margin: 16px 0;}

/* Offer filters: price */
#offer-filters {
	--price-accent: var(--selected);
	--price-track: var(--selected);
}

#offer-filters .filter_price_mode {
	position: relative;
	display: flex;
	gap: 8px;
	margin: 12px 0 16px 0;
}

#offer-filters .filter_price_mode input[type="radio"] {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

#offer-filters .filter_price_mode label {
	flex: 1 1 0;
	text-align: center;
	padding: 8px 10px;
	border: 1px solid var(--gray-light);
	border-radius: 8px;
	background: var(--primary-surface);
	color: var(--selected);
	font-weight: 600;
	cursor: pointer;
	user-select: none;
}

#offer-filters .filter_price_mode input[type="radio"]:checked + label {
	background: var(--selected);
	border-color: var(--selected);
	color: var(--white);
}

#offer-filters .filter_price_controls {
	display: flex;
	align-items: center;
	gap: 16px;
}

#offer-filters .filter_price_range {
	flex: 1 1 auto;
	min-width: 0;
	-webkit-appearance: none;
	appearance: none;
	height: 4px;
	border-radius: 999px;
	background: var(--price-track);
	outline: none;
	cursor: pointer;
}

#offer-filters .filter_price_range::-webkit-slider-runnable-track {
	height: 4px;
	border-radius: 999px;
	background: transparent;
}

#offer-filters .filter_price_range::-webkit-slider-thumb {
	-webkit-appearance: none;
	background: var(--price-accent);
	width: 22px;
	height: 22px;
	border: 3px solid var(--white);
	border-radius: 50%;
	cursor: pointer;
	margin-top: -9px;
}

#offer-filters .filter_price_range::-moz-range-track {
	height: 4px;
	border-radius: 999px;
	background: var(--primary-surface);
	border: 1px solid var(--price-track);
}

#offer-filters .filter_price_range::-moz-range-progress {
	height: 4px;
	border-radius: 999px;
	background: var(--price-accent);
}

#offer-filters .filter_price_range::-moz-range-thumb {
	background: var(--price-accent);
	width: 22px;
	height: 22px;
	border: 3px solid var(--white);
	border-radius: 50%;
	cursor: pointer;
}

#offer-filters .filter_price_amount {
	position: relative;
	flex: 0 0 0;
}

#offer-filters .filter_price_amount input {
	width: 105px;
	height: 38px;
	box-sizing: border-box;
	padding: 0 32px 0 12px;
	border: 2px solid var(--gray-light);
	border-radius: 8px;
	background: var(--primary-surface);
	appearance: textfield;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

#offer-filters .filter_price_amount input:focus-visible {
	border-color: var(--price-accent);
	outline: none;
}

#offer-filters .filter_price_amount input::-webkit-outer-spin-button,
#offer-filters .filter_price_amount input::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

#offer-filters .filter_price_currency {
	position: absolute;
	right: 12px;
	top: 50%;
	transform: translateY(-50%);
	font-size: 12px;
	color: var(--black);
	pointer-events: none;
}

/* Offer filters: standard (stars) */
#offer-filters .filter_standard-stars {
	display: flex;
	gap: 4px;
	align-items: center;
	padding: 18px 0;
	color: var(--primary);
}

#offer-filters .filter_standard-star {
	color: inherit;
	appearance: none;
	background: transparent;
	border: 0;
	padding: 0;
	cursor: pointer;
	line-height: 0;
}

#offer-filters .filter_standard-starIcon {
	width: 32px;
	height: 32px;
	display: block;
	fill: transparent;
	stroke: currentColor;
	stroke-width: 1.6;
	transition: fill 0.12s ease, fill-opacity 0.12s ease;
}

#offer-filters .filter_standard-star.is-hovered .filter_standard-starIcon {
	fill: currentColor;
	filter: opacity(0.50) saturate(1.5);
}

#offer-filters .filter_standard-star.is-selected .filter_standard-starIcon {
	fill: currentColor;
	fill-opacity: 1;
}

#offer-filters .filter_standard-star:focus-visible {
	outline: 2px solid var(--price-accent);
	outline-offset: 4px;
	border-radius: 6px;
}

.filter_region-list > *:nth-child(1n+10) {display: none;} /* ukrycie wszystkich oprócz pierwszych 9 regionów */
.filter_region-list > .region-list-toggle {display: block; margin: 16px 0;} /* pokazanie przycisku niezależnie od regionów */
.filter_region-list.expanded > * {display: block;} /* pokazanie wszystkich regionów po rozwinięciu */
.filter_region-region {margin-left: 16px;}

.custom-checkbox {display: flex; align-items: baseline; cursor: pointer; gap: 8px; position: relative;}
.custom-checkbox input, .custom-radio input[type="radio"] {position: absolute; opacity: 0;} /* ukrycie natywnego checkboxa */
.checkmark {display: inline-block; width: 18px; height: 18px; margin: -3px 0 0 0; border: 1px solid var(--gray-light); border-radius: 4px; vertical-align: middle; transition: background 0.3s;} /* kwadracik zastępczy */
.custom-checkbox input:checked + .checkmark {background: var(--primary); border-color: var(--primary); position: relative;} /* efekt zaznaczenia */
.custom-checkbox input:checked + .checkmark::after {content: ""; position: absolute; left: 5px; top: 2px; width: 4px; height: 8px; border: solid white; border-width: 0 2px 2px 0; transform: rotate(45deg);} /* ptaszek (pseudo-element) */
.custom-checkbox input:indeterminate + .checkmark {background: var(--primary); border-color: var(--primary); position: relative;} /* efekt indeterminate (częściowo zaznaczone) */
.custom-checkbox input:indeterminate + .checkmark::after {content: ""; position: absolute; left: 3px; top: 7px; width: 10px; height: 2px; background: white;} /* minus (pseudo-element) */
.radiomark {display: inline-block; border: 2px solid var(--input-borders); border-radius: 50%; height: 18px; position: relative; transition: all 0.2s ease; width: 18px;} /* Styl "kółka" */
.custom-radio {align-items: center; cursor: pointer; display: flex; gap: 8px; line-height: 250%; position: relative;  -webkit-tap-highlight-color: transparent;}
.custom-radio input[type="radio"]:checked + .radiomark::after {background: var(--primary); border-radius: 50%; content: ""; height: 12px; left: 50%; position: absolute; top: 50%; transform: translate(-50%, -50%); width: 12px;} /* Środek po zaznaczeniu */
/* .custom-radio:hover .radiomark {border-color: #000;} */ /* Efekt hover */

.oferta_kafelek {
	border-top: 1px solid var(--gray-light);
	border-radius: 16px;
	box-shadow: 0px 2px 10px 0px var(--black-semi-3);
	display: grid;
	position: relative;
	grid-template-areas:
		"zdjecie nazwa nazwa cena"
		"zdjecie parametry informacje poleca"
		"zdjecie parametry informacje button";
	grid-template-columns: 327px 220px minmax(168px, 1fr) 175px;
	gap: 0;
	margin-bottom: 16px;
	overflow: hidden;
	background: var(--primary-surface);
}

.oferta_kafelek[role="link"],
.oferta_kafelek[data-offer-link] {cursor: pointer; user-select: auto;}
.oferta_kafelek:focus-visible {outline: 3px solid var(--primary); outline-offset: 4px;}

.offers_load_more {align-items: center; display: flex; flex-direction: column; gap: 12px; margin: 24px 0 80px 0;}
.offers_count {font-size: 16px; font-weight: 400; color: var(--black); margin-bottom: 16px; width: 100%; text-align: right; display: flex; align-items: center; justify-content: flex-start; gap: 8px;}
.offers_toolbar {display: flex; flex-direction: column; gap: 10px; margin-bottom: 16px;}
.offers_sort_row {display: flex; justify-content: flex-end; align-items: center; gap: 12px; min-height: 30px;}
.offers_curated_toggle {align-items: center; display: inline-flex; flex: 0 0 auto; gap: 8px; width: fit-content;}
.offers_curated_toggle_checkmark {border: 1px solid currentColor; border-radius: 4px; display: inline-block; flex: 0 0 auto; height: 18px; position: relative; width: 18px;}
.offers_curated_toggle_checkmark::after {border: solid currentColor; border-width: 0 2px 2px 0; content: ''; height: 8px; left: 5px; opacity: 0; position: absolute; top: 2px; transform: rotate(45deg); transition: opacity 0.15s ease; width: 4px;}
.offers_curated_toggle[aria-pressed='true'],
.offers_curated_toggle.is-active {background-color: var(--primary-active); box-shadow: inset 0 0 0 2px rgba(255,255,255,0.35);}
.offers_curated_toggle[aria-pressed='true'] .offers_curated_toggle_checkmark::after,
.offers_curated_toggle.is-active .offers_curated_toggle_checkmark::after {opacity: 1;}
.offers_sort_control {display: inline-flex; align-items: center;}
.offers_sort_control select {min-width: 240px; border: 0; border-radius: 0; padding: 0 22px 0 0; background: transparent url("../images/iko-chevron.svg") no-repeat right center; color: var(--black); font-size: 16px; font-weight: 400; text-align: right; appearance: none; -webkit-appearance: none; -moz-appearance: none; cursor: pointer;}
.offers_sort_control select:focus-visible {outline: none; text-decoration: underline;}
.offers_results_feedback {align-items: center; background: var(--primary-surface); border: 1px solid var(--gray-light); border-radius: 16px; display: flex; flex-direction: column; gap: 12px; justify-content: center; min-height: 280px; padding: 24px 20px; text-align: center;}
.offers_results_feedback p {color: var(--black); font-size: 16px; line-height: 150%; margin: 0; max-width: 520px;}
.offers_results_feedback--loading { position: sticky; top: 20px; }
.offers_results_feedback--loading .spinner {margin: 0 auto;}
.offers_results_feedback--error {background: var(--red-light); border-color: var(--red-light-active);}
.offers_results_feedback--error .offers_results_feedback_message {font-weight: 500;}
.offers_results_feedback_retry {margin-top: 4px;}
.offers_end {font-size: 14px; color: var(--gray-dark);}

.oferta_kafelek--skeleton {
	min-height: 230px;
	position: relative;
	overflow: hidden;
	background: var(--gray-light);
	border: 1px solid var(--gray-light);
	box-shadow: 0px 2px 10px 0px var(--black-semi-3);
}

.oferta_kafelek--skeleton::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(90deg, rgba(241,243,246,0) 0%, rgba(255,255,255,0.65) 50%, rgba(241,243,246,0) 100%);
	transform: translateX(-100%);
	animation: skeleton-shimmer 1.1s linear infinite;
}

@keyframes skeleton-shimmer {
	0% {transform: translateX(-100%);}
	100% {transform: translateX(100%);}
}

@media (prefers-reduced-motion: reduce) {
	.oferta_kafelek--skeleton::after {animation: none;}
}
.oferta_kafelek .oferta_zdjecie {border-radius: 0; border-top-left-radius: 16px; border-bottom-left-radius: 16px; }
.oferta_kafelek .oferta_zdjecie_img {width: 100%; height: 100%;}
.oferta_kafelek .oferta_nazwa {grid-area: nazwa; font-size: 12px; padding: 24px 12px 0 24px;}
.oferta_gwiazdki,
.obiekt_nazwa-gwiazdki
{display: inline-flex; flex-wrap: nowrap; gap: 4px; align-items: center; justify-content: flex-start; width: min-content;}
.oferta_kafelek .oferta_nazwa .oferta_gwiazdki {margin-bottom: 8px;}

/* PODSTRONA Z WYBRANA OFERTA */

/* Alternative dates suggestions in variant picker */
.alternative_dates {display: flex; gap: 12px; margin-top: 8px; flex-wrap: wrap;}
.alternative_dates .alt_past, .alternative_dates .alt_future {display: flex; align-items: center; gap: 8px;}
.alternative_dates .date_option {background: transparent; border: 1px solid var(--gray-light); border-radius: 8px; padding: 6px 10px; cursor: pointer; font-size: 14px;}
.alternative_dates .date_option[disabled] {opacity: 0.6; cursor: default;}
.alternative_dates .date_note {font-size: 12px; color: var(--gray-dark); margin-left: 6px;}
.alternative_dates .no_date {color: var(--gray); font-size: 14px;}

.oferta_nazwa .oferta_hotel {font-size: 20px; font-weight: 600; margin: 0; text-align: left;}
.oferta_nazwa img {margin: 0 4px -1px 0;}
.oferta_cena {grid-area: cena; padding: 24px 24px 0 0; text-align: right; font-size: 20px; font-weight: 600; margin: 0;}
.oferta_cena .offer_benefits_summary {font-size: 16px; font-weight: 400; display: block; line-height: 140%; letter-spacing: 0; text-align: right;}
.oferta_poleca {grid-area: poleca; height: 70px; display: flex; align-items: flex-start; justify-content: flex-end; padding: 10px 24px 0 0;}
.oferta_poleca.jacek {justify-content: center; padding: 0;}
.oferta_parametry {grid-area: parametry; font-size: 12px; min-height: 150px; overflow-y: hidden; padding: 0 0 24px 24px; margin-top: 16px; margin-right: 8px;}
.oferta_parametry img {object-fit: none; object-position: center; width: 24px; height: 24px; margin-right: 5px; margin: 0; vertical-align: middle;}
.oferta_parametry p {font-size: 12px; font-weight: normal; padding: 4px 0 4px 28px; margin: 0; vertical-align: middle; position: relative;}
.oferta_parametry p::after {background-position: center; background-repeat: no-repeat; object-fit: fill; content: ''; display: block; width: 24px; height: 24px; position: absolute; left: 0; top: 50%; transform: translateY(-50%);}
.oferta_informacje {grid-area: informacje; min-height: 150px; overflow-y: hidden; padding: 0 0 24px 0; margin-top: 16px;}
.oferta_informacje p {background: url("../images/iko-ptaszek.svg") no-repeat left top 5px; font-size: 12px; font-weight: normal; padding-left: 25px; margin: 0; vertical-align: middle; min-height: 19px;}
.oferta_button {grid-area: button; display: flex; align-items: flex-end; justify-content: center; padding-bottom: 24px;}
.offer_tags {display: flex; flex-wrap: wrap; gap: 8px;}
.offer_tag {border-radius: 4px; font-size: 12px; padding: 2px 8px; display: inline-block;}
.param_tytul {font-size: 20px; font-weight: 600; padding: 0;}
.param_podtytul {font-size: 16px; font-weight: 600; padding: 0;}
.param_osoby::after {background-image: url("../images/iko-osoby.svg");}
.param_termin::after {background-image: url("../images/iko-kal1.svg");}
.param_pobyt::after {background-image: url("../images/iko-kal2.svg");}
.param_dojazd::after {background-image: url("../images/iko-dojazd.svg");}
.param_dojazd_szczegoly::after {background-image: url("../images/iko-skad.svg");}
.param_nocleg::after {background-image: url("../images/iko-nocleg.svg");}
.param_wyzywienie::after {background-image: url("../images/iko-wyzywienie.svg");}
.param_benefits::after {background-image: url("../images/iko-plus.svg");}
.param_stoki::after {background-image: url("../images/iko-stoki.svg");}
.param_gory::after {background-image: url("../images/iko-gory.svg");}

.promotion_ribbon {position: absolute; left: 0; z-index: 4; background: var(--primary-surface); color: var(--black); border-radius: 0 12px 12px 0; box-shadow: 0 10px 22px var(--black-semi-2); display: inline-flex; align-items: center; font-size: 11px; font-weight: 700; letter-spacing: 0.04em; line-height: 1.1; padding: 9px 16px 9px 14px; text-transform: uppercase; pointer-events: none; min-height: 30px; height: 30px; max-height: 30px;}
.promotion_ribbon--promoted {top: 14px; background: linear-gradient(90deg, var(--promotion-ink) 5%, var(--promotion-accent) 95%); background-color: var(--promotion-accent); color: var(--white); }
/* a sharp right arrow end */

.promotion_badge {display: inline-flex; align-items: center; background: linear-gradient(90deg, var(--promotion-ink) 0%, var(--promotion-accent) 100%); border: 0; border-radius: 12px; box-shadow: 0 10px 22px var(--black-semi-2); color: var(--white); font-size: 11px; font-weight: 700; letter-spacing: 0.04em; line-height: 1.1; max-width: 100%; padding: 9px 14px; text-transform: uppercase;}
.promotion_badge--promoted {background: linear-gradient(90deg, var(--promotion-ink) 0%, var(--promotion-accent) 100%); color: var(--white);}
.promotion_badge--details {font-size: 11px; padding: 10px 14px; white-space: nowrap;}
.jacek {background: url("../images/iko-jacek-poleca.svg") no-repeat center center;}

.ps_oferty_szczegoly {
	margin: 0 auto;
	min-width: 320px;
	max-width: 1440px;
	padding: 0;
} /* removed padding-top: 100px; */
.oferta {
	display: grid;
	grid-template-areas:
		"sciezka sciezka"
		"zdjecia sticky"
		"obiekt sticky"
		"szczegoly sticky";
	grid-template-columns: minmax(0, 1fr) clamp(380px, 30.35vw, 437px);
	gap: 0 32px;
	margin: 0 clamp(20px, 4.45vw, 64px) 0 clamp(20px, 4.45vw, 64px);
}
.oferta.oferta--no-gallery {
	grid-template-areas:
		"sciezka sciezka"
		"szczegoly sticky"
		"obiekt sticky";
}
.oferta.oferta--no-gallery .oferta_obiekt {align-self: start;}
.oferta_sticky {
	grid-row-start: 2;
	grid-row-end: 5;
	gap: 0;
}
#oferta_parametry {
	display: flex;
	flex-direction: column;
}
.oferta_parametry-inner {
	display: flex;
	position: sticky;
	top: 100px;
	flex-direction: column;
	flex: 0 1 calc(100vh - 20px);
	max-height: calc(100vh - 20px);
}
.oferta_parametry-spacer {
	flex: 1 0 1px;
}

.oferta a {text-decoration: underline;}

.oferta_sciezka {grid-area: sciezka; margin-bottom: 24px;}
.oferta_sciezka .offer_breadcrumb {font-size: 14px; padding: 0 8px;}
.oferta_sciezka .offer_breadcrumb.empty {font-size: 14px; padding: 0 8px; text-decoration: none;}
.oferta_sciezka .offer_breadcrumb:first-child {padding-left: 0;}
.oferta_sciezka .offer_breadcrumb:last-child {font-weight: 600;}

.oferta_zdjecia {grid-area: zdjecia; min-width: 0;}
.oferta_zdjecia .main-image {border-radius: 16px; box-shadow: 0px 4px 25px 0px var(--shadow-primary); overflow: hidden; position: relative;}
.oferta_zdjecia .slides {display: flex; gap: 16px; transition: transform 0.5s ease; width: 100%;}
.oferta_zdjecia .slides .slide {border-radius: 16px; flex: 0 0 100%; height: clamp(240px, 34vw, 520px); overflow: hidden; position: relative; user-select: none; -webkit-user-drag: none; display: flex; align-items: center; justify-content: center;}
.oferta_zdjecia .slides .slide .oferta_zdjecie_bg {border-radius: 0;}
.oferta_zdjecia .slides .slide .oferta_zdjecie_img {border-radius: 0; position: relative; margin: 0 auto;}
.oferta_zdjecia .nav-btn {align-items: center; background: rgba(0,0,0,0.5); border: none; border-radius: 50%; color: white; cursor: pointer; display: flex; font-size: 22px; height: 40px; justify-content: center; position: absolute; top: 50%; transform: translateY(-50%); transition: background 0.3s; width: 40px; z-index: 10;}
.oferta_zdjecia .nav-btn:hover {background: rgba(0,0,0,0.7);}
.oferta_zdjecia .prev {left: 10px;}
.oferta_zdjecia .next {right: 10px;}
.oferta_zdjecia .thumbnails-wrapper {align-items: center; display: flex; position: relative;}
.oferta_zdjecia .thumbnails {display: flex; gap: 2%; overflow-x: auto; padding: 16px 16px 16px 0px; scroll-behavior: smooth; scrollbar-width: none; -webkit-overflow-scrolling: touch;}
.oferta_zdjecia .thumbnails img {border-radius: 8px; box-shadow: 2px 4px 16px 0px var(--black-semi-2); cursor: pointer; flex-shrink: 0; object-fit: cover; transition: border 0.3s; height: 80px;}
.oferta_zdjecia .thumb-btn {background: rgba(0,0,0,0.4); border: none; border-radius: 50%; color: white; cursor: pointer; flex-shrink: 0; height: 30px; margin: 0 10px; position: absolute; width: 30px;}
.oferta_zdjecia .thumb-prev {left: 0;}
.oferta_zdjecia .thumb-next {right: 0;}
.oferta_zdjecia--no-accommodation {display: flex;}
.oferta_no_accommodation_gallery_note {
	align-items: flex-end;
	background: var(--block-background-color);
	border: 1px solid var(--gray-light);
	border-radius: 16px;
	box-shadow: 0px 4px 25px 0px var(--black-semi-3);
	display: flex;
	min-height: clamp(240px, 34vw, 520px);
	padding: clamp(16px, 2.22vw, 32px);
	width: 100%;
}
.oferta_zdjecia--no-accommodation .oferta_no_accommodation_info {margin: 0; width: 100%;}

.oferta_wlasciwosci {display: flex; flex-wrap: wrap; gap: 0; justify-content: space-between;}
.oferta_wlasciwosci a {color: var(--primary);}

.side-card {background-color: var(--primary-surface); border: 1px solid var(--gray-light); border-radius: 16px; box-shadow: 0px 4px 25px 0px var(--black-semi-3); margin-bottom: 8px; padding: 16px clamp(16px, 2.22vw, 32px); position: relative;}

.oferta_koszty-wrapper {
	flex: 0 0 auto;
	z-index: 2;
}

.oferta_koszty {
	grid-area: koszty;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	justify-content: flex-start;
	gap: 16px;
	/* allow absolutely-positioned spinner overlay inside */
	position: relative;
	overflow: hidden;
}

.oferta_koszty .param_tytul {
	margin: 0;
	text-align: left;
	width: auto;
}

.oferta_koszty #variant_price_values {
	align-self: stretch;
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.oferta_koszty .cena_row {
	align-items: center;
	display: grid;
	grid-template-columns: 1fr 130px;
	gap: 12px;
	width: 100%;
}

.oferta_koszty .cena_row.cena_row--person {
	grid-template-columns: 100px 1fr 90px;
}

.oferta_koszty .cena_row.cena_row--total {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.oferta_koszty .cena_row.cena_row--total .cena_value {
	flex: 1 1 auto;
}

.oferta_koszty .cena_row.participants_note {
	grid-template-columns: 1fr;
	padding: 12px 0;
}

.oferta_koszty .cena_row.participants_note .note_text {
	color: var(--gray);
	font-size: 14px;
	font-style: italic;
	line-height: 140%;
	text-align: center;
	margin: 0;
}

.oferta_koszty .cena_label,
.oferta_koszty .cena_value {
	color: var(--black);
	font-size: 16px;
	font-style: normal;
	font-weight: 400;
	line-height: 140%;
}

.oferta_koszty .cena_value {
	text-align: right;
}

.oferta_koszty .cena_birthdate {
	font-size: 14px;
	text-align: left;
	color: var(--gray);
}

.oferta_koszty .cena_row--total .cena_label,
.oferta_koszty .cena_row--total .cena_value {
	font-size: 20px;
	font-weight: 600;
}

.oferta_koszty .variant_price_status {
	align-self: stretch;
	font-size: 14px;
	line-height: 140%;
}

.oferta_koszty > p:last-of-type {
	width: 100%;
}

.oferta_koszty .button {
	background-color: var(--primary);
	border: none;
	border-radius: 8px;
	color: var(--white);
	cursor: pointer;
	font-size: 16px;
	font-weight: 600;
	line-height: 150%;
	min-height: 38px;
	padding: 10px 12px;
	width: 100%;
}

.oferta_warianty .param_benefits {display: none;}

.oferta_warianty {display: flex; flex-direction: column; gap: 8px; flex: 0 0 auto; z-index: 3;}
.oferta_warianty .param_tytul {margin-bottom: 4px;}
.oferta_warianty .offer_variant_summary {border: 1px solid var(--gray-light); border-width: 1px 0; border-radius: 0; padding: 12px 0; margin: 6px 0; display: grid; grid-template-columns: repeat(2, 1fr);}
.oferta_warianty .offer_variant_summary_wrapper {justify-self: flex-start; text-align: left;}
.oferta_warianty .offer_variant_summary_primary {font-size: 16px; font-weight: 600; margin: 0;}
.oferta_warianty .offer_variant_summary_secondary {color: var(--secondary-text-color); font-size: 14px; margin: 4px 0 0 0;}
.oferta_warianty .offer_variant_choices_open_handle {justify-self: flex-end; font-weight: 600;}
.oferta_warianty .offer_variant_choices_open {width: 100%; justify-content: center;}
.oferta_warianty .offer_variant_summary--static {width: 100%; border: 1px solid var(--gray-light); border-width: 1px 0; border-radius: 0; padding: 12px 0; margin: 6px 0; display: grid; grid-template-columns: 1fr;}
.oferta_warianty .offer_variant_participants_only {display: flex; flex-direction: column; gap: 8px;}
.oferta_warianty .offer_variant_state_controls[hidden] {display: none;}
.oferta_warianty .variant_params_toggle {width: 100%; justify-content: space-between; padding: 4px 0; gap: 8px;}
.oferta_warianty .variant_params_toggle_icon {display: inline-block; flex: 0 0 auto; box-sizing: border-box; position: relative;}
.oferta_warianty .variant_params_toggle_icon::after {content: 'rozwiń'; display: block; position: absolute; top: 50%; right: 0; transform: translateY(-50%); font-size: 14px; color: var(--primary); border: 0; width: 50px; text-align: right;}
.oferta_warianty .variant_params_toggle[aria-expanded="true"] .variant_params_toggle_icon::after {content: 'zwiń';}
.oferta_warianty .variant_params_panel {display: flex; flex-direction: column; gap: 8px;}
.oferta_warianty .variant_params_panel[hidden] {display: none;}
.oferta_warianty .wariant_pole {display: flex; flex-direction: row; gap: 12px; align-items: center;} /* removed width: 348px; */
.oferta_warianty label {display: inline-block; width: 22px; height: 22px; background-repeat: no-repeat; background-position: center; background-size: 22px; margin: 0; padding: 0; flex: 0 0 auto;}
.oferta_warianty label .sr-only {position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;}
.oferta_warianty select, .children_birth.form_field  {border: 1px solid var(--gray-light); border-radius: 8px; padding: 10px 36px 10px 12px; background: var(--primary-surface) url("../images/iko-rozwin-w-dol.svg") no-repeat right 12px center; font-size: 15px; width: 100%; flex: 1 1 100%; min-width: 120px; appearance: none; -moz-appearance: none; -webkit-appearance: none; -ms-progress-appearance: none;}
.oferta_warianty label[for="variant_start"] {background-image: url("../images/iko-kal1.svg");}
.oferta_warianty label[for="variant_length"] {background-image: url("../images/iko-kal2.svg");}
.oferta_warianty label[for="variant_transport"] {background-image: url("../images/iko-dojazd.svg");}
.oferta_warianty label[for="variant_departure_location"] {background-image: url("../images/iko-skad.svg");}
.oferta_warianty label[for="variant_board"] {background-image: url("../images/iko-wyzywienie.svg");}
.oferta_warianty label[for="variant_room"] {background-image: url("../images/iko-nocleg.svg");}
.oferta_warianty select:focus {outline: 2px solid var(--primary); outline-offset: 1px;}
.oferta_warianty .wariant_status {position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; background: rgba(255,255,255,0.86); backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px); border-radius: inherit; color: var(--primary); z-index: 6; pointer-events: auto; text-align: center; padding: 16px; box-sizing: border-box;}
.oferta_warianty .wariant_status:empty {display: none;}
.oferta_warianty .wariant_status.error {color: var(--black);}
.oferta_warianty .wariant_message {margin-top: 8px; color: var(--gray-darker); font-size: 14px;}
.oferta_warianty .wariant_message.error {color: var(--black);}
.spinner {width: 26px; height: 26px; border: 3px solid var(--gray-light); border-top-color: var(--primary); border-radius: 50%; margin: 0; animation: spin 0.8s linear infinite;}

/* Spinner overlay used in price box (reusable template) */
.price_loading[data-role="price-loading"] {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(255,255,255,0.86); /* semi-transparent white backdrop */
	z-index: 12; /* above other variant elements */
	pointer-events: auto; /* block interactions while loading */
	border-radius: inherit; /* match parent rounding visually */
}
@keyframes spin {
	from {transform: rotate(0deg);}
	to {transform: rotate(360deg);}
}

.oferta_warianty label[for="variant_people"] {background-image: url("../images/iko-osoby.svg");}
.oferta_warianty .osoby_wrapper {position: relative;}
.oferta_warianty .osoby_trigger {border: 1px solid var(--gray-light); border-radius: 8px; padding: 10px 38px 10px 12px; background: var(--primary-surface) url("../images/iko-rozwin-w-dol.svg") no-repeat right 12px center; background-size: 14px; font-size: 15px; width: auto; flex: 1 1 auto; text-align: left; cursor: pointer; box-sizing: border-box; font-weight: normal;}
.oferta_warianty .osoby_trigger:focus {outline: 2px solid var(--primary); outline-offset: 1px;}
.oferta_warianty .osoby_popup {background: var(--primary-surface); border: 1px solid var(--gray-light); border-radius: 10px; box-shadow: 0 8px 32px rgba(0, 0, 0, 0.07); bottom: auto; top: 0; margin-top: 0; min-width: clamp(260px, 25vw, 335px); max-width: clamp(260px, 25vw, 335px); padding: 12px; position: absolute; z-index: 10; display: none;}
.oferta_warianty .osoby_popup.open {display: block;}
.oferta_warianty .osoby_row {align-items: center; display: flex; justify-content: space-between; padding: 6px 0;}
.oferta_warianty .osoby_counter {display: flex; align-items: center; gap: 8px;}
.oferta_warianty .osoby_counter button {background: var(--primary-surface); border: 1px solid var(--gray-light); border-radius: 6px; color: var(--primary); cursor: pointer; font-weight: bold; height: 32px; width: 32px;}
.oferta_warianty .osoby_counter button:hover {background: var(--primary-surface-hover);}
.oferta_warianty .osoby_counter button:active {background: var(--primary-surface-active); color: var(--primary-active);}
.oferta_warianty .osoby_value {min-width: 20px; text-align: center; font-weight: 600;}
.oferta_warianty .osoby_birth_title {font-weight: 600; margin-top: 12px; margin-bottom: 8px;}
.oferta_warianty .osoby_births {display: grid; gap: 8px;}
.oferta_warianty .osoby_birth_row {display: flex; gap: 8px; align-items: center;}
.oferta_warianty .osoby_birth_row .osoby_label {min-width: 100px;}
.osoby_error {color: var(--primary); font-size: 13px; margin-top: 8px; min-height: 18px; display: block;}
.osoby_error.visible {color: var(--red-normal);}

.oferta_warianty .osoby_actions {margin-top: 12px;}
.oferta_warianty .osoby_actions .osoby_confirm {width: 100%;}

.offer_variant_choices_modal {display: none; position: fixed; inset: 24px; align-items: center; justify-content: center; z-index: 999;}
.offer_variant_choices_modal.open {display: flex;}
.offer_variant_choices_shell {background: var(--primary-surface); border-radius: 16px; box-shadow: 0 8px 32px rgba(0, 0, 0, 0.18); display: flex; flex-direction: column; max-height: calc(100vh - 48px); width: min(960px, 100%); overflow: hidden;}
.offer_variant_choices_header {align-items: center; border-bottom: 1px solid var(--gray-light); display: flex; gap: 16px; justify-content: space-between; padding: 20px 24px;}
.offer_variant_choices_header h2 {font-size: 28px; font-weight: 700; margin: 0;}
.offer_variant_choices_header .filters_close {display: inline-flex; align-items: center; justify-content: center; font-size: 32px; height: 40px; line-height: 1; padding: 0; width: 40px;}
.offer_variant_choices_toolbar {align-items: center; display: flex; gap: 12px; justify-content: flex-end; padding: 16px 24px 0 24px;}
.offer_variant_choices_toolbar label {color: var(--secondary-text-color); font-size: 14px; margin: 0;}
.offer_variant_choices_toolbar select {border: 1px solid var(--gray-light); border-radius: 8px; min-width: 210px; padding: 10px 36px 10px 12px; background: var(--primary-surface) url("../images/iko-rozwin-w-dol.svg") no-repeat right 12px center; appearance: none;}
.offer_variant_choices_feedback {color: var(--secondary-text-color); font-size: 14px; min-height: 20px; padding: 12px 24px 0 24px;}
.offer_variant_choices_feedback.error {color: var(--black);}
.offer_variant_choices_list {display: flex; flex-direction: column; gap: 8px; overflow: auto; padding: 16px 24px 24px 24px;}
.offer_variant_choices_footer {align-items: center; border-top: 1px solid var(--gray-light); display: flex; gap: 12px; justify-content: flex-end; padding: 16px 24px;}
.offer_variant_choices_row {align-items: start; background: var(--block-background-color); border: 1px solid var(--gray-light); border-radius: 12px; cursor: pointer; display: grid; gap: 16px; grid-template-columns: minmax(0, 1fr) auto; padding: 14px 16px; text-align: left; width: 100%; font-weight: 400;}
.offer_variant_choices_row:hover {border-color: var(--primary-hover);}
.offer_variant_choices_row.is-initial {filter: saturate(1.1); box-shadow: 0 0 5px 2px var(--black-semi-3);}
.offer_variant_choices_row.is-initial:not(.is-selected) {background: var(--primary-surface);}
.offer_variant_choices_row.is-initial .offer_variant_choices_row_dates {color: var(--dark-text-color);}
.offer_variant_choices_row.is-selected {background: var(--primary-surface-hover); border-color: var(--primary); box-shadow: 0 0 0 5px 2px var(--black-semi-3) inset;}
.offer_variant_choices_row_main {display: flex; flex-direction: column; gap: 6px; min-width: 0;}
.offer_variant_choices_row_dates {display: flex; flex-direction: row; flex-wrap: wrap; gap: 6px; align-items: baseline; min-width: 0;}
.offer_variant_choices_row_dates_primary {color: var(--black); font-size: 18px; font-weight: 600; line-height: 1.35;}
.offer_variant_choices_row_dates_secondary {color: var(--secondary-text-color); font-size: 13px; font-weight: 500; line-height: 1.45;}
.offer_variant_choices_row_meta {color: var(--secondary-text-color); font-size: 13px; line-height: 1.45; display: flex; flex-direction: row; flex-wrap: wrap; gap: 4px 16px; justify-content: flex-start; align-items: baseline;}
.offer_variant_choices_row_meta_part {
	word-break: break-word;
	white-space: break-spaces;
}
.offer_variant_choices_row_initial {align-self: flex-start; background: var(--primary-dark); border: 1px solid var(--primary-dark-hover); border-radius: 999px; color: var(--white); display: inline-flex; font-size: 11px; font-weight: 700; letter-spacing: 0.02em; line-height: 1.2; padding: 5px 9px; text-transform: uppercase;}
.offer_variant_choices_row_initial[hidden] {display: none;}
.offer_variant_choices_row_changes {color: var(--secondary-text-color); font-size: 13px; line-height: 1.45; font-weight: 600;}
.offer_variant_choices_row_changes:empty {display: none;}
.offer_variant_choices_row_price {align-self: center; color: var(--black); font-size: 20px; font-weight: 700; line-height: 1.2; text-align: right; white-space: nowrap;}

.oferta_obiekt {grid-area: obiekt; display: grid; grid-template-areas: "obiekt_nazwa obiekt_opinia obiekt_polecenie obiekt_mapa"; align-items: center; justify-content: space-between; margin-top: 48px; gap: 16px;}
.oferta_obiekt .obiekt_nazwa {grid-area: obiekt_nazwa; font-size: 12px; padding-left: 0px; margin-bottom: 24px;}
.oferta_obiekt .obiekt_nazwa .obiekt_nazwa-tekst {margin: 0; padding: 0; margin-top: 8px;}
.oferta_obiekt .obiekt_opinia {grid-area: obiekt_opinia; font-size: 14px; padding: 20px 0;}
.oferta_obiekt .obiekt_opinia span {background-color: var(--green-normal); border-radius: 4px; color: var(--white); padding: 2px 4px;}
.oferta_obiekt .polecenie {grid-area: obiekt_polecenie; min-height: 65px; display: flex; align-items: center; justify-content: center;}
.oferta_obiekt .polecenie.jacek {height: 65px; width: 65px;}
.oferta_obiekt .maps_link {grid-area: obiekt_mapa; text-align: right; height: 100%;}
.oferta_obiekt p {font-size: 32px; font-weight: 600; margin: 0;}
.oferta_obiekt img {margin: 0 4px 2px 0;}

.oferta_toc-anchor {height: 0; pointer-events: none;}
.oferta_toc-wrapper {flex: 0 1 min-content; min-height: 140px; z-index: 1;}
.oferta_toc-wrapper.is-fixed-viewport {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 120;
	margin: 0;
	min-height: unset;
	border-radius: 0;
}
.oferta_toc {display: flex; flex-wrap: wrap; gap: 8px; justify-content: space-between; height:100%; overflow: auto;}
.oferta_toc:empty {display: none;}
.oferta_toc .oferta_toc_tile {text-decoration: none; align-items: center; background: var(--primary-surface); border: 1px solid var(--gray-light); border-radius: 10px; box-sizing: border-box; color: var(--primary); display: block; flex: 1 1 calc(50% - 8px); max-width: 100%; font-size: 13px; font-weight: 500; min-height: 34px; padding: 8px 10px; text-align: center; text-decoration: none; text-wrap: nowrap; overflow: hidden; text-overflow: ellipsis; }
.oferta_toc .oferta_toc_tile_h3 {font-weight: 700; flex: 1 1 100%; max-width: 100%;}
.oferta_toc .oferta_toc_tile:hover {background: var(--primary-surface-hover); border-color: var(--primary-hover);}
.oferta_toc .oferta_toc_tile:active {background: var(--primary-surface-active); border-color: var(--primary-active);}
.oferta_toc .oferta_toc_tile:focus-visible {outline: 2px solid var(--primary-hover); outline-offset: 2px;}
.oferta_toc .oferta_toc_tile.active,
.oferta_toc .oferta_toc_tile[aria-current="location"] {background: var(--primary); border-color: var(--primary); color: var(--white);}

.oferta_koszty_placeholder {height: 0; pointer-events: none;}

.oferta_toc.sticky {flex-wrap: nowrap; justify-content: flex-start; overflow-x: auto; -webkit-overflow-scrolling: touch; max-width: 100%;}
.oferta_toc.sticky .oferta_toc_tile {flex: 0 0 auto; white-space: nowrap;}

.oferta_szczegoly h3[id],
.oferta_szczegoly h4[id] {scroll-margin-top: var(--offer-toc-offset);}

.wybrane_udogodnienia>div {display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px 24px;}
.wybrane_udogodnienia>div>div>img {vertical-align: middle;}
.wybrane_udogodnienia>p:last-of-type {margin: 32px 0;}
.wybrane_udogodnienia>button {background-color: var(--primary-surface); border: 1px solid var(--primary); border-radius: 8px; color: var(--primary); cursor: pointer; font-weight: 600; padding: 7px 12px}

.oferta_szczegoly {grid-area: szczegoly;}
.oferta_szczegoly>div:nth-of-type(n+3) {border-top: 1px solid var(--gray-light);}
.oferta_szczegoly>div>p:first-of-type {font-size: 20px; font-weight: 600; margin: 32px 0; padding: 0;}

.ps_oferty_szczegoly h1 {
	margin: 24px 0 8px 0;
	padding: 0;
}
.ps_oferty_szczegoly h2 {
	margin: 16px 0 8px 0;
	padding: 0;
}
.ps_oferty_szczegoly h3 {
	margin: 24px 0 8px 0;
	padding: 0;
}
.ps_oferty_szczegoly h4:not(:first-of-type),
.ps_oferty_szczegoly h5:not(:first-of-type),
.ps_oferty_szczegoly h6:not(:first-of-type) {
	margin: 12px 0 6px 0;
	padding: 0;
}

.o_obiekcie-description_wrapper {margin-bottom: 24px;}
.oferta_no_accommodation_info {
	background: var(--block-background-color);
	border: 1px solid var(--gray-light);
	border-radius: 12px;
	padding: 12px 14px;
	margin-top: 8px;
}

.o_obiekcie-information>div {margin: 0; padding: 0;}
.tekst_kol2 {column-count: 2; column-gap: 10px;}

.o_osrodku {margin-bottom: 32px;}
.o_osrodku>div {display: grid; grid-template-areas: "osrodek_nazwa osrodek_nazwa" "osrodek_info osrodek_mapa"; grid-template-columns: 1fr 319px; gap: 16px 32px;}
.o_osrodku>div p {font-size: clamp(13px, 4.06vw, 16px); margin: 0 0 16px 0;}
.o_osrodku>div>p {grid-area: osrodek_nazwa; font-weight: 600; margin: 0;}
.o_osrodku>div>img {grid-area: osrodek_mapa; border-radius: 8px; object-fit: cover; object-position: center; width: 100%;}
.o_osrodku>div>div {grid-area: osrodek_info; border: 1px solid var(--gray-light); border-radius: 16px; padding: 24px 32px 8px 32px;}
.o_osrodku>div>div>div {display: flex; justify-content: space-between;}
.o_osrodku>div>div>div>p>img {margin-right: 3px; vertical-align: middle;}
.o_osrodku>div>div>div>p:nth-of-type(even) {text-align: right;}

.o_regionie {padding-bottom: 32px;}
.o_regionie p {font-weight: 600;}
.o_regionie img {border-radius: 8px; box-shadow: 0px 4px 25px 0px var(--black-semi-2); height: 192px; object-fit: cover; object-position: center; width: 100%;}

.praktyczne_informacje>div>p {margin: 16px 0 8px 0;}
.praktyczne_informacje>div>p:first-of-type {margin-top: 0;}
.praktyczne_informacje img {margin-right: 3px; vertical-align: middle;}

#bar_cena {display: none;}

/* REZERWACJA */

.ps_rezerwacja {
	margin: 0 auto;
	min-width: 320px;
	max-width: 1440px;
}
.ps_rezerwacja>div {
	display: grid;
	grid-template-areas:
		"tytul tytul"
		"oferta formularz";
	grid-template-columns: 437px 1fr;
	gap: 48px;
	padding: clamp(20px, 4.44vw, 64px);
} /* removed padding-top: calc(100px + clamp(20px, 4.44vw, 64px)); */
.ps_rezerwacja>div>h1 {grid-area: tytul; font-size: 32px; font-weight: bold; text-align: center;}
.ps_rezerwacja>div>section {grid-area: oferta; display: flex; flex-direction: column; gap: 16px; border: 1px solid var(--gray-light); border-radius: 16px; box-shadow: 0px 4px 25px 0px var(--black-semi-2); padding: clamp(16px, 2.22vw, 32px);}
.ps_rezerwacja #reservation_submit, .ps_rezerwacja #inquiry_submit {width: 100%;}

.rezerwacja_szczegoly {--horizontal-flex-gap: 64px; --vertical-flex-gap: 16px}
.rezerwacja_szczegoly {display: flex; gap: var(--vertical-flex-gap); flex-wrap: wrap; justify-content: space-between;}
.rezerwacja_szczegoly.horizontal {flex-direction: row; gap: var(--horizontal-flex-gap);}
.rezerwacja_szczegoly.horizontal .rezerwacja_obiekt {flex: 1 0 calc(50% - var(--horizontal-flex-gap) / 2); min-width: 245px;}
.rezerwacja_szczegoly .rezerwacja_obiekt {font-size: 12px; flex: 1 0 100%; display: flex; flex-direction: column; flex-wrap: wrap;}
.rezerwacja_szczegoly .rezerwacja_obiekt .oferta_zdjecie {border-radius: 16px;}
.rezerwacja_szczegoly .rezerwacja_obiekt .oferta_header {display: flex; flex-direction: row; flex-wrap: wrap; align-items: flex-start; margin-top: 16px; text-align: center; gap: 8px;}
.rezerwacja_szczegoly .rezerwacja_obiekt .oferta_header .oferta_nazwa {flex: 1 0 auto; display: flex; flex-direction: column; align-items: flex-start; text-align: center; max-width: 100%;}
.rezerwacja_szczegoly .rezerwacja_obiekt .oferta_header .button.oferta_edit {flex: 1 0 0;}
.rezerwacja_szczegoly .rezerwacja_obiekt .oferta_header>img {box-shadow: 0px 4px 25px 0px var(--black-semi-2); border-radius: 16px; margin-bottom: 16px; object-fit: cover; object-position: center; width: 100%;}
.rezerwacja_szczegoly .rezerwacja_obiekt .oferta_header>p {font-size: 20px; font-weight: 600; margin: 0;}
.rezerwacja_szczegoly .rezerwacja_obiekt .oferta_header>p>img {margin: 0 4px 2px 0;}
.rezerwacja_szczegoly .rezerwacja_obiekt .stars_container {display: inline-block;}
.rezerwacja_szczegoly.horizontal .rezerwacja_parametry {flex: 1 0 calc(50% - var(--horizontal-flex-gap) / 2); min-width: 245px;}
.rezerwacja_szczegoly .rezerwacja_parametry {flex: 1 0 100%;}
.rezerwacja_szczegoly .rezerwacja_parametry .edytuj {display: none;}
.rezerwacja_szczegoly .rezerwacja_parametry>p {margin: 15px 0 0 0; padding: 0 0 0 28px; position: relative; font-size: 16px; font-weight: normal;}
.rezerwacja_szczegoly .rezerwacja_parametry>p::after {content: ''; width: 22px ; height: 22px; display: block; position: absolute; left: 0; top: 50%; transform: translateY(-50%); background-size: 22px; background-position: center; background-repeat: no-repeat;}
.rezerwacja_szczegoly .rezerwacja_parametry>div {display: flex; gap: 8px; justify-content: space-between;}
.rezerwacja_szczegoly .rezerwacja_parametry>div>p {font-size: 24px; font-weight: 600; margin: 16px 0 0 0; flex: 1 0 0; line-break: auto; white-space: break-spaces;}
.rezerwacja_szczegoly .rezerwacja_parametry>div>p:last-child {text-align: right; white-space: nowrap;}

.ps_rezerwacja .edytuj a {color: var(--primary); float: right; font-size: 16px; font-weight: normal; text-decoration: underline;}
.ps_rezerwacja>div>form {grid-area: formularz;}
.ps_rezerwacja>div>form input, .ps_rezerwacja>div>form select {border: 1px solid var(--gray-light); border-radius: 12px; box-sizing: border-box; height: 50px; padding: 0 12px; margin-top: 8px; width: 100%; appearance: none; -webkit-appearance: none; -moz-appearance: none;}
.ps_rezerwacja>div>form select {background: url("../images/iko-strzalka-dol2.svg") no-repeat right 10px center;}
.ps_rezerwacja>div>form>p {margin: 32px 0 0 0; text-align: justify;}
.ps_rezerwacja .pola1 {display: flex; flex-wrap: wrap; justify-content: space-between; margin: 32px 0 0 0;}
.ps_rezerwacja .pola1>div {margin-bottom: 24px; width: 49%;}
.ps_rezerwacja .pola1>div:nth-last-of-type(2) {position: relative; width: 15%;}
.ps_rezerwacja .pola1>div:last-of-type {width: 32%;}
.ps_rezerwacja .pola2 {display: flex; gap: 2%; justify-content: space-between;}
.ps_rezerwacja .pola2>div {margin-bottom: 24px; width: 50%;}
.ps_rezerwacja .pola2>div:last-of-type {max-height: 0; opacity: 0;transition: max-height 0.3s ease, opacity 0.3s ease;}
.ps_rezerwacja .pola2>div:last-of-type.show {max-height: 90px; opacity: 1;}
.ps_rezerwacja .rezerwuj_button {background-color: var(--primary); border: none; border-radius: 8px; color: var(--white); cursor: pointer; font-weight: 600; padding: 7px; width: 200px;}
.ps_rezerwacja .rezerwuj_button:disabled {opacity: 0.75; cursor: not-allowed;}
.ps_rezerwacja .rezerwuj_button.loading {cursor: progress;}
.ps_rezerwacja .rezerwacja_notice {margin-bottom: 16px; padding: 12px 14px; border-radius: 12px; border: 1px solid var(--gray-light); background: var(--block-background-color); color: #0f172a; font-weight: 600;}
.ps_rezerwacja .rezerwacja_notice.changed {border-color: var(--red-light-active); background: var(--reddish-white); color: var(--red-normal-hover);}
.ps_rezerwacja .rezerwacja_notice.error {border-color: var(--red-normal); background: var(--reddish-white); color: var(--red-normal);}

.ps_rezerwacja .reservation_form_fields_group {margin-bottom: 16px; padding: 12px 14px;}
.ps_rezerwacja .reservation_form_fields_group .reservation_form_fields_group-header {display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 0 8px;}
.ps_rezerwacja .reservation_form_fields_group .fields_group {display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px;}

.ps_podziekowania>div {grid-template-areas: "tytul" "oferta"; grid-template-columns: 1fr;}
.ps_podziekowania>div>h1 {text-align: left;}
.ps_podziekowania>div>section {grid-template-areas: "zdjecie parametry"; grid-template-columns: clamp(347px, 46.7vw, 560px) 1fr; gap: 20px;}
.ps_podziekowania>div>section>div>img {max-height: 206px;}
.ps_podziekowania .uwaga>p {color: var(--red-light-active); font-weight: 600;}
.ps_podziekowania .ubezpieczenia {background: url("../images/ubezpieczenia-tlo.jpg") no-repeat center 30%; background-size: cover; border-radius: 16px; box-sizing: border-box; display: block; font-size: 20px; font-weight: 600; min-height: 262px; object-fit: cover; object-position: center; margin: 0 clamp(20px, 4.44vw, 64px) clamp(20px, 4.44vw, 64px) clamp(20px, 4.44vw, 64px); padding: 32px; position: relative;}
.ps_podziekowania .ubezpieczenia>img {bottom: 0; height: 232px; margin-right: clamp(8px, 7.6vw, 100px); position: absolute; right: 0;}
.ps_podziekowania .ubezpieczenia>p {margin: 0; padding-top: 4%; width: clamp(50%, 50vw, 70%);}
.ps_podziekowania .ubezpieczenia>.button {margin-top: 24px; width: 220px;}

/* KOMPONENTY */

.wyszukiwarka {
  display: grid;
  grid-template-columns: 1fr;
  padding: 10px;
  margin: 0 auto;
  min-width: 320px;
  max-width: min(100vw, 1440px);
  padding: 0;
}
.wyszukiwarka .wyszukiwarka_pola {float: left; list-style-type: none; padding: 0; margin: 0; flex: 1 1 auto; display: flex; flex-wrap: nowrap; max-width: 100%; gap: clamp(12px, 1%, 16px); justify-content: space-between;}
.wyszukiwarka_tytul {color: var(--white); font-size: clamp(24px, 4vw, 56px); font-weight: bold; padding: clamp(0px, 13vw, 80px) clamp(0px, 18vw, 255px) 32px clamp(0px, 18vw, 255px); text-align: center;}

.hero .wyszukiwarka_formularz {gap: 20px; padding: 0 0 clamp(0px, 13vw, 180px) 0; max-width: min(100%, 100vw);}

.wyszukiwarka_formularz form {border-radius: 10px; display: flex; margin: 0 auto; padding: 10px; margin: clamp(10px, 5.53vw, 20px) clamp(20px, 5.53vw, 64px); min-width: 250px; gap: clamp(12px, 2%, 16px);} 
.wyszukiwarka_formularz.lato form {background-color: color-mix(in srgb, var(--primary-surface) 70%, transparent);}
.wyszukiwarka_formularz:not(.lato) form {background-color: var(--primary-surface);}
.wyszukiwarka_formularz .wyszukiwarka_pole_label {font-size: 10px; font-weight: bold; text-transform: uppercase;}

.wyszukiwarka_formularz .form_field {flex: 0 0 auto; cursor: pointer; border: 1px solid var(--gray-light); border-radius: 8px; padding: 7px 10px 6px 35px; appearance: none; -webkit-appearance: none; -moz-appearance: none; font: inherit; background-color: var(--primary-surface); height: 40px; text-align: left; position: relative;}
.wyszukiwarka_formularz .form_field_wrapper {position: relative; margin: 0;}
.wyszukiwarka_formularz .form_field + .icon {background-repeat: no-repeat; background-position: center; position: absolute; background-size: 20px; width: 20px; height: 20px; top: 50%; left: 10px; transform: translateY(-50%);}

.wyszukiwarka_formularz .form_field.gory {width: 220px }
.wyszukiwarka_formularz .form_field.gory .dropdown_multiselect_value {width: calc(100% - 10px); }
.wyszukiwarka_formularz .form_field.gory + .icon {background-image: url('../images/iko-gory.svg')}

.wyszukiwarka_formularz .form_field.wyjazd {width: 220px }
.wyszukiwarka_formularz .form_field.wyjazd .dropdown_multiselect_value {width: calc(100% - 10px); }
.wyszukiwarka_formularz .form_field.wyjazd + .icon {background-image: url('../images/iko-paper-plane.svg'); background-size: 16px; }

.wyszukiwarka_formularz .form_field.kal1 {width: 210px}
.wyszukiwarka_formularz .form_field.kal1 + .icon {background-image: url('../images/iko-kal1.svg');}

.wyszukiwarka_formularz .form_field.kal2 {width: 120px;}
.wyszukiwarka_formularz .form_field.kal2 + .icon {background-image: url('../images/iko-kal2.svg');}

.wyszukiwarka_formularz .form_field.osoby_trigger {width: 90px;}
.wyszukiwarka_formularz .form_field.osoby_trigger + .icon {background-image: url('../images/iko-osoby.svg');}

.wyszukiwarka_formularz .form_field.dojazd {width: 140px;}
.wyszukiwarka_formularz .form_field.dojazd + .icon {background-image: url('../images/iko-dojazd.svg');}

.wyszukiwarka_formularz .form_field.search {width: 180px;}
.wyszukiwarka_formularz .form_field.search + .icon {background-image: url('../images/iko-nocleg.svg');}
.wyszukiwarka_formularz .search_text_field_wrapper > .icon {top: 20px;}
.wyszukiwarka_formularz .form_field.input_error {border-color: #c00; box-shadow: 0 0 0 1px rgba(204, 0, 0, 0.12);}
.wyszukiwarka_formularz .field_error.search_text_error {color: #c00; display: block; font-size: 12px; line-height: 1.35; margin-top: 6px; max-width: 100%; width: 100%;}
.wyszukiwarka_formularz .field_error.search_text_error.hidden {display: none;}

.wyszukiwarka_formularz .search_suggestions_popup {
	left: 0;
	right: auto;
	min-width: 280px;
	width: 100%;
	max-width: min(420px, 100vw - 24px);
	max-height: 320px;
	padding: 6px;
}

.wyszukiwarka_formularz .search_suggestions_section + .search_suggestions_section {
	border-top: 1px solid var(--gray-light);
	margin-top: 4px;
	padding-top: 4px;
}

.wyszukiwarka_formularz .search_suggestions_heading {
	color: var(--gray);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.04em;
	padding: 6px 8px;
	text-transform: uppercase;
}

.wyszukiwarka_formularz .search_suggestions_item {
	background: transparent;
	border: 0;
	border-radius: 8px;
	cursor: pointer;
	display: block;
	padding: 8px;
	text-align: left;
	width: 100%;
}

.wyszukiwarka_formularz .search_suggestions_item:hover,
.wyszukiwarka_formularz .search_suggestions_item.active {
	background: var(--primary-surface);
}

.wyszukiwarka_formularz .stay_length_suggestions_item:hover {
	background: var(--primary-surface-hover);
}

.wyszukiwarka_formularz .search_suggestions_name {
	color: var(--black);
	display: block;
	font-size: 14px;
	font-weight: 500;
	line-height: 1.25;
}

.wyszukiwarka_formularz .search_suggestions_subtitle {
	color: var(--gray);
	display: block;
	font-size: 12px;
	line-height: 1.2;
	margin-top: 2px;
}

.wyszukiwarka_formularz .search_suggestions_status {
	color: var(--gray);
	font-size: 13px;
	padding: 10px 8px;
}

.wyszukiwarka_formularz .form_field_wrapper .clear_date_btn,
.wyszukiwarka_formularz .form_field_wrapper .clear_destination_btn {
	position: absolute;
	right: 2px;
	top: 50%;
	transform: translateY(-50%);
	padding: 0 4px;
	z-index: 10;
	background-color: transparent;
}

.wyszukiwarka_formularz .dropdown_multiselect_wrapper {position: relative;}
.wyszukiwarka_formularz .dropdown_multiselect_trigger {display: flex; align-items: center; width: 100%;}
.wyszukiwarka_formularz .dropdown_multiselect_trigger--input {cursor: text; padding-right: 30px;}
.wyszukiwarka_formularz .dropdown_multiselect_value {display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; width: 100%;}

.wyszukiwarka_formularz .dropdown_multiselect_popup {background: var(--primary-surface); border: 1px solid var(--gray-light); border-radius: 10px; box-shadow: 0 8px 32px rgba(0, 0, 0, 0.07); left: 0; margin-top: 8px; min-width: 280px; max-height: 290px; overflow: auto; padding: 8px; position: absolute; z-index: 999;}
.wyszukiwarka_formularz .dropdown_multiselect_popup.open {display: block;}
.wyszukiwarka_formularz .dropdown_multiselect_item {border-radius: 8px; padding: 6px 8px;}
.wyszukiwarka_formularz .dropdown_multiselect_item:hover {background: var(--primary-surface-hover);}
.wyszukiwarka_formularz .dropdown_multiselect_item--indent {padding-left: 18px;}
.wyszukiwarka_formularz .dropdown_multiselect_popup .custom-checkbox {align-items: center; gap: 8px; line-height: 1.35;}
.wyszukiwarka_formularz .dropdown_multiselect_popup .custom-checkbox > div:last-child {overflow: hidden; text-overflow: ellipsis; white-space: nowrap;}

.wyszukiwarka_formularz .transport_select_popup {left: auto; right: 0; min-width: 320px; max-width: min(420px, 100vw - 24px);}
.wyszukiwarka_formularz .transport_select_section + .transport_select_section {margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--gray-light);}
.wyszukiwarka_formularz .transport_select_section_header {display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 6px;}
.wyszukiwarka_formularz .transport_select_departure_note {padding: 8px 10px; border-radius: 8px; color: var(--disabled-text-color);}

.wyszukiwarka_formularz .osoby_wrapper {position: relative;}
.wyszukiwarka_formularz .osoby_popup {background: var(--primary-surface); border: 1px solid var(--gray-light); border-radius: 10px; box-shadow: 0 8px 32px rgba(0, 0, 0, 0.07); right: 0; margin-top: 8px; min-width: 300px; max-width: 100vw; padding: 12px; position: absolute; z-index: 5;}
.wyszukiwarka_formularz .osoby_popup.open {display: block;}
.wyszukiwarka_formularz .osoby_row {align-items: center; display: flex; justify-content: space-between; padding: 6px 0;}
.wyszukiwarka_formularz .osoby_counter {display: flex; align-items: center; gap: 8px;}
.wyszukiwarka_formularz .osoby_counter button {background: var(--primary-surface); border: 1px solid var(--gray-light); border-radius: 6px; color: var(--primary); cursor: pointer; font-weight: bold; height: 32px; width: 32px;}
.wyszukiwarka_formularz .osoby_counter button:hover {background: var(--primary-surface-hover);}
.wyszukiwarka_formularz .osoby_counter button:active {background: var(--primary-surface-active); color: var(--primary-active);}
.wyszukiwarka_formularz .osoby_value {min-width: 20px; text-align: center; font-weight: 600;}

.wyszukiwarka_formularz .button.search {margin: 12px auto 0; flex: 1 0 auto;}

.wyszukiwarka_formularz .osoby_birth_title {font-weight: 600; margin-top: 12px; margin-bottom: 8px;}
.wyszukiwarka_formularz .osoby_births {display: grid; gap: 8px;}
.wyszukiwarka_formularz .osoby_birth_row {display: flex; gap: 8px; align-items: center;}
.wyszukiwarka_formularz .osoby_birth_row .osoby_label {min-width: 80px;}
.wyszukiwarka_formularz .children_birth.form_field {flex: 1; padding: 8px;}

.wyszukiwarka_formularz .osoby_actions {margin-top: 12px;}
.wyszukiwarka_formularz .osoby_actions .osoby_confirm {width: 100%;}

.faq {
  display: grid;
  grid-template-areas: "faq pytania";
  grid-template-columns: clamp(200px, 35.4vw, 510px) 1fr;
  margin: 0 auto;
  min-width: 320px;
  max-width: 1440px;
}
.faq h1 {grid-area: faq;}
.pytania {grid-area: pytania;}
.pytanie {background: url('../images/iko-plus.svg') right clamp(16px, 1.66vw, 24px) center no-repeat; box-shadow: 14px -27px 60px 0px var(--primary); color: var(--dark-text-color); margin: 0 clamp(20px, 5.53vw, 80px) 0 0; padding: clamp(16px, 1.66vw, 24px) 48px clamp(16px, 1.66vw, 24px) clamp(16px, 1.66vw, 24px);}

/*********************************/

.scrollBox {display: grid;}
.scroller {
	display: flex;
	overflow-x: auto;
	padding: clamp(20px, 5.53vw, 80px) 0 clamp(32px, 3.35vw, 48px) clamp(20px, 5.53vw, 80px);
	scrollbar-width: none;
	scroll-behavior: smooth;
	-webkit-overflow-scrolling: touch;
}
.scroller::-webkit-scrollbar {display: none;}

a.oferta_promo {margin-right: clamp(16px, 2.22vw, 32px); position: relative; transition: transform 0.4s ease;}
a.oferta_promo:hover {transform: scale(1.05);}
a.oferta_promo > img {border-radius: 16px; box-shadow: 0px 4px 25px rgb(0 0 0 / 15%); display: block; width: clamp(260px, 22.71vw, 327px);}
a.oferta_promo > div {margin-top: 10px;}
a.oferta_promo > div > p {font-size: clamp(14px, 1.6vw, 18px);}
a.oferta_promo > div > p > img {width: clamp(12px, 1.3vw, 16px);}
a.oferta_promo > div > p:nth-of-type(2) {margin-bottom: 8px;}
a.oferta_promo > div > p:nth-of-type(2), a.oferta_promo > div > p:nth-of-type(4) {font-size: clamp(16px, 1.6vw, 20px); font-weight: 600;}
a.oferta_promo > div > p:nth-of-type(3) {color: var(--gray-dark); font-size: clamp(14px, 1.6vw, 16px);}

a.kafelek {margin-right: clamp(16px, 2.22vw, 32px); position: relative; transition: transform 0.4s ease;}
a.kafelek:hover {transform: scale(1.05);}
a.kafelek img {border-radius: 16px; box-shadow: 0px 4px 25px rgb(0 0 0 / 15%); display: block; width: clamp(260px, 22.71vw, 327px);}
a.kafelek div {background: linear-gradient(180deg, transparent 0%, var(--primary-active-semi-2) 100%); border-bottom-left-radius: 16px; border-bottom-right-radius: 16px; bottom: 0; color: var(--white); font-size: clamp(24px, 2.23vw, 32px); font-weight: 600; left: 0; padding: 125px 25px 15px 25px; position: absolute; right: 0; text-transform: uppercase;}
.typy_wyjazdow .scroller div {background: linear-gradient(180deg, transparent 0%, var(--primary) 100%); padding-bottom: 25px;}
a.kafelek p {line-height: 120%; margin: 0;}
a.kafelek p:nth-of-type(n+2) {text-transform: none;}
a.kafelek p:nth-of-type(3) {font-size: clamp(16px, 1.6vw, 24px);}
.ukladanka {
	display: grid;
	grid-template-columns: repeat(auto-fit, 295px);
	justify-content: space-between;
	column-gap: 32px;
	row-gap: 64px;
	padding: clamp(20px, 5.53vw, 80px) clamp(20px, 5.53vw, 80px) clamp(32px, 3.35vw, 48px) clamp(20px, 5.53vw, 80px);
}
a.kraj {margin: 0; position: relative; transition: transform 0.4s ease;}
a.kraj:hover {transform: scale(1.05);}
a.kraj img {border-radius: 16px; box-shadow: 0px 4px 25px rgb(0 0 0 / 15%); height: 365px; width: 296px; object-fit: cover; object-position: center;}
a.kraj div {margin-top: 10px; width: 296px;}
a.kraj p {float: left; font-size: 18px; margin: 0;}
a.kraj p:nth-of-type(1) {font-weight: 600;}
a.kraj p:nth-of-type(2) {float: right; font-weight: 600;}
a.kraj p:nth-of-type(3) {font-size: 14px; width: 100%;}
.opinia {border: 1px solid var(--gray-light); border-radius: 12px; box-shadow: 0px 6px 24px 0px var(--black-semi-3); margin-right: clamp(16px, 2.22vw, 32px); padding: 32px 32px 28px 32px; min-width: clamp(220px, 67vw, 500px);}
.opinia img, .filter_group img {margin-right: 4px;}
.opinia p:nth-of-type(1) {color: var(--dark-text-color); font-size: 18px; font-style: italic;}
.opinia p:nth-of-type(2) {font-weight: 600; margin: 0;}
.scroller_controls {padding-right: clamp(20px, 5.53vw, 80px);}
.scroller_controls img {cursor: pointer; float: right; margin-left: 16px;}
.scroller_controls .przesun_w_lewo img {transform: rotate(180deg);}

.overlay {display: none; z-index: 998}

@media (max-width: 1399px) {
	.oferty_lista {
	  grid-template-areas:
		"filtry"
		"lista";
	  grid-template-columns: 1fr;
	  gap: 0;
	}
	.oferty_lista div.filtry {background-color: var(--primary-surface); border-radius: 16px; display: none; height: 100%; left: 0; overflow: overlay; padding: 16px; position: fixed; scrollbar-width: none; top: 0; width: 100%; max-width: 360px; min-width: 320px; z-index: 999}
	.oferty_naglowek button {display: block;}
	#filtry {padding-top: 0;}
	.filtry .filters-main_actions_wrapper {padding-top: 16px; padding-bottom: 16px;}
	.filtry .filters_submit {top: 0px; left: 0px; flex: 1 1 auto;}
	.filtry .filters_close {top: 0px; right: 0px; display: inline-flex; flex: 0 1 auto;}
	.offers_sort_row {justify-content: space-between;}
}

@media (max-width: 1199px) {
	:root {
		--offer-toc-offset: 280px;
	}
	.oferta {
		grid-template-areas:
			"sciezka"
			"zdjecia"
			"sticky"
			"obiekt"
			"szczegoly";
		grid-template-columns: 100%;
		gap: 0;
	}
	.oferta.oferta--no-gallery {
		grid-template-areas:
			"sciezka"
			"zdjecia"
			"sticky"
			"obiekt"
			"szczegoly";
	}
	.oferta_sticky {
		margin-top: 16px;
		grid-row-start: 3;
		grid-row-end: 4;
	}
	.oferta_parametry-inner {
		gap: 16px;
		position: relative;
		top: auto;
		flex: 0 1 1px;
	}
	.oferta_warianty .osoby_popup {
		min-width: clamp(260px, 75vw, 335px);
		max-width: clamp(260px, 75vw, 335px);
	}
	.oferta_toc-wrapper {
		min-height: unset;
		flex: 0 1 1px;
		position: static;
		top: auto;
	}
	.oferta_toc {
		flex-direction: row;
		flex-wrap: nowrap;
		overflow-x: auto;
		padding-bottom: 8px; /* for scrollbar */
		align-items: center;
		justify-content: flex-start;
		gap: 16px;
	}
	.oferta_toc .oferta_toc_tile {
		flex: 1 0 fit-content;
		max-width: 200px;
		padding: 8px 16px;
	}

	#bar_cena {
		background-color: var(--primary-surface);
		border-top: 1px solid var(--gray-light);
		box-shadow: 0px 4px 25px 0px var(--black-semi-2);
		bottom: 0;
		display: flex;
		justify-content: space-between;
		left: 0;
		min-width: 288px;
		padding: 20px 16px;
		pointer-events: none;
		position: fixed;
		right: 0;
		transform: translateY(100%);
		transition: transform 0.4s ease;
	}
	#bar_cena div {font-weight: 600;}
	#bar_cena span {font-size: 24px;}
	#bar_cena button {background-color: var(--primary); border: none; border-radius: 8px; color: var(--white); cursor: pointer; font-size: 20px; font-weight: 600; padding: 7px; width: 50%;}
	#bar_cena.visible {transform: translateY(0); pointer-events: auto;}

	.ps_rezerwacja>div {grid-template-areas: "tytul" "oferta" "formularz"; grid-template-columns: 1fr; gap: 48px;}
	.ps_rezerwacja>div>section {grid-template-areas: "zdjecie parametry"; grid-template-columns: clamp(347px, 46.7vw, 560px) 1fr; gap: 20px;}
	.rezerwacja_obiekt>img {max-height: 206px;}
	.rezerwacja_obiekt .edytuj {display: none;}
	.rezerwacja_parametry>p:nth-of-type(-n+1) {margin-top: 0;}
	.rezerwacja_parametry .edytuj {display: block;}
}

@media (max-width: 767px) {
	.offers_sort_row {justify-content: flex-start;}
	.offers_sort_control select {min-width: 0; width: 100%; text-align: left;}
	.offer_variant_choices_modal {inset: 0;}
	.offer_variant_choices_shell {border-radius: 0; height: 100vh; max-height: 100vh; width: 100%;}
	.offer_variant_choices_header {padding: 16px;}
	.offer_variant_choices_header h2 {font-size: 24px;}
	.offer_variant_choices_toolbar {align-items: stretch; flex-direction: column; padding: 12px 16px 0 16px;}
	.offer_variant_choices_toolbar select {min-width: 0; width: 100%;}
	.offer_variant_choices_feedback {padding: 12px 16px 0 16px;}
	.offer_variant_choices_list {padding: 12px 16px 16px 16px;}
	.offer_variant_choices_footer {padding: 16px;}
	.offer_variant_choices_row {gap: 12px; padding: 12px 14px;}
	.offer_variant_choices_row_dates_primary {font-size: 16px;}
	.offer_variant_choices_row_dates_secondary,
	.offer_variant_choices_row_meta,
	.offer_variant_choices_row_changes {font-size: 12px;}
	.offer_variant_choices_row_price {font-size: 18px; white-space: normal;}
}

@media (max-width: 1000px) {
	.hero .wyszukiwarka {gap: 0; padding: 0;}
	.hero .wyszukiwarka li {float: none;}
	.hero + .wyszukiwarka .wyszukiwarka_pola {justify-content: space-around;}
	.hero .wyszukiwarka_formularz {padding: 55px 0;}
	.hero .wyszukiwarka_formularz:not(.wyszukiwarka_formularz--small) .form_field {width: 100%;}
/*	.hero .wyszukiwarka_formularz .form_field,
		.hero + .wyszukiwarka .wyszukiwarka_formularz .form_field:not(.children_birth) {margin: 0; width: 100%;} */
	.hero .wyszukiwarka_formularz button.search,
	.hero + .wyszukiwarka .wyszukiwarka_formularz button.search {/* background-position: 60px center; margin: 16px 0 0 4px; */ width: 240px;}
	.wyszukiwarka .wyszukiwarka_pola {display: grid; justify-content: normal;}
	.wyszukiwarka .wyszukiwarka_pola li {width: 100%;}
	.oferta_kafelek .oferta_zdjecie {border-bottom-left-radius: 0; border-bottom-right-radius: 0; border-top-left-radius: 16px; border-top-right-radius: 16px; height: clamp(200px, 10vw, 276px);}
	.oferta_kafelek .oferta_parametry {margin-top: 16px;}
	.oferta_kafelek .oferta_informacje {margin-top: 16px;}
	.wyszukiwarka_formularz form {flex-direction: column;}
	.wyszukiwarka_formularz:not(.wyszukiwarka_formularz_podstrona) form {margin-left: 0;}
}

@media (min-width: 850px) {
	.hero .wyszukiwarka_formularz {padding: 55px 25px;}
}

@media (min-width: 1001px) and (max-width: 1300px) {
	.hero .wyszukiwarka .wyszukiwarka_formularz .form_field:not(.children_birth) {margin: 0; width: 100%;}
	.hero .wyszukiwarka .wyszukiwarka_formularz .form_field:not(.children_birth) {margin: 0; width: 100%;}
	.hero .wyszukiwarka .wyszukiwarka_formularz .wyszukiwarka_pola {
		display: grid;
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
	.hero .wyszukiwarka .wyszukiwarka_formularz .wyszukiwarka_pola li {
		margin: 0;
		width: 100%;
	}
}

@media (min-width: 701px) and (max-width: 1300px) {
	.wyszukiwarka_formularz_podstrona .wyszukiwarka_pola {display: grid; grid-template-columns: repeat(2, minmax(0, 1fr));}
	.wyszukiwarka_formularz_podstrona .wyszukiwarka_pola li {margin: 0; width: 100%;}
	.wyszukiwarka_formularz_podstrona .form_field:not(.children_birth) {width: 100%;}
	.wyszukiwarka .wyszukiwarka_pola li {margin: unset;}
	.wyszukiwarka .wyszukiwarka_pola li:first-of-type {margin: unset;}
	.wyszukiwarka .wyszukiwarka_pola li:last-of-type {margin: unset;}
}

/* Poniższy mediaquery dodałem, żeby ujażmić pola formularza przy wybranych wielu destynacjach (za szeroki span) */ 
@media (max-width: 700px) {
	.wyszukiwarka_formularz_podstrona .wyszukiwarka_pola {display: grid; grid-template-columns: minmax(0, 1fr);}
	.wyszukiwarka_formularz_podstrona form { margin: 0 auto; width: 85%; }
	.wyszukiwarka_formularz_podstrona .form_field:not(.children_birth) {width: 100%;}
	.oferta_toc .oferta_toc_tile {
		padding: 10px 24px;
	}
}

@media (max-width: 900px) {
	.faq {
		grid-template-areas:
			"faq"
			"pytania";
		grid-template-columns: 1fr;
	}
	.pytania {padding-top: clamp(40px, 5.53vw, 80px);}
	.pytanie {margin-left: clamp(20px, 5.53vw, 80px);}
}

@media (max-width: 799px) {
	.oferta {
		grid-template-areas:
			"sciezka"
			"zdjecia"
			"obiekt"
			"sticky"
			"szczegoly";
		padding-top: 0;
	}
	.oferta.oferta--no-gallery {
		grid-template-areas:
			"sciezka"
			"zdjecia"
			"obiekt"
			"sticky"
			"szczegoly";
	}
	.oferta_sciezka {display: none;}
	.oferta_zdjecia:not(.oferta_zdjecia--no-accommodation) {margin: 20px clamp(-64px, -4.45vw, -20px);}
	.oferta_zdjecia .main-image, .oferta_zdjecia .slides .slide {border-radius: 0;}
	.oferta_zdjecia .thumbnails-wrapper {display: none;}
	.oferta_no_accommodation_gallery_note {
		border-left: 0;
		border-radius: 0;
		border-right: 0;
		box-shadow: none;
		min-height: clamp(180px, 56vw, 280px);
	}
	.oferta_toc_tile {flex: 0 0 auto; white-space: nowrap;}
	.oferta_obiekt {
		grid-template-areas:
			"obiekt_nazwa obiekt_mapa"
			"obiekt_opinia obiekt_polecenie";
		margin-top: 20px;
	}
	.oferta_obiekt .polecenie {justify-content: flex-end;}
	.oferta_obiekt .polecenie .promotion_badge--details {white-space: normal; text-align: center;}
	.oferta_obiekt p {font-size: 20px; display: flex; gap: 0 16px; flex-wrap: wrap;}
	.oferta_sticky {
	  grid-row-start: 4;
	  grid-row-end: 5;
	}
	.oferta_parametry-inner {
		gap: 0;
	}
	.oferta_wlasciwosci .param_podtytul,
	.oferta_wlasciwosci p {font-size: clamp(13px, 4.06vw, 16px);}
	.wybrane_udogodnienia>div {grid-template-columns: 1fr 1fr; gap: 12px 24px; gap: 8px 16px;}
	.oferta_szczegoly>div:nth-of-type(n+3) {border-top: 0 !important;}
	.o_osrodku>div>div {padding: 24px 16px 8px 16px;}
	.o_osrodku>div {grid-template-areas: "osrodek_nazwa" "osrodek_info" "osrodek_mapa"; grid-template-columns: 1fr; gap: 16px;}
	.o_osrodku>div>img {margin: 0 auto; max-width: 547px; width: 100%;}
	.tekst_kol2 {column-count: 1; column-gap: 0;}
	.ps_rezerwacja>div {gap: 20px;}
	.ps_rezerwacja>div>h1 {font-size: 24px; text-align: left;}
	.ps_rezerwacja>div>section {grid-template-areas: "zdjecie" "parametry"; grid-template-columns: 1fr;}
	.rezerwacja_obiekt>p {font-size: clamp(20px, 3vw, 24px);}
	.rezerwacja_obiekt .edytuj {display: block;}
	.rezerwacja_parametry .edytuj {display: none;}
	.rezerwacja_parametry>div>p {font-size: clamp(20px, 3vw, 24px);}
	.rezerwacja_parametry>p:nth-of-type(-n+1) {margin-top: 15px;}
/* 	.ps_podziekowania>div {margin: 0 clamp(-64px, -4.45vw, -20px);} */
	.ps_podziekowania .ubezpieczenia {border-radius: 0; font-size: clamp(16px, 2.51vw, 20px); margin: 0; min-height: clamp(200px, 32.7vw, 262px); padding: clamp(20px, 4.44vw, 64px);}
	.ps_podziekowania .ubezpieczenia>img {height: clamp(100px, 29.1vw, 232px); margin: 0 clamp(8px, 2vw, 50px);}
	.ps_podziekowania .ubezpieczenia>p {padding-top: 0; width: 70%;}
}

@media (max-width: 699px) {
	.ukladanka {grid-template-columns: repeat(auto-fit, 160px); column-gap: 20px; row-gap: 32px;}
	a.kraj img {height: 160px; width: 160px;}
	a.kraj div {width: 160px;}
	a.kraj p:nth-of-type(2) {float: left;}
/* 	.wyszukiwarka_formularz_podstrona form { width: 85%; margin: 0 auto; } <- przeniesiony do mediaquery "max-width: 700px" */
}

@media (min-width: 600px) and (max-width: 1000px) {
	.hero .wyszukiwarka {
		display: grid;
		grid-template-columns: 3fr 2fr;
	}
	.hero .wyszukiwarka_tytul {align-items: center; display: flex; font-size: 5vw; padding: 0 clamp(0px, 7.9vw, 80px) 0 clamp(0px, 7.9vw, 80px);}
	.oferta_kafelek {
		grid-template-areas:
			"zdjecie zdjecie zdjecie"
			"nazwa nazwa cena"
			"parametry informacje poleca"
			"parametry informacje button";
		grid-template-columns: 220px minmax(138px, 1fr) 175px;
	}
}

@media (max-width: 599px) {
	.wyszukiwarka_formularz .search_suggestions_popup,
	.wyszukiwarka_formularz .transport_select_popup,
	.wyszukiwarka_formularz .dropdown_multiselect_popup,
	.wyszukiwarka_formularz .osoby_popup,
	.oferta_warianty .osoby_popup {
		position: absolute;
		left: 0;
		right: 0;
		top: 100%;
		bottom: auto;
		margin-top: 8px;
		width: 100%;
		min-width: 0;
		max-width: 100%;
		overflow: auto;
		z-index: 1001;
		box-sizing: border-box;
		padding-bottom: 12px;
	}

	.oferta_warianty .wariant_pole {width: 100%;}

	.wyszukiwarka_formularz .osoby_birth_row,
	.oferta_warianty .osoby_birth_row {
		flex-direction: column;
		align-items: stretch;
		gap: 6px;
	}
	
	.wyszukiwarka_formularz form { margin: clamp(10px, 5.53vw, 20px) clamp(20px, 5.53vw, 64px); }

	.wyszukiwarka_formularz .osoby_birth_row .osoby_label,
	.oferta_warianty .osoby_birth_row .osoby_label {min-width: 0;}

	.wyszukiwarka_formularz .children_birth.form_field,
	.oferta_warianty .children_birth.form_field {
		width: 100%;
		max-width: 100%;
	}

	.hero .wyszukiwarka_tytul {margin: 0 auto; padding: 25px 0 0 0; width: 250px;}
	.hero .wyszukiwarka_formularz {justify-self: center; padding: 55px 0;}
	.hero .wyszukiwarka_formularz:not(.wyszukiwarka_formularz--small) .form_field {width: 240px;}
	.wyszukiwarka_formularz:not(.wyszukiwarka_formularz_podstrona) form {margin: 0 auto;}
	.scroller_controls {display: none;}
	.oferta_kafelek {
		grid-template-areas:
			"zdjecie zdjecie zdjecie"
			"nazwa nazwa nazwa"
			"parametry parametry poleca"
			"button cena cena";
		grid-template-columns: clamp(152px, 54%, 205px) 1fr clamp(80px, 28%, 150px);
	}
	.oferta_kafelek.oferta_nazwa {padding: 24px clamp(10px, 3.16vw, 24px) 0 clamp(10px, 3.16vw, 24px);}
	.oferta_parametry {overflow-y: hidden; padding: 0 0 clamp(10px, 3.16vw, 24px) clamp(10px, 3.16vw, 24px);}
	.oferta_informacje {display: none;}
	.oferta_poleca {margin-top: 32px; padding-right: clamp(10px, 3.16vw, 24px);}
	.promotion_ribbon {top: 10px; font-size: 10px; padding: 7px 12px 7px 10px;}
	.promotion_ribbon::after {right: -12px; width: 12px;}
	.promotion_badge {font-size: 11px; padding: 7px 10px;}
	.oferta_cena {font-size: clamp(12px, 3.55vw, 16px); padding: 0 clamp(10px, 3.16vw, 24px) 24px 0;}
	.oferta_cena p {font-size: clamp(16px, 4.57vw, 20px);}
	.oferta_button {justify-content: flex-start; padding: 0 0 24px clamp(10px, 3.16vw, 24px);}
	.oferta_button .button {width: 100%; height: 100%;}
	.wybrane_udogodnienia>div {grid-template-columns: 1fr; gap: 8px;}
	.ps_rezerwacja .pola1>div {margin-bottom: 16px; width: 100%;}
	.ps_rezerwacja .pola1>div:nth-last-of-type(2) {width: 32%;}
	.ps_rezerwacja .pola1>div:last-of-type {width: 66%;}
	.ps_rezerwacja .rezerwuj_button {width: 100%;}
	.ps_rezerwacja .pola2 {flex-wrap: wrap;}
	.ps_rezerwacja .pola2>div {width: 100%;}
	.ps_rezerwacja .pola2>div:first-of-type {margin-bottom: 12px;}
	.ps_rezerwacja .reservation_form_fields_group .fields_group {grid-template-columns: 1fr;}
	.ps_rezerwacja .reservation_form_fields_group .reservation_form_fields_group-header {margin-bottom: 16px;}
}

@media (max-width: 385px) {
	.ukladanka {grid-template-columns: repeat(auto-fit, 40.6vw);}
	a.kraj img {height: clamp(133px, 41.5vw, 160px); width: clamp(133px, 41.5vw, 160px);}
	a.kraj div {width: clamp(133px, 41.5vw, 160px);}
	.ps_podziekowania .ubezpieczenia>p {width: 100%;}
	.ps_podziekowania .ubezpieczenia>button {width: 160px;}
	.ps_oferty .offers_items .oferta_cena .offer_benefits_summary {font-size: 14px;}
}
