html, body {
  max-width: 100vw;
  overflow-x: hidden;
}
body {
     font-family: "Manrope", sans-serif !important;
     background-color: #fff;
     position: relative;
}


 body:before {
     content: "";
     position: absolute;
     top: 0;
     left: 0;
     right: 0;
     bottom: 0;
     background: rgba(0, 0, 0, 0.5);
     -webkit-transition: .3s all ease;
     -o-transition: .3s all ease;
     transition: .3s all ease;
     opacity: 0;
     visibility: hidden;
     z-index: 1;
}
 body.offcanvas-menu:before {
     opacity: 1;
     z-index: 1002;
     visibility: visible;
}
 html {
     scroll-behavior: smooth;
}
 section{
     padding-top: 5vh;
}
 p {
     color: #b3b3b3;
     font-weight: 300;
}
 h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6 {
     font-family: "Open Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
}
 a {
     -webkit-transition: .3s all ease;
     -o-transition: .3s all ease;
     transition: .3s all ease;
}
 a, a:hover {
     text-decoration: none !important;
}
 .hero {
     height: 100vh;
     width: 100%;
     background-size: cover;
     background-position: center center;
     background-repeat: no-repeat;
     transition: background-size 0.2s ease-out;
}
 .top-bar {
     padding: .5rem 0;
     background: #eee;
}
 .top-bar a {
     color: #666666;
}
 .site-navbar {
     margin-bottom: 0px;
     z-index: 1999;
     position: relative;
     width: 100%;
     padding: 1rem;
}
 @media (max-width: 991.98px) {
     .site-navbar {
         padding-top: 1rem;
         padding-bottom: 1rem;
    }
}
 .site-navbar .toggle-button {
     position: absolute;
     right: 0px;
}
 .site-navbar .site-logo {
     position: absolute;
     font-size: 2rem;
     text-transform: uppercase;
     font-weight: 900;
     line-height: 0;
     margin: 0;
     padding: 0;
     z-index: 3;
}
 @media (max-width: 991.98px) {
     .site-navbar .site-logo {
         float: left;
         position: relative;
    }
}
 .site-navbar .site-navigation.border-bottom {
     border-bottom: 1px solid white !important;
}
 .site-navbar .site-navigation .site-menu {
     margin-bottom: 0;
}
 .site-navbar .site-navigation .site-menu .active {
     color: #007bff !important;
}
 .site-navbar .site-navigation .site-menu a {
     text-decoration: none !important;
     display: inline-block;
}
 .site-navbar .site-navigation .site-menu > li {
     display: inline-block;
}
 .site-navbar .site-navigation .site-menu > li > a {
     margin-left: 15px;
     margin-right: 15px;
     padding: 20px 0px;
     color: #000 !important;
     display: inline-block;
     text-decoration: none !important;
}
 .site-navbar .site-navigation .site-menu > li > a:hover {
     color: #f7e010;
}
 .site-navbar .site-navigation .site-menu .has-children {
     position: relative;
}
 .site-navbar .site-navigation .site-menu .has-children > a {
     position: relative;
     padding-right: 20px;
}
 .site-navbar .site-navigation .site-menu .has-children > a:before {
     position: absolute;
     content: "\e313";
     font-size: 16px;
     top: 50%;
     right: 0;
     -webkit-transform: translateY(-50%);
     -ms-transform: translateY(-50%);
     transform: translateY(-50%);
     font-family: 'icomoon';
}
 .site-navbar .site-navigation .site-menu .has-children .dropdown {
     visibility: hidden;
     opacity: 0;
     top: 100%;
     position: absolute;
     text-align: left;
     border-top: 2px solid #f7e010;
     -webkit-box-shadow: 0 2px 10px -2px rgba(0, 0, 0, 0.1);
     box-shadow: 0 2px 10px -2px rgba(0, 0, 0, 0.1);
     padding: 0px 0;
     margin-top: 20px;
     margin-left: 0px;
     background: #fff;
     -webkit-transition: 0.2s 0s;
     -o-transition: 0.2s 0s;
     transition: 0.2s 0s;
}
 .site-navbar .site-navigation .site-menu .has-children .dropdown.arrow-top {
     position: absolute;
}
 .site-navbar .site-navigation .site-menu .has-children .dropdown.arrow-top:before {
     display: none;
     bottom: 100%;
     left: 20%;
     border: solid transparent;
     content: " ";
     height: 0;
     width: 0;
     position: absolute;
     pointer-events: none;
}
 .site-navbar .site-navigation .site-menu .has-children .dropdown.arrow-top:before {
     border-color: rgba(136, 183, 213, 0);
     border-bottom-color: #fff;
     border-width: 10px;
     margin-left: -10px;
}
 .site-navbar .site-navigation .site-menu .has-children .dropdown a {
     text-transform: none;
     letter-spacing: normal;
     -webkit-transition: 0s all;
     -o-transition: 0s all;
     transition: 0s all;
     color: #000 !important;
}
 .site-navbar .site-navigation .site-menu .has-children .dropdown a.active {
     color: #f7e010 !important;
     background: #f8f9fa;
}
 .site-navbar .site-navigation .site-menu .has-children .dropdown > li {
     list-style: none;
     padding: 0;
     margin: 0;
     min-width: 200px;
}
 .site-navbar .site-navigation .site-menu .has-children .dropdown > li > a {
     padding: 9px 20px;
     display: block;
}
 .site-navbar .site-navigation .site-menu .has-children .dropdown > li > a:hover {
     background: #f8f9fa;
     color: #ced4da;
}
 .site-navbar .site-navigation .site-menu .has-children .dropdown > li.has-children > a:before {
     content: "\e315";
     right: 20px;
}
 .site-navbar .site-navigation .site-menu .has-children .dropdown > li.has-children > .dropdown, .site-navbar .site-navigation .site-menu .has-children .dropdown > li.has-children > ul {
     left: 100%;
     top: 0;
}
 .site-navbar .site-navigation .site-menu .has-children .dropdown > li.has-children:hover > a, .site-navbar .site-navigation .site-menu .has-children .dropdown > li.has-children:active > a, .site-navbar .site-navigation .site-menu .has-children .dropdown > li.has-children:focus > a {
     background: #f8f9fa;
     color: #ced4da;
}
 .site-navbar .site-navigation .site-menu .has-children:hover > a, .site-navbar .site-navigation .site-menu .has-children:focus > a, .site-navbar .site-navigation .site-menu .has-children:active > a {
     color: #f7e010;
}
 .site-navbar .site-navigation .site-menu .has-children:hover, .site-navbar .site-navigation .site-menu .has-children:focus, .site-navbar .site-navigation .site-menu .has-children:active {
     cursor: pointer;
}
 .site-navbar .site-navigation .site-menu .has-children:hover > .dropdown, .site-navbar .site-navigation .site-menu .has-children:focus > .dropdown, .site-navbar .site-navigation .site-menu .has-children:active > .dropdown {
     -webkit-transition-delay: 0s;
     -o-transition-delay: 0s;
     transition-delay: 0s;
     margin-top: 0px;
     visibility: visible;
     opacity: 1;
}
 .site-mobile-menu {
     width: 300px;
     position: fixed;
     right: 0;
     z-index: 2000;
     padding-top: 20px;
     background: #fff;
     height: calc(100vh);
     -webkit-transform: translateX(110%);
     -ms-transform: translateX(110%);
     transform: translateX(110%);
     -webkit-box-shadow: -10px 0 20px -10px rgba(0, 0, 0, 0.1);
     box-shadow: -10px 0 20px -10px rgba(0, 0, 0, 0.1);
     -webkit-transition: .3s all ease-in-out;
     -o-transition: .3s all ease-in-out;
     transition: .3s all ease-in-out;
}
 .offcanvas-menu .site-mobile-menu {
     -webkit-transform: translateX(0%);
     -ms-transform: translateX(0%);
     transform: translateX(0%);
}
 .site-mobile-menu .site-mobile-menu-header {
     width: 100%;
     float: left;
     padding-left: 20px;
     padding-right: 20px;
}
 .site-mobile-menu .site-mobile-menu-header .site-mobile-menu-close {
     float: right;
     margin-top: 8px;
}
 .site-mobile-menu .site-mobile-menu-header .site-mobile-menu-close span {
     font-size: 30px;
     display: inline-block;
     padding-left: 10px;
     padding-right: 0px;
     line-height: 1;
     cursor: pointer;
     -webkit-transition: .3s all ease;
     -o-transition: .3s all ease;
     transition: .3s all ease;
}
 .site-mobile-menu .site-mobile-menu-header .site-mobile-menu-close span:hover {
     color: #ffd700 
}
 .site-mobile-menu .site-mobile-menu-header .site-mobile-menu-logo {
     float: left;
     margin-top: 10px;
     margin-left: 0px;
}
 .site-mobile-menu .site-mobile-menu-header .site-mobile-menu-logo a {
     display: inline-block;
     text-transform: uppercase;
}
 .site-mobile-menu .site-mobile-menu-header .site-mobile-menu-logo a img {
     max-width: 70px;
}
 .site-mobile-menu .site-mobile-menu-header .site-mobile-menu-logo a:hover {
     text-decoration: none;
}
 .site-mobile-menu .site-mobile-menu-body {
     overflow-y: scroll;
     -webkit-overflow-scrolling: touch;
     position: relative;
     padding: 0 20px 20px 20px;
     height: calc(100vh - 52px);
     padding-bottom: 150px;
}
 .site-mobile-menu .site-nav-wrap {
     padding: 0;
     margin: 0;
     list-style: none;
     position: relative;
}
 .site-mobile-menu .site-nav-wrap a {
     padding: 10px 20px;
     display: block;
     position: relative;
     color: #272921;
}
 .site-mobile-menu .site-nav-wrap a:hover {
     color: #f7e010;
}
 .site-mobile-menu .site-nav-wrap li {
     position: relative;
     display: block;
}
 .site-mobile-menu .site-nav-wrap li .nav-link.active {
     color: #f7e010;
}
 .site-mobile-menu .site-nav-wrap .arrow-collapse {
     position: absolute;
     right: 0px;
     top: 10px;
     z-index: 20;
     width: 36px;
     height: 36px;
     text-align: center;
     cursor: pointer;
     border-radius: 50%;
}
 .site-mobile-menu .site-nav-wrap .arrow-collapse:hover {
     background: #f8f9fa;
}
 .site-mobile-menu .site-nav-wrap .arrow-collapse:before {
     font-size: 12px;
     z-index: 20;
     font-family: "icomoon";
     content: "\f078";
     position: absolute;
     top: 50%;
     left: 50%;
     -webkit-transform: translate(-50%, -50%) rotate(-180deg);
     -ms-transform: translate(-50%, -50%) rotate(-180deg);
     transform: translate(-50%, -50%) rotate(-180deg);
     -webkit-transition: .3s all ease;
     -o-transition: .3s all ease;
     transition: .3s all ease;
}
 .site-mobile-menu .site-nav-wrap .arrow-collapse.collapsed:before {
     -webkit-transform: translate(-50%, -50%);
     -ms-transform: translate(-50%, -50%);
     transform: translate(-50%, -50%);
}
 .site-mobile-menu .site-nav-wrap > li {
     display: block;
     position: relative;
     float: left;
     width: 100%;
}
 .site-mobile-menu .site-nav-wrap > li > a {
     padding-left: 20px;
     font-size: 20px;
}
 .site-mobile-menu .site-nav-wrap > li > ul {
     padding: 0;
     margin: 0;
     list-style: none;
}
 .site-mobile-menu .site-nav-wrap > li > ul > li {
     display: block;
}
 .site-mobile-menu .site-nav-wrap > li > ul > li > a {
     padding-left: 40px;
     font-size: 16px;
}
 .site-mobile-menu .site-nav-wrap > li > ul > li > ul {
     padding: 0;
     margin: 0;
}
 .site-mobile-menu .site-nav-wrap > li > ul > li > ul > li {
     display: block;
}
 .site-mobile-menu .site-nav-wrap > li > ul > li > ul > li > a {
     font-size: 16px;
     padding-left: 60px;
}
 .site-mobile-menu .site-nav-wrap[data-class="social"] {
     float: left;
     width: 100%;
     margin-top: 30px;
     padding-bottom: 5em;
}
 .site-mobile-menu .site-nav-wrap[data-class="social"] > li {
     width: auto;
}
 .site-mobile-menu .site-nav-wrap[data-class="social"] > li:first-child a {
     padding-left: 15px !important;
}
 .sticky-wrapper {
     position: relative;
     z-index: 100;
     width: 100%;
}
 .sticky-wrapper .site-navbar {
     -webkit-transition: .3s all ease;
     -o-transition: .3s all ease;
     transition: .3s all ease;
}
 .sticky-wrapper .site-navbar {
     background: #fff;
}
 .sticky-wrapper .site-navbar .site-logo a {
     color: #fff;
}
 .sticky-wrapper .site-navbar ul li a {
     color: rgba(255, 255, 255, 0.7) !important;
}
 .sticky-wrapper .site-navbar ul li a.active {
     color: #fff !important;
}
 .sticky-wrapper.is-sticky .site-navbar {
     background: #fff;
     -webkit-box-shadow: 4px 0 20px -5px rgba(0, 0, 0, 0.2);
     box-shadow: 4px 0 20px -5px rgba(0, 0, 0, 0.2);
}
 .sticky-wrapper.is-sticky .site-navbar .site-logo a {
     color: #f7e010;
}
 .sticky-wrapper.is-sticky .site-navbar ul li a {
     color: #000 !important;
}
 .sticky-wrapper.is-sticky .site-navbar ul li a.active {
     color: #f7e010 important;
}
 .sticky-wrapper .shrink {
     padding-top: 0px !important;
     padding-bottom: 0px !important;
}
 @media (max-width: 991.98px) {
     .sticky-wrapper .shrink {
         padding-top: 30px !important;
         padding-bottom: 30px !important;
    }
}
 .footer-59391 {
     border-top: 1px solid #efefef;
     background-color: #fff;
     padding: 4rem 0;
}
 .footer-59391 .site-logo {
     color: #fff;
}
 .footer-59391 .site-logo a {
     font-size: 30px;
     color: #000;
     font-weight: 900;
}
 .footer-59391 .social-icons li {
     display: inline-block;
}
 .footer-59391 .social-icons li a {
     display: inline-block;
     position: relative;
     width: 40px;
     height: 40px;
     border-radius: 16px;
}
 .footer-59391 .social-icons li a.dr {
     background: #ff2e6e;
}
 .footer-59391 .social-icons li a.be {
     background: #394cff;
}
 .footer-59391 .social-icons li a.tw {
     background: #00a0fb;
}
 .footer-59391 .social-icons li a.in {
     background: #c31574;
}
 .footer-59391 .social-icons li a.fb {
     background: #3b579b;
}
 .footer-59391 .social-icons li a.tt {
     background: #0a0a0a;
}
 .footer-59391 .social-icons li a.yt {
     background: #fa2614;
}
 .footer-59391 .social-icons li a span {
     position: absolute;
     top: 50%;
     left: 50%;
     -webkit-transform: translate(-50%, -50%);
     -ms-transform: translate(-50%, -50%);
     transform: translate(-50%, -50%);
     color: #fff;
}
 .footer-59391 .nav-links li {
     display: inline-block;
}
 .footer-59391 .nav-links li a {
     font-size: 14px;
     color: #777;
     padding: 10px;
}
 @media (max-width: 1199.98px) {
     .footer-59391 .nav-links.nav-left li:first-child a {
         padding-left: 0;
    }
}
 .footer-59391 .nav-links.nav-right li:last-child a {
     padding-left: 0px;
}
 @media (max-width: 1199.98px) {
     .footer-59391 .nav-links.nav-right li:first-child a {
         padding-left: 0;
    }
}
 .footer-59391 .copyright {
     border-top: 1px solid #efefef;
     padding-top: 50px;
     text-align: center;
     color: #777;
}
 .icon-menu {
     color: #ffd700;
}
 .icon-close2 {
     opacity: 0.8;
}
/* Animované podtržení */
 .site-menu li a {
     position: relative;
     display: inline-block;
     padding-bottom: 5px;
     transition: color 0.3s;
}
/* Zakázat podtržení u "Více" */
 .site-menu li.has-children > a::after {
     display: none !important;
}
 .site-menu li a::after {
     content: '';
     position: absolute;
     left: 0;
     bottom: 0;
     width: 0%;
     height: 2px;
     background: #f7e010;
     transition: width 0.3s ease;
}
/* Aktivní + Hover */
 .site-menu li.active a::after, .site-menu li a:hover::after {
     width: 100%;
}
.contact-section {
    padding: 60px 5px;
    background: #f9f9f9;
}

.contact-card {
    display: flex;
    flex-wrap: wrap;
    background: #fff;
    box-shadow: 0 0 20px rgba(0,0,0,0.05);
    border-radius: 16px;
    overflow: hidden;
}

.contact-form-wrapper, .contact-info-wrapper {
    flex: 1 1 300px;
    padding: 40px;
}

.contact-form-wrapper {
    background: #ffffff;
}

.contact-form-wrapper h2 {
    margin-bottom: 20px;
}

.form-group {
    margin-bottom: 15px;
}

.form-group input,
.form-group textarea {
    width: 100%;
    padding: 12px;
    border: 1px solid #ddd;
    border-radius: 4px;
    transition: border-color 0.3s;
}

.form-group input:focus,
.form-group textarea:focus {
    border-color: #ffd700;
    outline: none;
}

.btn-send {
    background: #ffd700;
    color: #fff;
    border: none;
    padding: 12px 20px;
    cursor: pointer;
    border-radius: 4px;
    font-weight: bold;
    transition: background 0.3s ease, color 0.3s ease, transform 0.3s ease, box-shadow 0.3s ease !important;
    will-change: transform, box-shadow, background, color !important;
}

.btn-send:hover {
    background: #dfc324;
    color: #fff;
    transform: scale(1.05);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

.contact-info-wrapper {
    background: #fdf9ec;
    color: #333;
}

.contact-info-wrapper h2 {
    margin-bottom: 20px;
    color: #111;
}

.contact-info-list {
    list-style: none;
    padding: 0;
}

.contact-info-list li {
    margin-bottom: 10px;
}

.contact-info-list a {
    color: #333;
    text-decoration: underline;
}

#form-status {
    margin-top: 15px;
    padding: 8px 12px;
    border-radius: 5px;
    height: 38px;
    line-height: 20px;
    display: flex;
    align-items: center;
    gap: 8px;
    opacity: 0;
    transition: opacity 0.5s ease, background-color 0.5s ease;
    font-size: 14px;
    border: 1px solid transparent;
    box-sizing: border-box;
    overflow: hidden;
}

#form-status.show {
    opacity: 1;
}

#form-status.success {
    background-color: #d4edda;
    color: #155724;
    border-color: #c3e6cb;
}

#form-status.error {
    background-color: #f8d7da;
    color: #721c24;
    border-color: #f5c6cb;
}

#form-status.warning {
    background-color: #fff3cd;
    color: #856404;
    border-color: #ffeeba;
}

#form-status .icon {
    font-size: 18px;
}

@media (max-width: 529px) {
    .contact-label {
        display: none;
    }
}

.contact-box {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: #fff;
    border: 1px solid #e6e6e6;
    padding: 10px 15px;
    border-radius: 8px;
    margin-bottom: 12px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.03) !important;
    cursor: pointer;
    transition: transform 0.35s ease, box-shadow 0.35s ease !important;
    will-change: transform, box-shadow;
}

.contact-box:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.12) !important;
}



.contact-box::before {
    content: "";
    position: absolute;
    inset: 0;
    background: transparent;
    z-index: 0;
}

.contact-box > * {
    position: relative;
    z-index: 1;
}

.contact-box i {
    font-size: 18px;
    background: #ffd700;
    color: #fff;
    padding: 8px;
    border-radius: 50%;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-right: 10px;
    flex-shrink: 0;
}

.contact-label {
    flex: 1;
    font-weight: 700;
    font-size: 14px;
    color: #111;
}

.contact-value {
    text-align: right;
    font-size: 14px;
    white-space: nowrap;
    color: #484848;
}

.contact-value a {
    color: #333;
    text-decoration: underline;
}

.map-wrapper {
    margin-top: 20px;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.06);
    transition: all 0.3s ease;
    position: relative;
}

.map-wrapper iframe {
    opacity: 0;
    transform: scale(1.01);
    transition: opacity 1s ease, transform 1s ease;
    width: 100%;
    height: 230px;
    display: block;
}

.map-wrapper iframe.loaded {
    opacity: 1;
    transform: scale(1);
}


 .custom-shape-divider-bottom-1743453867 {
     position: absolute;
     bottom: 0;
     left: 0;
     width: 100%;
     overflow: hidden;
     line-height: 0;
}
 .custom-shape-divider-bottom-1743453867 svg {
     position: relative;
     display: block;
     width: calc(273% + 1.3px);
     height: 137px;
     transform: rotateY(180deg);
}
 .custom-shape-divider-bottom-1743453867 .shape-fill {
     fill: #F8F8F8 
}
/* Původní selektor upraven tak, aby se netýkal .social-icons */
 .footer-59391 ul:not(.social-icons) li a {
     position: relative;
     display: inline-block;
     padding-bottom: 3px;
     transition: color 0.3s;
     text-decoration: none;
}
 .footer-59391 ul:not(.social-icons) li a::after {
     content: '';
     position: absolute;
     left: 0;
     bottom: 0;
     width: 0%;
     height: 2px;
     background: #f7e010;
     transition: width 0.3s ease;
     border-radius: 2px;
}
 .footer-59391 ul:not(.social-icons) li a:hover::after {
     width: 100%;
}
 .social-icons li a {
     display: inline-block;
     transition: transform 0.3s ease;
}
 .social-icons li a:hover {
     transform: scale(1.12);
    /* jemné zvětšení */
}
 .custom-shape-divider-bottom-1743453557 {
     position: absolute;
     bottom: 0;
     left: 0;
     width: 100%;
     overflow: hidden;
     line-height: 0;
     transform: rotate(180deg);
}
 .custom-shape-divider-bottom-1743453557 svg {
     position: relative;
     display: block;
     width: 250%;
    /* bylo: 217%, více roztáhnuto */
     height: 150px;
    /* bylo: 137px, o něco vyšší */
     transform: rotateY(180deg);
}
 .custom-shape-divider-bottom-1743453557 .shape-fill {
     fill: #FFFFFF;
}
 @media (max-width: 768px) {
     .custom-shape-divider-bottom-1743453557 svg {
         width: 700%;
         height: 130px;
    }
}
 .services-section {
     background-color: #fdfdfd;
     padding: 60px 20px;
}
 .services-heading {
     margin-bottom: 50px;
}
 .services-grid {
     display: grid;
     grid-template-columns: repeat(4, 1fr);
     gap: 40px;
     max-width: 1200px;
     margin: 0 auto;
}
 @media (max-width: 991px) {
     .services-grid {
         grid-template-columns: repeat(2, 1fr);
    }
}
 @media (max-width: 600px) {
     .services-grid {
         grid-template-columns: 1fr;
    }
}
 .service-description {
     font-size: 1rem;
     color: #555;
     line-height: 1.6;
}
 .about-text {
     font-size: 1rem;
     color: #555;
     line-height: 1.6;
}
 .custom-shape-divider-top-1743941926 {
     position: absolute;
     top: 0;
     left: 0;
     width: 100%;
     overflow: hidden;
     line-height: 0;
     z-index: 50;
}
 .custom-shape-divider-top-1743941926 svg {
     position: relative;
     display: block;
     width: calc(209% + 1.3px);
     height: 54px;
}
 .custom-shape-divider-top-1743941926 .shape-fill {
     fill: #000000;
}
 .custom-shape-divider-bottom-1743941961 {
     position: absolute;
     bottom: 0;
     left: 0;
     width: 100%;
     overflow: hidden;
     line-height: 0;
     transform: rotate(180deg);
}
 .custom-shape-divider-bottom-1743941961 svg {
     position: relative;
     display: block;
     width: calc(209% + 1.3px);
     height: 54px;
}
 .custom-shape-divider-bottom-1743941961 .shape-fill {
     fill: #FFFFFF;
}
 .hero {
     position: relative;
     height: 800px;
     background-size: cover;
     background-position: center;
     display: flex;
     align-items: center;
     background-image: url('../images/fv-web-banner.webp');  
     overflow: hidden;
}
 .hero-overlay {
     max-width: 90%;
     padding-left: 5%;
     z-index: 2;
     margin-bottom: 10%;
}
 .hero h1 {
     font-size: 7rem;
     font-weight: 800;
     color: #f1f1f1;
     line-height: 1.2;
     text-shadow: 2px 2px 10px rgba(0, 0, 0, 0.5);
     margin: 0;
}
 .outline-text {
     font-size: 6rem;
    /* větší než zbytek textu */
     color: transparent;
     -webkit-text-stroke: 1px #f1f1f1;
     text-stroke: 2px #f1f1f1;
     letter-spacing: 2px;
     display: inline-block;
     line-height: 1.1;
}

 @keyframes fadeInUp {
     from {
         opacity: 0;
         transform: translateY(40px);
    }
     to {
         opacity: 1;
         transform: translateY(0);
    }
}
 .cta-button {
     padding: 1rem 2rem;
     font-size: 1.2rem;
     font-weight: bold;
     color: #000;
     background-color: #f7e010;
     background-size: 200% 200%;
     background-position: 0% 50%;
     border: none;
     border-radius: 50px;
     cursor: pointer;
     margin-top: 3%;
     box-shadow: 0 10px 25px rgba(0, 0, 0, 0.05);
     transition: transform 0.4s ease, box-shadow 0.4s ease !important;
     will-change: transform, box-shadow !important;
}
 .cta-button:hover {
     box-shadow: 12px 18px 40px rgba(255, 238, 0, 0.25) !important;
     background-color: #fcd21a;
}



 @media (max-width: 768px) {
     .outline-text {
         font-size: 4rem;
         -webkit-text-stroke: 1.2px #f1f1f1;
    }
     .hero-overlay {
         margin-bottom: 22%;
    }
    .hero {
        height: 700px;
        background-image: url('../images/fv-web-banner-m.webp');  
    }
     .hero h1 {
         font-size: 5rem;
         max-width: 90%;
    }
     .cta-button{
         font-size: 0.8rem;
         margin-top: 5%;
    }
}
 @media (max-width: 480px) {
    .hero {
        height: 700px;
        background-image: url('../images/fv-web-banner-s.webp');  
    }
      .hero h1 {
         font-size: 4rem;
         max-width: 90%;
    }
    .outline-text {
         font-size: 3.2rem;
         -webkit-text-stroke: 1.2px #f1f1f1;
    }
     .cta-button {
         font-size: 0.7rem;
         margin-top: 5%;
    }
}

 .about-section {
     padding: 60px 10px;
     position: relative;
}
 .about-container {
     display: flex;
     flex-wrap: wrap;
     align-items: center;
     gap: 40px;
}
 .about-image {
     flex: 1 1 300px;
     text-align: center;
}
 .about-image img {
     width: 100%;
     border-radius: 16px;
     box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
}
 .about-content {
     flex: 2 1 400px;
}
 .about-content h2 {
     font-size: 2em;
     margin-bottom: 20px;
}
 .about-content p {
     font-size: 1.1em;
     line-height: 1.7;
     margin-bottom: 15px;
}
 @media (max-width: 768px) {
     .about-container {
         flex-direction: column;
         text-align: center;
    }
}
 .site-logo img {
     max-height: 80px;
     height: auto;
     width: auto;
     display: block;
}
 .about-quote {
     margin-top: 30px;
     padding-left: 20px;
     border-left: 4px solid #f7e010;
     font-style: italic;
     color: #333;
     font-size: 1.1em;
     line-height: 1.6;
     position: relative;
}
 .about-quote span {
     display: block;
     margin-top: 8px;
     font-size: 0.95em;
     color: #666;
     font-style: normal;
}
 .cookies-section {
     background-color: #f8f9fa;
}
 .cookies-content {
     font-size: 1rem;
     color: #333;
}
 .cookies-content h2 {
     margin-top: 2rem;
     font-size: 1.4rem;
     font-weight: 600;
}
 .cookies-content h3 {
     margin-top: 1.2rem;
     font-size: 1.2rem;
}
 .cookies-content ul {
     list-style: disc;
     margin-left: 1.5rem;
     padding-left: 0.5rem;
}
 .privacy-section {
     background-color: #f8f9fa;
}
 .privacy-content {
     font-size: 1rem;
     color: #333;
}
 .privacy-content h2 {
     margin-top: 2rem;
     font-size: 1.4rem;
     font-weight: 600;
}
 .privacy-content ul {
     list-style: disc;
     margin-left: 1.5rem;
     padding-left: 0.5rem;
}
 #privacy-policy p {
     font-size: 1rem;
     color: #555;
     line-height: 1.6;
}
 #cookies-policy p {
     font-size: 1rem;
     color: #555;
     line-height: 1.6;
}
 .result-box {
     border-left: 5px solid #f7e010;
     padding: 1rem;
     margin-bottom: 1.5rem;
     background-color: #f8f9fa;
     border-radius: 0.375rem;
     min-height: 60px;
}
 .result-box.red {
     border-left-color: #dc3545;
     background-color: #fff5f5;
}
 .result-icon {
     font-size: 1.3rem;
     margin-right: 0.5rem;
     vertical-align: middle;
}
 .result-box div:last-child::after {
     content: ",-";
     margin-left: 0.25rem;
}
 .form-label {
     font-weight: 500;
}
 .service-item {
     background: #fff;
     padding: 30px 20px;
     border-radius: 16px;
     text-align: center;
     box-shadow: 0 10px 25px rgba(0, 0, 0, 0.05);
     transition: transform 0.4s ease, box-shadow 0.4s ease !important;
     will-change: transform, box-shadow !important;
}
 .service-item:hover {
     transform: scale(1.02) !important;
     box-shadow: 0 16px 32px rgba(255, 238, 0, 0.329) !important;
}
 .service-icon-wrapper {
     margin-bottom: 20px;
}
 .service-icon {
     font-size: 48px;
     color: #f7e010;
}
 .service-title {
     font-size: 1.3rem;
     margin-bottom: 12px;
     color: #222;
}
 .custom-social-list {
     display: flex;
     gap: 15px;
     padding-left: 0;
}
 .custom-social-list li {
     list-style: none;
}
 .custom-social-list a {
     display: inline-flex;
     align-items: center;
     justify-content: center;
     width: 40px;
     height: 40px;
     border-radius: 50%;
     text-decoration: none;
     color: white;
     transition: transform 0.2s, background-color 0.2s;
}
 .custom-social-list a:hover {
     transform: scale(1.1);
}
 .soc-fb987 {
     background-color: #3b5998;
}
 .soc-ig227 {
     background-color: #e4405f;
}
 .soc-yt654 {
     background-color: #ff0000;
}
 .soc-tt889 {
     background-color: #000000;
}
 .custom-social-list i {
     font-size: 18px;
}
 .image-section {
     width: 100%;
     overflow: hidden;
     background: #f9f9f9;
     padding: 20px 0;
}
 .image-track {
     display: flex;
     width: max-content;
     animation: scroll-left 120s linear infinite;
}
 .image-box {
     width: 250px;
     height: 140px;
     background-color: white;
     background-size: contain;
     background-position: center;
     background-repeat: no-repeat;
     border-radius: 16px;
     margin-right: 10px;
     opacity: 0.7;
}
 @keyframes scroll-left {
     0% {
         transform: translateX(0);
    }
     100% {
         transform: translateX(-50%);
    }
}
/* --- Sekce: stabilní výška --- */
.letokruh-section {
  position: relative;
  overflow: hidden;
  height: auto;
  min-height: 90svh;
  background-color: #000;
  color: #fff;
  isolation: isolate;
}
@supports not (height: 1svh) {
  .letokruh-section { min-height: 90vh; }
}

.letokruh-content {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: inherit;
  position: relative;
}

/* ---------- DESKTOP efekt (více vrstev) ---------- */
.letokruh-img-wrapper {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: 100%;
  transform: translate3d(-50%, -50%, 0);
  z-index: 1;
  pointer-events: none;
  contain: layout paint size;
  isolation: isolate;
  display: block; /* desktop default */
}

.letokruh-img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate3d(-50%, -50%, 0) scale(0.1);
  opacity: 0;
  transition: transform 1.2s ease-out, opacity 1.2s ease-out;
  transition-delay: calc(var(--i, 0) * 120ms);
  display: flex;
  justify-content: center;
  align-items: center;
  will-change: transform, opacity;
}

.letokruh-img img {
  width: auto;
  height: 100%;
  max-height: 100%;
  object-fit: contain;
  mix-blend-mode: screen;
  backface-visibility: hidden;
}

/* Z-indexy */
.letokruh-img1 { z-index: 6; }
.letokruh-img2 { z-index: 5; }
.letokruh-img3 { z-index: 4; }
.letokruh-img4 { z-index: 3; }
.letokruh-img5 { z-index: 2; }
.letokruh-img6 { z-index: 1; }

/* Spuštění efektu po .in-view */
#finance-hero.in-view .letokruh-img1 { transform: translate3d(-50%,-50%,0) scale(0.4);  opacity: 0.7; }
#finance-hero.in-view .letokruhy .letokruh-img2,
#finance-hero.in-view .letokruh-img2 { transform: translate3d(-50%,-50%,0) scale(0.45); opacity: 0.65; }
#finance-hero.in-view .letokruh-img3 { transform: translate3d(-50%,-50%,0) scale(0.52); opacity: 0.6;  }
#finance-hero.in-view .letokruh-img4 { transform: translate3d(-50%,-50%,0) scale(0.62); opacity: 0.4;  }
#finance-hero.in-view .letokruh-img5 { transform: translate3d(-50%,-50%,0) scale(0.8);  opacity: 0.25; }
#finance-hero.in-view .letokruh-img6 { transform: translate3d(-50%,-50%,0) scale(0.93); opacity: 0.10; }

/* Text */
.letokruh-text-wrapper {
  z-index: 10;
  text-align: center;
  max-width: 800px;
  padding: 2rem;
  border-radius: 20px;
}
.letokruh-title {
  font-size: 2.2rem;
  font-weight: bold;
  margin: 1rem 0;
}

/* Volitelné dýchání (ponecháno beze změny, nyní jen pro desktop) */
@keyframes float {
  0% { transform: scale(1); }
  50% { transform: scale(1.03); }
  100% { transform: scale(1); }
}
/* ---------- MOBILE/TABLET (<= 1200px): jeden obrázek ---------- */
.letokruh-mobile {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  display: none; /* desktop default */
  justify-content: center;
  align-items: center;
  overflow: hidden;
}

/* Výchozí stav mobilního obrázku – lehký zoom a slabá viditelnost */
.letokruh-mobile img {
  transform: scale(0.96);
  opacity: 0; /* před animací neviditelný */
  /* transform necháváme rychlejší (900ms), opacity prodloužena na 1900ms */
  transition: transform 900ms cubic-bezier(.22,.61,.36,1), opacity 1900ms ease-out;
  will-change: transform, opacity;
}

/* Radiální clona přes pseudo-element (tmavší okraje) */
.letokruh-mobile::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: rgba(0,0,0,0.75);
  -webkit-mask-image: radial-gradient(circle at 50% 50%, #000 0%, #000 60%, rgba(0,0,0,0) 92%);
  mask-image: radial-gradient(circle at 50% 50%, #000 0%, #000 60%, rgba(0,0,0,0) 92%);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;
  opacity: 1; /* před vstupem je clona silná */
  /* clonu necháme dojíždět ještě o chlup déle pro hladký „reveal“ */
  transition: opacity 2200ms ease-out;
}

/* Po vstupu do viewportu (spouští tvůj JS přes .in-view) */
#finance-hero.in-view .letokruh-mobile img {
  transform: scale(1);
  opacity: 0.9;
}
#finance-hero.in-view .letokruh-mobile::before {
  opacity: 0.25; /* jemné okraje po revealu */
}

/* Přepnutí layoutu na mobilech/tabletech */
@media (max-width: 1200px) {
  .letokruh-img-wrapper { display: none !important; }  /* schovat desktop vrstvy */
  .letokruh-mobile { display: flex !important; }       /* ukázat mobilní obrázek */
  .letokruh-title { font-size: 1.6rem; }
}

/* (breathing efekt odstraněn – žádné keyframes ani animation) */




 .custom-shape-divider-top-1748700023 {
     position: absolute;
     top: 0;
     left: 0;
     width: 100%;
     overflow: hidden;
     line-height: 0;
}
 .custom-shape-divider-top-1748700023 svg {
     position: relative;
     display: block;
     width: calc(113% + 1.3px);
     height: 60px;
}
 .custom-shape-divider-top-1748700023 .shape-fill {
     fill: #fdfdfd;
}
 .custom-shape-divider-bottom-1748700390 {
     position: absolute;
     bottom: 0;
     left: 0;
     width: 100%;
     overflow: hidden;
     line-height: 0;
     transform: rotate(180deg);
}
 .custom-shape-divider-bottom-1748700390 svg {
     position: relative;
     display: block;
     width: calc(100% + 1.3px);
     height: 48px;
}
 .custom-shape-divider-bottom-1748700390 .shape-fill {
     fill: #F9F9F9;
}
 .custom-shape-divider-bottom-1748700709 {
     position: absolute;
     bottom: 0;
     left: 0;
     width: 100%;
     overflow: hidden;
     line-height: 0;
     transform: rotate(180deg);
}
 .custom-shape-divider-bottom-1748700709 svg {
     position: relative;
     display: block;
     width: calc(131% + 1.3px);
     height: 147px;
}
 .custom-shape-divider-bottom-1748700709 .shape-fill {
     fill: #F9F9F9;
}
 .custom-shape-divider-bottom-1748701321 {
     position: absolute;
     bottom: 0;
     left: 0;
     width: 100%;
     overflow: hidden;
     line-height: 0;
     transform: rotate(180deg);
}
 .custom-shape-divider-bottom-1748701321 svg {
     position: relative;
     display: block;
     width: calc(100% + 1.3px);
     height: 96px;
}
 .custom-shape-divider-bottom-1748701321 .shape-fill {
     fill: #F9F9F9;
}
 .custom-shape-divider-bottom-1748702104 {
     position: absolute;
     bottom: 0;
     left: 0;
     width: 100%;
     overflow: hidden;
     line-height: 0;
     transform: rotate(180deg);
}
 .custom-shape-divider-bottom-1748702104 svg {
     position: relative;
     display: block;
     width: calc(132% + 1.3px);
     height: 37px;
}
 .custom-shape-divider-bottom-1748702104 .shape-fill {
     fill: #000000;
}
 .cookie-modal-wrapper {
  position: fixed;
  bottom: 30px;
  right: 30px;
  max-width: 360px;
  width: 100%;
  background: #ffffff;
  border-radius: 12px;
  padding: 20px 24px 26px;
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.1);
  transition: transform 0.4s ease, opacity 0.4s ease;
  z-index: 99999;
  opacity: 0;
  transform: translateY(100%);
  box-sizing: border-box;
}

.cookie-modal-wrapper.show {
  opacity: 1;
  transform: translateY(0);
}

/* Header */
.cookie-modal-header {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 10px;
}

.cookie-modal-header i {
  color: #f7d600;
  font-size: 36px;
}

.cookie-modal-header h2 {
  font-size: 20px;
  font-weight: 600;
  color: #2e2e2e;
  margin: 0;
}

/* Text */
.cookie-modal-data {
  font-size: 15px;
  line-height: 1.6;
  color: #444;
}

.cookie-modal-data a {
  color: #f7b500;
  text-decoration: underline;
  transition: color 0.2s ease;
}

.cookie-modal-data a:hover {
  color: #d49c00;
}

/* Buttons */
.cookie-modal-buttons {
  margin-top: 20px;
  display: flex;
  gap: 12px;
}

.cookie-modal-button {
  flex: 1;
  border: none;
  border-radius: 6px;
  padding: 10px 0;
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.3s ease;
}

/* Accept button */
#acceptBtn {
  background-color: #f7d600;
  color: #222;
}

#acceptBtn:hover {
  background-color: #e6c200;
}

/* Decline button */
#declineBtn {
  background-color: #fff;
  color: #c73e14;
  border: 2px solid #c73e14;
}

#declineBtn:hover {
  background-color: #c73e14;
  color: #fff;
}

/* Mobile tweaks */
@media (max-width: 768px) {
  .cookie-modal-wrapper {
    left: 20px;
    right: 20px;
    bottom: 20px;
  }
}

 @keyframes spin {
     0% {
         transform: rotate(0deg);
    }
     100% {
         transform: rotate(360deg);
    }
}
 


