@font-face {
    font-family: Montserrat;
    src: url('/fonts/Montserrat-VariableFont_wght.ttf');
}

body {
    font-family: Montserrat;
}

#banner {
    padding: 0;
    background-repeat: no-repeat;
    background-size: cover;
}

#banner .bg-image, #feedback-form-container {
    background-size: cover;
    height: 600px;
}

#banner .bg-image .container {
    color: white;
}

#banner h1 {
    margin-bottom: 42px;
}

#banner p {
    margin-bottom: 64px;
}

.single-event-banner#banner {
    background-color: gray;
    background-blend-mode: multiply;
    background-position: center;
}

.banner-caption {
    background-color: white;
    margin-top: -64px;
    margin-bottom: 48px;
}

.banner-caption hr {
    width: 28px;
    display: block;
    height: 1px;
    border: 0; border-top: 1px solid #2d2d2d;
}

.banner-caption .row div {
    padding: 32px 20px;
}

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

#home-program-block .item {
    height: 540px;
    width: 386px;
    padding: 36px;
    margin: 0 auto;
    color: white;
}

#home-program-block .item a, #feedback-form {
    color: white;
}

a {
    text-decoration: none;
}

a:hover {
    text-decoration: underline;
}

.expert-svg {
    margin-left: 8px;
}

#home-about a {
    color: black;
}

.block {
    margin-bottom: 82px;
}

h2, h4 {
    margin-bottom: 36px;
}

.nav-ml {
    margin-left: 32px;
}

.page-title {
    margin-top: 48px;
    margin-bottom: 86px;
}

.image-caption, .image-caption a {
    margin-top: 24px;
    margin-bottom: 0;
    text-align: center;
    color: #8f8f8f !important;
}

.client-item {
    height: 120px;
    filter: gray; /* IE6-9 */
    -webkit-filter: grayscale(1); /* Google Chrome, Safari 6+ & Opera 15+ */
    filter: grayscale(1); /* Microsoft Edge and Firefox 35+ */
}

.client-item img {
    max-height: 68px;
}

.bg-cover {
    background-size: cover;
    background-repeat: no-repeat;
    background-position: 50% 50%;
    height: 100%;
}

.loader {
    border: 8px solid #f3f3f3;
    border-radius: 50%;
    border-top: 8px solid #cd3259;
    width: 64px;
    height: 64px;
    -webkit-animation: spin 2s linear infinite; /* Safari */
    animation: spin 2s linear infinite;

    margin:auto;
    left:0;
    right:0;
    top:0;
    bottom:0;
    position:fixed;
}

#feedback-form-container a {
    color: white;
    text-decoration: underline;
}

.btn-primary, .btn-primary:hover {
    background-color: #cd3259;
    border-color: #cd3259;
}

.review-item img {
    height: 248px;
    width: auto;
    margin-bottom: 32px;
    object-fit: cover;
}

.review-item {
    margin-bottom: 42px;
}

.video-item {
    margin-bottom: 48px;
}

/* Safari */
@-webkit-keyframes spin {
    0% { -webkit-transform: rotate(0deg); }
    100% { -webkit-transform: rotate(360deg); }
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

#feedback-form button, #feedback-form button:hover {
    margin-top: 24px;
    color: #2d2d2d;
    background-color: #ffffff;
    border: 0;
}

#review img {
    width: auto;
    margin-bottom: 32px;
}

.multiply {
    background-color: gray;
    background-blend-mode: multiply;
}

#review-see-more {
    margin-top: 32px;
}

footer .d-flex {
    display: block !important;
}

footer li {
    list-style-type: none;
}

footer a, footer .nav-link {
    color: white;
    margin-top: 12px;
}

footer #footer-contacts {
    margin-top: 16px;
}

footer p {
    margin-bottom: 0;
}

footer a {
    margin-top: 0;
}

#footer-nav-container.d-flex {
    display: flex !important;
}

footer .social {
    margin-top: 16px;
}

footer .social a {
    margin-right: 16px;
}

.iti {
    display: block;
    width: 100%;
    padding: inherit;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: #212529;
    background-color: #fff;
    background-clip: padding-box;
    border: 1px solid #ced4da;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border-radius: 0.25rem;
    transition: border-color .15s ease-in-out,box-shadow .15s ease-in-out;
}

.popup img {
    margin-bottom: 32px;
}

span a {
    color: gray;
}

.mb-82 {
    margin-bottom: 82px;
}

.mb-32 {
    margin-bottom: 32px;
}

.ol-number {
    width: 40px;
    height: 40px;
    border-width: 0;
    background: #4f7f8d;
    border-radius: 50%;
    color: white;
    margin-bottom: 24px;
}

.expert-photo {
    height: 170px;
    width: 170px;
    object-fit: cover;
    border-radius: 50%;
    margin-bottom: 16px;
}

.upcoming-event-item {
    margin-bottom: 18px;
}

.expert-item {
    margin-bottom: 32px;
}

.event-item {
    margin-bottom: 42px;
    background-color: #ECF0F1;
    padding: 0;
}

.event-item .event-item-desc {
    padding: 32px;
}

.event-item .event-item-img {
    background-position: center;
}

.upcoming-event-item .bg-container {
    background-size: cover;
    color: white;
    padding: 48px;
    min-height: 248px;
    height: 100%;
}

.upcoming-event-item a {
    color: white;
}

.event-type-item {
    margin-bottom: 32px;
}

.event-expert-social {
    width: 53px;
    height: 53px;
    background-size: cover;
    background-repeat: no-repeat;
}

.single-event-banner .row, .single-event-banner hr {
    margin-bottom: 32px;
}

.single-event-banner .row:last-of-type {
    margin-bottom: 0;
}

.single-event-banner p {
    margin-bottom: 1rem !important;
}

.banner-title {
    margin-bottom: 0;
}

.static-event-item {
    margin-bottom: 48px;
}

.static-event-item .bg-image {
    margin-bottom: 18px;
    background-repeat: no-repeat;
    background-position: center;
    height: 400px;
}

.static-event-item a {
    color: black;
}

@media only screen and (max-width: 576px) {
    .nav-ml {
        margin-left: 0;
    }

    #footer-nav-container.d-flex {
        display: block !important;
    }

    #footer-nav-container {
        margin-bottom: 36px;
    }

    footer .d-flex {
        display: flex !important;
    }

    #banner h1 {
        margin-top: 18px;
    }

    #banner h1, #banner p {
        margin-bottom: 18px;
    }

    #banner .bg-image {
        display: block;
    }

    #banner .image-container {
        height: 64px;
    }

    #review img {
        margin-left: auto;
        margin-right: auto;
        object-fit: cover;
        display: block;
    }

    #feedback-form h2 {
        margin-bottom: 12px;
    }

    #review .col-12 {
        margin-bottom: 42px;
    }

    .col-md-6 img {
        margin-bottom: 32px;
    }

    #banner .bg-image, #feedback-form-container {
        padding: 32px;
        height: auto;
    }

    .mb-32 {
        margin-bottom: 0;
    }

    .upcoming-event-item {
        margin-bottom: 32px;
    }
}



