:root {
    --color-blue: #302393;
    --color-orange: #FF9B19;
    --color-light-orange: #fdd7a6;
    --color-light-gray: #F7F7F7;
    --color-gray: #DDDDDD;
    --color-dark-gray: #363636;
    --color-white: #FFFFFF;
    --color-green: #2FA66A;
    --color-red: #D9434E;
    --color-black: #000000;
    --color-white-opacity: rgba(255, 255, 255, 0.4);
}

body {
    margin: 0;
    text-align: center;
    padding-top: 20px; /* Stejná výška jako menu + 60px */
}

html {
    scroll-behavior: smooth;
    scroll-padding-top: 100px; /* Default padding */
    font-family: Fieldwork, Geo Bold, serif;
    color: var(--color-blue)
}

/* Apply larger padding for the section with ID 'home' */
html:target #home {
    scroll-padding-top: 20px; /* Override for the 'home' section */
}

.subject-container {
    width: 100%;
    max-width: 1246px;
    padding: 96px 20px 0 20px;
    box-sizing: border-box;
    .subject {
        font-size: 68px;
    }
    .text {
        font-size: 20px;
    }
    .error {
        font-size: 20px;
        color: var(--color-red);
    }
}

.separator {
    position: relative;
    width: 100%;
    max-width: 1366px;
    height: 32px;
    margin: 0 auto;
    padding: 0;
    display: block;
    box-sizing: border-box;

    background-image: url("../images/icons/oddelovac-2-376f1483e7b304ee77814eb02fe52280.svg");
    background-repeat: repeat-x;
    background-position: left center;
    background-size: auto;
    overflow: hidden;
    &.orange {
        background-color: var(--color-light-orange);
    }
}

.our-lifts-wrapper {
    background-color: var(--color-light-orange);
    /*background-color: linear-gradient(to bottom, yellow 0%, yellow 50%, white 50%, white 100%);*/
    background-image: url("../images/photos/VOL02209-33ace32b1414ed62c31a7197142d134f.jpg");
    width: 100%;
    background-size: max();
    background-position: left center;
    background-repeat: no-repeat;
    overflow: hidden;
}

.introduction-page-block {
    text-align: center;
    position: relative;
    width: 100%;
    max-width: 1366px;
    height: auto;
    margin: 0 auto 96px;
    padding: 0;
    display: flex;
    justify-content: space-between; /* Prostor mezi textem a videem */
    align-items: flex-start; /* Vertikální zarovnání */
    box-sizing: border-box;
    flex-direction: row; /* KLÍČOVÉ: Aby šly vedle sebe */
    border:  0 solid var(--color-black);
    gap: 60px;
    .intro-text {
        flex: 1 1 40%; /* flexibilní, ale základ 40% */
        min-width: 425px; /* aby se to nerozpadlo při hodně malém okně */
        box-sizing: border-box;
        text-align: left;
        height: auto;
        margin: 0;
        padding: 0;
        .subject {
            font-size: 89px;
            color: var(--color-blue);
            font-weight: 700;
        }
        .text {
            font-size: 20px;
            color: var(--color-blue);
            font-weight: 400;
        }
    }
    .intro-video {
        flex: 1 1 60%; /* flexibilní, ale základ 60% */
        min-width: 300px;
        aspect-ratio: 16 / 9;
        height: auto;
        background-color: var(--color-white);
        box-sizing: border-box;
        margin: 0;
        padding: 0;
    }
    .intro-video iframe {
        width: 100%;
        height: 100%;
        border: none;
    }
}



/* ---------- BENEFITS ----------- */
.benefits-page-block {
    display: grid;
    grid-template-columns: repeat(3, minmax(200px, 1fr));
    background-color: var(--color-blue);
    gap: 20px;
    padding: 60px 60px 0 60px;
    box-sizing: border-box;
    max-width: 1366px;
    width: 100%;
    margin: 0 auto;
    .benefits-box {
        width: auto;
        height: auto;
        margin: 0;
        padding: 20px;
        text-align: center;
        .subject {
            font-size: 29px !important;
            margin: 36px 0 0 0;
            color: #ff9b19 !important;
        }
        .notice {
            font-size: 20px !important;
            margin: 36px 0 0 0;
            color: #fdd7a6 !important;
        }
        img {
            display: inline-block;
            max-width: 100%; /* Responsive image */
            height: auto;    /* Maintain aspect ratio */
            margin: 40px 0 0 0;
        }
    }
}

.benefits-footer-wrapper {
    width: 100%;
    display: flex;
    height: 96px;
    text-align: center;
    background-color:  var(--color-light-orange);
    .benefits-page-footer-block {
        background-color:  var(--color-blue);
        border-radius: 0 0 0 72px;
        box-sizing: border-box;
        max-width: 1366px;
        width: 100%;
        margin: 0 auto;
    }
}

/* ---------- BENEFITS ----------- */

/* ---------- HOW IT WORKS ----------- */
.how-it-works-page-block {
    display: flex;
    justify-content: center;
    align-items:  center;
    width: 100%;
    height: 900px;
    margin: 0;
    background-image: url("../images/photos/VOL02162-12ce54b1879bceb9188d9ad6673961bc.jpg");
    background-color: var(--color-light-orange);
    background-repeat: no-repeat;
    background-size: auto 100%;
    background-position: left center;
    overflow: hidden;
    padding: 0;
    box-sizing: border-box;
    position: relative;
    text-align: center;
    .hot-it-works-wrapper {
        display: flex;
        flex-direction: column;
        width: 1366px;
        height: 100%;
        box-sizing: border-box;
        .row {
            display: flex;
            width: 100%;
            height: 100%;
            box-sizing: border-box;
            flex-wrap: wrap;
            .left-content {
                flex: 0 1 60%;
                box-sizing: border-box;
                height: 100%;
            }
            .right-content {
                background-color: var(--color-light-orange);
                flex: 0 1 40%;
                height: 100%;
                box-sizing: border-box;
                .content-wrapper {
                    display: flex;
                    width: 100%;
                    box-sizing: border-box;
                    padding: 0 60px;
                    margin: 0 0 20px 0;
                    .left {
                        width: 122px;
                        flex-shrink: 0;
                        box-sizing: border-box;
                    }
                    .right {
                        flex: 1;
                        padding: 0 0 20px 0;
                        text-align: left;
                        box-sizing: border-box;
                        &.bottom-border {
                            border-bottom: solid 4px var(--color-white);
                        }
                        .subject {
                            font-size: 68px;
                            font-weight: bold;
                        }
                    }
                    .point {
                        position: absolute;
                        width: 82px;
                        height: 82px;
                        background-color: #ff9b19;
                        font-family: Fieldwork, Geo Bold, serif;
                        font-weight: 700;
                        font-size: 45px;
                        color: #FFFFFF;
                        text-align: center;
                        border-radius: 50%; /* Makes it a perfect circle */
                        display: flex;
                        justify-content: center; /* Horizontal centering */
                        align-items: center; /* Vertical centering */

                        &.color-gray {
                            background-color: #DFDFDF;
                        }
                    }
                }
            }
        }
    }
}
.how-it-works-full-page-block {
    background-color: var(--color-light-orange);
    padding: 30px 0 60px 0;
    box-sizing: border-box;
    text-align: center;
    width: 100%;
    margin: 0 auto;
    .whole-content {
        width: 100%;
        max-width: 1366px;
        height: 30%;
        box-sizing: border-box;
        display: flex;
        justify-content: right;
        align-items: flex-end; // Lepší než self-end
        text-align: right !important;
        margin: 0 auto; // CENTROVÁNÍ BLOKU
    }
}

/* ---------- HOW IT WORKS ----------- */

.page-block {
    text-align: center; /* Zarovnání textu a inline prvků na střed */
    position: relative;
    width: 100%;
    max-width: 1366px;
    height: auto;
    margin: 0 auto 96px;
    padding: 0 60px 96px 60px; /* Doporučuji padding 20px na stranách kvůli odsazení */
    display: flex;
    justify-content: center; /* Vycentrování vnitřního kontejneru */
    align-items: flex-start;
    box-sizing: border-box;
    flex-direction: column;
    &.round-left-down {
        border-radius: 0 0 0 72px !important;
    }
    &.margin-zero {
        padding-bottom: 60px !important;
        margin-bottom: 0 !important;
        height: auto;
    }
    &.row {
        flex-direction: row;
    }

    .timeline-container {
        display: flex;
        flex-direction: row;
        flex-wrap: nowrap;
        justify-content: center;
        align-items: center;
        width: 100%;
    }

    .how-it-works-text {
        width: auto;
        height: auto;
        margin: 100px 0 0 1134px;
    }

    .point {
        position: absolute;
        width: 82px;
        height: 82px;
        background-color: #ff9b19;
        font-family: Fieldwork, Geo Bold, serif;
        font-weight: 700;
        font-size: 45px;
        color: #FFFFFF;
        text-align: center;
        border-radius: 50%; /* Makes it a perfect circle */
        display: flex;
        justify-content: center; /* Horizontal centering */
        align-items: center; /* Vertical centering */
        &.color-gray {
            background-color: #DFDFDF;
        }
    }

    .reservation-text {
        flex: 1 1 40%;     /* umožní růst i smrštění */
        max-width: 540px;
        min-width: 420px;
        height: auto;
        margin: 0 0 0 60px;
        border: solid 0 #000000;
    }

    .reservation-image {
        padding: 0;
        margin: 0;
        align-items: flex-start;
        flex: 1 1 60%;              /* Dovolí zmenšení i růst v rámci flexboxu */
        width: 100%;                /* Základní šířka podle rodiče */
        max-width: 826px;           /* Ale nikdy víc než 826px */
        background-color: #DDDDDD;
        height: auto;
        &.image {
            margin: 0;
            object-fit: cover; /* or 'contain' depending on your goal */
            display: block;
        }
    }

    .reservation-step {
        padding: 0;
        margin: 0;
        align-items: flex-start;
        width: 82px;
        height: 82px;
        float: left;
    }

    .reservation-step-gap {
        display: flex;
        align-items: center;
        justify-content: center;
        flex: 1 1 auto;
        padding: 0 20px; /* pevný padding, nebo menší rozsah */
        margin: 0 20px;   /* menší margin, nebo podle potřeby */
        height: clamp(10px, 6vw, 82px);
        background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="3" height="3"><rect width="3" height="3" fill="%23DFDFDF"/></svg>');
        background-repeat: repeat-x;
        background-position: center;
        &.color-orange {
            background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="3" height="3"><rect width="3" height="3" fill="%23FF9B19"/></svg>');
        }
    }

    .subject-text {
        width: 90%;
        height: auto;
        margin: 0 0 36px 0;
        padding: 0;
        text-align: left;
    }
}

.background-color-gray {
    background-color: #dfdfdf  !important;
}

.background-color-light-gray {
    background-color: var(--color-light-gray)  !important;
}

.background-color-blue {
    background-color: #302392 !important;
}

.font-color-blue {
    color: #302392 !important;
}

.background-color-light-orange {
    background-color: var(--color-light-orange)  !important;
}

.background-color-orange {
    background-color: var(--color-orange)  !important;
}

.font-color-orange {
    color: #ff9b19 !important;
}

.page-block img {
    width: 100%;      /* Přizpůsobí šířku rodiči */
    /*height: 32px;     !* Zachová poměr stran *!*/
    display: block;   /* Odstraní mezery pod obrázkem způsobené inline chováním */
}

.page-block-full {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.hide-div {
    display: block;
}

/* ------------- FOOTER -------------- */
.footer-container {
    font-family: Fieldwork, Geo Bold, serif;
    width: 100%;
    margin: 0;
    max-width: 100%;
    background-color: #534A96;
    display: flex;
    flex-direction: row;
    padding: 60px 0 60px 0;
    gap: 60px;
    justify-content: flex-start;
    align-items: flex-start;
    flex-wrap: wrap;
    .subject {
        font-size: 29px;
        font-weight: 700;
        width: 100%;
        color: #ff9b19 !important;
        text-align: left;
        box-sizing: border-box;
        margin: 0;
    }
    .text {
        min-width: 160px;
        color: #FFFFFF !important;
        text-align: left;
        box-sizing: border-box;
        margin: 0;
    }
}

.footer-gray {
    background-color: #363636;
    width: 100%;           /* viewport width pro plnou šířku */
    max-width: 100vw;       /* aby se nepřekročila viewport šířka */
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 20px 0 20px 0;
    margin: 0;
    .text {
        flex: 1 1 100%;
        width: 100%;
        max-width: 1366px;
        text-align: right;
        color: #FFFFFF;
        margin: 0 auto;
        a, a:hover, a:link {
            color: #FFFFFF;
            text-decoration: none;
        }
    }
}

.footer-container-logo {
    width: 232px;
    margin-left: 60px;
    padding: 0;
}

.footer-container-text {
    flex: 1;
    min-width: 300px;
    color: #FFFFFF;
    display: flex;
    flex-wrap: wrap;
    flex-direction: row;
    gap: 40px;
    .text {
        padding-right: 60px;
        flex: 1 1 auto;
    }
}
/* ------------- FOOTER -------------- */

.font-regular {
    font-family: Fieldwork, Geo Regular, serif;
    font-weight: 300;
}

.font-demi {
    font-family: Fieldwork, Geo DemiBold, serif;
    font-weight: 400;
}

.font-bold {
    font-family: Fieldwork, Geo Bold, serif;
    font-weight: 700;
}

.mt6 {
    margin-top: 6px;
}

.pl12 {
    padding-left: 12px;
}

.pl24 {
    padding-left: 24px;
}

.mt12 {
    margin-top: 12px;
}

.mt24 {
    margin-top: 24px !important;
}

.ml24 {
    margin-left: 24px;
}

.mt290 {
    margin-top: 290px;
}

.mt350 {
    margin-top: 460px;
}

.mt36 {
    margin-top: 36px;
}

.mt550 {
    margin-top: 650px;
}

.mt770 {
    margin-top: 920px;
}

.ml726 {
    margin-left: 726px;
}

.mt-10 {
    margin-top: calc(20px - 10px);
}

.md12 {
    margin-bottom: 12px;
}

.md24 {
    margin-bottom: 24px;
}

.mt48 {
    margin-top: 48px;
}

.md48 {
    margin-bottom: 48px;
}

.md96 {
    margin-bottom: 96px;
}

.mt96 {
    margin-top: 96px;
}

.ml12 {
    margin-left: 12px;
}

.ml36 {
    margin-left: 36px;
}

.ml-48 {
    margin-left: 48px;
}

.ml-50 {
    margin-left: 50px;
}

.ml-60 {
    margin-left: 60px;
}

.mt876 {
    margin-top: 876px;
}

.display-inline {
    display: inline;
}

.display-block {
    display: block;
}

.vehicle-photo {
    width: 100%;
    height: 340px;
    object-fit: cover;
    object-position: center;
    display: block;
}

.button-orange {
    width: auto;
    display: inline-block !important; /* Makes the button fit the content */
    background-color: #ff9b19 !important;
    border-radius: 30px 30px 30px 0 !important;
    padding: 11px 38px 7px 31px; /* Space around the text */
    font-size: 29px;
    color: #FFFFFF;
    border: none;
    cursor: pointer;
    text-align: center;
    max-height: 57px;
    font-family: Fieldwork, Geo Bold, serif;
    font-weight: 700;
    text-decoration: none;
    align-self: flex-start;
    &.menu  {
        font-size: 16px;
        height: 19px;
        padding: 11px 22px 11px 22px;
        text-decoration: none !important;
    }
}

.button-blue {
    width: auto;
    display: inline-block; /* Makes the button fit the content */
    background-color: #302393 !important;
    border-radius: 30px 0 30px 30px !important;
    padding: 11px 38px 7px 31px; /* Space around the text */
    font-size: 29px;
    color: #FFFFFF;
    border: none;
    cursor: pointer;
    text-align: center;
    max-height: 57px;
    font-family: Fieldwork, Geo Bold, serif;
    font-weight: 700;
    text-decoration: none;
    align-self: flex-start;
    &.technical {
        display: flex;
        max-width: 160px;
        font-size: 18px;
        height: 109px;
        padding: 11px 22px 11px 22px;
        align-items: center;
    }
    &.menu  {
        font-size: 16px;
        height: 19px;
        color: #ff9b19 !important;
        padding: 11px 22px 11px 22px;
        text-decoration: none !important;
    }
    &.next {
        border-radius: 30px 30px 0 30px !important;
    }
    &.introduction {
        margin-left: 12px;
        margin-top: 48px;
    }
}

.sharp-bottom-left {
    border-radius: 30px 30px 30px 0 !important;
}

.button-video {
    margin-top: 207px;
    margin-left: 374px;
}

/*.benefits-container {*/
/*    width: 1366px;*/
/*    height: 416px;*/
/*    border-radius: 0 0 0 72px;*/
/*    background-color: #302393;*/
/*    display: flex;*/
/*    justify-content: center;*/
/*    gap: 20px;*/
/*    flex-wrap: wrap;   !* Allows wrapping to the next line *!*/
/*}*/

/*.benefits-box {*/
/*    width: 355px;*/
/*    height: auto;*/
/*    margin: 0;*/
/*    padding: 20px;*/
/*    text-align: center;*/

/*    .subject {*/
/*        font-size: 29px !important;*/
/*        margin: 36px 0 0 0;*/
/*        color: #ff9b19 !important;*/
/*    }*/

/*    .notice {*/
/*        font-size: 20px !important;*/
/*        margin: 36px 0 0 0;*/
/*        color: #fdd7a6 !important;*/
/*    }*/
/*}*/

.white-line {
    width: 100%; /* Full width or adjust as needed */
    height: 2px; /* Line thickness */
    background-color: white;
    margin: 40px 0; /* Space around the line */
}

.align-right {
    display: flex;
    justify-content: flex-end; /* Aligns the content to the right */
}

.align-center {
    display: block;
    justify-content: center;
}

.background-light-orange {
    background-color: #fdd7a6;
}

.light-orange {
    color: #fdd7a6;
}

.map-menu-top-border {
    border-top: none;
}

.background-white {
    background-color: #ffffff;
}

.our-lifts-container {
    width: 1366px;
    height: auto; /* Let the height adjust based on content */
    border-radius: 0 0 0 72px;
    background-color: #ff9b19;
    display: flex;
    gap: 60px;
    flex-wrap: wrap;
    justify-content: center;
    align-items: flex-start; /* Align items to the top */
    .subject {
        width: 1104px; /* Takes full width */
        padding: 0; /* Adds space around the text */
        text-align: left;
        box-sizing: border-box;
        margin: 71px 0 0 0;
    }
}

.our-lifts-clear {
    height: 1230px;
}

.our-lifts-box {
    width: 522px;
    height: auto;
    padding: 0;
    justify-content: left;
    margin: 0 0 0 0;
    .subject {
        width: 100%;
        font-size: 29px !important;
        color: #302393 !important;
        margin: 0 0 0 0;
    }
    .full {
        width: 1084px;
        margin: 40px;
    }
    .top {
        margin: 36px 0 0 0 !important;
    }
}

.white {
    color: #FFFFFF !important;
}

ul.custom-list {
    list-style-type: none; /* Remove default bullets */
    padding: 0;
}

ul.custom-list li {
    position: relative;
    padding-left: 30px; /* Space for the graphic */
    margin-top: 12px;
}

ul.custom-list li::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' id='Component_13_1' data-name='Component 13 – 1' width='4' height='8' viewBox='0 0 8.773 12.694'%3E%3Cg id='Group_69' data-name='Group 69' transform='translate(8.773) rotate(90)'%3E%3Cpath id='Path_13' data-name='Path 13' d='M-23.954-11.978l-2.427,2.425-3.92-3.921-3.921,3.921-2.427-2.425,6.348-6.348Z' transform='translate(36.648 18.326)' fill='%23ffffff'%3E%3C/path%3E%3C/g%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-size: auto 18px; /* Height of 8px while maintaining aspect ratio */
    width: 18px; /* Adjust as needed */
    height: 18px; /* Set height explicitly */
}

ul.custom-list-blue {
    list-style-type: none; /* Remove default bullets */
    margin: 0;
    padding: 0;
    width: 100%;         /* ← Důležité */
    box-sizing: border-box; /* Volitelné, pokud používáš padding */
}

ul.custom-list-blue li {
    position: relative;
    padding-left: 30px; /* Space for the graphic */
    margin-top: 12px;
}

ul.custom-list-blue li::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' id='Component_13_1' data-name='Component 13 – 1' width='4' height='8' viewBox='0 0 8.773 12.694'%3E%3Cg id='Group_69' data-name='Group 69' transform='translate(8.773) rotate(90)'%3E%3Cpath id='Path_13' data-name='Path 13' d='M-23.954-11.978l-2.427,2.425-3.92-3.921-3.921,3.921-2.427-2.425,6.348-6.348Z' transform='translate(36.648 18.326)' fill='%23302393'%3E%3C/path%3E%3C/g%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-size: auto 18px; /* Height of 8px while maintaining aspect ratio */
    width: 18px; /* Adjust as needed */
    height: 18px; /* Set height explicitly */
}

.custom-list-blue li a.custom-link-blue {
    color: #302393;
    font-weight: bold;
    text-decoration: none;
}

.custom-list-blue li a.custom-link-blue:hover {
    text-decoration: none;
}

ul.custom-list-light-orange {
    list-style-type: none; /* Remove default bullets */
    margin: 0;
    padding: 0;
    width: 100%;         /* ← Důležité */
    box-sizing: border-box; /* Volitelné, pokud používáš padding */
    margin-top: 12px;
    margin-bottom:36px;
}

ul.custom-list-light-orange li {
    position: relative;
    padding-left: 30px; /* Space for the graphic */
    margin-top: 36px;
}

ul.custom-list-light-orange li::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' id='Component_13_1' data-name='Component 13 – 1' width='4' height='8' viewBox='0 0 8.773 12.694'%3E%3Cg id='Group_69' data-name='Group 69' transform='translate(8.773) rotate(90)'%3E%3Cpath id='Path_13' data-name='Path 13' d='M-23.954-11.978l-2.427,2.425-3.92-3.921-3.921,3.921-2.427-2.425,6.348-6.348Z' transform='translate(36.648 18.326)' fill='%23fdd7a6'%3E%3C/path%3E%3C/g%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-size: auto 18px; /* Height of 8px while maintaining aspect ratio */
    width: 18px; /* Adjust as needed */
    height: 18px; /* Set height explicitly */
}

.custom-list-light-prange li a.custom-link-light-orange {
    color: #fdd7a6;
    font-weight: bold;
    text-decoration: none;
}

.custom-list-light-orange li a.custom-link-light-orange:hover {
    text-decoration: none;
}

.price-list-container {
    width: 100%;
    max-width: 1246px;
    display: flex;
    gap: 60px;
    justify-content: center;
    box-sizing: border-box;
    padding: 0 20px;
    margin-top: 48px;
    .subject {
        width: 100%;
        max-width: 1104px; /* Takes full width */
        padding: 0; /* Adds space around the text */
        text-align: left;
        box-sizing: border-box;
        margin: 71px 0 0 0;
    }
    .text {
        width: 1104px; /* Takes full width */
        padding: 0; /* Adds space around the text */
        text-align: left;
        box-sizing: border-box;
        margin: 0 0 0 0;
    }
}

.price-list-text {
    margin: 0 0 0 60px !important;
}

.price-list-box {
    flex: 1 1 45%;           /* může růst i zmenšovat, výchozí šířka */
    min-width: 280px;        /* minimální šířka jednoho boxu */
    max-width: 522px;        /* maximální šířka */
    height: auto;
    padding: 0 0 96px 0;
    justify-content: left;
    margin: 0 0 0 0;
    box-sizing: border-box; /* aby padding neovlivnil rozměr */
    .full {
        width: 100% !important;
    }
    .top {
        margin: 36px 0 0 0 !important;
    }
}

/* ----------- OUR LIFTS ----------- */
.our-lifts-list-container {
    width: 100%;
    max-width: 1246px;
    display: flex;
    gap: 60px;
    justify-content: center;
    box-sizing: border-box;
    padding: 0 20px;
    margin-top: 48px;
    .subject {
        width: 100%;
        max-width: 1104px; /* Takes full width */
        padding: 0; /* Adds space around the text */
        text-align: left;
        box-sizing: border-box;
        margin: 71px 0 0 0;
    }
    .text {
        width: 1104px; /* Takes full width */
        padding: 0; /* Adds space around the text */
        text-align: left;
        box-sizing: border-box;
        margin: 0 0 0 0;
    }
}

.our-lifts-row {
    flex: 1;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    text-align: left;
    flex-wrap: wrap;
    gap: 20px;
    .row-wrapper {
        display: flex;
        flex-wrap: wrap;
        flex-direction: column;
        align-items: flex-start;
        gap: 20px;
        width: 100%;
        height: fit-content;
        .left,
        .right {
            flex: 0 0 50%;
            max-width: 50%;
            height: fit-content;
            box-sizing: border-box;
        }
    }
    .subject {
        margin: 0 0 24px 0;
        width: 100%;
        font-family:  Fieldwork, Geo Bold, serif;
        font-weight: 700;
        font-size: 29px;
    }
    .text {
        margin: 0 0 24px 0;
        width: 100%;
        box-sizing: border-box;
        font-family:  Fieldwork, Geo Bold, serif;
        font-weight: 400;
        text-align: left;
        font-size: 18px;
        &.order-type-margins {
            width: calc(100% - 60px);
            margin: 24px 0 0 50px !important;
        }
    }
}
/* --------- OUR LIFTS ----------- */

ul.blue-list {
    list-style-type: none; /* Remove default bullets */
    padding: 0;
}

ul.blue-list li {
    position: relative;
    padding-left: 30px; /* Space for the graphic */
    margin-top: 12px;
}

ul.blue-list li::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' id='Component_13_1' data-name='Component 13 – 1' width='4' height='8' viewBox='0 0 8.773 12.694'%3E%3Cg id='Group_69' data-name='Group 69' transform='translate(8.773) rotate(90)'%3E%3Cpath id='Path_13' data-name='Path 13' d='M-23.954-11.978l-2.427,2.425-3.92-3.921-3.921,3.921-2.427-2.425,6.348-6.348Z' transform='translate(36.648 18.326)' fill='%23302393'%3E%3C/path%3E%3C/g%3E%3C/svg%3E ");
    background-repeat: no-repeat;
    background-size: auto 18px; /* Height of 8px while maintaining aspect ratio */
    width: 18px; /* Adjust as needed */
    height: 18px; /* Set height explicitly */
}

ul.blue-list {
    list-style-type: none; /* Remove default bullets */
    padding: 0;
}

ul.blue-list li {
    position: relative;
    padding-left: 30px; /* Space for the graphic */
    margin-top: 12px;
}

ul.blue-list li::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' id='Component_13_1' data-name='Component 13 – 1' width='4' height='8' viewBox='0 0 8.773 12.694'%3E%3Cg id='Group_69' data-name='Group 69' transform='translate(8.773) rotate(90)'%3E%3Cpath id='Path_13' data-name='Path 13' d='M-23.954-11.978l-2.427,2.425-3.92-3.921-3.921,3.921-2.427-2.425,6.348-6.348Z' transform='translate(36.648 18.326)' fill='%23302393'%3E%3C/path%3E%3C/g%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-size: auto 18px; /* Height of 8px while maintaining aspect ratio */
    width: 18px; /* Adjust as needed */
    height: 18px; /* Set height explicitly */
}

.blue-list li:empty {
    list-style: none;
    display: none; /* volitelně, pokud nechceš ani místo */
}

.contact-container {
    width: 1366px;
    height: auto; /* Let the height adjust based on content */
    border-radius: 0 0 0 72px;
    background-color: #FFFFFF;
    display: flex;
    gap: 60px;
    flex-wrap: wrap;
    justify-content: center;
    align-items: flex-start; /* Align items to the top */
    .subject {
        width: 1104px; /* Takes full width */
        padding: 0; /* Adds space around the text */
        color: #302393 !important;
        text-align: left;
        box-sizing: border-box;
        margin: 71px 0 0 0;
    }
    .text {
        width: 1104px; /* Takes full width */
        padding: 0; /* Adds space around the text */
        color: #302393 !important;
        text-align: left;
        box-sizing: border-box;
        margin: 0 0 0 0;
    }
}

.top-zero {
    margin-top: 0 !important;
}

.contact-box {
    width: 522px;
    height: auto;
    padding: 0;
    justify-content: left;
    margin: 0 0 0 0;
    font-family: Fieldwork, Geo Bold, serif;
    font-weight: 400;
    .full {
        width: 100% !important;
    }
    .subject {
        width: 100%;
        font-size: 29px !important;
        color: #ff9b19 !important;
        margin: 0 0 0 0;
    }
    .notice {
        font-size: 20px !important;
        color: #302393;
    }
    .top {
        margin: 36px 0 0 0 !important;
    }
}

.contact-box-full {
    width: 1100px; /* Změna šířky */
    margin: 0;      /* Remove any margin */
    padding: 0;     /* Remove any padding */
    box-sizing: border-box;
}

.menu-wrapper {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%; /* full viewport */
    display: flex;
    justify-content: center; /* centrování obsahu */
    z-index: 1000;
    background-color: var(--color-white);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

.menu-container {
    width: 100%;
    max-width: 1366px;
    background-color: #fff;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px;
    box-sizing: border-box;
    flex-direction: column; /* pokud chceš */
    .menu-container-logo {
        width: 106px;
        padding: 24px 0 0 0;
        flex-direction: column;
        align-items: center;
        gap: 10px;
}

.menu-container-top {
    width: 100%;
    max-width: 1366px;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 60px;
    padding: 0 20px;
}
    margin: 0 0 0 0;
    &.logo-top {
        width: 106px;
        border: 0;
    }
}

.menu-container-links {
    flex: 1 1 auto;
    max-width: 1366px;
    min-width: 200px;
    padding: 24px 0 0 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 58px;
    .item {
        font-family: Fieldwork, Geo Bold, serif;
        font-weight: 700;
        font-size: 16px;
        color: #302393;
        padding: 11px 0 0 0;
        text-decoration: none !important;
        &:hover,
        &:focus,
        &:active,
        &:link,
        &:visited {
            color: #302393 !important;
            text-decoration: none !important;
        }
        &.button  {
            background-color: #302393 !important;
            color: #ff9b19 !important;
            border-radius: 30px 30px 30px 0 !important;
            padding: 11px 22px 11px 22px;
            text-decoration: none !important;
            &.orange {
                background-color: #ff9b19 !important;
                color: #ffffff !important;
            }
        }
    }
}

.menu-container-login {
    width: 100%;
    max-width: 1366px;
    padding: 0;
    display: flex;
    justify-content: flex-end;
    flex: 1 1 auto;
}

.menu-container-hamburger {
    display: none;
}

.mobile-menu-links {
    display: none;
}

.subject {
    margin: 0 0 24px 0;
    width: 100%;
    font-family:  Fieldwork, Geo Bold, serif;
    font-weight: 700;
    font-size: 29px;
    text-align: left;
}

.price-row {
    flex: 1;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    width: 100%;
    .subject {
        margin: 0 0 24px 0;
        width: 100%;
        font-family:  Fieldwork, Geo Bold, serif;
        font-weight: 700;
        font-size: 29px;
    }
    .text {
        margin: 0 0 24px 0;
        width: 100%;
        box-sizing: border-box;
        font-family:  Fieldwork, Geo Bold, serif;
        font-weight: 400;
        text-align: left;
        font-size: 18px;
        &.order-type-margins {
            width: calc(100% - 60px);
            margin: 24px 0 0 50px !important;
        }
    }
}


.price-box {
    padding: 16px;
    border: solid 2px #ff9b19;
    font-size: 24px;
    font-family: Fieldwork, Geo Bold, serif;
    color: #ff9b19;
    display: inline-block;
    white-space: nowrap;
}

.styled-select {
    appearance: none; /* Remove default arrow */
    -webkit-appearance: none; /* Safari */
    -moz-appearance: none; /* Firefox */
    background-color: white;
    border: none;
    border-bottom: 2px solid #ff9b19;
    padding: 8px 30px 8px 12px;
    color: #302393;
    font-family: Fieldwork, Geo Bold, sans-serif; /* Ensure bold font is used */
    font-size: 20px;
    font-weight: bold; /* Force bold weight */
    height: 50px; /* Set height */
    position: relative;
    outline: none;
    width: 100%; /* Full width */
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23ff9b19' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 8px center;
    background-size: 20px;
    cursor: pointer;
    &.margin-left {
        margin-left: 64px;
    }
    &.show {
        display: none;
    }
}

.align-it-left {
    text-align: left !important;
}

.styled-select option {
    font-family: Fieldwork, Geo Bold, sans-serif; /* Set your custom font */
    font-weight: bold;
    color: #302393; /* Text color for options */
    background-color: white; /* Background color for options */
}

.styled-select:hover, .styled-select:focus {
    border-color: #FFFFFF; /* Change border color on hover/focus */
}

.styled-checkbox {
    appearance: none; /* Remove default styles */
    -webkit-appearance: none;
    -moz-appearance: none;
    width: 24px;
    height: 24px;
    border: 2px solid #ff9b19; /* Orange border */
    border-radius: 4px;
    background-color: white;
    cursor: pointer;
    position: relative;
    display: inline-block;
    transition: all 0.3s ease-in-out;    font-size: 20px;
    /*&label {*/
    /*    font-weight: bold;*/
    /*    color: #000000 !important; !* Dark blue text *!*/
    /*}*/
}

/* Checked state - Add a checkmark */
.styled-checkbox:checked {
    /*background-color: #ff9b19; !* Orange background when checked *!*/
    border-color: #ff9b19;
}

/* Checkmark (✓) when checked */
.styled-checkbox:checked::before {
    content: "✓"; /* Unicode checkmark */
    color: #ff9b19;
    font-size: 32px;
    font-weight: bold;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
}

/* Add focus outline */
.styled-checkbox:focus {
    outline: 2px solid #ff9b19;
    outline-offset: 2px;
}

.checkbox-text {
    font-family: Fieldwork, Geo Bold, sans-serif;
    font-size: 20px;
    margin: 0;
    padding: 0;
    display: inline-block;
}

.item-input {
    width: 100%;
    min-height: 50px;
    margin: 12px 0 0 0;
    padding: 0;
    display: flex;
    flex-direction: column;
}


.item-select {
    width: 100%; /* Full width of the container */
    min-height: 50px;
    margin: 12px 0 0 0;
    padding: 0;
    display: flex;
    .left {
        text-align: left !important;
        flex-grow: 1; /* Takes up remaining space */
        max-width: calc(100% - 50px);
        padding: 15px 0 15px 0;
        border-bottom: solid 2px #ff9b19;
        cursor: pointer;
    }
    .right {
        width: 50px; /* Fixed width */
        text-align: center;
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='30' height='30' viewBox='0 0 34 34' fill='none' stroke='%23ff9b19' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
        background-repeat: no-repeat;
        background-position: 10px 10px;
        background-size: 40px;
        border-bottom: solid 2px #ff9b19;
        cursor: pointer;
    }
    .info {
        text-align: left !important;
        width: 100%;
        padding: 5px 0 5px 0;
        display: block;
        overflow: hidden;
        animation: slideDown 1s ease-out;
    }
}

@keyframes slideDown {
    from {
        opacity: 0;
        max-height: 0;
    }
    to {
        opacity: 1;
        max-height: 500px; /* Set a reasonable max height */
    }
}

.item-basket {
    width: 100%; /* Full width of the container */
    height: auto;
    margin: 2px 0 0 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    .left {
        width: 60%;
        padding: 0;
        margin: 12px 0 0 0;
        text-align: left;
    }
    .right {
        width: 40%;
        margin: 12px 0 0 0;
        text-align: right;
    }
    .info {
        width: 100%;
        padding: 8px 0 15px 0;
        height: auto;
        border-bottom: solid 2px #E3E3E3;
        text-align: left;
    }
}

.styled-radio-block {
    margin-bottom: 2rem;
    padding: 1rem;
    border: 1px solid var(--color-light-gray);
    border-radius: 8px;
    transition: border 0.3s;
}

.styled-radio-block:hover {
    border-color: var(--color-orange);
}

.styled-radio-label {
    display: flex;
    align-items: center;
    gap: 16px;
    cursor: pointer;
}

.styled-radio-label input[type="radio"] {
    appearance: none;
    -webkit-appearance: none;
    width: 12px;
    height: 12px;
    border: 2px solid var(--color-orange);
    border-radius: 50%;
    position: relative;
    cursor: pointer;
}

.styled-radio-label input[type="radio"]:checked {
    border-color: var(--color-orange);
}

.styled-radio-label input[type="radio"]:checked::before {
    content: ''; /* Prázdný obsah pro vnitřní kruh */
    position: absolute;
    top: 15%;
    left: 15%;
    width: 70%;
    height: 70%;
    background-color: var(--color-orange); /* Bílý vnitřní kruh */
    border-radius: 50%;
}

.styled-radio-label input[type="radio"]:focus {
    outline: none;  /* Žádný obrys při fokusu */
}

.styled-radio-extra {
    margin-left: 2rem;
    margin-top: 0.5rem;
    font-size: 0.9rem;
    color: var(--color-white);
    line-height: 1.4;
}


.hidden {
    display: none;
}

.hand {
    cursor: pointer;
}

h1 {
    font-family: Fieldwork, Geo Bold, serif;
    font-size: 89px;
    line-height: 81px;
    font-weight: 700;
    margin: 0;
    padding: 0;
}

h2 {
    font-family: Fieldwork, Geo Fieldwork, Geo DemiBold, serif;
    font-size: 20px;
    line-height: 24px;
    font-weight: 400;
    margin: 0;
    padding: 0;
}

h3 {
    font-family: Fieldwork, Geo Bold, serif;
    font-size: 68px;
    line-height: 62px;
    font-weight: 700;
    margin: 0;
    padding: 0;
}

/*input {*/
/*    border: 0;*/
/*    padding: 10px;*/
/*    font-size: 16px;*/
/*    border-radius: 4px;*/
/*    height: 34px;*/
/*    width: 100%;*/
/*    box-sizing: border-box;*/
/*    background-color: #f7f7f7;*/
/*    &.white {*/
/*        background-color: #FFFFFF !important;*/
/*        color: #000000 !important;*/
/*    }*/
/*}*/

input {
    border: 0;
    padding: 10px;
    font-size: 16px;
    border-radius: 4px;
    height: 48px;
    width: 100%;
    box-sizing: border-box;
    background-color: #f7f7f7;
    &.white {
        background-color: #FFFFFF !important;
        color: #000000 !important;
    }
}

textarea {
    border: 0;
    padding: 10px;
    font-size: 16px;
    border-radius: 4px;
    width: 100% !important;
    box-sizing: border-box;
    background-color: #f7f7f7;
    &.white {
        background-color: #FFFFFF !important;
        color: #000000 !important;
    }
}

.label {
    font-family: Fieldwork, Geo Bold, serif;
    font-weight: 700;
    font-size: 20px;
    color: #302393;
    margin-bottom: 6px;
    display: block;
    text-align: left;
}

.select {
    display: block;
    width: 100%;
}

label[for="formContact"],
label[for="formLogin"],
label[for="formOverview"] {
    font-family: Fieldwork, Geo Bold, serif;
    font-weight: 700;
    font-size: 20px;
    color: #302393;
    margin-bottom: 6px;
    display: inline-block;
}

label[for="formAdditional"],
label[for="checkboxLabel"] {
    font-family: Fieldwork, Geo Bold, serif;
    font-weight: 700;
    font-size: 18px;
    color: #302393;
    margin-top: 12px;
    margin-bottom: 6px;
    display: inline-block;
}

label[for="formOperator"],
label[for="formInsurance"]{
    font-family: Fieldwork, Geo Bold, serif;
    font-weight: 700;
    font-size: 24px;
    color: #302393;
    margin-bottom: 6px;
    display: inline-block;
}

.checkbox-wrapper {
    display: flex;
    align-items: center;
    gap: 12px;
}

.fs-89 {
    font-size: 89px;;
}

.fs-68 {
    font-size: 68px;
}

.fs-48 {
    font-size: 48px;
}

.fs-29 {
    font-size: 29px;
}

.fs-24 {
    font-size: 24px;
}

.fs-20 {
    font-size: 20px;
}

.fs-18 {
    font-size: 18px;
}

.fs-16 {
    font-size: 16px;
}

.fs-15 {
    font-size: 13px;
}

.fs-13 {
    font-size: 13px;
}

.fw-bold {
    font-weight: 700;
}

.fw-medium {
    font-weight: 400;
}

.fw-regular {
    font-weight: 300;
}

.fc-blue {
    color: var(--color-blue);
}

.fc-orange {
    color: var(--color-orange);
}

.fc-light-orange {
    color: var(--color-light-orange);
}

.fc-light-gray {
    color: var(--color-light-gray);
}

.fc-gray {
    color: var(--color-gray);
}

.fc-dark-gray {
    color: var(--color-dark-gray);
}

.fc-white {
    color: var(--color-white);
}

.bc-blue {
    background-color: var(--color-blue);
}

.bc-orange {
    background-color: var(--color-orange);
}

.bc-light-orange {
    background-color: var(--color-light-orange);
}

.bc-light-gray {
    background-color: var(--color-light-gray);
}

.bc-gray {
    background-color: var(--color-gray);
}

.bc-dark-gray {
    background-color: var(--color-dark-gray);
}

.bc-white {
    background-color: var(--color-white);
}

.price-button-row {
    display: flex;
    align-items: center;
    gap: 16px; /* mezera mezi cenou a tlačítkem */
}

.login-container {
    width: 1366px;
    height: auto; /* Let the height adjust based on content */
    border-radius: 0 0 0 72px;
    background-color: var(--color-light-gray);
    display: flex;
    gap: 60px;
    flex-wrap: wrap;
    justify-content: center;
    align-items: flex-start; /* Align items to the top */
    .subject {
        width: 1104px; /* Takes full width */
        padding: 0; /* Adds space around the text */
        color: #302393 !important;
        text-align: left;
        box-sizing: border-box;
        margin: 71px 0 0 0;
    }
    .text {
        width: 1104px; /* Takes full width */
        padding: 0; /* Adds space around the text */
        color: #302393 !important;
        text-align: left;
        box-sizing: border-box;
        margin: 0 0 0 0;
    }
}

.login-box {
    width: 522px;
    height: auto;
    padding: 0;
    justify-content: left;
    margin: 0 0 0 0;
    font-family: Fieldwork, Geo Bold, serif;
    font-weight: 400;
    .full {
        width: 100% !important;
    }
    .subject {
        width: 100%;
        font-size: 29px !important;
        color: #ff9b19 !important;
        margin: 0 0 0 0;
    }
    .notice {
        font-size: 20px !important;
        color: #302393;
    }
    .top {
        margin: 36px 0 0 0 !important;
    }
}

.login-box-full {
    width: 1100px; /* Změna šířky */
    margin: 0;      /* Remove any margin */
    padding: 0;     /* Remove any padding */
    box-sizing: border-box;
}

.checkbox-wrapper .form-group {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 0;
    padding: 0;
}

/* Checkbox samotný */
.checkbox-wrapper input[type="checkbox"] {
    width: 24px;
    height: 24px;
    margin: 0;
    cursor: pointer;
}

/* Label */
.checkbox-wrapper label {
    margin: 0;
    font-size: 16px;
    cursor: pointer;
}

.td-none {
    text-decoration: none;
}

.flash-message {
    padding: 12px 20px;
    margin: 12px 0;
    border-radius: 6px;
    font-weight: bold;
    font-size: 16px;
    opacity: 1;
    transition: opacity 0.5s ease-out;
}

.flash-success {
    color: var(--color-green);
}

.flash-error {
    color: var(--color-red);
}

.has-error input {
    border: 1px solid var(--color-red); /* třeba #D9434E */
    background-color: #fff0f0;
}

.form-error {
    color: var(--color-red);
    font-size: 14px;
    margin-top: 4px;
}