/* Base Styles */

:root {
  --font-family-fixed: Consolas,Monaco,Lucida Console,Liberation Mono,DejaVu Sans Mono,Bitstream Vera Sans Mono,Courier New, monospace;

  --background:   #3B4145;
  --background-1: #3B4145;
  --background-2: #2B3034;
  --background-3: #1C2023;
  --background-4: #20252999;
  --background-5: #202529;
  --background-6: #4F565A;
  --background-7: #30353A;
  --background-8: #23292D;
  --background-9: #454B4F;
  --background-10: #121314;


  --color: #ffffff;
  --color-1: #ffffff;
  --color-2: #A1A4A6;
  --color-3: #808385;

  --color-hover: rgba(115, 130, 140, 0.25);

  --color-purple: #9f6dd2;
  --color-red: #D5412A;
  --color-green: #7FD918;
  --color-orange: #d89538;
  --color-brown: #8d562c;
  --color-white: white;
  --color-silver: #b4b2b5;
  --color-lightblue: #6495ed;

}

.silver {
  color: var(--color-silver);
}

.red {
  color: var(--color-red);
  --color: var(--color-red);
  --color-1: var(--color-red);
  --color-2: var(--color-red);
  --color-3: var(--color-red);
  --color-hover: var(--color-red);
}

.primary {
  color: var(--primary);
  --color: var(--primary);
  --color-1: var(--primary);
  --color-2: var(--primary);
  --color-3: var(--primary);
  --color-hover: var(--primary);
}

.green {
  color: var(--color-green);
}

.orange {
  color: var(--color-orange);
}

.brown {
  color: var(--color-brown);
}

.purple {
  color: var(--color-purple);
}

.white {
  color: var(--color-white);
}

body {
  font-size: 0.7rem;
}

input[type='number'] {
  -moz-appearance:textfield;
}

input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
  -webkit-appearance: none;
}

input[type=checkbox][readonly] {
  pointer-events: none;
}

.ternary-checkbox [type=checkbox]:indeterminate {
  background-color: var(--background-2);
  border: 1pt solid #666;
}

a.delete[role=button] {
  background-color: var(--color-red);
}

.loader-1 {
  width: 1.5rem;
  height: 1.5rem;
  margin: 0;
  border-radius: 50%;
  display: inline-block;
  position: relative;
  background: linear-gradient(0deg, rgba(255, 61, 0, 0.2) 33%, #ff3d00 100%);
  box-sizing: border-box;
  animation: rotation-1 1s linear infinite;
}

.loader-1::after {
  content: '';
  box-sizing: border-box;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 1.3rem;
  height: 1.3rem;
  border-radius: 50%;
  background: var(--background-3);
}

@keyframes rotation-1 {
  0% { transform: rotate(0deg) }
  100% { transform: rotate(360deg)}
}

.centered-icon {
  position: relative;
}

.bullet-button svg,
.bullet-button img,
.icon-button svg,
.icon-button img,
.centered-icon svg,
.centered-icon img {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%,-50%);
}

.icon-button {
  position: relative;
  display: inline-block;
  height: 1.5rem;
  width: 1.5rem;
  padding: 0;
  margin: 0 0.125rem;
  border: none;
  border-radius: 0.25rem;
  vertical-align: middle;
  color: var(--color-2);
  cursor: pointer;
  background: none;
}

.icon-button:hover {
  color: #000 !important;
  background: var(--color-3) !important;
}

.icon-button[aria-busy='true'] svg {
  display: none;
}

.bullet-button {
  display: flex;
  border-radius: 0.25rem;
  cursor: pointer;
}

.bullet-button:hover {
  background: var(--color-hover);
}

.bullet-button .icon {
  position: relative;
  height: 1.5rem;
  width: 1.5rem;
  margin: 0 0.75rem 0 0;
  padding: 0;
  border: none;
  border-radius: 0.25rem;
  vertical-align: middle;
  color: var(--color-2);
  background: var(--background-2);
  font-size: 0.8rem;
}

.bullet-button:hover .icon {
  background: none;
}

.bullet-button .label {
  font-size: 0.8rem;
  line-height: 1.5rem;
}

.flashRed {
  animation-duration: 1s;
  animation-name: flashRed;
}

@keyframes flashRed {
  from {
    box-shadow: 0 0 0.5rem 0.5rem var(--color-red);
  }

  to {}
}

/*
 * Popup
 */

.popup-anchor {
  position: relative;
  height: 1.5rem;
}

.popup-anchor .popup {
  max-width: 50vw;
  max-height: 90vh;
  border-radius: 0.5rem;
  border: 1px solid var(--border-color);
  background: var(--background-color);
  padding: 0.5rem;
  display: none;
  position: absolute;
  z-index: 99999;
}

.popup-anchor .popup-bottom {
  top: 100%;
  left: 0;
}

.popup-anchor .popup-bottom-left {
  top: 100%;
  right: 0;
}

.popup-anchor .popup-top {
  bottom: 100%;
  left: 0;
}

.popup-anchor .popup-overlay {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  z-index: 99990;
}

.popup-anchor:has(.popup-overlay) .popup {
  padding: 0.25rem;
}

.popup-anchor:not(:has(.popup-overlay)):hover .popup,
.popup-anchor:has(.popup-overlay).active .popup {
  display: flex;
  flex-direction: column;
}

.popup-anchor:not(:has(.popup-overlay)):hover .popup-overlay,
.popup-anchor:has(.popup-overlay).active .popup-overlay {
  display: block;
}

/*
 * Busy screen
 */

.busy-screen {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: var(--color-hover);
  display: none;
}

.busy-screen.htmx-request {
  display: block;
}

.busy-screen div {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
}

/*
 * Landing Page
 */


.landing-page {
  position: fixed;
  font-family: roboto;
  top: 0;
  left: 0;
  height: 100vh;
  width: 100vw;
  background: linear-gradient(111.68deg, #1C2023 0.62%, #475159 99.38%);
  background-image: url('/lib_web-app-common/images/landing-1.svg'),
                    linear-gradient(111.68deg, #1C2023 0.62%, #475159 99.38%);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: top left;
}

.landing-page .logo {
  position: absolute;
  width: 7rem;
  top: 2rem;
  left: 3rem;
}

.landing-page .login {
  position: absolute;
  top: 2rem;
  right: 2rem;
  width: 5rem;
  height: 2rem;
  font-size: 0.8rem;
  font-weight: 500;
  text-align: center;
  padding: 0.5rem;
  background: #1d1d1d99;
}

.landing-page .login:hover {
  background: #1d1d1d66;
}

.landing-page .content {
  position: absolute;
  left: 3rem;
  bottom: 3rem;
  padding: 0;
}

.landing-page .title {
  font-size: 2.2rem;
  font-weight: 300;
  line-height: 1.2;
}

.landing-page .subtitle {
  font-size: 2.4rem;
  font-weight: 500;
}

.landing-page .sign-in {
  width: 7rem;
  height: 2rem;
  margin-top: 0.5rem;
  font-size: 0.8rem;
  font-weight: 500;
  text-align: center;
  padding: 0.5rem;
}


/*
 * PAGE
 */

.page {
  position: relative;
  min-width: 0;
  min-height: 0;
}

.page.page-fixed {
  display: flex;
  flex-direction: column;
  width: 100vw;
  height: 100vh;
}

.page.page-fixed .page-content {
  margin-right: 1rem;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.page.page-scrollable {}

.page-background {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: var(--background-1);
  z-index: 1;
}

.page.embedded .page-background {
  background: var(--background-9);
}

/* Page Content */

.page-content {
  position: relative;
  width: calc(100vw - 2rem);
  margin: 4.5rem auto 1rem 1rem;
  flex: 1;
  display: flex;
  justify-content: space-around;
  min-width: 0;
  min-height: 0;
  z-index: 10;
  /* border-radius: 0.5rem; */
  /* background: var(--background-3); */
}

.page.embedded .page-content {
  margin: 0;
  min-height: 100vh;
  width: unset;
  height: unset;
}

/* Page Creator */

.page-creator {
  position: fixed;
  display: flex;
  flex-direction: column;
  top: 4.5rem;
  left: 1rem;
  height: calc(100vh - 5.5rem);
  width: calc(100vw - 2rem);
  overflow: auto;
  margin: 0;
  border-radius: 0.5rem;
  z-index: 20;
  background: var(--background-3);
}

.page-creator:not(.active) { display: none; }

.page-creator .creator-header {
  display: flex;
  position: sticky;
  top: 0;
  background: var(--background-3);
  padding: 0.5rem;
  margin: 0.5rem;
  font-size: 0.7rem;
  z-index: 10;
}

.creator-header .title {
  font-size: 0.8rem;
  line-height: 1.5rem;
  padding: 0 2rem 0 0.5rem;
}

.creator-header .creator-menu-search {
  flex: 1;
  box-shadow: none;
  border: none;
  border-radius: 0.75rem;
  height: 1.5rem;
  background-color: var(--background-1);
  background-image: var(--icon-search);
  background-repeat: no-repeat;
  background-position: calc(100% - 0.5rem);
  background-size: 1rem;
  margin: 0 0.5rem;
  padding: 0.5rem 2rem 0.5rem 0.7rem;
}

.creator-header .page-creator-close {}

@media screen and (max-width:1100px) {
  .creator-header .title {
    padding-right: 1rem;
  }

  .creator-header .creator-menu-search {
    width: 0;
  }
}

.page-creator .creator-body {
  display: flex;
  flex-direction: column;
}

.creator-body .creator-menu {
  display: flex;
  flex-direction: column;
  padding: 0 0.5rem;
  margin: 0 1rem;
  font-size: 0.7rem;
}

.creator-body .creator-menu:not(:has(.creator-menu-item:not(.hidden))) {
  display: none;
}

.creator-menu .creator-menu-title {
  font-size: 0.8rem;
  font-weight: 700;
  padding: 0.5rem 0;
}

.creator-menu table.creator-menu-primary {
  display: flex;
  --table-border-color: transparent;
  margin: 0;
  padding: 0;
}

.creator-menu table.creator-menu-primary tbody {
  flex: 1;
  display: flex;
  flex-wrap: wrap;
}

.creator-menu table.creator-menu-primary tr.creator-menu-item:not(.hidden) {
  flex: 1;
  display: block;
  border-radius: 0.5rem;
  cursor: pointer;
  min-width: 10rem;
  margin: 0.5rem;
}

.creator-menu table.creator-menu-primary tr.creator-menu-item:not(:hover) {
  background: black;
}

.creator-menu table.creator-menu-primary th.creator-menu-link {
  color: var(--primary);
}

.creator-menu table.creator-menu-primary .centered-icon {
  font-size: 0.9rem;
  color: var(--color-1);
}

.creator-menu .content-menu {
  margin: 1rem 0 0 0;
}

.creator-menu table {
  margin: 0;
}

.creator-menu .creator-menu-item .centered-icon {
  display: inline-block;
  width: 1.5rem;
  height: 1.5rem;
  margin: 0 0.125rem;
  vertical-align: middle;
}

.creator-menu .creator-menu-item td {
  color: var(--color-2);
}

.creator-menu .creator-menu-item:hover {
  background: var(--color-hover);
  color: var(--color-1);
  cursor: pointer;
}

.creator-menu .creator-menu-item-header th {
  font-size: 1.2em;
  color: var(--primary);
  border-bottom: 1px solid var(--border-color);
}

.creator-menu .creator-menu-item-header .icon-button {
  font-size: 0.6rem;
  float: right;
}

.creator-menu .creator-menu-item-header.collapsed .icon-button.collapse { display: none; }
.creator-menu .creator-menu-item-header:not(.collapsed) .icon-button.expand { display: none; }

.creator-menu .creator-menu-item.collapsed,
.creator-menu .creator-menu-item.hidden,
.creator-menu .creator-menu-item-header.hidden { display: none; }

/* Page Sidebar */

.page-sidebar {
  position: fixed;
  display: flex;
  top: 4.5rem;
  left: 1rem;
  z-index: 30;
}

.page.embedded .page-sidebar { display: none; }

.page-sidebar .page-sidebar-close,
.page-sidebar .page-sidebar-open {
  font-size: 1rem;
  margin: 0.25rem;
  background: var(--background-2);
}

.page-sidebar .page-sidebar-content {
  display: flex;
  flex-direction: column;
  height: calc(100vh - 5.5rem);
  margin: 0;
  background: var(--background-2);
  border-radius: 0.5rem;
}

/* Page Header */

.page-header {
  position: fixed;
  padding-left: 1rem;
  padding-top: 1rem;
  padding-bottom: 0.5rem;
  top: 0;
  left: 0;
  /* background: var(--background); */
  z-index: 40;
}

.page.embedded .page-header { display: none; }

.page-header .page-header-shell {
  display: flex;
  height: 3rem;
  width: calc(100vw - 2rem);
  background: var(--background-2);
  border-radius: 0.5rem;
}

.page-header .header-left {
  padding: 0.5rem;
}
.page-header .header-left .logo {
  display: inline-block;
  height: 2rem;
  vertical-align: middle;
}
.page-header .header-left .logo img {
  height: 1.2rem;
  margin: 0.4rem;
}

.page-header .header-middle {
  flex: 1;
}

.page-header .header-right {
  display: flex;
  padding: 0.5rem;
}

.page-header .header-button {
  position: relative;
  display: inline-block;
  height: 2rem;
  width: 2rem;
  margin: 0;
  font-size: 1rem;;
  color: var(--color-2);
  background: none;
}

.page-header .header-button img,
.page-header .header-button svg {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
}

.page-header .header-button:hover {
  background: var(--color-hover);
}

/*
 * Desktop view
 */

@media not screen and (max-width:1100px) {

  .page.page-sidebar-active-maybe .page-creator,
  .page.page-sidebar-active .page-creator {
    left: 15.5rem;
    width: calc(100vw - 16.5rem);
  }

  .page:has(.page-sidebar).page-sidebar-active-maybe:not(.embedded) .page-content,
  .page:has(.page-sidebar).page-sidebar-active:not(.embedded) .page-content {
    margin-left: 15.5rem;
    width: calc(100vw - 16.5rem);
  }

  .page-sidebar .page-sidebar-content {
    width: 12.5rem;
  }

  .page:not(.page-sidebar-active-maybe):not(.page-sidebar-active) .page-sidebar-content {
    display: none;
  }

  .page.page-sidebar-active-maybe .page-sidebar-open,
  .page.page-sidebar-active .page-sidebar-open {
    display: none;
  }

  .page:not(.page-sidebar-active-maybe):not(.page-sidebar-active) .page-sidebar-close {
    display: none;
  }

}

/*
 * Mobile view
 */

@media screen and (max-width:1100px) {

  .page-header .header-left .title {
    display: none !important;
  }

  .page.page-sidebar-active .page-creator { display: none; }

  .page.page-sidebar-active:not(.embdded) .page-content { display: none; }

  .page.page-sidebar-active .page-sidebar-content {
    width: calc(100vw - 2rem);
  }

  .page.page-sidebar-active .page-sidebar-open { display: none; }

  .page:not(.page-sidebar-active) .page-sidebar-close {
    display: none;
  }

  .page.page-sidebar-active .page-sidebar-close {
    position: absolute;
    top: 0;
    right: 0;
  }

  .page:not(.page-sidebar-active) .page-sidebar-content {
    display: none;
  }
}

/*
 * App menu
 */

.app-menu-btn {
  position: relative;
  /* width: 100%; */
  /* height: 100%; */
}

.app-menu-popup-root {
  position: absolute;
  z-index: 99999;
  bottom: 0;
  right: 0;
}

.app-menu-popup {
  width: 15rem;
  max-width: 50vw;
  max-height: 90vh;
  border-radius: 0.5rem;
  border: 1px solid var(--border-color);
  background: var(--background-3);
  padding: 1.5rem 0.5rem;
  display: none;
  overflow: visible;
  position: absolute;
  top: 0;
  right: 0;
}

.app-menu-popup-overlay {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  z-index: 99990;
}

.app-menu-btn.active .app-menu-popup {
  display: flex;
  flex-direction: column;
}

.app-menu-btn.active .app-menu-popup-overlay {
  display: block;
}

.app-menu-list {
  display: flex;
  flex-direction: column;
}

.app-menu-item {
  display: flex;
  cursor: pointer;
  text-decoration: none;
  color: white;
}

.app-menu-item:hover {
  background: var(--primary-focus);
}

.app-menu-item-icon {
  width: 1.8rem;
  height: 1.8rem;
  padding: 0.5rem;
  margin: 0.35rem 0.5rem;
  background: white;
  border-radius: 50%;
}

.app-menu-item-icon img,
.app-menu-item-icon svg {
  display: block;
  height: 0.9rem;
  width: 0.9rem;
}

.app-menu-item .label {
  flex: 1;
  font-size: 1rem;
  text-align: left;
  padding: 0.5rem 0;
}

.app-menu-item-popup {
  position: absolute;
  top: 0;
  right: 100%;
  width: 17.5rem;
  max-width: 50vw;
  border-radius: 0.5rem;
  border: 1px solid var(--border-color);
  background: var(--background-3);
  padding: 0.5rem;
  margin: 0.5rem;
  display: none;
}

.app-menu-item-popup .app-title {
  font-size: 0.9rem;
  color: #ff5900;
  padding: 0.5rem
           margin-bottom: 0.5rem;
}

.app-menu-item-popup .app-info {
  font-size: 0.7rem;
  padding: 0.5rem;
  margin-bottom: 0.5rem;
}

.app-menu-item-popup img {
  flex: 1;
}

.app-menu-item:hover .app-menu-item-popup {
  display: flex;
  flex-direction: column;
}

/*
 * MARKDOWN
 */

figure.md.image {
  width: fit-content;
  height: fit-content;
}

figure.md.image img {
  margin: 0;
}

figure.md.image.preview {
  position: relative;
  cursor: pointer;
}

figure.md.image.preview .indicator {
  display: none;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background: #000a var(--icon-eye) no-repeat center/1rem;
}

figure.md.image.preview:hover .indicator {
  display: block;
}

figure.md.image.preview .popup {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: #0003;
  z-index: 9999;
}

figure.md.image.preview .popup.shown {
  display: block;
}

figure.md.image.preview .popup > .item,
figure.md.image.preview .popup > img {
  width: fit-content;
  height: fit-content;
  max-width: 80vw;
  max-height: 80vh;
  object-fit: contain;
  margin: 50vh 0 0 50vw;
  transform: translate(-50%,-50%);
  cursor: auto;
}

figure.md.image.preview .popup::after {
  display: block;
  width: 2rem;
  height: 2rem;
  line-height: 2rem;
  text-align: center;
  background: white;
  color: black;
  content: "❌";
  position: absolute;
  top: 5%;
  right: 5%;
}

figure.md.image .item {
  display: flex;
  flex-direction: column;
  border: 1pt solid var(--border);
  border-radius: 0.3rem;
  overflow: hidden;
}

figure.md.image:has(.item) .indicator {
  border-radius: 0.3rem;
}

figure.md.image .item .bar {
  position: relative;
  background: var(--background-2);
  height: 1rem;
}

figure.md.image > *,
figure.md.image .item > * {
  margin: 0;
}

figure.md.image .item .bar::before {
  content: "•••";
  color: var(--color-2);
  position: absolute;
  top: 0;
  left: 0;
  line-height: 1rem;
  padding: 0 0.5rem;
}

.gallery.md {
  display: flex;
  flex-wrap: wrap;
}

.gallery.md figure.md.image {
  margin: 0.25rem;
}

.gallery.md figure.md.image > .item img {
  width: 16rem;
  height: 10rem;
  object-fit: cover;
}

.markdown-content p {
  color: var(--color-2);
  --font-weight: 400;
  margin-bottom: 0.5rem;
}

.markdown-content p.para-bright {
  color: white;
}

.markdown-content a,
.markdown-content p,
.markdown-content pre {
  font-size: 0.7rem;
  line-height: 0.9rem;
}

.markdown-content b,
.markdown-content strong {
  color: white;
  font-weight: bold;
}

.markdown-content blockquote {
  border-top: 1px solid var(--color-2);
  border-right: none;
  border-bottom: 1px solid var(--color-2);
  border-left: none;
  padding: 0.5rem 0;
  margin: 0.5rem 0;
}

.markdown-content blockquote p {
  font-size: 1rem;
  line-height: 1.2rem;
  font-weight: 300;
  color: var(--color-1);
}

.markdown-content blockquote blockquote {
  border: none;
  padding: 0;
  margin-bottom: 0;
}

.markdown-content blockquote blockquote p {
  font-size: 0.6rem;
  line-height: 0.7rem;
  margin-bottom: 0;
}

.markdown-content h1,
.markdown-content h2,
.markdown-content h3,
.markdown-content h4,
.markdown-content h5 {
  font-weight: 500;
  color: var(--color-1);
  padding-bottom: 0.5rem;
  margin-bottom: 0.5rem;
  --typography-spacing-vertical: 2rem;
}

.markdown-content h1 {
  border-bottom: 1px solid var(--color-2);
}

.markdown-content li {
  margin-left: 0.5rem;
}

.page .page-content .CodeMirror {
  height: 3rem;
}

.page .cm-s-ayu-dark div.CodeMirror-selected {
  background: var(--primary-focus);
}

.page .cm-s-ayu-dark .CodeMirror-placeholder {
  font-style: italic;
  color: var(--color-3);
}

.page .cm-s-ayu-dark .CodeMirror-line::selection,
.page .cm-s-ayu-dark .CodeMirror-line>span::selection,
.page .cm-s-ayu-dark .CodeMirror-line>span>span::selection {
  background: var(--primary-focus);
}

.page .cm-s-ayu-dark .CodeMirror-line::-moz-selection,
.page .cm-s-ayu-dark .CodeMirror-line>span::-moz-selection,
.page .cm-s-ayu-dark .CodeMirror-line>span>span::-moz-selection {
  background: var(--primary-focus);
}

/*
 * Sidebar Content
 */

.page-sidebar-content .sidebar-header {
  background: var(--background-3);
  margin: 0;
  /* min-height: 0.5rem; */
  border-radius: 0.5rem 0.5rem 0 0;
  padding: 0.5rem;
}

.sidebar-header .bullet-button {
  padding: 0.25rem;
}

.page-sidebar-content .sidebar-body {
  padding: 0.25rem 0;
  overflow: auto;
}

.sidebar-body .sidebar-leaf {
  display: flex;
  flex-wrap: wrap;
  padding: 0.25rem;
  cursor:  pointer;
  font-size: 0.6rem;
  background: var(--background-10);
  border-bottom: 1px solid var(--background-5);
}

.sidebar-body .sidebar-leaf.level-1 {
  font-size: 0.7rem;
  font-weight: 400;
  background: var(--background-5);
  border-bottom: 1px solid var(--background-10);
}

.sidebar-body .sidebar-leaf.level-2 {
  background: var(--background-3);
  border-bottom: 1px solid var(--background-10);
}

.sidebar-body .sidebar-leaf.active {
  background-color: var(--border-color);
}

.sidebar-body .sidebar-leaf:hover {
  background-color: var(--color-hover);
}

.sidebar-subnodes .sidebar-leaf.action {
  font-size: 0.5rem;
  font-style: italic;
  color: var(--color-2);
  justify-content: space-around;
}

.sidebar-leaf .icon {
  width: 1.5rem;
  height: 1.5rem;
  font-size: 0.7rem;
  color: var(--color-2);
}

.sidebar-leaf.level-1 .icon {
  font-size: 0.8rem;
}
.sidebar-leaf.level-1.expanded .icon {
  color: var(--color-1);
}

.sidebar-leaf.level-2 .icon {}

.sidebar-leaf .label {
  flex: 1;
  padding: 0.2rem;
}

.sidebar-leaf .control-bar {
  display: flex;
  margin-left: auto;
  font-size: 0.8rem;
  color: var(--color-2);
}

.sidebar-leaf .expand,
.sidebar-leaf .collapse {
  width: 1rem;
  height: 1.5rem;
  font-size: 0.5rem;
}

.sidebar-leaf.expanded .expand { display: none; }
.sidebar-leaf:not(.expanded) .collapse { display: none; }
.sidebar-leaf:not(.expanded) + .sidebar-subnodes { display: none; }

.sidebar-subnodes .no-subnodes {
  padding: 0.5rem;
  font-size: 0.5rem;
  font-style: italic;
  text-align: center;
  color: var(--color-2);
  opacity: 50%;
}


.sidebar-body .indicator:not(.circle) {
  font-size: 0.5rem;
  height: 0.75rem;
  padding: 0 0.25rem;
  margin: 0.25rem;
  border-radius: 0.1rem;
  display: inline-block;
  color: black;
}

.sidebar-body .indicator.circle {
  height: 0.4rem;
  width: 0.4rem;
  margin: 0.25rem;
  border-radius: 50%;
  display: inline-block;
}

.sidebar-body .indicator.date {
  color: var(--color-2);
}

.sidebar-body .indicator.yellow {
  background-color: var(--color-orange);
}

.sidebar-body .indicator.blue {
  background-color: var(--color-lightblue);
}

.sidebar-body .indicator.green {
  background-color: var(--color-green);
}

.sidebar-body .indicator.purple {
  background-color: var(--color-purple);
}

.sidebar-body .indicator.cyan {
  background-color: #65a9b4;
}

.sidebar-body .indicator.gray-1 {
  color: var(--color-1);
  background-color: #000;
}

.sidebar-body .indicator.gray-2 {
  color: var(--color-1);
  background-color: #333;
}

.sidebar-body .indicator.gray-3 {
  color: var(--color-1);
  background-color: #666;
}

.sidebar-body .indicator.gray-4 {
  color: var(--color-1);
  background-color: #999;
}


.page-sidebar-content .sidebar-footer {
  /* background: var(--background-3); */
  margin: 0;
  min-height: 0.5rem;
  border-radius: 0 0 0.5rem 0.5rem;
}

/*
 * Tool selector
 */

input.tool-list-search {
  flex: 1;
  box-shadow: none;
  border: none;
  border-radius: 0.75rem;
  height: 1.5rem;
  background-color: var(--background-1);
  background-image: var(--icon-search);
  background-repeat: no-repeat;
  background-position: calc(100% - 0.5rem);
  background-size: 1rem;
  padding: 0.5rem 2rem 0.5rem 0.7rem;
}


.tool-list-box {
  overflow: auto;
  min-height: 1rem;
}

.tool-list-box .tool-list-item th {
}

.tool-list-box .tool-list-item td {
  padding-left: 1.5rem;
  color: var(--color-2);
}

.tool-list-box .tool-list-item.selected {
  font-weight: bold;
  color: var(--color-1);
  background: var(--background-1);
}

.tool-list-box .tool-list-item:hover {
  background: var(--color-hover);
  color: var(--color-1);
  cursor: pointer;
}

.tool-list-box .tool-list-item-header th {
  font-size: 1.2em;
  color: var(--primary);
  border-bottom: 1px solid var(--border-color);
}

.tool-list-box .tool-list-item-header .icon-button {
  font-size: 0.6rem;
  float: right;
}

.tool-list-box .tool-list-item-header.collapsed .icon-button.collapse { display: none; }
.tool-list-box .tool-list-item-header:not(.collapsed) .icon-button.expand { display: none; }

.tool-list-box .tool-list-item.collapsed,
.tool-list-box .tool-list-item.hidden,
.tool-list-box .tool-list-item-header.hidden { display: none; }

/*
 * user page - common for all apps except product-hub
 */

#user-page-common {
  flex: 1;
  display: flex;
  flex-direction: column;
}

#user-page-common .profile {
  display: flex;
  flex-direction: column;
  text-align: center;
  font-size: 0.8rem;
  background: var(--background-5);
  border-radius: 0.5rem;
  padding: 1rem;
}

#user-page-common .greeting {
  font-weight: 300;
  color: var(--color-2);
}

#user-page-common .user-name {
  font-weight: 600;
}

#user-page-common .user-email {
  font-size: 0.6rem;
  margin: 1rem 0;
}

#user-page-common .footer {
  display: flex;
  margin: 1rem auto;
}

#user-page-common [role=button] {
  margin: 0 0.5rem;
  padding: 0.25rem 1rem;
}
