.umb-block-grid__layout-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);
    -moz-column-gap: var(--umb-block-grid--column-gap, 0);
    column-gap: var(--umb-block-grid--column-gap, 0);
    row-gap: var(--umb-block-grid--row-gap, 0);
}

.umb-block-grid__layout-item {
    position: relative;
    /* For small devices we scale columnSpan by three, to make everything bigger than 1/3 take full width: */
    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);
}

.umb-block-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);
    -moz-column-gap: var(--umb-block-grid--areas-column-gap, 0);
    column-gap: var(--umb-block-grid--areas-column-gap, 0);
    row-gap: var(--umb-block-grid--areas-row-gap, 0);
}

.umb-block-grid__area {
    position: relative;
    height: 100%;
    display: flex;
    flex-direction: column;
    /* For small devices we scale columnSpan by three, to make everything bigger than 1/3 take full width: */
    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:1024px) {

    .umb-block-grid__layout-item {
        grid-column-end: span min(var(--umb-block-grid--item-column-span, 1), var(--umb-block-grid--grid-columns));
    }

    .umb-block-grid__area {
        grid-column-end: span min(var(--umb-block-grid--area-column-span, 1), var(--umb-block-grid--area-grid-columns));
    }
}

/**** Custom additions to the default Grid Layout Stylehseet: ****/


/* additional CSS options for area-container and areas: */

.umb-block-grid__layout-item .align-left .umb-block-grid__area-container {
    margin-left: 0;
    margin-right: auto;
}
.umb-block-grid__layout-item .align-center .umb-block-grid__area-container {
    margin-left: auto;
    margin-right: auto;
}
.umb-block-grid__layout-item .align-right .umb-block-grid__area-container {
    margin-left: auto;
    margin-right: 0;
}

.umb-block-grid__area {
    justify-content: center;
}

@media (min-width:1024px) {
    .umb-block-grid__layout-item[data-content-element-type-alias="blockOneColumnSection"] .umb-block-grid__layout-container {
        --umb-block-grid--column-gap: 60px;
    }
}


/** Inspiration */

.inspiration[bright-contrast] {
    --my-bright-contrast:;
}

.inspiration .area-container {
    max-width: var(--my-container-max-width);
    /*padding: var(--my-container-padding);*/
    margin-left: auto;
    margin-right: auto;
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr;
    grid-auto-flow: row;
    column-gap: 60px;
}

.inspiration {
    margin-bottom: 42px;
    min-height: 160px;
}

.inspiration .left-area {
    grid-column-end: span 1;
    display: block;
    z-index: 2;
    margin-bottom: 60px;
    transform: translateY(120px);
}

.inspiration .right-area {
    grid-column-end: span 1;
    display: block;
    z-index: 1;
    margin-top: auto;
    transform: translateX(-120px);
}

.inspiration .content-area {
    grid-column-end: span 2;
    display: block;
}

@media (max-width: 1024px) {
    .inspiration .area-container {
        grid-template-columns: 1fr 1fr;
        row-gap: 100px;
        column-gap: 30px;
    }
    .inspiration .right-area {
        transform: translateX(-80px);
    }
    .inspiration .left-area {
        margin-left: 24px;
    }
}

.umb-block-grid__layout-item[data-content-element-type-alias="blockInspiration"] .umb-block-grid__area[data-area-alias="leftArea"] {
    justify-content: end;
}

.umb-block-grid__layout-item[data-content-element-type-alias="blockInspiration"] .umb-block-grid__area[data-area-alias="rightArea"] {
    justify-content: start;
}


:root, :host, body {
    font-size: 16px;
    line-height: 1.5;
    margin: 0;
}

.umb-block-grid {
    container-type: inline-size;
    --my-container-padding: 0 20px;
}

@container (min-width: 720px) {
    .umb-block-grid__layout-container {
        --my-container-padding: 0 60px;
    }
}


section[bright-contrast] {
    color: white;
    --my-bright-contrast:;
}


/** only works on website. */
.umb-block-grid__layout-item:has(section[nobackgroundcolor]) +
.umb-block-grid__layout-item section[nobackgroundcolor] {
    padding-top: 0;
}


/*h1 {
    font-size: 60px;a
    font-weight: 300;
    line-height: 0.96;
    margin: 0;
    margin-bottom: 20px;
    color: inherit;
}

h2 {
    font-size: 35px;
    font-weight: 300;
    line-height: 1.2;
    margin: 0;
    color: inherit;
}

h3 {
    font-size: 30px;
    font-weight: 300;
    line-height: 1.2;
    margin: 0;
    color: inherit;
}

h4 {
    font-size: 21px;
    font-weight: 300;
    line-height: 1.2;
    margin: 0;
    color: inherit;
}*/


/** Image */

img.image {
    object-fit: cover;
    height: 100%;
    width: 100%;
}



/** Rich Text */

.rich-text {
    font-weight: 300;
    color: inherit;
    /** 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;
    }

/**umb_name:Lead Paragraph*/
p.lead-paragraph {
    font-size: 18px;
}


/** Hero */

.umb-block-grid__layout-item[data-content-element-type-alias="blockHero"] .umb-block-grid__area-container,
.umb-block-grid__layout-item[data-content-element-type-alias="blockHero"] .umb-block-grid__block--view::part(area-container) {
    padding: 0;
}

.umb-block-grid__layout-item[data-content-element-type-alias="blockHero"] .umb-block-grid__area[data-area-alias="right"] {
    justify-content: end;
}

.umb-block-grid__layout-item[data-content-element-type-alias="blockHero"] .umb-block-grid__area[data-area-alias="left"] {
    justify-content: start;
}


/* Card */

.card {
    display: flex;
    flex-direction: column;
    height: 100%;
    color: black;
    background-color: white;
}

.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;
    background-color: rgba(0,0,0,.22);
    pointer-events: none;
}

.card.--medium .card-content {
    position: absolute;
    z-index: 1;
    bottom: 0;
    color: white;
}

.card.--medium .card-content h4 {
    font-size: 30px;
}