@charset "utf-8";

:root { --primary: #1f3875; --black: #000513; --gray: #6b7280; --shadow-black: #00051026; --shadow-black-light: #0005101a; --white: #fefdff; --selected: #5D79BF;}

* {box-sizing: border-box;}
.hidden {display: none !important;}
.capitalize {text-transform: uppercase;}

html {overflow-y: scroll;}
body {background-color: var(--white); 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;} /* removed display: flex; */

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;}

header {background: #222; color: var(--white); padding: 20px; text-align: center;}
header a {color: var(--white); margin: 0 0 0 50px; text-decoration: underline;}
section {padding-top: clamp(20px, 5.53vw, 80px);}

div.obow_inf {background: #111115; color: var(--white); padding: 30px 20px; text-align: center; max-height: max-content; min-width: 320px;} /* added 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: #aaa; font-weight: 300;}
div.obow_inf .footer_copyright {font-weight: 400;}
div.obow_inf a {color: var(--white); text-decoration: underline; transition: color 0.2s ease;}
div.obow_inf a:hover {color: #ddd;}

.button.primary,
.button.secondary,
.button.tertiary,
.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: #a0a4b8; cursor: default;
}
.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(--white); 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: #a0a4b8; border-color: #a0a4b8; cursor: default;
}
.button.secondary.wide {padding: 7px 20px;}
.button.secondary.shadowed {box-shadow: 0px -3px 10px 0px #13234A80 inset;}

.button.tertiary {display: inline-block; background-color: var(--white); color: var(--black); border: 1px solid var(--shadow-black-light); padding: 9px 12px; font-size: 14px; font-weight: 200; text-align: center;}
.button.tertiary[disabled],
.button.tertiary.disabled {
	color: #a0a4b8; border-color: #e0e3ea; cursor: default;
}
.button.tertiary.wide {padding: 3px 20px;}

.button.icon {background-color: var(--white); 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: #a0a4b8; cursor: default; }

.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;}
.oferta_zdjecie_img {filter: saturate(1.05) contrast(1.05); display: block; height: 100%; width: 100%; object-fit: cover; position: relative; object-position: center; display: block; z-index: 1; 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;
}
.hero {background: url("images/hero-glowna-2880.jpg") #192970; background-repeat: no-repeat; background-size: cover; background-position: center 50%; flex: 1 0 auto; height: auto;} /* removed padding-top: 100px; */
.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 {background: url("images/contact-banner-background.jpg") no-repeat center 40%; background-size: cover; 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::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 {background-image: url("images/hero-oferty-2880.jpg"); background-position: center 31%;}
.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(--white); 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:nth-of-type(1) {border-top: 0; padding-top: 0; margin-top: 16px;}
.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 #e0e3ea; 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 #e0e3ea; 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 #e0e3ea;
	border-radius: 8px;
	background: var(--white);
	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(--white);
	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 #e0e3ea;
	border-radius: 8px;
	background: var(--white);
	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;}
.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 8px 0 0; border: 1px solid #e0e3ea; 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 #f2f2f2; 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 #e0e3ea;
  border-radius: 16px;
  box-shadow: 0px 2px 10px 0px var(--shadow-black-light);
  display: grid;
  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;
}

.oferta_kafelek[role="link"] {cursor: pointer;}

.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: 500; color: var(--primary); margin-bottom: 16px; width: 100%; text-align: right; display: flex; align-items: center; justify-content: flex-end; gap: 8px;}
.offers_end {font-size: 14px; color: #4b5563;}

.oferta_kafelek--skeleton {
	min-height: 230px;
	position: relative;
	overflow: hidden;
	background: #f1f3f6;
	border: 1px solid #e0e3ea;
	box-shadow: 0px 2px 10px 0px var(--shadow-black-light);
}

.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 0 0 24px;}
.oferta_kafelek .oferta_nazwa .oferta_gwiazdki {margin-bottom: 8px; display: block;}

/* 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 #e0e3ea; 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: #4b5563; margin-left: 6px;}
.alternative_dates .no_date {color: #6b7280; 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 .skipass {font-size: 16px; font-weight: 400; display: block; line-height: 140%; letter-spacing: 0; text-align: right;}
.oferta_poleca {grid-area: poleca; height: 70px}
.oferta_parametry {grid-area: parametry; font-size: 12px; min-height: 150px; overflow-y: hidden; padding: 0 0 0 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_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_nocleg::after {background-image: url("images/iko-nocleg.svg");}
.param_wyzywienie::after {background-image: url("images/iko-wyzywienie.svg");}
.param_stoki::after {background-image: url("images/iko-stoki.svg");}
.param_gory::after {background-image: url("images/iko-gory.svg");}
.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;
  padding: 80px clamp(20px, 4.45vw, 64px) 0 clamp(20px, 4.45vw, 64px);
}
.oferta_sticky {
  grid-row-start: 2;
  grid-row-end: -1;
  gap: 0;
}
.oferta_sticky>div {
	display: grid;
	grid-template-areas:
		"wlasciwosci"
		"koszty";
	grid-template-columns: 1fr;
	height: fit-content;
	position: sticky;
	top: 10px;
}

.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(--black); 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(--shadow-black); 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_wlasciwosci, .oferta_koszty, .oferta_warianty {background-color: var(--white); border: 1px solid #e0e3ea; border-radius: 16px; box-shadow: 0px 4px 25px 0px var(--shadow-black); margin-bottom: 8px; padding: 16px clamp(16px, 2.22vw, 32px) 24px clamp(16px, 2.22vw, 32px); position: relative;}
.oferta_wlasciwosci {grid-area: wlasciwosci; display: flex; flex-wrap: wrap; gap: 0; justify-content: space-between;}
.oferta_wlasciwosci a {color: var(--primary);}
.oferta_wlasciwosci p {background-position: left top 1px; background-repeat: no-repeat; margin: 15px 0 0 0; padding: 0 0 0 28px; width: 75%;}
.oferta_wlasciwosci p:first-of-type {margin-top: 6px; padding: 0; width: 100%;}
.oferta_wlasciwosci p:nth-of-type(2n+3) {padding: 0; text-align: right; width: 16%;}

.oferta_koszty {
	grid-area: koszty;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	justify-content: flex-start;
	gap: 16px;
	padding: 24px clamp(16px, 2.22vw, 32px);
	/* allow absolutely-positioned spinner overlay inside */
	position: relative;
}

.oferta_koszty.sticky {
	top: 0;
	left: 0;
	right: 0;
	position: fixed;
}

.oferta_koszty.sticky .param_tytul,
.oferta_koszty.sticky .cena_row--person
{
	display: none;
}

.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--skipass .cena_label,
.oferta_koszty .cena_row.cena_row--skipass .cena_value {
	font-weight: 600;
}

.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%;
}

/* Skipass is displayed in the price box; keep the variant label element for live JS updates/tests. */
.oferta_warianty .param_skipass {display: none;}

.oferta_warianty {display: flex; flex-direction: column; gap: 8px;}
.oferta_warianty .param_tytul {margin-bottom: 4px;}
.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 #e0e3ea; border-radius: 8px; padding: 10px 36px 10px 12px; background: var(--white) 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_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: #374151; font-size: 14px;}
.oferta_warianty .wariant_message.error {color: var(--black);}
.spinner {width: 26px; height: 26px; border: 3px solid #e0e3ea; 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 #e0e3ea; border-radius: 8px; padding: 10px 38px 10px 12px; background: var(--white) 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;}
.oferta_warianty .osoby_trigger:focus {outline: 2px solid var(--primary); outline-offset: 1px;}
.oferta_warianty .osoby_popup {background: var(--white); border: 1px solid #e0e3ea; border-radius: 10px; box-shadow: 0 8px 32px rgba(0, 0, 0, 0.07); top: 0; margin-top: 50px; min-width: 260px; 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: #f3f5fa; border: 1px solid #e0e3ea; border-radius: 6px; color: var(--primary); cursor: pointer; font-weight: bold; height: 32px; width: 32px;}
.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: #b91c1c;}

.oferta_warianty .osoby_actions {margin-top: 12px;}
.oferta_warianty .osoby_actions .osoby_confirm {width: 100%;}


.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;}
.oferta_obiekt .obiekt_nazwa {grid-area: obiekt_nazwa; font-size: 12px;}
.oferta_obiekt .obiekt_opinia {grid-area: obiekt_opinia; font-size: 14px; padding: 20px 0;}
.oferta_obiekt .obiekt_opinia span {background-color: #3f8262; border-radius: 4px; color: var(--white); padding: 2px 4px;}
.oferta_obiekt .polecenie {grid-area: obiekt_polecenie; 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;}

.wybrane_udogodnienia>div {display: grid; grid-template-columns: auto auto auto; gap: 24px;}
.wybrane_udogodnienia>div>div>img {vertical-align: middle;}
.wybrane_udogodnienia>p:last-of-type {margin: 32px 0;}
.wybrane_udogodnienia>button {background-color: var(--white); 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 #e0e3ea;}
.oferta_szczegoly>div>p:first-of-type {font-size: 20px; font-weight: 600; margin: 32px 0; padding: 0;}

.o_obiekcie>p {font-weight: 600;}
.o_obiekcie>div {margin: 0 0 32px 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 #e0e3ea; 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(--shadow-black); 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 #e0e3ea; border-radius: 16px; box-shadow: 0px 4px 25px 0px var(--shadow-black); 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(--shadow-black); 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 #e0e3ea; 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 #e0e3ea; background: #f8fafc; color: #0f172a; font-weight: 600;}
.ps_rezerwacja .rezerwacja_notice.changed {border-color: #f63b26; background: #fff1f2; color: #9f1239;}
.ps_rezerwacja .rezerwacja_notice.error {border-color: #b91c1c; background: #fef2f2; color: #b91c1c;}

.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: #f63b26; 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 0 auto; display: flex; flex-wrap: nowrap; max-width: 100%; gap: 8px;}
.wyszukiwarka .wyszukiwarka_pola li {float: left; margin: 0 auto}
.wyszukiwarka .wyszukiwarka_pola li:first-of-type {margin: 0 auto 0 0;}
.wyszukiwarka .wyszukiwarka_pola li:last-of-type {margin: 0 0 0 auto;}
.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 {background-color: var(--white); border-radius: 10px; display: flex; margin: 0 auto; padding: 10px; min-width: 250px; gap: 0 10px; width: min-content;} 
.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 #e0e3ea; border-radius: 8px; padding: 7px 10px 6px 35px; appearance: none; -webkit-appearance: none; -moz-appearance: none; font: inherit; background-color: var(--white); 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: 0 center; position: absolute; background-size: 20px; width: 20px; height: 20px; top: 50%; left: 10px; transform: translateY(-50%);}

.wyszukiwarka_formularz .form_field.gory {width: 240px }
.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.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: 170px;}
.wyszukiwarka_formularz .form_field.dojazd + .icon {background-image: url('images/iko-dojazd.svg');}

.wyszukiwarka_formularz .form_field_wrapper .clear_date_btn,
.wyszukiwarka_formularz .form_field_wrapper .clear_destination_btn {
	position: absolute;
	right: 1px;
	top: 50%;
	transform: translateY(-50%);
	padding: 0 4px;
	z-index: 10;
}

.wyszukiwarka_formularz .dropdown_multiselect_wrapper {position: relative;}
.wyszukiwarka_formularz .dropdown_multiselect_trigger {display: flex; align-items: center; width: 100%;}
.wyszukiwarka_formularz .dropdown_multiselect_value {display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; width: 100%;}

.wyszukiwarka_formularz .dropdown_multiselect_popup {background: var(--white); border: 1px solid #e0e3ea; 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: #f3f5fa;}
.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 .osoby_wrapper {position: relative;}
.wyszukiwarka_formularz .osoby_popup {background: var(--white); border: 1px solid #e0e3ea; 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: #f3f5fa; border: 1px solid #e0e3ea; border-radius: 6px; color: var(--primary); cursor: pointer; font-weight: bold; height: 32px; width: 32px;}
.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 #1f528d0a; color: #0f2552; 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;}
section h1 {font-size: clamp(24px, 4vw, 48px); font-weight: bold; line-height: 120%; padding-left: clamp(20px, 5.53vw, 80px);}
.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.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, rgba(25, 41, 112, 0) 0%, rgba(25, 41, 112, 0.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, var(--primary)00 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 #ebebeb; border-radius: 12px; box-shadow: 0px 6px 24px 0px var(--shadow-black-light); 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: #212e44; 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(--white); 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;}
}

@media (max-width: 1199px) {
	.oferta {
		grid-template-areas:
			"sciezka"
			"zdjecia"
			"sticky"
			"obiekt"
			"szczegoly";
		grid-template-columns: 1fr;
		gap: 0;
	}
	.oferta_sticky {
		margin-top: 16px;
		grid-row-start: 3;
		grid-row-end: 4;
	}
	.oferta_sticky>div {
		grid-template-areas:
			"wlasciwosci koszty";
		grid-template-columns: 1fr 1fr;
		gap: 16px;
		position: relative;
		top: auto;
	}

	#bar_cena {
		background-color: var(--white);
		border-top: 1px solid #e0e3ea;
		box-shadow: 0px 4px 25px 0px var(--shadow-black);
		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: 1000px) {
	.hero .wyszukiwarka {gap: 0; padding: 0;}
	.hero .wyszukiwarka li {float: none;}
	.hero + .wyszukiwarka .wyszukiwarka_pola {justify-content: space-around;}
	.hero + .wyszukiwarka .wyszukiwarka_pola li {margin: unset;}
	.hero + .wyszukiwarka .wyszukiwarka_pola li:first-of-type {margin: unset;}
	.hero + .wyszukiwarka .wyszukiwarka_pola li:last-of-type {margin: unset;}
	.hero .wyszukiwarka_formularz {padding: 55px 25px;}
	.hero .wyszukiwarka_formularz .form_field,
	.hero + .wyszukiwarka .wyszukiwarka_formularz .form_field:not(.children_birth) {margin: 0; width: 230px;}
	.hero .wyszukiwarka_formularz button.search,
	.hero + .wyszukiwarka .wyszukiwarka_formularz button.search {background-position: 60px center; margin: 16px 0 0 4px; min-width: 200px;}
	.wyszukiwarka .wyszukiwarka_pola {display: grid; grid-template-columns: 1fr;}
	.wyszukiwarka .wyszukiwarka_pola li {width: 100%;}
	.wyszukiwarka .wyszukiwarka_pola li:first-of-type {margin: 0 auto;}
	.wyszukiwarka .wyszukiwarka_pola li:last-of-type {margin: 0 auto;}
	.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 {height: 150px; margin-top: 16px;}
	.oferta_kafelek .oferta_informacje {margin-top: 16px;}
	.wyszukiwarka_formularz form {flex-direction: column; width: 250px;}
	.wyszukiwarka_formularz_podstrona form {width: 85%;}
	.wyszukiwarka_formularz_podstrona .form_field:not(.children_birth) {width: clamp(265px, 82.8vw, 828px) !important;}
}

@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_sciezka {display: none;}
	.oferta_zdjecia {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_obiekt {
		grid-template-areas:
			"obiekt_nazwa obiekt_mapa"
			"obiekt_opinia obiekt_polecenie";
		margin-top: 20px;
	}
	.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_sticky>div {
		grid-template-areas:
			"wlasciwosci"
			"koszty";
		grid-template-columns: 1fr;
		gap: 0;
	}
	.oferta_wlasciwosci p {font-size: clamp(13px, 4.06vw, 16px); width: 72%;}
	.wybrane_udogodnienia>div {grid-template-columns: auto auto; gap: 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;}
}

@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 .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 .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 {padding: 55px 0;}
	.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 {height: 150px; overflow-y: hidden; padding: 0 0 0 clamp(10px, 3.16vw, 24px);}
	.oferta_informacje {display: none;}
	.oferta_poleca {margin-top: 32px;}
	.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: auto;}
	.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 .skipass {font-size: 14px;}
}
