html {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    width: 100%;
    min-height: 100%;
    scroll-behavior: smooth;
}

body {
    font-family: var(--font-family);
    font-weight: 400;
    font-size: 16px;
    line-height: 148%;
    color: #000;
    width: 100%;
    min-width: 300px;
    min-height: 100vh;
    background: white;
    padding: 0;
    margin: 0;
}

*,
*::before,
*::after {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

a {
    cursor: pointer;
    text-decoration: none;
}

.color-white {
    color: #FFF !important;
}

header {
    padding: 20px 0 16px;
}

    header .bar {
        background: #ebf0f5;
        padding: 12px;
        display: flex;
        align-items: center;
        justify-content: space-between;
        flex-direction: row;
        flex-wrap: wrap;
        gap: 12px;
    }

        header .bar > a {
            border-radius: 431px;
            padding: 16px 20px;
            height: 44px;
            display: inline-flex;
            background: #9baabb;
            font-size: 15px;
            line-height: 100%;
            color: #fff;
            text-decoration: none;
            flex-grow: 0;
            justify-content: space-between;
            align-items: center;
        }

        header .bar a.lang {
            display: none;
        }

        header .bar a.partner {
            gap: 10px;
            flex-grow: 1;
            padding-right: 4px;
            background-color: #90baff;
            order: 1;
        }

            header .bar a.partner::after {
                content: '';
                display: block;
                width: 36px;
                height: 36px;
                background-image: url(/img3/right-ico.svg);
                background-position: 50% 50%;
                background-size: cover;
                background-repeat: no-repeat;
            }

        header .bar .navbar-closer {
            display: none;
            float: right;
        }

            header .bar .navbar-closer a {
                display: inline-block;
                width: 42px;
                height: 42px;
                background-color: #90baff;
                background-image: url('data:image/svg+xml,<svg width="42" height="42" viewBox="0 0 42 42" fill="none" xmlns="http://www.w3.org/2000/svg"><rect x="15" y="13" width="20" height="3" rx="1.5" transform="rotate(45 15 13)" fill="white" /><rect x="13" y="27.1421" width="20" height="3" rx="1.5" transform="rotate(-45 13 27.1421)" fill="white" /></svg>');
                background-repeat: no-repeat;
                background-position: center;
                background-size: 100%;
                border-radius: 50%;
            }

@media (min-width:576px) {

    header .bar {
        padding: 14px 21px;
    }

        header .bar > a {
            font-size: 17px;
        }

        header .bar a.partner {
            order: 0;
        }
}

@media (min-width: 768px) {
    header .bar {
        padding: 10px 33px;
    }
}

@media (max-width: 992px) {

    header .bar-show .navbar-toggler {
        display: none;
    }

    header .bar-show .navbar-closer {
        display: flex;
        justify-content: space-between;
        flex-grow: 1;
        font-family: var(--second-family);
        font-size: 22px;
        align-items: center;
    }

    header .bar:not(.bar-show) a.collapse {
        display: none;
    }

    header .bar-show {
        align-items: center;
        flex-wrap: wrap;
        gap: 6px 12px;
    }

        header .bar-show a.collapse {
            flex-basis: 100%;
            color: #000;
            border-radius: 0;
            background: no-repeat;
            padding-left: 0;
        }
}

@media (min-width: 992px) {
    header .bar {
        padding: 48px 44px;
        justify-content: center;
    }

        header .bar .navbar-toggler {
            justify-content: center;
        }

        header .bar .navbar-toggler {
            display: none;
        }

        header .bar > a {
            padding: 16px 18px;
        }

        header .bar a.partner {
            flex-grow: 0;
        }
}

@media (min-width: 1400px) {
    header .bar {
        padding: 14px 44px;
        gap: 17px;
    }
}

.content section:not(:first-child),
footer section:not(:first-child) {
    margin-top: 16px;
}

section.head {
    display: flex;
    align-items: stretch;
    justify-content: flex-start;
    flex-direction: column;
    gap: 16px;
}

    section.head .logo-security .b {
        position: relative;
        padding-top: 62.85714285714286%;
        background-color: #EBF0F5;
    }

    section.head .logo-security .c {
        position: absolute;
        top: 20px;
        left: 20px;
        right: 20px;
        bottom: 20px;
        overflow: hidden;
        background-image: url(/img3/logo-week.svg);
        background-repeat: no-repeat;
        background-position: 0 0;
        background-size: contain;
    }

    section.head .dates .b {
        position: relative;
        padding-top: 62.85714285714286%;
        background-color: #c8cdd7;
    }

    section.head .dates .c {
        position: absolute;
        top: 20px;
        left: 20px;
        right: 20px;
        bottom: 20px;
        display: flex;
        align-items: stretch;
        justify-content: space-between;
        flex-direction: column;
    }

    section.head .dates .title {
        display: flex;
        align-items: center;
        justify-content: space-between;
        flex-direction: row;
    }

        section.head .dates .title::after {
            content: '';
            display: block;
            width: 40px;
            height: 40px;
            background-image: url(/img3/ok-ico.svg);
            background-position: 50% 50%;
            background-size: cover;
            background-repeat: no-repeat;
        }

    section.head .dates .date {
        font-weight: 400;
        font-size: 32px;
        font-family: var(--second-family);
    }

    section.head .logo-socforum .b {
        position: relative;
        padding-top: 80%;
        background-color: #ebf0f5;
    }

    section.head .logo-socforum .c {
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        overflow: hidden;
        background-image: url(/img3/logo-soc-forum.png);
        background-repeat: no-repeat;
        background-position: 0 0;
        background-size: auto 85%;
    }


    section.head .reg-link {
        background: #000;
        padding: 19px 20px 23px 24px;
    }

        section.head .reg-link a {
            font-weight: 400;
            font-size: 24px;
            line-height: normal;
            color: #fff;
            display: flex;
            flex-direction: column;
            align-items: stretch;
            height: 100%;
        }

            section.head .reg-link a::after {
                content: '';
                display: block;
                width: 34.34px;
                height: 34.34px;
                background-image: url(/img3/down-ico.svg);
                background-position: 50% 50%;
                background-size: cover;
                background-repeat: no-repeat;
                align-self: flex-end;
                margin-top: -4px;
            }

@media (min-width:576px) {

    section.head {
        flex-direction: row;
        flex-wrap: wrap;
    }

        section.head > div {
            width: calc(50% - 8px);
        }

        section.head .logo-socforum .b {
            padding-top: 62.85714285714286%;
        }

        section.head .reg-link a span {
            flex-grow: 1;
        }

        section.head .reg-link a::after {
            width: 40px;
            height: 40px;
            margin-top: 0;
        }
}

@media (min-width: 768px) {
    section.head .logo-security,
    section.head .logo-socforum {
        width: calc(44.44444444% - 8px);
    }

    section.head .dates,
    section.head .reg-link {
        width: calc(55.55555556% - 8px);
    }

        section.head .logo-security .c,
        section.head .dates .c {
            top: 23px;
            left: 23px;
            right: 23px;
            bottom: 23px;
        }

    section.head .logo-security .b {
        padding-top: 62.71523178807947%;
    }

    section.head .dates .b {
        padding-top: 49.58115183246073%;
    }

    section.head .logo-socforum .b {
        padding-top: 74.17218543046358%;
    }

    section.head .reg-link {
        padding: 19px 20px 26px 24px;
    }

        section.head .reg-link a {
            font-size: 40px;
        }

            section.head .reg-link a::after,
            section.head .dates .title::after {
                width: 52px;
                height: 52px;
            }
}



@media (min-width: 992px) {
    section.head .logo-security,
    section.head .logo-socforum {
        width: calc(55.55555556% - 8px);
    }

    section.head .dates,
    section.head .reg-link {
        width: calc(44.44444444% - 8px);
    }

    section.head .logo-security .c {
        top: 34px;
        left: 32px;
        right: 33px;
        bottom: 17px;
    }

    section.head .dates .c {
        top: 31px;
        left: 32px;
        right: 32px;
        bottom: 35px;
    }

    section.head .logo-security .b {
        padding-top: 58.64077669902913%;
    }

    section.head .dates .b {
        padding-top: 73.83863080684597%;
    }

    section.head .logo-socforum .b {
        padding-top: 79.02912621359223%;
    }

    section.head .dates .title {
        font-size: 24px;
        line-height: 145%;
    }

    section.head .dates .date {
        font-size: 55px;
    }

    section.head .dates .title::after {
        width: 68px;
        height: 68px;
    }

    section.head .reg-link {
        padding: 19px 38px 54px 30px;
    }

        section.head .reg-link a {
            font-size: 52px;
        }

            section.head .reg-link a::after {
                width: 115px;
                height: 115px;
            }
}


@media (min-width: 1400px) {
    section.head .dates .date {
        font-size: 70px;
    }

    section.head .logo-socforum .b {
        padding-top: 59%;
    }

    section.head .logo-socforum .c {
        background-size: auto 95%;
    }

    section.head .reg-link a {
        font-size: 76px;
    }

    section.head .reg-link {
        padding: 19px 58px 54px 30px;
    }
}




section.regs {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

    section.regs .info {
        padding: 34px 20px;
        background-color: #ebf0f5;
        display: flex;
        flex-direction: column;
        gap: 49px;
    }

    section.regs .thanks-info {
        gap: 20px;
    }

    section.regs .info .agenda {
        display: flex;
        flex-direction: column;
        gap: 26px;
    }

        section.regs .info .agenda .agenda-type span {
            display: inline-block;
            background-color: #000;
            color: #fff;
            border-radius: 600px;
            line-height: 100%;
            padding: 7px 12px;
        }

        section.regs .info .agenda .agenda-day {
            display: flex;
            justify-content: center;
            flex-direction: column;
            gap: 12px;
        }

        section.regs .info .agenda .day-date span {
            border: 1px solid #000;
            border-radius: 431px;
            line-height: 100%;
            padding: 7px 12px;
        }

        section.regs .info .agenda .day-description {
            line-height: 133%;
            color: #9baabb;
        }

    section.regs h2 {
        font-size: 24px;
        font-weight: 400;
        line-height: normal;
        margin: 0;
    }

    section.regs h3 {
        font-weight: 400;
        font-size: 12px;
        line-height: 110%;
        color: #fff;
        border-radius: 431px;
        padding: 13px 20px;
        background: #9baabb;
        text-align: left;
        margin: 0;
    }

    section.regs h2 ~ h3 {
        margin-top: 16px;
    }

    section.regs .prices {
        display: flex;
        flex-direction: column;
        gap: 34px;
    }

        section.regs .prices .price-type {
            display: flex;
            flex-direction: column;
            gap: 40px;
            font-weight: 400;
            font-size: 16px;
            line-height: 148%;
            gap: 13px;
        }

            section.regs .prices .price-type .price {
                font-family: var(--second-family);
                font-weight: 400;
                font-size: 35px;
                line-height: 100%;
                color: #90baff;
            }

            section.regs .prices .price-type .price-description {
                font-size: 10px;
                line-height: 136%;
            }

.progress-container {
    position: relative;
    width: 100%;
    height: 8px;
    overflow: hidden;
}

.progress-bar {
    position: absolute;
    height: 4px;
    background-color: #c8cdd7; /* Серый цвет */
    border-radius: 2px; /* Скругление углов */
    width: 100%;
    top: 2px;
}

.progress-fill {
    position: absolute;
    height: 8px;
    background-color: #000; /* Черный цвет */
    border-radius: 4px; /* Скругление углов */
    width: 30%; /* Начальная ширина, можно менять */
    left: 0;
}

section.regs .review-period {
    display: flex;
    flex-direction: column;
    gap: 19px;
}

    section.regs .review-period .review-period-days .digit {
        font-size: 52px;
    }

    section.regs .review-period .description {
        font-size: 16px;
        line-height: 148%;
        color: #9baabb;
    }

section.regs .reg-button {
    display: block;
    font-weight: 400;
    font-size: 20px;
    line-height: 100%;
    text-align: center;
    color: #fff;
    border-radius: 431px;
    padding: 29.5px 0;
    background: #90baff;
    text-decoration: none;
}

section.regs .info-active {
    background-color: #90BAFF;
    gap: 40px
}

    section.regs .info-active .description {
        display: flex;
        justify-content: space-between;
        font-size: 14px;
        line-height: 113%;
        color: #fff;
        align-items: center;
        margin-top: 9px;
        gap: 10px;
    }

        section.regs .info-active .description > div {
            flex-basis: auto;
            text-align: center;
        }

            section.regs .info-active .description > div:first-child {
                text-align: left;
            }

            section.regs .info-active .description > div:last-child {
                text-align: right;
            }

        section.regs .info-active .description .current-step {
            color: #000000;
        }

    section.regs .info-active .progress-bar {
        background-color: #ebf0f5; /* Серый цвет */
    }

    section.regs .info-active .progress-fill {
        background-color: #FFF;
        width: 33.333333333%; /* Начальная ширина, можно менять */
    }

section.regs .two-steps .progress-fill {
    width: 50%; /* Начальная ширина, можно менять */
}

section.regs .two-steps .description > div:nth-child(n+3) {
    display: none;
}

section.regs .step2 .progress-fill {
    width: 66.666666666%;
}

section.regs .step3 .progress-fill,
section.regs .two-steps .step2 .progress-fill {
    width: 100%;
}



@media (min-width:576px) {

    section.regs .info {
        padding: 28px 20px 18px;
        gap: 80px;
    }

    section.regs .thanks-info {
        gap: 20px;
    }

    section.regs .info-smi {
        padding-top: 80px;
    }

    section.regs .info .agenda {
        font-size: 24px;
        gap: 52px;
    }

        section.regs .info .agenda .agenda-type span {
            padding: 13px 36px;
        }

        section.regs .info .agenda .agenda-day {
            flex-direction: row;
            justify-content: flex-start;
            align-items: center;
        }

            section.regs .info .agenda .agenda-day .day-date {
                font-size: 20px;
            }

        section.regs .info .agenda .day-date span {
            padding: 12px 34px;
        }

    section.regs h2 {
        font-size: 52px;
    }

    section.regs h3 {
        font-size: 24px;
        padding: 12px 32px;
    }

    section.regs .prices {
        gap: 24px;
    }

        section.regs .prices .price-type {
            font-size: 24px;
            gap: 14px;
        }

            section.regs .prices .price-type .price {
                font-size: 46px;
            }

            section.regs .prices .price-type .price-description {
                font-size: 14px;
            }

    section.regs .review-period {
        gap: 36px;
    }

        section.regs .review-period .review-period-days {
            font-size: 34px;
            white-space: nowrap;
        }

            section.regs .review-period .review-period-days .digit {
                font-size: 76px;
                margin-right: 11px;
            }

        section.regs .review-period .description {
            font-size: 24px;
        }

    section.regs .reg-button-block {
        display: flex;
        flex-direction: row;
        align-items: stretch;
        gap: 16px;
    }

        section.regs .reg-button-block::after {
            content: '';
            display: block;
            width: 160px;
            height: 160px;
            background-image: url(/img3/up-right-ico.svg);
            background-position: 50% 50%;
            background-size: cover;
            background-repeat: no-repeat;
        }

    section.regs .reg-button {
        display: flex;
        flex-grow: 1;
        justify-content: center;
        align-items: center;
        font-size: 24px;
    }

    section.regs .info-active {
        gap: 36px
    }
}

@media (min-width: 768px) {
    section.regs .info {
        padding: 23px 24px 30px;
        gap: 67px;
    }

    section.regs .thanks-info {
        gap: 20px;
    }

    section.regs .info-smi {
        padding-top: 102px;
        padding-bottom: 27px;
    }

    section.regs .info .agenda {
        flex-direction: row;
        flex-wrap: wrap;
        gap: 0;
        justify-content: space-between;
    }

        section.regs .info .agenda .agenda-type {
            flex-basis: 100%;
            margin-bottom: 61px;
        }

        section.regs .info .agenda .agenda-day {
            flex-direction: column;
            align-items: flex-start;
            gap: 25px;
        }

    section.regs h2 {
        font-size: 76px;
    }

    section.regs h3 {
        display: inline-block;
        padding: 9px 21px;
    }

    section.regs h2 ~ h3 {
        margin-top: 21px;
    }

    section.regs .prices {
        gap: 54px;
    }

        section.regs .prices .price-type {
            gap: 29px;
        }

            section.regs .prices .price-type .price {
                font-size: 76px;
                line-height: 100%;
            }

            section.regs .prices .price-type .price-description {
                font-size: 23px;
                line-height: 100%;
            }

    section.regs .review-period {
        flex-direction: row;
        flex-wrap: wrap;
        gap: 0;
        align-items: baseline;
    }

        section.regs .review-period .progress-container {
            flex-basis: 100%;
            flex-grow: 1;
            margin-bottom: 48px;
        }

        section.regs .review-period .review-period-days {
            flex: 1;
        }

        section.regs .review-period .description {
            flex-shrink: 1;
        }

    section.regs .reg-button {
        font-size: 34px;
    }

    section.regs .reg-button-block::after {
        width: 144px;
        height: 144px;
    }

    section.regs .info-active {
        gap: 20px
    }

        section.regs .info-active .description {
            font-size: 16px;
        }
}

@media (min-width: 992px) {

    section.regs .info {
        padding: 27px 35px 33px;
        gap: 88px;
    }

    section.regs .thanks-info {
        gap: 20px;
        font-size: 22px;
        line-height: 1.4;
    }

    section.regs .info-smi {
        padding-top: 53px;
        padding-bottom: 50px;
    }

    section.regs .info .agenda {
        justify-content: flex-start;
        gap: 28px;
    }

        section.regs .info .agenda .agenda-day {
            align-items: flex-start;
            gap: 25px;
        }

        section.regs .info .agenda .agenda-type {
            margin-bottom: 33px;
        }

        section.regs .info .agenda .agenda-day .day-date {
            font-size: 24px;
        }

        section.regs .info .agenda .day-date span {
            padding: 9px 34px;
        }

    section.regs .review-period {
        gap: 38px 58px;
    }

        section.regs .review-period .review-period-days {
            flex: 0;
        }

        section.regs .review-period .progress-container {
            margin-bottom: 0;
        }

    section.regs .reg-button {
        padding: 27.5px 0;
    }

    section.regs .reg-button-block::after {
        width: 94px;
        height: 94px;
    }

    section.regs .info-active {
        gap: 20px;
    }

        section.regs .info-active .description {
            font-size: 24px;
        }
}

@media (min-width: 1400px) {
    section.regs .info .agenda {
        flex-wrap: nowrap;
        justify-content: space-between;
        align-items: baseline;
    }

        section.regs .info .agenda .agenda-type {
            flex-basis: auto;
            flex-grow: 1;
            margin-bottom: 0;
        }

    section.regs .prices {
        flex-direction: row;
        flex-wrap: wrap;
        align-content: stretch;
        gap: 56px 154px;
    }

        section.regs .prices .title {
            flex-basis: 100%;
            flex-grow: 1;
            flex-shrink: 0;
        }

        section.regs .prices .price-type {
            flex: 1;
            gap: 35px;
        }

    section.regs .info {
        padding: 29px 37px 64px 34px;
    }

    section.regs .info-smi {
        padding-top: 139px;
        padding-bottom: 39px;
    }

    section.regs .reg-button {
        padding: 46.5px 0;
    }

    section.regs .reg-button-block::after {
        width: 128px;
        height: 128px;
    }

    section.regs .info-active {
        padding-bottom: 35px;
    }
}


section.contacts {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

    section.contacts .address-block {
        padding: 20px 20px 13px;
        background: #c8cdd7;
        display: flex;
        flex-direction: column;
        gap: 49px;
    }

    section.contacts a.location {
        padding: 12px 20px;
        line-height: 100%;
        color: #000;
        text-decoration: none;
        background: #FFF;
        border-radius: 600px;
        display: inline-flex;
        flex-direction: row;
        align-items: center;
        flex-grow: 0;
        gap: 10px;
    }

        section.contacts a.location::before {
            content: '';
            display: block;
            width: 24px;
            height: 24px;
            background-image: url(/img3/location-ico.svg);
            background-position: 50% 50%;
            background-size: cover;
            background-repeat: no-repeat;
        }

    section.contacts .contacts-block {
        padding: 20px;
        background: #c8cdd7;
        display: flex;
        flex-direction: column;
        gap: 58px;
    }

        section.contacts .contacts-block .links {
            list-style: none;
            margin: 0;
            padding: 0;
        }

            section.contacts .contacts-block .links li:not(:first-child) {
                margin-top: 14px;
            }

            section.contacts .contacts-block .links a {
                line-height: 137%;
                color: #000;
                text-decoration: none;
            }

        section.contacts .contacts-block .contacts-links {
            display: flex;
            flex-direction: column;
            gap: 19px;
        }

            section.contacts .contacts-block .contacts-links .social {
                display: flex;
                flex-direction: row;
                gap: 12px;
                align-items: flex-start;
            }

                section.contacts .contacts-block .contacts-links .social a {
                    display: block;
                    width: 48px;
                    height: 48px;
                    background-position: 50% 50%;
                    background-repeat: no-repeat;
                    background-size: cover;
                }

a.vk {
    background-image: url(/img3/vk-ico.svg);
}

a.tg {
    background-image: url(/img3/tg-ico.svg);
}

footer {
    padding: 16px 0 20px;
}

section.map {
    height: 413px;
    background-image: url(/img3/map.jpg);
    background-position: 60% 50%;
    background-repeat: no-repeat;
    background-size: cover;
}

@media (min-width:576px) {
    section.contacts {
        font-size: 24px;
        line-height: 148%;
    }

        section.contacts .address-block {
            padding: 24px 24px 17px;
            gap: 88px;
        }

        section.contacts a.location {
            font-size: 20px;
        }

        section.contacts .contacts-block {
            padding: 15px 20px 24px;
            gap: 83px;
        }

            section.contacts .contacts-block .links li:not(:first-child) {
                margin-top: 3px;
            }

            section.contacts .contacts-block .contacts-links {
                flex-direction: row;
                align-items: center;
                justify-content: space-between;
            }
}

@media (min-width: 768px) {
    section.contacts {
        flex-direction: row;
        line-height: 103%;
    }

        section.contacts .address-block {
            width: calc(55.55555556% - 8px);
            gap: 110px;
            font-size: 34px;
            line-height: 50px;
        }

        section.contacts .contacts-block {
            width: calc(44.44444444% - 8px);
            padding: 23px 24px 24px;
        }

            section.contacts .contacts-block .links li:not(:first-child) {
                margin-top: 12px;
            }

            section.contacts .contacts-block .contacts-links {
                flex-direction: column;
                align-items: flex-start;
            }

            section.contacts .contacts-block .links a {
                line-height: 103%;
            }
}


@media (min-width: 992px) {

    section.contacts {
        font-size: 34px;
    }

        section.contacts .address-block {
            width: calc(44.44444444% - 8px);
            padding: 29px 30px 14px;
            gap: 82px;
        }

        section.contacts .contacts-block {
            width: calc(55.55555556% - 8px);
            padding: 17px 38px 33px 29px;
            gap: 112px;
        }

        section.contacts a.location {
            font-size: 24px;
            gap: 11px;
        }

            section.contacts a.location::before {
                width: 32px;
                height: 32px;
            }

        section.contacts .contacts-block .links li:not(:first-child) {
            margin-top: 4px;
        }

        section.contacts .contacts-block .links a {
            font-size: 24px;
        }

        section.contacts .contacts-block .contacts-links {
            flex-direction: row;
            align-items: center;
        }

            section.contacts .contacts-block .contacts-links .social a {
                width: 59px;
                height: 59px;
            }
}


@media (min-width: 1400px) {
    section.contacts .address-block {
        width: calc(33.33333333% - 8px);
        padding: 36px 30px 30px;
        gap: 45px;
    }

    section.contacts .contacts-block {
        width: calc(66.66666667% - 8px);
        padding: 25px 32px 36px 26px;
        gap: 60px;
    }

        section.contacts .contacts-block .contacts-links {
            align-items: flex-end;
        }

            section.contacts .contacts-block .contacts-links .social a {
                width: 74px;
                height: 74px;
            }
}




/* modal */
.modal-open {
    overflow: hidden;
}


.modal {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: +15000;
    display: none;
    overflow: hidden;
    -webkit-overflow-scrolling: touch;
    outline: 0;
    background: url('/img2/modal-bg.png') 0 0 repeat;
}

.modal-open .modal {
    overflow-x: hidden;
    overflow-y: auto;
}

.modal-dialog {
    display: -ms-flexbox;
    display: flex;
    position: relative;
    height: auto;
    padding: 0;
    background: #FFFFFF;
    width: 100%;
    max-width: 940px;
    margin: 1.75em auto;
    max-height: calc(100vh - 3.5em);
    border-radius: 10px;
}

.modal-dialog-scrollable {
}


.modal-dialog .modal-content {
    position: relative;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
    flex-direction: column;
    width: 100%;
    pointer-events: auto;
    outline: 0;
    max-height: calc(100vh - 1rem);
}

.modal-dialog .modal-header {
    padding: 12px 40px 12px 24px;
    position: relative;
    border-bottom: 1px solid #6666;
    font-family: var(--second-family);
}

.modal-dialog h1 {
    padding: 0;
    margin: 0;
    text-align: left;
    font-weight: normal;
    font-size: 24px;
    line-height: 30px;
}

    .modal-dialog h1 + p {
        padding: 0;
        margin: 0;
        text-align: left;
        font-weight: normal;
        font-size: 18px;
    }



.modal-dialog .close {
    position: absolute;
    right: 11px;
    top: 18px;
    font-size: 18px;
    line-height: 15px;
    color: #7ED6FC;
    width: 20px;
    height: 20px;
    background: transparent url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23000'%3e%3cpath d='M.293.293a1 1 0 0 1 1.414 0L8 6.586 14.293.293a1 1 0 1 1 1.414 1.414L9.414 8l6.293 6.293a1 1 0 0 1-1.414 1.414L8 9.414l-6.293 6.293a1 1 0 0 1-1.414-1.414L6.586 8 .293 1.707a1 1 0 0 1 0-1.414'/%3e%3c/svg%3e") center/1em auto no-repeat;
    opacity: .6;
}

    .modal-dialog .close:hover {
        opacity: 1;
    }

.modal-dialog .modal-body {
    overflow-y: auto;
    padding: 12px 24px 0;
    font-size: 16px;
    line-height: 19px;
    margin-bottom: 24px;
}

    .modal-dialog .modal-body ul,
    .modal-dialog .modal-body ol {
        padding-left: 1.75em;
    }

    .modal-dialog .modal-body ul,
    .modal-dialog .modal-body ol,
    .modal-dialog .modal-body p {
        margin: 1em 0;
    }

        .modal-dialog .modal-body ul:first-child,
        .modal-dialog .modal-body ol:first-child,
        .modal-dialog .modal-body p:first-child {
            margin-top: 0;
        }

        .modal-dialog .modal-body ul:last-child,
        .modal-dialog .modal-body ol:last-child,
        .modal-dialog .modal-body p:last-child {
            margin-bottom: 0;
        }



        .modal-dialog .modal-body ul li,
        .modal-dialog .modal-body ol li {
            margin-top: 0;
            margin-bottom: .5em;
        }

            .modal-dialog .modal-body ul li:last-child,
            .modal-dialog .modal-body ol li:last-child {
                margin-bottom: 0;
            }



.nav-tabs {
    display: flex;
    padding: 0;
    margin: 0;
    list-style: none;
    gap: 12px;
}

    .nav-tabs > li {
        position: relative;
        display: block;
        margin-bottom: -1px;
    }

        .nav-tabs > li > a {
            border-radius: 431px;
            padding: 16px 20px;
            height: 44px;
            display: inline-flex;
            background: #FFF;
            font-size: 15px;
            line-height: 100%;
            color: #000;
            text-decoration: none;
            flex-grow: 0;
            justify-content: space-between;
            align-items: center;
            text-transform: uppercase;
        }

        .nav-tabs > li.active > a, .nav-tabs > li.active > a:hover, .nav-tabs > li.active > a:focus {
            cursor: default;
            background-color: #90baff;
            color: #FFF;
        }

.tab-content {
    padding-top: 20px;
}

    .tab-content > .tab-pane {
        display: none;
    }

    .tab-content > .active {
        display: block;
    }

table.requests {
    border-collapse: collapse;
    width: 100%;
}
    table.requests > thead {
        vertical-align: bottom;
    }

    table.requests tbody, table.requests td, table.requests tfoot, table.requests th, table.requests thead, table.requests tr {
        border-color: inherit;
        border-style: solid;
        border-width: 0;
        text-align: inherit;
    }

    table.requests > :not(caption) > * > * {
        padding: .5rem .5rem;
        color: black;
        background-color: white;
        border-bottom-width: 1;
    }