
:root {
  --sb-width: 5rem;
}

body {
    background-color: var(--letterbox-background-color); /* background colour of letter box edges for large screens */
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;

}

html {
	overflow: hidden;
}

p {
  margin-block-end: 1.5rem;
}

.wrapper {
    height: 100%;
    width: 100%;
    margin: auto;
    padding: 0;
    overflow: hidden;
    max-width: 1600px; /* define a maximum width */
    border-left: 0px solid var(--sidenav-border-color);
    display: grid;
    /* grid-template-columns: 100px 150px 200px 200px; */
    /* grid-template-columns: 100px auto 10rem 200px; */
    /* grid-template-columns: 100px auto repeat(2, 200px); */
    /* grid-template-columns: repeat(2, 100px 200px); */
    grid-template-columns: var(--sb-width) 3fr 0;
    /* Constrain UI to viewport */
    min-block-size: 100vh;
    min-block-size: 100dvh;
    max-block-size: 100vh;
    max-block-size: 100dvh;
    /*grid-template-rows: 100px 200px 100px;*/
    /*grid-template-rows: auto 1fr auto;*/
    grid-template-rows: 60px 1fr 60px;

    grid-template-areas:
        "header header ai"
        "sidebar main ai"
        "footer footer ai";
    /*grid-template-areas:
    "sidebar header"
    "sidebar main"
    "footer footer";
	*/

    gap: 0.0rem;
    transition: grid-template-columns .5s ease-in-out;
}

.wrapper.kynapses-sb-expand {	
  --sb-width: 12.5rem;	
  /*grid-template-columns: 12.5rem 1fr;*/
}

.kynapses-dashboard-header {
    grid-area: header;
    display: flex;
    background-color: var(--header-background-color);
    padding: 0 1.0rem 0 1.5rem;
    margin: 0;
    align-items: center;
    border: 0px solid #ff0000; /* debug */
}

.kynapses-dashboard-title {
    font-size: 1.3rem;
    color: var(--sidenav-header-text-color);
}

.kynapses-dashboard-footer {
    grid-area: footer;
    display: flex;
    padding: 0 1.0rem 0 1.5rem;
    margin: 0;
    background-color: var(--body-background-color);
    color: var(--body-text-color);
    align-items: center;
    border: 0px solid #ff0000; /* debug */
}

.kynapses-dashboard-main {
    grid-area: main;
    padding: 1.25rem 1.75rem 1.25rem 1.75rem;
    margin: 0;
    overflow-y: scroll;
    background-color: var(--body-background-color);
    color: var(--body-text-color);
}

.kynapses-dashboard-sidebar {
    scrollbar-gutter: stable; /* This is important - prevents scrollbar from moving content when the scrollbar is shown then hidden */
    position: relative;
    grid-area: sidebar;
    color: var(--sidenav-text-color);
    background-color: var(--sidenav-background-color);
    border-right: 1px solid var(--sidenav-border-color);
    /*inset: 0 auto 0 0;*/
    /*padding: 0.5rem 0.5rem 0.5rem 0.5rem;*/
    padding-right: 0.0rem;
    padding-left: 0.0rem;
    /*    overflow-y: scroll;*/
    /*    overflow-x: hidden;*/
    border-radius: 0;
}

.kynapses-dashboard-sidebar-group-header {
    margin: 0 0 0.5rem 0;
    color: var(--sidenav-group-heading-text-color);
    text-transform: none;
}

/* Check - NOT Used */
.kynapses-dashboard-sidebar button {
    position: absolute;
    inset: 4.5rem -0.75rem auto auto;
    width: 1.5rem;
    aspect-ratio: 1;
    background-color: var(--sidenav-text-color);
    border: transparent;
    cursor: pointer;
}

.kynapses-dashboard-sidebar nav {
  height: 100%;
  border: 0px solid #ff0000; /* debug */
  margin: 0;
  padding: 1.3rem;
}

.kynapses-dashboard-sidebar nav ul {
  list-style: none;
  /*height: 100%;*/
  display: flex;
  flex-flow: column;
  gap: .25rem;
  /*background-color: #ff0000;*/
  margin: 0;
  padding: 0;
}

    .kynapses-dashboard-sidebar nav li:last-child {
        margin-top: auto;
        color: var(--sidenav-text-color);
    }

    .kynapses-dashboard-sidebar nav a {
        display: flex;
        align-items: center;
        /*justify-content: center;*/
        gap: 0.625rem;
        /*padding: 0.625rem 0.875rem;*/
        padding: 0.25rem 0.25rem 0.25rem 0.375rem;
        color: var(--sidenav-text-color);
        text-decoration: none;
        border-radius: var(--systemBorderRadius);
        /*transition: background-color 0.5s ease-in-out, color 0.5s ease-in-out;*/
        border: 0px solid #ff0000; /* debug */
    }

        .kynapses-dashboard-sidebar nav a.active,
        .kynapses-dashboard-sidebar nav a:hover,
        .kynapses-dashboard-sidebar nav a:focus-visible {
            outline: none;
            color: var(--sidenav-active-text-color) !important;
            background-color: var(--sidenav-active-background-color);
        }

.kynapses-dashboard-sidebar h5 {
    font-size: 0.875rem;
    opacity: 0;
    visibility: hidden;
    display: none;
}

.kynapses-sb-expand .kynapses-dashboard-sidebar h5 {
    opacity: 1;
    visibility: visible;
    display: block;            
}

.kynapses-dashboard-sidebar nav a span {
    font-size: 0.875rem;
    opacity: 0;
    /* display and visibility must be removed to support transition */
    /*visibility: hidden;
    display: none;*/
    display: block;
    width: 100%;
    overflow: hidden;
    white-space: nowrap;
    border: 0px solid #ff0000; /* debug */
    transition: opacity 0.5s ease-in-out, visibility 0.5s ease-in-out;
}

.kynapses-sb-expand .kynapses-dashboard-sidebar nav a span {
    opacity: 1;
    /* display and visibility must be removed to support transition */
    /*visibility: visible;
    display: block;*/
}

.kynapses-dashboard-sidebar-expander {
    border:0px solid #ff0000; /* debug */
    margin: 0 0 0.25rem 0;
}

.kynapses-sb-expand .kynapses-dashboard-sidebar-expander {
    text-align: left;
    border:0px solid #ff0000; /* debug */
}

.sb-expander {
    rotate: 0deg;
}

.kynapses-sb-expand aside .sb-expander {
  rotate: 180deg;
  border: 0px solid #ff0000;
  width: 100%;
}

.kynapses-dashboard-ai-container {
    position: relative;
    grid-area: ai;
    background-color: var(--body-background-color);
    color: var(--body-text-color);
    border-left: 1px solid var(--sidenav-border-color);
    border-right: 1px solid var(--sidenav-border-color);
    inset: 0 auto 0 0;
    padding: 1rem;
    overflow-y: scroll;
    overflow-x: hidden;
}

.kynapses-menu-button {
    visibility: hidden;
    display: none;
}

.kynapses-logo {
  display: flex;
  justify-content: center;
  font-size: 3rem;
  line-height: 1.3;
}

.kynapses-dashboard-system-search-button {
  visibility: hidden;
  display: none;
  border: 0px solid #ff0000;
}

.burger-menu-expand {
    grid-template-columns: 1fr 0;
}

.burger-menu-sidebar-expand {
    visibility: visible;
    display: block;
}

/* Extra small devices (phones, 800px and down) */
@media (max-width: 800px) {

    .wrapper:not(.burger-menu-expand) {
        grid-template-columns: 0 3fr 0;
    }
    
    .wrapper.burger-menu-expand {
        grid-template-columns: 3fr 0 0;
    }

    main {       
        /* Collapse sidebar navigation */
    }

    .kynapses-menu-button {
        visibility: visible;
        display: block;
    }

    .kynapses-dashboard-sidebar:not(.burger-menu-sidebar-expand) {
        visibility: hidden;
        display: none;
    }

    .kynapses-dashboard-sidebar-expander {
        visibility: hidden;
        display: none;
    }

    .kynapses-dashboard-system-search-form {
        visibility: hidden;
        display: none;
    }

    .kynapses-dashboard-system-search-button {
      visibility: visible;
      display: block;
    }
}

@media (min-width: 200px) {

    .wrapper {
        /*grid-template-columns: var(--sb-width) 3fr 1fr;*/
        grid-template-columns: var(--sb-width) 3fr 0; /* Always hide ai container - possible future feature */
    }

    main {

    }

}

