/* Load defaults from `<userDir>/node_modules/node-red-contrib-uibuilder/front-end/uib-brand.min.css`
 * This version auto-adjusts for light/dark browser settings.
 */
@import url("../uibuilder/uib-brand.min.css");

/* CSS variables to make it easier to control */
:root {
    /* The layout container */
    --container-max-width: 500px;
    --container-col-gap: 0.2rem;
    --container-row-gap: 0.2rem;

    /* The main content container */
    --main-cols: repeat(12, 1fr);
    --main-rows: auto; /* auto OR repeat(12, 1fr); ... */
    --main-col-gap: var(--container-col-gap);
    --main-row-gap: var(--container-row-gap);
    
    /* The articles */
    --article-width: 4; /* number of columns or auto */
    --article-height: auto; /* auto or number of rows */

    /* The Sidebar container */
    --sidebar-max-width: 0.5fr;
    --sidebar-min-width: 0.1fr;
}

/* The outer container div */
.container {
    width: 100%;
    max-width: var(--container-max-width);
    margin: 0 auto;
    /* Center the container horizontally */
    display: grid;
    gap: var(--container-row-gap) var(--container-col-gap);

    /* 2 cols x 3 rows layout. Middle row & right column are larger. Left col is constrained min/max */
    grid-template-columns: minmax(var(--sidebar-min-width), var(--sidebar-max-width)) var(--main-width);
    grid-template-rows: 0fr 1fr 0fr;
    grid-template-areas: 
        "header header"
        "main main"
        "sidebar sidebar"
        "footer footer";
    justify-items: stretch;
    background-color: #fefefe;
}

/* The main content container */
main {
    /* Where you put your content */
    grid-area: main;
    
    display: grid;
    gap: var(--main-row-gap) var(--main-col-gap);
    grid-template-columns: var(--main-cols, 12); /* fallback to 12 cols */
    grid-template-rows: var(--main-rows, auto); /* fallback to auto */
}

/* Any article within the main container */
main > article, main > div {
    /* Width of an article in number of columns */
    grid-column: span var(--article-width);
    /* Height of an article in number of rows */
    grid-row: span var(--article-height);
    margin: 0;
}
/* Set a child div to have same format as an article */
main > div {
    border: 1px solid var(--text3);
    border-radius: var(--border-radius);
    padding: var(--border-pad);
    margin: 0;
    background-color: var(--surface3);
}
main > div > h2, main > div > h3, main > div > h4 {
    margin-block-start: 0;
    border-bottom: 1px solid var(--text3);
    padding-block-end: var(--border-pad);
}

header {
    /* Headings, nav, etc */
    grid-area: header;
}

footer {
    /* at the bottom, (c), dates, etc */
    grid-area: footer;
    margin-top: 0;
}

/* We might want other sidebars so be more explicit for this */
aside.sidebar {
    /* stuff to one side of the main content */
    grid-area: sidebar;
}

.cd-dropdown {
    position: fixed;
    z-index: 1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    transform: translateY(-100%);
    transition: transform 0.5s;
}

.cd-dropdown.dropdown-is-active {
    transform: translateY(0);
}


/*#endregion */

/* Adapt for narrow screens */
@media only screen and (max-width: 512px) {
    /* Very simple adaption example, a single column, 4 rows */
    .container {
        gap: 0.5rem;

        /* 1 cols x 4 rows layout. 2nd row is larger */
        grid-template-columns: 1fr;
        grid-template-rows: 0.1fr 1fr 0.1fr 0.1fr;
        grid-template-areas:
            "header"
            "main"
            "sidebar"
            "footer";
    }
}
