body {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    overflow-x: hidden;

    display:flex;
    flex-direction: column;
    min-height: 100svh;
    margin:0;
}

/* ----- HEADER ----- */

.nav {
        position:fixed;
        top:0;
        left:0;
        right:0;
        max-width: 100%;
        display: flex;
        align-items: center;
        justify-content: space-between; 
        background-color: #0C0704;
        padding: 10px 20px;
        color: white;
        z-index:50;
        border-bottom:1px solid white;
    }

    .nav h1 {
        margin: 0;
    }

    .nav a {
        text-decoration: none;
        color:white;
        font-weight: bold;
        font-family: sans-serif,Arial, Helvetica, sans-serif;
        border-left:2px solid white;
        padding-left:10px;
        padding-right:5px;
    }

    .nav a:hover {
        text-decoration: underline;
    }

    .nav img {
        width: 50px;
    }

    main {
        flex:1;
    }

/* ----- RESPONZIVITA ----- */

@media only screen and (max-width:1000px) {
    main {
        margin-top:15%;
    }
}

@media only screen and (max-width: 700px) {
    .container {
        max-width: 100%;
    }

    .about img {
        position:relative;
        top:70px;
    }
}

@media only screen and (max-width:480px) {
    .sluzby {
        margin-top:10%;
    }

    .footer {
        margin-bottom:50px;
    }
}

@media only screen and (max-width:400px) {
    .nav-links a {
        font-size:12px;
    }

    .nav a {
        padding-left:5px;
        padding-right:1px;
    }
}

/* ----- MAIN ----- */


.container {
    max-width: 1020px;
    margin: 0 auto;
    padding:10px;
}

/* ----- SLUŽBY ----- */

.sluzby {
    margin-top:10%;
}

.nadpis h1,
.nadpis h2 {
    text-align: center;
    margin-top:20px;
    font-size:30px;
}

.nadpis h1:after,
.nadpis h2:after {
    content: "";
    display:block;
    width:200px;
    border-bottom:2px solid black;
    margin:10px auto;
}

.nadpis h2 {
    font-size: 20px;
}

.oddil {
  background-color: #f4f4f4;
  padding: 20px;
  box-sizing: border-box;
  text-align: center;
  border: 1px solid black;
  border-radius: 12px;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1); 
  height: 250px;
  margin-bottom:20px;
}

@media only screen and (max-width:720px) {
    .sluzby .row {
    display: flex;         /* Aktivuje flexbox */
    flex-wrap: wrap;      /* Aby na mobilu skočily pod sebe */
    gap: 20px;            /* TA MEZERA, KTEROU CHCEŠ */
    justify-content: center;
}
}

/* ----- O NÁS ----- */

.about p {
    text-align: center;
}

.about img {
    max-width: 100%;
    margin-bottom:30px;
}

/* ----- OTEVÍRACÍ DOBA -----*/

.doba ul {
    list-style-type: none;
    text-align: center;
    padding:0;
    margin:0;
}

.doba li {
    margin: 11px 0;
}

/* ----- KONTAKT -----*/

@media only screen and (max-width:480px) {
    .kontakt {
    display: flex;
    flex-wrap: wrap; /* Důležité: na malém displeji se hodí pod sebe */
    gap: 20px;
    padding: 40px 0;
}

}

.kontakt li {
    list-style-type: none;
    text-align: center;
}

.kontakt ul {
    padding:0;
    margin:0;
}

.knadpis {
    font-size:20px;
    margin: 25px 0;
}

.knadpis:after {
    content: "";
    display:block;
    width:100px;
    border-bottom:2px dashed black;
    margin:10px auto;
}

.kontaktni-udaje ul li a {
    text-decoration: none;
    color:black;
}

/* ----- FOOTER ----- */


footer {
    clear: both;
    background: #0C0704;
    padding: 40px 0;
    color: white;
    text-align: center;
}