html, body{
  width:100%;
  overflow-x:hidden !important;
}

body {
       font-family: "IBM Plex Sans", 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: #031D67;
}
 .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 #031D67;
     -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: #031D67 !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: #031D67;
}
 .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: #031D67;
}
 .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: #031D67;
}
 .site-mobile-menu .site-nav-wrap li {
     position: relative;
     display: block;
}
 .site-mobile-menu .site-nav-wrap li .nav-link.active {
     color: #031D67;
}
 .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: #031D67;
}
 .sticky-wrapper.is-sticky .site-navbar ul li a {
     color: #000 !important;
}
 .sticky-wrapper.is-sticky .site-navbar ul li a.active {
     color: #031D67 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*/
.footer-59391 {
    background: linear-gradient(135deg, #1c3f96 0%, #3c63e0 100%);
    color: #eef1ff;
    padding: 3rem 0 2rem;
}



/* Logo a texty */
.footer-59391 .site-logo {
    color: #fff;
}

.footer-59391 .site-logo img {
    max-width: 210px;
    height: auto;
    display: block;
    margin-bottom: 0.75rem;
}

.footer-59391 .footer-logo-link {
    display: inline-block;
}

.footer-59391 .footer-tagline {
    margin: 0;
    font-size: 14px;
    color: #d2ddff;
}

/* Social ikony – sjednocený vzhled pro všechny (mail, FB, IG, scroll-up) */
.footer-59391 .social-icons {
    margin: 0;
    padding: 0;
}

.footer-59391 .social-icons li {
    display: inline-block;
    margin: 0 5px;
}

/* ZÁKLAD pro <a> i .icon-btn (scroll-up) */
.footer-59391 .social-icons li a,
.footer-59391 .social-icons li .icon-btn {
    width: 42px;
    height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;

    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.2);
    background: rgba(255, 255, 255, 0.08);

    color: #ffffff;
    cursor: pointer;
    text-decoration: none;
    padding: 0;

    transition: background 0.25s ease, color 0.25s ease,
                transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

/* Ikony uvnitř */
.footer-59391 .social-icons li a span,
.footer-59391 .social-icons li .icon-btn span {
    font-size: 18px;
    line-height: 1;
}

/* Hover efekt pro všechny ikonky */
.footer-59391 .social-icons li a:hover,
.footer-59391 .social-icons li .icon-btn:hover {
    background: #ffffff;
    color: #1c3f96;
    transform: translateY(-3px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.25);
    border-color: transparent;
}

/* Navigační odkazy ve footeru */
.footer-59391 .nav-links {
    margin: 0;
    padding: 0;
}

.footer-59391 .nav-links li {
    display: inline-block;
    margin-right: 12px;
}

.footer-59391 .nav-links.nav-right li {
    margin-left: 12px;
    margin-right: 0;
}

.footer-59391 .nav-links li a {
    font-size: 14px;
    color: #eef1ff;
    padding: 4px 0;
}

/* Breakpointy pro zarovnání */
@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-right: 0;
}

@media (max-width: 991.98px) {
    .footer-links-row {
        text-align: left;
    }
}

@media (max-width: 767.98px) {
    .footer-main {
        text-align: center;
    }

    .footer-59391 .social-icons {
        margin-top: 10px;
    }

    .footer-59391 .nav-links.nav-right,
    .footer-59391 .nav-links.nav-left {
        display: flex;
        flex-wrap: wrap;
        gap: 4px 16px;
    }

    .footer-59391 .nav-links li {
        margin-right: 0;
    }

    .footer-59391 .nav-links.nav-right li {
        margin-left: 0;
    }

    .footer-bottom {
        text-align: center;
    }

    .footer-59391 .footer-admin {
        margin-top: 8px;
    }

    .footer-actions {
        justify-content: center;
    }
}

/* Dělící čára pod odkazy přes celou šířku */
.footer-59391 .footer-divider {
    border-top: 1px solid rgba(255, 255, 255, 0.16);
    margin: 12px 0 18px;
}

/* Spodní lišta */
.footer-bottom {
    margin-top: 4px;
}

.footer-59391 .copyright {
    padding-top: 0;
    text-align: left;
    color: #d5dcff;
}

/* Světlejší barva pro Šimon Koláčka */
.footer-59391 .designer-link {
    color: #b3b3b3;
    text-decoration: none;
}

.footer-59391 .designer-link:hover {
    color: #ffffff;
    text-decoration: underline;
}

/* Akce vpravo dole (Administrace + případné další prvky) */
.footer-59391 .footer-actions {
    display: inline-flex;
    align-items: center;
    gap: 10px;
}

/* Tlačítko Administrace */
.footer-59391 .admin-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 6px 14px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.4);
    color: #eef1ff;
    font-size: 13px;
    text-decoration: none;
    background: rgba(12, 69, 173, 0.5);
    backdrop-filter: blur(4px);
    transition: background 0.3s ease, border-color 0.3s ease,
                transform 0.2s ease, box-shadow 0.2s ease, color 0.2s ease;
}

.footer-59391 .admin-link:hover {
    background: #ffffff;
    color: #1c3f96;
    border-color: transparent;
    transform: translateY(-1px);
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.25);
}

/* Animované podtržení pouze pro odkazy ve footeru (mimo 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: #b2c6ff;
    transition: width 0.3s ease;
    border-radius: 2px;
}

.footer-59391 ul:not(.social-icons) li a:hover {
    color: #ffffff;
}

.footer-59391 ul:not(.social-icons) li a:hover::after {
    width: 100%;
}

/* Efekt pro social ikony (už zajištěno v jednotném bloku, ale nechávám pro jistotu kompatibilitu) */
.social-icons li a {
    transition: transform 0.3s ease;
}

/* Ponechávám tvoje původní styly pro site-menu,
   aby fungovaly v hlavním menu webu */
.icon-menu {
    color: #031D67;
}

.icon-close2 {
    opacity: 0.8;
}

.site-menu li a {
    position: relative;
    display: inline-block;
    padding-bottom: 5px;
    transition: color 0.3s;
}

.site-menu li a::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    width: 0%;
    height: 2px;
    background: #031D67;
    transition: width 0.3s ease;
}

.site-menu li.active a::after,
.site-menu li a:hover::after {
    width: 100%;
}






























/*KONTAKT*/

.contact-section {
    padding: 70px 5px;
    background: #f4f7ff; /* světle modré pozadí */
}

/* Layout – dvě karty vedle sebe */
.contact-card {
    display: flex;
    flex-wrap: wrap;
    gap: 24px;
    background: transparent;
    box-shadow: none;
    border-radius: 0;
    border: none;
}

/* Levá / pravá část – každá jako samostatná karta */
.contact-form-wrapper,
.contact-info-wrapper {
    flex: 1 1 320px;
    padding: 30px 30px 28px;
    border-radius: 18px;
    background: #ffffff;
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.06);
    border: 1px solid #dde5ff;
}

/* PRAVÁ – FORMULÁŘ */
.contact-form-wrapper {
    position: relative;
}

.contact-form-header h2 {
    margin: 0 0 8px;
    color: #031D67;
    font-size: 1.4rem;
    font-weight: 600;
}

.contact-form-header .contact-subtitle {
    margin: 0;
    font-size: 0.9rem;
    color: #6b6b6b;
}

.contact-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 4px 11px;
    border-radius: 999px;
    background: rgba(3, 29, 103, 0.08);
    color: #031D67;
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin-bottom: 10px;
}

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

.form-group input,
.form-group textarea {
    width: 100%;
    padding: 11px 12px;
    border: 1px solid #c7d3ef;
    border-radius: 6px;
    font-size: 0.9rem;
    transition: border-color 0.25s ease, box-shadow 0.25s ease, background-color 0.25s ease;
    background-color: #ffffff;
}

.form-group input::placeholder,
.form-group textarea::placeholder {
    color: #9aa4c2;
    font-size: 0.88rem;
}

.form-group input:focus,
.form-group textarea:focus {
    border-color: #031D67;
    outline: none;
    box-shadow: 0 0 0 3px rgba(3, 29, 103, 0.12);
    background-color: #fdfdff;
}

.contact-form-footer {
    margin-top: 10px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.contact-note {
    font-size: 0.76rem;
    color: #8a8fa0;
    max-width: 360px;
}

/* Přístupnost – skryté labely */
.sr-only {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    border: 0 !important;
}

/* Tlačítko odeslat */
.btn-send {
    background: #031D67;
    color: #fff;
    border: none;
    padding: 11px 22px;
    cursor: pointer;
    border-radius: 999px;
    font-weight: 600;
    font-size: 0.9rem;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    box-shadow: 0 10px 24px rgba(3, 29, 103, 0.28);
    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: #052B9A;
    color: #fff;
    transform: translateY(-1px) scale(1.02);
    box-shadow: 0 14px 30px rgba(3, 29, 103, 0.35);
}

/* Stav formuláře */
#form-status {
    margin-top: 12px;
    padding: 7px 11px;
    border-radius: 5px;
    min-height: 34px;
    line-height: 18px;
    display: flex;
    align-items: center;
    gap: 8px;
    opacity: 0;
    transition: opacity 0.5s ease, background-color 0.5s ease;
    font-size: 0.85rem;
    border: 1px solid transparent;
    box-sizing: border-box;
    overflow: hidden;
}

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

#form-status.success {
    background-color: #d8f1e6;
    color: #165f3a;
    border-color: #b4e4cc;
}

#form-status.error {
    background-color: #f4dbe0;
    color: #7a1f2a;
    border-color: #e7b9c0;
}

#form-status.warning {
    background-color: #fff8d9;
    color: #857100;
    border-color: #f1e7a3;
}

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

/* LEVÁ – KONTAKTNÍ ÚDAJE */
.contact-info-wrapper {
    background: radial-gradient(circle at top left, #f8f9ff 0, #f0f4ff 35%, #e4ebff 100%);
    color: #333;
    position: relative;
}

.contact-info-inner {
    max-width: 420px;
}

.contact-info-title {
    margin-bottom: 16px;
    color: #031D67;
    font-size: 1.3rem;
    font-weight: 600;
}

/* Box pro kontaktní osobu */
.contact-person-card {
    background: #ffffff;
    border-radius: 10px;
    padding: 11px 13px;
    border: 1px solid #d7dffc;
    box-shadow: 0 8px 18px rgba(3, 29, 103, 0.08);
    margin-bottom: 15px;
}

.contact-person-label {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #7a84ad;
    display: block;
    margin-bottom: 4px;
}

.contact-person-name {
    font-weight: 700;
    margin: 0;
    font-size: 0.98rem;
    color: #031D67;
}

.contact-person-role {
    margin: 3px 0 0;
    font-size: 0.8rem;
    color: #6f7693;
}

/* Boxy s kontaktem – lepší ikonky */
.contact-box {
    position: relative;
    display: flex;
    align-items: flex-start;
    background: #fff;
    border: 1px solid #e0e6f5;
    padding: 9px 13px;
    border-radius: 10px;
    margin-bottom: 10px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.03) !important;
    cursor: pointer;
    transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease, background-color 0.3s ease !important;
    will-change: transform, box-shadow, border-color, background-color;
}

.contact-box:hover {
    transform: translateY(-1px) !important;
    box-shadow: 0 10px 22px rgba(3, 29, 103, 0.16) !important;
    border-color: #c3cff7;
    background-color: #f9fbff;
}

.contact-icon-wrapper {
    width: 38px;
    height: 38px;
    border-radius: 999px;
    border: 1px solid rgba(3, 29, 103, 0.16);
    background: radial-gradient(circle at 30% 30%, #ffffff 0, #e2e8ff 55%, #c7d4ff 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-right: 10px;
    flex-shrink: 0;
}

.contact-box i {
    font-size: 16px;
    color: #031D67;
}

.contact-text {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.contact-label {
    font-weight: 600;
    font-size: 0.8rem;
    color: #031D67;
    margin-bottom: 1px;
}

.contact-value {
    font-size: 0.86rem;
    color: #3c4a6e;
    word-break: break-word;
}

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

/* Detailní poznámka dole */
.contact-info-note {
    font-size: 0.76rem;
    color: #7b82a0;
    margin-top: 10px;
}

/* Schovat label u užších displejů – necháme raději viditelné, jen menší font */
@media (max-width: 529px) {
    .contact-label {
        font-size: 0.76rem;
    }
}

/* RESPONSIVNÍ úpravy pro celý blok */
@media (max-width: 991.98px) {
    .contact-section {
        padding: 60px 10px;
    }

    .contact-form-wrapper,
    .contact-info-wrapper {
        padding: 24px 20px;
    }

    .contact-info-inner {
        max-width: 100%;
    }
}

@media (max-width: 767.98px) {
    .contact-section {
        padding: 50px 10px;
    }

    .contact-card {
        flex-direction: column;
    }

    .contact-form-wrapper,
    .contact-info-wrapper {
        padding: 22px 18px;
    }

    .contact-form-header h2 {
        font-size: 1.2rem;
    }
}










































 


 .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;
}


 .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: 55px;
     height: auto;
     width: auto;
     display: block;
}
 @media (max-width: 768px) {
     .site-logo img {
        max-height: 45px;
    }
}
 .about-quote {
     margin-top: 30px;
     padding-left: 20px;
     border-left: 4px solid #031D67;
     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 #031D67;
     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: #031D67;
}
 .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%);
    }
}
 

/* Respektuj preferenci sníženého pohybu */
@media (prefers-reduced-motion: reduce){
  .letokruh-img{ transition: none; }
  .letokruh-img.visible{ opacity: 1; transform: translate(-50%, -50%) scale(0.5); }
}

 /* =========================
   COOKIE MODAL – SCHOLA MEDICA
   ========================= */

.cookie-modal-wrapper {
  position: fixed;
  bottom: 30px;
  right: 30px;
  max-width: 380px;
  width: 100%;
  background: #ffffff;
  border-radius: 14px;
  padding: 22px 26px 26px;
  box-shadow: 0 14px 40px rgba(3, 29, 103, 0.18);
  transition: transform 0.45s ease, opacity 0.45s ease;
  z-index: 99999;
  opacity: 0;
  transform: translateY(120%);
  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: 12px;
}

.cookie-modal-header i {
  color: #031d67; /* hlavní Schola Medica modrá */
  font-size: 34px;
}

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

/* Text */
.cookie-modal-data {
  font-size: 14.5px;
  line-height: 1.65;
  color: #4f5775;
}

.cookie-modal-data a {
  color: #031d67;
  text-decoration: underline;
  font-weight: 500;
  transition: color 0.2s ease;
}

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

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

.cookie-modal-button {
  flex: 1;
  border-radius: 999px;
  padding: 11px 0;
  font-size: 14.5px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.25s ease;
  border: none;
}

/* Accept button */
#acceptBtn {
  background: linear-gradient(135deg, #031d67, #0a2ea6);
  color: #ffffff;
  box-shadow: 0 8px 20px rgba(3, 29, 103, 0.35);
}

#acceptBtn:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 28px rgba(3, 29, 103, 0.45);
}

/* Decline button */
#declineBtn {
  background-color: #ffffff;
  color: #031d67;
  border: 2px solid #d6dcf4;
}

#declineBtn:hover {
  background-color: #f1f4ff;
  border-color: #031d67;
}

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

/* případná animace loaderu – nechávám */
@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

































/* KURZY – sekce */
.courses-section {
    padding: 80px 0;
    background: #f4f7ff;
}

.courses-container {
    max-width: 1140px;
}

/* Hlavička sekce */
.courses-header {
    text-align: center;
    max-width: 720px;
    margin: 0 auto 40px;
}

.courses-header h2 {
    font-size: 1.8rem;
    margin-bottom: 10px;
    color: #031D67;
    font-weight: 600;
}

.courses-header p {
    margin: 0;
    font-size: 0.95rem;
    color: #5f647a;
}

.courses-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 4px 12px;
    border-radius: 999px;
    background: rgba(3, 29, 103, 0.06);
    color: #031D67;
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin-bottom: 8px;
}

/* Karty pro aktuální/proběhlé */
.courses-card {
    background: #ffffff;
    border-radius: 18px;
    border: 1px solid #dde5ff;
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.06);
    padding: 18px 18px 16px;
    height: 100%;
}

.courses-card-muted {
    background: #f8f9ff;
}

/* Hlavička karty */
.courses-card-header h3 {
    font-size: 1.1rem;
    margin: 0 0 4px;
    color: #031D67;
    font-weight: 600;
}

.courses-card-header p {
    margin: 0 0 14px;
    font-size: 0.88rem;
    color: #6b6f85;
}

/* "Tabulka" kurzů */
.courses-table {
    width: 100%;
    font-size: 0.9rem;
}

.courses-table-row {
    display: grid;
    grid-template-columns: 2.2fr 1.4fr 1.8fr;
    gap: 12px;
    padding: 10px 10px;
    align-items: flex-start;
    border-radius: 10px;
}

.courses-table-header {
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: #6a7292;
    background: transparent;
    padding-bottom: 4px;
}

.courses-table-row:not(.courses-table-header) {
    background: #ffffff;
    border: 1px solid #e0e6f5;
    margin-bottom: 8px;
    transition: box-shadow 0.25s ease, transform 0.25s ease, border-color 0.25s ease;
}

.courses-card-muted .courses-table-row:not(.courses-table-header) {
    background: #fdfdff;
}

.courses-table-row:not(.courses-table-header):hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(3, 29, 103, 0.13);
    border-color: #c7d3ff;
}

/* Sloupce */
.courses-col-name {
    color: #2d3550;
    font-weight: 500;
}

.courses-col-accr {
    color: #4f5775;
    font-size: 0.86rem;
    word-break: break-word;
    text-align: center;
}

/* Kontejner pro soubory – stejné šířky tlačítek v řádku */
.courses-col-files {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    justify-content: flex-start;
}

/* "Table" label pro mobil */
.courses-table-row [data-label]::before {
    content: attr(data-label) " ";
    display: none;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #8a90aa;
    margin-bottom: 2px;
}

/* Pilulky souborů */
.course-file-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 6px 10px;
    border-radius: 999px;
    background: #edf1ff;
    color: #031D67;
    font-size: 0.78rem;
    text-decoration: none;
    border: 1px solid #d3dcff;
    transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease,
                transform 0.2s ease, box-shadow 0.2s ease;
    flex: 1 1 0;           /* stejné šířky v rámci řádku */
    text-align: center;
}

.course-file-pill i {
    font-size: 0.8rem;
}

.course-file-pill:hover {
    background: #031D67;
    color: #ffffff;
    border-color: #031D67;
    transform: translateY(-1px);
    box-shadow: 0 6px 16px rgba(3, 29, 103, 0.25);
}

/* Zelené CTA pro přihlášku */
.course-file-pill-cta {
    background: #e8f9f0;
    border-color: #bfe9d0;
    color: #136b3b;
    font-weight: 600;
}

.course-file-pill-cta:hover {
    background: #136b3b;
    border-color: #136b3b;
    color: #ffffff;
}

/* Jemnější verze pro proběhlé akce */
.course-file-pill-muted {
    background: #f1f3ff;
    border-color: #d8def7;
}

.course-file-pill-muted:hover {
    background: #4f5fa8;
    border-color: #4f5fa8;
}

/* Responsivita */
@media (max-width: 991.98px) {
    .courses-section {
        padding: 60px 0;
    }
}

@media (max-width: 767.98px) {
    .courses-header h2 {
        font-size: 1.5rem;
    }

    .courses-table-row {
        grid-template-columns: 1fr;
        padding: 10px 12px;
    }

    .courses-col-files {
        justify-content: flex-start;
    }

    .courses-table-row [data-label]::before {
        display: block;
    }

    .courses-table-header {
        display: none; /* na mobilu schováme hlavičku, místo ní používáme data-label */
    }
}


.courses-table-row-teaser {
    position: relative;
    overflow: hidden;
    margin-bottom: 8px;
}

.courses-table-row-teaser-inner {
    filter: blur(3px);
    opacity: 0.7;
    pointer-events: none;
}

.courses-table-row-teaser::after {
    content: "Další proběhlé akce v archivu…";
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(244, 247, 255, 0.9);
    font-size: 0.9rem;
    font-weight: 500;
    color: #4f5775;
}


/* ZRUŠENÍ animace / transform pro proběhlé kurzy */
.courses-table-row.prob-kurz-row:hover {
    transform: none !important;
}

/* ZRUŠENÍ animace / transform pro proběhlé kurzy */
.courses-table-row:hover {
    transform: none !important;
}


























/* =========================================================
   KURZY – TABLE LAYOUT (4 sloupce na desktopu)
   ========================================================= */

/* nový sloupec Termín */
.courses-col-termin{
  color:#4f5775;
  font-size:0.86rem;
  word-break:break-word;
}

/* Desktop: 4 sloupce + Akce vždy poslední a vpravo */
@media (min-width: 768px) {
  .courses-table-row{
    /* Název | Termín | Akreditace | Akce */
    grid-template-columns: 2.35fr 1.05fr 1.25fr 1.15fr;
    align-items: center;
  }

  /* Akce doprava */
  .courses-col-files{
    justify-content:center;
    align-items:center;
    gap:8px;
  }

  /* Tlačítka v Akce: kompaktní, neroztahovat */
  .courses-col-files .course-file-pill{
    flex: 0 0 auto;          /* přepíše tvé původní flex: 1 1 0 */
    width: auto;
    white-space: nowrap;
    padding: 6px 12px;
    width: 100%;
  }

  /* Když jsou 2 tlačítka, ať vypadají zarovnaně */
  .courses-col-files .course-file-pill span{
    white-space: nowrap;
  }
}

/* Mobil: nic neměníme – necháme tvůj 1 sloupec layout */
@media (max-width: 767.98px) {
  .courses-col-files{
    justify-content:flex-start;
  }
  .courses-col-files .course-file-pill{
    flex: 1 1 0; /* na mobilu klidně stejné šířky */
  }
}


/* =========================================================
   BADGE STAVU – sjednoceno + hezčí neaktivní (jemně červený)
   ========================================================= */

.course-status-wrapper{ margin-top:4px; }

.course-status-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:2px 9px;
  border-radius:999px;
  font-size:0.7rem;
  font-weight:600;
  letter-spacing:0.06em;
  text-transform:uppercase;
  white-space:nowrap;
  width:100px;
}

/* Aktivní */
.course-status-badge--active{
  background:#e0f6ea;
  color:#1b7b47;
  border:1px solid #bbe7d0;
}

/* Obsazeno */
.course-status-badge--full{
  background:#fff3d4;
  color:#a86b00;
  border:1px solid #f1d38a;
}

/* Neaktivní – jemně červený, ne „křiklavý“ */
.course-status-badge--inactive{
  background:#f9dde0;
  color:#7a1e24;
  border:1px solid #f2b5bb;
}

/* Kurz je obsazen – neklikací pill */
.course-file-pill-disabled{
  opacity:0.7;
  cursor:default;
  pointer-events:none;
}


/* =========================================================
   PROBĚHLÉ KURZY – bez hover animací (zachováno)
   ========================================================= */
.courses-table-row.prob-kurz-row,
.courses-table-row.courses-table-row-teaser{
  transition:none !important;
}

.courses-table-row.prob-kurz-row:hover,
.courses-table-row.courses-table-row-teaser:hover{
  transform:none !important;
  box-shadow:none !important;
  border-color:#e0e6f5 !important;
}


/* =========================================================
   MODÁLY – OPRAVA KONFLIKTU (ponecháme jednu variantu)
   DŮLEŽITÉ: Tohle přepíše tvoje 2 rozdílné definice overlay/modal
   ========================================================= */

body.kurz-modal-open{ overflow:hidden; }

.kurz-modal-overlay{
  position:fixed;
  inset:0;
  background:rgba(6, 15, 46, 0.52);
  display:flex;                 /* vždy flex, viditelnost řešíme přes opacity */
  align-items:center;
  justify-content:center;
  z-index:9999;
  padding:16px;

  opacity:0;
  visibility:hidden;
  transition:opacity 0.25s ease, visibility 0.25s ease;
}

.kurz-modal-overlay.is-visible{
  opacity:1;
  visibility:visible;
}

.kurz-modal{
  max-width:720px;
  width:100%;
  background:#fff;
  border-radius:16px;
  box-shadow:0 18px 50px rgba(3, 29, 103, 0.28);

  transform:translateY(16px);
  opacity:0;
  transition:transform 0.25s ease, opacity 0.25s ease;

  max-height:90vh;
  overflow-y:auto;
  padding:20px 22px 18px;
  position:relative;
  font-size:0.95rem;
}

.kurz-modal-overlay.is-visible .kurz-modal{
  transform:translateY(0);
  opacity:1;
}

@media (max-width: 575.98px){
  .kurz-modal{
    max-width:100%;
    border-radius:16px;
    padding:18px 16px 16px;
  }
}

.kurz-modal-close{
  position:absolute;
  top:10px;
  right:12px;
  border:none;
  background:transparent;
  font-size:1.4rem;
  line-height:1;
  cursor:pointer;
  color:#6b6f85;
}
.kurz-modal-close:hover{ color:#031D67; }

/* loading stav přihlášky */
.kurz-signup-status.is-loading{
  font-size:0.85rem;
  color:#4f5775;
}

.kurz-modal-submit.is-loading{
  position:relative;
  pointer-events:none;
  opacity:0.8;
}

.kurz-modal-submit.is-loading::after{
  content:'';
  display:inline-block;
  width:14px;
  height:14px;
  margin-left:8px;
  border-radius:50%;
  border:2px solid rgba(255,255,255,0.7);
  border-top-color:transparent;
  animation:kurz-btn-spinner 0.7s linear infinite;
}

@keyframes kurz-btn-spinner{ to{ transform:rotate(360deg);} }

/* soubory v info modalu */
.kurz-info-file-pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 10px;
  border-radius:999px;
  background:#f1f4ff;
  font-size:0.85rem;
  color:#2d3550;
  margin:4px 6px 0 0;
  text-decoration:none;
  border:1px solid #d8dffc;
}
.kurz-info-file-pill i{ font-size:0.9rem; }



stary CSS kod mas nekde v tomto chatu, proste si ho jen pouzij znova, dopln h



/*KURZ MODAL PRIHLASKA*/ /* MODÁL – přihláška na kurz */ .kurz-modal-open { overflow: hidden; } .kurz-modal-overlay { position: fixed; inset: 0; background: rgba(5, 12, 40, 0.55); display: none; align-items: center; justify-content: center; z-index: 1050; padding: 16px; } .kurz-modal-overlay.is-visible { display: flex; } .kurz-modal { background: #ffffff; border-radius: 18px; box-shadow: 0 18px 40px rgba(0, 0, 0, 0.25); max-width: 640px; width: 100%; padding: 20px 22px 18px; position: relative; font-size: 0.95rem; } @media (max-width: 575.98px) { .kurz-modal { max-width: 100%; border-radius: 16px; padding: 18px 16px 16px; } } .kurz-modal-close { position: absolute; top: 10px; right: 12px; border: none; background: transparent; font-size: 1.4rem; line-height: 1; cursor: pointer; color: #6b6f85; } .kurz-modal-close:hover { color: #031D67; } .kurz-modal-header { margin-bottom: 14px; } .kurz-modal-badge { display: inline-flex; align-items: center; justify-content: center; padding: 3px 10px; border-radius: 999px; background: rgba(3, 29, 103, 0.06); color: #031D67; font-size: 0.72rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 6px; } .kurz-modal-title { margin: 0 0 3px; font-size: 1.15rem; color: #031D67; font-weight: 600; } .kurz-modal-accr { margin: 0; font-size: 0.85rem; color: #555c78; } .kurz-modal-form { margin-top: 8px; } .kurz-modal-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px 16px; } @media (max-width: 575.98px) { .kurz-modal-grid { grid-template-columns: 1fr; } } .kurz-form-group { margin-bottom: 10px; } .kurz-form-group label { display: block; font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.06em; color: #6a7292; margin-bottom: 4px; } .kurz-form-group input, .kurz-form-group textarea { width: 100%; border-radius: 10px; border: 1px solid #d5dcf2; padding: 7px 9px; font-size: 0.9rem; font-family: inherit; outline: none; transition: border-color 0.2s ease, box-shadow 0.2s ease; } .kurz-form-group input:focus, .kurz-form-group textarea:focus { border-color: #031D67; box-shadow: 0 0 0 1px rgba(3, 29, 103, 0.09); } .kurz-modal-footer { display: flex; align-items: center; gap: 8px; margin-top: 10px; margin-bottom: 4px; flex-wrap: wrap; } .kurz-modal-submit { border: none; border-radius: 999px; padding: 7px 16px; background: #136b3b; color: #ffffff; font-size: 0.9rem; font-weight: 600; cursor: pointer; transition: background 0.2s ease, box-shadow 0.2s ease, transform 0.15s ease; } .kurz-modal-submit:hover { background: #0f5430; box-shadow: 0 8px 18px rgba(19, 107, 59, 0.3); transform: translateY(-1px); } .kurz-modal-cancel { border-radius: 999px; border: 1px solid #d0d6ee; background: #f6f7ff; color: #4f5775; padding: 7px 16px; font-size: 0.86rem; cursor: pointer; transition: background 0.2s ease, border-color 0.2s ease; } .kurz-modal-cancel:hover { background: #e5e8fb; border-color: #c0c7ea; } .kurz-modal-note { margin: 4px 0 0; font-size: 0.78rem; color: #7a8099; } .kurz-signup-status { min-height: 18px; margin-top: 4px; font-size: 0.83rem; } .kurz-signup-status.is-success { color: #176a3a; } .kurz-signup-status.is-error { color: #b82323; } /* Proběhlé kurzy – žádná hover animace */ .courses-table-row.prob-kurz-row, .courses-table-row.courses-table-row-teaser { transition: none !important; } .courses-table-row.prob-kurz-row:hover, .courses-table-row.courses-table-row-teaser:hover { transform: none !important; box-shadow: none !important; border-color: #e0e6f5 !important; } /* Teaser blur */ .courses-table-row-teaser { position: relative; overflow: hidden; margin-bottom: 8px; } .courses-table-row-teaser-inner { filter: blur(3px); opacity: 0.7; pointer-events: none; } .courses-table-row-teaser::after { content: "Další proběhlé akce v archivu…"; position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; background: rgba(244, 247, 255, 0.9); font-size: 0.9rem; font-weight: 500; color: #4f5775; } /*KURZ INFO*/ /* Smooth overlay + modal animace – sdílené pro oba modaly */ .kurz-modal-overlay { position: fixed; inset: 0; background: rgba(6, 15, 46, 0.52); opacity: 0; visibility: hidden; transition: opacity 0.25s ease, visibility 0.25s ease; z-index: 9999; display: flex; align-items: center; justify-content: center; } .kurz-modal-overlay.is-visible { opacity: 1; visibility: visible; } .kurz-modal { max-width: 720px; width: 100%; background: #ffffff; border-radius: 16px; box-shadow: 0 18px 50px rgba(3, 29, 103, 0.28); transform: translateY(16px); opacity: 0; transition: transform 0.25s ease, opacity 0.25s ease; max-height: 90vh; overflow-y: auto; } .kurz-modal-overlay.is-visible .kurz-modal { transform: translateY(0); opacity: 1; } /* Loading stav přihlášky */ .kurz-signup-status.is-loading { font-size: 0.85rem; color: #4f5775; } .kurz-modal-submit.is-loading { position: relative; pointer-events: none; opacity: 0.8; } .kurz-modal-submit.is-loading::after { content: ''; display: inline-block; width: 14px; height: 14px; margin-left: 8px; border-radius: 50%; border: 2px solid rgba(255,255,255,0.7); border-top-color: transparent; animation: kurz-btn-spinner 0.7s linear infinite; } @keyframes kurz-btn-spinner { to { transform: rotate(360deg); } } /* Když je nějaký modal otevřený */ body.kurz-modal-open { overflow: hidden; } /* Styl souborů v info modalu */ .kurz-info-file-pill { display: inline-flex; align-items: center; gap: 6px; padding: 6px 10px; border-radius: 999px; background: #f1f4ff; font-size: 0.85rem; color: #2d3550; margin: 4px 6px 0 0; text-decoration: none; border: 1px solid #d8dffc; } .kurz-info-file-pill i { font-size: 0.9rem; }











/* Jen pro tlačítka "Proběhlé akce" */
.probehle-actions{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  margin-top:6px;
}

.probehle-btn{
  appearance:none;
  border:1px solid #d7def5;
  background:#fff;
  color:#2d3550;
  padding:10px 14px;
  border-radius:999px;
  font-size:0.9rem;
  line-height:1;
  display:inline-flex;
  gap:8px;
  align-items:center;
  cursor:pointer;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease, opacity .2s ease;
  box-shadow:0 8px 18px rgba(18,38,63,.06);
}

.probehle-btn:hover{
  transform:translateY(-1px);
  border-color:#b9c7ff;
  box-shadow:0 12px 28px rgba(18,38,63,.10);
}

.probehle-btn:active{ transform:translateY(0); }

.probhle-btn--primary{
  background:linear-gradient(135deg,#2f5bff,#5d86ff);
  border-color:transparent;
  color:#fff;
}

.probhle-btn--primary:hover{ opacity:.95; }

.probhle-btn--ghost{
  background:#f7f9ff;
}

.probehle-btn[disabled]{
  cursor:not-allowed;
  opacity:.6;
  transform:none;
}

/* Smooth animace pro rozbalování řádků */
.prob-kurz-row{
  overflow:hidden;
  transition:max-height .35s ease, opacity .25s ease, transform .35s ease;
  will-change:max-height, opacity, transform;
}

.prob-kurz-row.is-hidden{
  opacity:0 !important;
  transform:translateY(-6px) !important;
  max-height:0 !important;

  padding-top:0 !important;
  padding-bottom:0 !important;
  margin-top:0 !important;
  margin-bottom:0 !important;

  border:0 !important;          /* <- tohle odstraní ty 2px */
  gap:0 !important;              /* pro jistotu (grid gap) */
  overflow:hidden !important;
}











/* ========== HERO SEKCE – SCHOLA MEDICA ========== */
.sm-hero {
  position: relative;
  padding: 110px 0 70px;
  background: radial-gradient(circle at top left, #e3ecff 0, #f4f7ff 40%, #ffffff 100%);
  overflow: hidden;
  font-family: "IBM Plex Sans", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.sm-hero::before {
  content: "";
  position: absolute;
  top: -140px;
  right: -160px;
  width: 380px;
  height: 380px;
  background: radial-gradient(circle, rgba(3,29,103,0.15) 0, transparent 60%);
  opacity: 0.8;
  pointer-events: none;
}

.sm-hero-container {
  position: relative;
  z-index: 1;
}

.sm-hero-inner {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  gap: 40px;
  align-items: center;
}

/* TEXTOVÁ ČÁST */
.sm-hero-content {
  max-width: 620px;
}

.sm-hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 5px 12px 5px 6px;
  border-radius: 999px;
  background: rgba(3,29,103,0.06);
  color: #031D67;
  font-size: 0.8rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 14px;
}

.sm-hero-badge-dot {
  width: 20px;
  height: 20px;
  border-radius: 999px;
  background: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 0 1px rgba(3,29,103,0.12), 0 4px 10px rgba(3,29,103,0.25);
  position: relative;
}

.sm-hero-badge-dot::before {
  content: "";
  width: 10px;
  height: 10px;
  border-radius: inherit;
  background: #2ecc71;
}

.sm-hero-title {
  font-size: clamp(1.9rem, 3vw, 2.4rem);
  line-height: 1.2;
  margin: 0 0 8px;
  color: #031D67;
  font-weight: 700;
}

.sm-hero-slogan {
  margin: 0 0 12px;
  font-size: 1.1rem;
  font-weight: 500;
  color: #1e2450;
}

.sm-hero-text {
  margin: 0 0 20px;
  font-size: 0.98rem;
  line-height: 1.65;
  color: #4f5775;
}

.sm-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 20px;
}

.sm-hero-btn {
  border-radius: 999px;
  padding: 10px 18px;
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  cursor: pointer;
  border: 1px solid transparent;
  transition:
    background 0.22s ease,
    color 0.22s ease,
    transform 0.18s ease,
    box-shadow 0.22s ease,
    border-color 0.22s ease;
}

.sm-hero-btn-primary {
  background: #031D67;
  color: #ffffff;
  box-shadow: 0 14px 32px rgba(3,29,103,0.45);
}

.sm-hero-btn-primary:hover {
  background: #052b9a;
  color: #ffffff;
  transform: translateY(-1px);
  box-shadow: 0 18px 40px rgba(3,29,103,0.55);
}

.sm-hero-btn-secondary {
  background: #ffffff;
  color: #031D67;
  border-color: #d3d7f0;
}

.sm-hero-btn-secondary:hover {
  background: #f6f7ff;
  border-color: #c2c8eb;
  color: #031D67;
  transform: translateY(-1px);
  box-shadow: 0 10px 26px rgba(0,0,0,0.08);
}

/* STATISTIKY */
.sm-hero-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin-top: 4px;
}

.sm-hero-stat {
  min-width: 150px;
}

.sm-hero-stat-value {
  display: block;
  font-size: 1.25rem;
  font-weight: 600;
  color: #031D67;
}

.sm-hero-stat-label {
  display: block;
  font-size: 0.8rem;
  color: #6b6f88;
}

/* VIZUÁLNÍ ČÁST */
.sm-hero-visual {
  position: relative;
  min-height: 280px;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 10px;
}

.sm-hero-visual-bg {
  position: absolute;
  inset: 8% 5% 5% 5%;
  background: radial-gradient(circle at top, rgba(3,29,103,0.15), transparent 70%);
  opacity: 0.7;
  filter: blur(4px);
  pointer-events: none;
}

.sm-hero-visual-card {
  position: relative;
  border-radius: 18px;
  border: 1px solid rgba(221,229,255,0.95);
  background: #ffffff;
  box-shadow: 0 18px 48px rgba(3,20,70,0.35);
  padding: 18px 18px 14px;
  z-index: 2;
  max-width: 360px;
  width: 100%;
}



/* sekundární karta – přímo pod hlavní, stejná šířka */
.sm-hero-visual-secondary {
  background: linear-gradient(135deg, #f7f8ff, #ffffff);
  box-shadow: 0 16px 38px rgba(3,20,70,0.25);
}

/* obsah karet */
.sm-hero-visual-header {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 8px;
}

.sm-hero-visual-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border-radius: 999px;
  padding: 4px 10px 4px 5px;
  background: linear-gradient(90deg, #031D67, #4b6ff5);
  color: #ffffff;
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.sm-hero-visual-pill-dot {
  width: 18px;
  height: 18px;
  border-radius: 999px;
  background: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.62rem;
  color: #031D67;
  box-shadow: 0 0 0 1px rgba(255,255,255,0.35);
}

.sm-hero-visual-label {
  font-size: 0.78rem;
  color: #8a90aa;
}

.sm-hero-visual-title {
  font-size: 1rem;
  margin: 4px 0 10px;
  color: #1f2550;
}

.sm-hero-visual-list {
  list-style: none;
  padding: 0;
  margin: 0 0 12px;
  font-size: 0.85rem;
  color: #4a5070;
}

.sm-hero-visual-list li {
  display: flex;
  gap: 8px;
  align-items: flex-start;
  margin-bottom: 6px;
}

.sm-hero-visual-list i {
  margin-top: 2px;
  font-size: 0.85rem;
  color: #031D67;
}

.sm-hero-visual-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  border-top: 1px dashed #e0e4f6;
  padding-top: 8px;
  margin-top: 4px;
}

.sm-hero-visual-capacity {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.8rem;
  color: #4f5775;
}

.sm-hero-capacity-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #2ecc71;
  box-shadow: 0 0 0 3px rgba(46,204,113,0.3);
}

.sm-hero-visual-link {
  font-size: 0.82rem;
  font-weight: 600;
  color: #031D67;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.sm-hero-visual-link i {
  font-size: 0.8rem;
}

.sm-hero-visual-link:hover {
  text-decoration: underline;
}

/* sekundární text – okruhy */
.sm-hero-mini-line {
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: #7b81a0;
  margin-bottom: 6px;
}

.sm-hero-mini-list {
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 0.8rem;
  color: #4a5070;
}

.sm-hero-mini-list li {
  display: flex;
  gap: 6px;
  align-items: flex-start;
  margin-bottom: 4px;
}

.sm-hero-mini-list i {
  margin-top: 2px;
  font-size: 0.78rem;
  color: #2ecc71;
}

/* RESPONSIVE */
@media (max-width: 991.98px) {
  .sm-hero {
    padding: 96px 0 54px;
  }

  .sm-hero-inner {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  /* pořadí – na mobilu vždy text nahoře, vizuál pod ním */
  .sm-hero-content {
    order: 1;
  }
  .sm-hero-visual {
    order: 2;
    align-items: stretch;
  }

  .sm-hero-visual-card {
    max-width: 100%;
  }
}

@media (max-width: 767.98px) {
  .sm-hero {
    padding-top: 88px;
  }

  .sm-hero-inner {
    gap: 24px;
  }

  .sm-hero-content {
    text-align: left;
  }

  .sm-hero-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .sm-hero-btn {
    justify-content: center;
  }

  .sm-hero-stats {
    gap: 12px;
  }

  .sm-hero-stat {
    min-width: 0;
    flex: 1 1 100%;
  }
}









/* ============ O NÁS ============ */

.sm-about-section {
  background: #ffffff;
  padding: 64px 0 56px;
}

.sm-about-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 24px;
  align-items: flex-start;
}

.sm-about-text {
  max-width: 760px;
}

.sm-about-eyebrow {
  margin: 0 0 6px;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: #6b7280;
  font-weight: 600;
}

.sm-about-title {
  margin: 0 0 10px;
  font-size: 1.6rem;
  line-height: 1.35;
  color: #111827;
  font-weight: 700;
}

@media (min-width: 992px) {
  .sm-about-title {
    font-size: 1.9rem;
  }
}

.sm-about-lead {
  margin: 0 0 18px;
  font-size: 0.98rem;
  line-height: 1.7;
  color: #374151;
}

/* krátké „feature“ řádky */
.sm-about-list {
  display: grid;
  gap: 14px;
}

.sm-about-item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 10px 14px;
  align-items: flex-start;
}

.sm-about-icon {
  width: 32px;
  height: 32px;
  border-radius: 999px;
  background: #eff6ff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #1d4ed8;
  flex-shrink: 0;
  font-size: 0.9rem;
}

.sm-about-item-title {
  margin: 0 0 2px;
  font-size: 0.9rem;
  font-weight: 600;
  color: #111827;
}

.sm-about-item-text {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.6;
  color: #4b5563;
}

/* jednoduchý meta-proužek pod textem */
.sm-about-meta-strip {
  margin-top: 20px;
  padding: 10px 12px;
  border-radius: 999px;
  background: #f3f4ff;
  display: flex;
  flex-wrap: wrap;
  gap: 8px 16px;
  align-items: center;
}

.sm-about-meta-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.82rem;
  color: #1f2937;
  white-space: nowrap;
}

.sm-about-meta-item i {
  font-size: 0.85rem;
  color: #1d4ed8;
}

@media (max-width: 575.98px) {
  .sm-about-meta-strip {
    border-radius: 14px;
    flex-direction: column;
    align-items: flex-start;
  }
  .sm-about-meta-item {
    white-space: normal;
  }
}

@media (max-width: 767.98px) {
  .sm-about-section {
    padding: 52px 0 48px;
  }
}

/* ============ NAŠE SLUŽBY ============ */

.sm-services-section {
  background: #ffffff;
  padding: 48px 0 64px;
  border-top: 1px solid #f3f4f6;
}

.sm-services-header {
  text-align: center;
  max-width: 680px;
  margin: 0 auto 28px;
}

.sm-services-eyebrow {
  margin: 0 0 6px;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: #6b7280;
  font-weight: 600;
}

.sm-services-title {
  margin: 0 0 8px;
  font-size: 1.6rem;
  color: #111827;
  font-weight: 700;
}

@media (min-width: 992px) {
  .sm-services-title {
    font-size: 1.9rem;
  }
}

.sm-services-lead {
  margin: 0;
  font-size: 0.96rem;
  color: #4b5563;
  line-height: 1.6;
}

/* grid služeb */
.sm-services-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}

@media (min-width: 768px) {
  .sm-services-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.sm-service-card {
  border-radius: 16px;
  background: #f9fafb;
  border: 1px solid #e5e7eb;
  padding: 16px 16px 14px;
  height: 100%;
  display: flex;
  flex-direction: column;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.sm-service-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 30px rgba(15, 23, 42, 0.10);
  border-color: #d1d5db;
}

.sm-service-icon {
  width: 36px;
  height: 36px;
  border-radius: 12px;
  background: #eff6ff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #1d4ed8;
  font-size: 1.05rem;
  margin-bottom: 10px;
}

.sm-service-title {
  margin: 0 0 6px;
  font-size: 1.02rem;
  color: #111827;
  font-weight: 600;
}

.sm-service-text {
  margin: 0 0 10px;
  font-size: 0.9rem;
  color: #4b5563;
  line-height: 1.6;
}

/* „tagy“ uvnitř karty */
.sm-service-tags {
  list-style: none;
  margin: auto 0 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.sm-service-tags li {
  font-size: 0.78rem;
  border-radius: 999px;
  padding: 3px 9px;
  background: #e5f0ff;
  color: #1e3a8a;
}

/* CTA pod kartami */
.sm-services-cta {
  margin-top: 22px;
  padding-top: 14px;
  border-top: 1px dashed #e5e7eb;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  justify-content: space-between;
  font-size: 0.9rem;
  color: #374151;
}

.sm-services-cta-link {
  font-size: 0.9rem;
  font-weight: 600;
  color: #1d4ed8;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.sm-services-cta-link i {
  font-size: 0.85rem;
}

.sm-services-cta-link:hover {
  text-decoration: underline;
}

@media (max-width: 767.98px) {
  .sm-services-section {
    padding: 40px 0 52px;
  }
  .sm-services-cta {
    flex-direction: column;
    align-items: flex-start;
  }
}
/* === ULTRA SMOOTH HOVER – PRIORITNÍ STYLY === */

/* Základní karta */
.sm-service-card {
  position: relative;
  border-radius: 16px;
  background: #f9fafb;
  border: 1px solid #e5e7eb;
  padding: 16px 16px 14px;
  display: flex;
  flex-direction: column;
  overflow: hidden;

  /* TADY JE KLÍČ – JEN OPACITY + TRANSFORM JSOU HLADKÉ */
  transition:
    transform 0.4s cubic-bezier(.25,.8,.25,1),
    background-color 0.35s ease,
    border-color 0.35s ease,
    box-shadow 0.45s cubic-bezier(.25,.8,.25,1);
  will-change: transform, box-shadow, background-color;
}

/* Jemný „glow“ efekt */
.sm-service-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(circle at top, rgba(59,130,246,0.20), transparent 70%);
  opacity: 0;
  transform: translateY(10px);
  transition:
    opacity 0.6s ease,
    transform 0.6s ease;
  pointer-events: none;
}

/* Hover */
.sm-service-card:hover {
  transform: translateY(-6px);
  background-color: #ffffff;
  border-color: #d0d7e2;
  box-shadow: 0 22px 44px rgba(0, 23, 71, 0.18);
}

.sm-service-card:hover::before {
  opacity: 1;
  transform: translateY(0);
}

/* Ikona – smooth */
.sm-service-icon {
  transition:
    transform 0.35s ease,
    background-color 0.35s ease,
    color 0.35s ease;
}

.sm-service-card:hover .sm-service-icon {
  transform: translateY(-2px) scale(1.08);
  background-color: #e0edff;
}

/* Tagy – jemný posun */
.sm-service-tags li {
  transition:
    transform 0.3s ease,
    background-color 0.3s ease;
}

.sm-service-card:hover .sm-service-tags li {
  transform: translateY(-2px);
  background-color: #dce9ff;
}


/* Neaktivní kurzy jsou defaultně skryté */
.admin-courses-row.is-inactive { display:none; }

/* Po kliknutí se zobrazí */
.admin-show-inactive .admin-courses-row.is-inactive { display:table-row; }

/* Mobil (kde jsou řádky display:block) */
@media (max-width: 767.98px) {
  .admin-show-inactive .admin-courses-row.is-inactive { display:block; }
}





  .nabidka-kurz-row { overflow:hidden; }
  .nabidka-kurz-row.is-hidden { display:none !important; }


/* Footer logo – jemný světlý glow kolem průhledného loga */
.footer-59391 .footer-logo-link img{
  filter: drop-shadow(0 0 10px rgba(255,255,255,0.7));
}






















/* Nabídka – animace řádků */
.nabidka-kurz-row{
  overflow: hidden;                 /* důležité proti "crop bugům" při animaci */
  transition: max-height .35s ease, opacity .25s ease, transform .25s ease;
  will-change: max-height;
}

/* skrytý stav */
.nabidka-kurz-row.is-hidden{
  max-height: 0 !important;
  opacity: 0;
  transform: translateY(-6px);
  pointer-events: none;
}






