:host {
  height: 100vh;
  width: 272px;
  user-select: none;
  box-sizing: border-box;
  display: inline-block;
  position: relative;
  white-space: nowrap;
}

@media (max-width: 900px) {
  :host {
    width: 70px;
  }
}

main {
  height: 100vh;
  box-sizing: border-box;
  width: 100%;
  padding: 0 var(--scale-400);
  margin: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  border-right: var(--border-width-sm) solid var(--color-border-primary);
  background-color: var(--color-surface-primary);

  color: var(--color-text-body);
  font-family: var(--font-family-body);
  font-size: var(--typography-size-body-sm);
  font-weight: var(--font-weight-semibold);
  line-height: var(--line-height-body-sm);
  letter-spacing: var(--font-letter-spacing-default);

  header {
    width: 100%;
    overflow: scroll;
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: flex-start;

    > div {
      display: flex;
      flex-direction: column;
      gap: var(--typography-spacing-md);
    }

    div:has(img) {
      display: flex;
      justify-content: center;
      align-items: flex-start;
      height: 40px;
      width: 100%;
      padding: var(--scale-400) 0;
      box-sizing: content-box;
      img {
        max-height: 40px;
        max-width: 100%;
      }
    }
  }

  div {
    box-sizing: border-box;
    width: 100%;

    &[disabled] {
      background-color: var(--color-surface-disabled);
      color: var(--color-text-disabled) svg {
        color: var(--color-icon-disabled);
      }
    }
  }

  h3 {
    font-family: var(--font-family-body);
    color: var(--color-text-disabled-on);
    margin: 0;
  }

  footer {
    margin-top: auto;
    width: 100%;

    @media (max-width: 900px) {
      display: none;
    }

    .logout {
      button {
        cursor: pointer;
        background-color: inherit;
        border: var(--border-width-sm) solid var(--color-border-secondary);
        color: var(--color-text-action);
        width: 100%;
        padding: var(--scale-250) var(--scale-200);
        border-radius: var(--border-radius-md);
        margin-bottom: var(--scale-250);

        &:focus-visible {
          outline: var(--border-width-sm) solid var(--color-border-focus);
          outline-offset: 1px;
        }

        &:hover {
          background-color: var(--color-surface-action-solid-hover);
          color: var(--color-text-action-on);
        }
      }
    }
  }
  .powered-by {
    user-select: none;
    box-sizing: content-box;
    margin-left: -16px;
    margin-right: -16px;
    border-top: var(--border-width-sm) solid var(--color-border-primary);
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    width: 100%;
    padding: 0;
    color: var(--color-text-body);
    font-family: var(--font-family-body);
    font-size: var(--typography-size-body-sm);
    font-weight: var(--font-weight-bold);
    line-height: var(--line-height-body-sm);
    letter-spacing: var(--font-letter-spacing-default);
    padding: var(--scale-400);
    gap: var(--scale-100);
    p {
      margin: 0;
    }
    img {
      width: 89px;
      height: 20px;
      max-width: 100%;
    }
  }
}
