html {
    scroll-behavior: smooth;
}

.flex {
    display: flex;
}

.flex-direction-row {
    flex-direction: row;
}

.flex-direction-column {
    flex-direction: column;
}

.flex-wrap {
    flex-wrap: wrap;
}

.flex-nowrap {
    flex-wrap: nowrap;
}

.flex-justify-start {
    justify-content: flex-start;
}

.flex-justify-end {
    justify-content: flex-end;
}

.flex-justify-center {
    justify-content: center;
}

.flex-justify-between {
    justify-content: space-between;
}

.flex-align-start {
    align-items: flex-start;
}

.flex-align-end {
    align-items: flex-end;
}

.flex-align-center {
    align-items: center;
}

.flex-grow {
    flex-grow: 1;
}

.grid-layout {
    display: grid;
}

@media screen and (min-width: 481px) {
    .grid-layout-column-3 {
        grid-template-columns: repeat(2, 1fr);
    }
    .grid-layout-column-4 {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media screen and (min-width: 577px) {
    .grid-layout--footer {
        grid-template-columns: 1.5fr 1fr;
    }
}

@media screen and (min-width: 771px) {
    .grid-layout--footer {
        grid-template-columns: 1.5fr repeat(2, 1fr);
    }
    .grid-layout--left-asymmetrical,
    .grid-layout--right-asymmetrical {
        grid-template-columns: repeat(2, 1fr);
    }
    .grid-layout-column-2 {
        grid-template-columns: repeat(2, 1fr);
    }
    .grid-layout-column-3 {
        grid-template-columns: repeat(3, 1fr);
    }
    .grid-layout-column-4 {
        grid-template-columns: repeat(4, 1fr);
    }
}

@media screen and (min-width: 1025px) {
    .grid-layout--left-asymmetrical {
        grid-template-columns: 1.4fr 1fr;
    }
    .grid-layout--right-asymmetrical {
        grid-template-columns: 1fr 1.4fr;
    }
}


.gap-8 {
    gap: 8px;
}

.gap-12 {
    gap: 12px;
}

.gap-16 {
    gap: 16px;
}

.gap-24 {
    gap: 24px;
}

.gap-48 {
    gap: 48px;
}

.rounding-6 {
    border-radius: 6px;
}

.rounding-8 {
    border-radius: 8px;
}

.rounding-12 {
    border-radius: 12px;
}

.linear-gradient::after {
    content: "";
    width: 100%;
    height: 101%;
    display: block;
    background: linear-gradient(180deg, rgba(44, 50, 69, 0.60) 10%, var(--dark-blue-color) 100%);
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
}

.overflow {
    overflow: hidden;
}


#program .time-block{
    text-shadow: 0 1px black;
}

@media screen and (max-width: 770px) {
    .hidden-770 {
        display: none;
    }
}

.hidden {
    display: none;
}