﻿body {
    font-family: Syne,sans-serif;
    text-rendering: optimizeLegibility;
    padding: 0px;
    margin: 0px;
    padding-top: 89px;
    background: #fff;
    min-height: 100vh;
}

.rezervaceVyber {
    padding-top: 30px;
    padding-bottom: 10px;
    min-height: calc(100vh - 111px);
}

/* Override the default bootstrap behavior where horizontal description lists 
   will truncate terms that are too long to fit in the left column 
*/
.dl-horizontal dt {
    white-space: normal;
}

/* Set width on the form input elements since they're 100% wide by default */
input,
select,
textarea {
    max-width: 380px;
}




@media (min-width: 1600px) {
    .all-products-container {
        max-width: 1500px;
    }
}


@media (min-width: 2200px) {
    .all-products-container {
        max-width: 1900px;
    }
}


#header {
    position: fixed;
    width: 100%;
    top: 0px;
    transition: all .4s ease-in-out;
    background: #4EAD9E;
    z-index: 9;
}

    /*#header.small
    {
        height: 200px;
    }*/

   

    #logo{
        width: 200px;
    }


.navbar {
    padding-top: 0px;
    padding-bottom: 0px;

}


.nav-item.accountItem .nav-link,
.nav-item.cartItem .nav-link,
.navbar-nav .nav-link {
    line-height: 90px;
    padding: 0px 18px !important;
    text-transform: uppercase;
    color: #fff !important;
    font-weight: 400;
    font-size: 1rem;
    transition: all .4s ease-in-out;
}

.nav-item {
    transition: all .3s ease-in-out;
    position: relative;
}

    .nav-item:hover {
        background: #83C6BB;
    }


.nav-item.active {
    /*background: #f2f2f2;*/
}

.nav-item.active .nav-link {
    font-weight: 700 !important;
}


    .nav-item.active:after,
    .nav-item.active:before {
        content: "";
        display: block;
        width: 0;
        height: 0;
        border-style: solid;
        border-width: 0 7px 6px;
        border-color: transparent transparent #cecece;
        position: absolute;
        left: 50%;
        margin-left: -7px;
        bottom: 0px;
    }


    .nav-item.active:after
    {
        display: block;
        border-color: transparent transparent #fff;
        bottom: -1px;
    }




#header.small {
    padding-top: 0px;
}


#header.small .nav-link {
    line-height: 51px;
}


.typGold {
    border-color: #cf3939 !important;
    /*box-shadow: inset 34px 0px 46px -8px #fde627;*/
}
.typPlatinum {
    border-color: #333 !important;
    /*box-shadow: inset 34px 0px 46px -8px #ff1e1e;*/
}
.typSilver {
    border-color: #1179d2 !important;
    /*box-shadow: inset 34px 0px 46px -8px #b2faff;*/
}


#content {
    position: relative;
}

#loadingApp2 {
    position: fixed;
    background: rgba(255, 255, 255, .6);
    z-index: 9999;
    top: 0px;
    left: 0px;
    bottom: 0px;
    right: 0px;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
}



.fade-enter-active, .fade-leave-active {
    transition: opacity .2s ease-out;
}

.fade-enter, .fade-leave-to {
    opacity: 0;
}




#slideIndicator 
{
    text-align: center;
    position: relative;
    top: -10px;
}

#slideIndicator > span {
    height: 15px;
    width: 15px;
    border: 1px solid #fff;
    border-radius: 50%;
    display: inline-block;
    transition: all .3s ease;
    cursor: pointer;

}

.arrowBar {
    display: flex;
    position: absolute;
    right: 0px;
    top: 35px;
    bottom: 20px;
    align-items: center;
    justify-content: flex-end;
    padding: 0px 5px;
    cursor: pointer;
    width: 50px;
    /*background: rgba(0,0,0, 0.2);*/
    /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#ffffff+0,ffffff+100&0+0,0.8+32,1+76 */
    background: -moz-linear-gradient(left, rgba(255,255,255,0) 0%, rgba(255,255,255,0.8) 30%, rgba(255,255,255,1) 75%, rgba(255,255,255,1) 100%);
    background: -webkit-linear-gradient(left, rgba(255,255,255,0) 0%,rgba(255,255,255,0.8) 30%,rgba(255,255,255,1) 75%,rgba(255,255,255,1) 100%);
    background: linear-gradient(to right, rgba(255,255,255,0) 0%,rgba(255,255,255,0.8) 30%,rgba(255,255,255,1) 75%,rgba(255,255,255,1) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00ffffff', endColorstr='#ffffff',GradientType=1 );
}

    .arrowBar.left {
        justify-content: flex-start;
        left: 0px;
        right: auto;
        background: -moz-linear-gradient(left, rgba(255,255,255,1) 0%, rgba(255,255,255,1) 25%, rgba(255,255,255,.8) 70%, rgba(255,255,255,0) 100%);
        background: -webkit-linear-gradient(left, rgba(255,255,255,1) 0%,rgba(255,255,255,1) 25%,rgba(255,255,255,.8) 70%,rgba(255,255,255,0) 100%);
        background: linear-gradient(to right, rgba(255,255,255,1) 0%,rgba(255,255,255,1) 25%,rgba(255,255,255,.8) 70%,rgba(255,255,255,0) 100%);
    }



    

.arrowBar > * {
    opacity: .7;
    transition: all .3s ease;
}

    .arrowBar:hover > * {
        opacity: 1;
        color: #4EAD9E;
    }

.slideArrow {
    position: absolute;
    top: calc(50% - 50px);
    right: -10px;
    color: #a2a2a2;
    box-shadow: 0px 0px 10px 5px rgba(255, 255, 255, .7);
    background: rgba(255, 255, 255, .8);
    border-radius: 50%;
    cursor: pointer;
    opacity: .7;
    transition: all .3s ease;
}


    .slideArrow:hover {
        /*box-shadow: 0px 0px 10px 5px #fe5a0e;*/
        color: #fe5a0e;
        opacity: 1;
    }

    #slideIndicator > span:hover {
        box-shadow: 0px 0px 4px 2px #fe5a0e;
        border-color: #fe5a0e;
    }

    
#slideIndicator > span.active {
    background: #fff;
}

.category {
    border: 1px solid #e9ecef;
    transition: border .2s linear;
    cursor: pointer;
    padding: 0px;
    margin-left: 20px;
    margin-bottom: 20px;
    position: relative;
    overflow: hidden;
} 

.category.selected{
    border: 1px solid #ff6a00;
}

.category-title {
    text-align: center;
    color: #fff;
    padding: 10px 0px;
    background: #83C6BB;
    position: relative;
    transition: .5s ease;
}

    .category-title:before {
        content: "";
        display: block;
        background: #83C6BB;
        width: 105%;
        height: 100px;
        position: absolute;
        left: 0;
        top: 0;
        -ms-transform-origin: 0 0;
        transform-origin: 0 0;
        -ms-transform: rotate(-12deg);
        transform: rotate(-12deg);
        transition: .5s ease;
    }


.category:hover .category-title:before {
    -ms-transform: rotate(-16deg);
    transform: rotate(-16deg)
}


.category.selected .category-title,
.category.selected .category-title:before {
    background: #171718;
    color: #fff;
}

.vyberTerminu {
    background: #171718;
    padding: 20px;
    color: #fff;
    height: calc( 100% - 35px);
}


.vyberTerminu input[type=radio] {
    transform: scale(1.3);
}




.redLeftBorder:before{
    content: '';
    position: absolute;
    background: #f00;
    left: 0px;
    top: 5px;
    bottom: 5px;
    width: 4px;
}


#allProducts {
    margin: 0px -30px;
}


@media (min-width: 2200px) {
    .productItemContainer {
        flex: 0 0 33.333333%;
        max-width: 33.333333%;
    }
}

.borderedPanel {
    border: 1px solid #ededed;
    border-radius: 4px;
    padding: 5px;
}

.pagerItem{
    border: 1px solid #aaa;
    padding: 3px 0px;
    display: inline-block;
    width: 30px;
    margin: 0px 5px;
    cursor: pointer;
    text-align: center;
    cursor: pointer;

}


.pagerItem:hover {
   background: #f2f2f2;
}

.pagerItem.selected {
    border-color: #ff6a00;
}


[v-cloak] {
    display: none;
}

.productImage {
    background-size: contain;
    background-position: center center;
    background-repeat: no-repeat;
    width: 100%;
    min-height: 80px;
    height: calc(100% - 40px);
    cursor: pointer;
}

.productImage.bike {
    /*width: 70%;*/
    min-height: 200px;
    /*float: left;*/
}


.productImage .lupa {
    position: absolute;
    opacity: .3;
    top: 2px;
    right: 5px;
}



    .productImage:hover .lupa {
        opacity: 1;
    }


.vyberPodpolozkuContainer {
    position: relative;
    cursor: pointer;
    transition: all .2s linear;
    overflow: hidden;
    background-position: center center;
    background-size: contain;
    background-repeat: no-repeat;
    height: 150px;
    width: 150px;
    border: 1px solid #f2f2f2;
    padding: 0px;
    margin: 0px auto;
    display: flex;
    justify-content: center;
    align-items: center;
    /*background: #f8f8f8;*/
}


.vyberPodpolozkuContainer.small {
    height: 70px;
    width: 70px;
}


.vyberPodpolozkuInfo {
   max-width: 160px;
}

.vyberPodpolozkuInfoInsidePicture {
    position: absolute;
    left: 0px;
    right: 0px;
    padding: 3px 5px;
    bottom: 0px;
    white-space: normal;
    opacity: .2;
    background: rgba(255, 255, 255, .85);
    transition: all .3s;
}

.vyberPodpolozkuContainer:hover .vyberPodpolozkuInfoInsidePicture,
.vyberPodpolozkuContainer:hover .btnVyberButton {
    opacity: 1 !important;
}

.vyberPodpolozkuContainer.active {
    /*border: 1px solid #fde627;*/
    box-shadow: 0px 0px 14px 0px #5ee96e;
}

.vyberPodpolozkuContainer:hover {
    /*border: 1px solid #fde627;*/
    box-shadow: 0px 0px 14px 0px #fde627;
}

.vyberPodpolozkuContainer > .check_uncheck,
.vyberPodpolozkuContainer > .removePodProdukt {
    position: absolute;
    bottom: -5px;
    padding: 0px;
    font-size: 20px;
    right: 0px;
    color: #17b729;
    
    padding: 4px;
}

    .vyberPodpolozkuContainer .fa {
        background: rgba(255, 255, 255, .8);
    }

.vyberPodpolozkuContainer > .removePodProdukt {
    bottom: unset;
    top: -5px;
    color: #f00;
    display: none;
}

.vyberPodpolozkuContainer .check {
    display: none;
}


.vyberPodpolozkuContainer.active .removePodProdukt {
    display: block;
}

.vyberPodpolozkuContainer.active .check {
    display: block;
}

.vyberPodpolozkuContainer.active .uncheck {
    display: none;
}


.vyberPodpolozkuContainer.active {
    /*border: 1px solid #ff6a00;*/
}

    .vyberPodpolozkuContainer.active > img {
        opacity: 1;
    }



.vyberPodPolozku {
    /*height: 500px;*/
    max-height: 65vh;
    overflow-x: hidden;
    overflow-y: auto;
    /*width: 400px;*/
}


    .vyberPodPolozku .PodPolozka {
        transition: all .1s linear;
        min-height: 100px;
        cursor: pointer;
        border-bottom: 1px solid #aaa;
        padding: 10px 0px;
    }

        /*.vyberPodPolozku .PodPolozka:hover {
            transform: scale(1.1);
            border-bottom: 1px solid #aaa;
            border-top: 1px solid #aaa;
        }*/


.popover
{
    max-width: unset;
}

.cena {
    font-size: 18px;
    font-weight: bold;
    color: #FF5A0E;
}


.cenaCelkem {
    font-size: 15px;
    font-weight: bold;
    color: #FF5A0E;
}

.zaloha {
    font-size: 14px;
    font-style: italic;
}

.account-menu,
.cartMiniDetail {
    position: absolute;
    background: #f9f9f9ee;
    border: 1px solid #ccc;
    border-radius: 5px;
    top: 25px;
    right: 100%;
    width: 300px;
    visibility: hidden;
    opacity: 0;
    padding: 5px 10px;
    transition: all .2s linear;
    font-size: 14px;
}

    .account-menu a {
        display: block;
        color: #505154 !important;
        padding: 5px 0px;
    }


#header.small .cartMiniDetail {
    top: 10px;
}

.accountItem:hover .account-menu {
    visibility: visible;
    opacity: 1;
}


.cartItem:hover .cartMiniDetail {
    visibility: visible;
    opacity: 1;
}


.account-menu:before,
.cartMiniDetail:before {
    position: absolute;
    background: transparent;
    content: '';
    border: 10px solid transparent;
    border-left: 10px solid #ccc;
    width: 1px;
    height: 1px;
    right: -20px;
    top: 10px;
}

.account-menu:after,
.cartMiniDetail:after {
    position: absolute;
    background: transparent;
    content: '';
    border: 8px solid transparent;
    border-left: 8px solid #f9f9f9;
    width: 1px;
    height: 1px;
    right: -16px;
    top: 12px;
}


.account-menu > div,
    .cartMiniDetail > div{
    border-bottom: 1px solid #ccc;
    padding: 5px 0px;
    margin: 0px;
}


    .account-menu > div:last-child,
    .cartMiniDetail > div:last-child {
        border-bottom: none;
    }



.validationFailed{
    border: 1px solid #f00;
}


.categoryContainer {
    flex-direction: column;
    position: relative;
    height: 430px;
    overflow: hidden;
}

.categoryContainer > div{
    padding: 0px;
    flex-grow: 0;
    width: 220px;
}

.kosikPolozkaItem {
    border-left: none;
    padding-top: 10px;
    margin: 0px 0px;
}


.vyberPodpolozkuContainer {
    width: 100px;
    height: 100px;
}

.produktyFilterContainer {
    position: sticky;
    top: 50px;
    z-index: 3;
    padding: 10px 15px;
    background: #83C6BB;
    color: #fff;
}

.produktyFilterContainer > div {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 50px;
}


.filtry > strong {
    width: 50px;
    display: inline-block;
}


.velikostFiltr {
    width: 400px;
}

.seraditFiltr {
    width: 200px;
}


.required:after{
    content: '*';
    position: relative;
    display: inline-block;
}


.slide-enter-active, .slide-leave-active {
    transition: all .5s;
}

.slide-enter, .slide-leave-to /* .fade-leave-active below version 2.1.8 */ {
    transform: scale(0);
}



.slide-enter-to, .slide-leave /* .fade-leave-active below version 2.1.8 */ {
}



.appCartItems h2{
    font-size: 20px;
    font-weight: bold;
}


.tooltip-inner{
    width: 400px;
    max-width: 400px;
}


body.wysiwyg {
    padding: 0px;
}


.wysiwyg h2 {
    margin-top: 30px;
    text-transform: uppercase;
}


.wysiwyg table {
    border: none;
    width: 100%;
}

    .wysiwyg table th {
        background: #4EAD9E;
        color: #fff;
        font-weight: 700;
    }

    .wysiwyg table td, .wysiwyg table th {
        border: none;
        padding: 10px 20px;
        white-space: nowrap;
    }


    .wysiwyg table tr:nth-child(even) td {
        background: #e6e6e6;
    }


#allProducts .viceInfo {
    position: absolute;
    cursor: pointer;
}

.podPololozka {
    max-width: 200px;
}

.badge-primary {
    background: #FF5A0E;
}

.btn {
    border-radius: 6.1875rem;
    height: 3rem;
    background: #171718;
    padding: 0 1.5rem;
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.btn-link {
    color: #4EAD9E;
}

.btn-success.disabled, .btn-success:disabled {
    background: #171718;
    opacity: 1;
}

.podpolozkaTitle{
    height: 50px;
}

@media (max-width: 768px) {
    body{
        padding-top: 85px;
    }


    .categoryContainer{
        height: 215px;
    }


    .categoryContainer > div:last-child {
        width: 240px;
    }



    #logo {
        width: 150px;
        max-width: 40vw;
    }

    .navbar {
        padding: 10px 0px;
    }

    .vyberTerminu{
        height: initial;
    }

    .navbar-nav .nav-link{
        line-height: 300%;
        border-bottom: 1px solid #e8e8e8;
    }

    .nav-item.active {
        background: #f6f6f6
    }


    .nav-item.active:after, .nav-item.active:before
    {
        display: none;
    }


   


    .vyberPodpolozkuContainer {
        width: 35vw;
        height: 35vw;
    }


    .vyberPrislusenstviFiltry label,
    .vyberPrislusenstviFiltry select{
        width: 50%;
        display: inline-block;
    }


    .kosikPolozkaItem {
        border-left: none;
    }

    .vyberPodpolozkuContainer {
        width: 100%;
        height: 40vw;
    }

    .categoryContainer
    {
        overflow-x: auto;
    }

    #allProducts {
        margin: 0px -15px;
    }

        #allProducts .viceInfo {
            position: relative;
        }

    #allProducts > div{
        padding-left: 0px;
        padding-right: 0px;
        padding-bottom: 15px !important;
    }

        .podPololozka {
            max-width: 50%;
        }

    .podpolozkaTitle{
        white-space: nowrap;
        text-overflow: ellipsis;
        max-width: 100%;
        overflow-x: hidden;
        height: auto;
    }


    .produktyFilterContainer {
        position: fixed;
        display: none;
        top: 80px;
        z-index: 999;
    }

    
    .produktyFilterContainer > div {
        display: block;
    }

    .filtry {
        margin-bottom: 15px;
    }

    .filtry > strong {
        width: auto;
        display: inline-block;
    }


    .velikostFiltr {
        width: 100%;
    }

    .velikostFiltr  > div{
        padding: 0px !important;
    }

    .velikostSlider{
        padding: 0px 20px;
    } 
    
    .seraditFiltr {
        width: 100%;
    }
}


.top-banner {
    z-index: 9;
    text-align: center;
    position: fixed;
    top: 0px;
    left: 0px;
    right: 0px;
    background: #f66666;
    color: #fff;
    font-size: 13px;
    transition: all .4s ease-in-out;
    height: 30px;
    overflow: hidden;
}



    .top-banner > div{
        margin: 5px 10px;
    }

    #header.small .top-banner {
        height: 0px;
    }





.zruseniRezervace table{
    table-layout: fixed;
}


.zruseniRezervace table tr td:first-child {
    font-weight: bold;
    padding-right: 50px;
}

.zruseniRezervace table tr td:last-child {
    width: 250px;
}



.celkova-cena-sticky {
    padding: 0px;
    position: fixed;
    bottom: 0px;
    width: 100%;
    left: 0px;
    margin: auto;
    transition: all .5s ease-in;
    max-height: 0px;
    overflow: hidden;
}




    .celkova-cena-sticky > div {
        padding: 10px 20px;
        width: 500px;
        max-width: 95%;
        margin: auto;
        background: #4EAD9E;
        color: #fff;
        border-radius: 5px 5px 0px 0px;
        box-shadow: 0px 0px 10px #999;
        display: flex;
        justify-content: space-between;
        align-items: center;
    }



    .celkova-cena-sticky.is-sticky {
        max-height: 100px;
        overflow: unset;
    }


    .celkova-cena-sticky .cena-celkova {
        white-space: nowrap;
    }