/** Grid for Front End */

.grid-item-container {
    position: relative;
    display: grid;
    grid-template-columns: repeat(var(--umb-block-grid--grid-columns, 1), minmax(0, 1fr));
    grid-auto-flow: row;
    grid-auto-rows: minmax(50px, min-content);
    column-gap: var(--umb-block-grid--column-gap, 0);
    row-gap: var(--umb-block-grid--row-gap, 0);
}

.grid-item {
    position: relative;
    grid-column-end: span min(calc(var(--umb-block-grid--item-column-span, 1) * 3), var(--umb-block-grid--grid-columns));
    grid-row: span var(--umb-block-grid--item-row-span, 1);
}


.grid-area-container, .umb-block-grid__block--view::part(area-container) {
    position: relative;
    display: grid;
    grid-template-columns: repeat(var(--umb-block-grid--area-grid-columns, var(--umb-block-grid--grid-columns, 1)), minmax(0, 1fr));
    grid-auto-flow: row;
    grid-auto-rows: minmax(50px, min-content);
    column-gap: var(--umb-block-grid--areas-column-gap, 0);
    row-gap: var(--umb-block-grid--areas-row-gap, 0);
}

.grid-area {
    position: relative;
    height: 100%;
    display: flex;
    flex-direction: column;
    grid-column-end: span min(calc(var(--umb-block-grid--area-column-span, 1) * 3), var(--umb-block-grid--area-grid-columns));
    grid-row: span var(--umb-block-grid--area-row-span, 1);
}

@media (min-width:992px) {
    .grid-item {
        grid-column-end: span min(var(--umb-block-grid--item-column-span, 1), var(--umb-block-grid--grid-columns));
    }

    .grid-area {
        grid-column-end: span min(var(--umb-block-grid--area-column-span, 1), var(--umb-block-grid--area-grid-columns));
    }
}


.umb-block-grid {
    --my-container-max-width: 1200px;
    --my-container-padding: 0 20px;
    --my-container-mob-padding: 0 30px;
}

@container (min-width: 720px) {
    .grid-item-container {
        --my-container-padding: 0 60px;
    }
}

.container, .container-fluid, .container-lg, .container-md, .container-sm, .container-xl, .container-xxl {
    padding-right: 30px;
    padding-left: 30px;
}

.grid-area-container, .umb-block-grid__block--view::part(area-container) {
    padding: var(--my-container-mob-padding);
    margin-left: auto;
    margin-right: auto;
    --umb-block-grid--areas-column-gap: 30px;
    --umb-block-grid--areas-row-gap: 30px;
}

@container (min-width: 720px) {
    .grid-area-container, .umb-block-grid__block--view::part(area-container) {
        --umb-block-grid--areas-column-gap: 60px;
        --umb-block-grid--areas-row-gap: 60px;
        padding: var(--my-container-padding);
    }

    .container, .container-fluid, .container-lg, .container-md, .container-sm, .container-xl, .container-xxl {
        padding-right: 15px;
        padding-left: 15px;
    }
}

.grid-area {
    justify-content: center;
}

.grid-item[data-content-element-type-alias="oneColumnSectionBlock"] .grid-item-container {
    --umb-block-grid--column-gap: 30px;
    --umb-block-grid--row-gap: 30px;
}

@container (min-width: 720px) {
    .grid-item[data-content-element-type-alias="oneColumnSectionBlock"] .grid-item-container {
        --umb-block-grid--column-gap: 60px;
        --umb-block-grid--row-gap: 60px;
    }
}

.grid-item:has(section[nobackgroundcolor]) +
.grid-item section[nobackgroundcolor] {
    padding-top: 0;
}





/**** Custom website styles: ****/

section {
    padding: var(--section-padding, 60px 0);
}

    section[bright-contrast] {
        color: white;
        --my-bright-contrast:;
    }



/** Image */

img.image {
    object-fit: cover;
    height: 100%;
    width: 100%;
}



/** Rich Text */

.rich-text {
    color: inherit;
}

@media (min-width:1024px) {
    .rich-text {
        /** Using CSS Calculation, which gives 1 for column spans of 1-11 and 2 for column span of 12. */
        columns: clamp(1, calc(var(--umb-block-grid--item-column-span) - 10), 2);
        column-gap: 60px;
    }
}

.rich-text > p:first-child {
    margin-top: 0;
}





/** Hero */

.grid-item[data-content-element-type-alias="heroBlock"] .grid-area-container,
.grid-item[data-content-element-type-alias="heroBlock"] .umb-block-grid__block--view::part(area-container) {
    padding: 0;
}

.hero {
    position: relative;
    height: 80vh;
    width: 100%;
    display: flex;
    align-items: end;
    padding: 60px 0;
    box-sizing: border-box;
}

    .hero[bright-contrast] {
        color: white;
        --my-bright-contrast:;
    }

    .hero .hero-background {
        position: absolute;
        inset: 0;
        background-position: 50% 50%;
        background-size: cover;
    }

        .hero .hero-background:after {
            content: '';
            position: absolute;
            inset: 0;
            background-color: rgba(0,0,0,.22);
            pointer-events: none;
        }

    .hero .hero-content {
        position: relative;
        width: 100%;
        max-width: var(--my-container-max-width);
        padding: var(--my-container-padding);
        margin-left: auto;
        margin-right: auto;
    }

        .hero .hero-content > h1 {
            max-width: 14em;
        }

        @media (max-width: 991px) {
            .container {
                max-width: none !important;
            }
        }


/** Call to action */

.call-to-action {
    display: inline-block;
    --call-to-action--background-color--condition: var(--my-bright-contrast) white;
    background-color: var(--call-to-action--background-color--condition, #3544b1);
    --call-to-action--text-color--condition: var(--my-bright-contrast) #372E2B;
    color: var(--call-to-action--text-color--condition, white);
    font-weight: 500;
    padding: 14px 28px;
    margin-top: 10px;
    margin-bottom: 10px;
    margin-right: auto;
    max-width: 180px;
    text-decoration: none;
}



.grid-item[data-content-element-type-alias="inspirationBlock"] .grid-area[data-area-alias="leftArea"] {
    justify-content: start;
}

.grid-item[data-content-element-type-alias="inspirationBlock"] .grid-area[data-area-alias="rightArea"] {
    justify-content: end;
}



/*Page header*/

.page-header-component {
.main-text{
    font-weight: 700;
}
}

/* Card */

.card {
    display: flex;
    flex-direction: column;
    height: 100%;
}

    .card .card-media {
        position: relative;
        width: 100%;
        aspect-ratio: 16 / 9;
        overflow: hidden;
    }

        .card .card-media img {
            object-fit: cover;
            height: 100%;
            width: 100%;
        }

    .card .card-content {
        display: flex;
        flex-direction: column;
        gap: 10px;
        padding: 20px;
        font-weight: 300;
    }

        .card .card-content p {
            margin: 0;
        }


    .card.--medium {
        height: auto;
    }

        .card.--medium .card-media::after {
            content: '';
            position: absolute;
            inset: 0;
            pointer-events: none;
        }

        .card.--medium .card-content {
            position: absolute;
            z-index: 1;
            bottom: 0;
        }

            .card.--medium .card-content h4 {
                font-size: 30px;
            }


/* Navigation */
.navbar .megamenu {
    padding: 1rem;
}

@media all and (min-width: 992px) {

    .navbar .has-megamenu {
        position: static !important;
    }

    .navbar .megamenu {
        left: 0;
        right: 0;
        width: 100%;
        margin-top: 0;
    }
}

@media(max-width: 991px) {
    .navbar.fixed-top .navbar-collapse, .navbar.sticky-top .navbar-collapse {
        overflow-y: auto;
        max-height: 90vh;
        margin-top: 10px;
    }
}


/* Carousel */

.carousel-item .image {
    aspect-ratio: 16 / 6;
    width: 100%;
    min-width: 100%;
    overflow: hidden;
}

.carousel-item img {
    width: 100%;
    height: 100%;
    object-position: 50% 50%;
    object-fit: cover;
}

.carousel-item:before {
    content: "";
    display: block;
    position: absolute;
    background-image: linear-gradient(to bottom, rgba(255,255,255, 0), rgba(255,255,255, 0.8));
    width: 100%;
    top: 0;
    height: 100%;
    z-index: 1;
}

.carousel-item .carousel-caption {
    z-index: 1;
    position: absolute;
    height: 100%;
    top: 0;
    display: flex !important;
    justify-content: center;
    flex-direction: column;
    align-content: center;
}

    .carousel-item .carousel-caption.text-left {
        text-align: left;
    }

    .carousel-item .carousel-caption.text-center {
        text-align: center;
    }

    .carousel-item .carousel-caption.text-right {
        text-align: right;
    }

/*
.carousel-item .video {
    position: relative;
}

.carousel-item .video-player {
    aspect-ratio: 16 / 9;
    width: 100%;
}

@supports not (aspect-ratio: 1) {
    .carousel-item .video {
        position: relative;
        padding-bottom: 56.25%;
    }

    .carousel-item .video-container iframe.video-player {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
    }
}

*/

/* Standard video */
.video-container {
    position: relative;
    width: 100%;
    height: 100%;
}

    .video-container .video-player {
        aspect-ratio: 16 / 9;
        width: 100%;
    }

@supports not (aspect-ratio: 1) {
    .video-container {
        position: relative;
        padding-bottom: 56.25%;
    }

        .video-container iframe.video-player {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
        }
}

/* Standard image */
a.image-link {
    aspect-ratio: 4 / 3;
    width: 100%;
}

figure {
    position: relative;
    width: 100%;
    height: 100%;
}

    figure img {
        width: 100%;
    }



/** TEXT CONTRAST */
.dark, .dark p, .dark h2, .dark h3, .dark h4, .dark h5, .dark label {
    color: white !important;
}

.light, .light p, .light h2, .light h3, .light h4, .light h5, .light label {
    color: #372E2B !important;
}

/**umb_name:Lead Paragraph*/
p.lead-paragraph {
    font-size: 18px;
}
