/*
  Loader Animation
  The loading animation displayed when the SingleSPA framework is loading up
*/
.loader__container {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: var(--sc-loaderBackground);
  z-index: 1000;
  align-items: center;
  display: flex;
  justify-content: center;
}

.loader__container.hidden {
  display: none;
}

.loader {
  color: var(--sc-loaderText);
  font-size: 90px;
  text-indent: -9999em;
  overflow: hidden;
  width: 1em;
  height: 1em;
  border-radius: 50%;
  margin: 72px auto;
  position: relative;
  -webkit-transform: translateZ(0);
  -ms-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-animation: load6 1.7s infinite ease, round 1.7s infinite ease;
  animation: load6 1.7s infinite ease, round 1.7s infinite ease;
}
@-webkit-keyframes load6 {
  0% {
    box-shadow: 0 -0.83em 0 -0.4em, 0 -0.83em 0 -0.42em, 0 -0.83em 0 -0.44em, 0 -0.83em 0 -0.46em, 0 -0.83em 0 -0.477em;
  }
  5%,
  95% {
    box-shadow: 0 -0.83em 0 -0.4em, 0 -0.83em 0 -0.42em, 0 -0.83em 0 -0.44em, 0 -0.83em 0 -0.46em, 0 -0.83em 0 -0.477em;
  }
  10%,
  59% {
    box-shadow: 0 -0.83em 0 -0.4em, -0.087em -0.825em 0 -0.42em, -0.173em -0.812em 0 -0.44em, -0.256em -0.789em 0 -0.46em,
      -0.297em -0.775em 0 -0.477em;
  }
  20% {
    box-shadow: 0 -0.83em 0 -0.4em, -0.338em -0.758em 0 -0.42em, -0.555em -0.617em 0 -0.44em, -0.671em -0.488em 0 -0.46em,
      -0.749em -0.34em 0 -0.477em;
  }
  38% {
    box-shadow: 0 -0.83em 0 -0.4em, -0.377em -0.74em 0 -0.42em, -0.645em -0.522em 0 -0.44em, -0.775em -0.297em 0 -0.46em,
      -0.82em -0.09em 0 -0.477em;
  }
  100% {
    box-shadow: 0 -0.83em 0 -0.4em, 0 -0.83em 0 -0.42em, 0 -0.83em 0 -0.44em, 0 -0.83em 0 -0.46em, 0 -0.83em 0 -0.477em;
  }
}
@keyframes load6 {
  0% {
    box-shadow: 0 -0.83em 0 -0.4em, 0 -0.83em 0 -0.42em, 0 -0.83em 0 -0.44em, 0 -0.83em 0 -0.46em, 0 -0.83em 0 -0.477em;
  }
  5%,
  95% {
    box-shadow: 0 -0.83em 0 -0.4em, 0 -0.83em 0 -0.42em, 0 -0.83em 0 -0.44em, 0 -0.83em 0 -0.46em, 0 -0.83em 0 -0.477em;
  }
  10%,
  59% {
    box-shadow: 0 -0.83em 0 -0.4em, -0.087em -0.825em 0 -0.42em, -0.173em -0.812em 0 -0.44em, -0.256em -0.789em 0 -0.46em,
      -0.297em -0.775em 0 -0.477em;
  }
  20% {
    box-shadow: 0 -0.83em 0 -0.4em, -0.338em -0.758em 0 -0.42em, -0.555em -0.617em 0 -0.44em, -0.671em -0.488em 0 -0.46em,
      -0.749em -0.34em 0 -0.477em;
  }
  38% {
    box-shadow: 0 -0.83em 0 -0.4em, -0.377em -0.74em 0 -0.42em, -0.645em -0.522em 0 -0.44em, -0.775em -0.297em 0 -0.46em,
      -0.82em -0.09em 0 -0.477em;
  }
  100% {
    box-shadow: 0 -0.83em 0 -0.4em, 0 -0.83em 0 -0.42em, 0 -0.83em 0 -0.44em, 0 -0.83em 0 -0.46em, 0 -0.83em 0 -0.477em;
  }
}
@-webkit-keyframes round {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}
@keyframes round {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}

/*
  To force scollbars within the modules, remove scrollbars at top level
*/
html {
  overflow: hidden;
}

.spa-container {
  background-color: var(--sc-secondaryBackground);
}

/*
  Header Section (Top Section)
    - Set max height to prevent height issues with the app.
    - Use overflow to catch cases where the header is wider than the page.
*/
.spa-container > header {
  overflow-x: auto;
  overflow-y: hidden;
  max-height: var(--sc-headerSectionHeight);
  background: var(--sc-primaryBackground);
}

/*
  Nav & Page Sections (Bottom Section)
*/
.spa-container__main {
  display: flex;
}

/*
  Nav Section (Left Side Section)
*/
.spa-container__main > nav {
  max-width: var(--sc-navSectionWidth);
  max-height: var(--sc-pageSectionHeight);
}

/*
  Page Section (Rigth Side Section)
    - Set dimensions of main app section.
    - Use overflow to catch cases where the inner app is wider than the page.
*/
.spa-container__app-content {
  min-width: var(--sc-pageContentWidth);
  max-width: var(--sc-pageSectionWidth);
  min-height: var(--sc-pageContentHeight);
  max-height: var(--sc-pageSectionHeight);
  margin: calc(var(--sc-pageContentMargin) / 2);
  padding: calc(var(--sc-pageContentPadding) / 2);
  background-color: var(--sc-primaryBackground);
  border-radius: var(--sc-pageContentBorderRadius);
  overflow: auto;
}

/*
  Page Inner Content Section (Module Section - App.vue)
    - Set height of the element that main apps mount in.
    - Use overflow to catch cases where the app is taller than the page
*/
.spa-container__app-content > div > div {
  height: var(--sc-pageInnerContentHeight);
  overflow: auto;
}

.spa-content--home {
  margin-top: 75px;
}

.spa-content--home,
.spa-content--not-found {
  text-align: center;
}

.spa-content--home h2,
.spa-content--not-found h2 {
  font-size: 32px;
  margin: 20px 0;
}

/*
  Blackout Screen Overlay style.
  - This is a div that fills the screen.
  - It is black and placed above all the other element via the z-index
  - You can find this element on the index.ejs page.
*/
#blackout-overlay {
  width: 100vw;
  height: 100vh;
  background-color: black;
  display: block;
  position: fixed;
  left: 0;
  top: 0;
  z-index: 99999;
}

/*
  Class used to hide the overlay
*/
#blackout-overlay.hidden {
  display: none;
}
