/* baloo-2-regular - latin_latin-ext */
@font-face {
    font-display: swap;
    font-family: 'Baloo 2';
    font-style: normal;
    font-weight: 400;
    src: url('../fonts/baloo-2-v23-latin_latin-ext-regular.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* baloo-2-500 - latin_latin-ext */
@font-face {
    font-display: swap;
    font-family: 'Baloo 2';
    font-style: normal;
    font-weight: 500;
    src: url('../fonts/baloo-2-v23-latin_latin-ext-500.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* baloo-2-600 - latin_latin-ext */
@font-face {
    font-display: swap;
    font-family: 'Baloo 2';
    font-style: normal;
    font-weight: 600;
    src: url('../fonts/baloo-2-v23-latin_latin-ext-600.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* baloo-2-700 - latin_latin-ext */
@font-face {
    font-display: swap;
    font-family: 'Baloo 2';
    font-style: normal;
    font-weight: 700;
    src: url('../fonts/baloo-2-v23-latin_latin-ext-700.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* baloo-2-800 - latin_latin-ext */
@font-face {
    font-display: swap;
    font-family: 'Baloo 2';
    font-style: normal;
    font-weight: 800;
    src: url('../fonts/baloo-2-v23-latin_latin-ext-800.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}




/*VARIABLES*/

:root {
    --background-global: #F5EADF;
    --background-primary: #26446F;
    --background-secondary: #E94E77;
    --background-bistro: #EF7696;
    --background-water: #21B2C5;
    --background-socks: #F0A89C;
    --background-job: #C394DE;
    --background-price: #26446F;
    --background-price-row: #1D375D;
    --background-price-cell1: #F5EADF;
    --background-price-cell2: #A3D889;
    --background-price-cell3: #E1A3AE;
    --background-price-note: #517CB980;
    --background-birthday: #A5D388;
    --background-birthday-page: #A3D889;
    --background-groups: #B2C9FA;
    --background-day-camp: #A3DDE0;
    --background-address: #A3DDE0;
    --background-work-hours: #EBBB1B;
    --background-parking: #D7E63F;
    --background-footer-menu: #E8AAC6;
    --background-package1: #BE8DDB;
    --background-package2: #E27968;
    --background-package3: #59C0D2;
    --background-package4: #8BABE2;
    --background-extra: #A6EDF9;
    --background-booking: #EBBB1B;
    --background-contact-button: #F0EDE9;
    --background-contact-page: #A3D889;
    --background-white: #fff;

    --color-primary: #173257;
    --color-navy: #26446F;
    --color-secondary: #FFF;
    --color-beige: #F5EADF;
    --color-price-group: #F7C3B8;
    --color-contact: #E94E77;
    --color-pink: #E94E77;

    --font-size-15: 0.875rem;
    --font-size-body: 1rem;
    --font-size-18: 1.125rem;
    --font-size-button: 1.25rem;
    --font-size-content: 1.25rem;
    --font-size-22: 1.375rem;
    --font-size-24: 1.5rem;
    --font-size-26: 1.625rem;
    --font-size-28: 1.750rem;
    --font-size-30: 1.875rem;
    --font-size-32: 2rem;
    --font-size-40: 2.5rem;
    --font-size-42: 2.625rem;
    --font-size-64: 4rem;
    --font-size-66: 4.125rem;
    --font-size-68: 4.250rem;
    --font-size-70: clamp(2rem, 2rem + 2vw, 4.375rem);
    --font-size-title-h1: clamp(2rem, 2rem + 2vw, 4.375rem);
    --font-size-title-h2: clamp(1.8rem, 1.4rem + 2.5vw, 3.5rem);
    --font-size-title-h3: clamp(1.4rem, 1.1rem + 1.8vw, 2.25rem);
}
html { scroll-behavior: auto; }
html.contrast {
    --background-global: #F5EADF;
    --background-primary: #173257;
    --background-secondary: #E94E77;
    --color-primary: #173257;
    --color-secondary: #FFF;
    --color-beige: #F5EADF;
}

body { background-color: var(--background-global); font-size: var(--font-size-body); background-repeat: no-repeat;
    font-family: "Baloo 2", sans-serif; }
body.no-scroll { overflow: hidden; }

.node--1 { background-image: url("/themes/papaja/images/back-1.svg"); background-position: 0 125%; background-size: contain; }
.node--2 { background-image: url("/themes/papaja/images/back-2.webp"); background-position: 0 50%; background-size: contain; }
.node--3 { background-image: url("/themes/papaja/images/back-3.webp"); background-position: 0 50%; background-size: contain; }
.node--4 { background-image: url("/themes/papaja/images/back-4.webp"); background-position: 0 125%; background-size: contain; }
.node--5 { background-image: url("/themes/papaja/images/back-5.webp"); background-position: 0 100%; background-size: contain; }

a,
a:hover { transition: .3s; }

.page { overflow: hidden; padding-bottom: 10px; }

/*VARIABLES*/

/*CKEDITOR*/

.font--13 { font-size: 13px; }
.font--14 { font-size: 14px; }
.font--16 { font-size: 16px; }
.font--18 { font-size: 18px; }
.font--20 { font-size: 20px; }
.font--22 { font-size: 22px; }
.font--23 { font-size: 23px; }
.font--24 { font-size: 24px; }
.font--26 { font-size: 26px; }
.font--36 { font-size: 36px; }
.text--upper { text-transform: uppercase; }
.weight--light { font-weight: 300; }
.weight--normal { font-weight: 400; }
.weight--semi-bold { font-weight: 600; }
.weight--medium { font-weight: 500; }
.weight--extra-bold { font-weight: 800; }
.color--navy { color: var(--color-primary); }
.color--beige { color: var(--color-beige); }
.color--white { color: var(--color-secondary); }
.color--price-group { color: var(--color-price-group); }
.background--navy { background: var(--background-primary); }
.background--bistro { background: var(--background-bistro); }

/*CKEDITOR*/

/*HEADER*/

.header { height: 90px; background: var(--background-global); width: 100%; position: relative; z-index: 99; }
.header__container { display: flex; padding: 0 100px; justify-content: space-between; align-items: center; height: 100%; }
.header--center { display: flex; align-items: center; justify-content: center; }

.header__logo { align-self: flex-start; width: 260px; margin-top: 5px; }
.header__logo-img { width: 257px; height: auto; will-change: filter; }
.header__home-link { display: inline-block; will-change: transform, opacity; }

.header__buttons { width: 260px; display: flex; align-items: center; gap: 40px; justify-content: flex-end; }

.logo--img { filter: drop-shadow(0 13px 10px rgba(0, 0, 0, .16)); }

.menu { padding: 0; margin: 0; list-style: none; }
.top-bar--menu .menu { display: flex; gap: 40px; align-items: center; }
.menu__item { }
.menu__link { padding: 10px 15px; font-size: var(--font-size-content); color: var(--color-navy); font-weight: 700; }
.menu__link:not(.menu--groups).is-active,
.menu__link:hover { color: var(--color-pink);}
.menu--button { display: none }

.eu__overlay { display: none; }

@media (max-width: 1450px) {
    .top-bar--menu .menu { gap: 10px; }
}

@media (max-width: 1200px) {
    .top-bar--menu .menu { gap: 0; }
    .header__logo { width: 240px; }
    .header__buttons { width: 240px; gap: 20px; }
    .header__buttons .button--pink a { padding: 7px 30px; }
}

@media (max-width: 1050px) {
    .header__logo { width: 200px; }
    .header__buttons { width: 200px; gap: 20px; }
    .header__buttons .button--pink a { font-size: var(--font-size-body); padding: 7px 20px; }
}

@media (max-width: 980px) {
    .header { height: 60px; }
    .header__buttons .button--pink { display: none; }
    .header__logo { width: 150px; }
    .header__buttons { margin: 0 30px 0 auto; width: initial; }
    .header--center { order: 3; }

    .nav-icon { width: 35px; height: 27px; position: relative; cursor: pointer; display: block; transform: rotate(0deg);
        transition: .5s ease-in-out; z-index: 11; }
    .nav-icon span { display: block; position: absolute; height: 5px; width: 100%; background: var(--background-primary);
        opacity: 1; left: 0; transform: rotate(0deg); transition: .25s ease-in-out; }
    .nav-icon span:nth-child(1) { top: 0; }
    .nav-icon span:nth-child(2),
    .nav-icon span:nth-child(3) { top: 10px; }
    .nav-icon span:nth-child(4) { top: 20px; }
    .nav-icon.open span:nth-child(2) { transform: rotate(45deg); }
    .nav-icon.open span:nth-child(3) { transform: rotate(-45deg); }
    .nav-icon.open span:nth-child(1),
    .nav-icon.open span:nth-child(4) { top: 18px; width: 0; left: 50%; }

    .top-bar--menu .menu { display: none; background: var(--background-global); width: 300px; height: 100vh;
        position: fixed; right: 0; top: 0; z-index: 10; padding-top: 60px; }
    .menu__link { display: block; }
    .menu--button { display: block; margin-left: 15px; margin-top: 15px; }
}

@media (max-width: 600px) {
    .header__container { padding: 0 20px; }
}

/*HEADER*/

/*FOOTER*/

.footer { margin-top: 100px; }
.footer__container { margin: 0 auto; }

.footer--part { flex: 1 1 calc(100% / 3); }
.footer__boxes { display: flex; gap: 20px; }
.footer--box:not(.footer__parking) { border-radius: 30px; padding: 30px; }
.footer__address { background: var(--background-address); }
.footer__hours { background: var(--background-work-hours); width: 100%; }
.footer__parking { background: var(--background-parking); border-radius: 30px; width: 100%; }
.footer__menu { background: var(--background-footer-menu); }

.footer__hours-parking { display: flex; flex-wrap: wrap; gap: 20px; }

.footer__body { padding: 0 10px; }
.footer__top { position: relative; }
.footer__label { font-size: var(--font-size-26); text-transform: uppercase; }
.footer__logo { position: absolute; right: 0; top: 0; }
.footer__logo-img { width: 150px; height: auto; }
.footer__address .footer__text { text-transform: uppercase; line-height: 1.2; }
.footer__address iframe { display: block; width: 100%; height: 160px; border-radius: 20px; }
.footer__text a:hover { color: var(--color-pink); }
.footer__see-map a { border-radius: 50px; font-size: var(--font-size-15); text-transform: uppercase; margin-top: 20px;
    background: var(--background-white); padding: 12px 0; display: block; text-align: center; font-weight: 800; }
.footer__see-map a:hover { background: var(--background-primary); color: var(--color-secondary); }

.footer__parking-wrapper { padding: 20px; display: flex; align-items: center; gap: 25px; }
.footer__parking-wrapper .footer__label { margin-bottom: 0; line-height: 1; }
.footer__parking-wrapper .footer__link { font-size: var(--font-size-26); text-transform: uppercase; line-height: 1; }
.footer__parking-wrapper iframe { display: block; width: 100px; height: 100px; border-radius: 20px; }

.footer__menu { color: var(--color-primary); }
.footer__menu .menu__link { padding: 8px 0; font-weight: 800; display: inline-block; }
.footer__menu .menu__item:first-child .menu__link { margin-top: -8px; }
.footer__menu .menu__item:last-child .menu__link { margin-top: 16px; }
.footer__menu .menu__link:not(.footer--link-home) { font-size: var(--font-size-content) }
.footer__menu .footer--link-home { font-size: var(--font-size-26); }
.footer__menu .footer--link-regulations { border-radius: 10px; border: 1px solid var(--color-primary); padding: 7px 32px; }
.footer__menu .footer--link-regulations:hover { border: 1px solid var(--color-pink); }


.footer__ue { margin-top: 50px; }
.footer__ue-image img { border-radius: 10px; width: 100%; height: auto; }
.footer__links { margin-top: 20px; display: flex; justify-content: center; gap: 20px; padding-bottom: 50px; }
.footer__link a:hover { color: var(--color-pink); }

@media (max-width: 1150px) {
    .footer__logo-img { width: 100px; }
}

@media (max-width: 1060px) {
    .footer--box:not(.footer__parking) { padding: 20px; }

    .footer__address .footer__wrapper { display: flex; flex-direction: column; justify-content: space-between; height: 100%; }
}

@media (max-width: 900px) {
    .footer__boxes { flex-wrap: wrap; }
    .footer__hours-parking { order: 2; flex: 1 1 100%; }
    .footer__hours,
    .footer__parking,
    .footer__menu,
    .footer__address { flex: 0 1 calc(50% - 10px); }

    .footer__parking-wrapper { flex-direction: column; align-items: initial; height: 100%; justify-content: space-between; }
    .footer__iframe { order: 2; width: 100%;  }
    .footer__parking-wrapper iframe { width: 100%; height: 160px; }
}

@media (max-width: 600px) {

    .footer__hours-parking,
    .footer__hours,
    .footer__parking,
    .footer__menu,
    .footer__address { flex: 0 1 100%; }
}

/*FOOTER*/

.container--base { width: 100%; margin: 0 auto; padding: 0 50px; }
.container--small { max-width: 940px; }
.container--medium { max-width: 1020px; }
.container--large { max-width: 1340px; }

@media (max-width: 600px) {
    .container--base { padding: 0 20px; }
}

button { background: none; border: none; padding: 0; margin: 0; }

.coming-soon { position: relative; }

/* dymek */
.coming-soon::after { content: attr(data-tooltip); position: absolute; top: calc(100% + 10px); left: 50%;
    transform: translateX(-50%); background: #000; color: #fff; padding: 6px 10px; font-size: 12px; border-radius: 6px;
    white-space: nowrap; opacity: 0; pointer-events: none; transition: 0.2s; }

/* strzałka */
.coming-soon::before { content: ""; position: absolute; top: 100%; left: 50%; transform: translateX(-50%);
    border: 5px solid transparent; border-bottom-color: #000; opacity: 0; transition: 0.2s; }

/* hover */
.coming-soon:hover::after,
.coming-soon:hover::before { opacity: 1; }

.button--base a { border-radius: 50px; font-size: var(--font-size-button); box-shadow: 0 0 8px rgba(0, 0, 0, .32);
    font-weight: 700; display: inline-block; cursor: pointer; }
.button--pink a { padding: 10px 40px; background: var(--background-secondary); color: var(--color-secondary);
    border: 1px solid var(--background-secondary); }
.button--pink a:hover { background: var(--background-white); color: var(--color-pink); }
.button--beige a { padding: 10px 20px; background: var(--background-global); color: var(--color-primary);
    border: 1px solid var(--background-global); }
.button--beige a:hover { background: var(--background-primary); color: var(--color-secondary);}

.title--h1 { font-size: var(--font-size-title-h1); color: var(--color-beige); position: relative; z-index: 0;
    font-weight: 800; }
.title--h1::before { content: attr(data-text); position: absolute; left: 0; top: 0; z-index: -1; width: 100%; height: 100%;
    -webkit-text-stroke: 20px #26446f; color: transparent; text-shadow: 0 12px 4px rgba(0, 0, 0, .25); }
.title--h2 { font-size: var(--font-size-title-h2); font-weight: 800; }
.title--h3 { font-size: var(--font-size-title-h3); font-weight: 800; }


img { max-height: 100%; display: block; max-width: 100%; }

.decor--container { position: relative; }
.decor { position: absolute; z-index: 1; }
.decor--bistro { right: 0; top: -60px; }
.decor--woda { left: 0; top: 50px; }
.decor--woda img { filter: drop-shadow(0 4px 9px rgba(0, 0, 0, .25)); }
.decor--price-list { right: 20px; top: -90px; }
.decor--price-list-birthday { right: 150px; top: -50px; }
.decor--prezent { top: -30px; left: 39%; }
.decor--prezent img { filter: drop-shadow(0 4px 9px rgba(0, 0, 0, .25)); }
.decor--prezent-urodzinowy { top: 10px; right: 150px; }
.decor--prezent-urodzinowy img { filter: drop-shadow(0 4px 9px rgba(0, 0, 0, .25)); }
.decor--lezki { bottom: 15px; left: 45%; }
.decor--grupy { top: -50px; right: 5%; }
.decor--flower-attraction { left: 5%; top: 12%; }
.page--attractions .decor--flower-attraction { display: none; }

@media (max-width: 1800px) {
    .decor--flower-attraction { top: 5%; }
    .decor--flower-attraction img { width: 150px; height: auto; }
}

@media (max-width: 1280px) {
    .decor--bistro { top: -100px; }
    .decor--prezent { top: -120px; }
    .decor--grupy { top: -80px; }
    .decor--prezent-urodzinowy { top: -100px; }
}

@media (max-width: 1080px) {
    .decor--bistro { right: -100px }
    .decor--price-list-birthday { top: -80px; }
    .decor--price-list-birthday img { width: 150px; }
}

@media (max-width: 1000px) {
    .decor--price-list { top: -90px; right: -20px;}
    .decor--price-list img { width: 150px; }
}

@media (max-width: 950px) {
    .decor--bistro { right: 0; top: -120px; }
    .decor--prezent { top: -50px; right: 0; left: initial; }
    .decor--grupy { top: -120px; }

    .decor--lezki { bottom: 15px; left: 0; }
}

@media (max-width: 500px) {
    .decor--prezent-urodzinowy { right: 0; }
    .decor--price-list-birthday { right: 0; }
    .decor--price-list img { width: 100px; }
    .decor--prezent img { width: 100px; height: auto; }
    .decor--grupy img { width: 100px; height: auto; }
    .decor--flower-attraction { top: 7%;  }
    .decor--flower-attraction img { width: 100px;  }
}

@media (max-width: 380px) {
    .decor--flower-attraction { top: 9%;  }
}

/*SLIDER*/

.slider__slideshow { height: 780px; overflow: hidden; position: relative; border-radius: 45px; }
.slider__slides { height: 100%; }
.slide { height: 100%; }
.slide img { width: 100%; height: 100%; object-fit: cover; filter: brightness(.85); }

.slide__img { transform: scale(1.2); transform-origin: 50% 50%; will-change: transform; }

.slider__content { position: absolute; top: 45%; width: 100%; text-align: center; padding: 0 20px; }
.slider__content .button--base { margin-top: 80px; }
.slider__eyebrow { display: block; }
.slider__title { position: relative; display: inline-block; font-size: var(--font-size-title-h3)}


.title-firework { position: absolute; inset: 0; pointer-events: none; z-index: 4; overflow: visible; }
.title-firework__particle { position: absolute; left: 0; top: 0; box-shadow: 0 4px 12px rgba(0, 0, 0, .22); }
.title-firework__particle--circle { border-radius: 999px; }
.title-firework__particle--square { border-radius: 3px; }
.title-firework__particle--pill { border-radius: 999px; }

@media (max-width: 980px) {
    .slider__slideshow { height: clamp(480px, 70vh, 780px); }
    .slider__content { top: 50%; transform: translateY(-50%); }
    .slider__button { margin-top: 40px; }
}

/*SLIDER*/

/*FEATURES*/

.features { margin-top: 100px; }
.features__list { display: flex; gap: 30px; align-items: center; flex-wrap: wrap; justify-content: center; }

.feature { filter: drop-shadow(0 4px 13px rgba(0, 0, 0, .25)); width: 280px; }
.feature__container { position: relative; }
.feature__description { position: absolute; text-align: center; width: 100%; padding: 0 30px; font-weight: 800; }
.feature__description p:last-child { margin-bottom: 0; }
.feature__img { width: 100%; height: auto; display: block; }

.feature:nth-child(1) .feature__description { bottom: 20px; }
.feature:nth-child(2) .feature__description { top: 50px; line-height: 1.1; }
.feature:nth-child(2) .feature__container { background: url("/themes/papaja/images/dots.png"); }
.feature:nth-child(2) .feature__description sup { top: 0; font-size: 50%; vertical-align: super; }
.feature:nth-child(3) .feature__description { bottom: 20px; line-height: 1; }
.feature:nth-child(4) .feature__description { bottom: 50px; line-height: 0.9; }
/*FEATURES*/

/*ATTRACTIONS*/

.attractions { margin-top: 100px; }
.attractions__title { text-align: center; margin: 0; }
.attractions__description { text-align: center; font-size: var(--font-size-22); margin-bottom: 50px; }
.attractions__list { display: grid; grid-template-columns: repeat(2, 1fr); gap: 40px; }

.attraction { border-radius: 80px; overflow: hidden; }
.attraction__container { height: 100%; padding: 32px 32px 20px; }
.attraction__content { padding: 0 8px; margin-top: 16px; }
.attraction__image { overflow: hidden; border-radius: 48px; }
.attraction__img { transition: .3s; width: 100%; height: 100%; object-fit: cover; cursor: pointer; }
.attraction__image:hover img { transition: .3s; transform: scale(1.1); }
.attraction__header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; }
.attraction__title { margin: 0; }
.attraction__description { font-size: var(--font-size-content); }

@media (max-width: 1200px) {
    .attractions__list { grid-template-columns: repeat(1, 1fr); justify-items: center; }
    .attraction { max-width: 600px; }
}

@media (max-width: 600px) {
    .attraction__container { padding: 20px; }
    .attraction__image { border-radius: 60px; }
    .attraction__content { padding: 0; }
    .attraction__button a { padding: 5px 10px; }
}

/*ATTRACTIONS*/

/*BISTRO*/

.bistro { margin-top: 100px; }
.bistro__content { border-radius: 75px; padding: 50px; }
.bistro__wrapper { display: flex; gap: 100px; }
.bistro--part { flex: 0 0 calc(50% - 50px); max-width: calc(50% - 50px); }
.bistro__left { display: flex; align-items: center; }
.bistro__text { font-size: var(--font-size-22); line-height: 1.1; }
.bistro__gallery { position: relative; border-radius: 40px; overflow: hidden; width: 100%; }
.bistro__gallery { aspect-ratio: 1 / 1; }
.bistro__gallery .field__items,
.bistro__gallery .field__item { position: absolute; inset: 0; }

.bistro__gallery img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: 0; }

/*.bistro__track { display: flex; width: max-content; animation: scroll 45s linear infinite; }*/
/*.bistro__track img { flex-shrink: 0; }*/

@media (max-width: 950px) {
    .bistro__wrapper { flex-wrap: wrap; gap: 50px; }
    .bistro--part { flex: 0 0 100%; max-width: 100% }
}

@media (max-width: 600px) {
    .bistro__content { padding: 20px; }
    .bistro__description { margin-top: 20px; }
    .bistro__gallery { border-radius: 55px; }
}

/*BISTRO*/

/*CARDS*/

.front-page__cards { margin-top: 50px; }
.front-page__cards .cards--vertical { display: flex; gap: 40px; flex-wrap: wrap; justify-content: center; }
.front-page__cards .card:first-child .card__container { background: var(--background-water); color: var(--color-secondary); }
.front-page__cards .card:nth-child(2) .card__container { background: var(--background-socks); color: var(--color-primary); }
.front-page__cards .card:last-child .card__container { background: var(--background-job); color: var(--color-secondary); }

.card { flex: 1; }
.card__container { border-radius: 75px; /*overflow: hidden;*/ font-size: var(--font-size-content); }
.card__container:hover .card__image > img { transition: .3s; transform: scale(1.1); }
.card__image { border-radius: 45px; overflow: hidden; }
.card__img { width: 100%; height: 100%; transition: .3s; object-fit: cover; }
.card__button { margin-top: 20px; }
.card__button a { font-size: var(--font-size-18); }

.cards--vertical .card { max-width: calc(100% / 3); min-width: 340px; }
.cards--vertical .card__container { line-height: 1.1; height: 100%; display: flex; flex-direction: column; padding: 40px 40px 16px; }
.cards--vertical .card__description { padding: 16px 0 16px; display: flex; align-items: center; /*height: 100%; */}
.cards--horizontal .card__container { line-height: 1.3; flex-wrap: wrap; }
.cards--horizontal .card--part { min-width: 365px; }
.cards--horizontal .card__image { filter: drop-shadow(0 20px 25px rgba(0, 0, 0, .25)); }

@media (max-width: 950px) {
    .cards--horizontal .card__image { max-width: 550px; margin: 0 auto; }
    .cards--horizontal .card:nth-child(2) .card__image { order: 2; }
}

@media (max-width: 730px) {
    .cards--vertical .card { max-width: initial; }
}

@media (max-width: 600px) {
    .cards--vertical .card__container { padding: 20px; }
    .cards--vertical .card__image { border-radius: 65px; }
}

@media (max-width: 450px) {
    .cards--horizontal .card--part { min-width: 100%; }
}

@media (max-width: 380px) {
    .cards--vertical .card { min-width: 100%; }
}

/*CARDS*/

/*SOCIALS*/

.social { display: flex; justify-content: center; align-items: center; padding: 0 50px; }
.social__container { display: inline-flex; border-radius: 80px; border: 2px solid var(--color-primary); padding: 56px 20px;
    gap: 24px; margin-top: 100px; max-width: 650px; justify-content: center; width: 100%; flex-wrap: wrap; }
.social__label { font-size: var(--font-size-30); font-weight: 800; }
.social__icons { display: flex; gap: 24px; justify-content: center; }
.social__icon { background: var(--background-secondary); border-radius: 100%; width: 48px; height: 48px; display: flex;
    justify-content: center; align-items: center; border: 1px solid var(--background-secondary); transition: .3s; }
.social__icon:hover { background: var(--background-white); transition: .3s; }
.social__icon svg { overflow: visible }
.social__icon:hover svg path { stroke: var(--background-secondary); transition: .3s; }
.social--youtube:hover svg path { stroke-width: 2px; }

@media (max-width: 600px) {
    .social { padding: 0 20px; }
}

@media (max-width: 500px) {
    .social__label { text-align: center; }
    .social__label,
    .social__icons { width: 100%; }
    .social__container { padding: 15px 20px; }
}

/*SOCIALS*/

/*PRICELIST*/

.price { margin-top: 50px; }
.price-list { border-radius: 75px; padding: 40px 40px 50px; background: var(--background-price); }
.price-list__header { text-align: center; }
.price-list__title { margin-bottom: 0; line-height: 1.2; }
.price-list__description { font-size: var(--font-size-30); }

.price-list__top-container { display: flex; justify-content: space-between; padding: 0 35px; }

.price-list__head { margin-top: 10px; }
.price-list__head-container { display: flex; justify-content: space-between; font-size: var(--font-size-content);
    padding: 0 35px; font-weight: 700; line-height: 1; }

.price-list__right span { font-size: var(--font-size-content); font-weight: 400; }

.price-list__body { display: flex; flex-direction: column; gap: 10px; margin-top: 20px; }
.price-list__row { background: var(--background-price-row); border-radius: 45px; display: flex;
    box-shadow: 0 4px 11px rgba(0, 0, 0, .25); }
.price-list__kids { flex: 4; border-radius: 45px; color: var(--color-primary); }
.price-list__row:nth-child(1) .price-list__kids { background: var(--background-price-cell1); }
.price-list__row:nth-child(2) .price-list__kids { background: var(--background-price-cell2); }
.price-list__row:nth-child(3) .price-list__kids { background: var(--background-price-cell3); }
.price-list__groups { flex: 2; color: var(--color-secondary); }
.price-list--row-part { display: flex; justify-content: space-between; padding: 5px 35px; }
.price-list__cell { font-size: var(--font-size-title-h3); font-weight: 800; }

.price-list__notes { display: flex; gap: 10px; flex-direction: column; align-items: center; max-width: 580px;
    margin: 40px auto 0; }
.price-list__note { background: var(--background-price-note); border-radius: 80px; padding: 5px 25px; display: flex;
    justify-content: space-between; align-items: center; width: 100%; }
.price-list__note-label { font-size: var(--font-size-content); font-weight: 700; }
.price-list__note-value { font-size: var(--font-size-28); font-weight: 800; }

.price-list__container .button--base { margin-top: 40px; text-align: center; }

@media (max-width: 1060px) {
    .price-list__table { max-width: initial; padding: 0; }
    .price-list__head-column:nth-child(2) { margin: 0 30px 0 -45px; }
    .price-list__unit { font-size: calc(.7 * var(--font-size-title-h3)); font-weight: 400; }
}

@media (max-width: 860px) {
    .price-list__head-container { align-items: center; padding: 0 20px; }
    .price-list__head-column:nth-child(1) { max-width: 60px; }
    .price-list__head-column:nth-child(2) { margin: 0 20px 0 5px; }
    .price-list__unit { font-size: calc(.5 * var(--font-size-title-h3)); font-weight: 400; }
    .price-list--row-part { padding: 5px 20px; }
}

@media (max-width: 600px) {
    .price-list { padding: 50px 20px; }
    .price-list__table { max-width: initial; position: relative; }
    .price-list__table::after { content: "↔"; position: absolute; bottom: -30px; left: calc(50% - 20px); font-size: 2.5rem;
        color: var(--color-secondary); pointer-events: none; animation: scrollHint 1.6s ease-in-out infinite; }
    .price-list__wrapper { overflow-x: scroll; padding: 20px 0; }
    .price-list__top,
    .price-list__head,
    .price-list__body { min-width: 500px; }

    .price-list__note-label { font-size: calc(.8 * var(--font-size-content)); }
    .price-list__note-value { font-size: calc(.8 * var(--font-size-28)); }
}

/* animacja */
@keyframes scrollHint {
    0%, 100% {
        transform: translateX(-12px);
    }
    50% {
        transform: translateX(12px);
    }
}


/*PRICELIST*/

/*OFFER*/

.front-page__offer { margin-top: 100px; }
.front-page__offer .cards--horizontal { display: flex; gap: 45px; flex-direction: column; }
.front-page__offer .card__container { display: flex; padding: 40px; gap: 40px; }
.front-page__offer .card:nth-child(1) .card__container { background: var(--background-birthday); }
.front-page__offer .card:nth-child(2) .card__container { background: var(--background-groups); }
.front-page__offer .card:nth-child(3) .card__container { background: var(--background-day-camp); }
.front-page__offer .card:first-child .card__description,
.front-page__offer .card:last-child .card__description { order: -1; }
.front-page__offer .card__description { display: flex; align-items: center; }
.front-page__offer .card--part { flex: 1; }

@media (max-width: 600px) {
    .front-page__offer .card__container { padding: 40px 20px 20px; }
    .front-page__offer .card__image { border-radius: 65px; }
}

/*OFFER*/

/*GALLERY*/

.gallery { margin-top: 50px; }
.gallery__container { display: flex; gap: 20px; }
.gallery__item { max-width: 300px; }
.gallery__img { border-radius: 20px; width: 100%; height: 100%; object-fit: cover; }

.gallery__item { display: block; overflow: hidden; border-radius: 20px; }
.gallery__img { display: block; }
.gallery__item--hidden { display: none; }

@media (max-width: 700px) {
    .gallery__container { flex-wrap: wrap; justify-content: center; }
    .gallery__item { max-width: calc((100% / 3) - 14px); }
}

@media (max-width: 500px) {
    .gallery__item { max-width: calc(50% - 10px); }
}

/*GALLERY*/

/*PAGE BANNER*/


.banner__content { position: relative; }
.banner__img { border-radius: 45px; width: 100%; height: 100%; max-height: 460px; object-fit: cover; }
.banner__text { top: 50%; transform: translateY(-50%); width: 100%; text-align: center; position: absolute; }

.page--contact .banner { margin-top: 50px; }
.page--contact .banner__title { font-size: var(--font-size-70); font-weight: 800; color: var(--color-primary); }
.page--contact .banner__text { position: static; transform: none; }

.page--page .banner { margin-top: 50px; }
.page--page .banner__title { font-size: var(--font-size-70); font-weight: 800; color: var(--color-primary); }
.page--page .banner__text { position: static; transform: none; }

.page--price .banner { margin-top: 50px; }
.page--price .banner__title { font-size: var(--font-size-70); font-weight: 800; color: var(--color-primary); }
.page--price .banner__text { position: static; transform: none; }

@media (max-width: 820px) {
    .banner__image { height: 200px; }
}


/*PAGE BANNER*/

/*BODY*/

.page--attractions .body { margin-top: 100px; }
.page--birthday .body { margin-top: 60px; }

.body__text { text-align: center; line-height: 1.2; }
.body__container .button--base { margin-top: 50px; text-align: center; }
.page--birthday .body__content { background: var(--background-birthday-page); border-radius: 80px; padding: 50px; }
.page--birthday .body__content {
    opacity: 0;
    transform: translateY(60px) scale(0.94);
}

.page--page .body__content { font-size: var(--font-size-content); }
.page--page .body__content img { width: 100%; height: auto; border-radius: 10px; margin-bottom: 20px; }

/*BODY*/

/*ROOMS*/

.rooms { margin-top: 50px; }
.rooms__list { margin-top: 50px; }
.rooms__row { display: flex; gap: 32px; justify-content: center; }
.rooms__row--bottom { margin-top: 100px; }
.rooms__title { font-size: var(--font-size-40); color: var(--color-primary); text-align: center; }
.rooms__row--top .room { flex: 0 1 calc((100% - 64px ) / 3); }
.rooms__row--bottom .room { flex: 0 1 calc(100% / 3); }
.room__container { text-align: center;  }
.room__image { cursor: pointer; border-radius: 40px; box-shadow: 0 0 18px 6px #D5C0AB; overflow: hidden;
    max-width: 500px; margin: 0 auto; }
.room__img { width: 100%; height: 100%; object-fit: cover; transition: .3s; }
.room__image:hover img { transition: .3s; transform: scale(1.1); }
.room__name span { font-size: var(--font-size-title-h3); color: var(--color-beige); font-weight: 800; padding: 5px 30px;
    background: var(--background-price); border-radius: 80px; display: inline-block; position: relative; bottom: 40px;
    box-shadow: 0 4px 4px rgba(0, 0, 0, .25); cursor: pointer; }
.room__limit span { font-size: var(--font-size-22); background: var(--background-price-cell2); border-radius: 80px;
    display: inline-block; font-weight: 800; padding: 0 30px; }

@media (max-width: 900px) {
    .rooms__row--top .room { flex: 0 1 calc((100% - 32px ) / 2); }
    .rooms__row--top,
    .rooms__row--bottom { flex-wrap: wrap; }
    .rooms__row--bottom .room { flex: 0 1 calc((100% - 32px) / 2); }
    .rooms__row--bottom .room:last-child { margin-top: 80px; }
}

@media (max-width: 900px) {
    .rooms__row--top .room { flex: 0 1 100%; }
    .rooms__row--bottom { margin-top: 32px; }
    .rooms__row--bottom .room { flex: 0 1 100%; }
    .rooms__row--bottom .room:last-child { margin-top: 0; }
}

/*ROOMS*/

/*PACKAGES*/

.packages { margin-top: 50px; }
.packages__title { font-size: var(--font-size-40); color: var(--color-primary); text-align: center; }
.packages__list { margin-top: 50px; display: flex; gap: 35px; flex-direction: column; }

.package:nth-child(1) .package__container { background: var(--background-package1); }
.package:nth-child(2) .package__container { background: var(--background-package2); }
.package:nth-child(3) .package__container { background: var(--background-package3); }
.package:nth-child(4) .package__container { background: var(--background-package4); }
.package__container { border-radius: 80px; padding: 50px; }
.package__wrapper { display: flex; gap: 50px; }
.package--part { flex: 1 1 50%; }
.package__text { line-height: 1.2; }
.package__text ul { padding: 0; margin: 0 0 0 15px; }
.package__text li::marker { color: var(--color-secondary); }
.package__text h3 { color: var(--color-primary); font-size: var(--font-size-42) }
.package__img { width: 100%; height: 100%; border-radius: 50px; object-fit: cover; max-width: 550px; }

@media (max-width: 900px) {
    .package__wrapper { flex-wrap: wrap; }
    .package__image { display: flex; justify-content: center; }
    .package--part { flex: 1 1 100%; }
}

@media (max-width: 600px) {
    .package__container { padding: 40px 20px 20px; border-radius: 60px; }
}

/*PACKAGES*/

/*EXTRA OPTIONS*/

.extra { margin-top: 80px; }
.extra__content { background: var(--background-extra); border-radius: 80px; padding: 50px; color: var(--color-primary);
    text-align: center; line-height: 1.2; }
.extra__content h2 { font-size: var(--font-size-40); line-height: 1.7; }

@media (max-width: 600px) {
    .extra__content { padding: 50px 20px; }
}

/*EXTRA OPTIONS*/

/*BOOKING*/

.booking { margin-top: 80px; }
.booking__content { background: var(--background-booking); border-radius: 80px; padding: 50px; color: var(--color-primary);
    text-align: center; line-height: 1.2; font-weight: 700; }
.booking__content h2 { font-size: var(--font-size-40); }
.booking__link a { font-size: var(--font-size-18); }

.page--contact .booking { margin-top: 20px; }

@media (max-width: 600px) {
    .booking__content { padding: 50px 20px; }
}

/*BOOKING*/

/*BIRTHDAY CONTACT*/

.contact { margin-top: 80px; }
.contact__content { text-align: center; color: var(--color-primary); font-weight: 700; font-size: var(--font-size-24);
    display: flex; gap: 20px; flex-direction: column; }
.contact__buttons { text-align: center; font-size: var(--font-size-24); font-weight: 700; display: flex; gap: 20px;
    flex-direction: column; }
.contact__buttons a { color: var(--color-contact); background: var(--background-contact-button); border-radius: 80px;
    border: 1px solid var(--color-contact); padding: 5px 40px; height: 60px; display: inline-flex; align-items: center;
    gap: 10px; }
.contact__buttons a svg path { transition: .3s; }
.contact__buttons a:hover { color: var(--color-secondary); background: var(--color-pink); }
.contact__buttons a:hover svg path { stroke: var(--color-secondary); transition: .3s; }

.page--contact .contact__wrapper { background: var(--background-contact-page); border-radius: 80px; padding: 50px }

@media (max-width: 650px) {
    .page--contact .contact__wrapper { padding: 50px 20px; }
    .contact__buttons { font-size: var(--font-size-content); }
    .contact__buttons a { padding: 5px 20px; }
}

@media (max-width: 450px) {
    .contact__buttons { font-size: var(--font-size-body); }
    .contact__buttons a { padding: 5px 15px; }
}

@media (max-width: 360px) {
    .contact__buttons { font-size: calc(.85 * var(--font-size-body)); }
    .contact__buttons a { padding: 5px 5px; }
}

/*BIRTHDAY CONTACT*/

/*CONTACT PAGE*/

.info { margin-top: 80px; }
.info__container { display: flex; flex-direction: column; gap: 20px; }
.info__row--top { display: flex; gap: 20px; }
.info__part { border-radius: 30px; padding: 30px; }
.info--left { flex: 2; background: var(--background-address); display: flex; }
.info--right { flex: 1; background: var(--background-work-hours); }
.info--bottom { background: var(--background-parking); }
.info--left > div { flex: 0 0 50%; }
.info--left .footer__body { padding: 0; }
.info--left .footer__text { text-transform: uppercase; }
.info--left .footer__logo,
.info--left .footer__see-map { display: none; }
.info--left .footer__iframe { height: 100%; }
.info--left iframe { display: block; width: 100%; height: 100%; border-radius: 20px; }

.info--bottom .footer__parking-wrapper { display: flex; flex-direction: column; align-items: flex-start; padding: 0; }
.info--bottom .footer__parking-text { order: -1; padding: 0 20px 20px; }
.info--bottom .footer__parking-description { font-size: var(--font-size-22); margin-top: 10px; }
.info--bottom .footer__iframe { width: 100%; }
.info--bottom iframe { display: block; width: 100%; height: 650px; border-radius: 20px; }


@media (max-width: 900px) {
    .info__row--top { flex-wrap: wrap; }
    .info--right,
    .info--left { flex: initial; width: 100%; }

    .info--bottom iframe { height: 400px; }
}

@media (max-width: 600px) {
    .info--bottom iframe { height: 250px; }
}

/*CONTACT PAGE*/

.eu--trigger { cursor: pointer }
.eu__overlay { display: none; width: 100%; height: 100vh; background: #000000aa; position: fixed; top: 0; left: 0;
    z-index: 12; font-size: 16px; }
.eu__container { background: #fff; border-radius: 5px; position: absolute; top: 50%; left: 50%;
    transform: translate(-50%, -50%); padding: 50px 40px 40px; max-height: 90%; overflow: auto; }
.eu__content { font-size: var(--font-size-content) }
.eu__content img { width: 100%; height: auto; }
.eu__close { position: absolute; top: -10px; right: 10px; font-size: var(--font-size-40); cursor: pointer; }


@media(max-width: 900px) {
    .eu__container { width: calc(100% - 40px); height: initial; }
    .eu__content { height: 100%; overflow: scroll; }
}

@media (max-width: 600px) {
    .eu__container { padding: 50px 20px 40px; }
}

/*ANIMATIONS*/


.feature__background { overflow: hidden; }
.attraction__image { overflow: hidden; }

.slider__title-wrap {
    overflow: visible;
}

.slider__eyebrow,
.slider__title,
.slider__button {
    opacity: 0;
    transform: translateY(40px);
}

.attractions__title,
.attractions__description {
    overflow: hidden;
}

.attractions__title > *,
.attractions__description > * {
    display: block;
}

.card__img { will-change: transform; }
.card__container { will-change: transform, opacity; }
.decor { pointer-events: none; }

/*ANIMATIONS*/