/* Anti-FOUT — skryje obsah dokud se font nenačte */
html {
    opacity: 0;
    transition: opacity 0.3s ease;
}
html.fonts-loaded {
    opacity: 1;
}

/* Color Flow — CSS proměnné pro mouse-driven animace */
:root {
    --cf-x: 50%;
    --cf-y: 50%;
    --cf-hue: 0deg;
}

/* Customizer styles from live psilocybin.cz */

/* Logo sizing */
.tx_logo img { height: 64px; }
.tx_sticky_logo img { height: 36px; }
@media(max-width: 1024px) {
    .tx_logo img { height: 32px; }
}

/* Menu hover underline - DISABLED */
.main-menu > li a:before,
.main-menu > li > a:before,
.main-menu > li:hover > a:before {
    display: none !important;
    content: none !important;
}

/* Kill grey rectangle behind submenu (.depth0:before backdrop) */
.depth0:before,
.depth0::before,
.tx-mega-menu .mega-menu-item .depth0::before {
    display: none !important;
    content: none !important;
}

/* Remove any leftover background/border on menu items */
.main-menu > li,
ul.main-menu > li,
.tx-mega-menu > li,
.tx-mega-menu > li > a {
    background: transparent !important;
    background-color: transparent !important;
    border: none !important;
    box-shadow: none !important;
    outline: none !important;
}
/* Menu links reset — bez !important na background, aby hover fungoval */
.main-menu > li > a,
ul.main-menu > li > a {
    background: transparent;
    background-color: transparent;
    border: none !important;
    outline: none !important;
}

/* Kill white/grey blocks behind menu area */
.menu-bar,
.site-nav-inner,
.navbar-responsive-collapse,
.navigation,
ul.main-menu,
ul.navbar-nav {
    background: transparent !important;
    background-color: transparent !important;
    box-shadow: none !important;
}

.tx-mega-menu .mega-menu-item .depth0 { left: -45%; }

/* ====== WATERCOLOR – hlavní menu styl ====== */

/* Header background – akvarel gradient */
#h-style-3,
.main-header {
    background: linear-gradient(160deg, #d4e6f8 0%, #daf2d0 40%, #f5d6eb 100%) !important;
    transition: background 1.5s ease-out !important;
}

/* Menu items – barva a hover */
.main-menu > li > a,
.main-menu li ul li a,
.depth0.sub-menu li a,
.psi-breadcrumbs a,
.psi-breadcrumbs-siblings a {
    cursor: pointer !important;
}

.main-menu > li > a {
    position: relative;
    color: #1a5276 !important;
    font-size: 16.5px !important;
    transition: color 0.7s ease-out,
                text-shadow 0.8s ease-out,
                transform 0.5s cubic-bezier(0.22,1,0.36,1),
                filter 0.7s ease-out,
                background 0.5s ease-out,
                border-radius 0.4s ease-out,
                box-shadow 0.5s ease-out,
                font-size 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) !important;
    overflow: visible;
    background: transparent !important;
    background-image: none !important;
    text-shadow: 0 0 0 transparent !important;
    filter: brightness(1) !important;
}

/* Gradient underline via ::after */
.main-menu > li > a::after,
.main-menu > li > a:after,
.main-menu > li.menu-item-has-children > a::after,
.main-menu > li.menu-item-has-children > a:after,
ul.main-menu > li.menu-item-has-children > a::after,
ul.main-menu > li.menu-item-has-children > a:after {
    content: '' !important;
    display: block !important;
    position: absolute !important;
    bottom: 2px !important;
    left: 50% !important;
    right: auto !important;
    top: auto !important;
    width: 0 !important;
    height: 1.5px !important;
    background: rgba(21,101,192,0.35) !important;
    border-radius: 1px !important;
    transition: width 0.7s cubic-bezier(0.22,1,0.36,1), opacity 0.7s ease-out, bottom 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) !important;
    opacity: 0 !important;
    transform: translateX(-50%) !important;
    float: none !important;
    font-family: inherit !important;
    margin: 0 !important;
    padding: 0 !important;
    z-index: 1;
}

.main-menu > li:hover > a::after,
.main-menu > li:hover > a:after {
    width: 60% !important;
    opacity: 0.8 !important;
}

ul.main-menu > li > a:hover,
ul.main-menu > li.menu-item-has-children:hover > a {
    color: #1565C0 !important;
    background: radial-gradient(ellipse at center, rgba(21,101,192,0.07) 0%, transparent 70%) !important;
    text-shadow: 0 0 12px rgba(21,101,192,0.15) !important;
    transform: translateY(-1px) !important;
    filter: brightness(1.05) !important;
}

/* ====== Active stav – hlavní menu ====== */

/* Rodičovská sekce (např. "Legislativa" když jsem na pravo.html) */
ul.main-menu > li.current-page-ancestor > a,
ul.main-menu > li.current-menu-ancestor > a {
    color: #1565C0 !important;
}

ul.main-menu > li.current-page-ancestor > a::after,
ul.main-menu > li.current-menu-ancestor > a::after {
    width: 40% !important;
    opacity: 0.7 !important;
}

/* Přímá stránka bez podmenu (Úvod, Události, Kontakt) */
ul.main-menu > li.current-menu-item > a {
    color: #1565C0 !important;
}

ul.main-menu > li.current-menu-item > a::after {
    width: 40% !important;
    opacity: 0.7 !important;
}

/* Aktivní položka v submenu */
.main-menu li ul li.current-menu-item > a,
.depth0.sub-menu li.current-menu-item > a {
    color: #1565C0 !important;
    font-weight: 600 !important;
    box-shadow: none !important;
    background: rgba(21,101,192,0.06) !important;
    border-radius: 10px !important;
    padding: 6px 14px !important;
}

/* ====== WATERCOLOR – Submenu (propojené s hl. menu) ====== */

.main-menu > li.menu-item-has-children {
    position: relative !important;
    transition: background 0.45s ease-out, border-radius 0.45s ease-out, box-shadow 0.45s ease-out !important;
    border-radius: 18px !important;
}

/* Rodičovský <li> na hover — horní část bloku, tmavší */
ul.main-menu > li.menu-item-has-children:hover {
    background: linear-gradient(160deg, #c3d9f0, #c8e8b8, #ecc5df) !important;
    background-attachment: fixed !important;
    border-radius: 18px 18px 0 0 !important;
    box-shadow: -4px -4px 20px rgba(21,101,192,0.10) !important;
    z-index: 110 !important;
}

/* Schovat underline když je submenu otevřené */
ul.main-menu > li.menu-item-has-children:hover > a::after {
    opacity: 0 !important;
    width: 0 !important;
}

/* Hover text v propojené ploše — bez translateY (jinak skáče) */
ul.main-menu > li.menu-item-has-children:hover > a {
    transform: none !important;
}

/* Submenu container – vždy "existuje", jen je neviditelný */
.main-menu li ul,
.main-menu li .depth0.sub-menu {
    display: block !important;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    transform: scaleY(0.95) !important;
    transform-origin: top center !important;
    transition: opacity 0.4s ease-out,
                visibility 0.4s ease-out,
                transform 0.4s cubic-bezier(0.22,1,0.36,1) !important;
    background: linear-gradient(160deg, #d4e6f8, #daf2d0, #f5d6eb) !important;
    background-attachment: fixed !important;
    border: none !important;
    border-radius: 0 18px 18px 18px !important;
    box-shadow: 0 10px 36px rgba(21,101,192,0.18) !important;
    padding: 10px 8px !important;
    top: 100% !important;
    margin-top: 0 !important;
    padding-top: 10px !important;
    overflow: hidden;
    z-index: 110 !important;
}

/* Submenu SHOW on hover – plynulý fade+scale */
.main-menu > li:hover > ul,
.main-menu > li:hover > .depth0.sub-menu,
.main-menu > li.menu-item-has-children:hover > ul,
.main-menu > li.menu-item-has-children:hover > .depth0.sub-menu,
.tx-mega-menu > li:hover > .depth0 {
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    transform: scaleY(1) !important;
}

/* Submenu items – jen opacity, žádný transform (kontejner už animuje) */
.main-menu li ul li,
.depth0.sub-menu > li {
    border: none !important;
    padding: 0 !important;
    opacity: 1 !important;
    transform: none !important;
}

/* Submenu links */
.main-menu li ul li a,
.depth0.sub-menu li a,
.depth0 li .depth1.standard.sub-menu li a {
    color: #2c4a6a !important;
    padding: 10px 18px !important;
    border-radius: 12px !important;
    border-left: none !important;
    transition: color 0.8s ease-out,
                background 1.4s cubic-bezier(0.22,1,0.36,1),
                box-shadow 1.4s cubic-bezier(0.22,1,0.36,1),
                text-shadow 1s ease-out !important;
    position: relative;
    font-size: 13px !important;
    font-weight: 400 !important;
    letter-spacing: 0.3px;
    background: transparent !important;
    display: block;
}

/* Submenu link hover — plynulý barevný přeliv */
.main-menu li ul li a:hover,
.depth0.sub-menu li a:hover,
.depth0 li .depth1.standard.sub-menu li a:hover {
    color: #0a4070 !important;
    background: linear-gradient(90deg,
        rgba(21,101,192,0.15),
        rgba(129,215,66,0.12),
        rgba(180,80,160,0.10),
        rgba(21,101,192,0.15)) !important;
    background-size: 300% 100% !important;
    animation: submenuColorFlow 4s ease-in-out infinite !important;
    border-radius: 10px !important;
    box-shadow: 0 2px 10px rgba(21,101,192,0.14) !important;
    text-shadow: 0 0 14px rgba(21,101,192,0.15) !important;
}

@keyframes submenuColorFlow {
    0%   { background-position: 0% 50%; }
    50%  { background-position: 100% 50%; }
    100% { background-position: 0% 50%; }
}

/* No ::before on submenu links */
.main-menu li ul li a::before,
.depth0.sub-menu li a::before {
    content: none !important;
    display: none !important;
}

/* Obsah – full-width layout */
.container.space-content {
    max-width: 100% !important;
    width: 100% !important;
    padding: 40px 0 0 0 !important;
}

/* ====== Breadcrumbs ====== */
.psi-breadcrumbs {
    padding: 12px 60px;
    margin-bottom: 20px;
    font-family: Poppins, sans-serif;
    font-size: 13px;
    letter-spacing: 0.2px;
    display: flex;
    align-items: center;
    justify-content: center;
    /* Sticky pod fixním headerem — top řízeno z sticky-header.js */
    position: sticky;
    top: 80px;
    z-index: 50;
    background: #ffffff;
    border-bottom: 1px solid #e2e8f0;
}

/* Bílý blok NAD BC — zakryje veškerý text mezi headerem a BC */
.psi-breadcrumbs::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: 100%;
    height: 150px;
    background: #ffffff;
    pointer-events: none;
}

/* Spodní hrana BC — ostrá, žádný gradient */
.psi-breadcrumbs::before {
    content: none;
}


.psi-breadcrumbs ol {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    align-items: center;
    flex-wrap: nowrap;
    gap: 0;
    flex-shrink: 0;
}

.psi-breadcrumbs li {
    display: flex;
    align-items: center;
    color: #6b8fad;
}

.psi-breadcrumbs li + li::before {
    content: '/';
    margin: 0 8px;
    color: rgba(21,101,192,0.2);
    font-size: 11px;
    font-weight: 300;
}

.psi-breadcrumbs a {
    color: #1E73BE;
    text-decoration: none;
    border-bottom: 1px dashed rgba(30,115,190,0.35);
    padding-bottom: 1px;
    transition: color 0.4s ease-out, border-color 0.4s ease-out;
    position: relative;
}

.psi-breadcrumbs a:hover {
    color: #1565C0;
    border-bottom-color: rgba(21,101,192,0.7);
    border-bottom-style: solid;
}

.psi-breadcrumbs li.current span {
    color: #1a5276;
    font-weight: 500;
}

/* Siblings – další stránky v sekci */
.psi-breadcrumbs-siblings {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: 7px;
    margin-left: 18px;
    padding-left: 18px;
    position: relative;
}

/* Gradient oddělovač místo border-left */
.psi-breadcrumbs-siblings::before {
    content: '';
    position: absolute;
    left: 0;
    top: 15%;
    bottom: 15%;
    width: 2px;
    border-radius: 1px;
    background: linear-gradient(180deg,
        rgba(21,101,192,0.15),
        rgba(46,125,50,0.2) 50%,
        rgba(180,80,160,0.15));
}

.psi-breadcrumbs-siblings a {
    display: inline-block;
    font-size: 11.5px;
    color: #2c5f8a;
    text-decoration: none;
    padding: 4px 12px;
    border-radius: 12px;
    background: linear-gradient(135deg, rgba(212,230,248,0.5), rgba(218,242,208,0.3), rgba(245,214,235,0.4));
    border: 1px solid rgba(21,101,192,0.08);
    transition: color 0.5s ease-out, background 1.5s ease-out, border-color 0.5s ease-out, box-shadow 0.5s ease-out;
    letter-spacing: 0.1px;
    font-family: Poppins, sans-serif;
    white-space: nowrap;
}

.psi-breadcrumbs-siblings a:hover {
    color: #1565C0;
    background: linear-gradient(135deg, rgba(212,230,248,0.8), rgba(218,242,208,0.5), rgba(245,214,235,0.6));
    border-color: rgba(21,101,192,0.15);
    box-shadow: 0 2px 8px rgba(21,101,192,0.08);
}

/* ====== Content Grid ====== */
.psi-content-grid {
    display: grid;
    grid-template-columns: 1fr 280px;
    gap: 40px;
    align-items: start;
}

/* 3-sloupcový layout: TOC + obsah + sidebar */
.psi-content-grid.has-toc {
    grid-template-columns: 240px 1fr 300px;
    gap: 0;
    max-width: 1440px;
    margin: 0 auto;
}

/* TOC bez sidebaru */
.psi-content-grid.has-toc:not(:has(.psi-sidebar)) {
    grid-template-columns: 240px 1fr;
}

/* Grid bez TOC — taky centrovat */
.psi-content-grid:not(.has-toc) {
    max-width: 1440px;
    margin: 0 auto;
}

/* ====== TOC — Table of Contents (levý panel) ====== */
.psi-toc {
    border-right: 1px solid #e2e8f0;
    padding: 20px 20px 60px 40px;
    align-self: stretch;
}

.psi-toc-inner {
    position: sticky;
    top: 140px;
    z-index: 40;
    background: #ffffff;
    max-height: calc(100vh - 180px);
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: #d1e8e8 transparent;
}

.psi-toc-title {
    font-size: 0.75rem;
    font-weight: 600;
    color: #718096;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin: 0 0 14px 0;
    font-family: Poppins, sans-serif;
}

.psi-toc-links {
    list-style: none;
    margin: 0;
    padding: 0;
}

.psi-toc-links li {
    margin-bottom: 2px;
}

.psi-toc-links a {
    display: block;
    padding: 6px 12px;
    font-size: 0.82rem;
    color: #718096;
    font-family: Poppins, sans-serif;
    text-decoration: none;
    border-left: 2px solid transparent;
    border-radius: 0 6px 6px 0;
    transition: all 0.2s ease;
    line-height: 1.4;
}

.psi-toc-links a:hover {
    color: #2B9E9E;
    border-left-color: #E8F5F5;
}

.psi-toc-links a.active {
    color: #2B9E9E;
    background: #E8F5F5;
    border-left-color: #2B9E9E;
    font-weight: 500;
}

/* Vnořené položky (H3) */
.psi-toc-links a.psi-toc-sub {
    padding-left: 24px;
    font-size: 0.78rem;
}

/* ====== Right Sidebar ====== */

.psi-sidebar {
    min-width: 0;
    align-self: stretch;
}

.psi-sidebar-inner {
    position: sticky;
    top: 140px;
    z-index: 40;
    background: #F0F9F9;
    border-radius: 16px;
    padding: 24px;
    font-family: Poppins, sans-serif;
}

.psi-sidebar-title {
    font-size: 1.05rem;
    font-weight: 600;
    color: #2B9E9E;
    margin: 0 0 12px 0;
    padding-bottom: 10px;
    border-bottom: 1px solid #D1E8E8;
}

.psi-sidebar-desc {
    font-size: 0.82rem;
    color: #4a5568;
    line-height: 1.6;
    margin: 0 0 18px 0;
}

.psi-sidebar-links {
    list-style: none;
    margin: 0;
    padding: 0;
}

.psi-sidebar-links li {
    margin-bottom: 3px;
}

.psi-sidebar-links a {
    display: block;
    padding: 9px 14px;
    text-decoration: none;
    color: #4A5568;
    font-size: 0.88rem;
    font-weight: 500;
    border-radius: 10px;
    transition: background 0.3s ease, color 0.3s ease;
    position: relative;
    padding-left: 18px;
}

.psi-sidebar-links a::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 3px;
    height: 0;
    background: #2B9E9E;
    border-radius: 2px;
    transition: height 0.25s ease;
}

.psi-sidebar-links a:hover {
    background: rgba(255,255,255,0.7);
    color: #319795;
}

.psi-sidebar-links a:hover::before {
    height: 55%;
}

.psi-sidebar-links a.active {
    background: rgba(255,255,255,0.8);
    color: #2B9E9E;
    font-weight: 600;
}

.psi-sidebar-links a.active::before {
    height: 55%;
}

.psi-sidebar-link-label {
    display: block;
    font-weight: 500;
}

.psi-sidebar-link-desc {
    display: block;
    font-size: 0.75rem;
    font-weight: 400;
    color: #5a7a8a;
    margin-top: 2px;
    line-height: 1.4;
    opacity: 0.85;
}

.psi-sidebar-more {
    display: block;
    margin-top: 16px;
    padding-top: 12px;
    border-top: 1px solid rgba(21,101,192,0.12);
    font-size: 0.82rem;
    font-weight: 500;
    color: #2B9E9E;
    text-decoration: none;
    transition: color 0.3s ease;
}

.psi-sidebar-more:hover {
    color: #319795;
}

/* Responsive sidebar + TOC */
@media (max-width: 1200px) {
    .psi-content-grid,
    .psi-content-grid.has-toc {
        grid-template-columns: 1fr !important;
    }
    .psi-toc {
        display: none;
    }
    .psi-sidebar {
        order: -1;
    }
    .psi-sidebar-inner {
        position: static;
    }
    .psi-sidebar-links {
        display: flex;
        flex-wrap: wrap;
        gap: 6px;
    }
    .psi-sidebar-links li {
        margin: 0;
    }
    .psi-sidebar-links a {
        padding: 8px 14px;
        padding-left: 14px;
    }
    .psi-sidebar-links a::before {
        display: none;
    }
    .psi-sidebar-link-desc {
        display: none;
    }
    .psi-sidebar-more {
        font-size: 0.78rem;
    }
}

/* ====== Tablet (max-width: 1024px) ====== */
@media (max-width: 1024px) {
    .main-header .container,
    .main-header .container-fluid {
        padding-right: 20px !important;
        padding-left: 20px !important;
    }
    .psi-breadcrumbs {
        padding: 8px 20px;
    }
    .container.space-content {
        padding: 20px 0 0 0 !important;
    }
    .main-menu > li > a {
        font-size: 14px !important;
    }
}

/* ====== Mobil (max-width: 767px) ====== */
@media (max-width: 767px) {
    .main-header .container,
    .main-header .container-fluid {
        padding-right: 16px !important;
        padding-left: 16px !important;
    }
    .psi-breadcrumbs {
        padding: 8px 16px;
        font-size: 12px;
        flex-wrap: wrap;
        gap: 4px;
    }
    .psi-breadcrumbs::after {
        height: 80px;
    }
    .container.space-content {
        padding: 16px 0 0 0 !important;
    }
    .psi-content-grid {
        gap: 0 !important;
        padding: 0 16px;
    }
    .psi-sidebar-inner {
        border-radius: 12px;
        padding: 16px;
    }
    .psi-sidebar-title {
        font-size: 0.95rem;
    }
    .psi-sidebar-desc {
        font-size: 0.78rem;
    }
    .main-header {
        transition-duration: 0.4s !important;
    }
    .tx_logo img,
    .tx_logo,
    nav.navbar,
    .main-menu > li > a {
        transition-duration: 0.4s !important;
    }
    .tx_logo img {
        height: 36px !important;
    }
    .psi-compact .tx_logo img {
        height: 28px !important;
    }
}

/* ====== Malý mobil (max-width: 480px) ====== */
@media (max-width: 480px) {
    .main-header .container,
    .main-header .container-fluid {
        padding-right: 12px !important;
        padding-left: 12px !important;
    }
    .psi-breadcrumbs {
        padding: 6px 12px;
        font-size: 11px;
    }
    .psi-content-grid {
        padding: 0 12px;
    }
    .psi-sidebar-inner {
        padding: 12px;
    }
    .entry-content {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
}

/* Menu border-radius */
.main-menu>li>a,
.header-style-eight .main-menu>li>a,
.header-style-four .main-menu>li>a,
.header-style-one .main-menu>li>a,
.header-style-seven .main-menu>li>a,
.header-style-six .main-menu>li>a,
.header-style-two .main-menu>li>a,
#h-style-10 .main-menu>li>a {
    border-radius: 0;
}

/* Theme customizer colors and layout */
body { background-color: #ffffff; }

/* ====== Full-width header layout ====== */

/* Header: full width, no boxed container */
#h-style-3 {
    width: 100% !important;
}

#h-style-3 > .container,
#h-style-3 > .container-fluid {
    max-width: 100% !important;
    width: 100% !important;
    padding: 0 40px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex-wrap: nowrap !important;
}

/* Logo: left, bigger, breathes */
.tx_logo,
.header-style-one .tx_logo,
.header-style-two .tx_logo,
.header-style-four .tx_logo,
.header-style-six .tx_logo,
.header-style-seven .tx_logo,
.header-style-eight .tx_logo {
    padding: 12px 0 12px 0 !important;
    flex-shrink: 0;
    margin-right: 0 !important;
    align-self: center;
}

/* Nav: centered, takes available space */
#h-style-3 nav.navbar {
    flex: 1 1 auto !important;
    display: flex !important;
    justify-content: center !important;
}

/* Menu ul: centered, horizontal */
ul.main-menu,
#main-menu {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    justify-content: center !important;
    align-items: center !important;
}

/* Menu items: inline, no stacking */
.main-menu > li {
    display: flex !important;
    float: none !important;
}

/* Social icons: right, vertikálně na osu s logem a menu */
.tx-nav-right-side-items-desktop {
    flex-shrink: 0 !important;
    margin-left: 0 !important;
    display: flex !important;
    align-items: center !important;
    align-self: center !important;
}

.tx-nav-right-side-items-desktop .social {
    display: flex !important;
    align-items: center !important;
    gap: 6px;
}

.tx-nav-right-side-items-desktop .social li a {
    font-size: 16px;
    color: #1E73BE !important;
    transition: color 0.2s ease, transform 0.2s ease;
}

.tx-nav-right-side-items-desktop .social li a:hover {
    color: #81D742 !important;
    transform: scale(1.15);
}

/* Header container — full-width, fixní padding → menu se nehýbe */
.main-header .container,
.main-header .container-fluid {
    max-width: 100% !important;
    width: 100% !important;
    padding-right: 40px !important;
    padding-bottom: 0 !important;
    padding-left: 40px !important;
}

/* Sticky header background */
.home #h-style-1.sticky-header,
.home #h-style-2.sticky-header,
.home #h-style-3.sticky-header,
.home #h-style-4.sticky-header,
.home #h-style-5.sticky-header,
.home #h-style-6.sticky-header,
.home #h-style-7.sticky-header,
.home #h-style-8.sticky-header,
.home #h-style-9.sticky-header,
.home #h-style-10.sticky-header,
.home #h-style-11.sticky-header {
    background-color: #ffffff;
}

#h-style-1.sticky-header,
#h-style-2.sticky-header,
#h-style-3.sticky-header,
#h-style-4.sticky-header,
#h-style-5.sticky-header,
#h-style-6.sticky-header,
#h-style-7.sticky-header,
#h-style-8.sticky-header,
#h-style-9.sticky-header,
#h-style-10.sticky-header,
#h-style-11.sticky-header {
    background-color: #ffffff;
}

.main-header {
    border-bottom: none !important;
    position: relative;
    height: auto;
    transition: padding 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94),
                box-shadow 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) !important;
}

/* Stín pod headerem — 3D efekt */
.main-header::after {
    content: '';
    position: absolute;
    bottom: -6px;
    left: 0;
    right: 0;
    height: 6px;
    background: linear-gradient(90deg,
        rgba(21,101,192,0.25),
        rgba(46,125,50,0.20) 35%,
        rgba(180,80,160,0.18) 65%,
        rgba(21,101,192,0.25));
    border-radius: 0 0 50% 50%;
    filter: blur(3px);
    pointer-events: none;
    z-index: 10;
}

/* Minimální mezera mezi headerem a obsahem */
#header {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
}

/* Slider na homepage — přitáhnout k headeru */
.home .elementor-1158,
.home #header + .elementor {
    margin-top: -15px !important;
    padding-top: 0 !important;
}

.main-header.sticky-header {
    border-bottom: none !important;
}
.main-header.sticky-header::after {
    opacity: 0.7;
    height: 4px;
    bottom: -4px;
}

/* ====== Sticky/Shrinking header ====== */

/* Transition na headeru i vnitřních prvcích — plynulé OBA směry */
.main-header {
    transition: padding 0.8s cubic-bezier(0.22, 0.61, 0.36, 1),
                box-shadow 0.8s cubic-bezier(0.22, 0.61, 0.36, 1) !important;
}
.tx_logo img {
    transition: height 0.8s cubic-bezier(0.22, 0.61, 0.36, 1) !important;
}
.tx_logo {
    transition: padding 0.8s cubic-bezier(0.22, 0.61, 0.36, 1), line-height 0.8s cubic-bezier(0.22, 0.61, 0.36, 1) !important;
}
nav.navbar {
    transition: min-height 0.8s cubic-bezier(0.22, 0.61, 0.36, 1), padding 0.8s cubic-bezier(0.22, 0.61, 0.36, 1) !important;
}
#top_head {
    transition: transform 0.8s cubic-bezier(0.22, 0.61, 0.36, 1), margin 0.8s cubic-bezier(0.22, 0.61, 0.36, 1) !important;
}

/* Override theme sticky-header — neschovávat logo */
.main-header.sticky-header .tx_logo {
    display: block !important;
}

/* Sticky stav — zmenšená výška (naše vlastní třída) */
.main-header.psi-compact {
    box-shadow: 0 4px 24px rgba(21,101,192,0.10) !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

/* Logo — zmenšené, ale zabírá stejný prostor → menu se nehýbe */
.tx_logo {
    min-width: 240px !important;
}
.psi-compact .tx_logo img {
    height: 38px !important;
}
.psi-compact .tx_logo {
    padding: 0 !important;
    line-height: 1 !important;
}

/* Container padding pryč */
.psi-compact > .container,
.psi-compact > .container-fluid,
.psi-compact#h-style-3 > .container,
.psi-compact#h-style-3 > .container-fluid {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    align-items: center !important;
}

/* Navbar */
.psi-compact nav.navbar {
    min-height: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

/* Menu items — minimální výška */
.main-menu > li > a {
    transition: padding 0.8s cubic-bezier(0.22, 0.61, 0.36, 1),
                line-height 0.8s cubic-bezier(0.22, 0.61, 0.36, 1),
                font-size 0.8s cubic-bezier(0.22, 0.61, 0.36, 1) !important;
}
.psi-compact .main-menu > li > a {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    line-height: 24px !important;
    font-size: 13px !important;
}

/* Social ikony — compact */
.psi-compact #top_head {
    margin-top: 0 !important;
    transform: scale(0.75);
    transform-origin: right center;
}
.psi-compact .tx-nav-right-side-items-desktop {
    align-self: center !important;
}

/* Top header — vertikálně zarovnat k menu */
#top_head {
    margin: 0 60px 0 7px;
    padding: 0 !important;
    display: flex;
    align-items: center;
    align-self: center;
    background: transparent !important;
    border: none !important;
}
#header .top-header-right-area .social li a i { color: #00C5F7; }
#header .social li:hover a i { color: #1E73BE; }
#header .social li { padding: 0 0 0 3px !important; margin-left: 5px; }

/* Search icon */
.search-icon { color: #1E73BE; }

/* Menu colors */
ul.main-menu>li>a,
.navbar-collapse > ul > li > a,
.navbar-collapse > ul > li > ul > li > a,
.navbar-collapse > ul > li > ul > li > ul > li > a,
.navbar-collapse > ul > li > span > i,
.navbar-collapse > ul > li > ul > li > span > i,
.mb-dropdown-icon:before,
.tx-res-menu li a {
    color: #1E73BE;
}

ul.main-menu>li>a,
.navbar-collapse > ul > li > a,
.navbar-collapse > ul > li > ul > li > a,
.navbar-collapse > ul > li > ul > li > ul > li > a,
.navbar-collapse > ul > li > span > i,
.navbar-collapse > ul > li > ul > li > span > i,
.mb-dropdown-icon:before,
.tx-res-menu li a {
    border-color: #FFFFFF;
}

/* Home menu colors */
.home ul.main-menu>li>a,
.home .navbar-collapse > ul > li > a,
.home .navbar-collapse > ul > li > ul > li > a,
.home .navbar-collapse > ul > li > ul > li > ul > li > a,
.home .navbar-collapse > ul > li > span > i,
.home .navbar-collapse > ul > li > ul > li > span > i,
.home .mb-dropdown-icon:before,
.tx-res-menu li a {
    color: #1E73BE;
}

.home ul.main-menu>li>a,
.home .navbar-collapse > ul > li > a,
.home .navbar-collapse > ul > li > ul > li > a,
.home .navbar-collapse > ul > li > ul > li > ul > li > a,
.home .navbar-collapse > ul > li > span > i,
.home .navbar-collapse > ul > li > ul > li > span > i,
.home .mb-dropdown-icon:before,
.tx-res-menu li a {
    border-color: #1E73BE;
}

/* Menu hover */
ul.main-menu>li>a:hover,
ul.main-menu>li>a:focus,
ul.main-menu>li.menu-item-has-children a:hover,
ul.main-menu>li.menu-item-has-children a:focus,
.tx-mega-menu .mega-menu-item .depth0 li .depth1.standard.sub-menu li a:hover {
    color: #2DE520;
}

/* Active menu item */
ul.main-menu>li.current-menu-item > a,
ul.main-menu>li.current-page-ancestor > a,
ul.main-menu>li.current-menu-ancestor > a,
ul.main-menu>li.current-menu-parent > a,
ul.main-menu>li.current_page_ancestor > a,
ul.main-menu.active>a:hover,
a.mega-menu-title.active {
    color: #81D742;
}

.main-menu>li:hover a:before { color: #23E2EF; }

/* Menu font + spacing */
.main-menu>li>a,
.navbar-collapse > ul > li > a {
    font-family: Poppins;
    text-transform: uppercase;
    font-weight: 500;
    font-style: normal;
    font-size: 14px;
    letter-spacing: 0.5px;
    padding: 20px 16px !important;
}

/* Submenu font */
.main-menu>li>ul>li>a,
.main-menu>li>ul>li>ul>li>a,
.main-menu>li>ul>li>ul>li>ul>li>a,
.main-menu>li>ul>li>ul>li>ul>li>ul>li>a,
.tx-mega-menu .mega-menu-item .depth0 li .depth1.standard.sub-menu li a,
.tx-mega-menu .mega-menu-item .depth0 li .depth1 li a,
.navbar-collapse > ul > li > ul > li > a,
.navbar-collapse > ul > li > ul > li > ul > li > a,
.navbar-collapse > ul > li > ul > li > ul > li > ul > li > a,
.navbar-collapse > ul > li > ul > li > ul > li > ul > li > ul > li > a {
    font-family: Poppins;
    text-transform: uppercase;
    font-weight: 400;
    font-style: normal;
    font-size: 15px;
}

/* Mobile menu */
.tx-res-menu-txt { text-align: right; }
.mobile-nav-toggle i { padding-left: 20px; }

/* Side menu */
#side-menu-wrapper { background-color: #1E73BE; }

/* Blog post styles */
.single-post .entry-title { color: #81D742; }
.single-post .entry-content p { color: #000000; }
.related-posts-title { background-color: #000000; }
.related-posts-item .overlay a,
.related-posts-item .entry-title { color: #1E73BE; }
.related-posts-item .overlay a:hover,
.related-posts-item:hover .entry-title { color: #DD3333; }

/* Team */
.team-single-left img {
    border-top: 0px solid #dfdfdf;
    border-bottom: 0px solid #dfdfdf;
    border-left: 0px solid #dfdfdf;
    border-right: 0px solid #dfdfdf;
}

/* Social hover */
#header .social li a:hover i { color: #21ADD1; }
