$icon-font-path: '~@neos21/bootstrap3-glyphicons/assets/fonts/';
@import '_bootstrap';

@import '_variables';
@import '_mixins';

@import '_fonts';

@import '~video.js/dist/video-js.css';

$assets-path: '../assets/';
@import './player/index';
@import './loading-bar';

@import './bootstrap';
@import './primeng-custom';

[hidden] {
  display: none !important;
}

body {
  /*** theme ***/
  // now beware node-sass requires interpolation
  // for css custom properties #{$var}
  --mainColor: #{$orange-color};
  --mainHoverColor: #{$orange-hover-color};
  --mainBackgroundColor: #{$bg-color};
  --mainForegroundColor: #{$fg-color};
  --menuBackgroundColor: #{$menu-background};
  --menuForegroundColor: #{$menu-color};
  --submenuColor: #{$sub-menu-color};
  --inputColor: #{$input-background-color};
  --inputPlaceholderColor: #{$input-placeholder-color};

  font-family: $main-fonts;
  font-weight: $font-regular;
  color: var(--mainForegroundColor);
  font-size: 14px;
}

#incompatible-browser {
  display: none;
  text-align: center;
  position: absolute;
  width: 100%;
  top: 45%;
}

strong {
  font-weight: $font-semibold;
}

input.readonly {
  /* Force blank on readonly inputs */
  background-color: var(--inputColor) !important;
}

input, textarea {
  outline: none;
  color: var(--mainForegroundColor);
}

.btn-outline-secondary {
  border-color: $input-border-color;
}

label {
  font-weight: $font-bold;
  font-size: 15px;
}

.form-error {
  display: block;
  color: $red;
  margin-top: 5px;
}

.input-error {
  border-color: $red !important;
}

.fullWidth {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  max-width: initial;
}

.glyphicon-black {
  color: black;
}

.main-col {
  margin-left: $menu-width;
  width: auto;

  .margin-content {
    margin-left: $not-expanded-horizontal-margins;
    margin-right: $not-expanded-horizontal-margins;
    flex-grow: 1;
  }

  .sub-menu {
    background-color: var(--submenuColor);
    width: 100%;
    height: 81px;
    margin-bottom: $sub-menu-margin-bottom;
    display: flex;
    align-items: center;
    padding-left: $not-expanded-horizontal-margins;
    padding-right: $not-expanded-horizontal-margins;
  }

  // Override some properties if the main content is expanded (no menu on the left)
  &.expanded {
    margin-left: 0;

    .margin-content {
      margin-left: $expanded-horizontal-margins;
      margin-right: $expanded-horizontal-margins;
    }

    .sub-menu {
      padding-left: $expanded-horizontal-margins;
      padding-right: $expanded-horizontal-margins;
    }
  }
}

.title-page {
  color: var(--mainForegroundColor);
  font-size: 16px;
  display: inline-block;
  margin-right: 55px;
  font-weight: $font-semibold;
  @include disable-default-a-behaviour;

  &.active, &.title-page-single {
    border-bottom: 2px solid var(--mainColor);
    font-weight: $font-bold;
    margin-top: 30px;
    margin-bottom: 25px;
  }

  &:hover, &:active, &:focus {
    color: var(--mainForegroundColor);
  }

  @media screen and (max-width: 500px) {
    margin-right: 15px;
  }
}

.admin-sub-header {
  display: flex;
  align-items: center;
  margin-bottom: 30px;

  .form-sub-title {
    flex-grow: 1;
  }

  .admin-sub-nav a {
    @include disable-default-a-behaviour;

    font-size: 16px;
    color: var(--mainForegroundColor);
    padding: 5px 15px;
    border-radius: 0.25rem;

    &.active {
      font-weight: $font-semibold;
      background-color: #f0f0f0;
      color: #000;
    }
  }
}

.form-sub-title {
  font-size: 20px;
  font-weight: bold;
}

@keyframes spin {
  from { transform: scale(1) rotate(0deg);}
  to { transform: scale(1) rotate(360deg);}
}

.orange-button {
  @include peertube-button;
  @include orange-button;
}

.orange-button-link {
  @include peertube-button-link;
  @include orange-button;
}

.grey-button {
  @include peertube-button;
  @include grey-button;
}

.grey-button-link {
  @include peertube-button-link;
  @include grey-button;
}

// In tables, don't have a hover different background
table {
  .action-button-edit, .action-button-delete {
    &:hover, &:active, &:focus, &[disabled], &.disabled {
      background-color: $grey-background-color !important;
    }
  }
}

.no-results {
  height: 40vh;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  font-weight: $font-semibold;
}

@media screen and (max-width: 1600px) {
  .main-col {
    &.expanded {
      .margin-content {
        margin-left: $expanded-horizontal-margins/2;
        margin-right: $expanded-horizontal-margins/2;
      }
    }
  }
}

@media screen and (max-width: 900px) {
  .main-col {
    &.expanded {
      .margin-content {
        margin-left: $expanded-horizontal-margins/3;
        margin-right: $expanded-horizontal-margins/3;
      }

      .sub-menu {
        padding-left: 50px;

        .title-page {
          font-size: 15px;
        }
      }
    }
  }
}

@media screen and (max-width: $small-view) {
  .main-col {
    margin-left: 0;

    &, &.expanded {
      .margin-content {
        margin-left: 15px;
        margin-right: 15px;
      }

      .sub-menu {
        width: 100vw;
        overflow-x: auto;
        padding-left: 15px;
        padding-right: 15px;
        margin-bottom: 10px;
      }

      input[type=text], input[type=password] {
        width: 100% !important;
      }
    }
  }
}