.sloupce { border: 0 !important; }
.header-controls { display: none; }
.in-editor .header-controls { display: block; }

.workspace-work-section { padding-left: 20px; padding-right: 20px; margin-bottom: 0 !important; }

/* Mobilní úprava textu v headeru */
@media screen and (max-width: 599px) {
.header-content { text-align: center !important; }
}

/* Desktop - zachování původních hodnot nebo mírné úpravy */
@media (min-width: 1200px) {
.workspace-header { padding: 150px 0px !important; }
.header-content { padding-left: 200px !important; padding-right: 200px !important; }
.header-content h1 { font-size: 72px !important; }
.header-content h2 { font-size: 48px !important; }
.header-content p { font-size: 22px !important; }
}

/* Laptop - menší paddingy */
@media (min-width: 992px) and (max-width: 1199px) {
.workspace-header { padding: 120px 0px !important; }
.header-content { padding-left: 120px !important; padding-right: 120px !important; }
.header-content h1 { font-size: 64px !important; }
.header-content h2 { font-size: 42px !important; }
.header-content p { font-size: 20px !important; }
}

/* Tablet - výrazně menší paddingy */
@media (min-width: 768px) and (max-width: 991px) {
.workspace-header { padding: 100px 0px !important; }
.header-content { padding-left: 60px !important; padding-right: 60px !important; }
.header-content h1 { font-size: 52px !important; }
.header-content h2 { font-size: 36px !important; }
.header-content p { font-size: 18px !important; }
}

/* Mobil landscape - ještě menší */
@media (min-width: 576px) and (max-width: 767px) {
.workspace-header { padding: 80px 0px !important; }
.header-content { padding-left: 40px !important; padding-right: 40px !important; text-align: center !important; }
.header-content h1 { font-size: 42px !important; line-height: 1.2; }
.header-content h2 { font-size: 30px !important; line-height: 1.3; }
.header-content p { font-size: 16px !important; line-height: 1.5; }
.header-content .btn { margin-left: auto; margin-right: auto; }
}

/* Mobil portrait - minimální paddingy */
@media (max-width: 575px) {
.workspace-header { padding: 60px 0px !important; }
.header-content { padding-left: 20px !important; padding-right: 20px !important; }
.header-content h1 { font-size: 32px !important; line-height: 1.2; margin-bottom: 15px; }
.header-content h2 { font-size: 24px !important; line-height: 1.3; margin-bottom: 12px; }
.header-content p { font-size: 16px !important; line-height: 1.5; margin-bottom: 15px; }
.header-content .btn { width: 100% !important; max-width: 200px; }
}

/* Extra malé mobily */
@media (max-width: 400px) {
.workspace-header { padding: 40px 0px !important; }
.header-content { padding-left: 15px !important; padding-right: 15px !important; }
.header-content h1 { font-size: 28px !important; }
.header-content h2 { font-size: 20px !important; }
.header-content p { font-size: 14px !important; }
}

/* Obecné vylepšení pro background obrázky */
.workspace-header { background-size: cover !important; background-position: center center !important; background-repeat: no-repeat !important; }

/* Zajištění správného zalamování textu */
.header-content h1, .header-content h2, .header-content p { word-wrap: break-word; overflow-wrap: break-word; max-width: 100%; }

/* Responzivní mezery mezi elementy */
.header-content > * + * { margin-top: 0.75rem; }
@media (min-width: 768px) { .header-content > * + * { margin-top: 1rem; } }
@media (min-width: 1200px) { .header-content > * + * { margin-top: 1.25rem; } }

/* Zajištění čitelnosti textu na background obrazcích */
.workspace-header::before { content: ''; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0, 0, 0, 0.2); z-index: 0; pointer-events: none; }

/* Zajištění, že obsah je nad overlay */
.header-content { position: relative !important; z-index: 1 !important; }


/* ===========================
COLUMNS (GRID LAYOUT)
=========================== */

/* Skrytí administračních prvků na ostrém webu */
.columns-toolbar { display: none !important; }

/* Pagelet wrapper bez extra paddingu */
.pagelet-columns { padding: 0 !important; }

/* Kontejner sloupců používá GRID (ne FLEX) */
.columns-container { display: grid; gap: 10px; }

/* Mobil – vynutit 1 sloupec bez ohledu na inline rozložení */
@media (max-width: 576px) {
.columns-container { grid-template-columns: 1fr !important; }
}

/* Volitelné výchozí nastavení pro ?577px, pokud JS nic nenastaví:
(pozn.: BEZ !important, aby inline z JS mělo přednost) */
@media (min-width: 577px) {
.columns-container { grid-template-columns: repeat(12, minmax(0, 1fr)); }
}

/* Sloupce – čisté na ostrém webu, ale s paddingem pro obsah */
.sloupce, .workspace-column { border: none !important; min-height: auto !important; background-color: transparent !important; padding: 10px; box-sizing: border-box; flex: initial !important; max-width: none !important; min-width: 0 !important; }

/* Editor (admin) – zvýraznění sloupců */
body.in-editor .sloupce, body.in-editor .workspace-column { border: 1px dashed #aaa !important; min-height: 100px !important; padding: 10px !important; background-color: #fafafa !important; }

/* Ostrý web – čisté sloupce */
body:not(.in-editor) .sloupce, body:not(.in-editor) .workspace-column { border: none !important; min-height: auto !important; background-color: transparent !important; }

/* Vnořené elementy v sloupcích */
.sloupce > *, .workspace-column > * { max-width: 100%; }

/* Obrázky v sloupcích budou responzivní */
.sloupce img, .workspace-column img { max-width: 100%; height: auto; }

/* Hover efekt pro tlačítka */
.workspace-button-pagelet[data-pagelet="button"] .cta-button:hover { background: var(--button-hover-bg) !important; color: var(--button-hover-color) !important; border-color: var(--button-hover-border) !important; }

.cta-button { margin-top: 20px; margin-bottom: 20px; }

#lightboxOverlay { position: fixed; top: 0; left: 0; width: 100vw; height: 100vh; background: rgba(0,0,0,0.8); display: none; justify-content: center; align-items: center; z-index: 99999; }
#lightboxOverlay img { max-width: 90%; max-height: 90%; border-radius: 8px; }

.my-footer { display: block; margin: auto; text-align: center; font-size: 12px; padding: 7px; }
.my-footer a { font-size: 12px; font-weight: 600; text-decoration: none; }
.my-footer a { text-decoration: none; }

.lang-switcher .lang-flag { width: 22px; height: auto; display: inline-block; border-radius: 0; }
.lang-switcher a { display: inline-flex; align-items: center; }
.lang-switcher a:not(.fw-bold) .lang-flag { opacity: 0.9; }
.lang-switcher a.fw-bold .lang-flag { opacity: 1; }

/* Tabulky z text pageletu na ostrém webu */
body:not(.in-editor) .workspace-text-pagelet .editor-table {
  width: 100% !important;
  border-collapse: collapse;
}

body:not(.in-editor) .workspace-text-pagelet .editor-table td,
body:not(.in-editor) .workspace-text-pagelet .editor-table th {
  border: 1px solid #ddd;
  padding: 6px 8px;
}

/* MOBIL ? v?echny dropdowny rozbalené */
@media (max-width: 991px) {
  .navbar .dropdown-menu { display: block !important; position: static; border: 0; box-shadow: none; padding-left: 15px; }
  .navbar .dropdown-toggle::after { display: none; }
}

/* DESKTOP ? dropdown klasicky */
@media (min-width: 992px) {
  .navbar .dropdown:hover > .dropdown-menu { display: block; }
}

.popup { display: none; position: fixed; z-index: 9999; left: 0; top: 0; width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.6); }
.popup-content { position: relative; width: 90%; max-width: 550px; height: 386px; margin: 5% auto; background: #ffffff; border-radius: 8px; }
.popup-button { width: 200px; position: absolute; bottom: 30px; left: 50%; transform: translateX(-50%); padding: 14px 28px; background-color: #e6881b; color: #ffffff !important; border: none; border-radius: 5px; cursor: pointer; font-weight: bold; }
.popup-button:hover { opacity: 0.9; color: #ffffff !important; text-decoration: none; }
.close-btn { position: absolute; top: 10px; right: 15px; font-size: 32px; color: #000000; cursor: pointer; font-weight: bold; z-index: 2; }
.close-btn:hover { opacity: 0.8; }
.popup-text { position: absolute; top: 0; left: 0; right: 0; bottom: 70px; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 40px 40px 0 40px; text-align: center; gap: 12px; }
.popup-text h2 { font-size: 22px; font-weight: 400; color: #222; margin: 0; }
.popup-text p { font-size: 15px; color: #555; line-height: 1.6; margin: 0; }
