@layer utilities {
    .relative {
        position: relative;
    }

    .fixed {
        position: fixed;
    }

    .fixed-b {
        position: fixed;
        bottom: 0;
    }

    .fixed-t {
        position: fixed;
        top: 0;
    }

    .block {
        display: block;
    }

    .inline-block {
        display: inline-block;
    }

    .inline-flex {
        display: inline-flex;
    }

    .inline {
        display: inline;
    }

    .inline-block {
        display: inline-block;
    }

    .sticky {
        position: sticky;
        top: 20px;
    }

    .grid {
        display: grid;
        grid-template-columns: var(--columns, 1fr);
        gap: var(--gap, var(--size-3));

        /* Tablet up */
        @media screen and (min-width: 768px) {
            grid-template-columns: var(--tablet-columns, var(--columns));
        }

        .mobile-span-2 {
            grid-column: 1 / 3;

            /* Tablet up */
            @media screen and (min-width: 768px) {
                grid-column: auto;
            }
        }

        .mobile-span-4 {
            grid-column: 1 / 3;

            /* Tablet up */
            @media screen and (min-width: 768px) {
                grid-column: 2 / 4;
            }
        }

        .span-1-1 {
            grid-column: 1 / 3;

            /* Tablet up */
            @media screen and (min-width: 768px) {
                grid-column: 1 / span 1;
            }
        }

        .span-3-1 {
            grid-column: 1 / 3;

            /* Tablet up */
            @media screen and (min-width: 768px) {
                grid-column: 3 / 5;
            }
        }
    }

    .inline-grid {
        display: inline-grid;
        grid-template-columns: var(--columns);
    }

    .flex {
        display: flex;
        gap: var(--gap, var(--size-3));
    }

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

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

    [class~="gap"] {
        gap: var(--size-3);
    }

    [class~="gap"],[class~="gap-"] {
        gap: var(--gap);
    }

    .gap-1 {
        --gap: var(--size-1);
    }

    .gap-2 {
        --gap: var(--size-2);
    }

    .gap-3 {
        --gap: var(--size-3);
    }

    .gap-4 {
        --gap: var(--size-4);
    }

    .gap-5 {
        --gap: var(--size-5);
    }

    .gap-6 {
        --gap: var(--size-6);
    }

    .gap-7 {
        --gap: var(--size-7);
    }

    .gap-8 {
        --gap: var(--size-8);
    }

    .gap-9 {
        --gap: var(--size-9);
    }

    [class~="gaps"] {
        gap: var(--size-3) var(--size-2);
    }

    [class~="gaps"],[class~="row-gap-"],[class~="col-gap-"] {
        gap: var(--row-gap) var(--col-gap);
    }

    .row-gap-1 {
        --row-gap: var(--size-1);
    }
    .row-gap-2 {
        --row-gap: var(--size-2);
    }
    .row-gap-3 {
        --row-gap: var(--size-3);
    }
    .row-gap-4 {
        --row-gap: var(--size-4);
    }
    .row-gap-5 {
        --row-gap: var(--size-5);
    }
    .row-gap-9 {
        --row-gap: var(--size-9);
    }

    .col-gap-1 {
        --col-gap: var(--size-1);
    }
    .col-gap-2 {
        --col-gap: var(--size-2);
    }
    .col-gap-3 {
        --col-gap: var(--size-3);
    }
    .col-gap-4 {
        --col-gap: var(--size-4);
    }
    .col-gap-5 {
        --col-gap: var(--size-5);
    }
    .col-gap-6 {
        --col-gap: var(--size-6);
    }
    .col-gap-7 {
        --col-gap: var(--size-7);
    }
    .col-gap-8 {
        --col-gap: var(--size-8);
    }
    .col-gap-9 {
        --col-gap: var(--size-9);
    }

    .m-3 {
        margin: var(--size-3);
    }

    [class~="padding"],[class~="padding-"] {
        padding: var(--padding);
    }

    [class~="padding"] {
        --padding: var(--size-6);
    }

    [class~="y-padding"] {
        padding: var(--padding) 0;
    }

    .padding-1 {
        --padding: var(--size-1);
    }

    .padding-2 {
        --padding: var(--size-2);
    }

    .padding-3 {
        --padding: var(--size-3);
    }

    .padding-4 {
        --padding: var(--size-4);
    }

    .padding-5 {
        --padding: var(--size-5);
    }

    .padding-6 {
        --padding: var(--size-6);
    }

    .padding-7 {
        --padding: var(--size-7);
    }

    .padding-8 {
        --padding: var(--size-8);
    }

    .place-center {
        place-items: center;
    }

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

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

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

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

    .justify-self-start {
        justify-self: start;
    }

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

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

    .items-baseline {
        align-items: baseline;
    }

    .align-items-last-baseline {
        align-items: last baseline;
    }

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

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

    .w-max {
        width: max-content;
    }

    .w-min {
        width: min-content;
    }

    .w-max-300 {
        max-width: 300px;
    }

    .w-full {
        width: 100%;
    }

    h-full {
        height: 100%;
    }

    .scroll-h {
        overflow-x: auto;

        /*  Does not force visibility. Style the scrollbar with Limited availability features. */
        /* scrollbar-width: thin;
        scrollbar-color: var(--color-border-grey) var(--color-light-grey);
        scrollbar-gutter: stable both-edges; */

        /* Does force visibility. Style the scrollbar with ::-webkit-scrollbar CSS pseudo-element. Non-standard and is not on a standards track. */
        &::-webkit-scrollbar {
            height: 7px;
        }

        &::-webkit-scrollbar-track {
            background: var(--color-light-grey);
        }

        &::-webkit-scrollbar-thumb {
            background: var(--color-border-grey);
        }
        &::-webkit-scrollbar-thumb:hover {
            background: var(--color-brand-blue);
        }
    }
}
