:root {
    --card-radius: 0.5em;
}

.gst-dark {
    background-image: url(/images/bg-texture-00.svg);

    /* spec: main content area, solid background */
    --primary-container-bg: #252525;
    --primary-container-color: whitesmoke;
    --primary-container-border: #333333;
    --primary-card-bg: #303030;
    --primary-card-color: whitesmoke;
    --primary-card-border: #222222;

    /* spec: secondary content area, allows background to show through, not for main text */
    --secondary-container-bg: transparent;
    --secondary-container-color: whitesmoke;
    --secondary-card-bg: #444444;
    --secondary-card-color: whitesmoke;
    --secondary-card-border: #222222;

    --section-title: whitesmoke;
    --leader-color: whitesmoke;
}

.gst-light {
    background-color: #fafafa;
    background-image: url(/images/bg-texture-light.png);
    background-repeat: repeat;

    /* spec: main content area, solid background */
    --primary-container-bg: #ffffff;
    --primary-container-color: #333333;
    --primary-container-border: #eeeeee;
    --primary-card-bg: #fcfcfc;
    --primary-card-color: #222222;
    --primary-card-border: #f7f7f7;

    /* spec: secondary content area, allows background to show through, not for main text */
    --secondary-card-bg: #ffffff;
    --secondary-card-color: #222222;
    --secondary-card-border: #eeeeee;

    --section-title: #222222;
    --leader-color: #222222;
}

/*
 * Global Theming
 */

.gst-primary {
    --card-bg: var(--primary-card-bg);
    --card-color: var(--primary-card-color);
    --card-border: var(--primary-card-border);
}

.gst-primary-container {
    position: relative;
    background: var(--primary-container-bg);
    border-top: 1px solid var(--primary-container-border);
    border-bottom: 1px solid var(--primary-container-border);
    color: var(--primary-container-color);
}

.gst-secondary {
    --card-bg: var(--secondary-card-bg);
    --card-color: var(--secondary-card-color);
    --card-border: var(--secondary-card-border);
}

.gst-secondary-container {
    position: relative;
    background-color: var(--secondary-container-bg);
    color: var(--secondary-container-color);

    background-image: url(/images/bg-texture-dark.png);
}

.gst-content, .gst-content-p {
    width: min(1440px, 100%);
    margin: 0 auto;
    box-sizing: border-box;
}

.gst-content-p h1, .gst-content-p h2, .gst-content-p h3 {
    color: var(--card-color);
}

.gst-content-p {
    padding: 5em 1em;
}

.gst-sbc {
    display: flex;
    flex-direction: row;
    gap: 2em;
}

.gst-sbc-main {
    flex: 1 0 300px;
}

.gst-sbc-sidebar {
    flex: 0 0 320px;
}

@media (max-width: 600px) {
    .gst-content-p {
        padding: 1em 1em;
    }
}

/*
 * Clickable Navigation Card
 */

.gst-navcard {
    all: unset;
    border-radius: var(--card-radius);
    display: flex;
    flex-direction: row;
    flex-grow: 1;
    gap: 0.25em;
    overflow: hidden;
    cursor: pointer;
    background: var(--card-bg);
    color: var(--card-color) !important;
    outline: 3px transparent;
    transition: all 0.2s ease-in-out;
    border: 1px solid var(--card-border);
}

.gst-navcard:hover {
    outline: 3px solid #53576d;
    overflow: hidden;;
    transition: all 0.2s ease-in-out;
}

.gst-navcad:focus {
    outline: 3px solid #eeeeee;
}

/*
 * Basic Card
 */

.gst-card {
    border-radius: var(--card-radius);
    display: flex;
    flex-direction: column;
    flex-grow: 1;
    overflow: hidden;
    background: var(--card-bg);
    color: var(--card-color);
    border: 1px solid var(--card-border);
}

.gst-card-title {
    padding: 1.5em;
    font-weight: bold;
}

.gst-card-content {
    padding: 1.5em;
}

/*
 * CGRID
 *
 * Displays in an auto-repeating grid, however, when the space is too small, it significantly collapses
 * the gap and changes the separation from such large padding, into a vertical list
 */

.gst-cgrid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(340px, 100%), 1fr));
    gap: 1.5em;
    margin: 0;
    padding: 0;
    list-style-type: none;
}

.gst-cgrid-card {
    border-radius: var(--card-radius);
    overflow: hidden;
}

@media (max-width: 700px) {
    .gst-cgrid {
        gap: 0;
        overflow: hidden;
        border-radius: var(--card-radius);
        animation: ease;
    }

    .gst-cgrid-card {
        border-radius: 0 !important;
        overflow: hidden;
    }

    .gst-cgrid-card + .gst-cgrid-card {
        margin-top: 3px;
    }
}

/*
 * Micro Label
 */

/*
 * MICRO LABEL
 * Key-Value label intended to be used for versions
 */

.gst-statuslabel {
    font-size: smaller;
    border-radius: 0.75em;
    border: 1px solid #77777755;
    overflow: hidden;
    display: inline-flex;
    align-items: center;
}

.gst-statuslabel-label {
    padding: 0.15em 0.5em;
    background: #00000044;
    border-right: 1px solid #777777;
}

.gst-statuslabel-value {
    padding: 0.15em 0.5em;
}
