@font-face {
    font-family: "Poppins";
    src: url("assets/fonts/Poppins/Poppins-Regular.ttf") format('truetype');
    font-weight: 400;
    font-style:normal;
    font-display: swap;
}

@font-face {
    font-family: "Poppins";
    src: url("assets/fonts/Poppins/Poppins-Italic.ttf") format('truetype');
    font-weight: 400;
    font-style:italic;
    font-display: swap;
}

@font-face {
    font-family: "Poppins";
    src: url("assets/fonts/Poppins/Poppins-SemiBold.ttf") format('truetype');
    font-weight: 600;
    font-style:normal;
    font-display: swap;
}

@font-face {
    font-family: "Poppins";
    src: url("assets/fonts/Poppins/Poppins-Bold.ttf") format('truetype');
    font-weight: 700;
    font-style:normal;
    font-display: swap;
}

@font-face {
    font-family: "Poppins";
    src: url("assets/fonts/Poppins/Poppins-BoldItalic.ttf") format('truetype');
    font-weight: 700;
    font-style:italic;
    font-display: swap;
}

html
{
    overflow-x:hidden ;
}

body
{
    font-family:"Poppins", sans-serif;
    font-size: 16px;
    line-height: 1.5em;
    color: #000000;
    overflow-x:hidden;
    background: #ffffff;
}

@media(min-width:1600px) {
    .container {
        max-width: 1526px;
    }
}

h2, h1
{
    font-weight: 700;
    text-align: left;
    margin-bottom:45px;
    margin-top:50px;
    font-size: 48px;
}

h3
{
    font-size:28px;
    font-weight:600;
    margin-top:28px;
    margin-bottom: 20px;
    color:#c32e1b;
}

h4
{
    font-size:18px;
    font-weight:600;
    color:#c32e1b;
    margin-bottom: 10px;
    line-height: 25px;
}

h3 strong, h4 strong
{
    color:black;
    font-weight: 700;
}

.main-content h3
{
    margin-top: 30px;
}

h4.special-red-border:after
{
    display: block;
    content:'';
    height:1px;
    background: #c32e1b;
    margin:19px 0 24px 0;
    width:443px;
    max-width: 100%;
}

.text-red
{
    color:#c32e1b;
}

p
{
    margin-bottom:25px;
}

#introCarousel, #introCarousel, #introCarousel .carousel-item img
{
    height:795px;
    max-height: 100vh;
    width: 100%;
    object-fit: cover;
    display: block;
}

#introCarousel
{
    margin-bottom: 5px;
    position: relative;
    z-index: 1;
}

#introCarousel .carousel-controllers
{
    bottom:90px;
}

@media (max-width: 1200px)
{
    #introCarousel, #introCarousel .carousel-item img
    {
        height:auto;
        min-height:400px;
    }

    #introCarousel .carousel-controllers
    {
        bottom:10px;
    }
}

@media (max-width: 768px)
{
    #introCarousel, #introCarousel .carousel-item img
    {
        height:auto;
        min-height:300px;
    }
}

#introCarousel:before
{
    height:100%;
    position:absolute;
    top: 0;
    left: 0;
    right: 0;
    content: '';
    display: block;
    object-fit: contain;
    z-index:1;
    background: url("assets/images/slider_mask.webp") left center;
    background-size: cover;

}


.carousel-control-next, .carousel-control-prev
{
    position: relative;
    font-size:0;
}

.carousel-indicators
{
    margin-left: 0;
    right: auto;
    margin-right: auto;
    width:300px;
    position: relative;
    max-width: 50%;
}

.carousel-indicators:before
{
    width:100%;
    height:1px;
    opacity:0.5;
    background: #FFFFFF;
    content: '';
    position: absolute;
    top:20px;
    z-index: 0;
}

.carousel-indicators button[data-bs-target]
{
    width:100%;
    margin:0;
    opacity:0;
    height:3px;
    border: 0;
    padding: 0;
}

.carousel-indicators button[data-bs-target].active
{
    opacity:1;
}

#header-title
{
    top:0;
    left:0;
    right:0;
    bottom:0;
    z-index: 5;
    color:white;
}

#header-title .subtitle, .title-in-carousel .subtitle
{
    font-size:34px;
    line-height:40px;
    font-style: italic;
    color:white;
}



#fullWidthCarousel .carousel-controllers
{
    top: 130px;
}

#fullWidthCarousel .carousel-controllers .carousel-control-next-icon, #fullWidthCarousel .carousel-controllers .carousel-control-prev-icon
{
    height:auto;
    width: auto;
}

.carousel-controls, .swiper-controls
{
    margin-right:0;
    text-align:right;
}

.carousel-controls>button, .swiper-controls>div, .swiper-controls>div.swiper-prev, .swiper-controls>div.swiper-next
{
    position: relative;
    display: inline-block;
    width: auto;
    margin-left: 13px;
    opacity:0.5;
}

.carousel-controls>button:hover, .swiper-controls>div:hover, .swiper-controls>div.swiper-prev:hover, .swiper-controls>div.swiper-next:hover
{
    opacity:1;
}

.carousel-control-next-icon, .carousel-control-prev-icon, .swiper-controls>div.swiper-prev, .swiper-controls>div.swiper-next
{
    content: url("assets/images/icons/arrow.svg");
    background: none;
}

.carousel-control-prev-icon,  .swiper-controls>div.swiper-prev, .swiper-controls>div.swiper-prev
{
    transform: rotateZ(180deg);
}

#referenceCarousel .carousel-indicators, .swiper-pronajmy-pagination.swiper-pagination-bullets.swiper-pagination-horizontal
{
    width: auto;
    margin-right: 0;
    margin-left: auto;
    position: absolute !important;
    right: 0;
    left: auto;
    top: 50px;
    bottom: auto;
}

.swiper-pronajmy-pagination.swiper-pagination-bullets.swiper-pagination-horizontal
{
    top:15px;
}


@media(max-width:992px)
{
    .carousel-controls, .swiper-controls
    {
       /* display: none;*/
    }

    #referenceCarousel .carousel-indicators, .swiper-pronajmy-pagination.swiper-pagination-bullets.swiper-pagination-horizontal
    {
        position: relative !important;
        top: 0px;
        text-align:right;    justify-content: end;
    }

    #fullWidthCarousel figure
    {
        width:100vw;
        margin-left:calc(50% - 50vw);
        margin-right:calc(50% - 50vw);

    }

}

.nav-link.search-button, .nav-link.calendar-button
{
    transition: all 0.2s ease-in-out;
}

.nav-link.search-button:hover, .nav-link.calendar-button:hover {
    filter: invert(26%) sepia(72%) saturate(2602%) hue-rotate(350deg) brightness(78%) contrast(94%);
}

.content
{
    margin-bottom: 70px;
}

.moved
{
    transform: translateY(150px);
    transition: all 0.5s ease-in-out;
}

.moved.moved-done
{
    transform: translateY(0px);
}

@media(max-width:768px)
{
    h2
    {
        font-size:35px;
        line-height:45px;
        margin-bottom:20px;
        margin-top:20px;
    }

    h3
    {
        font-size: 25px;
        line-height: 32px;
    }
}

ul
{
    padding-left:15px;
}

a
{
    color: #000000;
    transition:color 0.2s ease-in-out;
}

a:hover
{
    color:#000000;
}

.max-100
{
    max-width:100%;
}

.full-width
{
    width:100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    /*padding-left:15px;
    padding-right:15px;*/
    padding-left:5px;
    padding-right:5px;
}

@media (max-width: 768px)
{
    h1 
    {
          font-size: 30px;
          line-height: 35px;
          margin-bottom: 20px;
          margin-top: 20px;
    }

    h2
    {
        font-size:24px;
        line-height:30px;
    }

    h2.like-h1
    {
        font-size:30px;
        line-height:35px;
    }

    #header-title .subtitle
    {
        font-size: 30px;
        line-height: 35px;
    }

    h3
    {
        font-size:21px;
        line-height:26px;
    }


}

header
{
    z-index:20;
    transition:all 0.3s ease-in-out;
    position: fixed;
    top:0;
    left:0;
    right: 0;
}

#header-top
{
    max-height:200px;
    transition: all 0.3s ease-in-out;
    overflow: hidden;
}

header .custom-logo-link {
    z-index: 5;
    position: relative;
}

header .custom-logo
{
    transition: all 0.3s ease-in-out;

}

header.scrolled #header-top
{
    max-height: 0;
}

/*header.scrolled #header-fixed .custom-logo
{
    height:70px;
}
*/
@media(max-width: 1200px)
{

    header #header-fixed .custom-logo
    {
        height:60px;
        width:auto;
    }
}

#header-spacer
{
    height:137px;
}

#header-fixed
{
    padding-top:28px;
    transition: all 0.3s ease-in-out;
    background: white;
}

header.scrolled #header-fixed
{
    background:white;
    padding:10px 0;
}

.social-menu li a
{
    padding:7px;
}

.partners-loga img
{
    transition: all 0.3s ease-in-out;
}

.social-menu li a:hover img, .partners-loga img:hover
{
    filter: brightness(0);

}

ul.main-menu
{
    display:flex;
    justify-content: end;
    margin-top:15px;
}

ul.main-menu li
{
    padding:0 25px;
}

ul.main-menu li a
{
    color: #000000;
    font-size: 16px;
    line-height:24px;
    transition:color 0.2s ease-in-out;
    position:relative;
    padding:5px;
    font-weight: 600;
}

@media(max-width: 1600px)
{
    ul.main-menu li
    {
        padding:0 15px;
    }
}

@media(max-width: 1400px)
{

    ul.main-menu li
    {
        padding:0 5px;
    }
}

@media(max-width: 1200px)
{
    ul.main-menu li
    {
        padding:0 5px;
    }
}

ul.main-menu li a:hover
{
    color: #c32e1b;
}

ul.main-menu li a:hover, ul.main-menu li.current-menu-item a, ul.main-menu li .nav-link:focus,
#expanded-menu ul li a:hover, #expanded-menu ul li.current-menu-item a, ul.expanded-menu li .nav-link:focus
{
    color:#c32e1b;
}

ul.main-menu li a img
{
    margin-top:-5px;
}

body:not(.page-2) #site-header:not(.scrolled) ul.main-menu li a:hover
{
    color:#c32e1b;
}

@media(max-width:1200px)
{
    ul.main-menu li a
    {
        padding:8px;
    }
}

ul.main-menu
{
    margin-right:-30px
}

header ul.main-menu li:first-child a:hover img, header ul.main-menu li.current_page_item a img
{
    filter: invert(26%) sepia(72%) saturate(2602%) hue-rotate(350deg) brightness(78%) contrast(94%);
}


header #logo
{
    z-index:1000;
    position:relative;
}

@media(max-width: 1200px)
{
    header #logo img
    {
        height:50px;
    }
}

#main-menu-toggler
{
    display:block;
    width:33px;
    height:29px;
    margin-right:0;
    margin-left:auto;
    cursor:pointer;
    z-index:1000;
    position:relative;
    margin-top:10px;
}

#main-menu-toggler span
{
    display:block;
    height:3px;
    background: #000;
    border-radius:3px;
    width:33px;
    margin-top:10px;
    transition:all 0.2s ease-in-out; 
}

#main-menu-toggler span:first-child
{
    margin-top:0px;
}

#main-menu-toggler.active-menu span:nth-child(2)
{
    display:none;
}

#main-menu-toggler.active-menu span:first-child
{
    transform:rotate(45deg);
    margin-top:25px;
}

#main-menu-toggler.active-menu span:last-child
{
    transform:rotate(-45deg);
    margin-top:-3px;
}

#expanded-menu
{
    position:fixed;
    display: block;
    width: 100%;
    background: #ffffff;
    border-radius: 0;
    z-index: 2;
    justify-content: center;
    transition: all 0.3s ease-in-out;
    overflow: auto;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    max-height:0;
}

.scrolled #expanded-menu {
    background: #ffffff;
}

#expanded-menu.active-menu
{
    max-height:100vh;
    height: auto;
}

#expanded-menu ul
{
    display: block;
    padding:0;
    margin:150px 0 20px 0;
}

#expanded-menu ul li
{
    padding:15px 0;
}

#expanded-menu ul li a
{
    font-size:18px;
    line-height:25px;
    color:#000000;
    padding:0;
}

#expanded-menu ul li
{
    text-align:center;
}


.lang-switcher
{
    line-height: normal;
    list-style-type: none;
    margin-bottom: 0;
    padding: 0;
    margin-left:0px;
}

.lang-switcher li:after {
    content: " | ";
    display: inline-block;
    margin-left: 3px;
    color:#000;
}

.lang-switcher li
{
    display: inline-block;
}

.lang-switcher li a
{
    color:#000;
    text-decoration:none;
    font-size:16px;
    font-weight: 400;
}

.lang-switcher li.current-lang a
{
    font-weight:600;
}

.lang-switcher li:last-child:after
{
    display:none;
}

.lang-switcher li a:hover
{
    color:#c32e1b;
    text-decoration:none;
}

.card
{
    background-color: #f8f8f8;
    overflow:hidden;
    border: 0;
    border-radius:0;
    padding:46px 24px 19px 24px;
    text-align:center;
}

.card:hover img
{
    animation: hopsi 1s 3 linear;
}

@keyframes hopsi {
    10% {
        margin-top:0px;
        margin-bottom:0px;
        transform: rotateZ(0deg);
    }
    25%{
        transform: rotateZ(5deg);
    }
    50% {
        margin-top:-7px;
        margin-bottom:7px;
    }
    75%{
        transform: rotateZ(-5deg);
    }
    90% {
        margin-top:0px;
        margin-bottom:0px;
        transform: rotateZ(0deg);
    }
}

.dot-right-center, .dot-right-before, .dot-right-after, .dot-right-bottom,
.dot-left-center, .dot-left-after, .dot-left-before, .dot-left-bottom
{
    position: relative;
}

.dot-right-center:before, .dot-right-before:before, .dot-right-after:before, .dot-right-bottom:before,
.dot-left-center:before, .dot-left-before:before, .dot-left-after:before, .dot-left-bottom:before
{
    z-index: -1;
    position: absolute;
    width: 1053px;
    height:457px;
    content:'';
}
.bg-red .dot-right-center:before, .bg-red .dot-right-before:before, .bg-red .dot-right-after:before, .bg-red .dot-right-bottom:before,
.bg-red .dot-left-center:before, .bg-red .dot-left-before:before, .bg-red .dot-left-after:before, .bg-red .dot-left-bottom:before
{
    filter: invert(100%) sepia(100%) saturate(0%) hue-rotate(288deg) brightness(102%) contrast(102%);
    z-index: 0;
}

.dot-left-before:before
{
    background: url("assets/images/bg_dots_left.svg") no-repeat left bottom;
    right:46%;
    top:-85px;
}

.dot-left-center:before
{
    background: url("assets/images/bg_dots_left.svg") no-repeat right bottom;
    right:46%;
    bottom:calc(50% - 220px);
}

.dot-left-bottom:before
{
    background: url("assets/images/bg_dots_left.svg") no-repeat left bottom;
    right:46%;
    bottom:0;
}

@media(min-width: 992px) {
    .pb-lg-5.dot-left-bottom:before {
        bottom: 60px;
    }
}

.dot-left-after:before
{
    background: url("assets/images/bg_dots_left.svg") no-repeat left bottom;
    right:46%;
    bottom:-155px;
}

.dot-right-before:before
{
    background: url("assets/images/bg_dots.svg") no-repeat left bottom;
    left:50%;
    bottom:0;
}

.dot-right-bottom:before
{
    background: url("assets/images/bg_dots.svg") no-repeat left bottom;
    left:46%;
    bottom:0;
}

.dot-right-center:before
{
    background: url("assets/images/bg_dots.svg") no-repeat left bottom;
    left:46%;
    bottom:calc(50% - 220px);
}

.dot-right-after:before
{
    background: url("assets/images/bg_dots.svg") no-repeat left bottom;
    left:46%;
    bottom:-155px;
}


.card img
{
    height:52px;
    width:52px;
    object-fit: scale-down;
}

.card-body
{
    padding:26px 30px;
    color:white;
    font-size: 13px;
}

.card h3
{
    color: #ffffff;
    transition: all 0.3s ease-in-out;
    font-size:23px;
}

@media(min-width: 999px) {
    figure.overflowed-left {
        position: relative;
        margin-right: 0;
        margin-left: -100%;
        object-fit: scale-down;
        width: 200%;
        max-width: 200%;
        height: auto;
        object-position: right;
        text-align: right;
    }

    figure.overflowed-right {
        position: relative;
        margin-left: 0;
        margin-right: -100%;
        object-fit: scale-down;
        width: 200%;
        max-width: 200%;
        height: auto;
        object-position: left;
        text-align: left;
    }
}

.cards-black .card
{
    text-align:left;
    background-color: black;
    color:white;
    padding:25px 40px 40px 40px;
    border-radius:10px;
}

.cards-black .card h3
{
    font-size: 18px;
    margin-top:15px;
    color:white;
    margin-bottom:15px;
}

.cards-black .card h3:after
{
    background:white;
    height:2px;
    width:93px;
    content:'';
    display:block;
    margin-top:15px;
}

.cards-black .card img {
    height: 35px;
    width: 22px;
    margin-right:10px;
}

.cards-black .card a
{
    color:white;
}

.cards-black .card a:hover
{
    color:#c32e1b;
}

/*@media(max-width: 1200px)
{
    figure.overflowed-left {
        position: relative;
        margin-right: 0;
        margin-left: calc(100% - 50vw);
        object-fit: scale-down;
        width: 50vw;
        max-width: 50vw;
        height: auto;
        object-position: right;
        text-align: right;
    }
}*/

#partners-swiper
{
    position: relative;
}

.swiper-aktuality>.row, #partners-swiper .row
{
    margin-left: auto;
    margin-right: auto;
    position: relative;
    list-style: none;
    flex-wrap: nowrap;
    padding: 0;
    z-index: 1;

}

.swiper-slide {
    flex-shrink: 0;
    width: 100%;
    height: 100%;
    position: relative;
    transition-property: transform;
}

.swiper-aktuality .swiper-slide {
    width: 420px;
    padding: 0;
}

.swiper-controls-black>div
{
    filter: brightness(0%);
    opacity:1!important;
}

.swiper-controls-black>div.swiper-button-disabled
{
    opacity:0.5!important;
}

.red-slide
{
    color:white;
    background:#c32e1b;
    padding:30px 90px 30px 30px;
    transition: background-color 0.3s ease-in-out;
}

.swiper-aktuality .red-slide h3, .boxes .red-slide h3
{
    color:white;
}

.swiper-aktuality .red-slide:hover
{
    background-color: black;
}

span.read-more
{
    font-weight:600;
    color:white;
    text-decoration:underline;
    position: relative;
    display: inline-block;
}

span.read-more:after
{
    content: url("assets/images/icons/arrow.svg");
    transform: rotateZ(-45deg) scale(90%);
    position: relative;
    right:-10px;
    display: inline-block;
}

.card
{
    border-radius: 0;
}

.card .spaceholder, .spaceholder-square, .swiper-aktuality .spaceholder, .boxes .spaceholder
{
    height:0;
    padding-bottom: 60%;
    position: relative;
    overflow:hidden;
}

.card .spaceholder-square
{
    padding-bottom: 100%;
}



.swiper-slide .spaceholder img
{
    position: absolute;
    left:0;
    top:0;
    right:0;
    bottom: 0;
    height: 100%;
    width:100%;
    object-fit: cover;
    transition: all 0.6s ease-in-out;
}

.swiper-aktuality .swiper-slide .text-wrapper
{
    background:transparent;
    padding:0;
    margin-left:auto;
    margin-right:0;
}

.swiper-aktuality h3, .boxes h3
{
    color:black;
    font-weight:700;
    margin-top:40px;
}

@media(max-width: 768px)
{
    .swiper-aktuality .swiper-slide
    {
        width:250px;
    }
}

.spaceholder.with-overlay:after
{
    opacity: 0.9;
    background-image: linear-gradient(to top, #000, rgba(0, 0, 0, 0));
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    content: '';
    z-index: 1;
}

.spaceholder img
{
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.boxes .card-body
{
    position: absolute;
    bottom:0;
    z-index: 1;
}

.boxes-others .card
{
    background-color: white;
    color:black;
    padding:25px;
}

.boxes-others .card h3
{
    color:black;
    margin:0;
}

.boxes-others .card:hover {
    background: #c32e1b;
}

.boxes-others .card:hover h3
{
    color:white;
}

.boxes-aktuality .hover-wrapper
{
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    opacity:0;
    transition: opacity 0.3s ease-in-out;
}

.boxes-aktuality .aktuality-item:hover .hover-wrapper
{
    opacity:1;
}

figure.w-100>a, figure.w-100>a>img
{
    width:100%;
}

#ajax-load-more
{
    padding:0;
    margin-top:0!important;
}

#mapa-container .mapthumbnail figure
{
    margin-bottom:0;
}

#swiper-gallery a img
{
    object-fit: scale-down!important;
    z-index:1;
    position: relative;
}

#swiper-gallery a span
{
    background-size: cover;
    filter: blur(8px);
    -webkit-filter: blur(8px);
    position: absolute;
    left: 38px;
    bottom: 0;
    right: 38px;
    top: 0;
    z-index: 0;
    opacity:0.5;
    background-position: center;
}

.icon-text-left-margin img
{
    margin-left:15px;
}

@media(max-width:768px)
{
    #mapa-container ul.mapa-saly
    {
        display: none;
    }
}

.bg-black, .bg-red, .bg-black h3, .bg-red h3, .bg-black h2, .bg-red h2
{
    color:white;
}

.bg-red
{
    background:#c32e1b;
}

.wp-block-button
{
    padding:20px 60px 20px 0;
}

.btn-primary, .wp-element-button, .wpcf7-form-control[type='submit']
{
    line-height: 24px;
    color: #ffffff;
    font-size: 14px;
    font-weight: 600;
    text-align: center;
    padding:20px 25px 20px 25px;
    border: 0;
    background-color:#c32e1b;
    transition:all 0.3s ease-in-out;
    position:relative;
    text-decoration:none;
    display:inline-block;
    border-radius: 32px;
    min-width:130px;
    text-transform: uppercase;
}

.btn-primary:after, .wp-element-button:after, .wpcf7-form-control[type='submit']:after, .btn-primary.btn-white:before, .btn-white-border:before
{
    display: block;
    position:absolute;
    right:-45px;
    background:url("assets/images/icons/arrow.svg") no-repeat #c32e1b center center;
    width:64px;
    height:64px;
    content:'';
    top:0;
    transition:all 0.3s ease-in-out;
    border-radius: 32px;
}

.btn-primary.btn-white, .btn-primary.btn-white:after
{
    background-color: white;
    color: #c32e1b;
    border:2px solid #c32e1b;
}

.btn-primary.btn-white:before,  .btn-white-border:before
{
    width:68px;
    height:68px;
    right:-47px;
    top:-2px;
    z-index:-1;
}

.btn-primary.btn-white:after
{
    border:0;
    background:url("assets/images/icons/arrow_red.svg") no-repeat white center center;
    background-size:21px auto;
}

.btn-primary:hover, .btn-primary:hover:after, .wp-element-button:hover, .wp-element-button:hover:after, .wpcf7-form-control[type='submit']:hover:after
{
    background-color:black;
    color:white;
}

.bg-red .btn-primary, .bg-red .btn-primary:after
{
    background: black;
}

.bg-red .btn-primary:hover, .bg-red .btn-primary:hover:after
{
    background-color:white;
    color:#c32e1b;
}

.bg-red .btn-primary:after
{
    border:0;
    background:url("assets/images/icons/arrow_red.svg") no-repeat black center center;
    background-size:21px auto;
}

.bg-red .btn-primary:after
{
    background-image: url("assets/images/icons/arrow.svg");
}

.bg-red .btn-primary:hover:after
{
    background-image: url("assets/images/icons/arrow_red.svg");
}

.btn-primary.btn-white:hover
{
    border-color:black;
}

.btn-primary.btn-white:hover:after
{
    background-image: url("assets/images/icons/arrow.svg");
}

.btn-white-border
{
    position:relative;
}

.btn-white-border, .btn-white-border:before
{
    border:2px solid white;
    display: inline-block;
    border-radius:32px;
    background:white;
    z-index:0;
}

.btn-white-border


a.back-button
{
    padding:14px 32px 14px 66px;
}

.single-page .btn-primary
{
    margin-top:20px;
}

.filtr button, .timetable-day ul li button
{
    padding:14px 25px 14px 25px;
}


      /*@media(max-width:768px)
      {
          .btn-primary
          {
              font-size:14px;
              padding:15px 35px;
          }
      }*/

/*.btn-primary:after, .filtr button:after, .back-button:after
{
  content: "";
  z-index: -1;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 120%;
  height: 100%;
  background-color: #c32e1b;
  backface-visibility: hidden;
  transform: rotate3d(0,0,1,10deg) translate3d(-1.2em,110%,0);
  transform-origin: 0% 100%;
  transition: transform 0.5s ease;
}*/

/*.btn-primary:before, .back-button:before
{
    content: url("assets/images/arrow_top_right_white.svg");
    display: block;
    position: absolute;
    top: 50%;
    right: 32px;
    transform: scale(50%) rotate(45deg);
    margin-top: -10px;
    transition: all 0.3s ease-in-out;
}*/

.back-button:before
{
    right: unset;
    left:32px;
    transform: scale(50%) rotate(270deg);
}

.btn-primary:hover:before, .back-button:hover:before
{
    transform: scale(50%) rotate(0deg);
    /*filter: brightness(0);*/
}

.back-button:hover:before
{
    transform: scale(50%) rotate(225deg);
}

.btn-primary:hover:after, .filtr button:hover:after, .filtr button.active:after, .back-button:hover:after
{
    transform: rotate3d(0,0,1,0) translateZ(0);
}


.btn-primary:hover, .filtr button:hover, .filtr button.active, .back-button:hover
{
    /*color: #ffffff;
    background-color:rgba(41,41,41,0);*/
}



#breadcrumbs span.breadcumb-separator
{
   width: 30px;
   display: inline-block;
   position:relative;
   text-align:center;
}

#breadcrumbs span.breadcumb-separator:before
{
    content:url('assets/images/icons/bread_arrow.svg');
    display:block;
    position:absolute;
    left:12px;
    bottom:-7px;
}

#breadcrumbs a
{
    font-size: 12px;
    font-weight: 400;
    text-decoration:underline;
    color:#7f7f7f;
}

#breadcrumbs a:hover
{
    color: #000000;
    text-decoration: underline;
}

#breadcrumbs span.breadcrumb_last
{
    font-size: 12px;
    color:#000000;
    font-weight: 600;
}

  


/********************* content *********************/

#header-image
{
    height: 432px;
    margin-bottom: 40px;
}

@media(max-width: 1200px)
{
    #header-image
    {
        height:250px;
    }
}

#header-image:before
{
    position: absolute;
    top:0;
    left: 0;
    bottom:0;
    right:0;
    content: '';
    z-index:2;
    background: url("assets/images/head_mask.webp") center center;
    background-size: cover;
}

#header-image img
{
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 1;
    position: relative;
}

.main-content.front-page
{
    padding-top:90px;
    padding-bottom:90px;
}

.main-content
{
    padding-bottom:0px;
}

/*.single-page article .wp-block-image img
{
    margin-bottom:50px;
    margin-top:50px;
}*/

.single-page article div>.wp-block-image:first-child img
{
    margin-top: 0;
}


article ol, article ul
{
    margin-bottom:25px;
}

article ol li, article ul li
{
    margin-bottom:15px;
}

article ol ul
{   
    margin-bottom:15px;
}

article ol ul li, article ul li
{
    margin-top:15px;
}


.subpages-boxes figure
{
    position: relative;
    overflow:hidden;
    height: 0;
    padding-bottom: 100%;
    margin-bottom:0;
    transition: opacity 0.3s ease-in-out;
}

.subpages-boxes .card, .subpages-boxes figure
{
    border-radius: 0;
    padding:0;
}

.subpages-boxes .card
{
    background: #c32e1b;
}

.subpages-boxes .card:hover .card-body {
    background: rgba(48, 48, 48, 0);
}

.subpages-boxes .card:hover img
{
    opacity: 0;
}

.subpages-boxes .card .card-body, .subpages-boxes figure figcaption
{
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    display: flex;
    flex-flow: column;
    z-index: 2;
    background:rgba(48,48,48,0.5);
    transition: background-color 0.3s ease-in-out;
    margin:0;
    color:white;
    font-weight: 600;
    justify-content: end;
    align-items: start;
    height: 100%;
    width: 100%;
    padding:39px;
    pointer-events:none;
}

.subpages-boxes .card .card-body h3
{
    font-size: 34px;
    line-height: 44px;
    text-align:left;
    padding-bottom:23px;
}

.subpages-boxes>div {
    counter-increment: subpagesCounter;
}

.subpages-boxes .card .spaceholder img, .subpages-boxes figure img, .boxes .card .spaceholder img, .aktuality-item:hover .spaceholder img
{
    transition: all 0.3s ease-in-out;
    position: absolute;
}

.subpages-boxes .card:before
{
    content: counter(subpagesCounter, decimal-leading-zero);
    position: absolute;
    left:39px;
    top:40px;
    color:white;
    font-size:24px;
    z-index:10;
}

@media(max-width: 1400px)
{
    .subpages-boxes .card .card-body h3
    {
        font-size: 24px;
        line-height: 28px;
    }
}

@media(max-width: 1200px)
{
    .subpages-boxes .card .card-body
    {
        padding: 10px 30px;
    }

    .subpages-boxes .card .card-body h3 {
        padding-bottom: 15px;
    }

    .subpages-boxes .card:before {
        left: 30px;
        top: 20px;
        font-size: 20px;
    }
}


.subpages-boxes figure img
{
    max-width: unset;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    object-fit: cover;
    width: 100%;
    height: 100%;
}

.subpages-boxes .card:hover .spaceholder img, .subpages-boxes figure:hover img, .boxes .card:hover .spaceholder img, .swiper-slide:hover .spaceholder img,
.aktuality-item:hover .spaceholder img
{
    left:-10px;
    right: -10px;
    top:-10px;
    bottom:-10px;
    height: calc(100% + 20px);
    width: calc(100% + 20px);
}

.subpages-boxes .card .read-more
{
    font-weight:400;
}

.subpages-boxes .card:hover .card-body, .subpages-boxes figure:hover figcaption {
    /*background: rgba(15, 52, 96, 0.35);*/
}

.subpages-boxes .card:hover .spaceholder img
{
    animation: none;

}

.subpages-boxes .card .card-body h3, .subpages-boxes figcaption a
{
    text-decoration: none;
    border:0;
    margin: 0;
    color:white;
}

.subpages-boxes figcaption a
{

}

.subpages-boxes .card .card-body:before
{

}

.subpages-boxes .card .card-body h3:after
{
    display: none;
}

.single-page img.attachment-post-thumbnail
{
    max-width:100%;
    height:auto!important;
}

.ratio .wp-block-embed__wrapper iframe
{
    height:100%;
    width:100%;
}

@media (min-width: 600px)
{
    .wp-block-gallery.has-nested-images.columns-6 figure.wp-block-image:not(#individual-image) {
        width: calc(16.66667% - 7px * 0.83333);
        flex-grow:0;
    }
}

.kontakt-block
{
    font-size:16px;
}

#virtualni-prohlidka
{
    background:url('assets/images/smetanova-sin.webp') no-repeat center center;
    background-size: cover;
    height:520px;
    color:white;
    position: relative;
    background-attachment: fixed;
}

#virtualni-prohlidka:before
{
    position: absolute;
    opacity: 0.5;
    background: #000000;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    content:'';
    z-index: 1;
    transition: opacity 0.2s ease-in-out;
}

#virtualni-prohlidka>*
{
    z-index: 2;
}

#virtualni-prohlidka:hover:before
{
    opacity: 0.3;
}

.wp-block-pb-accordion-item
{
    border-top: 2px solid #c32e1b;
    padding-bottom:14px;
    counter-increment: accordionCounter;
}

.wp-block-pb-accordion-item h3.c-accordion__title, .wp-block-pb-accordion-item h2.c-accordion__title
{
    color:black;
    font-size:24px;
    margin:0;
    padding-top:39px;
    padding-bottom:25px;
}

.with-counter .wp-block-pb-accordion-item h3.c-accordion__title:before, .with-counter .wp-block-pb-accordion-item h2.c-accordion__title:before
{
    content: counter(accordionCounter)". ";
}

.wp-block-pb-accordion-item.is-open h3.c-accordion__title, .wp-block-pb-accordion-item.is-open h2.c-accordion__title
{
    color:#c32e1b;
}

.wp-block-pb-accordion-item .c-accordion__title:after
{
    color:#c32e1b;
    background-color: white;
    border: solid 2.5px #f8f8f8;
    text-align: center;
    height:56px;
    width:56px;
    border-radius: 56px;
    align-content: center;
    margin-top: 10px;
    transition: all 0.2s ease-in-out;
}

.wp-block-pb-accordion-item .c-accordion__title:hover:after, .wp-block-pb-accordion-item.is-open .c-accordion__title:after
{
    background-color:#c32e1b;
    color: white;
}

.wp-block-pb-accordion-item:last-of-type
{
    border-bottom: 2px solid #c32e1b;
    margin-bottom:80px;
}


.full-size-link
{
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    right: 0;
    opacity: 0;
    z-index: 2;
}

#mapa
{
    margin-bottom: -0px;
}

#mapa iframe
{
    width:100%;
    margin-bottom:-20px;
}

#mapa .btn-primary
{
    margin-top:-20px;
    min-width:208px;
}

a.button, input.button
{
    padding:24px 58px;
    font-size:16px;
    font-weight: 600;
    color:white;
    background: #c32e1b;
    text-decoration: none;
    z-index: 3;
    line-height:19px;
    transition: all 0.3s ease-in-out;
    border:0;
    position:relative;
    display: inline-block;
}

a.button:hover, input.button:hover
{
    background: black;
}

a.button.arrow-next, input.button.arrow-next, input.arrow-next
{
    padding-right: 80px;
}

a.button.arrow-prev, input.button.arrow-prev
{
    padding-left: 80px;
}

a.button.arrow-next:after, input.button.arrow-next:after, input.arrow-next:after, a.button.arrow-prev:before, input.button.arrow-prev:before
{
    position: absolute;
    //background: url("assets/images/icons/arrow.svg");
    height: 18px;
    width: 18px;
    background-size: contain;
    //content: '';
    margin-left:20px;
    content: url("assets/images/icons/arrow.svg");
    transform: scale(60%);
    filter: invert(100%) sepia(100%) saturate(0%) hue-rotate(288deg) brightness(102%) contrast(102%);
    top: 50%;
    margin-top: -10px;
}

a.button.arrow-prev:before, input.button.arrow-prev:before
{
    margin-left:-40px;
    margin-right:20px;
    margin-top: -6px;
    transform: scale(60%) rotateZ(180deg);
}


#mapa .button
{
    position:absolute;
    bottom:-27px;
    left:50%;
    transform: translateX(-50%);

}

.wpcf7-form label
{
    width:100%;
}

.wpcf7-form .wpcf7-form-control-wrap input[type='text'], .wpcf7-form .wpcf7-form-control-wrap input[type='email'],
.wpcf7-form .wpcf7-form-control-wrap input[type='tel'], .wpcf7-form .wpcf7-form-control-wrap textarea,
.wpcf7-form .wpcf7-form-control-wrap select
{
    width:100%;
    background: transparent;
    border:0;
    border-bottom: 1px solid #e5e5e5;
    padding:10px 0;
    font-size:13px;
    color:#828282;
}

.wpcf7-form .wpcf7-form-control-wrap textarea
{
    height:100px;
}

.wpcf7-form .wpcf7-acceptance
{
    font-size:12px;
}

.wpcf7-spinner
{
    display: block;
    margin-left: auto;
    margin-right: auto;
}
/*
.wp-block-table.is-style-stripes td:last-child
{
    text-align: right;
}*/

.contact-block
{
    padding: 60px 50px 0px 52px;
    object-fit: contain;
    border-radius: 8px;
    box-shadow: 0 20px 60px 0 rgba(62, 62, 62, 0.16);
    background-color: #fff;
    font-size:14px;
    z-index:3;
    position:relative;
    margin-bottom:50px;
}

@media(min-width: 999px)
{
    .contact-block {
        margin-bottom: -170px;
    }

}

.wp-block-table
{
    margin-bottom:50px;
}

.wp-block-table.is-style-stripes tbody tr
{
    /*background-color: rgba(182,141,64,0.07);*/
    background-color: rgba(195,46,27,0.07);
}

.wp-block-table.is-style-stripes tbody tr td
{
    border-bottom:1px solid #c32e1b;
    padding:14px 12px;
}

.wp-block-table.is-style-stripes tbody tr:first-child td
{
    border-top:1px solid #c32e1b;
}

.wp-block-table.is-style-stripes tbody td:last-child,  .wp-block-table.is-style-stripes.two-last-fixed tbody td:nth-child(2)
{
    width: 1px;
    white-space: nowrap;
}

.wp-block-table.is-style-stripes tbody tr:nth-child(2n+1)
{
    background:transparent;
}

.wp-block-file a
{
    font-size: 18px;
    font-weight: 600;
    text-decoration:underline;
    color: #c32e1b;
    display: block;
}

.wp-block-file a:before
{
    content:url("assets/images/icons/icon_pdf.svg");
    display: block;
    padding-bottom:28px;
}

.wp-block-file a:hover:before
{
    animation: hopsi 1s 3 linear;
}


.timeline
{
    padding-top:80px;
}

.timeline>div
{
    width:50%;
    position:relative;
    text-align: right;
    font-size: 14px;
    padding-right:15%;
    padding-top:3px;
}

.timeline>div:nth-child(odd)
{
    margin-right: 0;
    margin-left: auto;
    text-align: left;
    padding-left:15%;
    padding-right: 0;
}

.timeline>div:before
{
    position: absolute;
    content:'';
    width: 30px;
    height: 30px;
    background-color: #c32e1b;
    border-radius:30px;
    right:-15px;
}

.timeline>div:nth-child(odd):before
{
    right:auto;
    left:-15px;
}

.timeline>div:after
{
    width:1px;
    height:100%;
    content:'';
    position: absolute;
    top:0;
    bottom:0;
    right:0;
    background-color: #c32e1b;
    margin-top:15px;
}

.timeline>div:nth-child(odd):after
{
    right:auto;
    left:-1px;
}

.timeline>div:last-child:after
{
    display: none;
}

.timeline>div h3
{
    margin-bottom: 6px;
    margin-top:-6px;
}

.timeline>div h3:before
{
    height:1px;
    content: '';
    border-top: 1px dashed #c32e1b;
    position: absolute;
    top:16px;
    right:30px;
    width:23%;
}

.timeline>div:nth-child(odd) h3:before
{
    right:auto;
    left:30px;
}


@media(max-width: 768px)
{
    .timeline>div, .timeline>div:nth-child(odd)
    {
        width:100%;
        margin-right: 0;
        margin-left: auto;
        text-align: left;
        padding-left:50px;
        padding-right: 0;
    }

    .timeline>div:before, .timeline>div:nth-child(odd):before
    {
        right:auto;
        left:-5px;
    }

    .timeline>div:after, .timeline>div:nth-child(odd):after
    {
        right:auto;
        left:10px;
    }

    .timeline>div h3:before, .timeline>div:nth-child(odd) h3:before
    {
        right:auto;
        left:20px;
        width:25px;
    }

    .timeline
    {
        padding-top:0;
    }
}



.ajax-load-more-wrap.white button.alm-load-more-btn:before
{
    height:77px;
    width:77px;
    display: block;
    border-radius:77px;
    content:url("assets/images/icons/plus.svg");
    background: #c32e1b;
    padding-top: 28px;
    position: absolute;
    left: 50%;
    margin-left:-38px;
    top:0;
    transition: all 0.3s ease-in-out;
}

.ajax-load-more-wrap.white button.alm-load-more-btn
{
    border:0;
    padding-top:100px;
    background:transparent;
    color:#000000;
    height:130px;
    box-shadow: none;
    margin-top: 80px;
    font-size:14px;
}

.ajax-load-more-wrap.white button.alm-load-more-btn:hover:before
{
   transform: rotateZ(180deg);
}

.ajax-load-more-wrap.white button.alm-load-more-btn:hover
{
    background: transparent;
    border:0;
}

/********************* program **********************/


#programCalendar .flatpickr-calendar
{
    box-shadow: none;
    -webkit-box-shadow:none;
    border:0;
    margin-top:10px;
    margin-bottom:20px;
}

.flatpickr-calendar .numInputWrapper
{
    display: none!important;
}

.flatpickr-day.today:before, .flatpickr-day.selected:before
{
    width: 20px;
    height: 20px;
    padding: 1px 6px 2px;
    object-fit: contain;
    border-radius: 5px;
    background-color: #c32e1b;
    color:white;
    display:block;
    content:'';
    position:absolute;
    left:50%;
    top:50%;
    margin-top:-10px;
    margin-left:-10px;
    z-index:-1;
    border:1px solid #c32e1b
}

.flatpickr-day:hover:before
{
    background: #e6e6e6;
}

.flatpickr-day.today:before
{
    background: transparent;
}

.flatpickr-calendar .flatpickr-current-month
{
    font-size: 16px;
    padding-top:10px;
}

.flatpickr-calendar .flatpickr-weekdaycontainer span.flatpickr-weekday
{
    color:black;
    text-transform: uppercase;
}

.flatpickr-calendar .dayContainer
{
    font-size:12px;
}


.flatpickr-day.today, .flatpickr-day.selected
{
    border:0;
    color:#c32e1b;
    background: transparent!important;
}

.flatpickr-day.selected {
    color: white;
}

.vertical-separator:after
{
    height: calc(100% - 30px);
    width:1px;
    content:'';
    display: block;
    background: black;
    margin-left: auto;
    margin-right: auto;
}

.program-rangeselect li
{
    font-size: 24px;
    font-weight: 600;
    line-height:33px;
    padding:25px;
    cursor:pointer;
}

.program-rangeselect li:hover
{
    text-decoration: underline;
}

.program-range
{
    font-size: 24px;
    font-weight: 600;
    line-height:33px;
    padding:25px;
}

#program-previous img
{
    transform: rotateZ(180deg);
}

#program-previous img, #program-next img
{
    opacity:0.5;
    display: inline-block;
    margin-top: -8px;
    transition: opacity 0.3s ease-in-out;
}

#program-previous:hover img, #program-next:hover img
{
    opacity:1;
}

.program-items
{

}

.program-items .program-item
{
    transition: background-color 0.3s ease-in-out, max-height 0.5s ease-in-out;
    max-height: 700px;
    margin-bottom:30px;
    position: relative;
}

.program-items .program-item:hover, .terminy-table tr:hover td
{
    color:white;
    /*background-color: #c32e1b;*/
}

.program-items .program-item:before
{
    position:absolute;
    left:-12px;
    top:-12px;
    bottom:0;
    right:-12px;
    background:#c32e1b;
    content:'';
    z-index:-1;
    opacity:0;
    transition: opacity 0.3s ease-in-out;
}

.program-items .program-item:hover:before
{
    opacity:1
}


.program-item-date, .program-items h3
{
    font-size:24px;
    line-height: 32px;
}

.program-items .program-item:hover h3 a, .terminy-table tr:hover td a
{
    color:white;
}

.program-items h3 a
{
    text-decoration: none;
}

.program-items h3 a:hover
{
    text-decoration: underline;
}

.program-items .termin-day, .program-items .termin-mesic, .program-items .termin-dentydne, .program-items .termin-cas
{
    display: block;
}

.program-items .termin-day
{
    font-size:48px;
    line-height:67px;
}

.program-items .termin-mesic
{
    font-size:20px;
    line-height:28px;
}
.program-items .termin-dentydne
{
    font-size:14px;
    line-height:20px;
}
.program-items .termin-cas
{
    font-size:16px;
    line-height:16px;
    margin-top: 10px;
}

.program-items .termin-cas:before
{
    display:inline-block;
    width:16px;
    height:16px;
    content: '';
    background: url("assets/images/icons/icon_clock.svg");
    background-size: contain;
    margin-right:10px;
}

.program-items .program-item:hover .termin-cas:before
{
    filter: invert(100%) saturate(0%) brightness(102%) contrast(101%);
}

.program-items .button-vstupenky, .program-items .colosseum-form button
{
    font-size:18px;
    line-height:25px;
    font-weight: 600;
}

.program-items .colosseum-form button
{
    background: transparent;
    border:0;
    text-decoration: underline;
}

.program-items .program-item:hover .button-vstupenky, .terminy-table tr:hover .colosseum-form button, .program-items .program-item:hover .colosseum-form button
{
    color:white;
}

.program-items .program-item .button-vstupenky:after, .button-vstupenky:after, .colosseum-form button:after
{
    content: url("assets/images/icons/arrow.svg");
    display: inline-block;
    margin-left:18px;
    transform: rotateZ(-45deg) scale(80%);
    transition: all 0.3s ease-in-out;
    filter: invert(100%) saturate(0%) brightness(0%) contrast(101%);
}

.program-items .program-item:hover .button-vstupenky:after {
    filter: invert(0%) saturate(0%) brightness(100%) contrast(101%);
}

.program-item-doporucene h3
{
    font-size:24px;
    line-height:32px;
}

.program-item-doporucene h3 a
{
    color:white;
    text-decoration: none;
}

.program-item-doporucene figure
{
    height:0;
    padding-bottom:132%;
    margin:0;
}

.program-item-doporucene img
{
    position:absolute;
    top:0;
    left:0;
    bottom:0;
    right:0;
    width: 100%;
    height: 100%;
}

.program-item-doporucene:first-child figure
{
    padding-bottom:66%;
}


@media(min-width:1400px) {
    .program-item-doporucene:first-child h3 {
        font-size: 38px;
        line-height: 50px;
    }
}

@media(max-width: 1400px)
{

    .program-item-doporucene figure
    {
        padding-bottom:66%;
    }
}

.program-item-doporucene .btn-white-border .btn-primary,
.btn-white-border .btn-primary:after, .btn-white-border .btn-primary:after,
.program-item-doporucene:nth-child(4n+3),.program-item-doporucene:nth-child(4n+4),
.program-item-doporucene:nth-child(4n+3) .btn-white-border .btn-primary:hover, .program-item-doporucene:nth-child(4n+4) .btn-white-border .btn-primary:hover,
.program-item-doporucene:nth-child(4n+3) .btn-white-border .btn-primary:hover:after, .program-item-doporucene:nth-child(4n+4) .btn-white-border .btn-primary:hover:after
{
    background-color: black!important;
}

.program-item-doporucene:nth-child(4n+3),.program-item-doporucene:nth-child(4n+4),
.program-item-doporucene:nth-child(4n+3) .btn-white-border .btn-primary, .program-item-doporucene:nth-child(4n+4) .btn-white-border .btn-primary,
.program-item-doporucene:nth-child(4n+3) .btn-white-border .btn-primary:after, .program-item-doporucene:nth-child(4n+4) .btn-white-border .btn-primary:after,
.program-item-doporucene .btn-white-border .btn-primary:hover,
.btn-white-border .btn-primary:hover:after, .btn-white-border .btn-primary:hover:after
{
    background-color: #c32e1b!important;
}

#program-doporucene .program-item-doporucene:nth-child(n+4)
{
    max-height:0;
    overflow:hidden;
    transition: max-height 0.5s ease-in-out;
}

#program-doporucene.loaded .program-item-doporucene:nth-child(n+4)
{
    max-height:600px;
}


.terminy-table .button-vstupenky, .colosseum-form button
{
    line-height: 33px;
    text-decoration:none;
}

.terminy-table .button-vstupenky:hover, .colosseum-form button:hover
{
    text-decoration: underline;
}

.terminy-table .colosseum-form button
{
    background: transparent;
    border: 0;
    padding:0;
}

.button-vstupenky:after
{
    transform: rotateZ(-45deg) scale(60%);
}

.program-items .program-item .button-vstupenky:hover:after, .program-items .colosseum-form button:hover:after
{
    transform: rotateZ(0deg) scale(80%);
}

.program-items .program-item:hover .button-vstupenky:after, .terminy-table tr:hover .button-vstupenky:after,
.terminy-table tr:hover .colosseum-form button:after, .program-items .program-item:hover .colosseum-form button:after
{
    filter: invert(0%) saturate(0%) brightness(102%) contrast(101%);
}

.button-vstupenky:hover:after
{
    transform: rotateZ(0deg) scale(60%);
}

.program-items .program-image-container
{
    height:0;
    padding-bottom:60%;
    position: relative;
}

.program-items .program-image-container img
{
    position: absolute;
    top:0;
    bottom: 0;
    left: 0;
    right:0;
    object-fit: cover;
    height: 100%;
    width: 100%;
}

.filter-item
{
    border-bottom:1px solid black;
    padding:20px 0;
    position: relative;
}

.filter-item input[type='text']
{
    border:0;
    width:100%;
}

#program-search-icon
{
    width:18px;
    height:18px;
    position: absolute;
    right: 0;
    top:50%;
    transform: translateY(-50%);
    background-image: url("assets/images/icons/icon_search.svg");
    display: block;
    opacity: 0.5;
    background-size: contain;
    transition: opacity 0.2s ease-in-out;
}

#program-search-icon:hover
{
    opacity: 1;
}

.filter-item>a
{
    text-decoration:none;
    position: relative;
    display: block;
}

.filter-item>a:hover
{
    color:#c32e1b;
}

.filter-item>a:after
{
    content:url("assets/images/icons/arrow.svg");
    filter: invert(100%) saturate(0%) brightness(102%) contrast(101%);
    position: absolute;
    right: 0;
    top:0;
    transform: rotateZ(-90deg) scale(60%);
}

.filter-item>a.collapsed:after
{
    transform: rotateZ(90deg) scale(60%);
}

.front-page .program-items:not(.show-all) .program-item:nth-child(n+4)
{
    max-height:0;
    overflow: hidden;
    padding-top: 0;
    padding-bottom: 0;
    border-bottom: 0;
    margin-bottom:0;

}

#programCategory ul
{
    list-style-type: none;
    margin-top: 20px;
    padding-left:0;
    font-size: 16px;
}

#programCategory li
{
    padding:5px 0;
    cursor:pointer;
}

#programCategory li.active
{
    color:#c32e1b;
}

.loader {
    border: 6px solid #a3a3a3;
    border-top: 6px solid #c32e1b;
    border-radius: 50%;
    width: 60px;
    height: 60px;
    animation: spin 1s linear infinite;
    margin: 20px auto; /* vycentrování */
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}



.akce-icon
{
    height:32px;
    width:32px;
    object-fit: scale-down;
    margin-bottom:25px;
}

hr.red-line
{
    background:#c32e1b;
    border-color:#c32e1b;
}

.icon-underlined:after
{
    width: 68px;
    height: 2px;
    display: block;
    content:'';
    background:#c32e1b;
    margin-top: 23px;
}

@media (max-width: 768px)
{
    .program-rangeselect li
    {
        font-size: 18px;
        line-height: 25px;
        padding: 10px;
    }

    .program-range
    {
        font-size: 18px;
        font-weight: 600;
        line-height: 25px;
        padding: 15px;
    }

    .program-items h3
    {
        font-size: 20px;
        margin-top:10px;
        margin-bottom:5px;
    }

    .program-items .button-vstupenky
    {
        font-size:20px;
    }
}

#planuj-udalost
{
    background: url("assets/images/bg_planujte.webp") center center no-repeat;
    background-size: cover;
    padding-top:300px;
    margin-bottom:150px;
    margin-top:150px;
}

#planuj-udalost .content-box
{

    color:white;
    padding: 10px 69px 18px 55px;
    -webkit-backdrop-filter: blur(45px);
    backdrop-filter: blur(45px);
    /*background-color: rgba(255, 255, 255, 0.2);*/
    margin-bottom:-38px;
    background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.6), rgba(84, 84, 84, 0.5));
}


/**************************search**************************/

.full-over
{
    position:fixed;
    top:0;
    bottom:0;
    left:0;
    right:0;
    z-index:999;
    background:rgba(1255,255,255,0.5);
    display:none;
    text-align:center;
    transition:all 0.4s ease-in-out;
}

.full-over.showed
{
    display:flex;
}

.full-over form
{
    width:400px;
    padding:90px 80px 90px 45px;
    background:#c32e1b;
    margin:auto;
    -webkit-box-shadow: 0px 0px 17px -4px rgba(0,0,0,0.75);
    -moz-box-shadow: 0px 0px 17px -4px rgba(0,0,0,0.75);
    box-shadow: 0px 0px 17px -4px rgba(0,0,0,0.75);
    position:relative;
    max-width:90%;
}

.full-over form:after {
    content: url("assets/images/bg_dots.svg");
    position: absolute;
    right: -350px;
    top: -100px;
    bottom: 0;
    z-index: 0;
    filter: invert(100%) sepia(100%) saturate(0%) hue-rotate(288deg) brightness(102%) contrast(102%);
}

.full-over form>*
{
    z-index:2;
}


.full-over form input
{
    width:100%;
    height:64px;
    line-height:24px;
    padding:20px 25px;
    border:0;
    max-width:100%;
    font-size:16px;
    border-radius:50px;
    position: relative;
}

.full-over form button
{
    position:absolute;
    right:35px;
    /*top:45px;*/
    height:64px;
    width:64px;
    background:url('assets/images/icons/icon_search.svg') #ffffff no-repeat center center;
    border-radius: 50px;
    border:2px solid white;
}

.full-over form button:hover
{
    background:url('assets/images/icons/icon_search_white.svg') #000000 no-repeat center center;
}

@media(min-width:992px)
{
    .full-over form
    {
        padding:90px 130px 90px 90px;
        width:500px;
    }

    .full-over form button
    {
        top:90px;
        /*right:50%;
        margin-right:-150px;*/
        margin-right:45px;
    }
}

@media(min-width:1200px)
{
    .full-over form
    {
        padding:130px 190px 130px 150px;
        width:800px;
    }

    .full-over form button
    {
        top:130px;
        /*right:50%;
        margin-right:-150px;*/
        margin-right:105px;
    }


}

.close-over
{
    position:absolute;
    top:10px;
    right:10px;
    width:20px;
    height:20px;
    cursor:pointer;
}

.close-over:before, .close-over:after
{
    width:3px;
    height:25px;
    content:'';
    display:block;
    background:white;
    position:absolute;
}

.close-over:before
{
    transform:rotate(45deg);
    left: 8px;
    top: -3px;
}

.close-over:after
{
    transform:rotate(-45deg);
    left: 8px;
    top: -3px;
}

#newsletter
{
    background: url("assets/images/bg_dots.svg") #c32e1b no-repeat left center;
    padding:90px 60px;
    position: relative;
}

#newsletter:after
{
    content:url("assets/images/bg_dots.svg");
    position: absolute;
    right:-30px;
    top:0;
    bottom:0;
    z-index: 0;
    filter: invert(100%) sepia(100%) saturate(0%) hue-rotate(288deg) brightness(102%) contrast(102%);
}

#newsletter h2
{
    font-size:48px;
    line-height:74px;
    color:white;
    margin:0;
}

#newsletter form
{
    padding-right: 70px;
}

#newsletter .form-check label
{
    color:white;
    font-size: 14px;
}

#newsletter input[type=email]
{
    height:91px;
    background: white;
    width:100%;
    line-height:33px;
    font-size:24px;
    color:black;
    font-weight: 600;
    padding:29px 46px;
    border:0;
    border-radius:46px;
}

#newsletter #newsletter-form-send
{
    background-color:white;
    height:91px;
    width:91px;
    position:absolute;
    top: 0;
    right:0;
    border-radius: 46px;
    font-size:0;
    padding:0
}

#newsletter #newsletter-form-send:before
{
    content: url("assets/images/icons/arrow_red.svg");
    position:absolute;
    top: 33px;
    right:0;
    left:0;
}

#newsletter #newsletter-form-send:hover:before
{
    filter: saturate(0%) brightness(1013%) contrast(1);
    top: 29px;
}

#newsletter #newsletter-form-send:hover
{
    background: black;
    border:4px solid white;
}

#newsletter label a
{
    color:white;
}


@media (max-width: 768px) {
    #newsletter h2
    {
        font-size:28px;
        line-height:40px;
    }

    #newsletter
    {
        padding: 50px 30px;
    }

    #newsletter form
    {
        padding-right: 40px;
    }

    #newsletter input[type="email"]
    {
        font-size: 16px;
        line-height:20px;
        padding: 15px 30px;
        border: 0;
        border-radius: 46px;
        height:50px
    }

    #newsletter #newsletter-form-send {
        background-color: white;
        height: 50px;
        width: 50px;
    }

    #newsletter #newsletter-form-send:before
    {
        content: url("assets/images/icons/arrow_red.svg");
        position:absolute;
        transform: scale(50%);
        top: 12px;
        right:0;
        left:0;
    }
}


.ol-with-large-numbers {
    counter-reset: item;
    list-style: none;
    padding-left: 60px;
}

.ol-with-large-numbers li
{
    padding-top:20px;
    padding-bottom:20px;
    position: relative;
    font-size: 16px;
    counter-increment: item;

}

.ol-with-large-numbers li::before
{
    content: counter(item);
    position: absolute;
    left: -60px;
    font-size: 48px; /* 2x větší než text */
    font-weight: bold;
    line-height: 50px;
    margin-top:-15px;
}


#swiper-gallery
{
    --bs-gutter-x: 0;
    position:relative;
    overflow: hidden;/*
    margin:0 -38px 0 -38px;
    padding:0 38px;*/

    margin:70px 0 70px 0;
    padding:0;
}

#swiper-gallery .swiper-button-next, #swiper-gallery .swiper-button-prev
{
    border-radius: 0;
    height: 96px;
    width: 102px;
    position: absolute;
    top:0;
    margin-top:0;
    background: #c32e1b;
}

#swiper-gallery .swiper-button-prev
{
    left:auto;
    right:102px;
    margin-left:auto;
    z-index:10;
}

.swiper-button-next::after, .swiper-button-prev::after
{
    display: none;
}

.swiper-button-next::before, .swiper-button-prev::before
{
    font-size:0;
    background:url('assets/images/icons/arrow.svg') no-repeat center center;
    height:28px;
    width: 28px;
    background-size: contain;
    content:'';
    margin-right:20px;
}

#swiper-gallery .swiper-button-prev:before
{
    transform: rotateZ(180deg);
    margin-left:20px;
    margin-right:0;
}

#swiper-gallery .swiper-button-prev
{
    left:0;
}

#swiper-gallery .swiper-button-next
{
    right:0;
}

@media(max-width: 992px)
{
    #swiper-gallery .swiper-button-next, #swiper-gallery .swiper-button-prev {
        border-radius: 0;
        height: 60px;
        width: 65px;
    }

    #swiper-gallery .swiper-button-prev {
        right:62px;
    }

    #swiper-gallery .swiper-button-prev::before
    {
        margin-right:10px;
        margin-left:10px;
    }

    #swiper-gallery .swiper-button-next::before
    {
        margin-left:10px;
    }

}

#swiper-gallery figure.wp-block-image {
    flex-shrink: 0;
    width: 100%;
    height: 100%;
    position: relative;
    transition-property: transform;
}

#swiper-gallery .is-layout-flex
{
    flex-wrap: nowrap;
    gap: 0;
}

#swiper-gallery figure.wp-block-image
{
    height: 0;
    padding-top:56%;
    position: relative;
}

#swiper-gallery figure.wp-block-image>a, #swiper-gallery figure.wp-block-image>img
{
    position: absolute;
    left: 0;
    top:0;
    bottom:0;
    right:0;
}

.swiper-button-next.swiper-button-disabled, .swiper-button-prev.swiper-button-disabled
{
    opacity:0.7!important;
}


    /********************* footer **********************/


footer
{
    padding-top:120px;
    color:#000000;
    position:relative;
    font-size:13px;
}

footer:after
{
    width:100%;
    display:block;
    content:'';
    z-index:-1;
    left:0;
    right:0;
    top:-120px;
    bottom:0;
    position: absolute;
    background-image: linear-gradient(to bottom, rgba(248, 248, 248, 0), #f8f8f8);
}

footer>*
{
    z-index:1;
}

footer p:empty {
    display: none;
}

footer h2
{

    font-size: 24px;
    font-weight: 600;
    line-height:25px;
    margin-bottom:18px;
    margin-top:20;
}

footer h2:after
{
    width:74px;
    display: block;
    content:'';
    background: #000000;
    height:1px;
    margin-top:13px;
}

footer .footer-menus  ul.social-menu
{
    display: flex;
    margin:-8px -8px 0 -8px;
}

footer .social-menu li
{
    padding:0 3px;
}

footer li.only-head
{
    display: none;
}

footer .social-menu li a:hover svg path, a.svg svg path, .svg a svg path
{
    transition:all 0.2s ease-in-out;
}

footer a, footer li a.nav-link
{
    color:#000000;
    text-decoration:none;
}

footer a:hover, footer li a.nav-link:hover
{
    color:#000000;
    text-decoration:underline;
}

.footer-menus ul
{
    list-style-type:none;
    margin-left:0px;
    padding-left:0;
    margin-top:-8px;
}

@media(min-width: 400px)
{
    .footer-menus #menu-informace
    {
        column-count: 2;
    }
}

.footer-menus li.hide-in-footer
{
    display: none;
}

.footer-menus li a
{
    font-size:13px;
    padding:8px 0;
    line-height:19px;
    transition: all 0.3s ease-in-out;
}

.footer-menus ul.footer-menu
{
    column-count: 2;
    column-gap: 100px;
}

.footer-menus ul.footer-menu li {
    -webkit-column-break-inside: avoid;
}

.footer-menus ul.footer-menu li a
{
    position: relative;
    padding-left:31px;
    font-size: 14px;
    transition: color 0.3s ease-in-out;
}

.footer-menus ul.footer-menu li a:hover
{
    color:#000000;
    text-decoration: underline;
}

#footer-copy
{
    font-size: 12px;
    color: #666666;
    background: white;
    margin-top: 90px;
    padding-top:55px;
    padding-bottom:45px;
}

#footer-copy li a.nav-link
{
    padding:0;
}

#footer-copy a
{
    color: #666666;
}

#copy
{
    margin-bottom:20px;
}

hr.wp-block-separator, hr
{
    opacity: 1;
    border-top: 1px solid #000000;
}




#referenceCarousel .carousel-item
{
    display: block!important;
    opacity:0;
    transition: all 0.5s ease-in-out, opacity 0ms;
}

#referenceCarousel .carousel-item.carousel-item-next
{
    margin-right:-100%;
    margin-left:100%;
    transition:none;
}

#referenceCarousel .carousel-item.active, #referenceCarousel .carousel-item.carousel-item-next
{
    opacity:1;
}

body:not(.lang-cs) .only-cs, body:not(.lang-en) .only-en
{
    display: none;
}

.gdpr-menu
{
    margin-left:-10px;
    margin-right:-10px;
}

.gdpr-menu li
{
    padding-left:10px;
    padding-right:10px;
}













