:root {
    --color_00: rgb(255,255,255);
    --color_05: rgb(171,171,171);
    --color_10:  rgb(50,50,50);
    --color_11:  rgb(0,0,0);
    --color_01: #406b9c;
    --color_02: #828282;
    --color_31: rgb(168,226,244);
    --color_32: rgb(124,205,234);

    --color_33: rgb(13,168,224);
    --color_4:  rgb(0,136,203);
    --color_34: rgb(8,112,149);
    --color_35: rgb(4,56,74);

    --accent: #FDDCA5;

    --font1:  "Oswald", sans-serif;
    --font2:  "Nunito", serif;
    --padding: 120px 0;
}

body, html {
    height: 100%;
    margin: 0;
    padding: 0;
    font-optical-sizing: auto;
    font-family: var(--font2);
    font-size: 20px;
    color: var(--color_10);
}
*{box-sizing: border-box}

h1,h2,h3,h4,h5{font-family: var(--font1); color: var(--color_34);    font-weight: 400;}
h1,h2{text-align: center; font-size: 48px; margin-top: 0; padding-top: 0; text-shadow: 1px 1px 1px #fff;padding-bottom: 40px;}
h2{font-size: 42px;}
h5{font-size: 20px; margin: 0;}
.blog h2{position: relative; font-size: 34px; margin: 34px; padding: 0;}
.blog h2:after{
    content: ' ';
    position: absolute;
    width: 90px;
    height: 3px;
    background: #087095;
    margin: 0 auto;
    display: block;
    left: 0;
    right: 0;
    bottom: -10px;
}
.blog h2.pt-0:after{
    bottom: -20px;
}
a{color: var(--color_01);text-decoration: none; transition: all ease-in-out 0.35s;}
a:hover{color: var(--color_02);}
.container{max-width: 1048px;margin: 0 auto;    width: 100%;}
.inner-content{width: 100%; padding: 0 24px;}
section{padding: var(--padding); min-height: 100vh;     position: relative;}
.h-auto{min-height: auto}
.header {
    position: fixed;
    width: 100%;
    top: 0;
    background: var(--color_00);
    z-index: 301;
    box-shadow: 0 16px 24px rgba(104, 106, 115, .08), 0 2px 8px rgba(104, 106, 115, .06);
}
blockquote{
    font-style: italic;
    font-weight: bold;
    text-align: center;
}

.parallax {
    background-image: url('/themes/images/bg-1.webp');
    min-height: 100vh ;
    background-attachment: fixed;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}
.parallax-2{background-image: url("/themes/images/bg-3.webp");}
.parallax-3{background-image: url("/themes/images/bg-4.webp");}
.parallax-4{background-image: url("/themes/images/bg-5.webp");}
.parallax-5{background-image: url("/themes/images/bg-2.webp");}
.parallax-6{background-image: url("/themes/images/bg-6.webp");}
.parallax-7{background-image: url("/themes/images/bg-8.webp");}
.parallax-9{background-image: url("/themes/images/bg-9.webp");}
.parallax-10{background-image: url("/themes/images/bg-10.webp");}
.parallax-11{background-image: url("/themes/images/bg-11.webp");}
.parallax-12{background-image: url("/themes/images/bg-blog.jpg");}
.parallax-13{background-image: url("/themes/images/blog/blog-1.jpg");}
.parallax-14{background-image: url("/themes/images/blog/blog-2.jpg");}
.parallax-15{background-image: url("/themes/images/blog/blog-6.jpg");}

.parallax h1{text-shadow: 1px 1px 2px #000, 1px 1px 2px #000, 1px 1px 2px #000, 1px 1px 2px #000; font-weight: 700;}
.content {

    position: relative;
    z-index: 200;
}

.main-menu{list-style: none;display: flex;justify-content: space-between; padding: 10px 0;font-size: 20px}
.menu-button{
    width: 36px;
    background: var(--color_01);
    height: 36px;
    border-radius: 4px;
    color: var(--color_00);
    margin-top: -5px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-evenly;
    cursor: pointer;
    display: none;
}
.menu-button span{
    border: 2px solid #fff;
    display: block;
    color: #fff;
    background: #fff;
    width: 70%;
    border-radius: 4px;
}

.menu-booking a{
    padding: 7px 27px;
    margin-top: -7px;
    border: 1px solid var(--color_01);
    font-size: 16px;
    font-weight: bold;
}
.menu-booking a:hover{
    background: var(--color_01);
    border: 1px solid var(--color_02);
    color: #fff;
}
.main-logo{background:url("/themes/images/logo-2.webp") no-repeat center; width: 206px; height: 162px; margin: 0 auto;     padding-top: 35vh; background-position-y: bottom;}
.main-logo-txt svg{ width: 36px; height: 36px;}
.main-logo-txt{ display: flex; justify-content: space-evenly; align-items: center; color: #fff; font-weight: bolder; padding-top: 20px;font-style: unset;width: 250px;margin-left: -20px;}
.center{text-align: center}
.justify{text-align: justify; text-indent: 40px}
.fullwidth{width: 100%; max-width: 100%}
.small-title{    font-size: 24px;margin-top: 0px;display: block;}
.intro{background: #eff5f7; color: #406B9C}
.swimming-pool-time,
.zaezd-viezd{display: grid;grid-template-columns: 1fr 1fr; font-size: 90px; color: var(--accent); }
.swimming-pool-time div,
.zaezd-viezd div{position: relative; text-align: center; font-weight: bolder;}
.swimming-pool-time div span,
.zaezd-viezd div span{position: absolute; left: 0; right: 0; display: block; font-weight: 400; margin: 0 auto; top:35%; color: var(--color_34);font-size: 20px;}
.swimming-pool-time{font-size: 60px;max-width: 500px;}
.swimming-pool-time div{color: #eff5f7}

.swimming-pool-time div span{
    top:25%;
    font-size: 17px;
}
.sw-h5{margin-left: 50px;margin-bottom: 10px;}
.btn{
    display: flex;
    /* min-width: 380px; */
    font-size: 16px;
    max-width: 420px;
    text-align: center;
    padding: 10px 0;
    margin: 10px auto;
    border: 1px solid;
    justify-content: center;
    align-items: center;
    transition: ease-in-out all 0.3s;
    font-weight: 700;
}
.btn:hover{
    background: var(--color_01);
    border: 1px solid var(--color_02);
    color: #fff;
}
.btn.white:hover{
    background: white;
    color: var(--color_01);
}
.flex-column-center{
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}
.mt-0{margin-top: 0px}
.mt-40{margin-top: 40px}
.mt-60{margin-top: 60px}
.w-700{font-weight: 700}
.pt-0{padding-top: 0}
.lh-1{line-height: 1}
.white{color: white}
.blue{color: var(--color_34)}
.overlay{background: #00000050;position: absolute;width: 100%;height: 100%;left: 0;right: 0;top: 0;}
.swimming-pool-text{
    background: url("/themes/images/waterpool.svg") no-repeat left top;
    padding-left: 220px;
    padding-top: 10px;
}
.w-400{ width: 400px}
.float-right{float: right}
.gallery-3{display: flex;gap: 20px; justify-content: space-around; align-items: center;max-width: 100%}
.gallery-3 img{max-width: 30%; border-radius: 50%;     }
.table-text-and-image{
    display: grid;
    grid-template-columns: 1fr 1fr;
    text-align: center;
    justify-content: center;
    align-items: center;
    color: #406B9C;
}

.table-text-and-image img{
    max-width: 100%;

    display: block;
    margin: 0 auto;
}
.table-text-and-image .table-image div{
    position: relative;
    display: inline-block;
}
.table-text-and-image .table-image div:after{
    width: 100%;
    height: 100%;
    background: #eff5f7;
    position: absolute;
    top: -20px;
    right:  -25px;
    content: ' ';
    display: block;
    z-index: -1;
}

.table-text-and-image .table-image div.left-shadow:after{
    top: unset;
    right:  unset;
    bottom: -20px;
    left: -25px;
}
.otziv-table img{
    width: 100%;
}
.otziv-table{
    display: grid;
    grid-template-columns: 100px 1fr 50px;
    border-bottom: 1px solid #fff;
    gap: 20px;
    padding: 20px 0;
    align-items: center;
}
.otziv-table span{color: #FDDCA5;}
.otziv-table .avatar img{ border-radius: 50%;}
footer{
    background: #323232;
    padding: 60px 0 40px 0;
    color: #fff;
    font-weight: 300;
    font-size: 16px;
}
.footer-title{
    font-size: 32px;
    font-weight: 900;
}
footer a{color: #fff;}
.footer-flex-line-1,
.footer-flex-line-2,
.footer-flex-line-3{
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    gap: 20px;
}
.footer-flex-line-3{
    justify-content: center;
    padding-top: 30px;
}

.footer-logo-text img{     margin-left: -25px;}
.footer-logo-text{
    display: flex;
    align-items: start;
}
footer address,
footer nav{
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    text-align: right;
    gap: 5px;
}
.grid-3{
    display: grid;
    gap: 15px;
    grid-template-columns: 1fr 1fr 1fr;
    text-align: center;
    color: #406b9c;
    font-size: 16px;
    font-weight: 600;

}
.grid-3 span{
    padding-top: 5px;
    display: block;
}
.grid-3 img:hover{
    opacity: 0.5;
    transition: all ease-in-out 0.3s;
    cursor: pointer;
}
.grid-3 img{
    display: block;
    width: 100%;
    transition: all ease-in-out 0.3s;
}
.grid-4{
    display: grid;
    gap: 15px;
    grid-template-columns: 1fr 1fr 1fr 1fr;
    align-items: center;
    justify-content: center;
}
.grid-4 img{
    display: block;
    height: 100%;
    max-width: 100%;
    margin:  0 auto;
    width: 100%;
}
.lnk{color: var(--accent); display: block; text-align: center;}
.lnk:hover{color: var(--color_00);}
.excursion-album{
    padding: 20px;
    margin-left: -20px;
    margin-right: -20px;
    background: #69acdb;
    font-size: 18px;

    color: #fff;
}
.excursion-title{
    font-size: 30px;
    font-weight: 700;
    padding: 10px 0;
}
.excursion-name-desc{
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    gap: 0;
    font-weight: 300;
    padding: 10px 0;
}
.excursion-name-desc div:first-child{
    min-width: 250px;
    max-width: 250px;
    padding-right: 20px;
    border-right: 1px solid;
    font-size: 15px;
}
.excursion-name-desc div:last-child{
    padding-left: 20px;
}
.excursion-ap{
    padding: 20px 0 0 0;
    text-align: right;
    font-weight: bold;
    color: var(--accent);
}
.iframe-video{
    width: 100%;
    max-width: 100%;
    min-height: 450px;
}
.sm-hr{    color: #406B9C; width: 66px; margin-top: -40px; margin-bottom: 30px; border: 2px solid;}
.last-trip{
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    color: #fff;

}
.last-trip>div{
    background: #00000090;
    padding: 20px;
    text-align: center;
    padding-bottom: 40px;
}
.last-trip>div img{margin:0 auto; margin-top: 40px; display: block;}
.last-trip>div h3{ color: #fff;}
.last-trip>div hr{ color: #fff; width: 75px; border: 2px solid; margin-top: -20px; margin-bottom: 40px}
.image-grid-2 svg{
    fill: #858585;
    max-width: 100%;
}
.image-grid-2{
    display: grid;
    grid-template-columns: 36px 1fr;
    gap: 20px;
    align-items: center;
}
.map{border: 2px solid #aaaa;}
.grid-4.contact{

    gap: 10px 5px;
    text-align: center;
    color: #406B9C;
    padding-bottom: 20px;
}
.grid-4.contact img{
    width: 100%;
    display: block;
    margin-top: 10px;
    height: 100%;
}
.mmarkers{
    list-style-type: "💙 ";
    margin: 0 0 20px 24px;
    padding: 0;
    display: flex;
    justify-content: space-around;
    align-items: center;
    gap: 20px 50px;
    flex-wrap: wrap;
}
.mmarkers li span{
    font-size: 18px;
}
.mmarkers li::marker{
    margin-top: -3px;
}
.mmarkers li {
    margin: 7px 0;
    font-size: 14px;
    color: #406B9C;
}
table{
    border-spacing: 0px;
    border-collapse: collapse;
    width: 100%;
    max-width: 100%;
}
table th{ font-size: 16px; padding: 5px 10px; background: #f0f0f0;border: 1px solid #fff}
table td{ font-size: 15px; padding: 5px 10px; border: 1px solid #f0f0f0}

.blog-content{
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.blog-article{

    border-bottom: 2px solid #Fff;
    padding: 20px 0;
}
.blog-article:first-child{
    padding-top: unset;
}
.blog-article a{
    display: flex;
    max-width: 100%;
    justify-content: start;
    gap: 20px;
}
.blog-article h3{margin-top: 0; line-height: 1}
.blog-article img{display: block;  width: 300px; height: fit-content;    border: 5px solid #d2e0e5;}
.blog-article-text{padding-right:20px; text-align: justify; font-size: 18px}

.blog img{
    margin-top: 40px;
    padding: 20px;
    border: 2px solid;
    background: #eff5f7;
    max-width: 100%;
}
.blog.intro img{
    background: #fff;
}
@media screen and (max-width: 1024px){
    .content{padding: 0 20px}
}
@media screen and (max-width: 840px){
    .main-menu{
        flex-direction: column;
        gap: 15px;
        font-size: 20px;
    }
    .main-menu li{
        display: none;
    }
    .main-menu.active li{
        display: block;
        padding-left: 20px;
    }
    .main-menu.active li:nth-child(2){
        padding-top: 20px;
    }
    .main-menu li.menu-booking{
        display: block;
        position: absolute;
        right: 20px;
    }
    .main-menu.active li.menu-button,
    .main-menu li.menu-button{
        display: flex;
        padding: 0;
    }
    .grid-4{
        grid-template-columns: 1fr 1fr ;
    }
}


@media screen and (max-width: 768px){
    .table-text-and-image{
        display: flex;
        flex-direction: column;
        gap: 40px;
        padding: 20px 0;
    }
    .grid-3{
        grid-template-columns: 1fr 1fr;
    }
    .table-text-and-image.mobile-reverse{
        flex-direction: column-reverse;
    }
    .footer-flex-line-1{
        flex-wrap: wrap;
        justify-content: space-around;
    }
    footer nav{
        flex-direction: row;
        gap: 30px;
    }
    .last-trip {
        grid-template-columns: 1fr ;
        gap: 80px;
    }
}
@media screen and (max-width: 700px){
    .swimming-pool-text {
        background: unset;
        padding-left: 0px;
        text-align: justify;
    }
    .swimming-pool-text p{
        text-indent: 40px;
    }
    .blog-article h3 {
        font-size: 30px;
        text-align: center;
        padding: 10px 0 30px;
        margin: 0;
    }
    .blog-article img{
        width: 100%;
    }
    .blog-article a{
        flex-wrap: wrap;
    }
}
@media screen and (max-width: 640px){
    footer address{
        width: 100%;
        flex-direction: row;
        flex-wrap: wrap;
        padding: 10px 0;
        gap: 10px;
        justify-content: space-around;
    }
    .excursion-name-desc div:first-child{
        min-width: 30%;
        max-width: 30%;
    }

}
@media screen and (max-width: 540px){
     .zaezd-viezd{grid-template-columns: 1fr;}
    .w-400{ margin: 0px; width: 100%;}
    .grid-3{
        grid-template-columns: 1fr;
    }
    .grid-4{
        grid-template-columns: 1fr;
    }
}