/*
 Theme Name:   cec-livecanvas

 License: GPL-2.0
 License URI: http://www.opensource.org/licenses/gpl-license.php
*/

@import url('https://code.ionicframework.com/ionicons/2.0.1/css/ionicons.min.css');
@import url('https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,100;0,300;0,400;0,500;0,700;0,900;1,100;1,300;1,400;1,500;1,700;1,900&display=swap');

* {
    font-family: 'Roboto', sans-serif;
    color: #434343;
}

:root {
    --white: #ffffff;
    --black: #000;
    --red: #EF2B35;
    --dblue: #1D3E6D;
    --text: #3C3C3C;
}

:focus-visible {
    outline: 1px solid gainsboro;
    border-radius: 16px;
}

h1 {
    font: normal normal bold 70px/85px Roboto;
    letter-spacing: 0px;
}

h2 {

    font: normal normal bold 56px/76px Roboto;
    letter-spacing: 0px;
}

h3 {
    font: normal normal bold 50px/65px Roboto;
}

h4 {
    font: normal normal bold 30px/45px Roboto;
}

h5 {
    font: normal normal bold 25px/30px Roboto;
}

p {
    font: normal normal normal 16px/24px Roboto;
}

a {
    text-decoration: none;
}

@media screen and (max-width: 767px) {
    h1 {
        font: normal normal bold 32px/42px Roboto;
    }

    h2 {

        font: normal normal bold 40px/76px Roboto;
    }

    h3 {
        font: normal normal bold 32px/45px Roboto;
    }

    h4 {
        font: normal normal bold 28px/38px Roboto;
    }

    p {
        font: normal normal normal 16px/24px Roboto;
    }
}

.color-red {
    color: var(--red);
}

.sticky {
    position: -webkit-sticky;
    position: sticky;
    top: -50px;
    z-index: 1000;
    transition: all 0.3s ease-in-out;

}

/* Header */
.top-bar {
    max-height: 50px;
    display: flex;
    align-items: center;
    transition: max-height 0.3s ease-out, padding 0.3s ease-out;
    overflow: hidden;
}

.top-bar.hide {
    max-height: 0;
    padding: 0;
}

.top-bar .item:first-child {
    margin-right: 32px;
}

.top-bar .item svg {
    margin-right: 5px;
    width: 23px;
    height: 23px;
}

.top-bar a {
    text-decoration: unset;
    font-weight: bold;
    font-size: 16px;
}

#logo-tagline-wrap img {
    width: 400px;
}

#menu-hlavni-menu .nav-link {
    color: #434343;
    font-weight: bold;
    font-size: 16px;
    padding-right: 16px;
    padding-left: 16px;

}


#menu-hlavni-menu .menu-item:last-child .nav-link {
    color: white;
    background-color: #EF2B35;
    border-radius: 4px;
    margin-left: 16px;
}

#menu-hlavni-menu .menu-item:last-child .nav-link:hover,
.btn-red:hover,
.wpcf7-submit:hover {
    background-color: #A12026 !important;
}

/* GDPR */
.popup-gdpr {
    display: none;
}

.popup-gdpr h3,
.privacy-policy h3 {
    text-align: center;
    font: normal normal bold 40px Roboto;
    letter-spacing: 0.38px;
    color: #404040;
    margin-top: 0;
    margin-bottom: 24px;
}

.privacy-policy h3 {
    margin-top: 20px;
}

.popup-gdpr h4,
.privacy-policy h4 {
    text-align: center;
    font: normal normal bold 32px Roboto;
    letter-spacing: 0.3px;
    color: #404040;
    margin-top: 40px;
    margin-bottom: 24px;
}

.popup-gdpr p,
.privacy-policy p {
    text-align: left;
}

.popup-gdpr.active {
    padding-block: 50px;
}

.popup-gdpr.active {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: auto;
    z-index: 99999;
    padding: 20px;
    box-sizing: border-box;
    background-color: #000;
    background-color: rgba(0, 0, 0, 0.75);
    text-align: center;
    display: block;
}

.popup-gdpr-body-inner {
    position: relative;
    max-width: 80%;
    margin-inline: auto;
    background: #F5F6F9;
    border-radius: 15px;
    padding: 100px;
}

.privacy-policy #container-content-page {
    margin-block: 80px;
    background: #F5F6F9 0% 0% no-repeat padding-box;
    border-radius: 16px;
}

@media (max-width: 767px) {
    .privacy-policy #container-content-page {
        margin-block: 40px;
    }

    .popup-gdpr-body-inner {
        max-width: 100%;
        padding: 50px 30px;
    }

    .popup-gdpr h3,
    .privacy-policy h3 {
        font-size: 30px;
    }

    .popup-gdpr h4,
    .privacy-policy h4 {
        font-size: 24px;

    }

    .popup-gdpr p,
    .privacy-policy p {
        font-size: 16px !important;
        line-height: 21px !important;
    }
}

.close-icon {
    position: absolute;
    top: 50px;
    right: 50px;
    width: 30px;
    height: 30px;
    cursor: pointer;
}

@media (max-width: 767px) {
    .close-icon {
        top: 15px;
        right: 15px;
    }

}

.gdpr-info {
    font: normal normal normal 10px Roboto;
    letter-spacing: 0.09px;
    color: #00000099;
}

.gdpr-link {
    cursor: pointer;
    color: #26ABFF;

}

.nav-link:hover {
    background: #D6DCE4 0% 0% no-repeat padding-box;
    border-radius: 4px;
}

.top-bar {
    height: 60px;
}

#wrapper-navbar nav {
    height: 75px;
}

.navbar {
    box-shadow: 0px 10px 20px #43434326;
}

.navbar-collapse {
    flex-grow: inherit;
}


@media screen and (max-width: 991px) {


    .navbar-collapse {
        background: white;
        z-index: 1;
        margin-left: auto;
        position: absolute;
        top: 75px;
        left: 0;
        width: 100%;
        box-shadow: inset 0px 1px 15px #17171726;
        z-index: 3;
    }

    #wrapper-navbar nav {
        max-height: 75px;
    }

    #wrapper-navbar nav .container {
        max-height: 40px;
    }

    nav .nav-link {
        margin-block: 5px;
        font-size: 21px;
    }


    [data-bs-theme=dark] .navbar-toggler-icon {
        --bs-navbar-toggler-icon-bg: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' id='Component_37_2' data-name='Component 37 – 2' width='40' height='40' viewBox='0 0 40 40'%3E%3Crect id='Rectangle_407' data-name='Rectangle 407' width='40' height='40' fill='%23fff'/%3E%3Cg id='Group_1243' data-name='Group 1243' transform='translate(-54.674 -51.127)'%3E%3Cpath id='Path_2369' data-name='Path 2369' d='M13072.674,67.127h30' transform='translate(-13013 14)' fill='none' stroke='%231d3e6d' stroke-width='4'/%3E%3Cpath id='Path_2368' data-name='Path 2368' d='M13082.447,67.127h30' transform='translate(-13022.772 4)' fill='none' stroke='%231d3e6d' stroke-width='4'/%3E%3Cpath id='Path_2367' data-name='Path 2367' d='M13072.674,67.127h30' transform='translate(-13013 -6)' fill='none' stroke='%231d3e6d' stroke-width='4'/%3E%3C/g%3E%3C/svg%3E");
    }

    .navbar-toggler[aria-expanded="true"] .navbar-toggler-icon {
        --bs-navbar-toggler-icon-bg: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40' viewBox='0 0 40 40'%3E%3Crect width='40' height='40' fill='%23fff'%3E%3C/rect%3E%3Cg fill='none' stroke='%231d3e6d' stroke-width='4'%3E%3Cpath d='M 10,10 L 30,30'%3E%3C/path%3E%3Cpath d='M 30,10 L 10,30'%3E%3C/path%3E%3C/g%3E%3C/svg%3E");
    }

    #navbarNavDropdown ul {
        padding: 40px 15px;
    }

    #navbarNavDropdown li {
        border-bottom: 2px solid #D6DCE4;
    }

    #navbarNavDropdown li:last-child {
        border-bottom: 0;
        margin-top: 30px;
    }

    #menu-hlavni-menu .menu-item:last-child .nav-link {
        margin-left: 0;
        text-align: center;
    }

    .mob-menu-show {
        width: 100%;
        position: fixed;
        overflow: hidden;
        -webkit-overflow-scrolling: touch;
    }

    .navbar-collapse.collapsing {
        transition: height 0.5s ease;
    }

    .navbar-nav {
        height: calc(100vh);
    }


}

@media screen and (max-width: 575px) {
    #logo-tagline-wrap img {
        width: 251px;
    }

    #wrapper-navbar {
        position: fixed;
        width: 100%;
        top: 0;
        z-index: 4;
    }

    .sticky {
        top: 0;
    }
}

@media screen and (max-width: 400px) {
    #logo-tagline-wrap img {
        width: 230px;
    }
}

/* End of header */

/* Buttons */
.btn-container a {
    font-weight: bold;
    padding: 10px 24px;
    text-decoration: none;
    border-radius: 4px;
}

.btn-red {
    background-color: var(--red);
}

.btn-black {
    background-color: var(--black);
}

.btn-container {
    display: flex;
    font-size: 16px;
    line-height: 19px;
}

@media screen and (max-width: 767px) {

    #onas .btn-container a,
    .btn-container a {
        width: 100%;
        display: block;
        text-align: center;
    }
}

/* End of buttons */

/* Carousel a Slick */
#carouselHP button {
    display: none;
}

#carouselHP {
    max-height: 640px;
}

#carouselHP h1 {
    text-shadow: 0px 10px 20px #000000;
}

#carouselHP .carousel-item {
    transition: transform .5s ease-in-out !important;
    backface-visibility: hidden;
    perspective: 1000px;
    overflow: hidden;
    max-height: 650px;
    height: 100vh;
    background: no-repeat center center scroll;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
}

#carouselHP .carousel-item .container {
    height: 100%;
    display: flex;
    align-items: center;
}

#carouselHP .carousel-content {
    position: relative;
    width: 50%;
    padding-top: 1.25rem;
    padding-bottom: 1.25rem;
    color: #fff;
    text-align: left;
}

#carouselHP .carousel-buttons {
    display: flex;
    gap: 20px;
}

#carouselHP .carousel-desc {
    margin-block: 24px 30px;
    font: normal normal normal 16px/24px Roboto;
}

#carouselHP #carouselHP .btn-container a {
    padding: 10px 24px;
    text-decoration: none;
    font: normal normal bold 24px/28px Roboto;
    border-radius: 4px;
}

.carousel-dark .carousel-control-prev-icon,
.carousel-dark .carousel-control-next-icon {
    background-image: unset;
    filter: unset;
    background-color: #D6DCE4;
    border-radius: 8px;
    width: auto;
    height: auto;
}

.carousel-control-prev {
    left: -70px;
}

.carousel-control-next {
    right: -70px;
}

.carousel-indicators,
.slick-dots {
    position: absolute;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 2;
    display: flex;
    justify-content: center;
    padding: 0;
    margin-right: 15%;
    margin-bottom: 1rem;
    margin-left: 15%;
}

.carousel-indicators [data-bs-target],
.slick-dots button {
    border: unset !important;
    background-color: #ADB9CA !important;
    width: 30px !important;
    height: 5px !important;
    border-radius: 3px !important;
    opacity: 0.5 !important;
}

.carousel-indicators .active,
.slick-dots .slick-active button {
    background-color: #0E2B5C !important;
    opacity: 1 !important;
}

.slick-dots {
    display: flex !important;
    position: unset !important;
    justify-content: center;
    padding-left: 0;
    gap: 6px;
    justify-content: center;
    margin-inline: 0 !important;
}

.slick-dots li button {
    font-size: 0;
}

.slick-dots li {
    border-bottom: none;
    margin-right: 0px;
    list-style: none;
}

.slick-dots li::marker {
    display: none;
}


@media screen and (max-width: 1470px) {

    .carousel-control-prev,
    .carousel-control-next {
        display: none;
    }
}

@media screen and (max-width: 1200px) {
    #carouselHP .carousel-content {
        width: auto;
    }
}

@media screen and (max-width: 991px) {
    #second-carousel .carousel-indicators {
        bottom: 0px !important;
    }
}

@media screen and (max-width: 767px) {
    .carousel-buttons {
        flex-direction: column;
    }

    #second-carousel .carousel-indicators {
        bottom: 0 !important;
    }

    #carouselHP .btn-container a {
        font: normal normal bold 16px/19px Roboto;
        width: 100%;
        display: flex;
        justify-content: center;
    }

    #carouselHP .carousel-content {
        width: 100%;
    }

}

/* O nás */

#onas {}

.onas-img {
    min-height: 420px;
    background-size: cover;
    background-position: center;
    background-image: url('https://cec.xevos.eu/wp-content/uploads/2024/02/o-nas-min.jpg');
    border-radius: 16px;
    position: relative;

}

.onas-img .svg-container {
    position: absolute;
    background-color: #1D3E6D;
    border-radius: 16px;
    bottom: -105px;
    left: 0;
    padding: 40px;
}

.onas-img svg {
    width: 130px;
    height: 130px;
}

#onas .btn-container {
    margin-top: 40px;
}

#onas .btn-container a {
    font-size: 16px;
    line-height: 19px;
}

@media screen and (max-width: 767px) {

    .onas-img {
        min-height: 260px;
        width: calc(100% - 20px);
        margin-inline: auto;
    }

    .onas-img .svg-container {
        padding: 20px;
        bottom: -54px;
    }

    .onas-img svg {
        width: 65px;
        height: 65px;
    }

}

@media screen and (max-width: 500px) {
    .onas-img {
        min-height: 150px;
        max-height: 150px;
    }
}

/* Druhy práce */

#sluzby {
    background-color: #F5F6F9;
}

#sluzby h3 {
    margin-bottom: 30px;
}

.cards-blocks {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
}

.card-block {
    background-color: #fff;
    padding: 40px;
    box-shadow: 0px 0px 20px #001E4A26;
    border-radius: 16px;
    cursor: pointer;
}

.card-block.active {
    box-shadow: 0px 0px 20px #001E4A99;
    outline: 2px solid #EF2B35;
}

.card-block-headline {
    font: normal normal bold 20px/28px Roboto;
    letter-spacing: 0px;
    color: #1D3E6D;
    margin-block: 24px 32px;
}

.card-block-image svg {
    fill: var(--red);
    width: 57px;
    height: 57px;
}

.cards-content ul,
.cards-content li {
    list-style: unset;
    list-style-type: none;
}

.cards-content ul {
    padding-left: 0;
}

.cards-content ul li {
    display: flex;
    font-weight: bold;
    font-size: 18px;
    gap: 10px;
    margin-bottom: 25px;
}

.cards-content ul li::before {
    content: '';
    width: 25px;
    height: 25px;
    background-color: var(--red);
    display: inline-block;
    border-radius: 5px;
}

.card-content:not(.active) {
    display: none;
}

@media screen and (max-width: 1300px) {
    .cards-blocks {
        gap: 15px;
    }
}

@media screen and (max-width: 560px) {
    #sluzby .btn-red {
        width: 100%;
        text-align: center;
        display: block;
    }
}

/* Reference */

#reference {}

#reference .carousel-inner {}

#second-carousel {
    min-height: 440px;
    position: relative;
}

#second-carousel .carousel-indicators {
    bottom: 45px;
    height: 20px;
}

#second-carousel .carousel-desc {
    display: none;
}

#reference .carousel-content>.row {
    display: flex;
    align-items: center;
}

.ref-counter {
    font-size: 20px;
    font-weight: bold;
}

#reference h3 {
    margin-bottom: 40px;
}

#reference h4 {
    margin-bottom: 24px;
}

.ref-logo-holder {
    margin-bottom: 40px;
}

.ref-logo-holder img {
    max-width: 240px;
}

.ref-img {
    position: relative;
}

.ref-img>img {
    display: block;
    border-radius: 16px;
}

.testimonials {
    position: absolute;
    bottom: -23%;
    right: -3%;
    box-shadow: 0px 0px 30px #43434326;
    border-radius: 16px;
    max-width: 400px;
    background-color: #fff;
    font: normal normal normal 14px Roboto;
    letter-spacing: 0px;
    color: #434343;
}

.testimonials img {
    width: 40px;
}

.testimonials span {
    display: block;
    margin-block: 16px;
}

.testimonials span+img {
    float: right;
}

@media screen and (max-width: 767px) {
    #reference h3 {
        margin-bottom: 24px;
    }

    #reference h4 {
        margin-bottom: 16px;
    }

    .ref-logo-holder {
        margin-bottom: 32px;
    }

    .testimonials {
        right: -3%;
    }
}

@media screen and (max-width: 600px) {

    .testimonials {
        right: 1%;
        bottom: -15%;
    }

    .testimonials img {
        width: 30px;
    }

    .testimonials span {
        margin-block: 8px;
    }
}

@media screen and (max-width: 576px) {
    body {
        padding-top: 75px;
    }

    .testimonials {
        position: relative;
        right: -4%;
        margin-top: -9%;
    }

    .testimonials span+img {
        margin-left: auto;
        float: unset;
    }
}

/* Proces */
#proces {
    background-color: #F5F6F9;
}


#proces svg.arrow-right {
    stroke: #EF2B35;
}

#proces svg:not(.arrow-right) {
    fill: #EF2B35;
    width: 76px;
    height: 76px;
}

#proces .col:not(.col-arrow) {
    display: flex;
    flex-direction: column;
}

.col-arrow {
    display: flex;
    justify-content: center
}

.proces-headline {
    margin-top: 24px;
    font: normal normal bold 25px/30px Roboto;
    letter-spacing: 0px;
    color: #1D3E6D;
}


/* Kontakt */

#kontakt {
    background-color: #1D3E6D;
}

.kontakt-block {
    display: flex;
    flex-direction: column;
    gap: 30px;
}

.kontakt-block .item {
    display: flex;
    align-items: center;
    gap: 16px;
    font: normal normal normal 20px/30px Roboto;
}

#kontakt p {
    font: normal normal normal 20px/30px Roboto;
}

.kontakt-block a {
    width: 230px;
    font: normal normal bold 25px/29px Roboto;
}

.wpcf7 {
    padding: 50px 35px;
    background-color: #fff;
    border-radius: 16px;
}

.wpcf7 .screen-reader-response {
    display: none;
}

.wpcf7 .col-12:last-child {
    position: relative;
}

.wpcf7-spinner {
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
}

.wpcf7-form-control-wrap,
.wpcf7-form-control-wrap input,
.wpcf7-form-control-wrap textarea {
    display: block;
    width: 100%;
    height: 100%;
}

.wpcf7-form-control-wrap input,
.wpcf7-form-control-wrap textarea {
    border: unset;
    border-radius: 4px;
    font: normal normal normal 16px/24px Roboto;
}

.wpcf7-form-control-wrap textarea {
    height: 120px;
}

.wpcf7-not-valid-tip {
    display: none;
}

input.wpcf7-form-control.wpcf7-submit {
    background-color: #EF2B35;
    border: unset;
    border-radius: 4px;
    color: #fff;
    width: 100%;
    font-size: 16px;
    font-weight: bold;
    padding-block: 10px;
}

.wpcf7-response-output {
    border: unset !important;
    border-radius: 4px;

}

/* 
.wpcf7-not-valid,
.wpcf7-response-output {
    outline: 1px solid #EF2B35 !important;
    margin-inline: 0 !important;
    padding: 10px 18px;
    outline: unset !important;
    padding: 0 !important;
} */

/* Materials */
.mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__leading,
.mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__notch,
.mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__trailing {
    border-color: #26ABFF !important;
}

.mdc-text-field--focused:not(.mdc-text-field--disabled) .mdc-floating-label {
    color: #26ABFF !important;
}

.mdc-text-field--invalid:not(.mdc-text-field--disabled) .mdc-notched-outline__leading,
.mdc-text-field--invalid:not(.mdc-text-field--disabled) .mdc-notched-outline__notch,
.mdc-text-field--invalid:not(.mdc-text-field--disabled) .mdc-notched-outline__trailing {
    border-color: #EF2B35 !important;
}

.mdc-text-field--invalid:not(.mdc-text-field--disabled) .mdc-floating-label {
    color: #EF2B35 !important;
}

.mdc-text-field,
.mdc-text-field--textarea {
    width: 100% !important;
}

.mdc-text-field--textarea textarea {
    height: 120px;
}

@media screen and (max-width: 767px) {
    .kontakt-block a {
        font: normal normal bold 20px/24px Roboto;
    }

    .wpcf7 {
        padding: 35px 25px
    }

    footer {
        padding-inline: 10%;
    }
}

/* Footer */

footer {
    font: normal normal normal 14px/16px Roboto;
    padding-block: 35px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    text-align: center;
    background-color: #000;
    color: #fff;
    border-top: 1px solid #707070;
}

footer a {
    color: #fff;
    text-decoration: underline;

}

@media screen and (max-width: 767px) {
    .slick-track {
        padding-block: 20px;
        display: flex !important;
        gap: 20px;
        margin-left: 10px !important
    }

    .card-block {
        height: 360px !important;
        width: 260px !important;
    }

    #sluzby .container,
    #proces .container {
        margin: 0;
        width: 100%;
        max-width: 100%;
    }

    #sluzby .container .row>div:nth-child(2) {
        max-width: 540px;
        margin-inline: auto;
    }

    .proces-track .col {
        width: 100px;
        height: 160px;
        flex: unset;
    }

    .proces-track .col.col-arrow {
        display: flex;
        width: 80px;
    }

}

@media screen and (max-width: 560px) {
    .card-block {
        width: 260px !important;
    }

}