/* Grid Variables */
:root {
    --responsive-mode: "default";
    --container-width: 1080px;
    --container-gutter: calc(calc(100% - var(--container-width)) / 2);
    --whitespace: 50px;

    --breakpoint-lg-min: 1280px;
    --breakpoint-lg-container: 1080px;
    --breakpoint-md-max: 1279px;
    --breakpoint-md-container: 720px;
    --breakpoint-md-min: 768px;
    --breakpoint-sm-max: 767px;
    --breakpoint-sm-container: 90vw;
}

/* Grid Styles */
body {
    display: flex;
    flex-direction: column;
    margin: 0;
    padding: 0;
    min-height: 100vh;
}
header, section, footer { padding: var(--whitespace, 50px) 0; }
:is(main,section):last-of-type {
    display: flex;
    flex-direction: column;
    flex: 1;
}

content-container {
    display: block;
    width: var(--container-width);
    margin-left: var(--container-gutter);
    margin-right: var(--container-gutter);
    padding: 0;
}

content-row {
    display: block;
    width: 100%;
    max-width: 100%;
    gap: var(--gutter-1x, 15px);
}

[grid] {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px,1fr)); /* MAGIC */
    gap: var(--gutter-1x, 15px);
}

[flex] {
    display: flex;
    flex-direction: row;
}

[center] {
    justify-content: center;
    text-align: center;
}

content-row[align] { align-items: center; }
content-row[spread] { justify-content: space-between; }
content-row[spread] > :first-child { text-align: start; }
content-row[spread] > :last-child { text-align: end; }
[grid], [grid][columns="1"] { grid-template-columns: repeat(1, 1fr); grid-auto-flow: row; }
[grid][columns="2"] { grid-template-columns: repeat(2, 1fr); }
[grid][columns="3"] { grid-template-columns: repeat(3, 1fr); }
[grid][columns="4"] { grid-template-columns: repeat(4, 1fr); }
[grid][columns="5"] { grid-template-columns: repeat(5, 1fr); }
[grid][columns="6"] { grid-template-columns: repeat(6, 1fr); }
[grid][columns="7"] { grid-template-columns: repeat(7, 1fr); }
[grid][columns="8"] { grid-template-columns: repeat(8, 1fr); }
[grid][columns="9"] { grid-template-columns: repeat(9, 1fr); }
[grid][columns="10"] { grid-template-columns: repeat(10, 1fr); }
[grid][columns="11"] { grid-template-columns: repeat(11, 1fr); }
[grid][columns="12"] { grid-template-columns: repeat(12, 1fr); }

content-column {
    display: block;
    width: 100%;
    max-width: 100%;
}

content-whitespace {
    display: flex;
    flex-direction: column;
    flex: 1;
}

/* Grid Responsive Queries */
@media screen and (min-width: 1280px) {
    :root {
        --responsive-mode: "lg";
    }
}
@media screen and (min-width: 768px) and (max-width: 1279px) {
    :root {
        --responsive-mode: "md";
        --container-width: 720px;
        --container-gutter: calc(calc(100% - var(--container-width)) / 2);
    }
}
@media screen and (max-width: 767px) {
    :root {
        --responsive-mode: "sm";
        --container-width: 90vw;
        --container-gutter: 5vw;
        --gutter-width: 15px;
    }
    content-row[grid][columns] { grid-auto-flow: unset; }
}

/* NOTES */
/* Add support for subgrids? See: https://web.dev/articles/css-subgrid */
