/* ---  Styly pro hlavičku, patičku a společné vlastnosti všech stránek ---------------------------------------- --- */
/* --- ----------------------------------------------------------------------------- Základní reset a box-sizing --- */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html, body {
    height: 100%;
 /*   margin: 0;*/
 /*   padding: 0;*/
}

/* Flexbox kontejner */
body {
    font-family: Arial, sans-serif;
    line-height: 1.6;
    background-color: white;
    color: black;

    display: flex; /* Z body se stane flex kontejner */
    flex-direction: column; /* Uspořádá děti (header, main, footer) do sloupce */
}

p {
    margin-bottom: 15px;
    text-align: justify;
    hyphens: auto; /* Povolí automatické dělení slov */
      /* Pro lepší podporu v prohlížečích */
  -webkit-hyphens: auto;
  -moz-hyphens: auto;
}

h3 {
    margin-bottom: 15px;
}

hr {
    border: none; /* Odstraní případný výchozí okraj prohlížeče, který by mohl být divný */
    border-top: 1px solid #ccc; /* Nastaví čáru jako tenkou, plnou, světle šedou linku */
    height: 0; /* Zajišťuje, že čára nemá žádnou výšku, spoléháme se jen na border-top */
    margin: 0px 0px 0px 230px;
    width: 100%;       
}

/* --- ----------------------------------------------------------------------------- Styly pro HLAVIČKU a zarovnání LOGA a NAVIGACE --- */
header {
    background-color: #23405a; /* Pozadí celé hlavičky */
    padding: 10px 20px; /* Vnitřní odsazení hlavičky */
    display: flex; /* Flexbox pro zarovnání obsahu */
    justify-content: space-between; /* Rozmístí položky na okraje (logo vlevo, nav vpravo) */
    align-items: center; /* Vertikálně zarovná položky na střed */
    flex-wrap: wrap; /* Umožní zalomení obsahu na menších obrazovkách, pokud je potřeba */
    position: relative; /* Důležité pro z-index */
    z-index: 10; /* Zajišťuje, že hlavička je nad vším */
}

.logo-s-textem {
    display: flex;
    align-items: center;
    gap: 15px;
}

.logo {
    width: 60px;
    height: auto;
}

.logo-textovy-kontejner {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.logo-radek-1 {
    font-size: 36px;
    color: red;
    font-weight: bold;
    margin: 0;
    line-height: 1.2;
    font-family: 'Garamond', serif;
    font-style: italic;
    text-decoration: none;
}

.logo-radek-2 {
    font-size: 18px;
    color: red;
    margin: 0;
    line-height: 1.2;
    font-family: sans-serif;
    text-decoration: none;
}

/* --- -----------------------------------------------------------------------------Styly pro hlavní navigaci (.main-nav) --- */
.main-nav {
    display: flex;
    align-items: center;
}

.nav-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    justify-content: center;
}

.nav-list li a {
    display: block;
    color: white;
    text-decoration: none;
    padding: 10px 15px;
}

.nav-list li a:hover {
    background-color: #555;
}

.main-nav .nav-list a.active {
    /* Zde definujte styl pro aktivní odkaz */
    border-bottom: 2px solid #fff; /* Příklad: bílé podtržení */
    /* color: #5a9e22;  Příklad: zelená barva textu */
    /* font-weight: bold;  Příklad: tučný text */
}

a:link, a:visited {
    color: red; /* červená barva loga před kliknutím i po něm */
}

/* --- -----------------------------------------------------------------------------Styly pro responzivní hamburger menu --- */
.menu-toggle {
    display: none;
    background: none;
    border: none;
    color: white;
    font-size: 24px;
    cursor: pointer;
    padding: 10px;
    z-index: 1001;
}

.hamburger {
    display: block;
    width: 25px;
    height: 3px;
    background-color: white !important;
    position: relative;
    transition: background-color 0.3s ease-in-out;
    color-scheme: only light; /* Klíčové slovo 'only' brání automatické inverzi */
    color: black !important;
}

.hamburger::before,
.hamburger::after {
    content: '';
    display: block;
    width: 25px;
    height: 3px;
    background-color: white;
    position: absolute;
    transition: transform 0.3s ease-in-out, top 0.3s ease-in-out;
}

.hamburger::before {
    top: -8px;
}

.hamburger::after {
    top: 8px;
}

.menu-toggle.active .hamburger {
    background-color: transparent;
}

.menu-toggle.active .hamburger::before {
    transform: translateY(8px) rotate(45deg);
}

.menu-toggle.active .hamburger::after {
    transform: translateY(-8px) rotate(-45deg);
}

/* --- ----------------------------------------------------------------------------- VODOZNAK NA MAIN ELEMENTU A HLAVNÍ ROZLOŽENÍ --- */
main {
    position: relative;
    z-index: 1;
    flex-grow: 1;

    display: flex; /* Z 'main' se stane flex kontejner */
    flex-direction: row; /* Položky půjdou vedle sebe (výchozí pro desktop) */
    flex-wrap: wrap;  /* Umožní zalomení na další řádek na menších obrazovkách */
    justify-content: flex-start; /* Zarovná položky k levému okraji paddingu main */
    align-items: flex-start; /* Zarovná položky k hornímu okraji */
    padding: 0 60px; /* Odsazení zleva a zprava */

    /* Styly pro vodoznak */
    background-image: url('ladder.jpg');
    background-repeat: repeat-y;
    background-position: left top;
    background-size: 240px;
}

/* --- ----------------------------------------------------------------------------- Styly pro SEKCE v hlavní části stránky, tj od vodoznaku na konec --- */
.section {
    display: flex; /* Uděláme z ní flex kontejner */
    flex-direction: row; /* Její děti (text a mapa) půjdou vedle sebe */
    flex-wrap: nowrap; /* TOTO JE KLÍČOVÉ: ZABRÁNÍ ZALOMENÍ NA PC */
    justify-content: flex-start;
    align-items: flex-start;
    width: 100%; /* Zajistí, že zabere celou dostupnou šířku uvnitř main */
    margin-left: 230px; /* Odsazení pro blok, aby začal až za obrázkem ladderu */
    gap: 20px;     /* Vytvoří 20px mezeru mezi flex položkami */
}

/* --- ----------------------------------------------------------------------------- Styly pro patičku --- */
footer {
    background-color: #333;
    color: white;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 10px 0;
    position: relative;
    z-index: 10;
}

/* --- ----------------------------------------------------------------------------- Media Queries pro mobilní zařízení --- */

@media (max-width: 768px) {
    /* Styly menu na mobilu */
    .nav-list {
        flex-direction: column;
        width: 100%;
        background-color: #444;
        position: absolute;
        top: 70px;
        left: 0;
        transform: translateY(-100%);
        transition: transform 0.3s ease-in-out;
        overflow: hidden;
        height: 0;
        z-index: 1000;
    }

    .logo-s-textem {
    display: flex;
    align-items: center;
    gap: 12px;
    }

.logo {
    width: 45px;
    height: auto;
    }

    .logo-radek-1 {
    font-size: 23px;
    color: red;
    font-weight: bold;
    margin: 0;
    line-height: 1.2;
    font-family: 'Garamond', serif;
    font-style: italic;
    }

    .logo-radek-2 {
    font-size: 12px;
    color: red;
    margin: 0;
    line-height: 1.2;
    font-family: sans-serif;
    }

    .section {
        flex-direction: column; /* Děti sekce půjdou pod sebe */
        flex-wrap: wrap; /* Zde se děti zalomí */
        margin-left: 0px; /* na mobilu bez odsazení */
    }

    .nav-list.active {
        transform: translateY(0);
        height: auto;
    }

    .nav-list li {
        text-align: center;
        margin: 10px 0;
    }

    .menu-toggle {
        display: block;
    }

    hr {
    border: none; /* Odstraní případný výchozí okraj prohlížeče, který by mohl být divný */
    border-top: 1px solid #ccc; /* Nastaví čáru jako tenkou, plnou, světle šedou linku */
    height: 0; /* Zajišťuje, že čára nemá žádnou výšku, spoléháme se jen na border-top */
    margin: 0px 0px 15px 0px;
    width: 100%;       
    }

   
    /* Skryjeme seznam na mobilu, pokud není aktivní */
    .main-nav .nav-list:not(.active) {
        display: none;
    }

    .main-nav .nav-list a.active {
    /* Zde definujte styl pro aktivní odkaz */
    border-bottom: none; /* Příklad: bílé podtržení */
    color: white;  /*  barva textu */
    /* font-weight: bold;  Příklad: tučný text */
}

    