/*
 * SESAM application shell.
 *
 * Sidebar (blue, fixed left) + white top navbar layout used by the
 * Django application pages (anything extending base_application.html).
 *
 * Original structure derived from the SB-Admin-2 Bootstrap theme,
 * trimmed and re-prefixed for SESAM.
 */

/* ***************************************************
 * PAGE WRAPPER
 * *************************************************** */

#wrapper {
  display: flex;
}

#wrapper #content-wrapper {
  width: 100%;
  margin-left: var(--sesam-sidebar-width);
  overflow-x: hidden;
}

/* Default content-area background. Pages that opt into a decorative
   background (e.g. the auth pages) set their own class on #content and
   are excluded here so their background can take effect. */
#wrapper #content-wrapper #content:not(.sesam-lines-background) {
  flex: 1 0 auto;
  background-color: var(--sesam-content-bg) !important;
}

#wrapper #content-wrapper #content.sesam-lines-background {
  flex: 1 0 auto;
}

#white-navbar {
  height: var(--sesam-navbar-height) !important;
  background-color: var(--sesam-top-navbar-bg);
  z-index: 1001;
}

/* Bootstrap containers in the app shell get a small horizontal padding. */
.container,
.container-fluid,
.container-sm,
.container-md,
.container-lg,
.container-xl {
  padding-left: 1.5rem;
  padding-right: 1.5rem;
}

/* Cap the maximum container width at the Bootstrap-4-era 1140px. BS 5.3
   introduces an xxl breakpoint (≥1400px) that widens `.container` to
   1320px; SESAM intentionally keeps the narrower legacy width so login,
   account, and marketing layouts stay centered on large monitors. */
@media (min-width: 1400px) {
  .container,
  .container-sm,
  .container-md,
  .container-lg,
  .container-xl,
  .container-xxl {
    max-width: 1140px;
  }
}

/* ***************************************************
 * BLUE LEFT SIDEBAR
 * *************************************************** */

.sesam-sidebar {
  width: var(--sesam-sidebar-width);
  height: 100%;
  position: fixed;
  overflow: auto;
}

.sesam-bg-gradient-primary {
  background-color: var(--sesam-blue);
  background-size: cover;
}

.sesam-sidebar .nav-item {
  position: relative;
}

.sesam-sidebar .nav-item .nav-link {
  text-align: center;
  padding: 1rem 0.75rem;
}

.sesam-sidebar .nav-item .nav-link span {
  font-size: 0.65rem;
  display: inline;
}

.sesam-sidebar .nav-link .fas {
  font-size: 18px !important;
}

.sesam-sidebar .nav-item.active .nav-link {
  font-weight: 700;
}

/* Highlight active sidebar item with a thin white left border. */
.sesam-sidebar .nav-item.active {
  background-color: rgba(226, 239, 254, 0.08);
  border-left: 0.2rem solid #fff !important;
}

/* Compensate for the 0.2rem border so the icon stays centered. */
.sesam-sidebar .nav-item.active .nav-link {
  margin-left: -0.2rem;
}

.sesam-sidebar-logo {
  opacity: 0.3;
}

.sesam-sidebar-logo:hover {
  opacity: 1;
}

hr.sesam-sidebar-divider {
  margin: 1rem;
  border-top: 1px solid rgba(255, 255, 255, 0.15);
}

/* Dark variant (only one used in SESAM). */
.sesam-sidebar-dark .nav-item .nav-link {
  color: rgba(255, 255, 255, 0.8);
  text-align: center;
}

.sesam-sidebar-dark .nav-item .nav-link i {
  color: rgba(255, 255, 255, 0.3);
}

.sesam-sidebar-dark .nav-item .nav-link:active,
.sesam-sidebar-dark .nav-item .nav-link:focus,
.sesam-sidebar-dark .nav-item .nav-link:hover {
  color: #fff;
}

.sesam-sidebar-dark .nav-item .nav-link:active i,
.sesam-sidebar-dark .nav-item .nav-link:focus i,
.sesam-sidebar-dark .nav-item .nav-link:hover i {
  color: #fff;
}

.sesam-sidebar-dark .nav-item.active .nav-link,
.sesam-sidebar-dark .nav-item.active .nav-link i {
  color: #fff;
}

/* Vertical "account" nav inside the white content area. */
.sesam-vert-nav .nav-item.active {
  background-color: rgba(90, 134, 166, 0.2);
  border-left: 0.2rem solid var(--sesam-blue) !important;
}

/* ***************************************************
 * WHITE TOP NAVBAR (TOPBAR)
 * *************************************************** */

.sesam-topbar {
  height: 4.375rem;
}

/* Softer, wider topbar shadow than Bootstrap's default .shadow utility. */
.sesam-topbar.shadow {
  box-shadow: 0 0.15rem 1.75rem 0 rgba(58, 59, 69, 0.15) !important;
}

.sesam-topbar .nav-item .nav-link {
  display: flex;
  align-items: center;
  padding: 0 0.75rem;
}

.sesam-topbar .nav-item .nav-link:focus,
.sesam-topbar .nav-item:focus {
  outline: none;
}

.sesam-topbar .dropdown {
  position: static;
}

.sesam-topbar .dropdown .dropdown-menu {
  right: 0;
}

@media (min-width: 576px) {
  .sesam-topbar .dropdown {
    position: relative;
  }
  .sesam-topbar .dropdown .dropdown-menu {
    width: auto;
    right: 0;
  }
}

.sesam-topbar.navbar-light .navbar-nav .nav-item .nav-link {
  color: #d1d3e2;
}

.sesam-topbar.navbar-light .navbar-nav .nav-item .nav-link:hover {
  color: var(--sesam-blue);
}

.sesam-topbar.navbar-light .navbar-nav .nav-item .nav-link:active {
  color: #858796;
}

/* Replace Bootstrap's default triangular caret on dropdown toggles inside
   the sidebar and topbar with a Font Awesome chevron-down glyph (\f107). */
.sesam-sidebar .nav-item.dropdown .dropdown-toggle::after,
.sesam-topbar .nav-item.dropdown .dropdown-toggle::after {
  width: 1rem;
  text-align: center;
  float: right;
  vertical-align: 0;
  border: 0;
  font-weight: 900;
  content: '\f107';
  font-family: 'Font Awesome 5 Free', 'Font Awesome 6 Free';
}

/* ***************************************************
 * MOBILE OFFCANVAS SIDEBAR
 * Pattern from https://bootstrap-menu.com/detail-offcanvas-mobile.html
 * *************************************************** */

body.sesam-offcanvas-active {
  overflow: hidden;
}

#offcanvas-header-main-navbar {
  display: none;
}

@media all and (max-width: 767px) {
  .sesam-topbar .dropdown .dropdown-menu {
    margin-right: 1.5rem;
    margin-left: 1.5rem;
  }

  .sesam-sidebar .nav-item .nav-link span {
    display: block;
  }

  #offcanvas-header-main-navbar {
    display: block;
  }

  .sesam-mobile-offcanvas {
    visibility: hidden;
    transform: translateX(-100%);
    border-radius: 0;
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    height: 100%;
    z-index: 1200;
    overflow-y: scroll;
    overflow-x: hidden;
    transition:
      visibility 0.3s ease-in-out,
      transform 0.3s ease-in-out;
  }

  .sesam-mobile-offcanvas.show {
    visibility: visible;
    transform: translateX(0);
  }

  .sesam-mobile-offcanvas .container,
  .sesam-mobile-offcanvas .container-fluid {
    display: block;
  }

  #wrapper #content-wrapper {
    margin-left: 0 !important;
  }
}
