@import url('https://fonts.googleapis.com/css2?family=Playwrite+CU:wght@100..400&family=Playwrite+HR+Lijeva:wght@100..400&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Londrina+Sketch&family=Nanum+Gothic&display=swap');
@media (max-height: 90vw) {

html{
    scroll-behavior: smooth; 

}
body {
    max-width: 100%;
    overflow-x: hidden;
    font-family: Arial, sans-serif;
    margin: 0px;
    padding: 0px;
    background-color: #fff;
    background-image: url(images/karkonosze-4376304_1920.jpg);

   
}

.megabox {
    background-image: url(images/main_background.jpeg);
    background-size: cover;

    


}

.headerappear {
    z-index: 99;
    height: 15vh;
    width: 100%;
    position: sticky;
    top: 0px;
    display: block;
    padding: 0px ;
    transition: 500ms;
}
.headerappear_mobile {
    display: none;
}

.navbarrow {
    justify-content: space-between;
    margin: 0px;
    padding: 0px;
    display: flex;
    height: 15vh;
    background: rgb(0,0,0);
    background: linear-gradient(0deg, rgba(0,0,0,0) 0%, rgba(0,0,0,1) 100%);
    text-align: center;
    z-index: 99;
}

.navbarrow li {

    transition: 500ms;
    display: block;
    line-height: 15vh;
    padding: 0px 1vw;
    z-index: 5;
}

.navbarmark a{
    font-size: 2vh;
    float: right;
    display: block;
    height: 11vh;
    padding: 0px 1vw;
    margin: 2vh 0px;
    color: #fff;
    line-height: 11vh;
    text-decoration: none;
    transition: 500ms;


}
.navbarmark a:hover {
    color: #a8a8a8;
    transition: 500ms;
    scale: 1.1;
}
.navbarmark img{
    height: 13vh;
    margin: 1vh;

}
.navbarlink {
    display: flex;

}

ul li .dropdown-content {
    display: none;
    background-color: #bde0fe;
    z-index: 1;


}
main {
    
    padding: 0px;
}
.welcometext h1{
    display: table-cell;

    color: #fff;
    height: 35vh;
    width: 100vw;
    text-align: center;
    font-size: 7.5vh;
    vertical-align: bottom;
    text-shadow:
    1px 1px 2px black,
    0 0 1em rgb(0, 0, 0),
    0 0 0.2em rgb(0, 0, 0);
}
.welcomebutton {
    justify-content: center;

    text-align: center;
    display: flex;
    margin: 0px;
    color: white;

}
.welcomebutton h2 {
    border: solid #fff 0.5vh;
    font-size: 5vh;
    margin-top: 5vh;
    display: block;
    padding: 2.5vh 2.5vh;
    border-radius: 2vh;
    background-color: #00000085;
    transition: 500ms;


}
.welcomebutton h2:hover {
    scale: 1.1;
    transition: 500ms;
}
.more {
    transition: 500ms;

    display: block;
    text-decoration: none;
    padding-bottom: 20vh;


}
.more:hover{
    transition: 500ms;
    scale: 1.1;

}
.more h1{
    margin-bottom: 5vh;
    margin-bottom: 0px;
    z-index: 1;
    height: 10vh;
    display: block;
    text-align: center;
    color: #fff;
    text-shadow:
    1px 1px 2px black,
    0 0 1em rgb(0, 0, 0),
    0 0 0.2em rgb(0, 0, 0);
}
.arrow-container {
    text-align: center;
    margin-top: -2.5vh;
}

.arrow {
    width: 2vh;
    height: 2vh;
    border-right: 5px solid #fff;
    border-bottom: 5px solid #fff;
    margin: 0 auto;
    animation: bounce 2s infinite;
    
}

@keyframes bounce {
    0%, 20%, 50%, 80%, 100% {
        transform: translateY(0) rotate(45deg);
    }
    40% {
        transform: translateY(-15px) rotate(45deg);
    }
    60% {
        transform: translateY(-10px) rotate(45deg);
    }
}
.about_left {
    
    display: flex;
    justify-content: space-between;
    background-color: #00000088;

    background-size:cover;
    background-position: center; /* Center the image */
    background-repeat: no-repeat;

}
.about_left div h1 {
    font-family: "Montserrat", sans-serif;    font-optical-sizing: auto;
    font-optical-sizing: auto;
    font-size: 5vh;
    font-weight: 400;
    font-style: normal;
    padding: 2vh;
    text-align: center;
    color: #fff;
}
.about_left div {
    display: block;
    text-align: center;
    transition: 500ms;
    position: relative;
    left: -50vw;
    border-radius:0vh 2.5vh 2.5vh 0vh;

    width: 50vw;
    background-color: #000000cb;
}
.about_right {
    
    z-index: 1;
    display: flex;
    align-items: flex-end;
    background-size:cover;
    background-position: center; /* Center the image */
    background-repeat: no-repeat;
    width: 100vw;
}
.about_right div h1 {
    position: relative;
    z-index: 1;
    font-size: 5vh;

    font-family: "Montserrat", sans-serif;    font-optical-sizing: auto;
    font-optical-sizing: auto;
    font-weight: 400;
    font-style: normal;
    padding: 2vh;
    text-align: center;
    color: #fff;
}
.about_right div p {
    font-size: 2vh;
    position: relative;
    z-index: 1;
    font-family: "Montserrat", sans-serif;    font-optical-sizing: auto;
    font-weight: 400;
    font-style: normal;
    padding: 2vh 5vw 2vh 5vw;
    text-align: center;
    color: #fff;
}
.about_left div p {
    font-size: 2vh;
    position: relative;
    z-index: 1;
    font-family: "Montserrat", sans-serif;    font-optical-sizing: auto;
    font-weight: 400;
    font-style: normal;
    padding: 2vh 5vw 2vh 5vw;
    text-align: center;
    color: #fff;
}
.about_button_div {
    justify-content: center;
    display: flex;
}
.about_button_div a {
    margin-top: 3vh;
    margin-bottom: 5vh;

    display: block;
    border: solid #fff 0.5vh;
    border-radius: 1vh;
    font-size: 2vh;
    z-index: 1;
    font-family: "Montserrat", sans-serif;    font-optical-sizing: auto;
    font-optical-sizing: auto;
    font-weight: 500;
    font-style: normal;
    padding: 2vh;
    text-align: center;
    color: #fff;
    transition: 500ms;
    text-decoration: none;
}
.about_button_div a:hover {
    scale: 1.1;
    border: solid #808080 0.5vh;
    color: #808080;
    transition: 500ms;
}
.about_right div {
    z-index: 1;
    text-align: center;

    transition: 500ms;
    position: relative;
    right: -150vw;
    border-radius:2.5vh 0vh 0vh 2.5vh ;

    width: 50vw;
    background-color: #000000cb;
}
#about1 {
    background-image: url(images/about1bg.jpeg);

}
#about2 {
    background-image: url(images/about2bg.jpeg);

}
#about3 {
    background-image: url(images/about3bg.jpg);

}
#about4 {
    background-image: url(images/about_karpacz.jpg);

}
footer {
    justify-content: center;
    font-size: 2vh;
    background-color: #000000;
    color: white;
    text-align: center;
    padding: 0px 0px;
    width: 100%;
    height: 10vh;
    position: relative;
}
footer p {
    display: flex;

    justify-content: center;
    align-items: center;
    margin: 0px;

    height: 10vh;

    

}

footer p a {
    color: white;
    text-decoration: none;

}
footer p a:hover {
    color: rgb(119, 119, 119);
    scale: 1.1;

}
#gallery .gallery-container {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

#gallery .gallery-container img {
    width: calc(33.333% - 10px);
}

form {
    display: block;
    margin: 0 auto;
}


form input {
    font-size: 2.5vh;
    color: rgb(0, 0, 0);
    width: 20vw;
    margin-left: 20vw;

}
form label {
    margin-left: 20vw;

}


form button {
    margin-left: 25vw;
    background-color: #000000;
    color: white;
    width: 10vw;
    margin-top: 5vh;
    height: 5vh;
    border-radius: 5vh;
    border: none;
}

form button:hover {
    background-color: #000000;
}
.contact_box {
    display: flex;
    overflow: hidden;
    border-radius: 20px;
    background-color: #fff;
    margin-left: 12.5vw;
    width: 75vw;
    margin-top: 0px;
    margin-bottom: 5vh;


}
.gallery_box {
    border: #ffffff solid 0.5vw;
    border-radius: 10vh;
    display: flex;
    overflow: hidden;

    border-radius: 5vh;
    background-color: #fff;
    margin-left: 12.25vw;
    width: 75.5vw;
    margin-top: 0px;
    margin-bottom: 5vh;


}
.gallery_box_div {
    display:inline;
    align-items: center;
    align-items: start;
    padding: 0px;
    border-collapse: collapse;
    margin: 0px;
}
.gallery_box_div img{
    object-fit: cover;
    width: 37.5vw;
    height: 40vh;
    

}
.gallery_box_div table tr th a img{
    display: block;
    padding: 0px;
    margin: 0px;
    transition: 500ms;
    z-index: 10;

    
}
.gallery_box_div table tr th a ptext{
    display: flex;
}

.gallery_box_div table tr th a h1{
    margin: 0px;
    padding: 0px;
    height:40vh;
    align-content: center;
    display: block;
    width: 37.5vw;
    position: absolute;
    text-align: center;
    color: #fff;
    z-index: 12;
    transition: 500ms;
    opacity: 0;
    font-size: 2vw;
    font-family: "Montserrat", sans-serif; 
    font-weight: 500;





}

.gallery_box_div table tr th a img:hover{
    filter: brightness(20%);
    transition: 500ms;
    
}
.gallery_box_div table tr th a h1:hover{
    background-color: #000000b2;
    transition: 500ms;
    opacity: 1;


}
#text_top_left {
    border-top-left-radius: 4.5vh;
}
#text_top_right {
    border-top-right-radius: 4.5vh;
}
#text_bottom_left {
    border-bottom-left-radius: 4.5vh;
}
#text_bottom_right {
    border-bottom-right-radius: 4.5vh;
}
.gallery_box_div table {
        border-collapse: collapse;
        border-style: hidden;
        padding: 0px;
        margin: 0px;


}
.gallery_box_div table tr th,.gallery_box_div table tr th {
    border: #ffffff solid 0.5vw;
    padding: 0px;
    margin: 0px;
}
.gallery_box_mobile {
    display: none;
}
.map_embed {

    border:0;
    padding: 0vh 0vw;
    margin: 0px;
}
.kontakt_text h1{
    display: table-cell;

    color: #fff;
    height: 20vh;
    width: 100vw;
    text-align: center;
    font-size: 7.5vh;
    vertical-align: middle;
    text-shadow:
    1px 1px 2px black,
    0 0 1em rgb(0, 0, 0),
    0 0 0.2em rgb(0, 0, 0);
    font-family: "Montserrat", sans-serif;    font-optical-sizing: auto;
    font-weight: 400;


}
.contact_lines img {
    width: 10vh;
    height: 10vh;
}
.contact_lines p {
    padding: 0px;
    margin: 0px 0px 0px 2vw;
    vertical-align: middle;
    line-height: 10vh;
}
.contact_lines p a {
    
    color: #000000;
    text-decoration: none;
    font-size: 2vh;

}
.contact_lines {
    transition: 1000ms;
    scale: 0.1;
    margin: 0px 0px 0px 2vw;
    display: flex;
    padding: 2.5vh ;
}
.contact_box_div {
    display: flex;
    align-items: center;
    height: 75vh;
}
.shake-container {
    text-align: center;
    margin-top: 20px;
}

@keyframes shake {
    0% { transform: rotate(0turn); }
    25% { transform: rotate(0.02turn); }
    50% { transform: rotate(0turn); }
    75% { transform: rotate(-0.02turn); }
    100% { transform: rotate(0turn); }
}

.shake {
    animation: shake 1s ease-in-out;
    animation-iteration-count: 1;
}
.contact_box_div_mobile {
 display: none;       
}
.pricing_box {
    border: #ffffff solid 0.5vw;
    overflow: hidden;

    display: flex;
    overflow: hidden;
    border-radius: 5vh;
    background-color: #fff;
    margin-left: 12.25vw;
    width: 75.5vw;
    margin-top: 0px;
    margin-bottom: 5vh;


}
.pricing_box_div {
    display:inline;
    align-items: center;
    align-items: start;
    padding: 0px;
    border-collapse: collapse;

    margin: 0px;
}
.pricing_box_div img{
    
    object-fit: cover;
    width: 37.5vw;
    height: 40vh;
    

}
.pricing_box_div table tr th a img{
    display: block;
    padding: 0px;
    margin: 0px;
    transition: 500ms;
    z-index: 10;

    
}
.pricing_box_div table tr th a{

    display: flex;
    text-decoration: none;

}

.pricing_box_div table tr th a h1{
    width: 37.5vw;
    font-weight: 500;
    margin: 0px;
    padding: 0px;
    padding-bottom: 2.5vh;
    align-content: center;
    text-align: center;
    color: #000000;
    z-index: 12;
    transition: 500ms;
    font-size: 2vw;
    font-family: "Montserrat", sans-serif; 
    display: block;
    text-decoration: none;




}
.pricing_box_div table tr th a h2{
    width: 37.5vw;
    font-weight: 400;

    margin: 0px;
    padding: 0px;
    align-content: center;
    text-align: center;
    color: #000000;
    z-index: 12;
    transition: 500ms;
    font-size: 1.5vw;
    font-family: "Montserrat", sans-serif; 
    display: block;
    text-decoration: none;




}
.pricing_box_div table tr th a ptext{
    display: block;
}
.pricing_box_div table {
        border-collapse: collapse;
        border-style: hidden;
        padding: 0px;
        margin: 0px;


}
.pricing_box_div table tr th,.pricing_box_div table tr th {
    border: #ffffff solid 0.5vw;
    padding: 0px;
    margin: 0px;
}
.pricecheckbutton {


    margin-top: 2vw;

    justify-content: center;
    width: 100% !important;

    text-align: center;
    display: flex;

}
.pricecheckbuttontext {
    font-family: "Montserrat", sans-serif; 
    color: #000000;
    border: solid #000000 0.5vh;
    border-radius: 2vh;


    font-size: 3vh;
    display: block;
    width: 15vw;
    padding: 2.5vh 2.5vh;
    transition: 500ms;


}
.pricecheckbuttontext:hover {
    scale: 1.1;
    transition: 500ms;
}
.pricing_box_mobile {
    display: none;
}
.gallery_fullscreen {
    
    width: 100vw;
    height: 100vh;
    position: fixed;
    top: 0px;
    left: 0px;
    display: none;
    align-content: center;
    z-index: 1000;
    background-color: #000000b7;
    overflow: hidden;
    text-align: center;
}
.stop-scrolling {
    height: 100%;
    overflow: hidden;
  }
.main_gallery_image {
    border: #fff solid 0.5vw;
    border-radius: 2vw;
    display: block;
    max-width: 70vw;
    max-height: 80vh;
    margin-left: auto;
    margin-right: auto;
    background-color: #fff;

}
.back h1{
    font-family: "Nanum Gothic", sans-serif;

    display: block;
    border-radius: 2vw;
    width: 7.5vw;
    font-size: 10vh;
    height: 15vh;
    background-color: #ffffff;
    position: fixed;
    top: 42.5vh;
    left: 5vw;
    transition: 500ms;
    line-height: 15vh;
    padding: 0px;
    margin: 0px;
    font-weight: 100;

}
.back h1:hover {
    scale: 1.1;    
    transition: 500ms;
}
.forward h1{
    font-family: "Nanum Gothic", sans-serif;
    display: block;
    border-radius: 2vw;
    width: 7.5vw;
    font-size: 10vh;
    height: 15vh;
    background-color: #ffffff;
    position: fixed;
    top: 42.5vh;
    left: 87.5vw;
    transition: 500ms;
    line-height: 15vh;
    padding: 0px;
    margin: 0px;
    font-weight: 100;


}
.forward h1:hover {
    scale: 1.1;    
    transition: 500ms;
}
.loader {
    border: 16px solid #f3f3f3; /* Light grey */
    border-top: 16px solid #000000; /* Blue */
    border-radius: 50%;
    width: 10vw;
    height: 10vw;
    animation: loaderspin 2s linear infinite;
    position: fixed;
    bottom:calc(50vh - 5vw);
    left: 45vw;
}
@keyframes loaderspin {
    0% {
        transform: rotate(0deg);
    }
    100% {
        transform: rotate(360deg);
    }
}
.loadingbox{
    background-color: #000000;
    display: block;
    width: 100vw;
    height: 100vh;
    position: fixed;
    top: 0px;
    left: 0px;
    z-index: 2000;
}


.loadingboxgallery{
    display: none;
    width: 100vw;
    height: 100vh;
    position: fixed;
    top: 0px;
    left: 0px;
    z-index: 2000;
}
.gallery_close_button h1{

    border-radius: 100%;
    padding: 0px;
    margin: 0px;
    display: block;
    position: fixed;
    top: 10vh;
    left: 90vw;
    font-size: 6vh;
    line-height: 10vh;
    font-weight: 100;
    text-align: center;

    line-height: 10vh;
    color: #000000;
    background-color: #fff;
    width: 10vh;
    height: 10vh;
  }
.date_select_fullscreen {
    
    width: 100vw;
    height: 100vh;
    position: fixed;
    top: 0px;
    left: 0px;
    display: none;
    align-content: center;
    z-index: 3000;
    background-color: #000000b7;
    overflow: hidden;
    text-align: center;
}
.date_select_fullscreen_div {
    width: 80vw;
    height: 80vh;
    position: fixed;
    top: 10vh;
    left: 10vw;
    background-color: #fff;
    border-radius: 5vh;
    display: flex;

}
.date_select_fullscreen_div div {
    height: 100%;
    width: 50%;

}
.date_select_fullscreen_div div h1{
    font-size: 2vw;
    margin-top: 5vh;
    font-family: "Montserrat", sans-serif; 

}
.date_select_fullscreen_div div h2{
    text-align: center;
    font-size: 1.5vw;
    margin-top: 5vh;
    font-family: "Montserrat", sans-serif; 

}
.date_select_fullscreen_div div p{
    font-size: 1vw;

    padding-left: 5vw;
    padding-right: 5vw;
}
.date_select_fullscreen_div img {
    width: 50%;
    height: 100%;
    display: flex;
    border-top-left-radius: 5vh;
    border-bottom-left-radius: 5vh;

    object-fit: cover;

}
.table_select_desk {
    width: 80vw;
    height: 80vh;
}   
.table_select_desk tr th {
    padding: 0px;
    margin: 0px;
}
.table_select_desk thead {
    display: none;
}

.table_select_desk tr th {
    border-radius: 3vh;
    border: #000000 solid 0.5vh;
    width: calc((100% / 3) - 4vh);
    margin: 1vh;
    padding: 0px;
    height: 36vh;
    display: inline-flex;
}
.table_select_desk_days tr {
    display: block;

}
.table_select_desk_days_th {
    display: block;
    padding: 0.25vh !important;
    margin: 0.5vh !important;
    height: 2.5vh !important;
    width: 3vw !important;
    border-radius: 1vh !important;
}
.dateselector {
    font-size: 2.5vh;
    position: relative;
    border-radius: 1vh;
    align-self: center;
    border: #000000 solid 0.25vh;
    font-family: "Montserrat", sans-serif; 

}
.lightpick {
    position: absolute !important;
    top: 40% !important;
    left: calc(50vw - 148px);
}
.lockpickmod {
    display: none !important;
}
.reservequerrybutton {
    font-family: "Montserrat", sans-serif; 
    color: #000000;
    border: solid #000000 0.5vh;
    border-radius: 1vw;
    align-self: center;
    display: block;
    font-size: 3vh;
    width: 26.5vw;
    margin-top: 5vh;

    margin-left: 5vw;
    padding:1.5vw;
    transition: 500ms;


}
.reservequerrybutton:hover {
    scale: 1.1;
    transition: 500ms;
}
.login_box {
    background-color: #fff;
    width: 60vw;
    margin-left: 20vw;
    padding-top: 20vh;
    padding-bottom: 20vh;
    margin-top: 10vh;
    margin-bottom: 10vh;
    border-radius: 10vh;


}
.cookie-popup {
    position: fixed;
    bottom: 20px;
    left: 20px;
    right: 20px;
    padding: 20px;
    background-color: #333;
    color: white;
    font-size: 16px;
    text-align: center;
    border-radius: 8px;
    display: none; /* Domyślnie ukryte */
    z-index: 1000;
}

.cookie-popup button {
    background-color: #ff9800;
    color: white;
    border: none;
    padding: 10px 20px;
    font-size: 16px;
    cursor: pointer;
    border-radius: 4px;
    margin-top: 10px;
}

.cookie-popup button:hover {
    background-color: #e68900;
}
}


/*----------------------------------------------na telefony---------------------------------------------------*/





@media (min-height: 90vw) {


    html{
        scroll-behavior: smooth; 
        max-width: 100%;
        overflow-x: hidden;
    
    }
    body {
        background-image: url(images/karkonosze-4376304_1920.jpg);

        max-width: 100%;
        overflow-x: hidden;
        font-family: Arial, sans-serif;
        margin: 0px;
        padding: 0px;
        background-color: #f5f5f5;
    
    }
    .megabox {
        background-size:100vw;
        background-position: center;
        background-image: url(images/background_mobile.jpeg);

    
    }
    .headerappear{
        display: none;
    }
    .headerappear_mobile {

        z-index: 99;
        width: 100vw;

        display: block;
        padding: 0px ;
        transition: 500ms;
    }
    
    .navbarrow {
        position: sticky !important;
        top: 0px !important;
        margin: 0px;
        padding: 0px;
        display: block;
        background: rgb(0,0,0);
        text-align: center;
        z-index: 99;
    }
    
    .navbarrow li {
    
        transition: 500ms;
        display: flex;
        justify-content: space-between;
        line-height: 15vh;
        padding: 0px 1vw;
        z-index: 5;
    }
    
    .navbarmark a{
        width: 100vw;
        font-size: 2vh;
        display: block;
        height: 6vh;
        padding: 0px 1vw;
        margin: 2vh 0px;
        color: #fff;
        line-height: 6vh;
        text-decoration: none;
        transition: 500ms;
    
    
    }
    .navbarmark a:hover {
        color: #a8a8a8;
        transition: 500ms;
        scale: 1.1;
    }
    .navbarmark img{
        height: 13vh;
        margin: 1vh;
    
    }
    #listimage {
        filter: invert(1);

    }
    .navbarlink {
        width: 100vw;

        display: none;
    
    }
    
    ul li .dropdown-content {
        display: none;
        background-color: #bde0fe;
        z-index: 1;
    
    
    }
    main {
        min-height: 85vh;
        padding: 0px;
    }
    .welcometext h1{
        margin: 0px;
        display: table-cell;
        padding: 0px 10vw;

        color: #fff;
        height: 35vh;
        width: 100vw;
        text-align: center;
        font-size: 5vh;
        vertical-align:middle;
        text-shadow:
        1px 1px 2px black,
        0 0 1em rgb(0, 0, 0),
        0 0 0.2em rgb(0, 0, 0);
    }
    .welcomebutton {
        justify-content: center;
    
        text-align: center;
        display: flex;
        margin: 0px;
        color: white;
    
    }
    .welcomebutton h2 {
        border: solid #fff 0.5vh;

        font-size: 3vh;

        margin-top: 5vh;
        display: block;
        padding: 2.5vh 2.5vh;
        border-radius: 2vh;
        background-color: #00000085;
        transition: 500ms;
    
    
    }
    .welcomebutton h2:hover {
        scale: 1.1;
        transition: 500ms;
    }
    .more {
        transition: 500ms;
    
        display: block;
        text-decoration: none;
        padding-bottom: 18vh;
    
    
    }
    .more:hover{
        transition: 500ms;
        scale: 1.1;
    
    }
    .more h1{
        margin-bottom: 5vh;
        margin-bottom: 0px;
        z-index: 1;
        height: 10vh;
        display: block;
        text-align: center;
        color: #fff;
        text-shadow:
        1px 1px 2px black,
        0 0 1em rgb(0, 0, 0),
        0 0 0.2em rgb(0, 0, 0);
    }
    .arrow-container {
        text-align: center;
        margin-top: -2.5vh;
    }
    
    .arrow {
        width: 2vh;
        height: 2vh;
        border-right: 5px solid #fff;
        border-bottom: 5px solid #fff;
        margin: 0 auto;
        animation: bounce 2s infinite;
        
    }
    
    @keyframes bounce {
        0%, 20%, 50%, 80%, 100% {
            transform: translateY(0) rotate(45deg);
        }
        40% {
            transform: translateY(-15px) rotate(45deg);
        }
        60% {
            transform: translateY(-10px) rotate(45deg);
        }
    }
    .about_left {
        
        display: flex;
        justify-content: space-between;
        background-color: #00000088;
    
        background-size:cover;
        background-position: center; /* Center the image */
        background-repeat: no-repeat;
    
    }
    .about_left div h1 {
        font-family: "Montserrat", sans-serif;    font-optical-sizing: auto;
        font-optical-sizing: auto;
        font-weight: 400;
        font-style: normal;
        padding: 2vh;
        text-align: center;
        color: #fff;
    }
    .about_left div {
        display: block;
        text-align: center;
        transition: 500ms;
        position: relative;
        left: -100vw;
    
        width: 1000vw;
        background-color: #000000cb;
    }
    .about_right {
        
        z-index: 1;
        display: flex;
        align-items: flex-end;
        background-size:cover;
        background-position: center; /* Center the image */
        background-repeat: no-repeat;
        width: 100vw;
    }
    .about_right div h1 {
        position: relative;
        z-index: 1;
        font-family: "Montserrat", sans-serif; 
        font-optical-sizing: auto;
        font-weight: 400;
        font-style: normal;
        padding: 2vh;
        text-align: center;
        color: #fff;
    }
    .about_right div p {
        font-size: 2vh;
        position: relative;
        z-index: 1;
        font-family: "Montserrat", sans-serif;
        font-optical-sizing: auto;
        font-weight: 400;
        font-style: normal;
        padding: 2vh 10vw 2vh 10vw;

        text-align: center;
        color: #fff;
    }
    .about_left div p {
        font-size: 2vh;
        position: relative;
        z-index: 1;
        font-family: "Montserrat", sans-serif;
        font-optical-sizing: auto;
        font-weight: 400;
        padding: 2vh 10vw 2vh 10vw;

        font-style: normal;
        text-align: center;
        color: #fff;
    }
    .about_button_div {
        justify-content: center;
        display: flex;
    }
    .about_button_div a {
        margin-top: 3vh;
        margin-bottom: 5vh;
    
        display: block;
        border: solid #fff 0.5vh;
        border-radius: 1vh;
        font-size: 2vh;
        z-index: 1;
        font-family: "Montserrat", sans-serif; 
        font-optical-sizing: auto;
        font-weight: 500;
        font-style: normal;
        padding: 2vh;
        text-align: center;
        color: #fff;
        transition: 500ms;
        text-decoration: none;
    }
    .about_button_div a:hover {
        scale: 1.1;
        border: solid #808080 0.5vh;
        color: #808080;
        transition: 500ms;
    
    
    }
    .about_right div {
        z-index: 1;
        text-align: center;
    
        transition: 500ms;
        position: relative;
        right: -200vw;
    
        width: 100vw;
        background-color: #000000cb;
    }
    #about1 {
        background-image: url(images/about_outside.jpg);
    
    }
    #about2 {
        background-image: url(images/about_interior_2.jpg);
    
    }
    #about3 {
        background-image: url(images/about_terrain.jpg);
    
    }
    #about4 {
        background-image: url(images/about_karpacz.jpg);
    
    }
    footer {
        scroll-behavior: smooth;
    
        background-color: #000000;
        color: white;
        text-align: center;
        padding: 10px 0;
        width: 100vw;
    }
    footer p a {
        color: white;
        text-decoration: none;

    }
    
    #gallery .gallery-container {
        display: flex;
        flex-wrap: wrap;
        gap: 10px;
    }
    
    #gallery .gallery-container img {
        width: calc(33.333% - 10px);
    }
    
    form {
        display: block;
        margin: 0 auto;
    }
    
    
    form input {
        font-size: 2.5vh;
        color: rgb(0, 0, 0);
        width: 40vw;
        margin-left: 20vw;
    
    }
    form label {
        margin-left: 20vw;
    
    }
    
    
    form button {
        margin-left: 25vw;
        background-color: #000000;
        color: white;
        width: 30vw;
        margin-top: 5vh;
        height: 10vh;
        font-size: 2.5vh;
        border-radius: 5vh;
        border: none;
    }
    
    form button:hover {
        background-color: #000000;
    }
    .contact_box {
        border-radius: 1vh;

        display: block;
        overflow: hidden;
        background-color: #fff;
        margin-left: 0vw;
        width: 80vw;
        margin-top: 0px;
        margin-bottom: 5vh;
    
    
    }
    .map_embed {
    
        border:0;
        padding: 0vh 0vw;
        margin: 0px;
    }
    #main_kontakt {
        width: 80vw;
        padding-left: 10vw;

    }
    .kontakt_text h1{
        display: table-cell;
    
        color: #fff;
        height: 20vh;
        width: 80vw;
        text-align: center;
        font-size: 5vh;
        vertical-align: middle;
        text-shadow:
        1px 1px 2px black,
        0 0 1em rgb(0, 0, 0),
        0 0 0.2em rgb(0, 0, 0);
        font-family: "Montserrat", sans-serif;   
         font-optical-sizing: auto;
         font-weight: 400;
    
    }
    .contact_lines img {
        display: none;
        width: 10vh;
        height: 10vh;
    }
    .contact_lines p {
        display: none;
        padding: 0px;
        margin: 0px 0px 0px 2vw;
        vertical-align: middle;
        line-height: 10vh;
    }
    .contact_lines p a {
        
        color: #000000;
        text-decoration: none;
        font-size: 2vh;
    
    }
    .contact_lines {
        transition: 1000ms;
        scale: 0.1;
        margin: 0px 0px 0px 2vw;
        display: flex;
        padding: 2.5vh ;
    }
    .contact_box_div {
        display: none;
        align-items: center;
        height: 7vh;
    }
    .shake-container {
        text-align: center;
        margin-top: 20px;
    }
    
    @keyframes shake {
        0% { transform: rotate(0turn); }
        25% { transform: rotate(0.02turn); }
        50% { transform: rotate(0turn); }
        75% { transform: rotate(-0.02turn); }
        100% { transform: rotate(0turn); }
    }
    
    .shake {
        animation: shake 1s ease-in-out;
        animation-iteration-count: 1;
    }
    .contact_box_div_mobile {
        display: block;
        font-family: "Montserrat", sans-serif; 

        text-align: center;
        
    }
    .contact_box_div_mobile div {
        display: block;
        margin-bottom: 5vh;

    }
    .contact_box_div_mobile div a{
        color: #000000;
        text-decoration: none;
    }
    .contact_lines_mobile img {
        width: 10vh;
        height: 10vh;
    }
    .contact_box_div_mobile h1 {
        font-weight: 300;

    }
    .gallery_box {

        overflow: hidden;
        display: flex;
        overflow: hidden;
        background-color: #fff;
        margin-top: 0px;
        margin-bottom: 5vh;
    
    
    }
    .gallery_box_div {
        display:flex;
        align-items: center;
        align-items: start;
        padding: 0px;
        border-collapse: collapse;
    
        margin-bottom: 5vh;

        
    }
    .gallery_box_div img{

        
        object-fit: cover;
        width: 80vw;
        filter: brightness(50%);

        height: 40vh;
    }

    .gallery_box_div table tr th a div{
        margin: 0px;
        padding: 0px;
        border: 0px;
        display: flex;
        padding: 0px;
        margin: 0px;
        transition: 500ms;
        z-index: 10;
        border: #ffffff solid 0.5vh;



        
    }
    .gallery_box_div table tr th a div img{
        margin: 0px;
        padding: 0px;
        object-fit: cover;
        width: 80vw;

        height: 40vh;

    }
 
    .gallery_box_div table{
        display: flex;
    }
    .gallery_box_div table tr th a h1{
        padding: 0px;
        margin-left: 0.5vh;
        align-content: center;
        display: block;
        width: 70vw;
        position: absolute;
        text-align: center;
        color: #fff;
        z-index: 12;
        transition: 500ms;
        font-size: 3vh;
        font-family: "Montserrat", sans-serif; 
        padding-top: 17vh;
        padding-left: 5vw;
        padding-right: 5vw;

        font-weight: 500;
    
    
    
    
    }
    
    
    #text_top_mobile {
        border-top-left-radius: 4.5vh;
        border-top-right-radius: 4.5vh;

    }

    #text_bottom_mobile {
        border-bottom-left-radius: 4.5vh;
        border-bottom-right-radius: 4.5vh;

    }

    .gallery_box_div table {
            border-collapse: collapse;
            border-style: hidden;
            padding: 0px;
            margin: 0px;

    
    
    }
    .gallery_box_div table tr th,.gallery_box_div table tr th {
        padding: 0px;
        margin: 0px;
        border-radius: 5vh;

    }
    .gallery_box {
        display: none;
    }
    .gallery_box_mobile {

        display: block;
    }
    .pricing_box_mobile {
        border: #ffffff solid 0.5vw;
        overflow: hidden;
    
        display: flex;
        overflow: hidden;
        border-radius: 5vh;
        background-color: #fff;
        margin-left: 0vw;
        width: 80vw;
        margin-top: 0px;
        margin-bottom: 5vh;
    
    
    }
    .pricing_box_div {
        display:inline;
        align-items: center;
        align-items: start;
        padding: 0px;
        border-collapse: collapse;
    
        margin: 0px;
    }
    .pricing_box_div img{
        object-fit: cover;
        width: 80vw;
        height: 40vh;
        
    
    }
    .pricing_box_div table tr th a img{
        display: block;
        padding: 0px;
        margin: 0px;
        transition: 500ms;
        z-index: 10;
    
        
    }
    .pricing_box_div table tr th a{
    
        display: flex;
        text-decoration: none;
    
    }
    
    .pricing_box_div table tr th a h1{
        width: 80vw;
    
        margin: 0px;
        padding: 0px;
        align-content: center;
        text-align: center;
        color: #000000;
        z-index: 12;
        transition: 500ms;
        font-size: 3vh;
        font-family: "Montserrat", sans-serif; 
        font-weight: 500;
        display: block;
        text-decoration: none;
    
    
    
    
    }
    .pricing_box_div table tr th a h2{
        width: 75vw;
    
        margin: 0px;
        padding: 0px;
        align-content: center;
        text-align: center;
        color: #000000;
        z-index: 12;
        transition: 500ms;
        font-size: 2vh;
        font-family: "Montserrat", sans-serif; 
        display: block;
        text-decoration: none;
        font-weight: 400;

    
    
    
    
    }
    .pricing_box_div table tr th a ptext{
        display: block;
    }
    .pricing_box_div table {
            border-collapse: collapse;
            border-style: hidden;
            padding: 0px;
            margin: 0px;
    
    
    }
    .pricing_box_div table tr th,.pricing_box_div table tr th {
        border: #ffffff solid 0.5vw;
        padding: 0px;
        margin: 0px;
    }
    .pricecheckbutton {
    
    
        margin-top: 2vw;
    
        justify-content: center;
        width: 100% !important;
    
        text-align: center;
        display: flex;
    
    }
    .pricecheckbuttontext {
        font-weight: 500;

        font-family: "Montserrat", sans-serif; 
        color: #000000;
        border: solid #000000 0.5vh;
        border-radius: 2vh;
    
    
        font-size: 3vh;
        display: block;
        width: 50vw;
        padding: 2.5vh 2.5vh;
        transition: 500ms;
    
    
    }
    .pricecheckbuttontext:hover {
        scale: 1.1;
        transition: 500ms;
    }
    .pricing_box {
        display: none;
    }
    .gallery_fullscreen {
    
        width: 100vw;
        height: 100vh;
        position: fixed;
        top: 0px;
        left: 0px;
        display: none;
        z-index: 1000;
        background-color: #000000b7;
        overflow: hidden;
        overflow-x: hidden;

        text-align: center;
    }
    .stop-scrolling {
        height: 100vh;
        overflow: hidden;
        overflow-x: hidden;
        position: relative
      }
    .main_gallery_image {
        border: #fff solid 0.5vw;
        border-radius: 2vw;
        display: block;
        max-width: 90vw;
        max-height: 65vh;

        margin-left: auto;
        margin-right: auto;
        margin-top: 7.5vh;
        margin-bottom: auto;

        height: auto;
    }
    .back h1{
        font-family: "Nanum Gothic", sans-serif;

        display: block;
        border-radius: 2vw;
        width: 35vw;
        font-size: 7vh;
        height: 10vh;
        background-color: #ffffff;
        position: fixed;
        top: 77.5vh;
        left: 10vw;
        transition: 500ms;
        line-height: 10vh;
        padding: 0px;
        margin: 0px;
        -webkit-touch-callout: none;
        -webkit-user-select: none;
        -khtml-user-select: none;
        -moz-user-select: none;
        -ms-user-select: none;
        user-select: none;
    
    }
    .back h1:active {
        scale: 1.1;    
        transition: 500ms;
    }
    .forward h1{
        font-family: "Nanum Gothic", sans-serif;

        display: block;
        border-radius: 2vw;
        width: 35vw;
        font-size: 7vh;
        height: 10vh;
        background-color: #ffffff;
        position: fixed;
        top: 77.5vh;
        left: 55vw;
        transition: 500ms;
        line-height: 10vh;
        padding: 0px;
        margin: 0px;
        -webkit-touch-callout: none;
        -webkit-user-select: none;
        -khtml-user-select: none;
        -moz-user-select: none;
        -ms-user-select: none;
        user-select: none;
    
    }
    .forward h1:active {
        scale: 1.1;    
        transition: 500ms;
    }
    .loader {
        display: block;
        border: 16px solid #f3f3f3; /* Light grey */
        border-top: 16px solid #000000; /* Blue */
        border-radius: 50%;
        width: 10vw;
        height: 10vw;
        animation: loaderspin 2s linear infinite;
        position: fixed;
        bottom:calc(50vh - 5vw);
        left: 45vw;
    }
    @keyframes loaderspin {
        0% {
            transform: rotate(0deg);
        }
        100% {
            transform: rotate(360deg);
        }
    }
    .loadingbox{
        background-color: #000000;
        display: block;
        width: 100vw;
        height: 100vh;
        position: fixed;
        top: 0px;
        left: 0px;
        z-index: 2000;
    }
    .loadingboxgallery{
        display: none;
        width: 100vw;
        height: 100vh;
        position: fixed;
        top: 0px;
        left: 0px;
        z-index: 2000;
    }
    .gallery_close_button h1{
        
        border-radius: 100%;
        padding: 0px;
        margin: 2vh;
        display: block;
        position: fixed;
        top: 0px;
        right: 0px;
        font-size: 6;
        line-height: 5vh;
        text-align: center;
    
        line-height: 5vh;
        color: #000000;
        background-color: #fff;
        width: 5vh;
        height: 5vh;
      }
      .date_select_fullscreen {
    
        width: 100vw;
        height: 100vh;
        position: fixed;
        top: 0px;
        left: 0px;
        display: none;
        align-content: center;
        z-index: 3000;
        background-color: #000000b7;
        overflow: hidden;
        text-align: center;
    }
    .date_select_fullscreen_div {
        width: 80vw;
        height: 80vh;
        position: fixed;
        top: 10vh;
        left: 10vw;
        background-color: #fff;
        border-radius: 5vh;
        display: block;
    
    }
    .date_select_fullscreen_div div {
        height: 100%;
        width: 50%;
    
    }
    .date_select_fullscreen_div div h1{
        width: 80vw;
        display: block;
        font-size: 2.5vh;
        margin-top: 5vh;
        text-align: center;
        font-family: "Montserrat", sans-serif; 
    
    }
    .date_select_fullscreen_div div h2{
        width: 80vw;

        text-align: center;
        font-size: 2.5vh;
        margin-top: 1vh;
        font-family: "Montserrat", sans-serif; 
    
    }
    .date_select_fullscreen_div div p{
        font-size:min(1.5vh,3.5vw) ;
        width: 70vw;
        text-align: center;
    
        padding-left: 5vw;
        padding-right: 5vw;
    }
    .date_select_fullscreen_div img {
        width: 100%;
        height: 30%;
        display: flex;
        border-top-left-radius: 5vh;
        border-top-right-radius: 5vh;
    
        object-fit: cover;
    
    }
    .table_select_desk {
        width: 80vw;
        height: 80vh;
    }   
    .table_select_desk tr th {
        padding: 0px;
        margin: 0px;
    }
    .table_select_desk thead {
        display: none;
    }
    
    .table_select_desk tr th {
        border-radius: 3vh;
        border: #000000 solid 0.5vh;
        width: calc((100% / 3) - 4vh);
        margin: 1vh;
        padding: 0px;
        height: 36vh;
        display: inline-flex;
    }
    .table_select_desk_days tr {
        display: block;
    
    }
  
    .dateselector {
        pointer-events:stroke;
        margin: 5vw;
        width: 70vw;
        font-size: 2.5vh;
        position: relative;
        border-radius: 1vh;
        align-self: center;
        border: #000000 solid 0.25vh;
        font-family: "Montserrat", sans-serif; 
        margin-top: 0vh;
        margin-bottom: 2.5vh;

    
    }
    .lightpick {
        position: absolute !important;
        top: 40% !important;
        left: calc(50vw - 148px);
    }
    .lockpickmod {
        display: none !important;
    }
    .reservequerrybutton {
        font-family: "Montserrat", sans-serif; 
        color: #000000;
        border: solid #000000 0.5vh;
        border-radius: 1vh;
        margin: 0px 0px 0px 15vw;
        align-self: center;
        display: block;
        font-size: 2.5vh;
        font-weight: 500;
        width: 50vw;
    
        padding:1vh;
        transition: 500ms;
    
    
    }
    .reservequerrybutton:hover {
        scale: 1.1;
        transition: 500ms;
    }
    pricedisplay h3 {
        display: block;
        width: 80vw;
        text-align: center;
        font-size: min(5vw,3.5vh);
        margin-top: 0px;
        margin-bottom: 2.5vh;
        font-weight: 500;
    }
    .login_box {
        background-color: #fff;
        width: 80vw;
        margin-left: 10vw;
        padding-top: 20vh;
        padding-bottom: 20vh;
        margin-top: 10vh;
        margin-bottom: 10vh;
        border-radius: 10vh;
    
    
    }
    .cookie-popup {
        position: fixed;
        bottom: 20px;
        left: 20px;
        right: 20px;
        padding: 20px;
        background-color: #333;
        color: white;
        font-size: 16px;
        text-align: center;
        border-radius: 8px;
        display: none; /* Domyślnie ukryte */
        z-index: 1000;
    }
    
    .cookie-popup button {
        background-color: #ff9800;
        color: white;
        border: none;
        padding: 10px 20px;
        font-size: 16px;
        cursor: pointer;
        border-radius: 4px;
        margin-top: 10px;
    }
    
    .cookie-popup button:hover {
        background-color: #e68900;
    }
    }