@use 'responsive';
@use 'colours';
@use 'typography';
@use 'fontawesome';

nav#side-menu {
  background-color: colours.$colour-nav-bg;
  width: 100%;
  flex-direction: column;
  padding: 6px 0;

  @include responsive.not-desktop {
    display: none;
    visibility: hidden;
  }

  & > section {
    flex-grow: 1;
    border-bottom: 1px solid colours.$colour-divider;

    &.active {
      padding-bottom: 10px;
    }

    &:last-child {
      border-bottom: none;
    }

    & > h2 {
        margin: 0;
        line-height: 54px;

      > a {
        font-weight: normal;
        text-decoration: none;
        vertical-align: middle;
        font-size: 21px;
        line-height: 30px;
        padding: 0 18px;
        display: inline-block;
        width: 100%;
        color: colours.$colour-nav-subitem;

        &::after {
          @extend .fa;
          @extend .fa-chevron-right, :before;
          font-size: 14px;
          /* margin: 0 12px; */
          display: inline-block;
          float: right;
          line-height: 30px !important;
        }
      }
    }

    & > ul {
      display: none;
      visibility: hidden;
      margin-bottom: 0;
      position: relative;
    }

    &.active > ul {
      display: block;
      visibility: visible;

      & > li {
        margin-bottom: 0;
        transform: unset;
        padding-right: unset;
        &::before {
          margin: 0;
          content: none;
          display: none;
        }

        > a {
          display: inline-block;
          width: 100%;
          font-weight: typography.$font-weight-light;
          text-decoration: none;
          color: colours.$colour-nav-item;
          padding: 0 18px;
          font-size: 16px;
          line-height: 42px;

          &:hover {
            background-color: colours.$colour-nav-bg-hover;
          }

          &::after {
            @extend .fa;
            @extend .fa-chevron-right, :before;
            font-size: 12px;
            /* margin: 0 10px; */
            display: inline-block;
            float: right;
            line-height: 42px !important;
          }

        }

      }

    }
  }
}

.example-side-menu-wrap {
  max-width: 279px;
}
