/* =====================================================================
   COUNTRY ŠUŇAVA 2026 — vlastné doplnky
   - jemné „macOS" tiene a animácie obrázkov
   - dôkladný responzívny dizajn (tablet + mobil)
   Tento súbor sa načítava AKO POSLEDNÝ, aby mal prednosť.
   ===================================================================== */

/* ---------- 1. macOS tiene + animácie obrázkov ---------- */

/* spoločný „mac okno" tieň + jemné zaoblenie pre obsahové fotky */
.de-image-text img,
.de-event-item .d-image img,
.de-image-hover img,
#section-gallery .carousel-inner img,
.gallery-mac img,
.de-image-mac img,
.single-post-img img,
.about-img img {
    border-radius: 14px;
    box-shadow:
        0 2px 6px rgba(0, 0, 0, .28),
        0 14px 40px -8px rgba(0, 0, 0, .55),
        0 28px 64px -12px rgba(0, 0, 0, .45);
    transition: transform .55s cubic-bezier(.2, .7, .2, 1),
                box-shadow .55s cubic-bezier(.2, .7, .2, 1),
                filter .55s ease;
    will-change: transform;
    backface-visibility: hidden;
}

/* zdvih + výraznejší tieň pri prejdení myšou — ako okno v macOS */
.de-image-text:hover img,
.de-event-item:hover .d-image img,
.de-image-hover:hover img,
.gallery-mac a:hover img,
.de-image-mac:hover img {
    transform: translateY(-10px) scale(1.015);
    box-shadow:
        0 4px 10px rgba(0, 0, 0, .30),
        0 26px 60px -10px rgba(0, 0, 0, .60),
        0 44px 90px -16px rgba(0, 0, 0, .50);
}

/* hero/slider a pod-hlavičky necháme bez zaoblenia, ale s hĺbkou */
#de-carousel .carousel-item,
#subheader {
    box-shadow: inset 0 -120px 160px -60px rgba(0, 0, 0, .85);
}

/* pomalé „dýchanie" loga / featured fotiek */
@keyframes cs-float {
    0%   { transform: translateY(0); }
    50%  { transform: translateY(-9px); }
    100% { transform: translateY(0); }
}
.de-image-text.cs-float img {
    animation: cs-float 6s ease-in-out infinite;
}

/* jemné priblíženie pozadia v galérii pri carouseli */
#section-gallery .carousel-item img {
    transition: transform 6s ease;
}
#section-gallery .carousel-item.active img {
    transform: scale(1.04);
}

/* karty s programom / cenníkom dostanú tiež mac tieň */
.pricing-s1,
.tab_single_content,
.de-card-mac {
    border-radius: 16px;
    box-shadow:
        0 2px 6px rgba(0, 0, 0, .25),
        0 18px 50px -12px rgba(0, 0, 0, .55);
    transition: transform .45s ease, box-shadow .45s ease;
}
.pricing-s1:hover {
    transform: translateY(-8px);
    box-shadow:
        0 4px 10px rgba(0, 0, 0, .30),
        0 28px 70px -14px rgba(0, 0, 0, .62);
}

/* plynulé objavenie obrázkov po načítaní */
@keyframes cs-reveal {
    from { opacity: 0; transform: translateY(24px) scale(.985); }
    to   { opacity: 1; transform: none; }
}
.cs-reveal {
    animation: cs-reveal .9s cubic-bezier(.2, .7, .2, 1) both;
}

/* ---------- 2. Drobné štýlové doladenia ---------- */

/* odznak „obľúbené" / dni v programe nech sú čitateľné */
.cs-daybadge {
    display: inline-block;
    padding: 4px 14px;
    border-radius: 30px;
    background: var(--primary-color);
    color: #fff;
    font-family: var(--body-font, 'Open Sans', sans-serif);
    font-weight: 700;
    letter-spacing: 1px;
    font-size: 13px;
    text-transform: uppercase;
}

/* lepšia čitateľnosť dlhších odstavcov */
.cs-lead {
    font-size: 1.15rem;
    line-height: 1.8;
    opacity: .92;
}
.cs-prose p { line-height: 1.9; opacity: .9; margin-bottom: 1.2rem; }

/* mapa v päte/kontakte so zaoblením a tieňom */
.cs-map iframe {
    width: 100%;
    border: 0;
    border-radius: 16px;
    box-shadow: 0 18px 50px -12px rgba(0, 0, 0, .55);
    filter: grayscale(.25);
    transition: filter .5s ease;
}
.cs-map iframe:hover { filter: grayscale(0); }

/* ---------- 3. RESPONZÍVNY DIZAJN — tablet + mobil ---------- */

/* ----- veľký tablet / malý desktop ----- */
@media (max-width: 1199px) {
    .de_tab.tab_style_4 .de_nav li { padding: 0 14px; }
    section { padding: 80px 0; }
}

/* ----- tablet (na výšku aj šírku) ----- */
@media (max-width: 991px) {
    h1 { font-size: 42px; line-height: 1.15; }
    h2 { font-size: 30px; }
    .wm { font-size: 60px; }

    section { padding: 64px 0; }

    /* hero text nech sa zmestí */
    #de-carousel .carousel-item h1 { font-size: 38px; }
    #de-carousel .carousel-item .lead { font-size: 16px; }
    #de-carousel { min-height: 80vh; }
    #de-carousel .carousel-item { min-height: 80vh; }

    /* program: záložky dní nech zalomia pekne do mriežky */
    .de_tab.tab_style_4 .de_nav { display: flex; flex-wrap: wrap; justify-content: center; }
    .de_tab.tab_style_4 .de_nav li {
        flex: 0 0 auto; margin: 6px; padding: 10px 18px;
        border-radius: 12px;
    }
    .de_tab.tab_style_4 .de_nav li h3 { font-size: 18px; }
    .de_tab.tab_style_4 .de_nav li h4 { font-size: 13px; }

    /* featured / cenník karty: medzery */
    .de-image-text { margin-bottom: 26px; }
    .pricing-s1 { margin-bottom: 30px; }

    /* päta: poriadne medzery medzi stĺpcami */
    footer .col-md-3 { margin-bottom: 36px; }
}

/* ----- veľký mobil / malý tablet ----- */
@media (max-width: 767px) {
    h1 { font-size: 34px; }
    h2 { font-size: 26px; }
    .wm { display: none; } /* dekoratívny vodoznak na mobile preč — uvoľní miesto */

    section { padding: 50px 0; }
    .container { padding-left: 22px; padding-right: 22px; }

    #de-carousel .carousel-item h1 { font-size: 30px; }
    #de-carousel .carousel-item .lead { font-size: 15px; line-height: 1.6; }
    #de-carousel .carousel-indicators { bottom: 6px; }

    /* dátum / miesto pod hero */
    #section-date h2 { font-size: 30px; }
    #section-date h3 { font-size: 16px; }

    /* program: jeden stĺpec, väčšie klikacie plochy */
    .de_tab.tab_style_4 .de_nav { gap: 4px; }
    .de_tab.tab_style_4 .de_nav li { flex: 1 1 44%; text-align: center; }
    .list-boxed-s1 li { display: block; width: 100%; text-align: center; }
    .list-boxed-s1 li h3 { font-size: 18px; }
    .tab_single_content { padding: 26px 16px; }

    /* galéria a featured: jeden stĺpec na celú šírku */
    #section-gallery .col-md-8 { padding: 0; }
    .de-image-hover img { width: 100%; }

    /* cenník: plná šírka, nech nie sú „zlepené" */
    .pricing-s1 { max-width: 420px; margin-left: auto; margin-right: auto; }

    /* odpočet: menšie číslice, nech sa zmestia */
    #defaultCountdown .countdown-section { padding: 0 6px; }
    #defaultCountdown .countdown-amount { font-size: 30px !important; }
    #defaultCountdown .countdown-period { font-size: 12px !important; }

    /* zoznam interpretov */
    .list-inline-style-1 li { display: inline-block; margin: 4px 8px; font-size: 15px; }

    /* päta vycentrovaná */
    footer .widget address.s1 span,
    footer .widget { text-align: left; }
    .subfooter .de-flex { flex-direction: column; gap: 16px; text-align: center; }
    .subfooter .social-icons { justify-content: center; }

    /* mac tiene na mobile o čosi menšie, nech nie sú ťažké */
    .de-image-text img,
    .de-event-item .d-image img,
    .de-image-hover img {
        border-radius: 12px;
        box-shadow: 0 2px 6px rgba(0,0,0,.25), 0 12px 28px -8px rgba(0,0,0,.5);
    }

    /* formuláre: polia pod sebou s medzerou */
    #contact_form .col-md-6 { margin-bottom: 6px; }
    .form-border { padding: 22px 16px; }
}

/* ----- malý mobil ----- */
@media (max-width: 480px) {
    h1 { font-size: 28px; }
    #de-carousel .carousel-item h1 { font-size: 25px; }
    .btn-main { padding: 10px 22px; font-size: 13px; }
    .de_tab.tab_style_4 .de_nav li { flex: 1 1 100%; }
    #section-date h2 { font-size: 24px; }
    .pricing-s1 .price .m { font-size: 40px; }
    .subfooter .copy { display: block; margin-top: 10px; font-size: 12px; }
}

/* veľmi nízke zariadenia na šírku — nech hero nepreteká */
@media (max-height: 520px) and (orientation: landscape) {
    #de-carousel, #de-carousel .carousel-item { min-height: 460px; }
}

/* obrázky nech nikdy nepretečú kontajner */
img { max-width: 100%; height: auto; }

/* dekoratívny vodoznak nech neprekrýva obsah (galéria, tlačidlá) */
.wm { pointer-events: none; }
#section-gallery .container > .row { position: relative; }
#section-gallery .container > .row:not(:first-child) { z-index: 2; }
#section-gallery .carousel { position: relative; z-index: 2; }
#section-gallery .row:last-child .btn-main { position: relative; z-index: 3; }
/* tlačidlo „Celá galéria" jasne pod náhľadmi (náhľady ťahá hore záporný margin) */
#section-gallery .cs-gallery-cta { margin-top: 104px; position: relative; z-index: 4; }
@media (max-width: 767px) { #section-gallery .cs-gallery-cta { margin-top: 70px; } }

/* =====================================================================
   ZAOBLENÉ HRANY — všetky tlačidlá aj obrázky
   ===================================================================== */
.btn-main,
a.btn-main,
.btn,
a.btn,
button.btn-main,
input[type="submit"],
input[type="button"],
.btn-line,
a.btn-line,
#send_message,
.pagination .page-link,
.menu_side_area .btn-main {
    border-radius: 30px !important;
    overflow: hidden;
}

/* stránkovanie – guľaté označenie čísel */
.pagination { gap: 8px; align-items: center; }
.pagination .page-link {
    min-width: 46px; height: 46px; padding: 0 18px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 50% !important;
    border: 1px solid rgba(255,255,255,.2);
}
.pagination .page-item.active .page-link {
    background: var(--primary-color) !important;
    color: #1c1746 !important; border-color: var(--primary-color) !important;
    width: 46px; height: 46px; padding: 0;
}

/* obrázky – zaoblené rohy (hero/pozadia používajú data-bgimage, tých sa to netýka) */
img { border-radius: 14px; }
.carousel-inner img,
#section-gallery .carousel-item img,
.single-post-img img { border-radius: 16px; }
/* malé náhľady v galérii a avatary nech sú tiež zaoblené */
.carousel-indicators img { border-radius: 8px; }
.avatar img { border-radius: 50%; }
/* vstupný formulár a polia nech ladia */
.form-control { border-radius: 10px !important; }

/* =====================================================================
   LOGÁ PARTNEROV — dlaždice s logom (jednotné kovové pozadie)
   ===================================================================== */
.cs-plogo {
    background: #c3c5c7;
    border-radius: 14px;
    padding: 12px;
    height: 104px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 10px 26px -10px rgba(0, 0, 0, .55);
    transition: transform .4s ease, box-shadow .4s ease;
    overflow: hidden;
}
.cs-plogo:hover {
    transform: translateY(-6px);
    box-shadow: 0 18px 40px -12px rgba(0, 0, 0, .65);
}
.cs-plogo img {
    max-height: 80px;
    max-width: 92%;
    width: auto;
    border-radius: 4px;
    object-fit: contain;
}
.cs-partner-name {
    margin-top: 12px;
    margin-bottom: 4px;
    font-size: 14px;
    font-weight: 700;
    color: #fff;
    letter-spacing: .3px;
}
.cs-partner-role { font-size: 12px; color: var(--primary-color); }

/* stena lôg partnerov — jeden čistý obrázok */
.cs-logowall { border-radius: 16px; max-width: 760px; }
.cs-logowall img { border-radius: 16px; }

/* =====================================================================
   SPRIEVODNÝ PROGRAM — pri prejdení myšou sa karta znova „rozanimuje"
   (rovnako ako pri prvom načítaní)
   ===================================================================== */
#section-program-extra .de-card-mac {
    transition: transform .4s ease, box-shadow .4s ease;
    cursor: default;
}
#section-program-extra .de-card-mac:hover {
    animation-name: flipInY;
    animation-duration: .9s;
    animation-timing-function: ease;
    animation-fill-mode: both;
    box-shadow: 0 18px 44px -12px rgba(0, 0, 0, .6);
}
#section-program-extra .de-card-mac:hover i { color: #fff; }

/* =====================================================================
   PROGRAM — text musí byť dobre čitateľný nad fotkami
   ===================================================================== */
#section-schedule .tab_single_content { position: relative; overflow: hidden; }
#section-schedule .tab_single_content::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(rgba(18, 14, 48, .86), rgba(18, 14, 48, .9));
    z-index: 0;
}
#section-schedule .tab_single_content .row,
#section-schedule .tab_single_content .col-md-12 { position: relative; z-index: 1; }
#section-schedule .list-boxed-s1 h3,
#section-schedule .tab_single_content .cs-lead { text-shadow: 0 2px 12px rgba(0, 0, 0, .7); }
#section-schedule .list-boxed-s1 li {
    background: rgba(255, 255, 255, .06);
    border: 1px solid rgba(255, 255, 255, .14);
    border-radius: 14px;
    backdrop-filter: blur(2px);
    display: flex !important;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 20px 28px;
}
/* čas (template span) – z hover-pruhu spravíme čitateľný odznak nad menom */
#section-schedule .list-boxed-s1 li span {
    position: static;
    width: auto;
    height: auto;
    background: transparent;
    display: inline-block;
    order: -1;
    color: var(--primary-color);
    font-weight: 700;
    font-size: 14px;
    letter-spacing: 3px;
}
#section-schedule .list-boxed-s1 li:hover span { width: auto; }
#section-schedule .list-boxed-s1 h3 { margin: 0; }
#section-schedule .list-boxed-s1 .cs-fav { margin-left: 0; }

/* plynulé rolovanie ku kotvám v menu */
html { scroll-behavior: smooth; }

/* =====================================================================
   NOVÉ FUNKCIE — komponenty (mobile-first)
   ===================================================================== */

/* --- obľúbené (hviezdička v programe) --- */
.cs-fav {
    background: transparent; border: 0; color: var(--primary-color);
    font-size: 18px; line-height: 1; cursor: pointer; margin-left: 12px;
    padding: 6px; border-radius: 50%; transition: transform .2s ease, color .2s ease;
    min-width: 40px; min-height: 40px;
}
.cs-fav:hover { transform: scale(1.18); }
.cs-fav.is-on { color: #ffd166; }

/* --- widget Práve hrá / Najbližšie --- */
#cs-live {
    display: flex; flex-wrap: wrap; align-items: center; gap: 8px;
    justify-content: center; text-align: center;
    background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.14);
    border-radius: 40px; padding: 10px 18px; margin: 0 auto 6px; max-width: 760px;
    font-size: 15px; color: #fff;
}
#cs-live strong { color: var(--primary-color); }
.cs-live-tag {
    background: var(--primary-color); color: #1c1746; font-weight: 800;
    font-size: 11px; letter-spacing: .5px; text-transform: uppercase;
    padding: 3px 10px; border-radius: 20px;
}
.cs-live-now { background: #ffd166; }
.cs-live-sep { opacity: .5; }
.cs-live-next { opacity: .85; }

/* --- tlačidlá „Pridať do kalendára" --- */
.cs-cal-bar { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; margin-top: 24px; }
.cs-cal-bar .btn-main { font-size: 12px; padding: 9px 16px; }

/* --- lepkavé CTA na mobile --- */
.cs-sticky-cta { display: none; }
@media (max-width: 991px) {
    .cs-sticky-cta {
        display: block; position: fixed; left: 0; right: 0; bottom: 0; z-index: 1500;
        padding: 9px 12px calc(9px + env(safe-area-inset-bottom));
        background: rgba(28,23,70,.96); backdrop-filter: blur(6px);
        border-top: 1px solid rgba(255,255,255,.12); box-shadow: 0 -8px 24px rgba(0,0,0,.4);
    }
    .cs-sticky-cta a {
        display: flex; align-items: center; justify-content: center; gap: 8px;
        width: 100%; background: #c3c5c7; color: #1c1746; font-weight: 800;
        text-transform: uppercase; letter-spacing: .5px; text-decoration: none;
        padding: 14px; border-radius: 30px; font-size: 15px;
    }
    /* aby lepkavé CTA neprekrylo pätu */
    footer { padding-bottom: 76px; }
}

/* --- detail interpreta (modal) --- */
.cs-modal { position: fixed; inset: 0; z-index: 2000; display: none; }
.cs-modal.open { display: block; }
.cs-modal-bg { position: absolute; inset: 0; background: rgba(10,8,30,.72); backdrop-filter: blur(3px); }
.cs-modal-box {
    position: relative; z-index: 1; background: #2b2566; color: #fff;
    max-width: 520px; width: 92%; margin: 14vh auto 0; padding: 30px 26px;
    border-radius: 18px; box-shadow: 0 30px 80px rgba(0,0,0,.6);
    animation: cs-reveal .35s ease both;
}
.cs-modal-title { margin: 0 0 6px; }
.cs-modal-meta { color: var(--primary-color); font-size: 14px; margin-bottom: 14px; }
.cs-modal-text { opacity: .9; line-height: 1.7; }
.cs-modal-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 20px; }
.cs-modal-x {
    position: absolute; top: 10px; right: 14px; background: transparent; border: 0;
    color: #fff; font-size: 30px; line-height: 1; cursor: pointer; opacity: .7;
}
.cs-modal-x:hover { opacity: 1; }

/* --- tlačidlo prepínača témy --- */
.cs-theme-btn {
    background: transparent; border: 1px solid rgba(255,255,255,.22); color: #fff;
    width: 38px; height: 38px; border-radius: 10px; cursor: pointer;
    font-size: 16px; display: inline-flex; align-items: center; justify-content: center;
    transition: background .2s ease, color .2s ease;
}
.cs-theme-btn:hover { background: #c3c5c7; color: #1c1746; border-color: #c3c5c7; }

/* =====================================================================
   SVETLÁ TÉMA — flip obsahových sekcií (hero/pätu necháme tmavé)
   ===================================================================== */
body.cs-light { background: #eef2f8; }
.cs-light.dark-scheme section:not([data-bgimage]),
.cs-light.dj-home.dark-scheme section:not([data-bgimage]) { background-color: #eef2f8 !important; }
.cs-light section:not([data-bgimage]) h1,
.cs-light section:not([data-bgimage]) h2,
.cs-light section:not([data-bgimage]) h3,
.cs-light section:not([data-bgimage]) h4,
.cs-light section:not([data-bgimage]) h5,
.cs-light section:not([data-bgimage]) h6,
.cs-light section:not([data-bgimage]) p,
.cs-light section:not([data-bgimage]) li,
.cs-light section:not([data-bgimage]) small,
.cs-light section:not([data-bgimage]) strong,
.cs-light section:not([data-bgimage]) .cs-prose p { color: #241f54; }
/* akcent na svetlom musí mať dosť kontrastu */
.cs-light .id-color { color: #2f6f9e !important; }
.cs-light section:not([data-bgimage]) .wm { color: #241f54; opacity: .06; }
/* karty na bielo */
.cs-light .de-card-mac { background: #ffffff; border: 1px solid rgba(36,31,84,.1); }
.cs-light .cs-plan-item { background: #ffffff; border: 1px solid rgba(36,31,84,.12); }
.cs-light .cs-plan-item span { color: #241f54 !important; }
.cs-light .de_tab_content .tab_single_content { box-shadow: 0 18px 50px -16px rgba(36,31,84,.3); }
.cs-light .de-card-mac h4, .cs-light .de-card-mac h5, .cs-light .de-card-mac h6,
.cs-light .de-card-mac p, .cs-light .de-card-mac small { color: #241f54; }
/* zoznam interpretov, widget */
.cs-light .list-inline-style-1 li { color: #241f54; }
.cs-light #cs-live { background: rgba(36,31,84,.06); border-color: rgba(36,31,84,.16); color: #241f54; }
.cs-light #cs-live strong { color: #2f6f9e; }
.cs-light .cs-faq-q { color: #241f54; }
.cs-light .cs-faq-item { background: #fff; border-color: rgba(36,31,84,.12); }
.cs-light .cs-faq-a p { color: #241f54; }
.cs-light .pricing-s1 { background: #fff; border: 1px solid rgba(36,31,84,.1); }
.cs-light .pricing-s1 .top h2 { color: #241f54; }
.cs-light .small-border { opacity: .9; }
/* dátumový pruh ostáva biely (už je) — text tmavý */
.cs-light .cs-band-white { box-shadow: 0 14px 40px -16px rgba(36,31,84,.35); }
/* hlavička vo svetlej téme = svetlý pruh s tmavým menu (vždy, aby bolo vidieť) */
.cs-light header.transparent,
.cs-light header.smaller,
.cs-light header.sticky {
    background: rgba(238,242,248,.96) !important;
    box-shadow: 0 4px 22px rgba(36,31,84,.10);
}
.cs-light #mainmenu > li > a { color: #241f54 !important; }
.cs-light #mainmenu > li > a:hover { color: #2f6f9e !important; }
body.cs-light .cs-logo .cs-logo-1 { color: #2f6f9e !important; }
body.cs-light .cs-logo .cs-logo-2 { color: #241f54 !important; }
.cs-light .cs-lang button,
.cs-light .cs-theme-btn { color: #241f54; border-color: rgba(36,31,84,.28); }
.cs-light .cs-lang button.is-on { background: #241f54; color: #fff; border-color: #241f54; }
/* hamburger na mobile nech je tmavý */
.cs-light #menu-btn::before,
.cs-light #menu-btn::after,
.cs-light #menu-btn span { background: #241f54 !important; color: #241f54 !important; }
/* rozbalené mobilné menu na svetlom pozadí */
.cs-light #mainmenu li li a { color: #241f54 !important; }
/* plagát/galéria/partneri – stena lôg ostáva ako je (na svetlom funguje) */

/* DÔLEŽITÉ: prvky na tmavom podklade musia ostať svetlé aj vo svetlej téme */
/* 1) program nad fotkou (tab content má tmavé prekrytie) */
.cs-light #section-schedule .tab_single_content h1,
.cs-light #section-schedule .tab_single_content h2,
.cs-light #section-schedule .tab_single_content h3,
.cs-light #section-schedule .tab_single_content h4,
.cs-light #section-schedule .tab_single_content p,
.cs-light #section-schedule .tab_single_content li,
.cs-light #section-schedule .tab_single_content small { color: #ffffff !important; }
.cs-light #section-schedule .list-boxed-s1 li span { color: var(--primary-color) !important; }
/* 2) záložky dní (tmavé pozadie) */
.cs-light #section-schedule .de_nav li h3,
.cs-light #section-schedule .de_nav li h4 { color: #ffffff !important; }
.cs-light #section-schedule .de_nav li.active { background: var(--primary-color) !important; }
.cs-light #section-schedule .de_nav li.active h3,
.cs-light #section-schedule .de_nav li.active h4 { color: #1c1746 !important; }
/* 3) galéria a podstránkové hlavičky na fotke */
.cs-light .dih-title { color: #ffffff !important; }
.cs-light #subheader h1,
.cs-light #subheader p,
.cs-light #de-carousel h1,
.cs-light #de-carousel p { color: #ffffff !important; }
/* 4) biele podklady (dátumový pruh, štítky mien) – tmavý text */
.cs-light .cs-band-white h2,
.cs-light .cs-band-white h3,
.cs-light .cs-band-white p { color: #241f54 !important; }
.cs-light .de-image-text.s2 h3 { color: #241f54 !important; }
/* 5) tlačidlá majú vždy tmavý text na striebornej */
.cs-light a.btn-main,
.cs-light .btn-main { color: #1c1746 !important; }
/* 6) zoznam interpretov klikateľný – tmavý na svetlom */
.cs-light #section-artists .list-inline-style-1 li { color: #241f54 !important; }
/* 7) komponenty so svetlým textom v šablóne (mimo päty) – stmaviť */
.cs-light #content .pricing-s1 .bottom li,
.cs-light #content .pricing-s1 .bottom li s,
.cs-light #content .pricing-s1 .top h2,
.cs-light #content .de-event-item .d-text h4,
.cs-light #content .de-event-item .d-text p,
.cs-light #content .blog-read,
.cs-light #content .post-text,
.cs-light #content .post-text p,
.cs-light #content blockquote,
.cs-light #content #blog-comment h4,
.cs-light #content .comment,
.cs-light #content .c_name,
.cs-light #content .widget,
.cs-light #content .widget h3,
.cs-light #content .widget h4,
.cs-light #content .widget p,
.cs-light #content .widget li a,
.cs-light #content .widget_tags li a,
.cs-light #content address,
.cs-light #content address span,
.cs-light #content address a,
.cs-light #content label,
.cs-light #content .cs-faq-q,
.cs-light #content .cs-plan-item span { color: #241f54 !important; }
/* formulárové polia vo svetlej téme */
.cs-light #content .form-control { background: #fff; color: #241f54; border: 1px solid rgba(36,31,84,.2); }
.cs-light #content .form-control::placeholder { color: rgba(36,31,84,.5); }
/* karty plánu/sprievodného programu */
.cs-light #content .de-card-mac i,
.cs-light #content .cs-plan-item i { color: #2f6f9e; }
/* odpočet (countdown) – číslice tmavé na svetlom */
.cs-light #content #defaultCountdown,
.cs-light #content .countdown-amount,
.cs-light #content .countdown-period { color: #241f54 !important; }
.cs-light #content .countdown-period { opacity: .65; }
/* stránkovanie a meta blogu vo svetlej téme */
.cs-light #content .pagination .page-link { color: #241f54 !important; background: #fff; border-color: rgba(36,31,84,.15); }
.cs-light #content .pagination .page-item.disabled .page-link { color: rgba(36,31,84,.4) !important; }
.cs-light #content .post-date,
.cs-light #content .post-like,
.cs-light #content .post-comment,
.cs-light #content .c_reply a,
.cs-light #content .c_date { color: #241f54 !important; }
/* titulky galérie sa zobrazujú len pri hover nad tmavým prekrytím — necháme biele */
.cs-light .de-image-hover .dih-title { color: #ffffff !important; }

/* --- prepínač jazykov + CTA v jednom riadku --- */
.menu_side_area { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; justify-content: flex-end; }
.cs-lang { display: flex; gap: 3px; margin: 0; }

/* --- hlavička: všetko na šírku, zvislo vycentrované, menu v jednom riadku --- */
@media (min-width: 992px) {
    header .container { max-width: 96%; width: 96%; }
    header .de-flex { align-items: center !important; flex-wrap: nowrap; }
    header .de-flex > .de-flex-col { display: flex; align-items: center; }
    .header-col-mid { flex: 1 1 auto; }
    #mainmenu { display: flex; flex-wrap: nowrap; justify-content: center; align-items: center; gap: 0; }
    #mainmenu > li > a { padding: 10px 11px !important; font-size: 13.5px; white-space: nowrap; }
    .menu_side_area { flex-wrap: nowrap; }
    .cs-lang button { padding: 5px 7px; min-width: 30px; }
    /* CTA má vždy rovnakú veľkosť ako v slovenčine (174 px), nech sa pri jazykoch nemení */
    .menu_side_area .btn-main { min-width: 174px; justify-content: center; white-space: nowrap; }
    .menu_side_area .btn-main span { white-space: nowrap; }
}
.cs-lang button {
    background: transparent; border: 1px solid rgba(255,255,255,.22); color: #fff;
    font-size: 11px; font-weight: 700; letter-spacing: .5px; padding: 5px 8px;
    border-radius: 8px; cursor: pointer; min-width: 34px; min-height: 32px;
}
.cs-lang button.is-on { background: #c3c5c7; color: #1c1746; border-color: #c3c5c7; }
/* jazyk + téma ostávajú VIDITEĽNÉ v mobilnej lište (kompaktné, jeden riadok) */
.cs-menu-tools { display: none !important; } /* duplikát v menu nepoužívame */
@media (max-width: 991px) {
    header .de-flex { align-items: center !important; flex-wrap: nowrap; }
    header .de-flex > .de-flex-col:last-child { flex: 0 0 auto; min-width: 0; }
    .menu_side_area { display: flex !important; align-items: center; gap: 5px; flex-wrap: nowrap !important; white-space: nowrap; flex: 0 0 auto; }
    header .menu_side_area > a.btn-main { display: none !important; } /* máme lepkavé „Kúpiť" dole */
    header .menu_side_area .cs-lang { display: flex !important; margin: 0; gap: 2px; flex: 0 0 auto; flex-wrap: nowrap !important; }
    header .menu_side_area .cs-lang button { min-width: 23px; min-height: 28px; padding: 2px 1px; font-size: 9px; border-radius: 6px; }
    header .menu_side_area .cs-theme-btn { display: inline-flex !important; width: 30px; height: 30px; font-size: 13px; border-radius: 8px; }
    #menu-btn { display: block; position: static; float: none; margin-left: 4px; }
    /* kompaktnejšie logo, aby sa všetko zmestilo */
    .cs-logo .cs-logo-1 { font-size: 9px; letter-spacing: 4px; }
    .cs-logo .cs-logo-2 { font-size: 21px; }
}
@media (max-width: 360px) {
    header .menu_side_area .cs-lang button { min-width: 20px; font-size: 8px; }
}

/* --- FAQ akordeón --- */
.cs-faq { max-width: 820px; margin: 0 auto; }
.cs-faq-item { border: 1px solid rgba(255,255,255,.12); border-radius: 14px; margin-bottom: 12px; overflow: hidden; background: rgba(255,255,255,.03); }
.cs-faq-q {
    display: flex; justify-content: space-between; align-items: center; gap: 14px;
    padding: 18px 20px; cursor: pointer; font-weight: 700; font-size: 17px; color: #fff;
}
.cs-faq-q::after { content: "+"; color: var(--primary-color); font-size: 24px; transition: transform .3s ease; }
.cs-faq-item.open .cs-faq-q::after { transform: rotate(45deg); }
.cs-faq-a { max-height: 0; overflow: hidden; transition: max-height .35s ease; }
.cs-faq-item.open .cs-faq-a { max-height: 400px; }
.cs-faq-a p { padding: 0 20px 18px; margin: 0; opacity: .9; line-height: 1.7; }

/* --- mapa areálu (plán) --- */
.cs-plan { position: relative; border-radius: 18px; overflow: hidden; box-shadow: 0 18px 50px -14px rgba(0,0,0,.55); }
.cs-plan-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.cs-plan-item {
    background: #2e2768; border: 1px solid rgba(255,255,255,.1); border-radius: 14px;
    padding: 18px 12px; text-align: center;
}
.cs-plan-item i { color: var(--primary-color); font-size: 22px; }
.cs-plan-item span { display: block; margin-top: 8px; font-size: 13px; color: #fff; }
@media (max-width: 575px) { .cs-plan-grid { grid-template-columns: repeat(2, 1fr); } }

/* =====================================================================
   MOBIL — dôkladné doladenie (stránka bude prevažne mobilná)
   ===================================================================== */
@media (max-width: 991px) {
    /* menu na celú šírku, väčšie klikacie plochy */
    #mainmenu li a { padding: 14px 10px !important; font-size: 16px; }
    /* POZN.: ovládače v lište musia byť v RIADKU (nie stĺpec) — viď blok vyššie */
    /* program: hviezdička a čas nech sa zmestia */
    #section-schedule .list-boxed-s1 li { display: flex; align-items: center; justify-content: center; gap: 10px; flex-wrap: wrap; }
    /* modal vyššie, väčší */
    .cs-modal-box { margin-top: 9vh; padding: 26px 20px; }
    #cs-live { font-size: 14px; padding: 9px 14px; }
}
@media (max-width: 575px) {
    .container { padding-left: 18px; padding-right: 18px; }
    h1.ultra-big { font-size: 18vw; }
    .cs-cal-bar .btn-main { flex: 1 1 100%; }
    .cs-modal-actions .btn-main { flex: 1 1 100%; text-align: center; }
    /* tap targety min 44px */
    a.btn-main, .btn-main { min-height: 46px; display: inline-flex; align-items: center; justify-content: center; }
    /* obrázky galérie na celú šírku s medzerou */
    #gallery .item { margin-bottom: 16px; }
}

/* cenníkové karty — rovnaká výška a zvislé zarovnanie riadkov */
.pricing-s1 { height: 100%; display: flex; flex-direction: column; }
.pricing-s1 .top {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}
.pricing-s1 .mid { display: flex; align-items: center; justify-content: center; }
.pricing-s1 .bottom { flex: 1 1 auto; }
/* na tabletoch a väčších: pevná výška hlavičky → cenové pásy presne zarovnané */
@media (min-width: 768px) {
    .pricing-s1 .top { height: 150px; }
    .pricing-s1 .mid { height: 132px; }
}

/* textové logo (wordmark) — bez obrázka */
.cs-logo { display: inline-block; line-height: 1; text-decoration: none; }
.cs-logo .cs-logo-1 {
    display: block;
    font-family: 'Oswald', 'Red Hat Display', 'Arial Narrow', sans-serif;
    font-weight: 600;
    letter-spacing: 8px;
    font-size: 13px;
    color: var(--primary-color);
    text-transform: uppercase;
    margin-bottom: 2px;
}
.cs-logo .cs-logo-2 {
    display: block;
    font-family: 'Oswald', 'Red Hat Display', 'Arial Narrow', sans-serif;
    font-weight: 800;
    letter-spacing: 1px;
    font-size: 30px;
    color: #fff;
    text-transform: uppercase;
}
.subfooter .cs-logo { vertical-align: middle; }
.subfooter .cs-logo .cs-logo-2 { font-size: 22px; }
.subfooter .cs-logo + .copy { margin-left: 14px; }
.cs-credit { margin-left: 18px; opacity: .82; }
.cs-credit::before { content: "·"; margin-right: 12px; opacity: .55; }
@media (max-width: 575px) {
    .cs-credit { display: block; margin-left: 0; margin-top: 6px; }
    .cs-credit::before { display: none; }
}

/* =====================================================================
   DJ-FEST LAYOUT — BIELE PODKLADY namiesto limetkovej
   (podľa pokynu: „miesto tejto farby podkladu má byť biela")
   ===================================================================== */

/* dátumový pruh: biely podklad, tmavý text, zaoblené rohy ako v šablóne */
.cs-band-white {
    background: #ffffff !important;
    border-radius: 0 90px 0 90px;
    box-shadow: 0 18px 50px -14px rgba(0, 0, 0, .55);
    margin: 0 12px;
}
.cs-band-white h2,
.cs-band-white h3,
.cs-band-white p,
.cs-band-white .text-black { color: #16100a !important; }
.cs-band-white h3 { opacity: .85; }

/* štítok s menom interpreta: namiesto limetkového podkladu biely */
.dark-scheme .de-image-text.s2 h3 {
    background: #ffffff !important;
    color: #16100a !important;
}

/* tlačidlá a malé akcenty necháme farebné (nie sú „podklad"),
   ale text na nich nech je vždy čitateľný */
.dark-scheme a.btn-main,
.dark-scheme .btn-main { color: #16100a; }

/* poistka pre obrovský hero nadpis na širokých monitoroch */
@media (min-width: 1200px) {
    h1.ultra-big { font-size: min(200px, 13.5vw); }
}
@media (max-width: 575px) {
    h1.ultra-big { font-size: 17vw; }
    .cs-band-white { border-radius: 0 44px 0 44px; margin: 0 6px; }
    h2.s2 { font-size: 42px; }
    #subheader h1 { font-size: 44px !important; }
}

/* sekcia galérie má fotku v pozadí — pridáme tmavé prekrytie pre čitateľnosť */
#section-gallery[data-bgimage]::before {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(28, 23, 70, .82);
    z-index: 0;
}
#section-gallery { position: relative; }
#section-gallery .container { position: relative; z-index: 1; }

/* =====================================================================
   PALETA PODĽA LOGA — výhradne navy, oceľová modrá a biela
   (podľa pokynu: „používaj len tieto farby a farby loga")
   ===================================================================== */
:root {
    --primary-color: #8cb4d2;          /* oceľová modrá zo slova ŠUNAVA */
    --primary-color-rgb: 140, 180, 210;
    --primary-color-2: #2a2560;        /* sýta navy zo siluet */
    --primary-color-2-rgb: 42, 37, 96;
    --cs-navy: #241f54;
    --cs-navy-light: #2e2768;
}

/* tmavé podklady sekcií = navy z loga (úvodná stránka; fotky v pozadí ostávajú) */
/* :not(.cs-light) — vo svetlej téme tieto tmavé podklady NEPLATIA */
.dj-home:not(.cs-light).dark-scheme section,
.dj-home:not(.cs-light).dark-scheme footer,
.dj-home:not(.cs-light) header.smaller,
.dj-home:not(.cs-light) .de_tab.tab_style_4 .de_nav.de_nav_dark li {
    background-color: #241f54 !important;
}
.dj-home:not(.cs-light).dark-scheme { background: #1c1746 !important; }

/* karty na navy podklade nech sú viditeľné, jemne svetlejšie */
.de-card-mac { background: #2e2768; }

/* biele podklady → tmavomodrý text */
.cs-band-white h2,
.cs-band-white h3,
.cs-band-white p,
.cs-band-white .text-black { color: #241f54 !important; }
.dark-scheme .de-image-text.s2 h3 { background: #fff !important; color: #241f54 !important; }

/* text na tlačidlách = navy, čitateľný na oceľovej modrej */
.dark-scheme a.btn-main,
.dark-scheme .btn-main { color: #1c1746 !important; }

/* =====================================================================
   TLAČIDLÁ vo farbe podkladu lôg (strieborná ako stena partnerov)
   ===================================================================== */
.btn-main,
a.btn-main,
a.btn-main:visited,
button.btn-main,
input[type="submit"],
input[type="submit"].btn-main,
#send_message,
.menu_side_area .btn-main,
.pricing-s1 .action a.btn-main,
.dark-scheme a.btn-main,
.dark-scheme .btn-main {
    background: #c3c5c7 !important;
    color: #1c1746 !important;
    border: 1px solid #c3c5c7 !important;
}
.btn-main:hover,
a.btn-main:hover,
button.btn-main:hover,
input[type="submit"]:hover,
#send_message:hover,
.dark-scheme a.btn-main:hover {
    background: #e2e4e6 !important;
    color: #14102e !important;
    border-color: #e2e4e6 !important;
}
/* obrysové tlačidlá: strieborný okraj a text */
.btn-line,
a.btn-line {
    color: #c3c5c7 !important;
    border: 2px solid #c3c5c7 !important;
    background: transparent !important;
}
.btn-line:hover,
a.btn-line:hover {
    background: #c3c5c7 !important;
    color: #1c1746 !important;
}

/* jemný navy nádych na fotkách, aby ladili s paletou */
.dj-home #de-carousel .mask { box-shadow: inset 0 0 0 2000px rgba(28, 23, 70, .28); }

/* =====================================================================
   PLAGÁT — jemná animácia, nech pekne zapadne do stránky
   ===================================================================== */
@keyframes cs-poster-float {
    0%, 100% { transform: translateY(0) rotate(-0.4deg); }
    50%      { transform: translateY(-14px) rotate(0.4deg); }
}
.cs-poster {
    animation: cs-poster-float 7s ease-in-out infinite;
    border-radius: 12px;
    box-shadow:
        0 4px 10px rgba(0, 0, 0, .35),
        0 24px 60px -12px rgba(0, 0, 0, .6),
        0 0 0 6px rgba(255, 255, 255, .04);
}
.de-image-mac:hover .cs-poster { animation-play-state: paused; }
/* jemný „svetelný" podklad za plagátom */
#section-poster .de-image-mac::after {
    content: "";
    position: absolute;
    inset: -8% -6%;
    background: radial-gradient(closest-side, rgba(140, 180, 210, .22), transparent 70%);
    z-index: -1;
}
#section-poster .de-image-mac { position: relative; }
