#wrap {
  overflow: hidden; }

.col-auto {
  max-width: 100%; }

/* md */
@media (min-width: 768px) {
  .fluid-reverse-md-l {
    margin-left: -15px; }
    .fluid-reverse-md-l.preloader {
      left: -15px; }

  .fluid-reverse-md-r {
    margin-right: -15px; }
    .fluid-reverse-md-r.preloader {
      right: -15px; } }
@media (max-width: 991px) {
  .master-container-fluid {
    padding-left: 15px;
    padding-right: 15px; }

  .fluid-reverse-l {
    margin-left: -15px; }
    .fluid-reverse-l.preloader {
      left: -15px; }

  .fluid-reverse-r {
    margin-right: -15px; }
    .fluid-reverse-r.preloader {
      right: -15px; } }
@media (min-width: 992px) {
  .master-container-fluid {
    padding-left: 51.5px;
    padding-right: 51.5px; }

  .fluid-reverse-l {
    margin-left: -51.5px; }
    .fluid-reverse-l.preloader {
      left: -51.5px; }

  .fluid-reverse-r {
    margin-right: -51.5px; }
    .fluid-reverse-r.preloader {
      right: -51.5px; }

  .fluid-reverse-lg-l {
    margin-left: -51.5px; }
    .fluid-reverse-lg-l.preloader {
      left: -51.5px; }

  .fluid-reverse-lg-r {
    margin-right: -51.5px; }
    .fluid-reverse-lg-r.preloader {
      right: -51.5px; }

  .fluid-reverse-lg-none {
    margin-right: 0; } }
.fluid-reverse-l.preloader, .fluid-reverse-r.preloader {
  min-width: 100%;
  width: auto;
  margin-right: 0;
  margin-left: 0; }

@media (min-width: 768px) {
  .fluid-reverse-md-none {
    margin: 0; }

  .fluid-reverse-r-md-none {
    margin-right: 0; }

  .fluid-reverse-md-l-none {
    margin-left: 0; } }
.col-grow-40 {
  flex: 0 0 40%;
  flex-grow: 1;
  width: 40%;
  max-width: none; }

.masonry-item {
  float: left; }

/* md */
@media (min-width: 768px) {
  .flex-column-content-md {
    width: 40%;
    flex: 2 0 auto;
    max-width: 90%; }

  .flex-column-sidebar-md {
    width: 350px;
    flex: 0 0 350px;
    max-width: 350px; }

  .col-md-grow-40 {
    flex: 0 0 40%;
    flex-grow: 1;
    width: 40%;
    max-width: none; } }
/* lg */
@media (min-width: 992px) {
  .col-lg-grow-40 {
    flex: 0 0 40%;
    flex-grow: 1;
    width: 40%;
    max-width: none; }

  .col-lg-grow-40 {
    flex: 0 0 auto;
    flex-grow: 1;
    width: 40%;
    max-width: none; } }
/* xl */
@media (min-width: 1200px) {
  .col-xl-grow-40 {
    flex: 0 0 40%;
    flex-grow: 1;
    width: 40%;
    max-width: none; }

  .col-xl-grow-40 {
    flex: 0 0 40%;
    flex-grow: 1;
    width: 40%;
    max-width: none; } }
@media (min-width: 1200px) {
  .flex-column-content-xl {
    width: 40%;
    flex: 2 0 auto;
    max-width: 90%; }

  .flex-column-sidebar-xl {
    width: 350px;
    flex: 0 0 350px;
    max-width: 350px; }

  .content-middle-grow {
    flex: 0 0 40%;
    flex-grow: 1;
    width: 40%;
    max-width: none; } }
/* extra large xxl */
@media (min-width: 1600px) {
  .d-xxl-flex {
    display: flex !important; }

  .d-xxl-none {
    display: none !important; }

  .col-xxl-1 {
    -ms-flex: 0 0 8.3333333333%;
    flex: 0 0 8.3333333333%;
    max-width: 8.3333333333%; }

  .col-xxl-2 {
    -ms-flex: 0 0 16.6666666667%;
    flex: 0 0 16.6666666667%;
    max-width: 16.6666666667%; }

  .col-xxl-3 {
    -ms-flex: 0 0 25%;
    flex: 0 0 25%;
    max-width: 25%; }

  .col-xxl-4 {
    -ms-flex: 0 0 33.3333333333%;
    flex: 0 0 33.3333333333%;
    max-width: 33.3333333333%; }

  .col-xxl-5 {
    -ms-flex: 0 0 41.6666666667%;
    flex: 0 0 41.6666666667%;
    max-width: 41.6666666667%; }

  .col-xxl-6 {
    -ms-flex: 0 0 50%;
    flex: 0 0 50%;
    max-width: 50%; }

  .col-xxl-7 {
    -ms-flex: 0 0 58.3333333333%;
    flex: 0 0 58.3333333333%;
    max-width: 58.3333333333%; }

  .col-xxl-8 {
    -ms-flex: 0 0 66.6666666667%;
    flex: 0 0 66.6666666667%;
    max-width: 66.6666666667%; }

  .col-xxl-9 {
    -ms-flex: 0 0 75%;
    flex: 0 0 75%;
    max-width: 75%; }

  .col-xxl-10 {
    -ms-flex: 0 0 83.3333333333%;
    flex: 0 0 83.3333333333%;
    max-width: 83.3333333333%; }

  .col-xxl-11 {
    -ms-flex: 0 0 91.6666666667%;
    flex: 0 0 91.6666666667%;
    max-width: 91.6666666667%; }

  .col-xxl-12 {
    -ms-flex: 0 0 100%;
    flex: 0 0 100%;
    max-width: 100%; }

  .justify-content-xxl-start {
    -ms-flex-pack: start !important;
    justify-content: flex-start !important; }

  .pb-xxl-3 {
    padding-bottom: 1rem !important; }

  .justify-content-xxl-end {
    -ms-flex-align: end !important;
    justify-content: flex-end !important; } }
/*numbered columns */
.columns-1 > * {
  -ms-flex: 0 0 100%;
  flex: 0 0 100%;
  max-width: 100%; }

.columns-2 > * {
  -ms-flex: 0 0 50%;
  flex: 0 0 50%;
  max-width: 50%; }

.columns-3 > * {
  -ms-flex: 0 0 33.3333333333%;
  flex: 0 0 33.3333333333%;
  max-width: 33.3333333333%; }

.columns-4 > * {
  -ms-flex: 0 0 25%;
  flex: 0 0 25%;
  max-width: 25%; }

.columns-5 > * {
  -ms-flex: 0 0 20%;
  flex: 0 0 20%;
  max-width: 20%; }

.columns-6 > * {
  -ms-flex: 0 0 16.6666666667%;
  flex: 0 0 16.6666666667%;
  max-width: 16.6666666667%; }

.columns-7 > * {
  -ms-flex: 0 0 14.2857142857%;
  flex: 0 0 14.2857142857%;
  max-width: 14.2857142857%; }

.columns-8 > * {
  -ms-flex: 0 0 12.5%;
  flex: 0 0 12.5%;
  max-width: 12.5%; }

.columns-9 > * {
  -ms-flex: 0 0 11.1111111111%;
  flex: 0 0 11.1111111111%;
  max-width: 11.1111111111%; }

.columns-10 > * {
  -ms-flex: 0 0 10%;
  flex: 0 0 10%;
  max-width: 10%; }

.columns-11 > * {
  -ms-flex: 0 0 9.0909090909%;
  flex: 0 0 9.0909090909%;
  max-width: 9.0909090909%; }

.columns-12 > * {
  -ms-flex: 0 0 8.3333333333%;
  flex: 0 0 8.3333333333%;
  max-width: 8.3333333333%; }

/* margin */
.mb-e-0 {
  margin-bottom: 0px !important; }

.mb-e-10 {
  margin-bottom: 10px !important; }

.mb-e-15 {
  margin-bottom: 15px !important; }

.mb-e-20 {
  margin-bottom: 20px !important; }

.mb-e-25 {
  margin-bottom: 25px !important; }

.mb-e-30 {
  margin-bottom: 30px !important; }

.mb-e-40 {
  margin-bottom: 40px !important; }

.mb-e-50 {
  margin-bottom: 50px !important; }

.mb-e-60 {
  margin-bottom: 60px !important; }

@media (min-width: 768px) {
  .mb-e-md-0 {
    margin-bottom: 0px !important; }

  .mb-e-md-10 {
    margin-bottom: 10px !important; }

  .mb-e-md-15 {
    margin-bottom: 15px !important; }

  .mb-e-md-20 {
    margin-bottom: 20px !important; }

  .mb-e-md-25 {
    margin-bottom: 25px !important; }

  .mb-e-md-30 {
    margin-bottom: 30px !important; }

  .mb-e-md-40 {
    margin-bottom: 40px !important; }

  .mb-e-md-50 {
    margin-bottom: 50px !important; }

  .mb-e-md-60 {
    margin-bottom: 60px !important; } }
@media (min-width: 992px) {
  .mb-e-lg-0 {
    margin-bottom: 0px !important; }

  .mb-e-lg-10 {
    margin-bottom: 10px !important; }

  .mb-e-lg-15 {
    margin-bottom: 15px !important; }

  .mb-e-lg-20 {
    margin-bottom: 20px !important; }

  .mb-e-lg-25 {
    margin-bottom: 25px !important; }

  .mb-e-lg-30 {
    margin-bottom: 30px !important; }

  .mb-e-lg-40 {
    margin-bottom: 40px !important; }

  .mb-e-lg-50 {
    margin-bottom: 50px !important; }

  .mb-e-lg-60 {
    margin-bottom: 60px !important; } }
@media (min-width: 1200px) {
  .mb-e-xl-0 {
    margin-bottom: 0px !important; }

  .mb-e-xl-10 {
    margin-bottom: 10px !important; }

  .mb-e-xl-15 {
    margin-bottom: 15px !important; }

  .mb-e-xl-20 {
    margin-bottom: 20px !important; }

  .mb-e-xl-25 {
    margin-bottom: 25px !important; }

  .mb-e-xl-30 {
    margin-bottom: 30px !important; }

  .mb-e-xl-40 {
    margin-bottom: 40px !important; }

  .mb-e-xl-50 {
    margin-bottom: 50px !important; }

  .mb-e-xl-60 {
    margin-bottom: 60px !important; } }
.mt-e-0 {
  margin-top: 0px !important; }

.mt-e-10 {
  margin-top: 10px !important; }

.mt-e-15 {
  margin-top: 15px !important; }

.mt-e-20 {
  margin-top: 20px !important; }

.mt-e-25 {
  margin-top: 25px !important; }

.mt-e-30 {
  margin-top: 30px !important; }

.mt-e-40 {
  margin-top: 40px !important; }

.mt-e-50 {
  margin-top: 50px !important; }

.mt-e-60 {
  margin-top: 60px !important; }

@media (min-width: 768px) {
  .mt-e-md-0 {
    margin-top: 0px !important; }

  .mt-e-md-10 {
    margin-top: 10px !important; }

  .mt-e-md-15 {
    margin-top: 15px !important; }

  .mt-e-md-20 {
    margin-top: 20px !important; }

  .mt-e-md-25 {
    margin-top: 25px !important; }

  .mt-e-md-30 {
    margin-top: 30px !important; }

  .mt-e-md-40 {
    margin-top: 40px !important; }

  .mt-e-md-50 {
    margin-top: 50px !important; }

  .mt-e-md-60 {
    margin-top: 60px !important; } }
@media (min-width: 992px) {
  .mt-e-lg-0 {
    margin-top: 0px !important; }

  .mt-e-lg-10 {
    margin-top: 10px !important; }

  .mt-e-lg-15 {
    margin-top: 15px !important; }

  .mt-e-lg-20 {
    margin-top: 20px !important; }

  .mt-e-lg-25 {
    margin-top: 25px !important; }

  .mt-e-lg-30 {
    margin-top: 30px !important; }

  .mt-e-lg-40 {
    margin-top: 40px !important; }

  .mt-e-lg-50 {
    margin-top: 50px !important; }

  .mt-e-lg-60 {
    margin-top: 60px !important; } }
@media (min-width: 1200px) {
  .mt-e-xl-0 {
    margin-top: 0px !important; }

  .mt-e-xl-10 {
    margin-top: 10px !important; }

  .mt-e-xl-15 {
    margin-top: 15px !important; }

  .mt-e-xl-20 {
    margin-top: 20px !important; }

  .mt-e-xl-25 {
    margin-top: 25px !important; }

  .mt-e-xl-30 {
    margin-top: 30px !important; }

  .mt-e-xl-40 {
    margin-top: 40px !important; }

  .mt-e-xl-50 {
    margin-top: 50px !important; }

  .mt-e-xl-60 {
    margin-top: 60px !important; } }
.ml-e-0 {
  margin-left: 0px !important; }

.ml-e-10 {
  margin-left: 10px !important; }

.ml-e-15 {
  margin-left: 15px !important; }

.ml-e-20 {
  margin-left: 20px !important; }

.ml-e-25 {
  margin-left: 25px !important; }

.ml-e-30 {
  margin-left: 30px !important; }

.ml-e-40 {
  margin-left: 40px !important; }

.ml-e-50 {
  margin-left: 50px !important; }

.ml-e-60 {
  margin-left: 60px !important; }

@media (min-width: 768px) {
  .ml-e-md-0 {
    margin-left: 0px !important; }

  .ml-e-md-10 {
    margin-left: 10px !important; }

  .ml-e-md-15 {
    margin-left: 15px !important; }

  .ml-e-md-20 {
    margin-left: 20px !important; }

  .ml-e-md-25 {
    margin-left: 25px !important; }

  .ml-e-md-30 {
    margin-left: 30px !important; }

  .ml-e-md-40 {
    margin-left: 40px !important; }

  .ml-e-md-50 {
    margin-left: 50px !important; }

  .ml-e-md-60 {
    margin-left: 60px !important; } }
@media (min-width: 992px) {
  .ml-e-lg-0 {
    margin-left: 0px !important; }

  .ml-e-lg-10 {
    margin-left: 10px !important; }

  .ml-e-lg-15 {
    margin-left: 15px !important; }

  .ml-e-lg-20 {
    margin-left: 20px !important; }

  .ml-e-lg-25 {
    margin-left: 25px !important; }

  .ml-e-lg-30 {
    margin-left: 30px !important; }

  .ml-e-lg-40 {
    margin-left: 40px !important; }

  .ml-e-lg-50 {
    margin-left: 50px !important; }

  .ml-e-lg-60 {
    margin-left: 60px !important; } }
@media (min-width: 1200px) {
  .ml-e-xl-0 {
    margin-left: 0px !important; }

  .ml-e-xl-10 {
    margin-left: 10px !important; }

  .ml-e-xl-15 {
    margin-left: 15px !important; }

  .ml-e-xl-20 {
    margin-left: 20px !important; }

  .ml-e-xl-25 {
    margin-left: 25px !important; }

  .ml-e-xl-30 {
    margin-left: 30px !important; }

  .ml-e-xl-40 {
    margin-left: 40px !important; }

  .ml-e-xl-50 {
    margin-left: 50px !important; }

  .ml-e-xl-60 {
    margin-left: 60px !important; } }
.mr-e-0 {
  margin-right: 0px !important; }

.mr-e-10 {
  margin-right: 10px !important; }

.mr-e-15 {
  margin-right: 15px !important; }

.mr-e-20 {
  margin-right: 20px !important; }

.mr-e-25 {
  margin-right: 25px !important; }

.mr-e-30 {
  margin-right: 30px !important; }

.mr-e-40 {
  margin-right: 40px !important; }

.mr-e-50 {
  margin-right: 50px !important; }

.mr-e-60 {
  margin-right: 60px !important; }

@media (min-width: 768px) {
  .mr-e-md-0 {
    margin-right: 0px !important; }

  .mr-e-md-10 {
    margin-right: 10px !important; }

  .mr-e-md-15 {
    margin-right: 15px !important; }

  .mr-e-md-20 {
    margin-right: 20px !important; }

  .mr-e-md-25 {
    margin-right: 25px !important; }

  .mr-e-md-30 {
    margin-right: 30px !important; }

  .mr-e-md-40 {
    margin-right: 40px !important; }

  .mr-e-md-50 {
    margin-right: 50px !important; }

  .mr-e-md-60 {
    margin-right: 60px !important; } }
@media (min-width: 992px) {
  .mr-e-lg-0 {
    margin-right: 0px !important; }

  .mr-e-lg-10 {
    margin-right: 10px !important; }

  .mr-e-lg-15 {
    margin-right: 15px !important; }

  .mr-e-lg-20 {
    margin-right: 20px !important; }

  .mr-e-lg-25 {
    margin-right: 25px !important; }

  .mr-e-lg-30 {
    margin-right: 30px !important; }

  .mr-e-lg-40 {
    margin-right: 40px !important; }

  .mr-e-lg-50 {
    margin-right: 50px !important; }

  .mr-e-lg-60 {
    margin-right: 60px !important; } }
@media (min-width: 1200px) {
  .mr-e-xl-0 {
    margin-right: 0px !important; }

  .mr-e-xl-10 {
    margin-right: 10px !important; }

  .mr-e-xl-15 {
    margin-right: 15px !important; }

  .mr-e-xl-20 {
    margin-right: 20px !important; }

  .mr-e-xl-25 {
    margin-right: 25px !important; }

  .mr-e-xl-30 {
    margin-right: 30px !important; }

  .mr-e-xl-40 {
    margin-right: 40px !important; }

  .mr-e-xl-50 {
    margin-right: 50px !important; }

  .mr-e-xl-60 {
    margin-right: 60px !important; } }
/* Paddings */
.pt-e-0 {
  padding-top: 0px !important; }

.pt-e-10 {
  padding-top: 10px !important; }

.pt-e-15 {
  padding-top: 15px !important; }

.pt-e-20 {
  padding-top: 20px !important; }

.pt-e-25 {
  padding-top: 25px !important; }

.pt-e-30 {
  padding-top: 30px !important; }

.pt-e-40 {
  padding-top: 40px !important; }

.pt-e-50 {
  padding-top: 50px !important; }

.pt-e-60 {
  padding-top: 60px !important; }

@media (min-width: 768px) {
  .pt-e-md-0 {
    padding-top: 0px !important; }

  .pt-e-md-10 {
    padding-top: 10px !important; }

  .pt-e-md-15 {
    padding-top: 15px !important; }

  .pt-e-md-20 {
    padding-top: 20px !important; }

  .pt-e-md-25 {
    padding-top: 25px !important; }

  .pt-e-md-30 {
    padding-top: 30px !important; }

  .pt-e-md-40 {
    padding-top: 40px !important; }

  .pt-e-md-50 {
    padding-top: 50px !important; }

  .pt-e-md-60 {
    padding-top: 60px !important; } }
@media (min-width: 992px) {
  .pt-e-lg-0 {
    padding-top: 0px !important; }

  .pt-e-lg-10 {
    padding-top: 10px !important; }

  .pt-e-lg-15 {
    padding-top: 15px !important; }

  .pt-e-lg-20 {
    padding-top: 20px !important; }

  .pt-e-lg-25 {
    padding-top: 25px !important; }

  .pt-e-lg-30 {
    padding-top: 30px !important; }

  .pt-e-lg-40 {
    padding-top: 40px !important; }

  .pt-e-lg-50 {
    padding-top: 50px !important; }

  .pt-e-lg-60 {
    padding-top: 60px !important; } }
@media (min-width: 1200px) {
  .pt-e-xl-0 {
    padding-top: 0px !important; }

  .pt-e-xl-10 {
    padding-top: 10px !important; }

  .pt-e-xl-15 {
    padding-top: 15px !important; }

  .pt-e-xl-20 {
    padding-top: 20px !important; }

  .pt-e-xl-25 {
    padding-top: 25px !important; }

  .pt-e-xl-30 {
    padding-top: 30px !important; }

  .pt-e-xl-40 {
    padding-top: 40px !important; }

  .pt-e-xl-50 {
    padding-top: 50px !important; }

  .pt-e-xl-60 {
    padding-top: 60px !important; } }
.pb-e-0 {
  padding-bottom: 0px !important; }

.pb-e-10 {
  padding-bottom: 10px !important; }

.pb-e-15 {
  padding-bottom: 15px !important; }

.pb-e-20 {
  padding-bottom: 20px !important; }

.pb-e-25 {
  padding-bottom: 25px !important; }

.pb-e-30 {
  padding-bottom: 30px !important; }

.pb-e-40 {
  padding-bottom: 40px !important; }

.pb-e-50 {
  padding-bottom: 50px !important; }

.pb-e-60 {
  padding-bottom: 60px !important; }

@media (min-width: 768px) {
  .pb-e-md-0 {
    padding-bottom: 0px !important; }

  .pb-e-md-10 {
    padding-bottom: 10px !important; }

  .pb-e-md-15 {
    padding-bottom: 15px !important; }

  .pb-e-md-20 {
    padding-bottom: 20px !important; }

  .pb-e-md-25 {
    padding-bottom: 25px !important; }

  .pb-e-md-30 {
    padding-bottom: 30px !important; }

  .pb-e-md-40 {
    padding-bottom: 40px !important; }

  .pb-e-md-50 {
    padding-bottom: 50px !important; }

  .pb-e-md-60 {
    padding-bottom: 60px !important; } }
@media (min-width: 992px) {
  .pb-e-lg-0 {
    padding-bottom: 0px !important; }

  .pb-e-lg-10 {
    padding-bottom: 10px !important; }

  .pb-e-lg-15 {
    padding-bottom: 15px !important; }

  .pb-e-lg-20 {
    padding-bottom: 20px !important; }

  .pb-e-lg-25 {
    padding-bottom: 25px !important; }

  .pb-e-lg-30 {
    padding-bottom: 30px !important; }

  .pb-e-lg-40 {
    padding-bottom: 40px !important; }

  .pb-e-lg-50 {
    padding-bottom: 50px !important; }

  .pb-e-lg-60 {
    padding-bottom: 60px !important; } }
@media (min-width: 1200px) {
  .pb-e-xl-0 {
    padding-bottom: 0px !important; }

  .pb-e-xl-10 {
    padding-bottom: 10px !important; }

  .pb-e-xl-15 {
    padding-bottom: 15px !important; }

  .pb-e-xl-20 {
    padding-bottom: 20px !important; }

  .pb-e-xl-25 {
    padding-bottom: 25px !important; }

  .pb-e-xl-30 {
    padding-bottom: 30px !important; }

  .pb-e-xl-40 {
    padding-bottom: 40px !important; }

  .pb-e-xl-50 {
    padding-bottom: 50px !important; }

  .pb-e-xl-60 {
    padding-bottom: 60px !important; } }
.pl-e-0 {
  padding-left: 0px !important; }

.pl-e-10 {
  padding-left: 10px !important; }

.pl-e-15 {
  padding-left: 15px !important; }

.pl-e-20 {
  padding-left: 20px !important; }

.pl-e-25 {
  padding-left: 25px !important; }

.pl-e-30 {
  padding-left: 30px !important; }

.pl-e-40 {
  padding-left: 40px !important; }

.pl-e-50 {
  padding-left: 50px !important; }

.pl-e-60 {
  padding-left: 60px !important; }

@media (min-width: 768px) {
  .pl-e-md-0 {
    padding-left: 0px !important; }

  .pl-e-md-10 {
    padding-left: 10px !important; }

  .pl-e-md-15 {
    padding-left: 15px !important; }

  .pl-e-md-20 {
    padding-left: 20px !important; }

  .pl-e-md-25 {
    padding-left: 25px !important; }

  .pl-e-md-30 {
    padding-left: 30px !important; }

  .pl-e-md-40 {
    padding-left: 40px !important; }

  .pl-e-md-50 {
    padding-left: 50px !important; }

  .pl-e-md-60 {
    padding-left: 60px !important; } }
@media (min-width: 992px) {
  .pl-e-lg-0 {
    padding-left: 0px !important; }

  .pl-e-lg-10 {
    padding-left: 10px !important; }

  .pl-e-lg-15 {
    padding-left: 15px !important; }

  .pl-e-lg-20 {
    padding-left: 20px !important; }

  .pl-e-lg-25 {
    padding-left: 25px !important; }

  .pl-e-lg-30 {
    padding-left: 30px !important; }

  .pl-e-lg-40 {
    padding-left: 40px !important; }

  .pl-e-lg-50 {
    padding-left: 50px !important; }

  .pl-e-lg-60 {
    padding-left: 60px !important; } }
@media (min-width: 1200px) {
  .pl-e-xl-0 {
    padding-left: 0px !important; }

  .pl-e-xl-10 {
    padding-left: 10px !important; }

  .pl-e-xl-15 {
    padding-left: 15px !important; }

  .pl-e-xl-20 {
    padding-left: 20px !important; }

  .pl-e-xl-25 {
    padding-left: 25px !important; }

  .pl-e-xl-30 {
    padding-left: 30px !important; }

  .pl-e-xl-40 {
    padding-left: 40px !important; }

  .pl-e-xl-50 {
    padding-left: 50px !important; }

  .pl-e-xl-60 {
    padding-left: 60px !important; } }
.pr-e-0 {
  padding-right: 0px !important; }

.pr-e-10 {
  padding-right: 10px !important; }

.pr-e-15 {
  padding-right: 15px !important; }

.pr-e-20 {
  padding-right: 20px !important; }

.pr-e-25 {
  padding-right: 25px !important; }

.pr-e-30 {
  padding-right: 30px !important; }

.pr-e-40 {
  padding-right: 40px !important; }

.pr-e-50 {
  padding-right: 50px !important; }

.pr-e-60 {
  padding-right: 60px !important; }

@media (min-width: 768px) {
  .pr-e-md-0 {
    padding-right: 0px !important; }

  .pr-e-md-10 {
    padding-right: 10px !important; }

  .pr-e-md-15 {
    padding-right: 15px !important; }

  .pr-e-md-20 {
    padding-right: 20px !important; }

  .pr-e-md-25 {
    padding-right: 25px !important; }

  .pr-e-md-30 {
    padding-right: 30px !important; }

  .pr-e-md-40 {
    padding-right: 40px !important; }

  .pr-e-md-50 {
    padding-right: 50px !important; }

  .pr-e-md-60 {
    padding-right: 60px !important; } }
@media (min-width: 992px) {
  .pr-e-lg-0 {
    padding-right: 0px !important; }

  .pr-e-lg-10 {
    padding-right: 10px !important; }

  .pr-e-lg-15 {
    padding-right: 15px !important; }

  .pr-e-lg-20 {
    padding-right: 20px !important; }

  .pr-e-lg-25 {
    padding-right: 25px !important; }

  .pr-e-lg-30 {
    padding-right: 30px !important; }

  .pr-e-lg-40 {
    padding-right: 40px !important; }

  .pr-e-lg-50 {
    padding-right: 50px !important; }

  .pr-e-lg-60 {
    padding-right: 60px !important; } }
@media (min-width: 1200px) {
  .pr-e-xl-0 {
    padding-right: 0px !important; }

  .pr-e-xl-10 {
    padding-right: 10px !important; }

  .pr-e-xl-15 {
    padding-right: 15px !important; }

  .pr-e-xl-20 {
    padding-right: 20px !important; }

  .pr-e-xl-25 {
    padding-right: 25px !important; }

  .pr-e-xl-30 {
    padding-right: 30px !important; }

  .pr-e-xl-40 {
    padding-right: 40px !important; }

  .pr-e-xl-50 {
    padding-right: 50px !important; }

  .pr-e-xl-60 {
    padding-right: 60px !important; } }
.pt-e-percent-1 {
  padding-top: 1%; }

.pt-e-percent-2 {
  padding-top: 2%; }

.pt-e-percent-3 {
  padding-top: 3%; }

.pt-e-percent-4 {
  padding-top: 4%; }

.pt-e-percent-5 {
  padding-top: 5%; }

.pt-e-percent-7 {
  padding-top: 7%; }

.pt-e-percent-8 {
  padding-top: 8%; }

.pt-e-percent-10 {
  padding-top: 10%; }

.pt-e-percent-12 {
  padding-top: 12%; }

.pt-e-percent-15 {
  padding-top: 15%; }

.pt-e-percent-18 {
  padding-top: 18%; }

.pt-e-percent-20 {
  padding-top: 20%; }

.pt-e-percent-25 {
  padding-top: 25%; }

.pb-e-percent-1 {
  padding-bottom: 1%; }

.pb-e-percent-2 {
  padding-bottom: 2%; }

.pb-e-percent-3 {
  padding-bottom: 3%; }

.pb-e-percent-4 {
  padding-bottom: 4%; }

.pb-e-percent-5 {
  padding-bottom: 5%; }

.pb-e-percent-7 {
  padding-bottom: 7%; }

.pb-e-percent-8 {
  padding-bottom: 8%; }

.pb-e-percent-10 {
  padding-bottom: 10%; }

.pb-e-percent-12 {
  padding-bottom: 12%; }

.pb-e-percent-15 {
  padding-bottom: 15%; }

.pb-e-percent-18 {
  padding-bottom: 18%; }

.pb-e-percent-20 {
  padding-bottom: 20%; }

.pb-e-percent-25 {
  padding-bottom: 25%; }

.pl-e-percent-1 {
  padding-left: 1%; }

.pl-e-percent-2 {
  padding-left: 2%; }

.pl-e-percent-3 {
  padding-left: 3%; }

.pl-e-percent-4 {
  padding-left: 4%; }

.pl-e-percent-5 {
  padding-left: 5%; }

.pl-e-percent-7 {
  padding-left: 7%; }

.pl-e-percent-8 {
  padding-left: 8%; }

.pl-e-percent-10 {
  padding-left: 10%; }

.pl-e-percent-12 {
  padding-left: 12%; }

.pl-e-percent-15 {
  padding-left: 15%; }

.pl-e-percent-18 {
  padding-left: 18%; }

.pl-e-percent-20 {
  padding-left: 20%; }

.pl-e-percent-25 {
  padding-left: 25%; }

.pr-e-percent-1 {
  padding-right: 1%; }

.pr-e-percent-2 {
  padding-right: 2%; }

.pr-e-percent-3 {
  padding-right: 3%; }

.pr-e-percent-4 {
  padding-right: 4%; }

.pr-e-percent-5 {
  padding-right: 5%; }

.pr-e-percent-7 {
  padding-right: 7%; }

.pr-e-percent-8 {
  padding-right: 8%; }

.pr-e-percent-10 {
  padding-right: 10%; }

.pr-e-percent-12 {
  padding-right: 12%; }

.pr-e-percent-15 {
  padding-right: 15%; }

.pr-e-percent-18 {
  padding-right: 18%; }

.pr-e-percent-20 {
  padding-right: 20%; }

.pr-e-percent-25 {
  padding-right: 25%; }

.pb-vh-5 {
  padding-bottom: 5vh; }

.pb-vh-7 {
  padding-bottom: 7vh; }

.pb-vh-10 {
  padding-bottom: 10vh; }

/* gutters */
.gutter-4 {
  margin-left: -2px;
  margin-right: -2px; }
  .gutter-4 [class^="col-"], .gutter-4 .owl-item .item, .gutter-4 .swiper-slide {
    padding-left: 2px;
    padding-right: 2px; }

@media (min-width: 768px) {
  .gutter-md-4 {
    margin-left: -2px;
    margin-right: -2px; }
    .gutter-md-4 [class^="col-"], .gutter-md-4 .owl-item .item, .gutter-md-4 .swiper-slide {
      padding-left: 2px;
      padding-right: 2px; } }
@media (min-width: 992px) {
  .gutter-lg-4 {
    margin-left: -2px;
    margin-right: -2px; }
    .gutter-lg-4 [class^="col-"], .gutter-lg-4 .owl-item .item, .gutter-lg-4 .swiper-slide {
      padding-left: 2px;
      padding-right: 2px; } }
@media (min-width: 1200px) {
  .gutter-xl-4 {
    margin-left: -2px;
    margin-right: -2px; }
    .gutter-xl-4 [class^="col-"], .gutter-xl-4 .owl-item .item, .gutter-xl-4 .swiper-slide {
      padding-left: 2px;
      padding-right: 2px; } }
.gutter-10 {
  margin-left: -5px;
  margin-right: -5px; }
  .gutter-10 [class^="col-"], .gutter-10 .owl-item .item, .gutter-10 .swiper-slide {
    padding-left: 5px;
    padding-right: 5px; }

@media (min-width: 768px) {
  .gutter-md-10 {
    margin-left: -5px;
    margin-right: -5px; }
    .gutter-md-10 [class^="col-"], .gutter-md-10 .owl-item .item, .gutter-md-10 .swiper-slide {
      padding-left: 5px;
      padding-right: 5px; } }
@media (min-width: 992px) {
  .gutter-lg-10 {
    margin-left: -5px;
    margin-right: -5px; }
    .gutter-lg-10 [class^="col-"], .gutter-lg-10 .owl-item .item, .gutter-lg-10 .swiper-slide {
      padding-left: 5px;
      padding-right: 5px; } }
@media (min-width: 1200px) {
  .gutter-xl-10 {
    margin-left: -5px;
    margin-right: -5px; }
    .gutter-xl-10 [class^="col-"], .gutter-xl-10 .owl-item .item, .gutter-xl-10 .swiper-slide {
      padding-left: 5px;
      padding-right: 5px; } }
.gutter-20 {
  margin-left: -10px;
  margin-right: -10px; }
  .gutter-20 [class^="col-"], .gutter-20 .owl-item .item, .gutter-20 .swiper-slide {
    padding-left: 10px;
    padding-right: 10px; }

@media (min-width: 768px) {
  .gutter-md-20 {
    margin-left: -10px;
    margin-right: -10px; }
    .gutter-md-20 [class^="col-"], .gutter-md-20 .owl-item .item, .gutter-md-20 .swiper-slide {
      padding-left: 10px;
      padding-right: 10px; } }
@media (min-width: 992px) {
  .gutter-lg-20 {
    margin-left: -10px;
    margin-right: -10px; }
    .gutter-lg-20 [class^="col-"], .gutter-lg-20 .owl-item .item, .gutter-lg-20 .swiper-slide {
      padding-left: 10px;
      padding-right: 10px; } }
@media (min-width: 1200px) {
  .gutter-xl-20 {
    margin-left: -10px;
    margin-right: -10px; }
    .gutter-xl-20 [class^="col-"], .gutter-xl-20 .owl-item .item, .gutter-xl-20 .swiper-slide {
      padding-left: 10px;
      padding-right: 10px; } }
.gutter-30 {
  margin-left: -15px;
  margin-right: -15px; }
  .gutter-30 [class^="col-"], .gutter-30 .owl-item .item, .gutter-30 .swiper-slide {
    padding-left: 15px;
    padding-right: 15px; }

@media (min-width: 768px) {
  .gutter-md-30 {
    margin-left: -15px;
    margin-right: -15px; }
    .gutter-md-30 [class^="col-"], .gutter-md-30 .owl-item .item, .gutter-md-30 .swiper-slide {
      padding-left: 15px;
      padding-right: 15px; } }
@media (min-width: 992px) {
  .gutter-lg-30 {
    margin-left: -15px;
    margin-right: -15px; }
    .gutter-lg-30 [class^="col-"], .gutter-lg-30 .owl-item .item, .gutter-lg-30 .swiper-slide {
      padding-left: 15px;
      padding-right: 15px; } }
@media (min-width: 1200px) {
  .gutter-xl-30 {
    margin-left: -15px;
    margin-right: -15px; }
    .gutter-xl-30 [class^="col-"], .gutter-xl-30 .owl-item .item, .gutter-xl-30 .swiper-slide {
      padding-left: 15px;
      padding-right: 15px; } }
.gutter-40 {
  margin-left: -20px;
  margin-right: -20px; }
  .gutter-40 [class^="col-"], .gutter-40 .owl-item .item, .gutter-40 .swiper-slide {
    padding-left: 20px;
    padding-right: 20px; }

@media (min-width: 768px) {
  .gutter-md-40 {
    margin-left: -20px;
    margin-right: -20px; }
    .gutter-md-40 [class^="col-"], .gutter-md-40 .owl-item .item, .gutter-md-40 .swiper-slide {
      padding-left: 20px;
      padding-right: 20px; } }
@media (min-width: 992px) {
  .gutter-lg-40 {
    margin-left: -20px;
    margin-right: -20px; }
    .gutter-lg-40 [class^="col-"], .gutter-lg-40 .owl-item .item, .gutter-lg-40 .swiper-slide {
      padding-left: 20px;
      padding-right: 20px; } }
@media (min-width: 1200px) {
  .gutter-xl-40 {
    margin-left: -20px;
    margin-right: -20px; }
    .gutter-xl-40 [class^="col-"], .gutter-xl-40 .owl-item .item, .gutter-xl-40 .swiper-slide {
      padding-left: 20px;
      padding-right: 20px; } }
.gutter-50 {
  margin-left: -25px;
  margin-right: -25px; }
  .gutter-50 [class^="col-"], .gutter-50 .owl-item .item, .gutter-50 .swiper-slide {
    padding-left: 25px;
    padding-right: 25px; }

@media (min-width: 768px) {
  .gutter-md-50 {
    margin-left: -25px;
    margin-right: -25px; }
    .gutter-md-50 [class^="col-"], .gutter-md-50 .owl-item .item, .gutter-md-50 .swiper-slide {
      padding-left: 25px;
      padding-right: 25px; } }
@media (min-width: 992px) {
  .gutter-lg-50 {
    margin-left: -25px;
    margin-right: -25px; }
    .gutter-lg-50 [class^="col-"], .gutter-lg-50 .owl-item .item, .gutter-lg-50 .swiper-slide {
      padding-left: 25px;
      padding-right: 25px; } }
@media (min-width: 1200px) {
  .gutter-xl-50 {
    margin-left: -25px;
    margin-right: -25px; }
    .gutter-xl-50 [class^="col-"], .gutter-xl-50 .owl-item .item, .gutter-xl-50 .swiper-slide {
      padding-left: 25px;
      padding-right: 25px; } }
.gutter-60 {
  margin-left: -30px;
  margin-right: -30px; }
  .gutter-60 [class^="col-"], .gutter-60 .owl-item .item, .gutter-60 .swiper-slide {
    padding-left: 30px;
    padding-right: 30px; }

@media (min-width: 768px) {
  .gutter-md-60 {
    margin-left: -30px;
    margin-right: -30px; }
    .gutter-md-60 [class^="col-"], .gutter-md-60 .owl-item .item, .gutter-md-60 .swiper-slide {
      padding-left: 30px;
      padding-right: 30px; } }
@media (min-width: 992px) {
  .gutter-lg-60 {
    margin-left: -30px;
    margin-right: -30px; }
    .gutter-lg-60 [class^="col-"], .gutter-lg-60 .owl-item .item, .gutter-lg-60 .swiper-slide {
      padding-left: 30px;
      padding-right: 30px; } }
@media (min-width: 1200px) {
  .gutter-xl-60 {
    margin-left: -30px;
    margin-right: -30px; }
    .gutter-xl-60 [class^="col-"], .gutter-xl-60 .owl-item .item, .gutter-xl-60 .swiper-slide {
      padding-left: 30px;
      padding-right: 30px; } }
.gutter-80 {
  margin-left: -40px;
  margin-right: -40px; }
  .gutter-80 [class^="col-"], .gutter-80 .owl-item .item, .gutter-80 .swiper-slide {
    padding-left: 40px;
    padding-right: 40px; }

@media (min-width: 768px) {
  .gutter-md-80 {
    margin-left: -40px;
    margin-right: -40px; }
    .gutter-md-80 [class^="col-"], .gutter-md-80 .owl-item .item, .gutter-md-80 .swiper-slide {
      padding-left: 40px;
      padding-right: 40px; } }
@media (min-width: 992px) {
  .gutter-lg-80 {
    margin-left: -40px;
    margin-right: -40px; }
    .gutter-lg-80 [class^="col-"], .gutter-lg-80 .owl-item .item, .gutter-lg-80 .swiper-slide {
      padding-left: 40px;
      padding-right: 40px; } }
@media (min-width: 1200px) {
  .gutter-xl-80 {
    margin-left: -40px;
    margin-right: -40px; }
    .gutter-xl-80 [class^="col-"], .gutter-xl-80 .owl-item .item, .gutter-xl-80 .swiper-slide {
      padding-left: 40px;
      padding-right: 40px; } }
/*side nav */
.fixed-layout-full {
  height: 100vh; }

.height-100 {
  height: 100%; }

.fixed-height-grow {
  flex: 2 0 auto;
  height: 50%; }

.player-fixed-bottom {
  height: 120px;
  flex: 0 0 120px;
  box-shadow: -5px 0px 5px 1px rgba(0, 0, 0, 0.1); }

.no-padding-left {
  padding-left: 0; }

.overflow-h {
  overflow: hidden; }

.overflow-x-h {
  overflow-x: hidden; }

.overflow-y-h {
  overflow-y: hidden; }

.no-padding-right {
  padding-right: 0; }

img {
  max-width: 100%; }

hr {
  border-top-color: #5e5d5a; }

.pointer {
  cursor: pointer; }

.inline-preloader {
  display: inline-block;
  position: relative;
  left: 3px;
  height: 0;
  width: 0;
  overflow: visible; }

.no-transition {
  transition: 0s !important; }

/* Dropdown */
#os-popup-menu {
  z-index: 2000;
  padding-top: 0;
  padding-bottom: 0; }
  #os-popup-menu li {
    position: relative; }
    #os-popup-menu li .dropdown-menu {
      left: 100%;
      top: 0;
      opacity: 0;
      display: none;
      transition: opacity 0.3s; }
    #os-popup-menu li.has-dropdown::after {
      content: "";
      border-width: 5px;
      border-color: transparent transparent transparent #111111;
      border-style: solid;
      height: 0;
      width: 0;
      position: absolute;
      right: 10px;
      top: 50%;
      transform: translateY(-50%); }
    #os-popup-menu li.has-dropdown:hover .dropdown-menu {
      opacity: 1;
      display: block; }
  #os-popup-menu ul {
    margin-bottom: 0;
    padding-top: 1.2rem;
    padding-bottom: 1.2rem; }
  #os-popup-menu .dropdown-item {
    padding: .32rem 1.8rem; }
  #os-popup-menu.dropdown-reverse .has-dropdown .dropdown-menu {
    left: auto;
    right: 100%; }

/* tabs */
.tabs-content {
  position: relative; }
  .tabs-content > .inactive-hide {
    top: 0;
    left: 0;
    right: 0;
    width: auto;
    opacity: 0;
    z-index: -1;
    position: absolute;
    transform-origin: top;
    -webkit-transform: scale(0.95);
    -ms-transform: scale(0.95);
    -moz-transform: scale(0.95);
    -o-transform: scale(0.95);
    transform: scale(0.95);
    transition: opacity 0.3s ease-out, transform 0.5s ease-out; }
    .tabs-content > .inactive-hide.active {
      z-index: 1;
      opacity: 1;
      position: relative;
      -webkit-transform: scale(1);
      -ms-transform: scale(1);
      -moz-transform: scale(1);
      -o-transform: scale(1);
      transform: scale(1); }

/*table */
.table td, .table th {
  border-color: #ebebeb; }

tr.border-top-0 td, tr.border-top-0 th {
  border-top: none; }

tr.border-bottom-0 td, tr.border-bottom-0 th {
  border-bottom: none; }

.table tbody tr:first-child th, .table tbody tr:first-child td {
  border-top: none; }

.dropdown-show {
  opacity: 1; }
  .dropdown-show#os-popup-menu {
    display: block !important; }

/* gradient and drop shadow */
.g-bg, .h-g-bg .hover-state {
  /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#c60000+0,b08cf9+86 */
  background: #c60000;
  /* Old browsers */
  background: -moz-linear-gradient(39deg, #c60000 0%, #e60000 86%);
  /* FF3.6-15 */
  background: -webkit-linear-gradient(39deg, #c60000 0%, #e60000 86%);
  /* Chrome10-25,Safari5.1-6 */
  background: linear-gradient(39deg, #c60000 0%, #e60000 86%);
  /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#c60000', endColorstr='#e60000',GradientType=1 );
  /* IE6-9 fallback on horizontal gradient */ }

.navbar .brand .logo-play {
  /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#c60000+0,b08cf9+86 */
  background: #c60000;
  /* Old browsers */
  background: -moz-linear-gradient(39deg, #c60000 0%, #e60000 86%);
  /* FF3.6-15 */
  background: -webkit-linear-gradient(39deg, #c60000 0%, #e60000 86%);
  /* Chrome10-25,Safari5.1-6 */
  background: linear-gradient(39deg, #c60000 0%, #e60000 86%);
  /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#c60000', endColorstr='#e60000',GradientType=1 );
  /* IE6-9 fallback on horizontal gradient */
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent; }

.h-g-bg:hover a, .h-g-bg:hover .title, .h-g-bg:hover .title a, .h-g-bg:hover p, .h-g-bg:hover .des p {
  color: #fff !important;
  transition-duration: 0s; }
.h-g-bg:hover .icon-dots span {
  background-color: #fff; }

.d-shadow, .h-d-shadow:hover {
  -webkit-box-shadow: 4px 4px 15px 0 rgba(168, 179, 211, 0.2);
  box-shadow: 4px 4px 15px 0 rgba(168, 179, 211, 0.2); }

.d-md-shadow, .h-d-md-shadow:hover {
  -webkit-box-shadow: 4px 4px 15px 0 rgba(168, 179, 211, 0.2);
  box-shadow: 4px 4px 15px 0 rgba(168, 179, 211, 0.2); }

.gradient-os {
  /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#c60000+0,b08cf9+86 */
  background: #c60000;
  /* Old browsers */
  background: -moz-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
  /* FF3.6-15 */
  background: -webkit-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
  /* Chrome10-25,Safari5.1-6 */
  background: linear-gradient(135deg, #c60000 0%, #e60000 86%);
  /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#c60000', endColorstr='#e60000',GradientType=1 );
  /* IE6-9 fallback on horizontal gradient */ }

.gradient-os-hover {
  position: relative;
  overflow: hidden;
  z-index: 1; }
  .gradient-os-hover::before {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    opacity: 0;
    z-index: -1;
    transition: opacity 0.3s; }
  .gradient-os-hover:hover {
    background: transparent; }
    .gradient-os-hover:hover::before {
      opacity: 1; }
  .gradient-os-hover > div {
    position: relative;
    z-index: 10; }

.w-nowrap {
  white-space: nowrap; }

.rounded-thumb {
  overflow: hidden;
  border-radius: 50%; }

/* Backgrounds */
.bg-white {
  background-color: #ffffff; }

.bg-dark {
  background-color: #222222; }

.bg-light-alt {
  background-color: #eeeeee; }

.bg-cover {
  background-size: cover; }

@-webkit-keyframes menuAnimeIn {
  from {
    margin-top: 15px;
    opacity: 0; }
  to {
    margin-top: .125rem;
    opacity: 1; } }
@keyframes menuAnimeIn {
  from {
    margin-top: 15px;
    opacity: 0; }
  to {
    margin-top: .125rem;
    opacity: 1; } }
@-webkit-keyframes menuAnimeOut {
  from {
    margin-top: 0.125rem;
    opacity: 0; }
  to {
    margin-top: 2.5rem;
    opacity: 1; } }
@keyframes menuAnimeOut {
  from {
    margin-top: 0.125rem;
    opacity: 0; }
  to {
    margin-top: 2.5rem;
    opacity: 1; } }
/* Dropdwon */
.dropdown-menu {
  min-width: 13rem;
  -webkit-animation-duration: 0.2s;
  -moz-animation-duration: 0.2s;
  -o-animation-duration: 0.2s;
  animation-duration: 0.2s; }
  .dropdown-menu.show {
    animation-name: menuAnimeIn; }

.dropdown-item {
  white-space: normal;
  padding: 0.3rem 1.5rem;
  font-size: 0.8125rem;
  color: #2a2824; }
  .dropdown-item:hover {
    color: #e60000;
    background: transparent; }
  .dropdown-item.active, .dropdown-item:active {
    /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#c60000+0,b08cf9+86 */
    background: #c60000;
    /* Old browsers */
    background: -moz-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
    /* FF3.6-15 */
    background: -webkit-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
    /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(135deg, #c60000 0%, #e60000 86%);
    /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#c60000', endColorstr='#e60000',GradientType=1 );
    /* IE6-9 fallback on horizontal gradient */
    color: #2a2824 !important; }

.dropdown-lg {
  min-width: 320px; }

/* Pagination start */
.pagination .page-item .page-link {
  color: #d5d6d6;
  background-color: #5e5d5a;
  border: 1px solid #2a2824; }
  .pagination .page-item .page-link:focus {
    color: #e2e3e4;
    text-decoration: none;
    background-color: #8e9194;
    border-color: #2a2824; }
  .pagination .page-item .page-link:hover {
    color: #e2e3e4;
    text-decoration: none;
    background-color: #8e9194;
    border-color: #2a2824; }
  .pagination .page-item .page-link:not([disabled]):not(.disabled) {
    cursor: pointer; }
.pagination .page-item.active .page-link {
  z-index: 1;
  color: #fff;
  background-color: #e60000;
  border-color: #2a2824; }

/* Pagination end */
/* Highlight */
.os-highlight-dark {
  background: #000000;
  color: #ffffff;
  border-radius: 0.2rem;
  padding: 0 3px;
  vertical-align: super;
  font-weight: normal; }

.os-highlight-active {
  /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#c60000+0,b08cf9+86 */
  background: #c60000;
  /* Old browsers */
  background: -moz-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
  /* FF3.6-15 */
  background: -webkit-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
  /* Chrome10-25,Safari5.1-6 */
  background: linear-gradient(135deg, #c60000 0%, #e60000 86%);
  /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#c60000', endColorstr='#e60000',GradientType=1 );
  /* IE6-9 fallback on horizontal gradient */
  color: #ffffff;
  padding: 0 3px;
  vertical-align: super;
  border-radius: 0.2rem;
  font-weight: normal; }

/* Off canvas */
.off-canvas {
  height: 100%;
  /* 100% Full-height */
  position: fixed !important;
  /* Stay in place */
  z-index: 1200;
  /* Stay on top */
  top: 0;
  transition: all 0.5s;
  /* 0.5 second transition effect to slide in the sidenav */
  background: #ffffff; }
  .off-canvas.off-canvas-static {
    position: relative !important; }
  .off-canvas.off-canvas-right {
    left: 100%;
    right: auto; }
  .off-canvas.off-canvas-left {
    right: 100%;
    left: auto;
    transform: translate(0px, 0);
    width: 580px;
    max-width: 100%; }
    .off-canvas.off-canvas-left.show {
      -webkit-box-shadow: 13px 36px 35px 0 rgba(165, 149, 198, 0.28);
      box-shadow: 13px 36px 35px 0 rgba(165, 149, 198, 0.28);
      transform: translate(100%, 0); }
  .off-canvas.off-canvas-left-fixed {
    right: 100%;
    left: auto;
    transform: translate(0px, 0);
    width: 350px;
    max-width: 100%; }
    .off-canvas.off-canvas-left-fixed.show {
      -webkit-box-shadow: 13px 36px 35px 0 rgba(165, 149, 198, 0.28);
      box-shadow: 13px 36px 35px 0 rgba(165, 149, 198, 0.28);
      transform: translate(100%, 0); }
  .off-canvas.off-canvas-full {
    right: 100%;
    left: auto;
    transform: translate(0px, 0);
    width: 100%; }
    .off-canvas.off-canvas-full.show {
      transform: translate(100%, 0); }

body.off-canvas-overlay-on {
  overflow-x: hidden; }

.off-canvas-overlay {
  background: rgba(0, 0, 0, 0.5);
  position: fixed;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease;
  z-index: -1; }

body.off-canvas-overlay-on .off-canvas-overlay {
  opacity: 1;
  z-index: 1100;
  visibility: visible; }

.off-canvas.show {
  display: block !important; }

.d-flex.show {
  display: flex !important; }

@media (min-width: 768px) {
  .off-canvas-off-md {
    position: inherit !important;
    z-index: 100 !important;
    height: auto !important; } }
.bg-current-color {
  background-color: currentcolor; }

.dropdown-menu {
  font-size: 0.8125rem; }

@media (min-width: 768px) {
  .d-shadow, .h-d-shadow {
    transition-duration: 0.3s; } }
::selection {
  background: #e60000;
  /* WebKit/Blink Browsers */
  color: #FFFFFF; }

::-moz-selection {
  background: #e60000;
  /* Gecko Browsers */
  color: #FFFFFF; }

.separator {
  line-height: 0; }
  .separator > span {
    width: 30px;
    display: inline-block;
    height: 2px;
    background: #151412; }
    .separator > span.separator-sm {
      width: 25px; }
    .separator > span.separator-md {
      width: 35px; }
    .separator > span.separator-lg {
      width: 50px; }

/* site content */
#site-content {
  position: static;
  transition: height 0.3s ease-in-out; }

.site-content-loading {
  /*  height: 50vh;
    max-height: 50vh;*/
  /* position: relative;
   overflow: hidden;*/ }

.accordion .title {
  position: relative; }
  .accordion .title::after {
    border-width: 6px;
    display: block;
    content: "";
    border-style: solid;
    position: absolute;
    right: 0;
    border-color: #000 transparent transparent;
    top: 0;
    transition: all 0.3s ease;
    -webkit-transform: rotate(180deg);
    -ms-transform: rotate(180deg);
    -moz-transform: rotate(180deg);
    -o-transform: rotate(180deg);
    transform: rotate(180deg); }
  .accordion .title.collapsed::after {
    -webkit-transform: rotate(0deg);
    -ms-transform: rotate(0deg);
    -moz-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    transform: rotate(0deg); }
.accordion .card {
  border: none;
  background: transparent; }

.bullet-1 {
  position: relative;
  padding-left: 25px; }
  .bullet-1::before {
    border-width: 4px;
    content: '';
    border-color: #8e9194;
    display: block;
    border-style: solid;
    border-radius: 4px;
    position: absolute;
    left: 0;
    top: 50%;
    -webkit-transform: translate(0, -50%);
    -ms-transform: translate(0, -50%);
    -moz-transform: translate(0, -50%);
    -o-transform: translate(0, -50%);
    transform: translate(0, -50%); }

.genres-horizontal {
  padding-top: 0.6rem;
  padding-bottom: 0.6rem;
  align-items: center; }
  .genres-horizontal.h-g-bg .hover-state {
    padding-right: 15px; }
  .genres-horizontal .hover-state .play-btn-dark {
    width: 24px;
    height: 24px;
    border-radius: 0;
    top: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 62px;
    border-radius: 0; }
  .genres-horizontal .hover-state .play-btn-light {
    background: rgba(0, 0, 0, 0.8);
    width: 45px;
    height: 45px;
    display: flex;
    text-align: center;
    align-items: center;
    justify-content: center;
    position: relative;
    /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#c60000+0,b08cf9+86 */
    background: #c60000;
    /* Old browsers */
    background: -moz-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
    /* FF3.6-15 */
    background: -webkit-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
    /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(135deg, #c60000 0%, #e60000 86%);
    /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#c60000', endColorstr='#e60000',GradientType=1 );
    /* IE6-9 fallback on horizontal gradient */ }

.genres-list-item .play-btn-light .play-icon {
  position: relative;
  width: 18px;
  height: 20px; }
.genres-list-item .play-btn-light:hover .play-icon::before {
  opacity: 0; }
.genres-list-item .play-btn-light:hover .play-icon::after {
  opacity: 1; }

body {
  font-family: "Poppins", sans-serif;
  font-size: 15px;
  line-height: 1.7;
  color: #b8babc;
  background: #151412 url(/assets/images/osbg.png) no-repeat;
  background-position: bottom;
background-size: contain;
  }

h1, .h1, h2, .h2, h3, .h3, h4, .h4, h5, .h5, h6, .h6 {
  color: #edeeef;
  font-family: "Poppins", sans-serif; }

h1, .h1 {
  font-size: 2.250625rem;
  font-weight: 700; }

h2, .h2 {
  font-size: 1.86875rem;
  font-weight: 700; }

h3, .h3 {
  font-size: 1.37475rem;
  font-weight: 600; }

h4, .h4 {
  font-size: 1.1253125rem;
  font-weight: 600; }

h5, .h5 {
  font-size: 0.999375rem;
  font-weight: 500; }

h6, .h6 {
  font-size: 0.8750625rem;
  font-weight: 500; }

@media (max-width: 768px) {
  .h1-md {
    font-size: 2.250625rem;
    font-weight: 700; }

  .h2-md {
    font-size: 1.86875rem;
    font-weight: 700; }

  .h3-md {
    font-size: 1.37475rem;
    font-weight: 600; }

  .h4-md {
    font-size: 1.1253125rem;
    font-weight: 600; }

  .h5-md {
    font-size: 0.999375rem;
    font-weight: 500; }

  .h6-md {
    font-size: 0.8750625rem;
    font-weight: 500; } }
/*font sizes*/
.fs-1 {
  font-size: 0.7475rem !important; }

.fs-2 {
  font-size: 0.8125rem !important; }

.fs-3 {
  font-size: 0.8775rem !important; }

.fs-4 {
  font-size: 0.9368125rem !important; }

.fs-5 {
  font-size: 1.0018125rem !important; }

.fs-6 {
  font-size: 1.1253125rem !important; }

.fs-7 {
  font-size: 1.2504375rem !important; }

.fs-8 {
  font-size: 1.38125rem !important; }

.fs-9 {
  font-size: 1.625rem !important; }

.fs-10 {
  font-size: 2.03125rem !important; }

.fs-11 {
  font-size: 2.4375rem !important; }

.fs-12 {
  font-size: 2.998125rem !important; }

.fs-13 {
  font-size: 3.7496875rem !important; }

@media (min-width: 768px) {
  .fs-md-1 {
    font-size: 0.7475rem !important; }

  .fs-md-2 {
    font-size: 0.8125rem !important; }

  .fs-md-3 {
    font-size: 0.8775rem !important; }

  .fs-md-4 {
    font-size: 0.9368125rem !important; }

  .fs-md-5 {
    font-size: 1.0018125rem !important; }

  .fs-md-6 {
    font-size: 1.1253125rem !important; }

  .fs-md-7 {
    font-size: 1.2504375rem !important; }

  .fs-md-8 {
    font-size: 1.38125rem !important; }

  .fs-md-9 {
    font-size: 1.625rem !important; }

  .fs-md-10 {
    font-size: 2.03125rem !important; }

  .fs-md-11 {
    font-size: 2.4375rem !important; }

  .fs-md-12 {
    font-size: 2.998125rem !important; }

  .fs-md-13 {
    font-size: 3.7496875rem !important; } }
@media (min-width: 992px) {
  .fs-lg-1 {
    font-size: 0.7475rem !important; }

  .fs-lg-2 {
    font-size: 0.8125rem !important; }

  .fs-lg-3 {
    font-size: 0.8775rem !important; }

  .fs-lg-4 {
    font-size: 0.9368125rem !important; }

  .fs-lg-5 {
    font-size: 1.0018125rem !important; }

  .fs-lg-6 {
    font-size: 1.1253125rem !important; }

  .fs-lg-7 {
    font-size: 1.2504375rem !important; }

  .fs-lg-8 {
    font-size: 1.38125rem !important; }

  .fs-lg-9 {
    font-size: 1.625rem !important; }

  .fs-lg-10 {
    font-size: 2.03125rem !important; }

  .fs-lg-11 {
    font-size: 2.4375rem !important; }

  .fs-lg-12 {
    font-size: 2.998125rem !important; }

  .fs-lg-13 {
    font-size: 3.7496875rem !important; } }
/* Font weights */
.f-w-100 {
  font-weight: 100 !important; }

.f-w-200 {
  font-weight: 200 !important; }

.f-w-300 {
  font-weight: 300 !important; }

.f-w-400 {
  font-weight: 400 !important; }

.f-w-500 {
  font-weight: 500 !important; }

.f-w-600 {
  font-weight: 600 !important; }

.f-w-700 {
  font-weight: 700 !important; }

.f-w-800 {
  font-weight: 800 !important; }

.f-w-900 {
  font-weight: 900 !important; }

/*letter spacing*/
.l-s-1 {
  letter-spacing: 0.1em; }

.l-s-2 {
  letter-spacing: 0.15em; }

a {
  color: #b8babc; }
  a:hover {
    text-decoration: none;
    color: #e60000; }
  a:focus {
    outline: none; }
  a.reverse {
    color: #e60000; }
    a.reverse:hover {
      color: #b8babc; }

.h-color-black:hover {
  color: #000000; }

@media (min-width: 768px) {
  a {
    transition: color 0.2s ease; } }
.active-color, .color-active {
  color: #e60000 !important; }

.inactive-color, .color-inactive, .sidebar .inactive-color, .sidebar .color-inactive {
  color: #8e9194; }

.inactive-color-two, .color-inactive-two {
  color: #edeeef; }

.active-color-2, .color-active-2 {
  color: #c60000 !important; }

.color-active-third, .color-active-3 {
  color: #a49ac3 !important; }

.color-pink {
  color: #ed145b !important; }

.inactive-colored-links a {
  color: #8e9194; }
  .inactive-colored-links a:hover {
    color: #e60000; }

.caps {
  text-transform: uppercase; }

.lh-0 {
  line-height: 0; }

.text-light::-webkit-input-placeholder {
  color: #FFFFFF; }
.text-light::-moz-placeholder {
  color: #FFFFFF; }
.text-light:-ms-input-placeholder {
  color: #FFFFFF; }

.black-text, .color-dark {
  color: #151412 !important; }

.color-white {
  color: #FFFFFF; }

/* Elements & components*/
.brand .icon-brand-play {
  /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#c60000+0,b08cf9+86 */
  background: #c60000;
  /* Old browsers */
  background: -moz-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
  /* FF3.6-15 */
  background: -webkit-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
  /* Chrome10-25,Safari5.1-6 */
  background: linear-gradient(135deg, #c60000 0%, #e60000 86%);
  /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#c60000', endColorstr='#e60000',GradientType=1 );
  /* IE6-9 fallback on horizontal gradient */
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent; }

.navbar {
  padding: .5rem 0;
  box-shadow: none;
}

.site-header {
  position: relative;
  background: #151412;
  border-bottom: 1px solid rgba(255,255,255,0.06); }
  .site-header a {
    color: #fff; }
    .site-header a:hover {
      color: #c60000; }
  .site-header .header-inner {
    padding-top: 7px;
    padding-bottom: 7px; }
  .site-header .absolute-header {
    position: absolute;
    width: 100%;
    top: 0;
    left: 0; }
  .site-header .navbar-tool {
    position: relative; }
    .site-header .navbar-tool .navbar-nav > li > a.nav-link {
      margin-left: 8px;
      margin-right: 8px; }
  .site-header .brand .logo-play {
    font-size: 39px;
    vertical-align: middle;
    margin-right: 10px; }
  .site-header #top-search {
    display: none;
    position: absolute;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0; }
    .site-header #top-search.show {
      display: block; }
    .site-header #top-search .form-control {
      width: 100%;
      height: 100%; }
  .site-header .dropdown-item {
    white-space: normal;
    padding: 0.3rem 1.5rem;
    font-size: 0.8125rem;
    color: #151412; }
    .site-header .dropdown-item:hover {
      color: #c60000;
      background: transparent; }
    .site-header .dropdown-item.active, .site-header .dropdown-item:active {
      /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#c60000+0,b08cf9+86 */
      background: #c60000;
      /* Old browsers */
      background: -moz-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
      /* FF3.6-15 */
      background: -webkit-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
      /* Chrome10-25,Safari5.1-6 */
      background: linear-gradient(135deg, #c60000 0%, #e60000 86%);
      /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
      filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#c60000', endColorstr='#e60000',GradientType=1 );
      /* IE6-9 fallback on horizontal gradient */
      color: #151412 !important; }
  .site-header .dropdown-menu {
    border: none;
    padding: 1.4rem 0; }
    .site-header .dropdown-menu a {
      color: #2a2824; }
      .site-header .dropdown-menu a:hover {
        color: #e60000; }
    .site-header .dropdown-menu .title, .site-header .dropdown-menu h5 {
      color: #000; }
  .site-header span.triangle {
    position: absolute;
    left: 25px;
    top: 0;
    transform: translateY(-90%); }
    .site-header span.triangle svg {
      fill: #fff;
      -webkit-filter: drop-shadow(0px -5px 6px rgba(0, 0, 0, 0.3));
      filter: drop-shadow(0px -5px 6px rgba(0, 0, 0, 0.3)); }
    .site-header span.triangle.drop-right {
      left: auto;
      right: 10px; }
  .site-header .user-settings-menu {
    font-size: 0.8125rem; }
    .site-header .user-settings-menu .li {
      display: block;
      width: 100%;
      float: none;
      clear: both; }
      .site-header .user-settings-menu .li .os-icon {
        width: 30px;
        text-align: center;
        float: left; }
  .site-header .dropdown-item {
    cursor: pointer; }
  .site-header #os-popup-menu .dropdown-item {
    font-size: 14px;
    padding-left: 15px; }
    .site-header #os-popup-menu .dropdown-item [class^="icon-"] {
      margin-right: 7px; }
  .site-header .dropdown-2x {
    min-width: 20rem; }
  .site-header .dropdown-md {
    min-width: 16.125rem; }

.notification-toggle.has-notification .notification {
  position: relative; }
  .notification-toggle.has-notification .notification:after {
    display: inline-block;
    content: "";
    width: 9px;
    height: 9px;
    background: #e60000;
    position: absolute;
    top: 0;
    right: 0;
    border-radius: 50%; }

.notifications.dropdown-menu {
  width: 324px; }

.notification.media {
  border-bottom: 1px solid #ddd;
  padding: 0.8rem 0;
  font-size: 0.8125rem; }
  .notification.media:last-child {
    border-bottom: 0; }
  .notification.media .user-thumb {
    max-width: 45px; }
  .notification.media p {
    margin-bottom: 0.3rem; }
  .notification.media a {
    color: #252525; }
  .notification.media a:hover {
    color: #e60000; }
  .notification.media .notification-desc {
    position: relative;
    padding-right: 30px; }
    .notification.media .notification-desc .close-notification {
      position: absolute;
      right: 0;
      top: 5px;
      border: 1px solid #959595;
      color: #959595;
      border-radius: 50%;
      cursor: pointer; }

#dropdownUserSettings img {
  max-width: 35px; }
#dropdownUserSettings::after {
  vertical-align: baseline; }

.navbar-nav .nav-item {
  display: flex;
  align-items: center; }

.navbar-toggler {
  display: flex;
  flex-direction: column;
  padding: 0;
  background: none;
  width: 40px;
  height: 40px;
  cursor: pointer;
  border: 1px solid #cccccc !important;
  border-radius: 50%;
  min-width: 40px;
  justify-content: center;
  align-items: flex-start !important;
  padding-left: 11px;
  border-radius: 50%; }
  .navbar-toggler .navbar-toggler-icon {
    display: block;
    height: 2px;
    background: currentColor;
    margin: 2px 0 2px 0;
    border-radius: 3px;
    width: 18px; }
    .navbar-toggler .navbar-toggler-icon:nth-child(3) {
      width: 0.7em; }
  .navbar-toggler:hover {
    background-color: #f9f9f9; }

.top-search-toggle {
  line-height: 0; }

.side-nav-container {
  overflow-x: hidden;
  height: 100%;
  max-width: 100%;
  width: 100%; }

#primary-menu-offcanvas {
  background: #2a2824;
  transition: all 0.3s ease; }

.side-nav {
  list-style: none;
  padding: 0;
  margin-top: 5vmin;
  width: 100%;
  transition: all 0.3s; }
  .side-nav a {
    display: block;
    position: relative;
    line-height: 1.1;
    font-weight: 700;
    padding: 0.5rem 1rem 0.5rem 5vmin;
    font-size: 2.3rem; }
    .side-nav a .os-icon {
      right: 1rem;
      top: 50%;
      position: absolute;
      -webkit-transform: translate(0, -50%);
      -ms-transform: translate(0, -50%);
      -moz-transform: translate(0, -50%);
      -o-transform: translate(0, -50%);
      transform: translate(0, -50%); }
  .side-nav .sub-level {
    list-style: none;
    padding: 0;
    margin: 0;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    -webkit-transform: translate3d(100%, 0, 0);
    -ms-transform: translate3d(100%, 0, 0);
    -moz-transform: translate3d(100%, 0, 0);
    -o-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
    display: none; }
  .side-nav .open.has-dropdown {
    transform: none !important; }
    .side-nav .open.has-dropdown .sub-level {
      display: block; }
  .side-nav .open .sub-level {
    opacity: 1; }
  .side-nav .nav-indicator {
    position: absolute;
    right: 5px;
    top: 50%;
    transform: translateY(-50%); }
  .side-nav.active-level-2 {
    -webkit-transform: translate3d(-100%, 0, 0);
    -ms-transform: translate3d(-100%, 0, 0);
    -moz-transform: translate3d(-100%, 0, 0);
    -o-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0); }
  .side-nav.active-level-3 {
    -webkit-transform: translate3d(-200%, 0, 0);
    -ms-transform: translate3d(-200%, 0, 0);
    -moz-transform: translate3d(-200%, 0, 0);
    -o-transform: translate3d(-200%, 0, 0);
    transform: translate3d(-200%, 0, 0); }

.bordered-round-btn-sm {
  border: 1px solid inherit;
  border-radius: 50%; }

.bordered-round-btn-md {
  border: 2px solid;
  border-radius: 50%;
  line-height: 0 !important;
  display: inline-block;
  text-align: center;
  padding: 4px; }

.user-settings-dropdown {
  width: 317px;
  padding-top: 0 !important;
  overflow: hidden; }
  .user-settings-dropdown .user-profile-image {
    border-radius: 50%;
    overflow: hidden;
    width: 100px;
    position: relative;
    left: 50%;
    margin-bottom: -30px;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    -o-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    border: 3px solid #ffffff; }
  .user-settings-dropdown .user-settings-menu a {
    display: block;
    padding: 0.5rem 2rem;
    border-left: 4px solid transparent;
    transition: all 0.3s; }
    .user-settings-dropdown .user-settings-menu a.active, .user-settings-dropdown .user-settings-menu a:hover {
      background: #ebf2f3;
      border-color: inherit; }

.header-light .color-variable {
  color: #FFFFFF !important; }

/* main menu */
.navbar .navbar-nav {
  font-size: 0.9368125rem;
  /* mega menu */ }
  .navbar .navbar-nav .menu-item {
    position: relative; }
  .navbar .navbar-nav > li > a, .navbar .navbar-nav > li.menu-item > a {
    white-space: nowrap;
    padding: 0.3rem 1.1rem;
    color: #fff;
    font-size: 0.9368125rem;
    font-weight: 400; }
    .navbar .navbar-nav > li > a:hover, .navbar .navbar-nav > li > a:active, .navbar .navbar-nav > li.menu-item > a:hover, .navbar .navbar-nav > li.menu-item > a:active {
      color: #c60000; }
  .navbar .navbar-nav > li.active > a, .navbar .navbar-nav > li.menu-item.active > a {
    color: #c60000; }
  .navbar .navbar-nav .dropdown-menu {
    padding-left: 1rem;
    padding-right: 1rem; }
    .navbar .navbar-nav .dropdown-menu li.menu-item a {
      display: block;
      color: #151412;
      font-weight: 400;
      font-size: 0.8125rem;
      padding: 0.3rem 0;
      letter-spacing: 0.5px;
      border-bottom: 1px solid #eeeeee; }
      .navbar .navbar-nav .dropdown-menu li.menu-item a:hover, .navbar .navbar-nav .dropdown-menu li.menu-item a:active, .navbar .navbar-nav .dropdown-menu li.menu-item a.active {
        color: #c60000; }
    .navbar .navbar-nav .dropdown-menu li.menu-item:last-child a {
      border-bottom: 0; }
  .navbar .navbar-nav > li:first-child > a.nav-link {
    padding-left: 0; }
  .navbar .navbar-nav > li:last-child > a.nav-link {
    padding-right: 0; }
  .navbar .navbar-nav .dropdown-mega-menu {
    width: auto; }
    .navbar .navbar-nav .dropdown-mega-menu li.menu-item a {
      display: block;
      color: #5e5d5a;
      font-weight: 400;
      font-size: 0.8125rem;
      padding: 0.3rem 0;
      letter-spacing: 0.5px;
      border-bottom: 1px solid #eeeeee; }
      .navbar .navbar-nav .dropdown-mega-menu li.menu-item a:hover, .navbar .navbar-nav .dropdown-mega-menu li.menu-item a:active, .navbar .navbar-nav .dropdown-mega-menu li.menu-item a.active {
        color: #e60000;
        background: none; }
    .navbar .navbar-nav .dropdown-mega-menu.show {
      display: flex; }
    .navbar .navbar-nav .dropdown-mega-menu .col {
      min-width: 10rem;
      padding-left: 1rem;
      padding-right: 1rem; }
    .navbar .navbar-nav .dropdown-mega-menu.dropdown-bg {
      padding-right: 8rem; }
    .navbar .navbar-nav .dropdown-mega-menu .bg-col {
      min-width: 12rem;
      background-repeat: no-repeat;
      position: absolute;
      height: 100%;
      top: 0;
      z-index: -1;
      right: 0;
      background-size: cover !important;
      border-radius: 4px; }
    .navbar .navbar-nav .dropdown-mega-menu li:last-child .menu-item {
      border-bottom: none; }
    .navbar .navbar-nav .dropdown-mega-menu h5 {
      color: #151412;
      letter-spacing: .15rem;
      margin-bottom: .8rem; }

/* Tabbed item */
#os-tabbed-nav {
  overflow-x: auto; }

.os-tabbed-nav.tab-style-2 {
  white-space: nowrap;
  flex-wrap: nowrap;
  overflow: visible; }
  .os-tabbed-nav.tab-style-2 .nav-item {
    padding: 0 1rem; }
    .os-tabbed-nav.tab-style-2 .nav-item .nav-link {
      padding: 0.3rem 0;
      display: block; }
    .os-tabbed-nav.tab-style-2 .nav-item:first-child .nav-link {
      padding-left: 0; }

.nav-border .nav-item, .nav-border .menu-item {
  font-size: 1.125rem; }
  .nav-border .nav-item a, .nav-border .nav-item .nav-link, .nav-border .menu-item a, .nav-border .menu-item .nav-link {
    padding: 0.5rem 1rem;
    color: #c60000;
    /*&:after{
      content: "";
      height: 3px;
      width: 30px;
      display: block;
      background: #000;
      opacity: 0;
      margin-top: 5px;
    }*/ }
    .nav-border .nav-item a.active:after, .nav-border .nav-item .nav-link.active:after, .nav-border .menu-item a.active:after, .nav-border .menu-item .nav-link.active:after {
      opacity: 1; }

.tab-style-1 {
  width: 100%;
  border-radius: 5px;
  overflow: hidden;
  position: relative; }
  .tab-style-1 .nav {
    display: flex;
    justify-content: space-between;
    position: relative;
    flex-wrap: nowrap; }
    .tab-style-1 .nav .menu-item, .tab-style-1 .nav .nav-item {
      margin: 0;
      position: static;
      -ms-flex-preferred-size: 0;
      flex-basis: 0;
      -ms-flex-positive: 1;
      flex-grow: 1;
      max-width: 100%;
      text-align: center;
      background: #2a2824;
      border-right: 1px solid #000;
      white-space: nowrap; }
      .tab-style-1 .nav .menu-item a, .tab-style-1 .nav .nav-item a {
        padding: 1rem 2rem;
        position: relative;
        color: #b8babc; }
        .tab-style-1 .nav .menu-item a span, .tab-style-1 .nav .nav-item a span {
          position: relative;
          z-index: 2; }
        .tab-style-1 .nav .menu-item a::before, .tab-style-1 .nav .nav-item a::before {
          content: '';
          width: 100%;
          position: absolute;
          left: 0;
          top: 0;
          display: block;
          height: 0;
          z-index: 1;
          opacity: 0;
          /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#c60000+0,b08cf9+86 */
          background: #c60000;
          /* Old browsers */
          background: -moz-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
          /* FF3.6-15 */
          background: -webkit-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
          /* Chrome10-25,Safari5.1-6 */
          background: linear-gradient(135deg, #c60000 0%, #e60000 86%);
          /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
          filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#c60000', endColorstr='#e60000',GradientType=1 );
          /* IE6-9 fallback on horizontal gradient */
          transition: all 0.4s ease-in-out; }
        .tab-style-1 .nav .menu-item a.active, .tab-style-1 .nav .nav-item a.active {
          color: #fff; }
          .tab-style-1 .nav .menu-item a.active::before, .tab-style-1 .nav .nav-item a.active::before {
            height: 100%;
            opacity: 1; }
          .tab-style-1 .nav .menu-item a.active .os-icon, .tab-style-1 .nav .nav-item a.active .os-icon {
            color: #fff; }
      .tab-style-1 .nav .menu-item::after, .tab-style-1 .nav .nav-item::after {
        content: '';
        height: 50%;
        width: 1px; }
      .tab-style-1 .nav .menu-item:last-child, .tab-style-1 .nav .nav-item:last-child {
        border-right: none; }

/* Full screen nav */
.off-canvas-full .side-nav {
  font-weight: 700; }
  .off-canvas-full .side-nav .os-icon svg {
    height: auto; }

@media (max-width: 576px) {
  .navbar-secondary .nav-link {
    display: block;
    padding: .5rem 0.7rem; }

  #dropdownUserSettings img {
    max-width: 30px; } }
.moving-border {
  position: relative; }
  .moving-border .m-item {
    position: relative; }

hr.border-hr {
  margin: 0;
  height: 3px;
  bottom: 0;
  border: 0;
  width: 0;
  position: absolute;
  transition: 0.3s ease-in-out;
  /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#c60000+0,b08cf9+86 */
  background: #c60000;
  /* Old browsers */
  background: -moz-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
  /* FF3.6-15 */
  background: -webkit-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
  /* Chrome10-25,Safari5.1-6 */
  background: linear-gradient(135deg, #c60000 0%, #e60000 86%);
  /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#c60000', endColorstr='#e60000',GradientType=1 );
  /* IE6-9 fallback on horizontal gradient */ }

.align-items-center.align-items-stretch .nav-item > a, .align-items-center.align-items-stretch > div > a.nav-link {
  height: 100%;
  display: flex;
  align-items: center; }

.sidebar .lt-side-menu a {
  color: #252525; }
  .sidebar .lt-side-menu a:hover {
    color: #e60000; }
.sidebar .lt-side-menu li.active a {
  color: #e60000; }

.lt-side-menu-title {
  font-weight: 600; }

@-webkit-keyframes os-play-loading {
  0% {
    height: 0; }
  100% {
    height: 100%; } }
@keyframes os-play-loading {
  0% {
    height: 0; }
  100% {
    height: 100%; } }
@-webkit-keyframes bounce {
  from {
    -webkit-transform: translateY(0px);
    -ms-transform: translateY(0px);
    -moz-transform: translateY(0px);
    -o-transform: translateY(0px);
    transform: translateY(0px); }
  to {
    -webkit-transform: translateY(-15px);
    -ms-transform: translateY(-15px);
    -moz-transform: translateY(-15px);
    -o-transform: translateY(-15px);
    transform: translateY(-15px); } }
@keyframes bounce {
  from {
    -webkit-transform: translateY(0px);
    -ms-transform: translateY(0px);
    -moz-transform: translateY(0px);
    -o-transform: translateY(0px);
    transform: translateY(0px); }
  to {
    -webkit-transform: translateY(-15px);
    -ms-transform: translateY(-15px);
    -moz-transform: translateY(-15px);
    -o-transform: translateY(-15px);
    transform: translateY(-15px); } }
.section-preloader-wrap {
  min-height: 125px; }

.preloader {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  transform-origin: 50% 200px; }
  .preloader.tab-preloader {
    display: none;
    z-index: 800; }
  .preloader.section-loader {
    display: none;
    z-index: 800; }
  .preloader.site-preloader {
    z-index: 2000;
    position: fixed; }
  .preloader .preloader-overlay {
    background: #151412;
    position: absolute;
    width: 100%;
    bottom: 0;
    left: 0;
    top: 0; }
  .preloader.negative-overlay .preloader-overlay {
    top: -200px; }
  .preloader .center-center {
    position: fixed;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    z-index: 2000; }
  .preloader > .loader-icon {
    position: absolute;
    left: 50%;
    top: 0;
    z-index: 1900;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    -o-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%); }
  .preloader .animate-loading {
    position: absolute;
    animation: os-play-loading 5s infinite alternate;
    z-index: 1;
    bottom: 0;
    left: 0;
    overflow: hidden;
    width: 100%; }
    .preloader .animate-loading .os-icon {
      position: absolute;
      bottom: 0;
      z-index: 10;
      left: 0; }
  .preloader .shadow {
    width: 200%;
    height: 20px;
    display: block;
    top: 100%;
    position: absolute;
    border-radius: 50%;
    box-shadow: 0 27px 20px 0 #5e5d5a !important;
    left: -55%; }
  .preloader .icons {
    animation: bounce 1s infinite alternate;
    -webkit-transform-origin: center bottom;
    transform-origin: center bottom; }
  .preloader .tab-loader {
    -webkit-transform: translateY(20vh);
    -ms-transform: translateY(20vh);
    -moz-transform: translateY(20vh);
    -o-transform: translateY(20vh);
    transform: translateY(20vh); }
  .preloader .top-50-vh {
    left: 50%;
    top: 50vh;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    -o-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%); }

.preloader-static {
  min-height: 50px; }

.os-rotate,
.os-rotate > div {
  position: relative;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box; }

.os-rotate {
  display: block;
  font-size: 0;
  color: #fff; }

.os-rotate.dark {
  color: #333; }

.os-rotate > div {
  display: inline-block;
  float: none;
  background-color: transparent;
  border-radius: 100%;
  -webkit-box-shadow: 0px 0px 0px 2px #ddd inset;
  box-shadow: 0px 0px 0px 2px #ddd inset; }

.os-rotate {
  width: 32px;
  height: 32px; }

.os-rotate > div {
  width: 32px;
  height: 32px; }
  .os-rotate > div div {
    width: 100%;
    height: 100%;
    background: transparent;
    border-width: 2px;
    border: 2px solid #000;
    border-bottom-color: transparent;
    border-radius: 100%;
    -webkit-animation: ball-clip-rotate .75s linear infinite;
    -moz-animation: ball-clip-rotate .75s linear infinite;
    -o-animation: ball-clip-rotate .75s linear infinite;
    animation: ball-clip-rotate .75s linear infinite;
    position: absolute;
    border-right-color: transparent;
    border-left-color: transparent; }

.os-rotate.os-sm {
  width: 16px;
  height: 16px; }

.os-rotate.os-sm > div {
  width: 16px;
  height: 16px;
  -webkit-box-shadow: 0 0 0 1px #ddd inset;
  box-shadow: 0 0 0 1px #ddd inset; }
  .os-rotate.os-sm > div div {
    border-width: 1px; }

.os-rotate.os-2x {
  width: 64px;
  height: 64px; }

.os-rotate.os-2x > div {
  width: 64px;
  height: 64px;
  -webkit-box-shadow: 0 0 0 3px #ddd inset;
  box-shadow: 0 0 0 3px #ddd inset; }
  .os-rotate.os-2x > div div {
    border-width: 3px; }

.os-rotate.os-3x {
  width: 96px;
  height: 96px; }

.os-rotate.os-3x > div {
  width: 96px;
  height: 96px;
  border-width: 6px;
  -webkit-box-shadow: 0 0 0 4px #ddd inset;
  box-shadow: 0 0 0 4px #ddd inset; }
  .os-rotate.os-3x > div div {
    border-width: 4px; }

/*
 * Animation
 */
@-webkit-keyframes ball-clip-rotate {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg); }
  50% {
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg); }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg); } }
@-moz-keyframes ball-clip-rotate {
  0% {
    -moz-transform: rotate(0deg);
    transform: rotate(0deg); }
  50% {
    -moz-transform: rotate(180deg);
    transform: rotate(180deg); }
  100% {
    -moz-transform: rotate(360deg);
    transform: rotate(360deg); } }
@-o-keyframes ball-clip-rotate {
  0% {
    -o-transform: rotate(0deg);
    transform: rotate(0deg); }
  50% {
    -o-transform: rotate(180deg);
    transform: rotate(180deg); }
  100% {
    -o-transform: rotate(360deg);
    transform: rotate(360deg); } }
@keyframes ball-clip-rotate {
  0% {
    -webkit-transform: rotate(0deg);
    -moz-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    transform: rotate(0deg); }
  50% {
    -webkit-transform: rotate(180deg);
    -moz-transform: rotate(180deg);
    -o-transform: rotate(180deg);
    transform: rotate(180deg); }
  100% {
    -webkit-transform: rotate(360deg);
    -moz-transform: rotate(360deg);
    -o-transform: rotate(360deg);
    transform: rotate(360deg); } }
.site-footer a {
  color: #8e9194; }
  .site-footer a:hover {
    color: #e60000; }

.social-icons ul {
  display: inline-flex;
  text-decoration: none;
  margin-bottom: 0; }
.social-icons a {
  padding: 10px; }
.social-icons li:first-child a {
  padding-left: 0; }

.site-footer .widget {
  margin-bottom: 30px; }
  .site-footer .widget .widget-title {
    padding: 0;
    padding-bottom: 20px; }
  .site-footer .widget .vertical-list li {
    padding: 0 0 8px 0; }
.site-footer .copyright {
  padding: 10px 0; }

.sidebar a {
  color: #fff; }
  .sidebar a:hover {
    color: #e60000; }

.tagcloud a {
  padding: 5px 15px;
  margin: 0 10px 10px 0;
  display: inline-block;
  border-radius: 3px;
  border: none;
  position: relative;
  cursor: pointer;
  color: #edeeef;
  background-color: transparent;
  transition: all 0.3s; }
  .tagcloud a a, .tagcloud a p, .tagcloud a span {
    color: #edeeef; }
  .tagcloud a::before {
    -webkit-box-shadow: 0 0 0 1px none inset;
    box-shadow: 0 0 0 1px none inset;
    background-color: #5e5d5a;
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    opacity: 0;
    z-index: -1;
    transition: opacity 0.3s;
    opacity: 1; }
  .tagcloud a::after {
    /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#c60000+0,b08cf9+86 */
    background: #c60000;
    /* Old browsers */
    background: -moz-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
    /* FF3.6-15 */
    background: -webkit-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
    /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(135deg, #c60000 0%, #e60000 86%);
    /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#c60000', endColorstr='#e60000',GradientType=1 );
    /* IE6-9 fallback on horizontal gradient */
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    opacity: 0;
    z-index: -1;
    transition: opacity 0.3s; }
  .tagcloud a:hover, .tagcloud a:not([disabled]):not(.disabled):active, .tagcloud a:focus {
    -webkit-box-shadow: 0 0 0 1px none inset;
    box-shadow: 0 0 0 1px none inset;
    color: #fff !important;
    background-color: transparent; }
    .tagcloud a:hover a, .tagcloud a:hover p, .tagcloud a:hover span, .tagcloud a:not([disabled]):not(.disabled):active a, .tagcloud a:not([disabled]):not(.disabled):active p, .tagcloud a:not([disabled]):not(.disabled):active span, .tagcloud a:focus a, .tagcloud a:focus p, .tagcloud a:focus span {
      color: #fff !important; }
    .tagcloud a:hover::before, .tagcloud a:not([disabled]):not(.disabled):active::before, .tagcloud a:focus::before {
      opacity: 0; }
    .tagcloud a:hover::after, .tagcloud a:not([disabled]):not(.disabled):active::after, .tagcloud a:focus::after {
      opacity: 1; }
  .tagcloud a::before, .tagcloud a::after {
    border-radius: 3px; }

.sidebar .os-list {
  padding-left: 0;
  margin-left: 0; }
  .sidebar .os-list li {
    margin-bottom: 6px;
    padding: 0;
    list-style: none; }
    .sidebar .os-list li ul {
      padding-left: 20px; }
.sidebar .widget {
  margin-bottom: 2rem; }
  .sidebar .widget .widget-title {
    font-size: 1.125rem;
    padding-bottom: 17px; }
  .sidebar .widget.mb-lg {
    margin-bottom: 45px; }

.sidebar, .side-menu {
  font-size: 13px; }

/* follower-box */
.follower-box {
  margin-bottom: 1.3rem; }
  .follower-box .artist {
    font-size: 0.8125rem;
    margin-bottom: 0.2rem; }

@media (min-width: 768px) {
  .tagcloud a {
    transition: color 0.3s ease-out; }
    .tagcloud a::before {
      transition: opacity 0.3s ease-out; } }
.title-box {
  margin-bottom: 16px;
  display: flex;
  flex-direction: column; }
  .title-box .sub-title {
    line-height: 1; }

input:focus {
  outline: none;
  box-shadow: none; }

.color-variable::-webkit-input-placeholder {
  /* Chrome/Opera/Safari */
  color: currentColor; }

.color-variable::-moz-placeholder {
  /* Firefox 19+ */
  color: currentColor; }

.color-variable:-ms-input-placeholder {
  /* IE 10+ */
  color: currentColor; }

.color-variable:-moz-placeholder {
  /* Firefox 18- */
  color: currentColor; }

input[type=checkbox], input[type=radio] {
  vertical-align: middle; }

label {
  margin: 0 0 0.6rem 0; }

.form-control {
  display: block;
  width: 100%;
  padding: 12px 12px;
  font-size: 0.875rem;
  line-height: 1.5;
  color: #7d7d7d;
  background-color: #f1f3f9;
  background-clip: padding-box;
  border: 1px solid transparent; }
  .form-control:focus {
    border-color: #e60000;
    outline: none;
    box-shadow: none; }

select.form-control:not([size]):not([multiple]) {
  height: 45px; }
select.form-control:focus::-ms-value {
  color: #7d7d7d;
  background-color: #f1f3f9; }

.os-checkbox .label, .os-radio .label {
  position: relative; }
  .os-checkbox .label::before, .os-radio .label::before {
    content: '';
    border: 2px solid #e1e1e1;
    background-color: transparent;
    width: 20px;
    height: 20px;
    position: relative;
    margin-right: 8px;
    display: inline-block;
    vertical-align: middle;
    z-index: 4; }
  .os-checkbox .label:after, .os-radio .label:after {
    content: '';
    left: 5px;
    top: 4px;
    width: 9px;
    height: 9px;
    position: absolute;
    z-index: 5; }
/* Removed: was hiding native inputs inside .os-checkbox / .os-radio wrappers.
   Those classes are no longer used in any HTML in this codebase, but the rule
   was greedy enough to surface in DevTools as a candidate match. If you ever
   re-introduce a custom .os-checkbox / .os-radio component, restore this rule
   alongside the .label::before / ::after visuals below. */

.os-checkbox .label::before {
  border-radius: 2px; }
.os-checkbox .label:after {
  border: 1px solid white;
  border-top: none;
  border-right: none;
  -webkit-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  -moz-transform: rotate(-45deg);
  -o-transform: rotate(-45deg);
  transform: rotate(-45deg); }
.os-checkbox input[type="checkbox"]:checked + label .label:before {
  background-color: #e60000;
  border: none; }

.os-radio .label::before, .os-radio .label::after {
  border-radius: 50%; }
.os-radio input[type="radio"]:checked + label .label:before {
  background-color: #e60000;
  border: none; }
.os-radio input[type="radio"]:checked + label .label:after {
  background: #e60000;
  border: 3px solid white;
  width: 16px;
  height: 16px;
  top: 2px;
  left: 2px; }

/*<div class="form-group-g-style">
    <label class="label-control">
      <span class="label-text">&nbsp; Find and listen to your favorite music</span>
    </label>
    <input type="email" name="email" class="form-control" />
</div>*/
.form-group-g-style {
  padding-bottom: 16px;
  position: relative;
  width: 100%;
  overflow: hidden; }
  .form-group-g-style .form-control {
    border: none;
    background: transparent;
    position: relative;
    bottom: -14px;
    padding: 4px 0;
    margin-top: 4px; }
  .form-group-g-style .label-control {
    display: block;
    font-size: 14px;
    position: absolute;
    top: 0;
    left: 0;
    padding: 0;
    width: 100%;
    pointer-events: none;
    height: 100%;
    white-space: nowrap; }
    .form-group-g-style .label-control.no-border::before {
      display: none; }
  .form-group-g-style .label-control::before,
  .form-group-g-style .label-control::after {
    content: "";
    left: 0;
    position: absolute;
    bottom: 0;
    width: 100%; }
  .form-group-g-style .label-control::before {
    border-bottom: 1px solid #B9C1CA;
    transition: transform 0.3s;
    -webkit-transition: -webkit-transform 0.3s; }
  .form-group-g-style .label-control::after {
    border-bottom: 2px solid #e60000;
    -webkit-transform: translate3d(-100%, 0, 0);
    -ms-transform: translate3d(-100%, 0, 0);
    -moz-transform: translate3d(-100%, 0, 0);
    -o-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
    -webkit-transition: -webkit-transform 0.3s;
    transition: transform 0.3s; }
  .form-group-g-style .label-control .label-text {
    -webkit-transform: translate3d(0, 20px, 0) scale(1);
    -ms-transform: translate3d(0, 20px, 0) scale(1);
    -moz-transform: translate3d(0, 20px, 0) scale(1);
    -o-transform: translate3d(0, 20px, 0) scale(1);
    transform: translate3d(0, 20px, 0) scale(1);
    -webkit-transform-origin: left top;
    -ms-transform-origin: left top;
    -moz-transform-origin: left top;
    -o-transform-origin: left top;
    transform-origin: left top;
    transition: transform 0.3s;
    position: absolute; }
  .form-group-g-style.active .label-control::after {
    -webkit-transform: translate3d(0%, 0, 0);
    -ms-transform: translate3d(0%, 0, 0);
    -moz-transform: translate3d(0%, 0, 0);
    -o-transform: translate3d(0%, 0, 0);
    transform: translate3d(0%, 0, 0); }
  .form-group-g-style.active .label-control .label-text {
    opacity: 1;
    -webkit-transform: scale(0.9);
    -ms-transform: scale(0.9);
    -moz-transform: scale(0.9);
    -o-transform: scale(0.9);
    transform: scale(0.9); }
  .form-group-g-style .input-field label:before {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    border-bottom: 1px solid #B9C1CA;
    transition: transform 0.3s; }

.round-input {
  border-radius: 50px;
  padding-left: 1.2rem;
  padding-right: 1.2rem; }

.btn, button {
  font-size: 13px;
  position: relative;
  cursor: pointer;
  text-align: center;
  transition: all 0.3s ease; }
  .btn:focus, button:focus {
    outline: none;
    box-shadow: none; }
  .btn::before, .btn::after, button::before, button::after {
    border-radius: 3px; }

.rounded-btn {
  border-radius: 50px; }
  .rounded-btn::before, .rounded-btn::after {
    border-radius: 50px; }

.btn.rounded-circle {
  border-radius: 50%; }
  .btn.rounded-circle::before, .btn.rounded-circle::after {
    border-radius: 50%; }

.active-border {
  border-color: #e60000 !important; }

/* btn sizes */
.btn-sm {
  padding: 0.2rem 0.5rem;
  font-size: 0.8125rem; }
  .btn-sm::before, .btn-sm::after {
    border-radius: 3px; }

.btn-md {
  padding: 0.2rem 1rem;
  font-size: 12px; }

.btn-lg {
  padding: 0.75rem 1.5rem;
  font-size: 13px; }

.btn-xl {
  padding: 1rem 3.5rem;
  font-size: 16px; }

.btn-sm-wide {
  font-size: 0.8125rem;
  padding: .365rem 1.28rem; }

.btn-md-wide {
  padding: 0.75rem 2.5rem;
  font-size: 12px; }

.btn-lg-wide {
  padding: 0.75rem 3.5rem;
  font-size: 13px; }

.btn-xl-wide {
  padding: 0.75rem 4.5rem;
  font-size: 16px; }

.btn-80-60 {
  width: 80px;
  height: 60px; }

.btn-120-60 {
  width: 120px;
  height: 60px; }

.btn-90-90 {
  width: 90px;
  height: 90px; }

.btn-45-45 {
  width: 45px;
  height: 45px; }

.btn-40-40 {
  width: 40px;
  height: 40px; }

.btn-50-50 {
  width: 50px;
  height: 50px; }

.btn-60-60 {
  width: 60px;
  height: 60px; }

.btn-light {
  border: none;
  position: relative;
  cursor: pointer;
  color: #a1a1a1;
  background-color: transparent;
  transition: all 0.3s; }
  .btn-light a, .btn-light p, .btn-light span {
    color: #a1a1a1; }
  .btn-light::before {
    -webkit-box-shadow: 0 0 0 1px none inset;
    box-shadow: 0 0 0 1px none inset;
    background-color: #ebf4f5;
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    opacity: 0;
    z-index: -1;
    transition: opacity 0.3s;
    opacity: 1; }
  .btn-light::after {
    /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#c60000+0,b08cf9+86 */
    background: #c60000;
    /* Old browsers */
    background: -moz-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
    /* FF3.6-15 */
    background: -webkit-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
    /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(135deg, #c60000 0%, #e60000 86%);
    /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#c60000', endColorstr='#e60000',GradientType=1 );
    /* IE6-9 fallback on horizontal gradient */
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    opacity: 0;
    z-index: -1;
    transition: opacity 0.3s; }
  .btn-light:hover, .btn-light:not([disabled]):not(.disabled):active, .btn-light:focus {
    -webkit-box-shadow: 0 0 0 1px none inset;
    box-shadow: 0 0 0 1px none inset;
    color: #ffffff !important;
    background-color: transparent; }
    .btn-light:hover a, .btn-light:hover p, .btn-light:hover span, .btn-light:not([disabled]):not(.disabled):active a, .btn-light:not([disabled]):not(.disabled):active p, .btn-light:not([disabled]):not(.disabled):active span, .btn-light:focus a, .btn-light:focus p, .btn-light:focus span {
      color: #ffffff !important; }
    .btn-light:hover::before, .btn-light:not([disabled]):not(.disabled):active::before, .btn-light:focus::before {
      opacity: 0; }
    .btn-light:hover::after, .btn-light:not([disabled]):not(.disabled):active::after, .btn-light:focus::after {
      opacity: 1; }

.btn-primary {
  border: none;
  position: relative;
  cursor: pointer;
  color: #fff;
  background-color: transparent;
  transition: all 0.3s; }
  .btn-primary a, .btn-primary p, .btn-primary span {
    color: #fff; }
  .btn-primary::before {
    -webkit-box-shadow: 0 0 0 1px none inset;
    box-shadow: 0 0 0 1px none inset;
    /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#c60000+0,b08cf9+86 */
    background: #c60000;
    /* Old browsers */
    background: -moz-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
    /* FF3.6-15 */
    background: -webkit-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
    /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(135deg, #c60000 0%, #e60000 86%);
    /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#c60000', endColorstr='#e60000',GradientType=1 );
    /* IE6-9 fallback on horizontal gradient */
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    opacity: 0;
    z-index: -1;
    transition: opacity 0.3s;
    opacity: 1; }
  .btn-primary::after {
    /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#c60000+0,b08cf9+86 */
    background: #7A8BF4;
    /* Old browsers */
    background: -moz-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
    /* FF3.6-15 */
    background: -webkit-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
    /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(135deg, #a60000 0%, #e60000 86%);
    /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#c60000', endColorstr='#e60000',GradientType=1 );
    /* IE6-9 fallback on horizontal gradient */
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    opacity: 0;
    z-index: -1;
    transition: opacity 0.3s; }
  .btn-primary:hover, .btn-primary:not([disabled]):not(.disabled):active, .btn-primary:focus {
    -webkit-box-shadow: 0 0 0 1px none inset;
    box-shadow: 0 0 0 1px none inset;
    color: #fff !important;
    background-color: transparent; }
    .btn-primary:hover a, .btn-primary:hover p, .btn-primary:hover span, .btn-primary:not([disabled]):not(.disabled):active a, .btn-primary:not([disabled]):not(.disabled):active p, .btn-primary:not([disabled]):not(.disabled):active span, .btn-primary:focus a, .btn-primary:focus p, .btn-primary:focus span {
      color: #fff !important; }
    .btn-primary:hover::before, .btn-primary:not([disabled]):not(.disabled):active::before, .btn-primary:focus::before {
      opacity: 0; }
    .btn-primary:hover::after, .btn-primary:not([disabled]):not(.disabled):active::after, .btn-primary:focus::after {
      opacity: 1; }

.btn-secondary {
  border: none;
  position: relative;
  cursor: pointer;
  color: #555555;
  background-color: transparent;
  transition: all 0.3s; }
  .btn-secondary a, .btn-secondary p, .btn-secondary span {
    color: #555555; }
  .btn-secondary::before {
    -webkit-box-shadow: 0 0 0 1px none inset;
    box-shadow: 0 0 0 1px none inset;
    background-color: #e1e1e1;
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    opacity: 0;
    z-index: -1;
    transition: opacity 0.3s;
    opacity: 1; }
  .btn-secondary::after {
    /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#c60000+0,b08cf9+86 */
    background: #c60000;
    /* Old browsers */
    background: -moz-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
    /* FF3.6-15 */
    background: -webkit-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
    /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(135deg, #c60000 0%, #e60000 86%);
    /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#c60000', endColorstr='#e60000',GradientType=1 );
    /* IE6-9 fallback on horizontal gradient */
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    opacity: 0;
    z-index: -1;
    transition: opacity 0.3s; }
  .btn-secondary:hover, .btn-secondary:not([disabled]):not(.disabled):active, .btn-secondary:focus {
    -webkit-box-shadow: 0 0 0 1px none inset;
    box-shadow: 0 0 0 1px none inset;
    color: #FFFFFF !important;
    background-color: transparent; }
    .btn-secondary:hover a, .btn-secondary:hover p, .btn-secondary:hover span, .btn-secondary:not([disabled]):not(.disabled):active a, .btn-secondary:not([disabled]):not(.disabled):active p, .btn-secondary:not([disabled]):not(.disabled):active span, .btn-secondary:focus a, .btn-secondary:focus p, .btn-secondary:focus span {
      color: #FFFFFF !important; }
    .btn-secondary:hover::before, .btn-secondary:not([disabled]):not(.disabled):active::before, .btn-secondary:focus::before {
      opacity: 0; }
    .btn-secondary:hover::after, .btn-secondary:not([disabled]):not(.disabled):active::after, .btn-secondary:focus::after {
      opacity: 1; }

.btn-outline {
  border: none;
  position: relative;
  cursor: pointer;
  color: #b8babc;
  background-color: transparent;
  transition: all 0.3s; }
  .btn-outline a, .btn-outline p, .btn-outline span {
    color: #b8babc; }
  .btn-outline::before {
    -webkit-box-shadow: 0 0 0 1px #5e5d5a inset;
    box-shadow: 0 0 0 1px #5e5d5a inset;
    background-color: transparent;
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    opacity: 0;
    z-index: -1;
    transition: opacity 0.3s;
    opacity: 1; }
  .btn-outline::after {
    /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#c60000+0,b08cf9+86 */
    background: #c60000;
    /* Old browsers */
    background: -moz-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
    /* FF3.6-15 */
    background: -webkit-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
    /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(135deg, #c60000 0%, #e60000 86%);
    /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#c60000', endColorstr='#e60000',GradientType=1 );
    /* IE6-9 fallback on horizontal gradient */
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    opacity: 0;
    z-index: -1;
    transition: opacity 0.3s; }
  .btn-outline:hover, .btn-outline:not([disabled]):not(.disabled):active, .btn-outline:focus {
    -webkit-box-shadow: 0 0 0 1px #5e5d5a inset;
    box-shadow: 0 0 0 1px #5e5d5a inset;
    color: #ffffff !important;
    background-color: transparent; }
    .btn-outline:hover a, .btn-outline:hover p, .btn-outline:hover span, .btn-outline:not([disabled]):not(.disabled):active a, .btn-outline:not([disabled]):not(.disabled):active p, .btn-outline:not([disabled]):not(.disabled):active span, .btn-outline:focus a, .btn-outline:focus p, .btn-outline:focus span {
      color: #ffffff !important; }
    .btn-outline:hover::before, .btn-outline:not([disabled]):not(.disabled):active::before, .btn-outline:focus::before {
      opacity: 0; }
    .btn-outline:hover::after, .btn-outline:not([disabled]):not(.disabled):active::after, .btn-outline:focus::after {
      opacity: 1; }

.btn-transparent {
  border: none;
  position: relative;
  cursor: pointer;
  color: #a1a1a1;
  background-color: transparent;
  transition: all 0.3s; }
  .btn-transparent a, .btn-transparent p, .btn-transparent span {
    color: #a1a1a1; }
  .btn-transparent::before {
    -webkit-box-shadow: 0 0 0 1px none inset;
    box-shadow: 0 0 0 1px none inset;
    background-color: transparent;
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    opacity: 0;
    z-index: -1;
    transition: opacity 0.3s;
    opacity: 1; }
  .btn-transparent::after {
    /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#c60000+0,b08cf9+86 */
    background: #c60000;
    /* Old browsers */
    background: -moz-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
    /* FF3.6-15 */
    background: -webkit-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
    /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(135deg, #c60000 0%, #e60000 86%);
    /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#c60000', endColorstr='#e60000',GradientType=1 );
    /* IE6-9 fallback on horizontal gradient */
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    opacity: 0;
    z-index: -1;
    transition: opacity 0.3s; }
  .btn-transparent:hover, .btn-transparent:not([disabled]):not(.disabled):active, .btn-transparent:focus {
    -webkit-box-shadow: 0 0 0 1px none inset;
    box-shadow: 0 0 0 1px none inset;
    color: #ffffff !important;
    background-color: transparent; }
    .btn-transparent:hover a, .btn-transparent:hover p, .btn-transparent:hover span, .btn-transparent:not([disabled]):not(.disabled):active a, .btn-transparent:not([disabled]):not(.disabled):active p, .btn-transparent:not([disabled]):not(.disabled):active span, .btn-transparent:focus a, .btn-transparent:focus p, .btn-transparent:focus span {
      color: #ffffff !important; }
    .btn-transparent:hover::before, .btn-transparent:not([disabled]):not(.disabled):active::before, .btn-transparent:focus::before {
      opacity: 0; }
    .btn-transparent:hover::after, .btn-transparent:not([disabled]):not(.disabled):active::after, .btn-transparent:focus::after {
      opacity: 1; }

.btn-blank {
  background: transparent; }

.btn-transparent .dark {
  color: #151412; }
.btn-transparent span {
  color: #8e9194; }
.btn-transparent:hover span, .btn-transparent:not([disabled]):not(.disabled):active span, .btn-transparent:focus span {
  color: #fff; }

.btn-group-sm > .btn {
  padding: .16rem .5rem;
  border-radius: 0.15rem;
  font-size: 0.75rem; }

.btn-outline-secondary.focus, .btn-outline-secondary:focus, .btn-outline-secondary:not([disabled]):not(.disabled).active, .btn-outline-secondary:not([disabled]):not(.disabled):active, .show > .btn-outline-secondary.dropdown-toggle {
  /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#c60000+0,b08cf9+86 */
  background: #c60000;
  /* Old browsers */
  background: -moz-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
  /* FF3.6-15 */
  background: -webkit-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
  /* Chrome10-25,Safari5.1-6 */
  background: linear-gradient(135deg, #c60000 0%, #e60000 86%);
  /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#c60000', endColorstr='#e60000',GradientType=1 );
  /* IE6-9 fallback on horizontal gradient */
  border-color: transparent;
  box-shadow: none;
  color: #fff; }

.btn-outline-secondary {
  color: #a1a1a1;
  border-color: #e1e1e1; }
  .btn-outline-secondary:hover {
    border-color: transparent; }

.lt-side-btn {
  text-align: left; }
  .lt-side-btn.gradient-os-hover:hover {
    color: #ffffff; }

.input-group .form-control {
  border: 1px solid #ced4da; }
.input-group .input-group-text {
  padding: .375rem .75rem;
  background-color: #e9ecef;
  border: 1px solid #ced4da;
  height: 100%;
  align-items: center;
  display: inline-flex; }
  .input-group .input-group-text.right-edge {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    border-top-right-radius: 3px;
    border-bottom-right-radius: 3px;
    border-left: 0; }

.round-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border-radius: 50%; }
  .round-btn::before, .round-btn::after {
    border-radius: 50%; }
  .round-btn.gradient-os-hover:hover {
    color: #FFFFFF; }
    .round-btn.gradient-os-hover:hover p {
      color: #FFFFFF !important; }

.btn-close-round {
  width: 46px;
  height: 46px;
  line-height: 46px;
  border-radius: 50%;
  background: #ebebeb;
  text-align: center;
  border: none; }

/* color */
.btn-primary:not(:disabled):not(.disabled).active:focus, .btn-primary:not(:disabled):not(.disabled):active:focus, .show > .btn-primary.dropdown-toggle:focus {
  box-shadow: none; }

@-webkit-keyframes osShadowOut {
  from {
    -webkit-box-shadow: 0 0 0 0 #a68cf8;
    box-shadow: 0 0 0 0 #a68cf8; }
  to {
    -webkit-box-shadow: 0 0 1rem 0.5rem rgba(166, 140, 248, 0);
    box-shadow: 0 0 1rem 0.5rem rgba(166, 140, 248, 0); } }
@keyframes osShadowOut {
  from {
    -webkit-box-shadow: 0 0 0 0 #a68cf8;
    box-shadow: 0 0 0 0 #a68cf8; }
  to {
    -webkit-box-shadow: 0 0 1rem 0.5rem rgba(166, 140, 248, 0);
    box-shadow: 0 0 1rem 0.5rem rgba(166, 140, 248, 0); } }
.shadow-out {
  -webkit-animation: osShadowOut .5s linear;
  animation: osShadowOut .5s linear; }

.btn-search {
  background: none;
  border: none;
  padding: 0; }

.album-cover-bg {
  position: absolute;
  width: 100%;
  height: 60vh;
  background-repeat: no-repeat;
  background-position: center top;
  -webkit-background-size: cover;
  background-size: cover;
  mask-image: -webkit-gradient(linear, left 70%, left 100%, from(black), to(rgba(0, 0, 0, 0)));
  -webkit-mask-image: -webkit-gradient(linear, left 70%, left 100%, from(black), to(rgba(0, 0, 0, 0))); }
  .album-cover-bg.blur-bottom::after {
    content: '';
    display: block;
    position: absolute;
    bottom: 0;
    width: 100%;
    height: 20vh; }

.album-spacer {
  height: 40vmin; }

@media (min-width: 768px) {
  .flex-column-md-album-poster {
    width: 300px;
    flex: 0 0 260px;
    flex-grow: 0;
    max-width: none; }

  .flex-column-md-album-content {
    width: 40%;
    flex: 2 0 auto;
    max-width: none; } }
@media (min-width: 992px) {
  .flex-column-lg-album-poster {
    width: 300px;
    flex: 0 0 260px;
    flex-grow: 0;
    max-width: none; }

  .flex-column-lg-album-content {
    width: 40%;
    flex: 2 0 auto;
    max-width: none; } }
@media (min-width: 1200px) {
  .flex-column-xl-album-poster {
    width: 350px;
    flex: 0 0 350px;
    min-width: 250px; }

  .flex-column-xl-album-content {
    width: 40%;
    flex: 2 0 auto;
    max-width: none; } }
.os-album-list {
  list-style: none;
  padding: 0;
  margin: 0; }
  .os-album-list > li {
    padding: 1.3rem 0;
    margin: 0;
    position: relative;
    display: flex;
    border-bottom: 1px solid #dddddd;
    align-items: center;
    transition: all 0.3s ease; }
    .os-album-list > li > div {
      min-height: 20px; }
    .os-album-list > li:first-child {
      padding-top: 0; }
    .os-album-list > li a {
      color: #000000; }
    .os-album-list > li .hover-bg {
      opacity: 0;
      position: absolute;
      width: 100%;
      height: 100%;
      left: 0;
      top: 0;
      z-index: -1;
      transition: all 0.3s ease; }
    .os-album-list > li .hover-show {
      opacity: 0;
      visibility: hidden;
      position: absolute;
      top: 50%;
      -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
      -moz-transform: translateY(-50%);
      -o-transform: translateY(-50%);
      transform: translateY(-50%); }
    .os-album-list > li .hover-hide {
      position: absolute;
      top: 50%;
      -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
      -moz-transform: translateY(-50%);
      -o-transform: translateY(-50%);
      transform: translateY(-50%); }
    .os-album-list > li .item-number {
      width: 4%;
      min-width: 20px;
      padding-left: 0; }
    .os-album-list > li .item-title {
      width: 50%;
      max-width: 50%;
      min-width: 150px;
      white-space: nowrap;
      text-overflow: ellipsis;
      overflow: hidden; }
    .os-album-list > li .item-eptitle {
      width: 50%;
      max-width: 50%;
      padding: 0 0.2rem;
      white-space: nowrap;
      text-overflow: ellipsis;
      margin-left: auto;
      position: relative;
      overflow: hidden;
      min-width: 20%; }
      .os-album-list > li .item-eptitle span {
        max-width: 100%;
        text-overflow: ellipsis;
        overflow: hidden; }
    .os-album-list > li .item-dateup {
      width: 120px;
      min-width: 40px;
      margin-left: auto; }
    .os-album-list > li .item-upby {
      width: 60px;
      min-width: 40px;
      margin-left: auto; }
    .os-album-list > li .item-tools {
      width: 60px;
      min-width: 50px;
      text-align: center;
      margin-left: auto; }
    .os-album-list > li .item-price {
      width: 140px;
      min-width: 140px;
      margin-left: auto;
      text-align: right; }
    .os-album-list > li .item-dateup,.os-album-list > li .item-upby, .os-album-list > li .item-tools {
      text-align: center;
      position: relative;
      margin-left: auto; }
      .os-album-list > li .item-upby .hover-show, .os-album-list > li .item-upby .hover-hide, .os-album-list > li .item-dateup .hover-show, .os-album-list > li .item-dateup .hover-hide, .os-album-list > li .item-tools .hover-show, .os-album-list > li .item-tools .hover-hide {
        width: 100%;
        text-align: center;
        left: 0; }
    .os-album-list > li .hover-tools {
      right: 1.5rem;
      left: auto !important;
      width: auto !important;
      align-items: center; }
    .os-album-list > li.item:hover a:not([class^="btn"]) {
      color: #e60000; }
    .os-album-list > li.item:hover.hover-bg-item {
      color: #ffffff; }
    .os-album-list > li.item:hover .hover-bg {
      opacity: 1; }
    .os-album-list > li.item:hover .hover-hide {
      opacity: 0;
      visibility: hidden; }
    .os-album-list > li.item:hover .hover-show {
      opacity: 1;
      visibility: visible; }

@media (min-width: 992px) {
  .os-album-list > li.item:hover .hover-lg-show {
    opacity: 1;
    visibility: visible; }
  .os-album-list > li.item .item-number {
    padding-left: 1rem;
    min-width: 50px; } }
@media (max-width: 767px) {
  .album-spacer {
    height: 70vmin; }

  .os-album-list > li .item-eptitle {
    display: none; }
  .os-album-list > li .item-dateup {
    display: none; }
  .os-album-list > li .item-upby {
    display: none; }

  /* Mobile: bigger tap targets for episode list */
  .os-album-list > li.item {
    min-height: 44px;
    padding: 8px 0; }
  .os-album-list > li .item-title {
    width: 75%;
    max-width: 75%;
    font-size: 0.85rem; }
  .os-album-list > li .item-tools {
    width: 44px;
    min-width: 44px; }

  /* Thread content: prevent overflow */
  .os-thread-content img,
  .spoiler-content img,
  .bbcode-quote img {
    max-width: 100% !important;
    height: auto !important; }
  .os-thread-content,
  .spoiler-content {
    overflow-wrap: break-word;
    word-break: break-word; }
  .os-thread-content pre,
  .os-thread-content code {
    overflow-x: auto;
    max-width: 100%;
    white-space: pre-wrap; }
  .os-thread-content iframe,
  .os-thread-content video,
  .os-thread-content embed {
    max-width: 100% !important; }

  /* Modals: full-screen on mobile */
  .modal-dialog {
    margin: 0;
    max-width: 100%; }
  .modal-content {
    border-radius: 0;
    min-height: 100vh; }
}
.customer-rating .rating {
  display: flex;
  align-items: center;
  margin-bottom: 0.8rem; }
  .customer-rating .rating .star-number {
    width: 3.5rem;
    margin-right: 0.3rem; }
  .customer-rating .rating .progress {
    width: 50%;
    flex: 0 0 50%;
    max-width: 20rem;
    flex-grow: 3;
    height: 3px;
    background-color: #e1e1e1; }
    .customer-rating .rating .progress .progress-bar {
      background-color: #e60000; }
  .customer-rating .rating .star-percent {
    width: 3.5rem;
    text-align: center; }

.customer-review img {
  max-width: 35px; }

.shop-attributes th {
  width: 20%;
  min-width: 10rem; }

.os-star-rating {
  margin-bottom: 0.7rem; }
  .os-star-rating .star-full {
    background: url("../images/star.svg") no-repeat 0 0;
    width: 5rem;
    height: 1rem;
    display: inline-flex;
    vertical-align: middle; }
    .os-star-rating .star-full .star-active {
      background: url("../images/star-active.svg") no-repeat 0 0;
      display: block;
      height: 100%;
      background-size: 5rem;
      -webkit-transform: translate(-1px, 0);
      -ms-transform: translate(-1px, 0);
      -moz-transform: translate(-1px, 0);
      -o-transform: translate(-1px, 0);
      transform: translate(-1px, 0); }

.os-cart-table td, .os-cart-table th {
  padding-left: 0;
  padding-right: 0;
  padding-top: 1.2rem;
  padding-bottom: 1.2rem; }
.os-cart-table .product-image {
  width: auto;
  max-width: 150px; }
.os-cart-table .product-description {
  width: 70%; }
.os-cart-table .unit-price {
  text-align: center;
  vertical-align: middle;
  border-bottom: none; }
.os-cart-table .product-buttons {
  text-align: right;
  vertical-align: middle; }
.os-cart-table thead th {
  border-bottom: none;
  border-top: none; }

.cart-total {
  background: #f6f7fb; }
  .cart-total tbody tr:first-child td, .cart-total tbody tr:first-child th {
    padding-top: 1.2rem; }
  .cart-total tbody tr:last-child td, .cart-total tbody tr:last-child th {
    padding-bottom: 1.2rem; }
  .cart-total td, .cart-total th {
    padding: 0.75rem 0; }
  .cart-total .title {
    border-bottom: 1px solid #e1e1e1; }
  .cart-total thead th {
    border-bottom-width: 1px;
    border-top: none; }
  .cart-total td.product-name, .cart-total td.product-total {
    border-top: none;
    padding: 0.45rem 0; }

#payment label {
  font-weight: bold;
  color: #151412; }
  #payment label img {
    margin-left: 10px;
    margin-right: 10px; }

.borderless td, .borderless th {
  border: none;
  padding-left: 0; }

.product-tabs a {
  padding: 0.2rem 1rem;
  color: #a1a1a1;
  border: 1px solid transparent;
  border-radius: 50px; }
  .product-tabs a:hover, .product-tabs a.active {
    color: #e60000; }
  .product-tabs a.active {
    border-color: #e60000;
    color: #252525;
    background: none; }

.os-news-articles .news-box {
  position: relative; }
  .os-news-articles .news-box .img-box img {
    width: 100%; }
  .os-news-articles .news-box .info-box {
    padding: 0.5rem 0; }

.os-player-wrap, .os-playlist-player {
  /* @end */
  /* @group progress bar */
  /* The seeking class is added/removed inside jPlayer */
  /* @end */
  /* @group volume controls */
  /* @end */
  /* @group current time and duration */
  /* @end */
  /* @group playlist */
  /* Note that the first-child (IE6) and last-child (IE6/7/8) selectors do not work on IE */
  /* @end */
  /*.jp-video-270p .jp-video-play {
    margin-top: -270px;
    height: 270px; }

  .jp-video-360p .jp-video-play {
    margin-top: -360px;
    height: 360px; }

  .jp-video-full .jp-video-play {
    height: 100%; }

  .jp-video-play-icon {
    position: relative;
    display: block;
    width: 112px;
    height: 100px;
    margin-left: -56px;
    margin-top: -50px;
    left: 50%;
    top: 50%;
    background: url("../image/jplayer.blue.monday.video.play.png") 0 0 no-repeat;
    text-indent: -9999px;
    border: none;
    cursor: pointer; }

  .jp-video-play-icon:focus {
    background: url("../image/jplayer.blue.monday.video.play.png") 0 -100px no-repeat; }

  .jp-jplayer audio,
  .jp-jplayer {
    width: 0px;
    height: 0px; }*/
  /* @group TOGGLES */
  /* The audio toggles are nested inside jp-time-holder */
  /* @end */
  /* @group NO SOLUTION error feedback */ }
  .os-player-wrap.fixed-player, .os-playlist-player.fixed-player {
    position: fixed;
    width: 100%;
    top: 0;
    left: 0;
    z-index: 1200; }
  .os-player-wrap.player-fixed-bottom, .os-playlist-player.player-fixed-bottom {
    position: fixed;
    width: 100%;
    bottom: 0;
    left: 0;
    z-index: 1200; }
  .os-player-wrap a, .os-playlist-player a {
    cursor: pointer; }
  .os-player-wrap .jp-play, .os-playlist-player .jp-play {
    width: auto;
    height: auto; }
  .os-player-wrap .jp-play, .os-playlist-player .jp-play {
    background: none; }
  .os-player-wrap .jp-play:focus, .os-playlist-player .jp-play:focus {
    background: none; }
  .os-player-wrap .jp-state-playing .jp-play, .os-player-wrap .jp-stop, .os-playlist-player .jp-state-playing .jp-play, .os-playlist-player .jp-stop {
    background: none; }
  .os-player-wrap .jp-state-playing .jp-play:focus, .os-playlist-player .jp-state-playing .jp-play:focus {
    background: none; }
  .os-player-wrap .jp-stop, .os-player-wrap .jp-previous, .os-player-wrap .jp-next, .os-playlist-player .jp-stop, .os-playlist-player .jp-previous, .os-playlist-player .jp-next {
    width: auto;
    height: auto;
    margin-top: 0; }
  .os-player-wrap .jp-stop, .os-playlist-player .jp-stop {
    background: none;
    margin-left: 10px; }
  .os-player-wrap .jp-stop:focus, .os-playlist-player .jp-stop:focus {
    background: none; }
  .os-player-wrap .jp-previous, .os-playlist-player .jp-previous {
    background: none; }
  .os-player-wrap .jp-previous:focus, .os-playlist-player .jp-previous:focus {
    background: none; }
  .os-player-wrap .jp-next, .os-playlist-player .jp-next {
    background: none; }
  .os-player-wrap .jp-next:focus, .os-playlist-player .jp-next:focus {
    background: none; }
  .os-player-wrap .jp-progress, .os-playlist-player .jp-progress {
    overflow: visible;
    height: 40px;
    background-color: transparent;
    cursor: pointer;
    margin-top: -17px;
    width: 100%; }
    .os-player-wrap .jp-progress.jp-progress-pos-top, .os-playlist-player .jp-progress.jp-progress-pos-top {
      top: 18px; }
    .os-player-wrap .jp-progress.inner, .os-playlist-player .jp-progress.inner {
      margin: 0 10px; }
  .os-player-wrap .jp-audio .jp-progress, .os-playlist-player .jp-audio .jp-progress {
    position: absolute;
    top: 32px;
    height: 15px; }
  .os-player-wrap .jp-audio .jp-type-single .jp-progress, .os-playlist-player .jp-audio .jp-type-single .jp-progress {
    left: 110px;
    width: 186px; }
  .os-player-wrap .jp-audio .jp-type-playlist .jp-progress, .os-playlist-player .jp-audio .jp-type-playlist .jp-progress {
    left: 166px;
    width: 130px; }
  .os-player-wrap .jp-video .jp-progress, .os-playlist-player .jp-video .jp-progress {
    top: 0px;
    left: 0px;
    width: 100%;
    height: 10px; }
  .os-player-wrap .jp-seek-bar, .os-playlist-player .jp-seek-bar {
    background: none;
    position: relative;
    width: 0;
    height: 3px;
    cursor: pointer; }
    .os-player-wrap .jp-seek-bar:before, .os-playlist-player .jp-seek-bar:before {
      content: "";
      position: absolute;
      width: 100%;
      height: 100%;
      background-color: #5e5d5a; }
  .os-player-wrap .jp-play-bar, .os-playlist-player .jp-play-bar {
    transition-duration: 0s !important;
    overflow: visible !important;
    position: absolute;
    /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#c60000+0,b08cf9+86 */
    background: #c60000;
    /* Old browsers */
    background: -moz-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
    /* FF3.6-15 */
    background: -webkit-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
    /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(135deg, #c60000 0%, #e60000 86%);
    /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#c60000', endColorstr='#e60000',GradientType=1 );
    /* IE6-9 fallback on horizontal gradient */
    width: 0;
    height: 100%; }
  .os-player-wrap .jp-seeking-bg, .os-playlist-player .jp-seeking-bg {
    background: none; }
  .os-player-wrap .jp-state-no-volume .jp-volume-controls, .os-playlist-player .jp-state-no-volume .jp-volume-controls {
    display: none; }
  .os-player-wrap .jp-volume-controls, .os-playlist-player .jp-volume-controls {
    position: inherit;
    top: inherit;
    left: inherit;
    width: auto; }
  .os-player-wrap .jp-audio-stream .jp-volume-controls, .os-playlist-player .jp-audio-stream .jp-volume-controls {
    left: inherit; }
  .os-player-wrap .jp-video .jp-volume-controls, .os-playlist-player .jp-video .jp-volume-controls {
    top: inherit;
    left: inherit; }
  .os-player-wrap .jp-volume-controls button, .os-playlist-player .jp-volume-controls button {
    display: block;
    position: inherit;
    overflow: hidden;
    text-indent: 0;
    border: inherit;
    cursor: pointer; }
  .os-player-wrap .jp-mute,
  .os-player-wrap .jp-volume-max, .os-playlist-player .jp-mute,
  .os-playlist-player .jp-volume-max {
    width: auto;
    height: auto; }
  .os-player-wrap .jp-volume-max, .os-playlist-player .jp-volume-max {
    left: 74px; }
  .os-player-wrap .jp-mute, .os-playlist-player .jp-mute {
    background: none; }
  .os-player-wrap .jp-mute:focus, .os-playlist-player .jp-mute:focus {
    background: none; }
  .os-player-wrap .jp-state-muted .jp-mute, .os-playlist-player .jp-state-muted .jp-mute {
    background: none; }
  .os-player-wrap .jp-state-muted .jp-mute:focus, .os-playlist-player .jp-state-muted .jp-mute:focus {
    background: none; }
  .os-player-wrap .jp-volume-max, .os-playlist-player .jp-volume-max {
    background: none; }
  .os-player-wrap .jp-volume-max:focus, .os-playlist-player .jp-volume-max:focus {
    background: none; }
  .os-player-wrap .jp-volume-bar, .os-playlist-player .jp-volume-bar {
    position: inherit;
    overflow: hidden;
    background: none;
    width: 46px;
    height: 4px;
    cursor: pointer;
    left: 0; }
  .os-player-wrap .jp-volume-bar-value, .os-playlist-player .jp-volume-bar-value {
    /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#c60000+0,b08cf9+86 */
    background: #c60000;
    /* Old browsers */
    background: -moz-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
    /* FF3.6-15 */
    background: -webkit-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
    /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(135deg, #c60000 0%, #e60000 86%);
    /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#c60000', endColorstr='#e60000',GradientType=1 );
    /* IE6-9 fallback on horizontal gradient */
    width: 0;
    height: 3px; }
  .os-player-wrap .jp-current-time,
  .os-player-wrap .jp-duration, .os-playlist-player .jp-current-time,
  .os-playlist-player .jp-duration {
    width: 45px;
    font-size: inherit;
    font-style: inherit; }
  .os-player-wrap .jp-current-time, .os-playlist-player .jp-current-time {
    float: none;
    display: inline;
    cursor: default; }
  .os-player-wrap .jp-duration, .os-playlist-player .jp-duration {
    float: none;
    display: inline;
    text-align: right;
    cursor: pointer; }
  .os-player-wrap .jp-video .jp-current-time, .os-playlist-player .jp-video .jp-current-time {
    margin-left: 20px; }
  .os-player-wrap .jp-video .jp-duration, .os-playlist-player .jp-video .jp-duration {
    margin-right: 20px; }
  .os-player-wrap .jp-details, .os-playlist-player .jp-details {
    font-weight: bold;
    text-align: inherit;
    cursor: default; }
  .os-player-wrap .jp-details,
  .os-player-wrap .jp-playlist, .os-playlist-player .jp-details,
  .os-playlist-player .jp-playlist {
    width: auto;
    background-color: transparent;
    border-top: none; }
  .os-player-wrap .jp-type-single .jp-details,
  .os-player-wrap .jp-type-playlist .jp-details, .os-playlist-player .jp-type-single .jp-details,
  .os-playlist-player .jp-type-playlist .jp-details {
    border-top: none; }
  .os-player-wrap .jp-details .jp-title, .os-playlist-player .jp-details .jp-title {
    margin: 0;
    padding: 0;
    font-size: inherit;
    font-weight: bold; }
  .os-player-wrap .jp-playlist ul, .os-playlist-player .jp-playlist ul {
    list-style-type: none;
    margin: 0;
    padding: 0;
    font-size: inherit; }
  .os-player-wrap .jp-playlist li, .os-playlist-player .jp-playlist li {
    padding: 0;
    border-bottom: none; }
  .os-player-wrap .jp-playlist li div, .os-playlist-player .jp-playlist li div {
    display: inherit; }
  .os-player-wrap div.jp-type-playlist div.jp-playlist li:last-child, .os-playlist-player div.jp-type-playlist div.jp-playlist li:last-child {
    padding: 5px 0 5px 20px;
    border-bottom: none; }
  .os-player-wrap div.jp-type-playlist div.jp-playlist li.jp-playlist-current, .os-playlist-player div.jp-type-playlist div.jp-playlist li.jp-playlist-current {
    list-style-type: square;
    list-style-position: inside;
    padding-left: 7px; }
  .os-player-wrap div.jp-type-playlist div.jp-playlist a, .os-playlist-player div.jp-type-playlist div.jp-playlist a {
    color: #333;
    text-decoration: none; }
  .os-player-wrap div.jp-type-playlist div.jp-playlist a:hover, .os-playlist-player div.jp-type-playlist div.jp-playlist a:hover {
    color: #0d88c1; }
  .os-player-wrap div.jp-type-playlist div.jp-playlist a.jp-playlist-current, .os-playlist-player div.jp-type-playlist div.jp-playlist a.jp-playlist-current {
    color: #0d88c1; }
  .os-player-wrap div.jp-type-playlist div.jp-playlist a.jp-playlist-item-remove, .os-playlist-player div.jp-type-playlist div.jp-playlist a.jp-playlist-item-remove {
    float: right;
    display: inline;
    text-align: right;
    margin-right: 10px;
    font-weight: bold;
    color: #666; }
  .os-player-wrap div.jp-type-playlist div.jp-playlist a.jp-playlist-item-remove:hover, .os-playlist-player div.jp-type-playlist div.jp-playlist a.jp-playlist-item-remove:hover {
    color: #0d88c1; }
  .os-player-wrap div.jp-type-playlist div.jp-playlist span.jp-free-media, .os-playlist-player div.jp-type-playlist div.jp-playlist span.jp-free-media {
    float: right;
    display: inline;
    text-align: right;
    margin-right: 10px; }
  .os-player-wrap div.jp-type-playlist div.jp-playlist span.jp-free-media a, .os-playlist-player div.jp-type-playlist div.jp-playlist span.jp-free-media a {
    color: #666; }
  .os-player-wrap div.jp-type-playlist div.jp-playlist span.jp-free-media a:hover, .os-playlist-player div.jp-type-playlist div.jp-playlist span.jp-free-media a:hover {
    color: #0d88c1; }
  .os-player-wrap span.jp-artist, .os-playlist-player span.jp-artist {
    font-size: .8em;
    color: #666; }
  .os-player-wrap .jp-video-play, .os-playlist-player .jp-video-play {
    width: 100%;
    overflow: hidden;
    /* Important for nested negative margins to work in modern browsers */
    cursor: pointer;
    background-color: transparent;
    /* Makes IE9 work with the active area over the whole video area. IE6/7/8 only have the button as active area. */ }
  .os-player-wrap .jp-jplayer, .os-playlist-player .jp-jplayer {
    background-color: #000000; }
  .os-player-wrap .jp-toggles, .os-playlist-player .jp-toggles {
    padding: 0;
    margin: 0;
    overflow: hidden; }
  .os-player-wrap .jp-audio .jp-type-single .jp-toggles, .os-playlist-player .jp-audio .jp-type-single .jp-toggles {
    width: 25px; }
  .os-player-wrap .jp-audio .jp-type-playlist .jp-toggles, .os-playlist-player .jp-audio .jp-type-playlist .jp-toggles {
    width: 55px;
    margin: 0;
    position: absolute;
    left: 325px;
    top: 50px; }
  .os-player-wrap .jp-video .jp-toggles, .os-playlist-player .jp-video .jp-toggles {
    position: absolute;
    right: 16px;
    margin: 0;
    margin-top: 10px;
    width: 100px; }
  .os-player-wrap .jp-toggles button, .os-playlist-player .jp-toggles button {
    float: none;
    width: auto;
    display: inherit;
    height: 18px;
    text-indent: 0;
    line-height: 100%;
    /* need this for IE6 */
    border: none;
    cursor: pointer; }
  .os-player-wrap .jp-full-screen, .os-playlist-player .jp-full-screen {
    background: #333;
    margin-left: 20px; }
  .os-player-wrap .jp-full-screen:focus, .os-playlist-player .jp-full-screen:focus {
    background: #333; }
  .os-player-wrap .jp-state-full-screen .jp-full-screen, .os-playlist-player .jp-state-full-screen .jp-full-screen {
    background: #333; }
  .os-player-wrap .jp-state-full-screen .jp-full-screen:focus, .os-playlist-player .jp-state-full-screen .jp-full-screen:focus {
    background: #333; }
  .os-player-wrap .jp-repeat, .os-playlist-player .jp-repeat {
    background: none; }
  .os-player-wrap .jp-repeat:focus, .os-playlist-player .jp-repeat:focus {
    background: none; }
  .os-player-wrap .jp-state-looped .jp-repeat, .os-playlist-player .jp-state-looped .jp-repeat {
    background: none; }
  .os-player-wrap .jp-state-looped .jp-repeat:focus, .os-playlist-player .jp-state-looped .jp-repeat:focus {
    background: none; }
  .os-player-wrap .jp-shuffle, .os-playlist-player .jp-shuffle {
    background: none;
    margin-left: 5px; }
  .os-player-wrap .jp-shuffle:focus, .os-playlist-player .jp-shuffle:focus {
    background: none; }
  .os-player-wrap .jp-state-shuffled .jp-shuffle, .os-playlist-player .jp-state-shuffled .jp-shuffle {
    background: none; }
  .os-player-wrap .jp-state-shuffled .jp-shuffle:focus, .os-playlist-player .jp-state-shuffled .jp-shuffle:focus {
    background: none; }
  .os-player-wrap .jp-no-solution, .os-playlist-player .jp-no-solution {
    padding: 5px;
    font-size: .8em;
    background-color: #eee;
    border: 2px solid #009be3;
    color: #000;
    display: none; }
  .os-player-wrap .jp-no-solution a, .os-playlist-player .jp-no-solution a {
    color: #000; }
  .os-player-wrap .jp-no-solution span, .os-playlist-player .jp-no-solution span {
    font-size: 1em;
    display: block;
    text-align: center;
    font-weight: bold; }

/* new */
#os-playlist::-webkit-scrollbar {
  display: none; }

.os-player-wrap .os-player-horizontal {
  background: #2a2824;
  z-index: 900;
  position: relative; }
.os-player-wrap h1, .os-player-wrap .h1, .os-player-wrap h2, .os-player-wrap .h2, .os-player-wrap h3, .os-player-wrap .h3, .os-player-wrap h4, .os-player-wrap .h4, .os-player-wrap h5, .os-player-wrap .h5, .os-player-wrap h6, .os-player-wrap .h6 {
  color: #fff; }
.os-player-wrap a {
  color: #fff; }
  .os-player-wrap a:hover {
    color: #e60000; }
.os-player-wrap a.inactive-color {
  color: #a1a1a1; }
  .os-player-wrap a.inactive-color:hover {
    color: #e60000; }
.os-player-wrap .player-top {
  padding-top: 15px; }
.os-player-wrap .icon-pause {
  display: none; }
.os-player-wrap .jp-state-playing .icon-pause {
  display: block; }
.os-player-wrap .jp-state-playing .icon-play {
  display: none; }
.os-player-wrap .player-controls a {
  padding: 7px 10px;
  cursor: pointer;
  display: inline-block; }
.os-player-wrap .jp-current-time {
  opacity: 0.7; }
.os-player-wrap .jp-volume-controls a {
  display: inline-block;
  line-height: 0; }
.os-player-wrap .jp-volume-controls div {
  line-height: 0; }
.os-player-wrap .jp-volume-controls .jp-volume-bar {
  width: 110px;
  overflow: visible;
  position: relative;
  height: 30px;
  top: -1px; }
  .os-player-wrap .jp-volume-controls .jp-volume-bar::before {
    content: "";
    height: 4px;
    width: 100%;
    background: #ddd;
    position: absolute;
    display: inline-block; }
.os-player-wrap .jp-volume-controls .jp-volume-bar-value {
  justify-content: flex-end;
  display: flex;
  align-items: center; }
.os-player-wrap .jp-volume-bar-value, .os-player-wrap .jp-play-bar {
  position: relative; }
.os-player-wrap .jp-volume-bar-value::after, .os-player-wrap .jp-play-bar::after {
  content: "";
  height: 9px;
  width: 9px;
  background: #e60000;
  display: inline-block;
  border-radius: 50%;
  position: absolute;
  right: -10px;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  -moz-transform: translate(-50%, -50%);
  -o-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  border-radius: 50%; }
.os-player-wrap .music-thumb {
  max-width: 40px; }
.os-player-wrap .jp-state-shuffled .jp-shuffle, .os-player-wrap .jp-state-looped .jp-repeat, .os-player-wrap .jp-shuffle:focus, .os-player-wrap .jp-repeat:focus {
  color: #e60000; }
.os-player-wrap .os-poster {
  position: relative;
  cursor: pointer;
  z-index: 100; }
  .os-player-wrap .os-poster.sm {
    max-width: 40px;
    max-height: 40px;
    min-width: 40px;
	overflow: hidden;
    border-radius: 3px !important;	}
.os-player-wrap .os-playlist {
  z-index: 1200;
  width: 595px;
  max-width: 100%;
  background: #151412;
  position: absolute;
  height: 100vh;
  color: #8e9194; }
  .os-player-wrap .os-playlist a {
    color: #edeeef; }
    .os-player-wrap .os-playlist a:hover {
      color: #e60000; }
  .os-player-wrap .os-playlist.off-canvas-right {
    transform: translate(595px, 0); }
  .os-player-wrap .os-playlist.off-canvas-right.show {
    transform: translate(-595px, 0); }
  .os-player-wrap .os-playlist .jp-title {
    color: #fff; }
  .os-player-wrap .os-playlist .os-player {
    padding: 40px;
    position: relative;
    background: #2a2824; }
    .os-player-wrap .os-playlist .os-player .os-poster, .os-player-wrap .os-playlist .os-player .playlist-player-control {
      flex-grow: 0; }
      .os-player-wrap .os-playlist .os-player .os-poster img, .os-player-wrap .os-playlist .os-player .playlist-player-control img {
        width: 100%; }
    .os-player-wrap .os-playlist .os-player .jp-progress {
      flex-basis: auto;
      display: flex;
      flex-grow: 1; }
  .os-player-wrap .os-playlist .control-ext {
    flex-grow: 1; }
  .os-player-wrap .os-playlist .jp-time {
    width: 40px; }
  .os-player-wrap .os-playlist .jp-progress {
    top: 8px; }
  .os-player-wrap .os-playlist .jp-playlist {
    padding: 40px;
    overflow: hidden; }
    .os-player-wrap .os-playlist .jp-playlist .os-poster {
      width: 50px;
      margin-right: 15px;
      float: left;
      margin-bottom: 25px; }
      .os-player-wrap .os-playlist .jp-playlist .os-poster img {
        height: auto;
        border-radius: 3px; }
    .os-player-wrap .os-playlist .jp-playlist li {
      margin-bottom: 0px;
      width: 100%;
      clear: both;
      position: relative; }
      .os-player-wrap .os-playlist .jp-playlist li:hover .hover-state {
        display: block;
        opacity: 1; }
      .os-player-wrap .os-playlist .jp-playlist li:hover .jp-time, .os-player-wrap .os-playlist .jp-playlist li:hover .playlist-animate {
        display: none; }
    .os-player-wrap .os-playlist .jp-playlist:last-child {
      margin-bottom: 0; }
    .os-player-wrap .os-playlist .jp-playlist .meta {
      float: right; }
    .os-player-wrap .os-playlist .jp-playlist .description {
      flex: 100%; }
      .os-player-wrap .os-playlist .jp-playlist .description a.jp-playlist-item {
        margin-top: 5px;
        display: block;
        margin-bottom: 3px; }
    .os-player-wrap .os-playlist .jp-playlist .jp-artist {
      display: block; }
      .os-player-wrap .os-playlist .jp-playlist .jp-artist a {
        color: #8e9194; }
    .os-player-wrap .os-playlist .jp-playlist .play-btn-dark {
      width: 100%;
      height: 100%;
      line-height: 55px;
      text-align: center;
      border-radius: 3px;
      display: flex;
      align-items: center;
      justify-content: center;
      overflow: hidden; }
  .os-player-wrap .os-playlist .player-details {
    flex: auto; }
  .os-player-wrap .os-playlist .blurred-bg-wrap {
    position: absolute;
    height: 100%;
    width: 100%;
    top: 0;
    left: 0;
    overflow: hidden;
    z-index: 1; }
    .os-player-wrap .os-playlist .blurred-bg-wrap .blurred-bg {
      position: absolute;
      height: 100%;
      width: 100%;
      top: 0;
      left: 0;
      background-size: cover;
      background-position: center;
      -webkit-filter: blur(30px);
      -moz-filter: blur(30px);
      -ms-filter: blur(30px);
      -o-filter: blur(30px);
      filter: blur(30px);
      filter: blur(32px);
      opacity: 0.2; }
  .os-player-wrap .os-playlist .current-item, .os-player-wrap .os-playlist .controls {
    z-index: 10;
    position: relative; }
.os-player-wrap .artist-name a {
  color: #8e9194; }
.os-player-wrap .auto-progress-width-50 {
  flex-basis: 40%;
  flex-grow: 50; }
.os-player-wrap .jp-volume-controls .icon-mute {
  display: none; }
.os-player-wrap .jp-state-muted .jp-volume-controls .icon-mute {
  display: block; }
.os-player-wrap .jp-state-muted .jp-volume-controls .icon-volume {
  display: none; }
.os-player-wrap .close-offcanvas {
  position: absolute;
  right: 0;
  top: 0;
  z-index: 100; }

/* player horizontal */
@media (max-width: 991px) {
  .os-player-wrap .jp-volume-controls .jp-volume-bar {
    width: 100px; } }
.jp-progress {
  position: relative; }

.playlist-animate {
  display: none; }
  .playlist-animate.playing {
    position: relative;
    width: auto;
    height: 30px;
    float: left;
    margin-right: 40px; }
  .playlist-animate.playing:after {
    display: block;
    width: 100%;
    margin-top: 10px; }
  .playlist-animate.now.playing .bar {
    display: inline-block;
    position: relative;
    margin-right: 4px;
    width: 3px;
    height: 1px;
    overflow: hidden;
    background: linear-gradient(to bottom, #ff9500, #ff5e3a);
    color: transparent;
    animation-name: pulse;
    animation-duration: 1s;
    animation-iteration-count: infinite; }
  .playlist-animate.paused.playing .bar {
    animation-iteration-count: 1; }
  .playlist-animate .n1 {
    animation-delay: 0.5s; }
  .playlist-animate .n2 {
    animation-delay: 0.2s; }
  .playlist-animate .n3 {
    animation-delay: .8s; }

.jp-state-playing .jp-playlist-current .playlist-animate {
  display: block; }

@keyframes pulse {
  0% {
    height: 1px;
    margin-top: 0; }
  10% {
    height: 15px;
    margin-top: -15px; }
  50% {
    height: 12px;
    margin-top: -12px; }
  60% {
    height: 17px;
    margin-top: -17px; }
  80% {
    height: 15px;
    margin-top: -15px; }
  100% {
    height: 1px;
    margin-top: 0; } }
@media (min-width: 768px) {
  #os-playlist {
    transition: all 0.6s; } }
@media (max-width: 767px) {
  .os-player-wrap .os-playlist.off-canvas-right.show {
    transform: translate(-100%, 0); }

  .current-item .os-poster {
    min-width: 40px !important; }

  .os-player-wrap .os-playlist .os-player, .os-player-wrap .os-playlist .jp-playlist {
    padding: 15px; }

  .os-player-wrap .os-playlist .os-player {
    padding-top: 25px; }

  .os-player-wrap .playlist-player-control {
    width: 100% !important;
    flex: 100% !important;
    flex-grow: 0; }

  .os-playlist .jp-playlist {
    overflow: initial !important; }
  .os-playlist .player-details .jp-title {
    font-size: 5vw; }

  .os-player-wrap .player-controls a {
    padding: 8px; } }
@media (max-width: 550px) {
  .os-playlist .jp-playlist {
    display: block !important; } }
@media (max-width: 750px) and (orientation: landscape) {
  .os-playlist .jp-playlist {
    display: block !important; } }
/* music img box */
#tabbed-browse-content-overview {
  overflow: hidden; }

.os-img-box {
  position: relative; }
  .os-img-box .img-box {
    margin-bottom: 13px;
    overflow: hidden;
    position: relative; 
	}
    .os-img-box .img-box img {
      width: 100%; }
  .os-img-box .os-price {
    color: #e60000; }
  .os-img-box .title {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
    margin-bottom: 5px;
    color: #b8babc; 
	width:200px;
	}
    .os-img-box .title a {
      color: currentColor; }
    .os-img-box .title.h2, .os-img-box .title.h3, .os-img-box .title.h4 {
      margin-bottom: 9px; }
    .os-img-box .title.multi-line {
      white-space: inherit; }
  .os-img-box .sub-title {
    margin-bottom: 8px;
    color: #5e5d5a; }
    .os-img-box .sub-title:last-child {
      margin-bottom: 0; }
  .os-img-box .sub-title, .os-img-box .sub-title a {
    color: #5e5d5a; }
  .os-img-box .icon-dots span {
    background: #e60000; }
  .os-img-box .hover-style-2 a {
    border-bottom: 1px solid transparent;
    display: inline-block; }
  .os-img-box .h-underline {
    display: inline-block;
    border: 1px solid transparent; }
  .os-img-box .hover-show {
    opacity: 0;
    visibility: hidden;
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    -o-transform: translateY(-50%);
    transform: translateY(-50%); }
  .os-img-box:hover .h-underline {
    border-bottom-color: currentColor; }
  .os-img-box:hover .title {
    color: #e60000; }
  .os-img-box:hover .hover-style-2 a {
    border-bottom: 1px solid currentColor; }
  .os-img-box:hover .hover-hide {
    opacity: 0;
    visibility: hidden; }
  .os-img-box:hover .hover-show {
    opacity: 1;
    visibility: visible; }
  .os-img-box.img-box-horizontal:hover .title {
    width: calc(100% - 80px); }
  .os-img-box.img-box-horizontal.shop-item:hover .title {
    margin-right: 0;
    width: 100%; }
  .os-img-box:hover .hover-state, .os-img-box.show .hover-state {
    opacity: 1; }
  .os-img-box:hover a.os-icon, .os-img-box.show a.os-icon {
    color: #e60000; }
  .os-img-box .dropdown-menu-toggle .os-icon {
    color: #e60000; }
  .os-img-box .hover-state a {
    color: #fff; }
  .os-img-box.os-img-box-bg-light .hover-state a {
    color: #e60000; }
  .os-img-box .hover-show {
    opacity: 0;
    transition: opacity 0.3s ease; }
  .os-img-box:hover .hover-show {
    opacity: 1; }

.hover-state-parent:hover .hover-state, .hover-state-parent.show .hover-state {
  opacity: 1; }
.hover-state-parent:hover .h-opacity-0 {
  opacity: 0; }

.album-scroller .img-scroller-wrap {
  padding-top: 30%;
  padding-bottom: 30%; }
  .album-scroller .img-scroller-wrap .os-img-box {
    -webkit-transform: translate(0, 0);
    -ms-transform: translate(0, 0);
    -moz-transform: translate(0, 0);
    -o-transform: translate(0, 0);
    transform: translate(0, 0);
    transition: all 0.4s ease-in-out; }
  .album-scroller .img-scroller-wrap .desc {
    -webkit-transform: translate(-10%, -10%);
    -ms-transform: translate(-10%, -10%);
    -moz-transform: translate(-10%, -10%);
    -o-transform: translate(-10%, -10%);
    transform: translate(-10%, -10%);
    position: absolute;
    opacity: 0;
    transition: all 0.4s ease-in-out; }
    .album-scroller .img-scroller-wrap .desc.top-sm {
      -webkit-transform: translate(0, -10%);
      -ms-transform: translate(0, -10%);
      -moz-transform: translate(0, -10%);
      -o-transform: translate(0, -10%);
      transform: translate(0, -10%); }
  .album-scroller .img-scroller-wrap .img-box {
    -webkit-transform: translate(0, 0);
    -ms-transform: translate(0, 0);
    -moz-transform: translate(0, 0);
    -o-transform: translate(0, 0);
    transform: translate(0, 0);
    transition: all 0.4s ease-in-out; }
  .album-scroller .img-scroller-wrap:hover .os-img-box {
    -webkit-transform: translate(0, -30%);
    -ms-transform: translate(0, -30%);
    -moz-transform: translate(0, -30%);
    -o-transform: translate(0, -30%);
    transform: translate(0, -30%);
    transition: all 0.4s ease-in-out; }
  .album-scroller .img-scroller-wrap:hover .desc {
    opacity: 1;
    -webkit-transform: translate(-10%, -50%);
    -ms-transform: translate(-10%, -50%);
    -moz-transform: translate(-10%, -50%);
    -o-transform: translate(-10%, -50%);
    transform: translate(-10%, -50%); }
    .album-scroller .img-scroller-wrap:hover .desc.top-sm {
      -webkit-transform: translate(0, -10px);
      -ms-transform: translate(0, -10px);
      -moz-transform: translate(0, -10px);
      -o-transform: translate(0, -10px);
      transform: translate(0, -10px); }
  .album-scroller .img-scroller-wrap:hover .img-box {
    -webkit-box-shadow: 7px 30px 80px 0 rgba(0, 0, 0, 0.5);
    box-shadow: 7px 30px 80px 0 rgba(0, 0, 0, 0.5); }
    .album-scroller .img-scroller-wrap:hover .img-box.light-shadow {
      -webkit-box-shadow: 7px 30px 80px 0 rgba(165, 169, 158, 0.5);
      box-shadow: 7px 30px 80px 0 rgba(165, 169, 158, 0.5); }

.img-box-sm {
  max-width: 50px; }

.hover-state, .absolute-info {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  opacity: 0; }
  .hover-state.show, .absolute-info.show {
    opacity: 1; }
  .hover-state.absolute-info, .absolute-info.absolute-info {
    opacity: 1; }
  .hover-state .absolute-top, .absolute-info .absolute-top {
    width: 100%;
    position: absolute;
    left: 0;
    top: 0; }
  .hover-state .absolute-bottom, .absolute-info .absolute-bottom {
    width: 100%;
    position: absolute;
    left: 0;
    bottom: 0; }
  .hover-state .absolute-bottom-left, .absolute-info .absolute-bottom-left {
    position: absolute;
    left: 0;
    bottom: 0; }
  .hover-state .absolute-top-right, .absolute-info .absolute-top-right {
    position: absolute;
    right: 0;
    top: 0; }
  .hover-state .absolute-bottom-right, .absolute-info .absolute-bottom-right {
    position: absolute;
    right: 0;
    bottom: 0; }
  .hover-state .absolute-center, .absolute-info .absolute-center {
    position: absolute;
    left: 50%;
    top: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    -o-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%); }

/* img-box-text-over */
.img-box-text-over {
  position: relative; }
  .img-box-text-over.lg {
    border-radius: 10px; }
    .img-box-text-over.lg .absolute-info .up-left {
      position: absolute;
      padding: 8%;
      top: 0;
      left: 0; }
    .img-box-text-over.lg .absolute-info .bottom-right {
      position: absolute;
      padding: 25px;
      bottom: 0;
      right: 0; }

/* other */
.os-img-box-cont-lg .os-img-box .desc {
  min-height: 75px; }

.os-img-box-cont-md .os-img-box {
  margin-bottom: 40px; }

.os-img-box-cont-sm .os-img-box {
  border-radius: 3px; }

.owl-theme-os .os-img-box:last-child {
  margin-bottom: 0; }

.box-rounded-lg {
  border-radius: 10px !important;
  overflow: hidden; }

.box-rounded-md {
  border-radius: 5px !important;
  overflow: hidden; }

.box-rounded-sm {
  border-radius: 3px !important;
  overflow: hidden; }

.absolute-info {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0; }

.play-btn-dark {
  background: rgba(0, 0, 0, 0.8);
  width: 45px;
  height: 45px;
  display: flex;
  text-align: center;
  align-items: center;
  justify-content: center;
  position: relative; }
  .play-btn-dark.play-btn-md {
    width: 70px;
    height: 70px; }
  .play-btn-dark.full-w-h {
    width: 100%;
    height: 100%; }
  .play-btn-dark.round-btn {
    border-radius: 50%; }
  .play-btn-dark.round-btn::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#c60000+0,b08cf9+86 */
    background: #c60000;
    /* Old browsers */
    background: -moz-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
    /* FF3.6-15 */
    background: -webkit-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
    /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(135deg, #c60000 0%, #e60000 86%);
    /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#c60000', endColorstr='#e60000',GradientType=1 );
    /* IE6-9 fallback on horizontal gradient */
    border-radius: 50%;
    opacity: 0;
    -webkit-transform: scale(1.02);
    -ms-transform: scale(1.02);
    -moz-transform: scale(1.02);
    -o-transform: scale(1.02);
    transform: scale(1.02); }
  .play-btn-dark:hover::before {
    opacity: 1; }
  .play-btn-dark .play-icon {
    display: inline-block;
    position: relative;
    width: 18px;
    height: 20px;
    background: url(../images/svg/play-btn-light.svg) no-repeat; }
  .play-btn-dark:hover .play-icon::before {
    opacity: 0; }
  .play-btn-dark:hover .play-icon::after {
    opacity: 1; }

.img-box-horizontal {
  display: inline-flex;
  width: 100%;
  margin-bottom: 1rem;
  /* overflow: visible;
   overflow-x: hidden;*/ }
  .img-box-horizontal .img-box-sm.img-box {
    max-width: 50px;
    min-width: 50px;
    margin-bottom: 0; }
  .img-box-horizontal .img-box-md.img-box {
    max-width: 75px;
    min-width: 75px;
    margin-bottom: 0; }
  .img-box-horizontal .des {
    padding-left: 15px;
    padding-top: 7px;
    position: relative;
    max-width: calc(100% - 50px);
    /* overflow: visible;
     overflow-x: hidden;*/
    flex-wrap: wrap;
    flex-grow: 1; }
    .img-box-horizontal .des p {
      margin-bottom: 0;
      overflow: hidden;
      text-overflow: ellipsis;
      padding-right: 20px;
    }
    .img-box-horizontal .des .left-description {
      width: 50%;
      flex: 0 0 100px;
      flex-grow: 3;
      padding-right: 1rem; }
    .img-box-horizontal .des .right-btn {
      width: auto;
      flex: 0 0 auto;
      flex-grow: 0; }
  .img-box-horizontal.h-g-bg .hover-state {
    padding-right: 15px; }
  .img-box-horizontal .hover-state .play-btn-dark {
    width: 50px;
    height: 50px;
    border-radius: 0;
    top: 0;
    align-items: center;
    justify-content: center;
    border-radius: 0; }
  .img-box-horizontal:hover .h-opacity-0 {
    opacity: 0; }
  .img-box-horizontal.img-box-horizontal-style-2 .title a {
    border-bottom: 1px solid transparent;
    display: inline-block; }
  .img-box-horizontal.img-box-horizontal-style-2:hover .title a {
    border-bottom-color: inherit; }

.album-listener {
  position: relative; }
  .album-listener .album-listerer-overlay {
    background-repeat: no-repeat;
    background-position: center center;
    -webkit-background-size: cover;
    background-size: cover;
    position: absolute;
    width: 100%;
    top: -200px;
    bottom: 0;
    left: 0;
    z-index: -1; }
  .album-listener .owl-stage-outer {
    padding-bottom: 0 !important; }

.dot-horizontal-icon {
  background: url(../images/svg/dot-nav-horizontal.svg) 100% no-repeat;
  width: 26px;
  height: 20px;
  display: inline-block;
  background-size: 100%; }

.genres {
  list-style: none;
  padding-left: 0; }
  .genres li {
    padding-left: 0; }
    .genres li a {
      color: #d5d6d6; }

.color-primary {
  color: #0c5460; }

.color-white {
  fill: #fff; }

.os-carousel {
  overflow: hidden; }

.album-listener-lg {
  height: 30vmin;
  max-height: 40vh; }

.playlist-table tr {
  display: table-row; }
.playlist-table td {
  vertical-align: middle;
  border: none;
  padding: 0; }

.os-album-button .icon-pause {
  display: none; }
.os-album-button.jp-playing .icon-play {
  display: none; }
.os-album-button.jp-playing .icon-pause {
  display: block; }

/*
.music-box-fixed-md{
  max-width: 150px;
}*/
@media (min-width: 768px) {
  .play-btn-dark.round-btn::before {
    transition: all 0.3s; }

  .os-img-box .img-box {
    transition: all 0.5s; }
  .os-img-box .title a {
    transition: color 0.3s; }

  .hover-state {
    transition: opacity 0.3s; } }
.img-box-sm-holder .hover-state {
  padding-right: 15px; }
  .img-box-sm-holder .hover-state .play-btn-dark {
    width: 50px;
    height: 50px;
    border-radius: 0;
    top: 0;
    display: inline-block;
    line-height: 62px;
    border-radius: 0; }
.img-box-sm-holder .os-img-box .des {
  padding-left: 15px;
  padding-top: 7px;
  position: relative;
  overflow: hidden;
  z-index: 1300; }
  .img-box-sm-holder .os-img-box .des p {
    margin-bottom: 0; }

.watch-album .watch-img-box {
  position: relative;
  margin-bottom: 40px; }
.watch-album .watch-img-box img {
  width: 100%;
  height: 100%; }

.play-button {
  margin-left: 2px; }

.os-browse-tabs .scrollbar {
  height: 20px;
  background: #ddd; }
  .os-browse-tabs .scrollbar .draggable-scroll {
    cursor: all-scroll;
    cursor: -webkit-grab;
    width: 10%;
    background: #555555;
    height: 100%; }

.owl-carousel .owl-item .item {
  max-width: 100%; }
  .owl-carousel .owl-item .item .preloader .position-absolute {
    top: calc(50% - 30px); }
  .owl-carousel .owl-item .item.os-lazy-item .os-img-box {
    opacity: 0;
    transition: opacity 0.3s ease-in; }

.os-carousel.nav-middle .owl-carousel {
  padding-left: 50px;
  padding-right: 50px; }
.os-carousel.nav-middle .owl-prev, .os-carousel.nav-middle .owl-next {
  position: absolute;
  left: 0;
  top: 35%; }
.os-carousel.nav-middle .owl-next {
  left: auto;
  right: 0; }
.os-carousel.padding-top .owl-item .item {
  padding-top: 15px; }

@media (min-width: 1200px) {
  .os-carousel.gutter-xl-60 .owl-item .item {
    padding-left: 30px;
    padding-right: 30px; } }
.os-carousel-swiper {
  overflow: hidden; }

[class^="gutter-"] {
  width: auto; }

.owl-theme-os .owl-nav {
  margin-top: 10px;
  text-align: center;
  -webkit-tap-highlight-color: transparent; }
  .owl-theme-os .owl-nav [class*='owl-'] {
    color: #666;
    font-size: 14px;
    margin: 5px;
    padding: 8px 7px;
    background: transparent;
    display: inline-block;
    cursor: pointer;
    border-radius: 3px; }
    .owl-theme-os .owl-nav [class*='owl-']:hover {
      background: #000;
      color: #fff;
      text-decoration: none; }
  .owl-theme-os .owl-nav .disabled {
    opacity: 0.5;
    cursor: default; }
.owl-theme-os .owl-nav.disabled + .owl-dots {
  margin-top: 0;
  margin-bottom: 20px; }
.owl-theme-os .owl-stage-outer {
  margin-bottom: 35px; }
.owl-theme-os.stage-margin-0 .owl-stage-outer {
  margin-bottom: 0; }
.owl-theme-os .owl-dots {
  text-align: center;
  -webkit-tap-highlight-color: transparent; }
  .owl-theme-os .owl-dots .owl-dot {
    display: inline-block;
    zoom: 1;
    *display: inline; }
    .owl-theme-os .owl-dots .owl-dot span {
      width: 8px;
      height: 8px;
      margin: 5px 7px;
      background: #ddd;
      display: block;
      -webkit-backface-visibility: visible;
      transition: opacity 200ms ease;
      border-radius: 30px;
      transition: all 0.3s; }
    .owl-theme-os .owl-dots .owl-dot.active span, .owl-theme-os .owl-dots .owl-dot:hover span {
      /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#c60000+0,b08cf9+86 */
      background: #c60000;
      /* Old browsers */
      background: -moz-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
      /* FF3.6-15 */
      background: -webkit-linear-gradient(-45deg, #c60000 0%, #e60000 86%);
      /* Chrome10-25,Safari5.1-6 */
      background: linear-gradient(135deg, #c60000 0%, #e60000 86%);
      /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
      filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#c60000', endColorstr='#e60000',GradientType=1 );
      /* IE6-9 fallback on horizontal gradient */ }
    .owl-theme-os .owl-dots .owl-dot.active span {
      width: 38px; }

@media (min-width: 992px) {
  .owl-theme-os .owl-nav [class*='owl-'] {
    transition: all 0.3s; } }
/* dark */
.dark-theme .owl-theme-os .owl-dots .owl-dot.active span {
  -webkit-box-shadow: none;
  box-shadow: none; }

.horizontal-icons {
  display: inline-flex;
  text-decoration: none;
  margin-bottom: 20px; }
  .horizontal-icons li > a {
    padding: 10px; }
  .horizontal-icons > li > a:first-child {
    padding-left: 0; }

.os-svg-library {
  height: 0;
  width: 0; }

.os-icon {
  line-height: 0;
  display: inline-block;
  vertical-align: middle;
  height: auto; }
  .os-icon svg {
    fill: currentColor;
    height: auto; }
  .os-icon.icon-arrow {
    -webkit-transform: translateY(-1px);
    -ms-transform: translateY(-1px);
    -moz-transform: translateY(-1px);
    -o-transform: translateY(-1px);
    transform: translateY(-1px); }
  .os-icon.icon-ssm svg {
    width: 8px;
    max-height: 8px; }
  .os-icon.icon-ssm svg {
    width: 8px;
    max-height: 8px; }
  .os-icon.icon-sm svg {
    width: 12px;
    max-height: 14px; }
  .os-icon.icon-1x svg {
    width: 16px;
    max-height: 18px; }
  .os-icon.icon-0x svg {
    width: 17px;
    max-height: 18px; }
  .os-icon.icon-2x svg {
    width: 18px;
    max-height: 20px; }
  .os-icon.icon-3x svg {
    width: 20px;
    max-height: 22px; }
  .os-icon.icon-4x svg {
    width: 25px;
    max-height: 27px; }
  .os-icon.icon-5x svg {
    width: 30px;
    max-height: 32px; }
  .os-icon.icon-6x svg {
    width: 35px;
    max-height: 38px; }
  .os-icon.icon-7x svg {
    width: 40px;
    max-height: 45px; }
  .os-icon.icon-8x svg {
    width: 50px;
    max-height: 55px; }
  .os-icon.icon-9x svg {
    width: 60px;
    max-height: 65px; }
  .os-icon.icon-10x svg {
    width: 70px;
    max-height: 75px; }

.icon-dot-nav-horizontal {
  width: 5px;
  height: 5px;
  background: currentColor;
  display: inline-block;
  position: relative;
  border-radius: 50%;
  margin: 5px 12px 2px 12px !important; }
  .icon-dot-nav-horizontal::before, .icon-dot-nav-horizontal::after {
    width: 100%;
    height: 100%;
    display: inline-block;
    background: inherit;
    content: "";
    position: absolute;
    left: -200%;
    border-radius: 50%; }
  .icon-dot-nav-horizontal::after {
    left: 200%; }
  .icon-dot-nav-horizontal.white {
    background: #ffffff; }

.icon-dot-nav-vertical {
  width: 4px;
  height: 4px;
  background: #a27bf9;
  display: block;
  position: relative;
  border-radius: 50%;
  margin: 10px; }
  .icon-dot-nav-vertical::before, .icon-dot-nav-vertical::after {
    width: 100%;
    height: 100%;
    display: block;
    background: inherit;
    content: "";
    position: absolute;
    top: -200%;
    border-radius: 50%; }
  .icon-dot-nav-vertical::after {
    top: 200%; }

.img-box-horizontal .des {
  z-index: 500; }
.img-box-horizontal .hover-state a, .img-box-horizontal .pointer {
  z-index: 600;
  position: relative; }

#top-search {
  z-index: 1200; }

.sidebar {
  position: relative; }

.z-index-100 {
  z-index: 100;
  position: relative; }

.site-header {
  z-index: 1000; }
  .site-header .absolute-header {
    z-index: 1000; }

.btn {
  z-index: 1; }

.album-cover-bg {
  z-index: -1; }

.ps__rail-x {
  z-index: 900; }

.scroll-y {
  display: flex;
  flex-direction: column;
  overflow: auto;
  position: relative; }
  .scroll-y .ps__rail-x {
    display: none; }

.scroll-x {
  overflow: auto;
  transition: .2s linear left;
  overflow-y: hidden;
  position: relative; }

.scroll-x-alt {
  overflow: auto;
  transition: .2s linear left;
  overflow-y: hidden;
  position: relative; }

.ps__rail-y {
  z-index: 1300; }

#wrap {
  transition: all 0.6s; }
  #wrap.search-open {
    /* transform: scale(0.99); */
  }

#search-box-4 #btn-search-close {
  position: fixed;
  right: 0;
  top: 0;
  opacity: 0;
  z-index: -1;
  -webkit-transform: scale(0.8);
  -ms-transform: scale(0.8);
  -moz-transform: scale(0.8);
  -o-transform: scale(0.8);
  transform: scale(0.8);
  transition: all 0.3s; }
#search-box-4 .search-inner {
  width: 100%;
  left: 0;
  overflow: hidden;
  position: fixed;
  z-index: 1000;
  transition: all 0.3s; }
  #search-box-4 .search-inner.search-inner-up {
    height: 15vh;
    top: 0;
    background: #2a2824;
    -webkit-transform: translate3d(0, -100%, 0);
    -ms-transform: translate3d(0, -100%, 0);
    -moz-transform: translate3d(0, -100%, 0);
    -o-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0); }
    #search-box-4 .search-inner.search-inner-up .search-input {
      font-size: 3.5vw;
      line-height: 1;
      display: inline-block;
      padding: 0 0 0.1em 0;
      color: #fff;
      border: 0;
      border-bottom: 0;
      background: transparent;
      border-radius: 0; }
  #search-box-4 .search-inner.search-inner-down {
    height: 85vh;
    top: 15vh;
    background: #151412;
    color: #edeeef;
    -webkit-transform: translate3d(0, 100%, 0);
    -ms-transform: translate3d(0, 100%, 0);
    -moz-transform: translate3d(0, 100%, 0);
    -o-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0); }
    #search-box-4 .search-inner.search-inner-down > div {
      height: 100%; }
    #search-box-4 .search-inner.search-inner-down nav a {
      color: #edeeef; }
      #search-box-4 .search-inner.search-inner-down nav a:hover {
        color: #e60000; }
  #search-box-4 .search-inner .navbar-expand {
    min-height: 50px; }
#search-box-4.search-active #btn-search-close {
  z-index: 1010; }
#search-box-4.search-active .search-inner.search-inner-up {
  -webkit-transform: translate3d(0, 0, 0);
  -ms-transform: translate3d(0, 0, 0);
  -moz-transform: translate3d(0, 0, 0);
  -o-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0); }
#search-box-4.search-active .search-inner.search-inner-down.open {
  -webkit-transform: translate3d(0, 0, 0);
  -ms-transform: translate3d(0, 0, 0);
  -moz-transform: translate3d(0, 0, 0);
  -o-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0); }
#search-box-4.search-active #btn-search-close {
  -webkit-transform: scale(1);
  -ms-transform: scale(1);
  -moz-transform: scale(1);
  -o-transform: scale(1);
  transform: scale(1);
  opacity: 1; }

@media (max-width: 768px) {
  #search-box-4 .search-inner.search-inner-up {
    height: 10vh; }
  #search-box-4 .search-inner.search-inner-down {
    top: 10vh;
    bottom: 0;
    height: auto; } }
/* Title status dots — /anime + /drama lists (Legacy legend:
   green=completed, blue=movie, orange=in progress, yellow=incomplete). */
.os-status-dot { width: 9px; height: 9px; border-radius: 50%; display: inline-block; flex-shrink: 0; margin-right: 7px; vertical-align: middle; }
.os-status-dot.is-movie     { background: #0d6efd; }
.os-status-dot.is-completed { background: #198754; }
.os-status-dot.is-incomplete{ background: #f0c000; }
.os-status-dot.is-progress  { background: #fd7e14; }
.os-status-legend { font-size: 12px; color: #9aa0a6; display: flex; gap: 16px; flex-wrap: wrap; align-items: center; margin: 0 0 14px; }
.os-status-legend span { display: inline-flex; align-items: center; }
.search-style-absolute {
  position: relative;
  width: 40px;
  overflow: visible; }
  .search-style-absolute .form-control {
    position: absolute;
    z-index: 5;
    height: 45px;
    width: 45px;
    padding-right: 28px;
    padding-left: 15px;
    right: 0px;
    border-radius: 30px;
    transition: 0.3s ease-in-out; }
  .search-style-absolute .search-icon {
    position: relative;
    z-index: 10;
    border-radius: 50%;
    overflow: hidden;
    height: 40px;
    width: 40px;
    top: 2px;
    right: 2px; }
  .search-style-absolute:hover .form-control, .search-style-absolute.active .form-control {
    width: 250px; }

.modal-ex-lg {
  max-width: 1030px; }

/* Other */
.dropdown-mega-menu .bg-col {
  background: linear-gradient(to left, rgba(255, 255, 255, 0) 70%, white 100%), url("../images/new-releases/new-releases-2.jpg") no-repeat; }

.artist-bg-1 {
  background-image: url("../images/single/single-3.jpg"); }

.artist-bg-2 {
  background-image: url("../images/single/single-1.jpg"); }

.listener-banner-1 {
  background-image: url("../images/banner-1.jpg");
  top: -200px; }

.sidebar-bg-1 {
  background: url("../images/sidebar-bg-1.jpg") no-repeat 0 0 !important;
  background-size: cover  !important;
  position: absolute;
  top: 0;
  right: 0;
  height: 100%;
  width: calc(100% + 200px);
  z-index: -1; }

.user {
	overflow: hidden;height: 35px;
}

#os_jplayer_main {
	position: fixed;
    bottom: 20px;
    right: 20px;
    z-indeX: 999999;
	display:none;
}

.titlebg{
	background:#000;
	opacity:0.5;
}

.follower-box-wrap {
	max-height:500px;
	overflow-y:auto;
	display:block;
}

.desrev {
	color:#5e5d5a;
}

.img-box-don {
  width:50px;
  height:50px;
  overflow:hidden;
  border-radius:50%;
}

.video-container {
  padding:10px;
  -webkit-box-shadow: 2px 7px 18px -5px rgba(0,0,0,0.72);
  -moz-box-shadow: 2px 7px 18px -5px rgba(0,0,0,0.72);
  box-shadow: 2px 7px 18px -5px rgba(0,0,0,0.72);
  border:1px dotted #333;
}
.oslist-container {
  padding:15px;
  -webkit-box-shadow: 2px 7px 18px -5px rgba(0,0,0,0.72);
  -moz-box-shadow: 2px 7px 18px -5px rgba(0,0,0,0.72);
  box-shadow: 2px 7px 18px -5px rgba(0,0,0,0.72);
  border:1px dotted #333;
  background:#111;
  min-height:1200px;
}
.comment-container {
  margin-top:20px;
  padding:15px;
  -webkit-box-shadow: 2px 7px 18px -5px rgba(0,0,0,0.72);
  -moz-box-shadow: 2px 7px 18px -5px rgba(0,0,0,0.72);
  box-shadow: 2px 7px 18px -5px rgba(0,0,0,0.72);
  border:1px dotted #333;
  background:#111;
}


.oscontent{
  padding:15px;
  -webkit-box-shadow: 2px 7px 18px -5px rgba(0,0,0,0.72);
  -moz-box-shadow: 2px 7px 18px -5px rgba(0,0,0,0.72);
  box-shadow: 2px 7px 18px -5px rgba(0,0,0,0.72);
  border:1px dotted #333;
  background-color: rgba(0, 0, 0, 0.5);
  -webkit-border-radius: 15px;
  -moz-border-radius: 15px;
  border-radius: 15px;
}

.comment-container .title-box, .oslist-container .title-box {
  border-bottom:1px dotted #333;
}
.video-components {
  padding:10px 0px;
}
.osbtn {
  position:relative;
  margin-right:5px;
}
.ospagination {
  float:right;
}
.osbtnl {
  position:relative;
  margin-left:5px;
}
.osbtnc {
  position:relative;
  margin:10px;
}

.osbtn b {
  position: absolute;
  float: right;
  bottom: -9px;
  padding: 2px 5px;
  font-size: 9px;
  background: #1a1a1a;
  border: 1px solid #e3e3e3;
  -webkit-box-shadow: 2px 7px 18px -5px rgba(0,0,0,0.72);
  -moz-box-shadow: 2px 7px 18px -5px rgba(0,0,0,0.72);
  box-shadow: 2px 7px 18px -5px rgba(0,0,0,0.72);
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px;
  border-radius: 5px;
}

.oswatchlistb {
  position: absolute;
  float: right;
  bottom: -9px;
  padding: 2px 5px;
  font-size: 9px;
  background: #1a1a1a;
  border: 1px solid #e3e3e3;
  -webkit-box-shadow: 2px 7px 18px -5px rgba(0,0,0,0.72);
  -moz-box-shadow: 2px 7px 18px -5px rgba(0,0,0,0.72);
  box-shadow: 2px 7px 18px -5px rgba(0,0,0,0.72);
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px;
  border-radius: 5px;
  right:0px;
}

.osright {
  float:right;
}
.osleft {
  float:left;
}

.commentslist {
  border-top:1px dotted #333;
}

.active-epl {
  background: #222;
}

.active-epl h5:after {
  content: '<<';
}

.itsortdesc:after{
  content: ' \2193';
}
.itsortasc:after{
  content: ' \2191';
}

.dropdown-menu-toggle-watch {
  float:right;
}
.dropdown-menu-toggle-watch svg{
  color:#FFF;
}

.donator-box,.oscomment-box {
  background:#222;
  margin:0px;
  padding:10px;
  border-bottom:1px dotted #333;
}

.userpm-box {
  margin:0px;
  padding:10px;
}
.userpm-box .des {
  padding:0px;
  padding-left:10px;
}
.userpm-box .artist {
  margin-bottom: 0px;
  font-size:20px;
}
.userpm-box .os-icon {
font-size:19px;
}

.msg-box {
  margin:0px;
  padding:10px;
  border-bottom:1px dotted #333;
}
.msg-box:hover {
  cursor:pointer;
}
.pm-messages {
  background:#333;
  border:1px solid #444;
  padding:10px;
}
.pm-messages ul {
  padding:0px;
  margin:0px;
}

.pmtitle {
  text-decoration:underline;
  font-weight:bold;
}

.pm-messages ul li #sender{

}
.pm-messages ul li #recipient{

}
.pm-messages ul li .user{
  top: -15px;
  left: 7px;
  font-size: 14px;
  border-bottom: 1px dotted #333;
  margin-bottom: 10px;
  height: auto;
  padding-bottom: 9px;
}
.pm-messages ul li .user b {
  float: right;
  font-size: 10px;
  font-weight: normal;
}
.osfw {
  color:#ccc !important;
}
.osfw:hover {
  color:#fff !important;
}
.pm-messages ul li{
  list-style: none;
  background: #222;
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px;
  border-radius: 5px;
  margin-top: 25px;
  padding: 20px;
  position: relative;
}

.oscomment-box-nc {
  text-align:center;
}
.nocomment h5{
padding:10px;
}
.nocomment {
  width:100%;
}

.donator-box:nth-child(even) {background: inherit;}
.oscomment-box:nth-child(even) {background: inherit;}

.blur {
  filter: progid:DXImageTransform.Microsoft.Blur(PixelRadius='3');
  -webkit-filter: url(#blur-filter);
  filter: url(#blur-filter);
  -webkit-filter: blur(3px);
  filter: blur(3px);
}
.blur-svg {
  display: none;
}
.os-video {
  z-index:888;
}
.oslightoverlay {
  background-color: rgb(0, 0, 0);
  opacity: 0.95;
  -moz-opacity: 0.95;
  filter: alpha(opacity=95);
  z-index: 777;
  height: 100%;
  width: 100%;
  background-repeat: repeat;
  position: fixed;
  top: 0px;
  left: 0px;
  display: none;
}

.blur:hover {
  filter:none;
  webkit-filter:none;
}
.oslist_letter {

}
.oslist-letters {
  position: absolute;
  right: -22px;
  top: -1px;
}
.oslist-letters ul{
  list-style:none;
}
.oslist-letters ul li:hover:after{
  position:absolute;
  right:-10px;

  content: "<";
}
.oslist-letters ul li:hover{
  background:#444;
  font-size:20px;
  position:relative;
}
.oslist-letters ul li{
  text-align:center;
  background:#333;
}
.oslist-letters ul li{
  padding:3px;
  border:1px dotted #222;
}
.oslists li {
  font-size: 10px;
  list-style: none;
  padding: 1px;
  margin: 0px;
  padding-left: 11px;
}

.oslists li:hover {
  background:#222;
  font-weight:bold;
}

.ostb tr td{
  border-top:0px;
  border-bottom:1px dotted #333;
  font-weight:bold;
}
.ostable tbody td {
  border:0px;
}

.ostable tbody tr:nth-child(even) {background: #222;}
.ostable tbody tr:hover {
  background:#333;
}

.ostable .osuser {
  max-width:35px;
  float:left;
  margin-right:5px;
}

.ostable td{
  vertical-align: middle;
  font-size: 14px;
}

.ostable td li #bullet, .news-box #bullet{
  flex: 0 0 auto;
  width: 9px;
  height: 9px;
  margin-right: 5px;
  display: inline-block;
}
.ostable td ul {
  margin:0px;
  padding:0px;
}
.ostable td li {
  font-size:10px;
  list-style:none;
  display:inline;
}
.ostable td a{
  font-weight:bold;
  font-size: 16px;
  color: #FFF;
}

b,strong {
  font-weight:bold;
}

.threaderr {
  color:#F00;
}

.osmodal {
  background-color: #222;
  -webkit-box-shadow: 2px 7px 18px -5px rgba(0,0,0,0.72);
  -moz-box-shadow: 2px 7px 18px -5px rgba(0,0,0,0.72);
  box-shadow: 2px 7px 18px -5px rgba(0,0,0,0.72);
}

.err404 {
  font-size:250px;
  line-height:220px;
}
.err403 {
  font-size: 40px;
  line-height: 110px;
}
.oserr404 p{
  font-size:16px;
}

.ospost-first .userinfo .uname{
  font-size: 15px;
  padding: 5px;
  text-transform: uppercase;
}

.osreview-post .userinfo .uname{
  font-size: 15px;
  padding: 5px;
  text-transform: uppercase;
}

.mobonly.userinfo {    margin-bottom: 20px;}
.mobonly.userinfo:after {
  content: ' ';
  width: 0;
  height: 0;
  border-left: 20px solid transparent;
  border-right: 20px solid transparent;
  margin-left: auto;
  margin-right: auto;
  left: 0;
  right: 0;
  border-top: 30px solid #555;
  position: absolute;
  bottom: -38px;
  z-index: 1;
}
.mobonly.userinfo .avyReply {}
.mobonly.userinfo .uname {}


.osthread {
  padding:15px;
}

.ospost-content {
  padding: 35px 20px;
  -webkit-box-shadow: -1px -4px 8px -2px rgba(0,0,0,0.75);
  -moz-box-shadow: -1px -4px 8px -2px rgba(0,0,0,0.75);
  box-shadow: -1px -4px 8px -2px rgba(0,0,0,0.75);
  border-top:1px dotted #333;
  border-left:1px dotted #333;
  border-right:1px dotted #333;
  background-color: rgba(0, 0, 0, 0.5);
  -webkit-border-top-left-radius: 15px;
  -webkit-border-top-right-radius: 15px;
  -moz-border-radius-topleft: 15px;
  -moz-border-radius-topright: 15px;
  border-top-left-radius: 15px;
  border-top-right-radius: 15px;
}

.osreview-post .ospost-content {
  min-height: 250px;
  padding: 15px;
  -webkit-box-shadow: 2px 7px 18px -5px rgba(0,0,0,0.72);
  -moz-box-shadow: 2px 7px 18px -5px rgba(0,0,0,0.72);
  box-shadow: 2px 7px 18px -5px rgba(0,0,0,0.72);
  border: 1px dotted #333;
  background-color: rgba(0, 0, 0, 0.5);
  -webkit-border-radius: 15px;
  -moz-border-radius: 15px;
  border-radius: 15px;
  padding-bottom: 50px;
  padding-top: 40px;
}

.feeduseravy {
  width: 20px;
  height: 20px;
  overflow: hidden;
  -webkit-border-radius: 10px;
  -moz-border-radius: 10px;
  border-radius: 10px;
  float: left;
  margin-right: 5px;
}

.feedlist ul li {
  list-style:none;
  padding: 0px 12px;
  font-size: 11px;
}

.feedlist ul {
  padding:0px;
  margin:0px;
}

.feedtime {
  font-size:10px;
  color:#444;
  display:block;
  text-align:right;
}

.discuss_ostitle {
  font-size:9px;
}

.discuss_ostitle a{
  font-size:9px !important;
}

.thread-animetitle-close {
  display:none;
  position: absolute;
  top: 11px;
  right: 18px;
  font-size: 15px;
}

.thread-animetitle-close:hover {
  cursor:pointer;
}

#thread-animeac {
  position:relative;

}

.ospost-content p{
  font-size:15px;
}

.ospost-first{

}
.ospost-main {
  min-height: 330px;
  position:relative;
  padding-bottom: 50px;
}

.ospost-main .postinfo {
  position:absolute;
  top:15px;
  right:20px;
  font-size:12px;
}

.ospost-main .buttons {
  bottom: 20px;
  position: absolute;
  right: 10px;
}

.ospost-main .userbuttons {
  bottom: 20px;
  position: absolute;
  left: 20px;
}

.ospost-main .buttons .osbtn:hover, .ospost-main .userbuttons .osbtn:hover{ background:#333; cursor:pointer; }
.ospost-main .buttons .osbtn, .ospost-main .userbuttons .osbtn{
  padding:5px 10px;
}

.ospost-stats {
}
.ospost-stats-content-center {
  padding:10px;
  background-color: rgba(0, 0, 0, 0.5);
  border-left:1px dotted #333;
  border-right:1px dotted #333;
}
.ospost-stats-content {
  padding:10px;
  background-color: rgba(0, 0, 0, 0.5);
  border-left:1px dotted #333;
  border-right:1px dotted #333;
  border-bottom:1px dotted #333;
  -webkit-box-shadow: -1px 4px 8px -2px rgba(0,0,0,0.75);
  -moz-box-shadow: -1px 4px 8px -2px rgba(0,0,0,0.75);
  box-shadow: -1px 4px 8px -2px rgba(0,0,0,0.75);
}

.ospost-stats-content-center ul {
  padding:0px;
  margin:0px;
}
.ospost-stats-content-center ul li #head{
  padding:5px 10px;
}
.ospost-stats-content-center ul li{
  display:inline-block;
  text-align:center;
  padding:5px;
  min-width:80px;
}

.ospost-stats-content-center ul li span{

}

.ospost-stats-content-center ul li .usericon .user {
  width:25px;
  display:inline-block;
  height:25px;
}
.ospost-stats-content-center ul li h6{
  font-size: 28px;
}
.ospost-stats-content-center ul li b{
  display:inline;
}
.ospost-stats-content-center ul li .usericon{
  display: flex;
  align-items: center;
  padding:5px;
}

.ospost-stats-btn {
  text-align:center;
  font-size:15px;
  font-weight:bold;
  background:#222;
}

.ospost-replies {}

.ospost-replies .row {
  margin-top: 20px;
}

.avyReply{}
.avyReply .user{
  width:100px;
  height:100px;
  margin:0 auto;
}

.mirror {
  -webkit-transform: scaleX(-1);
  transform: scaleX(-1);
}

#btn-search-close {
  border-shadow:none;
  -webkit-box-shadow:none;

}

.ospost-replies .ospost-main{
  min-height: 250px;
  padding: 15px;
  -webkit-box-shadow: 2px 7px 18px -5px rgba(0,0,0,0.72);
  -moz-box-shadow: 2px 7px 18px -5px rgba(0,0,0,0.72);
  box-shadow: 2px 7px 18px -5px rgba(0,0,0,0.72);
  border: 1px dotted #333;
  background-color: rgba(0, 0, 0, 0.5);
  -webkit-border-radius: 15px;
  -moz-border-radius: 15px;
  border-radius: 15px;
  padding-bottom: 50px;
  padding-top: 40px;
}

.ospost-main blockquote .usericon b{
  display:inline;
}
.ospost-main blockquote .usericon .user {
  width:25px;
  display:inline-block;
  height:25px;
}
.ospost-main blockquote .usericon{
  display:inline-block;
}
.ospost-main blockquote{
  position:relative;
  background-color: rgba(10,10, 10, 0.5);
  border: 1px solid #444;
  padding: 20px;
  -webkit-border-radius: 15px;
  -moz-border-radius: 15px;
  border-radius: 15px;
}

.ospost-main blockquote .quoteShowAll:hover{
  background:#333;
}
.ospost-main blockquote .quoteShowAll {
  position:absolute;
  right:20px;
  top:15px;
  padding:5px 10px;
}
.oslogin-dd a{
  color:#FFF !important;
}
.oslogin-dd {
  background:#222;
  color:#FFF;
  border:1px solid #333
}
.osbtnlogin:hover {
  background:#222;
  color:#c60000;
}
.osbtnlogin {
  cursor:pointer;
  font-weight:bold;
  text-transform:uppercase;
  font-size:16px;
  padding:5px 10px;
}

.deskonly {
  display:block;
}
.mobonly,.mobright {
  display:none;
}

.oscontent-exp {
  margin-top:10px;
  display: block;
  position:relative;
}

.os-expand {
  display:block;
}
.osregister {
  min-height:700px
}
.osregister .row{
  padding:40px 0px;
}
.osregister input[type=checkbox] {
  display: inline-block;
}

.user-settings-dropdown {
  background: #111;
  border: 1px solid #222 !important;
  -webkit-box-shadow: 2px 7px 18px -5px rgba(0,0,0,0.72);
  -moz-box-shadow: 2px 7px 18px -5px rgba(0,0,0,0.72);
  box-shadow: 2px 7px 18px -5px rgba(0,0,0,0.72);
}

.user-settings-dropdown .user-settings-menu li a{
  color:#FFF;
}

.notifications ul, .osnotiflist {
  padding:0px;
  margin:0px;
}

.notifications ul li, .osnotiflist li {
  list-style: none;
  padding: 5px 20px 5px 0px;
}

.notifications ul li div, .osnotiflist li div {
  position:relative;
  padding: 0px;
}
.notifications ul li .notiftime, .osnotiflist li .notiftime {
  position:absolute;
  top:8px;
  right: -20px;
}

.osnotif {
  overflow:hidden;
}

.osnotiflist li:hover {
  background:#333;
}

.osnotiflist .notification-desc a {
  font-weight:bold;
  color:#fff;
  text-decoration: underline;
}

.member-cover{
  background-size:cover;
  background-repeat:no-repeat;
}

.osmedals img {
  padding:15px;
}

.osimgavy img{
    -webkit-border-radius: 15px;
    -moz-border-radius: 15px;
    border-radius: 15px;
    -webkit-box-shadow: 2px 2px 5px 0px rgba(0,0,0,0.75);
    -moz-box-shadow: 2px 2px 5px 0px rgba(0,0,0,0.75);
    box-shadow: 2px 2px 5px 0px rgba(0,0,0,0.75);
}

.oslw{
    border-bottom: 2px solid #333;
    padding-bottom: 10px;
}

.oswatchlist {
  overflow:inherit;
}

.progress {
    background-color: #333;
}

.progress-bar-success {
    background-color:#c00;
}
.osfriendlist {}
.osfriendlist .img-box-horizontal {
  padding:5px 15px;
}
.osfriendlist .img-box-horizontal:nth-child(odd) {background:#333;}

.osfriendreqlist {}
.osfriendreqlist .img-box-horizontal {
  padding:5px 15px;
}
.osfriendreqlist .img-box-horizontal:nth-child(odd) {background:#333;}

.myplaylist .title {
  padding:10px;
}

.showplaylist:hover,.playlbtn:hover {
  cursor:pointer;
  background:#333;
}
.plistbox:hover {
  background:#333;
}

.nowplaying {
  background:#333;
  font-weight:bold;
}

.playdel,.playlistdel {
  cursor: pointer;
  right: 10px;
  position: absolute;
  padding-top: 10px;
}

.vidcont {
  position:relative;
  overflow:hidden;
}

.vidplaceholder img{
  width: 100%;
}
.vidplaceholder {
  position:absolute;
  width:100%;
  top:0px;
  left:0px;
  z-index:991;
}

.oswatched {
  font-size: 18px;
}

.osversion {
  font-size: 10px;
  display: block;
  padding: 0px;
  margin-top: -9px;
  font-weight: normal;
}

.vidoverlay {
  position: absolute;
  font-size: 16px;
  top: 10px;
  z-index: 9999;
  color: #FFF;
  background: rgba(0,0,0,0.5);
  padding: 10px;
  font-weight: bold;
  left:-1000px;
}

.vidoverlay-title {
  font-size:20px;
}

.plistbox {
  position:relative;
}

.thread-pb:hover{
  background:#222;
}

.thread-pb {
  border: 1px solid #333;
  padding: 20px 0px;
  margin: 20px 0px;
  background: #111;
}

.thread-pb .ththumb {

}

.thread-pb .thinfo {

}
.thread-pb .thinfo h5{
  font-size:20px;
}

.osreview-rate {
  padding: 10px;
  margin: 0px;
  background: #111;
}
.osreview-rate li:nth-child(even){
  background:#222;
}
.osreview-rate li{
  list-style: none;
  margin: 0px;
  padding: 3px;
}
.osreview-rate li span{
  float: right;
  padding-right: 10px;
}
.osreview-rate .overall {
  font-size:15px;
  background:#333 !important;
}

.osrevhome {
  background:rgba(0,0,0,0.5);
  padding:10px;
}

#ospm ul li {
  background: #222;
  border:0px;
}
#ospm ul li:hover{
  background:#333;
}
#ospm .modal-danger .modal-header {
  background:#c60000;
}

.osiconloading svg{
  width: 100px !important;
  max-height: 105px !important;
}

.noshow {
  width: 0px;
  height: 0px;
  overflow: hidden;
}

.haspm {
  position:relative;
}
.haspm .pmchat:after {
  display: inline-block;
  content: "";
  width: 9px;
  height: 9px;
  background: #e60000;
  position: absolute;
  top: 3px;
  right: 10px;
  border-radius: 50%;
}

#forgetpass {
  cursor:pointer;
}

/* ── Shoutbox Redesign ── */
:root {
  --sb-panel-bg: #1a1a1a;
  --sb-msg-bg: #222;
  --sb-input-bg: #2a2824;
  --sb-border: #2a2824;
  --sb-text: #b8babc;
  --sb-heading: #edeeef;
  --sb-muted: #8e9194;
  --sb-red: #e60000;
  --sb-red-dark: #c60000;
  --sb-green: #4caf50;
  --sb-width: 380px;
  --sb-radius: 12px;
  --fab-size: 52px;
}

/* FAB Button */
.sb-fab {
  position: fixed;
  bottom: 24px;
  right: 24px;
  width: var(--fab-size);
  height: var(--fab-size);
  border-radius: 50%;
  background: linear-gradient(135deg, var(--sb-red-dark), var(--sb-red));
  border: none;
  color: #fff;
  font-size: 20px;
  cursor: pointer;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 16px rgba(230,0,0,0.35), 0 2px 4px rgba(0,0,0,0.4);
  transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 0.3s ease;
  outline: none;
}
.sb-fab:hover {
  transform: scale(1.08);
  box-shadow: 0 6px 24px rgba(230,0,0,0.45), 0 2px 8px rgba(0,0,0,0.5);
}
.sb-fab:active { transform: scale(0.95); }
.sb-fab .fab-icon {
  transition: transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1), opacity 0.2s;
}
.sb-fab.is-open .fab-icon {
  transform: rotate(90deg) scale(0.8);
  opacity: 0;
}
.sb-fab .fab-close {
  position: absolute;
  opacity: 0;
  transform: rotate(-90deg) scale(0.8);
  transition: transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1), opacity 0.2s;
}
.sb-fab.is-open .fab-close {
  opacity: 1;
  transform: rotate(0deg) scale(1);
}

/* Online badge on FAB */
.sb-fab-badge {
  position: absolute;
  top: -4px; right: -4px;
  background: var(--sb-green);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  min-width: 20px;
  height: 20px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 5px;
  line-height: 1;
  box-shadow: 0 2px 6px rgba(0,0,0,0.4);
  border: 2px solid #151412;
  transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.sb-fab:hover .sb-fab-badge { transform: scale(1.1); }

/* Pulse animation for new messages */
.sb-fab.has-new::after {
  content: '';
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  background: var(--sb-red);
  z-index: -1;
  animation: sb-fab-pulse 1.5s cubic-bezier(0.66, 0, 0, 1) infinite;
}
@keyframes sb-fab-pulse {
  0% { transform: scale(1); opacity: 0.5; }
  100% { transform: scale(1.6); opacity: 0; }
}

/* Panel */
.sb-panel {
  position: fixed;
  bottom: 90px;
  right: 24px;
  width: var(--sb-width);
  max-height: calc(100vh - 120px);
  background: var(--sb-panel-bg);
  border-radius: var(--sb-radius);
  border: 1px solid rgba(255,255,255,0.06);
  box-shadow: 0 20px 60px rgba(0,0,0,0.5), 0 4px 16px rgba(0,0,0,0.3), inset 0 1px 0 rgba(255,255,255,0.04);
  z-index: 999;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transform-origin: bottom right;
  transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1), opacity 0.25s ease;
}
.sb-panel.is-hidden {
  transform: scale(0.85) translateY(20px);
  opacity: 0;
  pointer-events: none;
}

/* Header */
.sb-header {
  display: flex;
  align-items: center;
  padding: 14px 16px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  background: linear-gradient(180deg, rgba(255,255,255,0.02) 0%, transparent 100%);
  flex-shrink: 0;
}
.sb-header-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--sb-heading);
  letter-spacing: 0.02em;
}
.sb-header-online {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  margin-left: 10px;
  font-size: 11px;
  color: var(--sb-green);
  font-weight: 500;
}
.sb-header-online .dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--sb-green);
  animation: sb-dot-glow 2s ease-in-out infinite;
}
@keyframes sb-dot-glow {
  0%, 100% { box-shadow: 0 0 4px rgba(76,175,80,0.4); }
  50% { box-shadow: 0 0 8px rgba(76,175,80,0.8); }
}
.sb-header-actions {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 6px;
}
.sb-header-actions a,
.sb-header-actions button {
  color: var(--sb-muted);
  font-size: 11px;
  text-decoration: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 6px;
  transition: all 0.2s;
  font-family: inherit;
}
.sb-header-actions a:hover,
.sb-header-actions button:hover {
  color: var(--sb-text);
  background: rgba(255,255,255,0.05);
}
.sb-minimize { font-size: 14px !important; }

/* Tabs (All / Updates / Chat) */
.sb-tabs {
  display: flex;
  gap: 2px;
  padding: 0 6px;
  background: var(--sb-msg-bg);
  border-bottom: 1px solid rgba(255,255,255,0.05);
}
.sb-tab {
  flex: 1;
  background: transparent;
  border: 0;
  color: #888;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .3px;
  text-transform: uppercase;
  padding: 8px 4px;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  transition: color .15s, border-color .15s;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
}
.sb-tab:hover { color: #ccc; }
.sb-tab.active { color: #fff; border-bottom-color: var(--sb-red, #e60000); }
.sb-tab-count {
  background: var(--sb-red, #e60000);
  color: #fff;
  font-size: 9px;
  line-height: 1;
  padding: 2px 5px;
  border-radius: 8px;
  min-width: 16px;
  text-align: center;
  font-weight: 700;
}

/* Tab filtering — driven by data-tab on the panel; works for both initial
   render and live socket appends with zero per-message JS work. */
.sb-panel[data-tab="updates"] .sb-msg[data-msg-type="chat"]   { display: none; }
.sb-panel[data-tab="chat"]    .sb-msg[data-msg-type="update"] { display: none; }

/* Guest blur — wraps recent-replies / recent-reviews for non-logged-in
   visitors. Shows real data behind a blur with a sign-up CTA overlay. */
.guest-blur-wrap { position: relative; }
.guest-blurred {
  filter: blur(4px);
  pointer-events: none;
  user-select: none;
}
.guest-blur-cta {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  z-index: 5;
  background: rgba(20, 20, 30, 0.94);
  border: 1px solid rgba(230, 0, 0, 0.4);
  border-radius: 10px;
  padding: 24px 32px;
  text-align: center;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.6);
  max-width: 420px;
  backdrop-filter: blur(2px);
}
.guest-blur-cta h3 {
  font-size: 18px; font-weight: 700; color: #fff; margin: 0 0 6px 0;
}
.guest-blur-cta p {
  font-size: 13px; color: #b8babc; margin: 0 0 14px 0;
}
.guest-blur-cta .btn { font-weight: 600; padding: 10px 22px; }

/* "Join Discord" CTA banner — slim row between tabs and messages, only
   visible to logged-in users who haven't linked their Discord account. */
.sb-discord-banner {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 12px;
  background: linear-gradient(90deg, rgba(88,101,242,0.18), rgba(88,101,242,0.08));
  border-bottom: 1px solid rgba(88,101,242,0.3);
  font-size: 12px;
}
.sb-discord-link {
  color: #a8b3ff; text-decoration: none; font-weight: 600;
  display: inline-flex; align-items: center; gap: 8px;
  transition: color .15s;
}
.sb-discord-link i { font-size: 14px; color: #5865f2; }
.sb-discord-link:hover { color: #fff; }
.sb-discord-dismiss {
  background: transparent; border: 0; color: #8e9194; font-size: 18px;
  line-height: 1; cursor: pointer; padding: 0 4px;
}
.sb-discord-dismiss:hover { color: #fff; }

/* Inline GIFs / images bridged from Discord (or pasted image URLs).
   Sized like Discord's small inline preview so they don't dominate the panel. */
.sb-inline-img {
  max-width: 220px;
  max-height: 180px;
  border-radius: 6px;
  display: block;
  margin-top: 4px;
  background: rgba(255,255,255,0.04);
}

/* Messages */
.sb-messages {
  flex: 1;
  overflow-y: auto;
  padding: 8px 0;
  background: var(--sb-msg-bg);
  scroll-behavior: smooth;
  max-height: 420px;
  min-height: 200px;
}
.sb-messages::-webkit-scrollbar { width: 4px; }
.sb-messages::-webkit-scrollbar-track { background: transparent; }
.sb-messages::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 2px; }
.sb-messages::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,0.2); }

/* Single message */
.sb-msg {
  padding: 8px 14px;
  transition: background 0.15s;
  position: relative;
  border-left: 3px solid transparent;
}
.sb-msg:hover { background: rgba(255,255,255,0.02); }
.sb-msg.is-mentioned {
  border-left-color: var(--sb-red);
  background: rgba(230,0,0,0.04);
}
.sb-msg.is-mentioned:hover { background: rgba(230,0,0,0.07); }

.sb-msg-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 3px;
}
.sb-msg-avatar {
  width: 28px; height: 28px;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
  border: 1.5px solid rgba(255,255,255,0.08);
}
.sb-msg-avatar img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.sb-msg-name {
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: opacity 0.15s;
  text-decoration: none;
}
.sb-msg-name:hover { opacity: 0.8; }
.sb-msg-name.role-admin { color: #e60000; }
.sb-msg-name.role-mod { color: #4caf50; }
.sb-msg-name.role-vip { color: #ffc107; }
.sb-msg-name.role-member { color: var(--sb-text); }

/* Group title badge — slim outlined chip next to the username. Uses the
   group's color for text + border on a faint dark tint, so it complements
   the username styling without dominating it (the earlier filled-pill design
   competed visually with the username and the donor badge). */
.sb-group-badge {
    display: inline-block;
    padding: 0 6px;
    margin-left: 6px;
    font-size: 9.5px;
    font-weight: 600;
    line-height: 14px;
    height: 16px;
    border-radius: 3px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.18);
    color: rgba(255, 255, 255, 0.7);
    vertical-align: 1px;
    letter-spacing: 0.03em;
    white-space: nowrap;
    text-transform: none;
    opacity: 0.92;
}
.os-light-mode .sb-group-badge {
    background: rgba(0, 0, 0, 0.04);
    border-color: rgba(0, 0, 0, 0.18);
    color: rgba(0, 0, 0, 0.65);
}

.sb-msg-time {
  margin-left: auto;
  font-size: 10px;
  color: var(--sb-muted);
  opacity: 0.6;
  flex-shrink: 0;
}
.sb-msg-mod {
  display: flex;
  gap: 4px;
  opacity: 0;
  transition: opacity 0.15s;
  flex-shrink: 0;
}
.sb-msg:hover .sb-msg-mod { opacity: 1; }
.sb-msg-mod button {
  background: none;
  border: none;
  color: rgba(255,255,255,0.2);
  font-size: 10px;
  cursor: pointer;
  padding: 2px 4px;
  border-radius: 3px;
  transition: all 0.15s;
}
.sb-msg-mod .mod-del:hover { color: #e63946; background: rgba(230,57,70,0.1); }
.sb-msg-mod .mod-ban:hover { color: #f4a261; background: rgba(244,162,97,0.1); }

.sb-msg-body {
  font-size: 12.5px;
  line-height: 1.5;
  color: var(--sb-text);
  padding-left: 36px;
  word-wrap: break-word;
}
.sb-msg-body .mention {
  font-weight: 600;
  cursor: pointer;
}
.sb-msg-body .mention:hover { text-decoration: underline; }

/* Typing Indicator */
.sb-typing {
  padding: 6px 14px 6px 50px;
  font-size: 11px;
  color: var(--sb-muted);
  background: var(--sb-msg-bg);
  display: flex;
  align-items: center;
  gap: 6px;
  min-height: 28px;
  border-top: 1px solid rgba(255,255,255,0.03);
  opacity: 0;
  transition: opacity 0.25s;
}
.sb-typing.is-visible { opacity: 1; }

.typing-dots {
  display: flex;
  gap: 3px;
}
.typing-dots span {
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--sb-muted);
  animation: sb-typing-bounce 1.2s ease-in-out infinite;
}
.typing-dots span:nth-child(2) { animation-delay: 0.15s; }
.typing-dots span:nth-child(3) { animation-delay: 0.3s; }
@keyframes sb-typing-bounce {
  0%, 60%, 100% { transform: translateY(0); opacity: 0.4; }
  30% { transform: translateY(-4px); opacity: 1; }
}

/* Input Area */
.sb-input-area {
  padding: 10px 12px;
  border-top: 1px solid rgba(255,255,255,0.06);
  background: var(--sb-panel-bg);
  flex-shrink: 0;
  position: relative;
}
.sb-input-wrap {
  display: flex;
  align-items: center;
  gap: 6px;
  background: var(--sb-input-bg);
  border-radius: 22px;
  padding: 4px 6px 4px 14px;
  border: 1px solid rgba(255,255,255,0.04);
  transition: border-color 0.2s;
}
.sb-input-wrap:focus-within { border-color: rgba(230,0,0,0.3); }
.sb-input-wrap input {
  flex: 1;
  background: none;
  border: none;
  outline: none;
  color: var(--sb-heading);
  font-family: 'Poppins', sans-serif;
  font-size: 12.5px;
  padding: 6px 0;
  min-width: 0;
}
.sb-input-wrap input::placeholder { color: var(--sb-muted); opacity: 0.5; }

.sb-input-btn {
  width: 32px; height: 32px;
  border-radius: 50%;
  border: none;
  background: none;
  color: var(--sb-muted);
  font-size: 15px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
  flex-shrink: 0;
}
.sb-input-btn:hover { color: var(--sb-text); background: rgba(255,255,255,0.05); }
.sb-input-btn.btn-send {
  background: linear-gradient(135deg, var(--sb-red-dark), var(--sb-red));
  color: #fff;
  font-size: 13px;
}
.sb-input-btn.btn-send:hover {
  box-shadow: 0 2px 8px rgba(230,0,0,0.4);
  transform: scale(1.05);
}

/* Emoji Picker */
.sb-emoji-picker {
  position: absolute;
  bottom: 100%;
  left: 12px; right: 12px;
  margin-bottom: 8px;
  background: var(--sb-panel-bg);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 10px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.5);
  padding: 10px;
  z-index: 10;
  transform: translateY(8px);
  opacity: 0;
  pointer-events: none;
  transition: all 0.25s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.sb-emoji-picker.is-open {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}
.sb-emoji-tabs {
  display: flex;
  gap: 2px;
  margin-bottom: 8px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  padding-bottom: 6px;
}
.sb-emoji-tab {
  font-size: 14px;
  padding: 4px 8px;
  border-radius: 6px;
  cursor: pointer;
  transition: background 0.15s;
  border: none;
  background: none;
}
.sb-emoji-tab:hover { background: rgba(255,255,255,0.06); }
.sb-emoji-tab.active { background: rgba(230,0,0,0.15); }

.sb-emoji-grid {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 2px;
  max-height: 160px;
  overflow-y: auto;
}
.sb-emoji-grid::-webkit-scrollbar { width: 3px; }
.sb-emoji-grid::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 2px; }
.sb-emoji-grid span {
  font-size: 18px;
  padding: 4px;
  text-align: center;
  cursor: pointer;
  border-radius: 6px;
  transition: all 0.15s;
  line-height: 1.3;
  user-select: none;
}
.sb-emoji-grid span:hover {
  background: rgba(255,255,255,0.08);
  transform: scale(1.2);
}

/* Message entrance animation (applied via JS only to new messages) */
.sb-msg-enter {
  animation: sb-msg-in 0.3s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}
@keyframes sb-msg-in {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Responsive */
@media (max-width: 440px) {
  :root { --sb-width: calc(100vw - 16px); }
  .sb-panel { right: 8px; bottom: 80px; }
  .sb-fab { right: 12px; bottom: 12px; }
}

/* ── End Shoutbox ── */

/* ══════════════════════════════════════════
   Discussions List Page Redesign
   ══════════════════════════════════════════ */
.disc-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
}
.disc-header h1 {
  font-size: 22px;
  font-weight: 700;
  color: #edeeef;
  letter-spacing: -0.02em;
}
.disc-header .btn-new-thread {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 9px 20px;
  background: linear-gradient(135deg, #c60000, #e60000);
  color: #fff;
  font-family: inherit;
  font-size: 12.5px;
  font-weight: 600;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  box-shadow: 0 3px 12px rgba(230,0,0,0.25);
  transition: all 0.2s;
}
.disc-header .btn-new-thread:hover {
  box-shadow: 0 5px 20px rgba(230,0,0,0.35);
  transform: translateY(-1px);
}

.disc-filters {
  background: #1a1a1a;
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 10px;
  padding: 14px 16px;
  margin-bottom: 16px;
}
.disc-filter-row {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.disc-filter-row + .disc-filter-row {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid rgba(255,255,255,0.06);
}
.disc-filter-label {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: #8e9194;
  margin-right: 6px;
  min-width: 40px;
}
.disc-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px;
  font-size: 11.5px;
  font-weight: 500;
  border-radius: 20px;
  border: 1.5px solid transparent;
  background: rgba(255,255,255,0.04);
  color: #8e9194;
  cursor: pointer;
  transition: all 0.2s;
  text-decoration: none;
}
.disc-pill:hover {
  background: rgba(255,255,255,0.07);
  color: #b8babc;
  text-decoration: none;
}
.disc-pill .pill-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
  display: inline-block;
}
.disc-pill.active {
  color: #fff;
  font-weight: 600;
}

.disc-list {
  background: #1a1a1a;
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 10px;
  overflow: hidden;
}
.disc-row {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 14px 18px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  transition: background 0.15s;
  cursor: pointer;
  position: relative;
}
.disc-row:last-child { border-bottom: none; }
.disc-row:hover { background: #2a2824; }
.disc-row.is-pinned { background: rgba(230,0,0,0.02); }
.disc-row.is-pinned:hover { background: rgba(230,0,0,0.05); }

.disc-avatar {
  width: 38px; height: 38px;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
  border: 2px solid rgba(255,255,255,0.06);
  margin-top: 2px;
}
.disc-avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }

.disc-content { flex: 1; min-width: 0; }
.disc-title-row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 2px;
}
.disc-pin { color: #e60000; font-size: 11px; opacity: 0.7; }
.disc-title {
  font-size: 14.5px;
  font-weight: 600;
  color: #edeeef;
  transition: color 0.15s;
  line-height: 1.3;
}
.disc-row:hover .disc-title { color: #fff; }
.disc-title a { color: inherit; text-decoration: none; }
.disc-title a:hover { color: #fff; }

.disc-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 10px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 10px;
  letter-spacing: 0.02em;
  white-space: nowrap;
  line-height: 1.5;
}
.disc-badge .badge-dot {
  width: 5px; height: 5px;
  border-radius: 50%;
  flex-shrink: 0;
  display: inline-block;
}

.disc-anime {
  font-size: 11px;
  color: #8e9194;
  margin-bottom: 4px;
}
.disc-anime i { margin-right: 4px; font-size: 10px; }
.disc-anime a { color: #8e9194; font-style: italic; transition: color 0.15s; text-decoration: none; }
.disc-anime a:hover { color: #e60000; }

.disc-meta {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: 6px;
  font-size: 11.5px;
  color: #8e9194;
}
.disc-meta-item {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.disc-meta-item i { font-size: 10px; opacity: 0.6; }

.disc-contributors {
  display: flex;
  align-items: center;
  margin-left: auto;
}
.disc-contrib-avatar {
  width: 22px; height: 22px;
  border-radius: 50%;
  overflow: hidden;
  border: 2px solid #1a1a1a;
  margin-left: -6px;
  transition: transform 0.15s;
}
.disc-contrib-avatar:first-child { margin-left: 0; }
.disc-row:hover .disc-contrib-avatar { transform: translateY(-1px); }
.disc-contrib-avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }

.disc-activity {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  color: #8e9194;
  margin-left: 10px;
  white-space: nowrap;
  text-decoration: none;
}
.disc-activity:hover { color: #b8babc; }
.disc-activity i { font-size: 9px; opacity: 0.5; }

.disc-pagination {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 4px;
  margin-top: 16px;
}
.disc-page-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 34px;
  height: 34px;
  padding: 0 10px;
  font-family: inherit;
  font-size: 12px;
  font-weight: 500;
  color: #8e9194;
  background: #1a1a1a;
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.15s;
  text-decoration: none;
}
.disc-page-btn:hover { background: #2a2824; color: #b8babc; text-decoration: none; }
.disc-page-btn.active {
  background: #e60000;
  color: #fff;
  border-color: #e60000;
  font-weight: 600;
}
.disc-page-btn.disabled {
  opacity: 0.3;
  cursor: default;
  pointer-events: none;
}

@media (max-width: 640px) {
  .disc-row { padding: 12px 14px; gap: 10px; }
  .disc-title { font-size: 13.5px; }
  .disc-contributors { display: none; }
  .disc-meta { flex-wrap: wrap; gap: 8px; }
}

/* ══════════════════════════════════════════
   Thread Detail Page Redesign
   ══════════════════════════════════════════ */
.thread-header { margin-bottom: 20px; }
.thread-breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  color: #8e9194;
  margin-bottom: 10px;
}
.thread-breadcrumb a { color: #8e9194; transition: color 0.15s; text-decoration: none; }
.thread-breadcrumb a:hover { color: #e60000; }
.thread-breadcrumb .sep { opacity: 0.3; }

.thread-title-bar {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}
.thread-title-bar h1 {
  font-size: 20px;
  font-weight: 700;
  color: #edeeef;
  letter-spacing: -0.02em;
  line-height: 1.3;
  flex: 1;
}
.thread-badges { display: flex; gap: 6px; margin-top: 8px; }
.thread-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 10px;
  font-weight: 600;
  padding: 3px 9px;
  border-radius: 10px;
  white-space: nowrap;
}
.thread-badge .badge-dot { width: 5px; height: 5px; border-radius: 50%; display: inline-block; }

.btn-reply-thread {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 9px 20px;
  background: linear-gradient(135deg, #c60000, #e60000);
  color: #fff;
  font-family: inherit;
  font-size: 12.5px;
  font-weight: 600;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  box-shadow: 0 3px 12px rgba(230,0,0,0.25);
  transition: all 0.2s;
  white-space: nowrap;
  flex-shrink: 0;
}
.btn-reply-thread:hover {
  box-shadow: 0 5px 20px rgba(230,0,0,0.35);
  transform: translateY(-1px);
  color: #fff;
  text-decoration: none;
}

.thread-pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
  font-size: 12px;
  color: #8e9194;
}
.thread-pagination-info { opacity: 0.7; }
.thread-pages { display: flex; gap: 4px; }
.thread-page-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 32px;
  height: 32px;
  padding: 0 8px;
  font-family: inherit;
  font-size: 11.5px;
  font-weight: 500;
  color: #8e9194;
  background: #1a1a1a;
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 7px;
  cursor: pointer;
  transition: all 0.15s;
  text-decoration: none;
}
.thread-page-btn:hover { background: #2a2824; color: #b8babc; text-decoration: none; }
.thread-page-btn.active {
  background: #e60000;
  color: #fff;
  border-color: #e60000;
  font-weight: 600;
}

.thread-post {
  display: flex;
  background: #1a1a1a;
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 10px;
  overflow: hidden;
  margin-bottom: 12px;
}
.thread-post.is-op { border-color: rgba(230,0,0,0.12); }

.thread-user {
  width: 140px;
  flex-shrink: 0;
  padding: 20px 16px;
  text-align: center;
  background: #191917;
  border-right: 1px solid rgba(255,255,255,0.06);
}
.thread-user-avatar {
  width: 72px; height: 72px;
  border-radius: 50%;
  overflow: hidden;
  margin: 0 auto 10px;
  border: 3px solid rgba(255,255,255,0.06);
  transition: border-color 0.2s;
}
.thread-post:hover .thread-user-avatar { border-color: rgba(255,255,255,0.12); }
.thread-user-avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.thread-user-name {
  font-size: 12.5px;
  font-weight: 600;
  margin-bottom: 4px;
  line-height: 1.3;
}
.thread-user-name a { transition: opacity 0.15s; text-decoration: none; }
.thread-user-name a:hover { opacity: 0.8; }
.thread-user-rank {
  display: inline-block;
  font-size: 9.5px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 8px;
  background: rgba(255,255,255,0.05);
  color: #8e9194;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}
.thread-user-rank.rank-admin { background: rgba(230,0,0,0.12); color: #e66; }
.thread-user-rank.rank-mod { background: rgba(76,175,80,0.12); color: #6c9; }
.thread-user-rank.rank-vip { background: rgba(255,193,7,0.12); color: #fc7; }

.thread-body {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
}
.thread-post-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 18px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  font-size: 11.5px;
  color: #8e9194;
}
.thread-post-time {
  display: flex;
  align-items: center;
  gap: 6px;
}
.thread-post-time i { font-size: 10px; opacity: 0.5; }
.thread-post-anchor {
  font-size: 11px;
  color: #8e9194;
  opacity: 0.4;
  transition: opacity 0.15s;
  text-decoration: none;
}
.thread-post-anchor:hover { opacity: 1; color: #e60000; }

.thread-post-content {
  flex: 1;
  padding: 18px;
  font-size: 13.5px;
  line-height: 1.75;
  color: #b8babc;
}
.thread-post-content p { margin-bottom: 12px; }
.thread-post-content p:last-child { margin-bottom: 0; }
.thread-post-content img { max-width: 100%; border-radius: 6px; margin: 8px 0; }
.thread-post-content a { color: #e60000; }
.thread-post-content a:hover { text-decoration: underline; }

.thread-quote {
  border-left: 3px solid rgba(230,0,0,0.4);
  background: rgba(255,255,255,0.02);
  border-radius: 0 8px 8px 0;
  padding: 12px 14px;
  margin-bottom: 14px;
  font-size: 12.5px;
  color: #8e9194;
  position: relative;
}
.thread-quote-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
  font-size: 11px;
  font-weight: 600;
  color: #b8babc;
}
.thread-quote-avatar {
  width: 20px; height: 20px;
  border-radius: 50%;
  overflow: hidden;
}
.thread-quote-avatar img { width: 100%; height: 100%; object-fit: cover; }
.thread-quote-expand {
  display: inline-block;
  margin-top: 6px;
  font-size: 10.5px;
  color: #e60000;
  cursor: pointer;
  opacity: 0.7;
  transition: opacity 0.15s;
}
.thread-quote-expand:hover { opacity: 1; }

.thread-actions {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 10px 18px;
  border-top: 1px solid rgba(255,255,255,0.06);
}
.thread-action-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 6px 12px;
  font-family: inherit;
  font-size: 11.5px;
  font-weight: 500;
  color: #8e9194;
  background: none;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.15s;
}
.thread-action-btn:hover { background: rgba(255,255,255,0.05); color: #b8babc; }
.thread-action-btn i { font-size: 12px; }
.thread-action-btn.liked { color: #e60000; }
.thread-action-btn.liked i { font-weight: 900; }
.thread-actions-right { margin-left: auto; display: flex; gap: 4px; }
.thread-action-btn.btn-edit:hover { color: #ffc107; }
.thread-action-btn.btn-delete:hover { color: #e63946; }

.thread-stats {
  background: #1a1a1a;
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 10px;
  margin-bottom: 12px;
  overflow: hidden;
}
.thread-stats-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 10px;
  font-family: inherit;
  font-size: 11px;
  font-weight: 500;
  color: #8e9194;
  background: none;
  border: none;
  cursor: pointer;
  width: 100%;
  transition: all 0.15s;
}
.thread-stats-toggle:hover { color: #b8babc; background: rgba(255,255,255,0.02); }
.thread-stats-toggle i { font-size: 9px; transition: transform 0.25s; }
.thread-stats-toggle.is-open i { transform: rotate(180deg); }

.thread-stats-grid {
  display: none;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 1px;
  background: rgba(255,255,255,0.06);
  border-top: 1px solid rgba(255,255,255,0.06);
}
.thread-stats-grid.is-open { display: grid; }
.thread-stat { padding: 14px 16px; background: #1a1a1a; text-align: center; }
.thread-stat-value { font-size: 18px; font-weight: 700; color: #edeeef; line-height: 1; margin-bottom: 4px; }
.thread-stat-label { font-size: 10px; font-weight: 500; color: #8e9194; text-transform: uppercase; letter-spacing: 0.5px; }

@media (max-width: 700px) {
  .thread-post { flex-direction: column; }
  .thread-user {
    width: 100%;
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    text-align: left;
    border-right: none;
    border-bottom: 1px solid rgba(255,255,255,0.06);
  }
  .thread-user-avatar { width: 40px; height: 40px; margin: 0; }
  .thread-user-name { margin-bottom: 0; }
  .thread-title-bar { flex-direction: column; gap: 10px; }
  .thread-title-bar h1 { font-size: 17px; }
  .thread-stats-grid { grid-template-columns: repeat(3, 1fr); }
}

/* ── End Discussions/Thread ── */

/* ══════════════════════════════════════════
   Redesigned Modals (Thread/Reply/Edit)
   ══════════════════════════════════════════ */
.os-modal-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.7);
  z-index: 9000;
  display: none;
  align-items: flex-start;
  justify-content: center;
  padding: 80px 20px 20px;
  backdrop-filter: blur(4px);
  overflow-y: auto;
}
.os-modal-overlay.is-open { display: flex; }
.os-modal {
  background: #1a1a1a;
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 12px;
  width: 100%; max-width: 720px;
  max-height: calc(100vh - 40px);
  display: flex; flex-direction: column;
  box-shadow: 0 20px 60px rgba(0,0,0,0.6);
  animation: os-modal-in 0.3s cubic-bezier(0.34,1.56,0.64,1);
}
@keyframes os-modal-in { from { opacity:0; transform:scale(0.95) translateY(10px); } to { opacity:1; transform:scale(1) translateY(0); } }
.os-modal-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 22px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.os-modal-header h3, .os-modal-header h5 { font-size: 16px; font-weight: 600; color: #edeeef; margin: 0; }
.os-modal-close {
  background: none; border: none; color: #8e9194; font-size: 18px;
  cursor: pointer; padding: 4px 8px; border-radius: 6px; transition: all 0.15s;
}
.os-modal-close:hover { color: #b8babc; background: rgba(255,255,255,0.05); }
.os-modal-body { flex: 1; overflow-y: auto; padding: 22px; }
.os-modal-body::-webkit-scrollbar { width: 4px; }
.os-modal-body::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 2px; }
.os-modal-footer {
  display: flex; align-items: center; justify-content: flex-end; gap: 10px;
  padding: 16px 22px;
  border-top: 1px solid rgba(255,255,255,0.06);
}
.os-modal-footer .modal-err, .os-modal-footer .threaderr, .os-modal-footer .editposterr {
  color: #e63946; font-size: 11.5px; margin-right: auto;
}

/* Inline preview panel under the new-thread editor. Sized to match the
   visual weight of a rendered thread post so the preview = final render. */
.os-thread-preview {
  margin-top: 12px;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 6px;
  background: rgba(255,255,255,0.02);
  overflow: hidden;
}
.os-thread-preview-head {
  font-size: 11px; font-weight: 700; color: #8e9194;
  text-transform: uppercase; letter-spacing: 0.5px;
  padding: 8px 14px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  background: rgba(255,255,255,0.02);
}
.os-thread-preview-body {
  padding: 14px;
  color: #d4d6d9; font-size: 14px; line-height: 1.6;
  word-wrap: break-word; overflow-wrap: anywhere;
}
.os-thread-preview-body img { max-width: 100%; height: auto; }

.os-form-group { margin-bottom: 18px; }
.os-form-label {
  display: block; font-size: 11.5px; font-weight: 600; color: #b8babc;
  margin-bottom: 6px; text-transform: uppercase; letter-spacing: 0.5px;
}
.os-form-input, .os-modal .form-control {
  width: 100%; padding: 10px 14px;
  background: #2a2824; border: 1px solid rgba(255,255,255,0.06); border-radius: 8px;
  color: #edeeef; font-family: inherit; font-size: 13px; outline: none; transition: border-color 0.2s;
}
.os-form-input:focus, .os-modal .form-control:focus { border-color: rgba(230,0,0,0.3); box-shadow: none; }
.os-form-input::placeholder, .os-modal .form-control::placeholder { color: #8e9194; opacity: 0.5; }
.os-form-hint { font-size: 10.5px; color: #8e9194; margin-top: 4px; }
.os-form-hint .count.warn { color: #e63946; }

.os-pill-group { display: flex; gap: 6px; flex-wrap: wrap; }
.os-pill-option {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 6px 14px; font-size: 11.5px; font-weight: 500; font-family: inherit;
  border-radius: 20px; border: 1.5px solid transparent;
  background: rgba(255,255,255,0.04); color: #8e9194;
  cursor: pointer; transition: all 0.2s; user-select: none;
}
.os-pill-option:hover { background: rgba(255,255,255,0.07); color: #b8babc; }
.os-pill-option .pill-dot { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; display: inline-block; }
.os-pill-option.selected { color: #fff; font-weight: 600; }
.os-pill-option input[type="radio"] { display: none; }

.os-editor-toggle-btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 4px 12px; font-size: 10.5px; font-weight: 500; font-family: inherit;
  color: #8e9194; background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.06); border-radius: 6px;
  cursor: pointer; transition: all 0.15s; margin-bottom: 8px;
}
.os-editor-toggle-btn:hover { background: rgba(255,255,255,0.08); color: #b8babc; }

.os-btn-primary {
  padding: 10px 24px;
  background: linear-gradient(135deg, #c60000, #e60000);
  color: #fff; border: none; border-radius: 8px;
  font-family: inherit; font-size: 13px; font-weight: 600;
  cursor: pointer; box-shadow: 0 3px 12px rgba(230,0,0,0.25); transition: all 0.2s;
}
.os-btn-primary:hover { box-shadow: 0 5px 20px rgba(230,0,0,0.35); transform: translateY(-1px); }
.os-btn-primary:disabled { opacity: 0.5; cursor: not-allowed; }
.os-btn-ghost {
  padding: 10px 20px; background: none;
  border: 1px solid rgba(255,255,255,0.1); border-radius: 8px;
  color: #b8babc; font-family: inherit; font-size: 13px; font-weight: 500;
  cursor: pointer; transition: all 0.15s;
}
.os-btn-ghost:hover { background: rgba(255,255,255,0.05); border-color: rgba(255,255,255,0.15); }

.os-reply-to {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 14px; background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.06); border-radius: 8px;
  margin-bottom: 16px; font-size: 12px; color: #8e9194;
}
.os-reply-to-avatar { width: 24px; height: 24px; border-radius: 50%; overflow: hidden; }
.os-reply-to-avatar img { width: 100%; height: 100%; object-fit: cover; }

@media(max-width:600px) {
  .os-modal { max-width: 100%; border-radius: 10px; }
  .os-modal-body { padding: 16px; }
  .os-pill-option { padding: 5px 10px; font-size: 10.5px; }
}

/* ══════════════════════════════════════════
   News Page Redesign
   ══════════════════════════════════════════ */
.news-header { margin-bottom: 24px; }
.news-header h1 { font-size: 22px; font-weight: 700; color: #edeeef; letter-spacing: -0.02em; }
.news-header p { font-size: 13px; color: #8e9194; margin-top: 4px; }

.news-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-bottom: 24px; }
.news-card {
  display: block;
  background: #1a1a1a; border: 1px solid rgba(255,255,255,0.06);
  border-radius: 10px; overflow: hidden; transition: all 0.25s; text-decoration: none; color: inherit;
}
.news-card:hover { transform: translateY(-3px); box-shadow: 0 12px 32px rgba(0,0,0,0.4); border-color: rgba(255,255,255,0.1); text-decoration: none; color: inherit; }
.news-card-img { position: relative; aspect-ratio: 16/9; overflow: hidden; background: #111; }
.news-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.3s; }
.news-card:hover .news-card-img img { transform: scale(1.03); }
.news-card-badges { position: absolute; bottom: 10px; left: 10px; display: flex; gap: 6px; }
.news-card-badge { display: inline-flex; align-items: center; gap: 4px; font-size: 9.5px; font-weight: 600; padding: 3px 9px; border-radius: 8px; backdrop-filter: blur(8px); letter-spacing: 0.02em; }
.news-card-badge .badge-dot { width: 5px; height: 5px; border-radius: 50%; }
.news-card-badge-pinned { background: rgba(230,0,0,0.85); color: #fff; }
.news-card-body { padding: 16px; }
.news-card-title { font-size: 15px; font-weight: 600; color: #edeeef; line-height: 1.35; margin-bottom: 8px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.news-card:hover .news-card-title { color: #fff; }
.news-card-excerpt { font-size: 12px; color: #8e9194; line-height: 1.6; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; margin-bottom: 14px; }
.news-card-footer { display: flex; align-items: center; gap: 8px; font-size: 11px; color: #8e9194; }
.news-card-avatar { width: 22px; height: 22px; border-radius: 50%; overflow: hidden; border: 1.5px solid rgba(255,255,255,0.08); }
.news-card-avatar img { width: 100%; height: 100%; object-fit: cover; }
.news-card-date { margin-left: auto; font-size: 10.5px; opacity: 0.7; }

.news-pagination { display: flex; justify-content: center; gap: 4px; }

@media(max-width:860px) { .news-grid { grid-template-columns: repeat(2, 1fr); } }
@media(max-width:520px) { .news-grid { grid-template-columns: 1fr; } }

/* ══════════════════════════════════════════
   Unified News & Discussions page
   (extends .disc-* and .news-* above)
   ══════════════════════════════════════════ */

/* Breadcrumb shown when a filter is active (e.g., /news or ?type=news) */
.disc-crumbs {
  display:flex; align-items:center; gap:8px; flex-wrap:wrap;
  font-size:12px; color:#8e9194; margin-bottom:12px;
}
.disc-crumbs a { color:#8e9194; text-decoration:none; }
.disc-crumbs a:hover { color:#fff; text-decoration:none; }
.disc-crumb-sep { opacity:.5; font-size:10px; }
.disc-crumb-current { color:#fff; font-weight:600; }
.disc-clear-filter {
  margin-left:8px;
  display:inline-flex; align-items:center; gap:5px;
  padding:3px 9px; border-radius:6px;
  background:rgba(230,0,0,0.12); color:#ff6b6b;
  font-size:11px; font-weight:600;
  border:1px solid rgba(230,0,0,0.25);
}
.disc-clear-filter:hover { background:rgba(230,0,0,0.2); color:#fff; text-decoration:none; }

/* Small "Filtered" chip next to the page H1 */
.disc-filter-chip {
  display:inline-flex; align-items:center; gap:6px;
  margin-left:10px; vertical-align:middle;
  padding:4px 10px; border-radius:6px;
  background:rgba(230,0,0,0.1); border:1px solid rgba(230,0,0,0.25);
  font-size:11px; font-weight:600; color:#ff6b6b;
  letter-spacing:.06em; text-transform:uppercase;
}
.disc-filter-chip .badge-dot { width:6px; height:6px; border-radius:50%; }

/* Featured news strip — generic, reuses .news-grid + .news-card */
.news-featured { margin-bottom:32px; }
.section-strip-head { display:flex; align-items:center; gap:12px; margin-bottom:14px; }
.section-strip-kicker {
  display:inline-flex; align-items:center; gap:8px;
  font-size:10.5px; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:#8e9194;
}
.section-strip-kicker .strip-dot { width:6px; height:6px; border-radius:50%; background:#e60000; box-shadow:0 0 8px rgba(230,0,0,.5); }
.section-strip-more { margin-left:auto; font-size:11px; color:#8e9194; text-decoration:none; display:inline-flex; align-items:center; gap:6px; }
.section-strip-more:hover { color:#fff; text-decoration:none; }
.news-featured .news-grid { grid-template-columns:repeat(3, 1fr); margin-bottom:0; }
@media(max-width:860px){ .news-featured .news-grid { grid-template-columns:repeat(2, 1fr); } }
@media(max-width:520px){ .news-featured .news-grid { grid-template-columns:1fr; } }

/* Sort dropdown — extends .disc-filters with a right-aligned control */
.disc-filters .disc-filter-row:last-child { position:relative; }
.disc-sort {
  margin-left:auto;
  display:inline-flex; align-items:center; gap:8px;
  padding:6px 14px;
  background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.08);
  border-radius:8px; cursor:pointer; font-size:12px; color:#b8babc;
  transition:all .15s; position:relative;
  user-select:none;
}
.disc-sort:hover { color:#fff; border-color:rgba(255,255,255,0.15); background:rgba(255,255,255,0.07); }
.disc-sort i { font-size:9px; opacity:.7; }
.disc-sort b { color:#fff; font-weight:600; }
.disc-sort-menu {
  position:absolute; right:0; top:calc(100% + 6px);
  background:#141414; border:1px solid rgba(255,255,255,0.08);
  border-radius:8px; padding:6px;
  display:none; min-width:200px; z-index:50;
  box-shadow:0 10px 30px rgba(0,0,0,.5);
}
.disc-sort.is-open .disc-sort-menu { display:block; }
.disc-sort-menu a {
  display:block; padding:8px 12px; font-size:12px;
  color:#b8babc; text-decoration:none; border-radius:6px;
}
.disc-sort-menu a:hover { background:rgba(255,255,255,0.05); color:#fff; text-decoration:none; }
.disc-sort-menu a.is-active { background:rgba(230,0,0,0.12); color:#fff; }

/* News row variant inside the unified list */
.disc-row.is-news .disc-avatar {
  width:64px; height:64px; border-radius:8px; border:1px solid rgba(255,255,255,0.06);
}
.disc-row.is-news .disc-avatar img { object-fit:cover; }
.disc-row-excerpt {
  font-size:12px; color:#8e9194; margin:4px 0 0;
  line-height:1.5;
  display:-webkit-box; -webkit-line-clamp:1; -webkit-box-orient:vertical; overflow:hidden;
}
.disc-row-author {
  display:inline-flex; align-items:center; gap:6px;
  font-size:11px; color:#8e9194;
}
.disc-row-author img { width:18px; height:18px; border-radius:50%; }
.disc-row-author b { color:#b8babc; font-weight:500; }

/* Stronger red treatment so news stands out in the mixed list */
.disc-badge-news {
  background:linear-gradient(135deg, rgba(230,0,0,0.18), rgba(230,0,0,0.08));
  color:#ff6b6b;
  border:1px solid rgba(230,0,0,0.25);
  font-weight:700; letter-spacing:.06em;
}
.disc-badge-news .badge-dot { background:#e60000; }

/* ══════════════════════════════════════════
   Genres Page Redesign
   ══════════════════════════════════════════ */
.genres-header { margin-bottom: 24px; }
.genres-header h1 { font-size: 22px; font-weight: 700; color: #edeeef; letter-spacing: -0.02em; }
.genres-header p { font-size: 13px; color: #8e9194; margin-top: 4px; }

.genres-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.genre-card {
  display: flex; align-items: center; gap: 12px;
  padding: 16px 18px; background: #1a1a1a;
  border: 1px solid rgba(255,255,255,0.06); border-radius: 10px;
  border-left: 3px solid transparent;
  transition: all 0.2s; cursor: pointer; text-decoration: none; color: inherit;
}
.genre-card:hover { background: #2a2824; transform: translateX(3px); border-color: rgba(255,255,255,0.1); text-decoration: none; color: inherit; }
.genre-card-icon {
  width: 36px; height: 36px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; flex-shrink: 0; transition: transform 0.2s;
}
.genre-card:hover .genre-card-icon { transform: scale(1.1); }
.genre-card-info { flex: 1; min-width: 0; }
.genre-card-name { font-size: 13.5px; font-weight: 600; color: #edeeef; line-height: 1.2; }
.genre-card:hover .genre-card-name { color: #fff; }
.genre-card-count { font-size: 10.5px; color: #8e9194; margin-top: 2px; }
.genre-card-arrow { color: #8e9194; font-size: 11px; opacity: 0; transition: all 0.2s; transform: translateX(-4px); }
.genre-card:hover .genre-card-arrow { opacity: 1; transform: translateX(0); }

@media(max-width:860px) { .genres-grid { grid-template-columns: repeat(3, 1fr); } }
@media(max-width:600px) { .genres-grid { grid-template-columns: repeat(2, 1fr); } }
@media(max-width:400px) { .genres-grid { grid-template-columns: 1fr; } }

/* ══════════════════════════════════════════
   New Titles Page Redesign
   ══════════════════════════════════════════ */
.titles-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 24px; flex-wrap: wrap; gap: 10px; }
.titles-header h1 { font-size: 22px; font-weight: 700; color: #edeeef; letter-spacing: -0.02em; }
.titles-season {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 14px; background: rgba(230,0,0,0.1);
  border: 1px solid rgba(230,0,0,0.2); border-radius: 20px;
  font-size: 11.5px; font-weight: 600; color: #e66;
}
.titles-season i { font-size: 10px; }

.titles-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); gap: 14px; margin-bottom: 24px; }
.title-card { position: relative; cursor: pointer; display: block; text-decoration: none; color: inherit; }
.title-card:hover { text-decoration: none; color: inherit; }
.title-card-img {
  position: relative; aspect-ratio: 2/3; border-radius: 6px; overflow: hidden;
  background: #111; border: 2px solid transparent; transition: all 0.25s;
  max-height: 360px;
}
.title-card:hover .title-card-img { border-color: #e60000; transform: translateY(-3px); box-shadow: 0 8px 24px rgba(0,0,0,0.4); }
.title-card-img img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.3s; }
.title-card:hover .title-card-img img { transform: scale(1.04); }
.title-card-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.85) 0%, transparent 50%);
  opacity: 0; transition: opacity 0.25s;
  display: flex; flex-direction: column; justify-content: flex-end; padding: 10px;
}
.title-card:hover .title-card-overlay { opacity: 1; }
.title-card-overlay-genre { font-size: 10px; color: rgba(255,255,255,0.7); line-height: 1.4; }
.title-card-name {
  display: block; font-size: 11.5px; font-weight: 600; color: #edeeef;
  margin-top: 8px; line-height: 1.3;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; transition: color 0.15s;
}
.title-card:hover .title-card-name { color: #fff; }
.title-card-genre { font-size: 10.5px; color: #8e9194; margin-top: 3px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; display: block; }

.titles-pagination { display: flex; justify-content: center; gap: 4px; }
.titles-page-btn {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 34px; height: 34px; padding: 0 10px;
  font-family: inherit; font-size: 12px; font-weight: 500;
  color: #8e9194; background: #1a1a1a;
  border: 1px solid rgba(255,255,255,0.06); border-radius: 8px;
  cursor: pointer; transition: all 0.15s; text-decoration: none;
}
.titles-page-btn:hover { background: #2a2824; color: #b8babc; text-decoration: none; }
.titles-page-btn.active { background: #e60000; color: #fff; border-color: #e60000; font-weight: 600; }

@media(max-width:400px) { .titles-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; } }

/* ── End Modals/News/Genres/Titles ── */

/* ══════════════════════════════════════════
   Title Detail Page Redesign
   ══════════════════════════════════════════ */
.tp-hero{display:flex;gap:28px;margin-bottom:28px}
.tp-cover{width:240px;flex-shrink:0}
.tp-cover-img{width:100%;aspect-ratio:2/3;border-radius:10px;overflow:hidden;box-shadow:0 8px 30px rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.06)}
.tp-cover-img img{width:100%;height:100%;object-fit:cover;display:block}
.tp-cover-stats{display:flex;justify-content:center;gap:20px;margin-top:14px;font-size:11px;color:#8e9194}
.tp-cover-stats .stat{display:flex;align-items:center;gap:5px}
.tp-cover-stats .stat i{font-size:12px}
.tp-cover-stats .stat.liked i{color:#e60000}
.tp-info{flex:1;min-width:0}
.tp-type-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:10px;font-size:10px;font-weight:600;background:rgba(230,0,0,.12);color:#e66;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}
.tp-title{font-size:24px;font-weight:700;color:#edeeef;line-height:1.25;margin-bottom:6px}
.tp-alt-titles{font-size:12px;color:#8e9194;margin-bottom:14px;font-style:italic}
.tp-meta-grid{display:grid;grid-template-columns:auto 1fr;gap:4px 16px;font-size:12.5px;margin-bottom:18px}
.tp-meta-label{color:#8e9194;font-weight:500}
.tp-meta-value{color:#b8babc}
.tp-meta-value a{color:#b8babc;transition:color .15s;text-decoration:none}
.tp-meta-value a:hover{color:#e60000}
.tp-genre-pills{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:16px}
.tp-genre-pills a,.tp-genre-pill{padding:4px 12px;border-radius:14px;font-size:10.5px;font-weight:500;background:rgba(255,255,255,.05);color:#b8babc;border:1px solid rgba(255,255,255,.08);transition:all .15s;text-decoration:none;display:inline-block}
.tp-genre-pills a:hover,.tp-genre-pill:hover{background:rgba(230,0,0,.1);border-color:rgba(230,0,0,.2);color:#fff;text-decoration:none}
.tp-rating{display:flex;align-items:center;gap:8px;margin-bottom:18px}
.tp-rating-stars{display:flex;gap:2px;color:#ffc107;font-size:14px}
.tp-rating-stars .empty{color:#444}
.tp-rating-score{font-size:18px;font-weight:700;color:#edeeef}
.tp-rating-count{font-size:11px;color:#8e9194}
.tp-actions{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}
.tp-action-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;font-family:inherit;font-size:12px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s;border:none;text-decoration:none}
.tp-action-btn:hover{text-decoration:none}
.tp-action-btn.primary{background:linear-gradient(135deg,#c60000,#e60000);color:#fff;box-shadow:0 3px 12px rgba(230,0,0,.25)}
.tp-action-btn.primary:hover{box-shadow:0 5px 20px rgba(230,0,0,.35);transform:translateY(-1px);color:#fff}
.tp-action-btn.secondary{background:rgba(255,255,255,.06);color:#b8babc;border:1px solid rgba(255,255,255,.1)}
.tp-action-btn.secondary:hover{background:rgba(255,255,255,.1);color:#fff}
.tp-synopsis{margin-bottom:20px}
.tp-synopsis h3{font-size:14px;font-weight:600;color:#edeeef;margin-bottom:8px}
.tp-synopsis p{font-size:13px;color:#b8babc;line-height:1.8}
.tp-trailer{margin-bottom:22px}
.tp-trailer h3{font-size:14px;font-weight:600;color:#edeeef;margin-bottom:10px;display:flex;align-items:center;gap:8px}
.tp-trailer h3 i{color:#e60000}
/* Compact clickable thumbnail (replaces the old full-width 16:9 inline embed) */
.tp-trailer-thumb{position:relative;display:inline-block;width:280px;height:158px;padding:0;border:0;border-radius:8px;overflow:hidden;cursor:pointer;background:#000;box-shadow:0 4px 16px rgba(0,0,0,0.4);transition:transform .15s ease}
.tp-trailer-thumb:hover{transform:translateY(-2px)}
.tp-trailer-thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;transition:opacity .15s}
.tp-trailer-thumb:hover img{opacity:.75}
.tp-trailer-thumb .tp-trailer-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:54px;height:54px;border-radius:50%;background:rgba(230,0,0,0.9);display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px;pointer-events:none;transition:transform .15s ease,background .15s}
.tp-trailer-thumb .tp-trailer-play i{margin-left:3px}
.tp-trailer-thumb:hover .tp-trailer-play{transform:translate(-50%,-50%) scale(1.1);background:#e60000}
.tp-trailer-thumb .tp-trailer-label{position:absolute;left:0;right:0;bottom:0;padding:6px 10px;background:linear-gradient(to top,rgba(0,0,0,0.85),transparent);color:#fff;font-size:12px;font-weight:600;letter-spacing:.3px;text-align:left;pointer-events:none}
/* Modal (full-screen backdrop, centered 16:9 player) */
.tp-trailer-modal{position:fixed;inset:0;background:rgba(0,0,0,0.85);display:none;align-items:center;justify-content:center;z-index:9999;padding:20px}
.tp-trailer-modal.is-open{display:flex}
.tp-trailer-modal-content{position:relative;width:100%;max-width:720px;aspect-ratio:16/9;background:#000;border-radius:8px;overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,0.6)}
.tp-trailer-modal-body,.tp-trailer-modal-body iframe,.tp-trailer-modal-body video{position:absolute;inset:0;width:100%;height:100%;border:0;background:#000}
.tp-trailer-modal-close{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:50%;background:rgba(0,0,0,0.7);border:0;color:#fff;font-size:24px;line-height:1;cursor:pointer;z-index:1;display:flex;align-items:center;justify-content:center;transition:background .15s}
.tp-trailer-modal-close:hover{background:rgba(230,0,0,0.85)}
.tp-related{margin-bottom:0}
.tp-related h3{font-size:14px;font-weight:600;color:#edeeef;margin-bottom:8px}
.tp-related-item{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:12px;list-style:none}
.tp-related-type{font-size:10px;font-weight:600;color:#8e9194;text-transform:uppercase;min-width:60px}
.tp-related-link{color:#b8babc;transition:color .15s;text-decoration:none}
.tp-related-link:hover{color:#e60000}
.tp-episodes{background:#1a1a1a;border:1px solid rgba(255,255,255,.06);border-radius:10px;overflow:hidden;margin-bottom:24px}
.tp-ep-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid rgba(255,255,255,.06)}
.tp-ep-header h3{font-size:14px;font-weight:600;color:#edeeef;margin:0}
.tp-ep-sort{display:flex;gap:4px}
.tp-ep-sort button{background:none;border:1px solid rgba(255,255,255,.08);border-radius:6px;color:#8e9194;font-size:11px;padding:4px 10px;cursor:pointer;font-family:inherit;transition:all .15s}
.tp-ep-sort button:hover{color:#b8babc;background:rgba(255,255,255,.05)}
.tp-ep-sort button.active{color:#e60000;border-color:rgba(230,0,0,.3)}
.tp-ep-labels{display:flex;align-items:center;gap:12px;padding:8px 18px;font-size:10px;font-weight:600;color:#8e9194;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid rgba(255,255,255,.06);background:rgba(255,255,255,.01)}
.tp-ep-labels span:first-child{width:36px;text-align:center;flex-shrink:0}
.tp-ep-labels .l-title{flex:1}
.tp-ep-labels .l-uploader{width:80px;text-align:center}
.tp-ep-labels .l-date{width:90px;text-align:center}
.tp-ep-labels .l-views{width:50px;text-align:right}
.tp-ep-labels .l-status{width:24px}
.tp-ep-labels .l-play{width:28px}
.tp-ep-labels .l-unwatch{width:28px}
.tp-ep-row{display:flex;align-items:center;gap:12px;padding:10px 18px;border-bottom:1px solid rgba(255,255,255,.06);transition:background .15s;cursor:pointer;color:inherit;text-decoration:none}
.tp-ep-row:last-child{border-bottom:none}
.tp-ep-row:hover{background:#2a2824;text-decoration:none;color:inherit}
.tp-ep-num{width:36px;font-size:13px;font-weight:600;color:#8e9194;text-align:center;flex-shrink:0}
.tp-ep-row:hover .tp-ep-num{color:#e60000}
.tp-ep-title{flex:1;min-width:0}
.tp-ep-title span,.tp-ep-title a{font-size:13px;color:#b8babc;text-decoration:none}
.tp-ep-row:hover .tp-ep-title span,.tp-ep-row:hover .tp-ep-title a{color:#fff}
.tp-ep-progress{display:inline-block;width:60px;height:3px;background:rgba(255,255,255,.1);border-radius:2px;vertical-align:middle;margin-left:6px;position:relative;top:-1px;overflow:hidden}
.tp-ep-progress-bar{display:block;height:100%;background:#e60000;border-radius:2px}
.tp-ep-uploader{font-size:11px;color:#8e9194;width:80px;text-align:center;flex-shrink:0}
.tp-ep-date{font-size:11px;color:#8e9194;width:90px;text-align:center;flex-shrink:0}
.tp-ep-views{font-size:11px;color:#8e9194;width:50px;text-align:right;flex-shrink:0}
.tp-ep-watched{width:24px;flex-shrink:0;text-align:center;font-size:14px;color:#4caf50}
.tp-ep-play{width:28px;flex-shrink:0;text-align:center;font-size:14px;color:#8e9194;opacity:0;transition:opacity .15s}
.tp-ep-row:hover .tp-ep-play{opacity:1;color:#e60000}
.tp-ep-unwatch{width:28px;flex-shrink:0;text-align:center;font-size:13px;color:#8e9194;opacity:0;transition:opacity .15s,color .15s;cursor:pointer}
.tp-ep-row:hover .tp-ep-unwatch{opacity:1}
.tp-ep-unwatch:hover{color:#e60000}
.tp-ep-unwatch[style*="hidden"]{pointer-events:none}
.tp-similar{margin-bottom:24px}
.tp-similar h3{font-size:14px;font-weight:600;color:#edeeef;margin-bottom:14px}
.tp-similar-grid{display:flex;gap:14px;overflow-x:auto;padding-bottom:8px}
.tp-similar-grid::-webkit-scrollbar{height:4px}
.tp-similar-grid::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:2px}
.tp-similar-card{flex:0 0 100px;cursor:pointer;text-decoration:none;color:inherit}
.tp-similar-card:hover{text-decoration:none}
.tp-similar-card-img{aspect-ratio:2/3;border-radius:6px;overflow:hidden;border:2px solid transparent;transition:all .2s;max-height:170px}
.tp-similar-card:hover .tp-similar-card-img{border-color:#e60000;transform:translateY(-2px)}
.tp-similar-card-img img{width:100%;height:100%;object-fit:cover;display:block}
.tp-similar-card-name{font-size:11px;font-weight:500;color:#b8babc;margin-top:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
@media(max-width:700px){.tp-hero{flex-direction:column;align-items:center;text-align:center;gap:20px}.tp-cover{width:180px}.tp-genre-pills{justify-content:center}.tp-actions{justify-content:center}.tp-ep-uploader,.tp-ep-date,.tp-ep-labels .l-uploader,.tp-ep-labels .l-date{display:none}}

/* ══════════════════════════════════════════
   Watch Page Redesign
   ══════════════════════════════════════════ */
.wp-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:8px}
.wp-breadcrumb{display:flex;align-items:center;gap:8px;font-size:12px;color:#8e9194}
.wp-breadcrumb a{color:#8e9194;transition:color .15s;text-decoration:none}
.wp-breadcrumb a:hover{color:#e60000}
.wp-breadcrumb .sep{opacity:.3;font-size:8px}
.wp-breadcrumb .current{color:#edeeef;font-weight:500}
.wp-nav{display:flex;gap:6px}
.wp-nav-btn{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;font-family:inherit;font-size:11.5px;font-weight:500;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.06);border-radius:7px;color:#b8babc;cursor:pointer;transition:all .15s;text-decoration:none}
.wp-nav-btn:hover{background:rgba(255,255,255,.08);color:#fff;text-decoration:none}
.wp-nav-btn.primary{background:linear-gradient(135deg,#c60000,#e60000);color:#fff;border-color:transparent;box-shadow:0 2px 8px rgba(230,0,0,.2)}
.wp-nav-btn.primary:hover{color:#fff}
.wp-nav-btn i{font-size:10px}
.wp-main{display:flex;gap:14px;margin-bottom:20px}
.wp-player-col{flex:1;min-width:0}
.wp-sidebar-col{width:280px;flex-shrink:0}
.wp-video-wrap{border-radius:10px;overflow:hidden;margin-bottom:12px;background:#000}
.wp-video-wrap .video-js{border-radius:10px}
.wp-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:14px 16px;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.05);border-radius:10px;margin-top:12px}
.wp-action-btn{display:inline-flex;align-items:center;gap:5px;padding:8px 14px;font-family:inherit;font-size:11.5px;font-weight:500;border-radius:7px;cursor:pointer;transition:all .15s;border:none;text-decoration:none}
.wp-action-btn:hover{text-decoration:none}
.wp-action-btn.wl{background:#e60000;color:#fff}
.wp-action-btn.wl:hover{background:#ff1a1a;color:#fff}
.wp-action-btn.ghost{background:rgba(255,255,255,.05);color:#b8babc;border:1px solid rgba(255,255,255,.06)}
.wp-action-btn.ghost:hover{background:rgba(255,255,255,.08);color:#fff}
.wp-action-btn i{font-size:12px}
.wp-action-btn .badge-count{background:rgba(255,255,255,.2);padding:1px 6px;border-radius:8px;font-size:10px;margin-left:2px}
.wp-uploader{margin-left:auto;font-size:11px;color:#8e9194}
.wp-uploader a{color:#b8babc;font-weight:500;transition:color .15s;text-decoration:none}
.wp-uploader a:hover{color:#e60000}
.wp-ep-panel{background:#1a1a1a;border:1px solid rgba(255,255,255,.06);border-radius:10px;overflow:hidden;height:fit-content;max-height:calc(100vh - 120px);display:flex;flex-direction:column}
.wp-ep-panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0}
.wp-ep-panel-header h4{font-size:13px;font-weight:600;color:#edeeef;margin:0}
.wp-ep-panel-header .ep-count{font-size:11px;color:#8e9194}
.wp-ep-list{overflow-y:auto;flex:1}
.wp-ep-list::-webkit-scrollbar{width:3px}
.wp-ep-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:2px}
.wp-ep-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid rgba(255,255,255,.06);transition:background .15s;cursor:pointer;text-decoration:none;color:inherit}
.wp-ep-item:last-child{border-bottom:none}
.wp-ep-item:hover{background:#2a2824;text-decoration:none;color:inherit}
.wp-ep-item.active{background:rgba(230,0,0,.06);border-left:3px solid #e60000}
.wp-ep-item-num{font-size:12px;font-weight:600;color:#8e9194;min-width:24px}
.wp-ep-item.active .wp-ep-item-num{color:#e60000}
.wp-ep-item-info{flex:1;min-width:0}
.wp-ep-item-name{font-size:12px;color:#b8babc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wp-ep-item.active .wp-ep-item-name{color:#fff;font-weight:500}
.wp-ep-item-progress{height:2px;background:rgba(255,255,255,.06);border-radius:1px;margin-top:4px}
.wp-ep-item-progress-bar{height:100%;background:#e60000;border-radius:1px}
.wp-ep-item-watched{font-size:12px;color:#4caf50;flex-shrink:0}
.wp-ep-item-playing{font-size:9px;color:#e60000;flex-shrink:0;display:none}
.wp-ep-item.active .wp-ep-item-playing{display:block}
.wp-comments{background:#1a1a1a;border:1px solid rgba(255,255,255,.06);border-radius:10px;overflow:hidden}
.wp-comments-header{padding:14px 18px;border-bottom:1px solid rgba(255,255,255,.06)}
.wp-comments-header h4{font-size:13px;font-weight:600;color:#edeeef;margin:0}
.wp-comment-form{padding:14px 18px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;gap:10px}
.wp-comment-avatar{width:32px;height:32px;border-radius:50%;overflow:hidden;flex-shrink:0}
.wp-comment-avatar img{width:100%;height:100%;object-fit:cover}
.wp-comment-input-wrap{flex:1;display:flex;flex-direction:column;gap:8px}
.wp-comment-input{width:100%;padding:10px 14px;background:#2a2824;border:1px solid rgba(255,255,255,.06);border-radius:8px;color:#edeeef;font-family:inherit;font-size:12.5px;resize:vertical;min-height:60px;outline:none;transition:border-color .2s}
.wp-comment-input:focus{border-color:rgba(230,0,0,.3)}
.wp-comment-input::placeholder{color:#8e9194;opacity:.5}
.wp-comment-btns{display:flex;gap:6px;justify-content:flex-end}
.wp-comment-btn{padding:6px 14px;font-family:inherit;font-size:11px;font-weight:600;border-radius:6px;cursor:pointer;transition:all .15s;border:none}
.wp-comment-btn.spoiler{background:rgba(255,255,255,.05);color:#8e9194;border:1px solid rgba(255,255,255,.06)}
.wp-comment-btn.spoiler:hover{color:#b8babc}
.wp-comment-btn.submit{background:#e60000;color:#fff}
.wp-comment-btn.submit:hover{background:#ff1a1a}
.wp-comment-list{max-height:500px;overflow-y:auto}
.wp-comment-list::-webkit-scrollbar{width:3px}
.wp-comment-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:2px}
.wp-comment-item{display:flex;gap:10px;padding:12px 18px;border-bottom:1px solid rgba(255,255,255,.06)}
.wp-comment-item:last-child{border-bottom:none}
.wp-comment-item-avatar{width:28px;height:28px;border-radius:50%;overflow:hidden;flex-shrink:0;margin-top:2px}
.wp-comment-item-avatar img{width:100%;height:100%;object-fit:cover}
.wp-comment-item-body{flex:1;min-width:0}
.wp-comment-item-header{display:flex;align-items:center;gap:8px;margin-bottom:3px}
.wp-comment-item-name{font-size:12px;font-weight:600}
.wp-comment-item-name a{text-decoration:none;color:inherit}
.wp-comment-item-name a:hover{opacity:.8}
.wp-comment-item-time{font-size:10px;color:#8e9194;margin-left:auto}
.wp-comment-item-text{font-size:12.5px;color:#b8babc;line-height:1.6}
@media(max-width:900px){.wp-main{flex-direction:column}.wp-sidebar-col{width:100%}.wp-ep-panel{max-height:300px}}
@media(max-width:600px){.wp-action-btn{padding:6px 10px;font-size:10.5px}.wp-uploader{width:100%;margin-left:0;margin-top:4px}}

/* Episode title subtitle on title page list */
.tp-ep-ep-title{display:block;font-size:11px;color:#8e9194;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* Episode info block below player */
.wp-ep-info{margin-top:12px;padding:16px 18px;background:linear-gradient(135deg,rgba(230,0,0,.06) 0%,rgba(255,255,255,.02) 60%);border:1px solid rgba(255,255,255,.06);border-radius:10px;border-left:3px solid #e60000}
.wp-ep-info-head{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.wp-ep-info-num{display:inline-flex;align-items:center;font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:#fff;background:#e60000;padding:3px 9px;border-radius:4px;flex:none}
.wp-ep-info-title{margin:0;font-size:16px;font-weight:600;color:#edeeef;line-height:1.35;letter-spacing:.1px}
.wp-ep-synopsis{margin-top:12px;font-size:13px;color:#a8aaad}
.wp-ep-synopsis summary{display:inline-flex;align-items:center;gap:8px;cursor:pointer;color:#b8babc;font-size:12px;font-weight:600;letter-spacing:.3px;text-transform:uppercase;user-select:none;outline:none;padding:6px 10px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:6px;list-style:none;transition:background .15s,color .15s}
.wp-ep-synopsis summary::-webkit-details-marker{display:none}
.wp-ep-synopsis summary:hover{background:rgba(255,255,255,.08);color:#edeeef}
.wp-ep-synopsis summary i.fas.fa-align-left{font-size:11px;color:#e60000}
.wp-ep-synopsis-chev{font-size:10px;transition:transform .2s ease;margin-left:2px}
.wp-ep-synopsis[open] .wp-ep-synopsis-chev{transform:rotate(180deg)}
.wp-ep-synopsis p{margin:12px 2px 2px;padding:10px 12px;line-height:1.65;color:#c8cacc;background:rgba(0,0,0,.18);border-radius:6px;border-left:2px solid rgba(230,0,0,.4)}

/* ── End Title/Watch Pages ── */

/* ══════════════════════════════════════════
   Sidebar Redesign
   ══════════════════════════════════════════ */
.os-widget{background:#1a1a1a;border:1px solid rgba(255,255,255,0.06);border-radius:10px;padding:16px;margin-bottom:14px}
.os-widget-title{display:flex;align-items:center;justify-content:space-between;font-size:12px;font-weight:600;color:#edeeef;margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}
.os-widget-title a{font-size:10px;color:#8e9194;font-weight:500;text-transform:none;letter-spacing:0;transition:color .15s;text-decoration:none}
.os-widget-title a:hover{color:#e60000}
.os-don-goal{margin-bottom:10px}
.os-don-month{font-size:10.5px;color:#8e9194;margin-bottom:8px}
.os-don-bar{height:8px;background:rgba(255,255,255,0.06);border-radius:4px;overflow:hidden;margin-bottom:6px}
.os-don-bar-fill{height:100%;background:linear-gradient(90deg,#c60000,#e60000);border-radius:4px;transition:width .5s}
.os-don-amounts{display:flex;justify-content:space-between;font-size:10px;color:#8e9194}
.os-don-amounts .raised{color:#edeeef;font-weight:600}
.os-don-cta{display:block;text-align:center;margin-top:10px;padding:8px;background:rgba(230,0,0,0.08);border:1px solid rgba(230,0,0,0.15);border-radius:8px;font-size:11px;font-weight:600;color:#e66;transition:all .15s;cursor:pointer;text-decoration:none}
.os-don-cta:hover{background:rgba(230,0,0,0.15);color:#fff;text-decoration:none}
.os-supporter{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid rgba(255,255,255,0.06)}
.os-supporter:last-child{border-bottom:none}
.os-supporter-avy{width:32px;height:32px;border-radius:50%;overflow:hidden;flex-shrink:0;border:1.5px solid rgba(255,255,255,0.08)}
.os-supporter-avy img{width:100%;height:100%;object-fit:cover}
.os-supporter-info{flex:1;min-width:0}
.os-supporter-name{font-size:11.5px;font-weight:600;color:#b8babc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.os-supporter-name a{color:inherit;text-decoration:none}
.os-supporter-name a:hover{color:#e60000}
.os-supporter-tier{display:inline-flex;align-items:center;gap:3px;font-size:9px;font-weight:600;padding:1px 6px;border-radius:6px;margin-top:2px}
.os-supporter-amount{font-size:11px;font-weight:600;color:#4caf50;flex-shrink:0}
.os-genre-cloud{display:flex;flex-wrap:wrap;gap:6px}
.os-genre-tag{padding:4px 10px;border-radius:12px;font-size:10.5px;font-weight:500;background:rgba(255,255,255,0.04);color:#b8babc;border:1px solid rgba(255,255,255,0.06);transition:all .15s;text-decoration:none}
.os-genre-tag:hover{background:rgba(230,0,0,0.1);border-color:rgba(230,0,0,0.2);color:#fff;text-decoration:none}
.os-feed-item{display:flex;gap:8px;padding:8px 0;border-bottom:1px solid rgba(255,255,255,0.06);font-size:11px}
.os-feed-item:last-child{border-bottom:none}
.os-feed-avy{width:24px;height:24px;border-radius:50%;overflow:hidden;flex-shrink:0;margin-top:2px}
.os-feed-avy img{width:100%;height:100%;object-fit:cover}
.os-feed-text{flex:1;color:#b8babc;line-height:1.4}
.os-feed-text a{color:#edeeef;font-weight:500;text-decoration:none}
.os-feed-text a:hover{color:#e60000}
.os-feed-time{font-size:9px;color:#8e9194;margin-top:2px}
.os-pop-title{display:flex;gap:10px;padding:8px 0;border-bottom:1px solid rgba(255,255,255,0.06);transition:background .15s;cursor:pointer;text-decoration:none;color:inherit}
.os-pop-title:last-child{border-bottom:none}
.os-pop-title:hover{text-decoration:none;color:inherit}
.os-pop-title-img{width:40px;height:56px;border-radius:4px;overflow:hidden;flex-shrink:0}
.os-pop-title-img img{width:100%;height:100%;object-fit:cover}
.os-pop-title-info{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center}
.os-pop-title-name{font-size:11.5px;font-weight:600;color:#b8babc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.os-pop-title:hover .os-pop-title-name{color:#e60000}
.os-pop-title-genre{font-size:10px;color:#8e9194;margin-top:1px}
.os-social{display:flex;gap:8px;margin-bottom:12px}
.os-social a{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,0.04);color:#8e9194;font-size:14px;transition:all .15s;border:1px solid rgba(255,255,255,0.06);text-decoration:none}
.os-social a:hover{color:#fff;background:rgba(255,255,255,0.08)}
.os-footer-links{font-size:10px;color:#8e9194;line-height:1.8}
.os-footer-links a{color:#8e9194;transition:color .15s;text-decoration:none}
.os-footer-links a:hover{color:#b8babc}
.os-copyright{font-size:9px;color:#8e9194;opacity:.5;margin-top:8px}

/* ══════════════════════════════════════════
   Header Redesign
   ══════════════════════════════════════════ */
.os-header{position:fixed;top:0;left:0;right:0;z-index:999;background:rgba(21,20,18,0.95);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,0.06)}
.os-header-inner{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;align-items:center;height:56px;gap:16px}
.os-header .os-logo{display:flex;align-items:center;gap:8px;flex-shrink:0;text-decoration:none;color:inherit}
.os-header .os-logo:hover{text-decoration:none}
.os-header .os-logo-svg{display:flex;align-items:center;color:#edeeef;flex-shrink:0}
.os-header .os-logo-svg svg{width:28px;height:24px}
.os-header .os-logo-text{font-size:15px;font-weight:700;color:#edeeef;letter-spacing:-0.02em}
.os-nav{display:flex;align-items:center;gap:2px;margin-left:16px}
.os-nav-link{padding:6px 12px;font-size:12px;font-weight:500;color:#8e9194;border-radius:6px;transition:all .15s;text-decoration:none}
.os-nav-link:hover{color:#b8babc;background:rgba(255,255,255,0.04);text-decoration:none}
.os-nav-link.active{color:#edeeef;font-weight:600}
.os-don-mini{display:flex;align-items:center;gap:8px;margin-left:auto;padding:4px 12px;background:rgba(230,0,0,0.06);border:1px solid rgba(230,0,0,0.12);border-radius:20px;cursor:pointer;transition:all .15s;text-decoration:none}
.os-don-mini:hover{background:rgba(230,0,0,0.1);text-decoration:none}
.os-don-mini-bar{width:60px;height:4px;background:rgba(255,255,255,0.08);border-radius:2px;overflow:hidden}
.os-don-mini-fill{height:100%;background:#e60000;border-radius:2px}
.os-don-mini-text{font-size:10px;color:#e66;font-weight:600}
.os-header-right{display:flex;align-items:center;gap:4px}
.os-header-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#8e9194;font-size:15px;cursor:pointer;transition:all .15s;position:relative}
.os-header-icon:hover{color:#b8babc;background:rgba(255,255,255,0.05)}
.os-header-icon .badge-dot{position:absolute;top:6px;right:6px;width:7px;height:7px;background:#e60000;border-radius:50%;border:1.5px solid #151412}
.os-header-user{display:flex;align-items:center;gap:8px;padding:4px 10px 4px 4px;border-radius:20px;cursor:pointer;transition:all .15s;margin-left:4px;text-decoration:none;color:inherit}
.os-header-user:hover{background:rgba(255,255,255,0.04);text-decoration:none}
.os-header-user-avy{width:30px;height:30px;border-radius:50%;overflow:hidden;border:2px solid rgba(255,255,255,0.1)}
.os-header-user-avy img{width:100%;height:100%;object-fit:cover}
.os-header-user-name{font-size:11.5px;font-weight:600;color:#b8babc}
.os-header-user-chevron{font-size:9px;color:#8e9194}

/* Header dropdowns */
.os-notif-dropdown,.os-user-dropdown{position:absolute;top:100%;background:#1a1a1a;border:1px solid rgba(255,255,255,0.06);border-radius:10px;box-shadow:0 12px 40px rgba(0,0,0,0.5);display:none;z-index:6000}
.os-notif-dropdown.show,.os-user-dropdown.show{display:block}
.os-notif-dropdown{right:0;width:340px}
.os-user-dropdown{right:0;width:220px;overflow:hidden}
.os-notif-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid rgba(255,255,255,0.06)}
.os-notif-header h4{font-size:13px;font-weight:600;color:#edeeef;margin:0}
.os-notif-header a{font-size:10px;color:#8e9194;transition:color .15s;text-decoration:none}
.os-notif-header a:hover{color:#e60000}
.os-notif-list{max-height:320px;overflow-y:auto}
.os-notif-list::-webkit-scrollbar{width:3px}
.os-notif-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.1);border-radius:2px}
.os-notif-item{display:flex;gap:10px;padding:10px 16px;border-bottom:1px solid rgba(255,255,255,0.06);transition:background .15s;cursor:pointer}
.os-notif-item:hover{background:#2a2824}
.os-notif-item.unread{background:rgba(230,0,0,0.03)}
.os-notif-item-avy{width:32px;height:32px;border-radius:50%;overflow:hidden;flex-shrink:0}
.os-notif-item-avy img{width:100%;height:100%;object-fit:cover}
.os-notif-item-text{flex:1;font-size:11.5px;color:#b8babc;line-height:1.4}
.os-notif-item-text strong{color:#edeeef}
.os-notif-item-time{font-size:9px;color:#8e9194;margin-top:3px}
.os-notif-footer{padding:10px 16px;text-align:center;border-top:1px solid rgba(255,255,255,0.06)}
.os-notif-footer a{font-size:11px;color:#e60000;font-weight:500;text-decoration:none}
.os-user-dropdown-header{padding:16px;text-align:center;border-bottom:1px solid rgba(255,255,255,0.06);background:rgba(255,255,255,0.01)}
.os-user-dropdown-header-avy{width:48px;height:48px;border-radius:50%;overflow:hidden;margin:0 auto 8px;border:2px solid rgba(255,255,255,0.1)}
.os-user-dropdown-header-avy img{width:100%;height:100%;object-fit:cover}
.os-user-dropdown-header-name{font-size:13px;font-weight:600;color:#edeeef}
.os-user-dropdown-header-rank{font-size:10px;color:#8e9194}
.os-user-dropdown-menu{padding:6px 0}
.os-user-dropdown-item{display:flex;align-items:center;gap:10px;padding:8px 16px;font-size:12px;color:#b8babc;transition:all .15s;cursor:pointer;text-decoration:none}
.os-user-dropdown-item:hover{background:#2a2824;color:#fff;text-decoration:none}
.os-user-dropdown-item i{width:16px;text-align:center;font-size:13px;color:#8e9194}
.os-user-dropdown-item:hover i{color:#b8babc}
.os-user-dropdown-item.danger{color:#e63946}
.os-user-dropdown-item.danger i{color:#e63946}
.os-user-dropdown-divider{height:1px;background:rgba(255,255,255,0.06);margin:4px 0}
@media(max-width:768px){.os-nav{display:none}.os-don-mini{display:none}.os-header-user-name{display:none}}

/* ══════════════════════════════════════════
   Review Page Redesign (moved from inline)
   ══════════════════════════════════════════ */
/* Existing review classes (moved from inline in review.php) */
.review-hero{background:#1a1a1a;border-radius:12px;padding:20px 24px;margin-bottom:24px;display:flex;align-items:center;gap:20px;box-shadow:0 2px 12px rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.06)}
.review-hero-thumb{flex-shrink:0;width:80px;height:110px;border-radius:8px;overflow:hidden;box-shadow:0 4px 12px rgba(0,0,0,.5)}
.review-hero-thumb img{width:100%;height:100%;object-fit:cover}
.review-hero-info h4{margin:0 0 4px;font-size:1.1rem;font-weight:700;color:#edeeef}
.review-hero-info .meta{font-size:.8rem;color:#8e9194;margin-bottom:12px}
.review-avg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px 16px}
@media(max-width:576px){.review-avg-grid{grid-template-columns:repeat(2,1fr)}}
.review-avg-item{display:flex;flex-direction:column;gap:2px}
.review-avg-label{font-size:.68rem;color:#8e9194;text-transform:uppercase;letter-spacing:.04em}
.review-avg-bar-wrap{display:flex;align-items:center;gap:6px}
.review-avg-bar{flex:1;height:5px;border-radius:3px;background:rgba(255,255,255,.12);overflow:hidden}
.review-avg-bar-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,#c60000,#e60000);transition:width .4s}
.review-avg-score{font-size:.72rem;font-weight:700;min-width:22px;text-align:right;color:#b8babc}
.review-avg-overall{font-size:2rem;font-weight:800;color:#e60000;line-height:1}
.review-avg-overall-label{font-size:.7rem;color:#8e9194}
.review-card{background:#1a1a1a;border-radius:10px;margin-bottom:18px;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,.3);transition:box-shadow .2s;border:1px solid rgba(255,255,255,.06)}
.review-card:hover{box-shadow:0 4px 16px rgba(0,0,0,.5)}
.review-card-header{display:flex;align-items:center;gap:12px;padding:14px 18px 10px;border-bottom:1px solid rgba(255,255,255,.06)}
.review-card-avy{width:42px;height:42px;border-radius:50%;overflow:hidden;flex-shrink:0}
.review-card-avy img{width:100%;height:100%;object-fit:cover}
.review-card-user{flex:1}
.review-card-user .uname{font-size:.88rem;font-weight:600;line-height:1.2}
.review-card-user .rank-meta{font-size:.72rem;color:#8e9194}
.review-card-time{font-size:.72rem;color:#8e9194;white-space:nowrap}
.review-card-scores{display:flex;gap:0;padding:10px 18px;flex-wrap:wrap;border-bottom:1px solid rgba(255,255,255,.06)}
.review-score-pill{display:flex;flex-direction:column;align-items:center;padding:4px 12px;border-right:1px solid rgba(255,255,255,.06);min-width:60px}
.review-score-pill:last-child{border-right:none}
.review-score-pill .lbl{font-size:.62rem;color:#8e9194;text-transform:uppercase;letter-spacing:.04em}
.review-score-pill .val{font-size:.95rem;font-weight:700;color:#b8babc}
.review-score-pill.overall .val{color:#e60000;font-size:1.1rem}
.review-card-body{padding:14px 18px;font-size:.9rem;line-height:1.7;color:#b8babc}
.review-card-footer{display:flex;align-items:center;justify-content:flex-end;padding:8px 18px;gap:10px;border-top:1px solid rgba(255,255,255,.06)}
.review-card-footer .osbtn{cursor:pointer;font-size:.82rem;color:#8e9194;transition:all .2s}
.review-card-footer .osbtn:hover{color:#b8babc}
.review-card-footer .osheart i.fas{color:#e60000}

/* New rv- aliases */
.rv-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.rv-header h1{font-size:20px;font-weight:700;color:#edeeef}
.rv-write-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;background:linear-gradient(135deg,#c60000,#e60000);color:#fff;border:none;border-radius:8px;font-family:inherit;font-size:12px;font-weight:600;cursor:pointer;box-shadow:0 3px 12px rgba(230,0,0,0.25);transition:all .2s}
.rv-write-btn:hover{box-shadow:0 5px 20px rgba(230,0,0,0.35);transform:translateY(-1px)}
.rv-hero{display:flex;gap:20px;background:#1a1a1a;border:1px solid rgba(255,255,255,0.06);border-radius:10px;padding:20px;margin-bottom:20px}
.rv-hero-thumb{width:80px;height:110px;border-radius:8px;overflow:hidden;flex-shrink:0}
.rv-hero-thumb img{width:100%;height:100%;object-fit:cover}
.rv-hero-info{flex:1}
.rv-hero-title{font-size:16px;font-weight:600;color:#edeeef;margin-bottom:4px}
.rv-hero-meta{font-size:11px;color:#8e9194;margin-bottom:12px}
.rv-hero-scores{display:flex;align-items:center;gap:16px}
.rv-hero-overall{text-align:center}
.rv-hero-overall-num{font-size:32px;font-weight:700;color:#e60000;line-height:1}
.rv-hero-overall-label{font-size:9px;color:#8e9194;text-transform:uppercase;letter-spacing:.5px;margin-top:2px}
.rv-hero-bars{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:6px 16px}
.rv-bar-item{display:flex;align-items:center;gap:8px}
.rv-bar-label{font-size:10px;color:#8e9194;min-width:55px}
.rv-bar-track{flex:1;height:4px;background:rgba(255,255,255,0.06);border-radius:2px;overflow:hidden}
.rv-bar-fill{height:100%;background:linear-gradient(90deg,#c60000,#e60000);border-radius:2px}
.rv-bar-score{font-size:10px;font-weight:600;color:#b8babc;min-width:20px;text-align:right}
.rv-card{background:#1a1a1a;border:1px solid rgba(255,255,255,0.06);border-radius:10px;padding:18px;margin-bottom:14px;transition:box-shadow .2s}
.rv-card:hover{box-shadow:0 4px 16px rgba(0,0,0,0.3)}
.rv-card-header{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.rv-card-avy{width:40px;height:40px;border-radius:50%;overflow:hidden;flex-shrink:0;border:2px solid rgba(255,255,255,0.06)}
.rv-card-avy img{width:100%;height:100%;object-fit:cover}
.rv-card-user{flex:1}
.rv-card-name{font-size:12.5px;font-weight:600}
.rv-card-name a{transition:opacity .15s;text-decoration:none;color:inherit}
.rv-card-name a:hover{opacity:.8}
.rv-card-rank{font-size:10px;color:#8e9194}
.rv-card-time{font-size:10px;color:#8e9194}
.rv-card-scores{display:flex;flex-wrap:wrap;gap:0;margin-bottom:14px;border:1px solid rgba(255,255,255,0.06);border-radius:8px;overflow:hidden}
.rv-score-pill{flex:1;min-width:0;padding:8px 0;text-align:center;border-right:1px solid rgba(255,255,255,0.06)}
.rv-score-pill:last-child{border-right:none}
.rv-score-pill .lbl{display:block;font-size:8.5px;text-transform:uppercase;color:#8e9194;letter-spacing:.5px}
.rv-score-pill .val{display:block;font-size:15px;font-weight:700;color:#b8babc;margin-top:1px}
.rv-score-pill.overall .val{color:#e60000;font-size:17px}
.rv-card-body{font-size:13px;color:#b8babc;line-height:1.8;margin-bottom:14px}
.rv-card-footer{display:flex;align-items:center;gap:8px}
.rv-card-action{display:inline-flex;align-items:center;gap:4px;padding:5px 12px;font-size:11px;color:#8e9194;background:none;border:none;border-radius:6px;cursor:pointer;font-family:inherit;transition:all .15s}
.rv-card-action:hover{background:rgba(255,255,255,0.05);color:#b8babc}
.rv-card-action.liked{color:#e60000}
.rv-card-action.liked i{font-weight:900}
@media(max-width:600px){.rv-hero{flex-direction:column;align-items:center;text-align:center}.rv-hero-scores{flex-direction:column}.rv-hero-bars{grid-template-columns:1fr}}

/* ══════════════════════════════════════════
   Member Page Redesign
   ══════════════════════════════════════════ */
.mp-cover{min-height:300px;border-radius:12px;position:relative;overflow:hidden;margin-bottom:20px;background-size:cover !important;mask-image:none !important;-webkit-mask-image:none !important}
.mp-cover::before{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,0.85) 0%,rgba(0,0,0,0.6) 40%,rgba(0,0,0,0.2) 70%,transparent 100%);z-index:1}
.mp-profile{display:flex;gap:20px;position:absolute;bottom:0;left:0;right:0;z-index:2;padding:24px 28px;align-items:flex-start}
.mp-avatar{width:90px;height:90px;border-radius:50%;overflow:hidden;border:3px solid rgba(255,255,255,0.2);box-shadow:0 4px 16px rgba(0,0,0,0.5);flex-shrink:0}
.mp-avatar img{width:100%;height:100%;object-fit:cover}
.mp-info{padding-top:0;flex:1;padding-bottom:4px}
.mp-name{font-size:22px;font-weight:700;line-height:1.2;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,0.5)}
.mp-rank{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:600;padding:2px 8px;border-radius:8px;margin-top:4px;background:rgba(230,0,0,0.12);color:#e66;text-transform:uppercase}
.mp-bio{font-size:12px;color:rgba(255,255,255,0.7);margin-top:6px;max-width:500px;line-height:1.5}
/* All text inside profile overlay on cover should be bright & visible */
.mp-profile,.mp-profile *{color:rgba(255,255,255,0.9)}
.mp-info .os-icon,.mp-info span,.mp-info .mb-2{color:rgba(255,255,255,0.85) !important;font-size:12px}
.mp-info .inactive-color,.mp-info h5.inactive-color{color:rgba(255,255,255,0.7) !important}
.mp-info h5{color:rgba(255,255,255,0.85) !important;font-size:12px !important}
.mp-info a{color:#fff !important}
.mp-info .oslw{font-size:11px !important}
.mp-info .mp-actions .mp-action-btn{opacity:1 !important}
.mp-info .progress{background:rgba(255,255,255,0.15) !important}
.mp-info .progress-bar{opacity:1 !important}
.mp-actions{display:flex;gap:6px;margin-top:10px}
.mp-action-btn{padding:7px 16px;font-size:11px;font-weight:600;border-radius:7px;border:none;cursor:pointer;font-family:inherit;transition:all .15s;text-decoration:none}
.mp-action-btn.primary{background:#e60000;color:#fff}
.mp-action-btn.primary:hover{background:#ff1a1a}
.mp-action-btn.ghost{background:rgba(255,255,255,0.1);color:#fff;border:1px solid rgba(255,255,255,0.2)}
.mp-action-btn.ghost:hover{background:rgba(255,255,255,0.2);color:#fff}
.mp-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin:24px 0}
.mp-stat{background:#1a1a1a;border:1px solid rgba(255,255,255,0.06);border-radius:10px;padding:14px;text-align:center}
.mp-stat-value{font-size:20px;font-weight:700;color:#edeeef;line-height:1}
.mp-stat-label{font-size:10px;color:#8e9194;margin-top:4px;text-transform:uppercase;letter-spacing:.5px}
.mp-stat-icon{font-size:14px;color:#8e9194;margin-bottom:6px}
.mp-badges{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}
.mp-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:14px;font-size:10px;font-weight:600;border:1px solid rgba(255,255,255,0.08);background:rgba(255,255,255,0.03)}
.mp-section{margin-bottom:24px}
.mp-section-title{font-size:14px;font-weight:600;color:#edeeef;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.mp-section-title a{font-size:10px;color:#8e9194;margin-left:auto;font-weight:500;transition:color .15s;text-decoration:none}
.mp-section-title a:hover{color:#e60000}
.mp-activity{max-height:300px;overflow-y:auto;padding-right:8px}
.mp-activity::-webkit-scrollbar{width:3px}
.mp-activity::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.1);border-radius:2px}
.mp-activity-item{display:flex;gap:10px;padding:8px 0;border-bottom:1px solid rgba(255,255,255,0.06);font-size:11.5px}
.mp-activity-item:last-child{border-bottom:none}
.mp-activity-dot{width:8px;height:8px;border-radius:50%;background:#e60000;margin-top:5px;flex-shrink:0}
.mp-activity-text{flex:1;color:#b8babc}
.mp-activity-text a{color:#edeeef;font-weight:500;text-decoration:none}
.mp-activity-text a:hover{color:#e60000}
.mp-activity-time{font-size:9px;color:#8e9194;margin-top:2px}
.mp-titles-row{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px}
.mp-titles-row::-webkit-scrollbar{height:3px}
.mp-titles-row::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.1);border-radius:2px}
.mp-title-card{flex:0 0 100px;text-decoration:none;color:inherit}
.mp-title-card:hover{text-decoration:none}
.mp-title-card-img{aspect-ratio:2/3;border-radius:6px;overflow:hidden;border:2px solid transparent;transition:all .2s}
.mp-title-card:hover .mp-title-card-img{border-color:#e60000}
.mp-title-card-img img{width:100%;height:100%;object-fit:cover;display:block}
.mp-title-card-name{font-size:10px;font-weight:500;color:#b8babc;margin-top:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
.mp-friends{display:flex;gap:10px;flex-wrap:wrap}
.mp-friend{display:flex;align-items:center;gap:8px;padding:8px 12px;background:rgba(255,255,255,0.02);border:1px solid rgba(255,255,255,0.06);border-radius:8px;min-width:160px;text-decoration:none;color:inherit;transition:background .15s}
.mp-friend:hover{background:rgba(255,255,255,0.04);text-decoration:none}
.mp-friend-avy{width:32px;height:32px;border-radius:50%;overflow:hidden}
.mp-friend-avy img{width:100%;height:100%;object-fit:cover}
.mp-friend-name{font-size:11.5px;font-weight:600;color:#b8babc}
.mp-friend-rank{font-size:9px;color:#8e9194}
@media(max-width:640px){.mp-stats{grid-template-columns:repeat(3,1fr)}.mp-profile{flex-direction:column;align-items:center;text-align:center;padding:16px}.mp-cover{min-height:350px}.mp-actions{justify-content:center}}

/* ══════════════════════════════════════════
   Homepage Redesign
   ══════════════════════════════════════════ */
.hp-hero{text-align:center;padding:50px 20px 40px;margin-bottom:24px}
.hp-hero-tagline{font-size:32px;font-weight:700;color:#edeeef;line-height:1.2;margin-bottom:12px}
.hp-hero-tagline span{background:linear-gradient(135deg,#c60000,#ff4444);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hp-hero-sub{font-size:14px;color:#8e9194;margin-bottom:24px;max-width:500px;margin-left:auto;margin-right:auto}
.hp-hero-cta{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;background:linear-gradient(135deg,#c60000,#e60000);color:#fff;border-radius:10px;font-size:15px;font-weight:600;box-shadow:0 4px 20px rgba(230,0,0,0.3);transition:all .2s;text-decoration:none}
.hp-hero-cta:hover{transform:translateY(-2px);box-shadow:0 6px 30px rgba(230,0,0,0.4);color:#fff;text-decoration:none}
.hp-hero-login{display:block;margin-top:12px;font-size:12px;color:#8e9194}
.hp-hero-login a{color:#b8babc;font-weight:500;text-decoration:none}
.hp-hero-login a:hover{color:#e60000}
.hp-hero-stats{display:flex;justify-content:center;gap:40px;margin-top:30px}
.hp-hero-stat-num{font-size:22px;font-weight:700;color:#edeeef}
.hp-hero-stat-label{font-size:10px;color:#8e9194;text-transform:uppercase;letter-spacing:.5px}
.hp-section{margin-bottom:28px}
.hp-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.hp-section-title{font-size:16px;font-weight:600;color:#edeeef}
.hp-section-link{font-size:11px;color:#8e9194;transition:color .15s;text-decoration:none}
.hp-section-link:hover{color:#e60000}
.hp-continue-grid{display:flex;gap:14px;overflow-x:auto;padding-bottom:8px}
.hp-continue-grid::-webkit-scrollbar{height:3px}
.hp-continue-grid::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.1);border-radius:2px}
.hp-continue-card{flex:0 0 160px;cursor:pointer;text-decoration:none;color:inherit}
.hp-continue-card:hover{text-decoration:none}
.hp-continue-img{aspect-ratio:16/9;border-radius:8px;overflow:hidden;position:relative;background:#111}
.hp-continue-img img{width:100%;height:100%;object-fit:cover;display:block}
.hp-continue-progress{position:absolute;bottom:0;left:0;right:0;height:3px;background:rgba(0,0,0,0.5)}
.hp-continue-progress-bar{height:100%;background:#e60000}
.hp-continue-ep{font-size:10.5px;font-weight:500;color:#b8babc;margin-top:6px}
.hp-continue-title{font-size:10px;color:#8e9194;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hp-trending-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:14px}
.hp-trending-card{cursor:pointer;text-decoration:none;color:inherit}
.hp-trending-card:hover{text-decoration:none}
.hp-trending-img{aspect-ratio:2/3;border-radius:6px;overflow:hidden;border:2px solid transparent;transition:all .25s;max-height:220px;position:relative}
.hp-trending-card:hover .hp-trending-img{border-color:#e60000;transform:translateY(-2px)}
.hp-trending-img img{width:100%;height:100%;object-fit:cover;display:block}
.hp-trending-rank{position:absolute;top:6px;left:6px;width:22px;height:22px;background:rgba(0,0,0,0.7);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff}
.hp-trending-name{font-size:11px;font-weight:500;color:#b8babc;margin-top:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
.hp-trending-genre{font-size:10px;color:#8e9194;display:block}
.hp-disc-list{background:#1a1a1a;border:1px solid rgba(255,255,255,0.06);border-radius:10px;overflow:hidden}
.hp-disc-row{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid rgba(255,255,255,0.06);transition:background .15s;text-decoration:none;color:inherit}
.hp-disc-row:last-child{border-bottom:none}
.hp-disc-row:hover{background:#2a2824;text-decoration:none;color:inherit}
.hp-disc-avy{width:32px;height:32px;border-radius:50%;overflow:hidden;flex-shrink:0}
.hp-disc-avy img{width:100%;height:100%;object-fit:cover}
.hp-disc-info{flex:1;min-width:0}
.hp-disc-title{font-size:12.5px;font-weight:600;color:#b8babc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hp-disc-row:hover .hp-disc-title{color:#fff}
.hp-disc-meta{font-size:10px;color:#8e9194;margin-top:2px}
.hp-disc-badge{font-size:9px;font-weight:600;padding:2px 6px;border-radius:6px;flex-shrink:0}
.hp-disc-time{font-size:10px;color:#8e9194;flex-shrink:0}
@media(max-width:640px){.hp-hero-tagline{font-size:24px}.hp-hero-stats{gap:20px;flex-wrap:wrap}}

/* Donation tier grid (modals) */
.os-don-tier-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:14px}
.os-don-tier{padding:12px;background:rgba(255,255,255,0.02);border:1px solid rgba(255,255,255,0.06);border-radius:8px;text-align:center;transition:all .15s}
.os-don-tier:hover{border-color:rgba(255,255,255,0.12)}
.os-don-tier.current{border-color:rgba(230,0,0,0.3);background:rgba(230,0,0,0.04)}
.os-don-tier-icon{font-size:20px;margin-bottom:6px}
.os-don-tier-name{font-size:11px;font-weight:600;color:#edeeef}
.os-don-tier-amount{font-size:10px;color:#8e9194;margin-top:2px}
.os-don-tier-badge{font-size:8px;font-weight:700;color:#e60000;text-transform:uppercase;margin-top:4px}
@media(max-width:500px){.os-don-tier-grid{grid-template-columns:repeat(2,1fr)}}

/* ══════════════════════════════════════════
   Header Visual Override (matching mockup)
   ══════════════════════════════════════════ */
.site-header {
  position: sticky !important;
  top: 0;
  z-index: 999 !important;
  backdrop-filter: blur(14px) !important;
  -webkit-backdrop-filter: blur(14px) !important;
  background: rgba(21, 20, 18, 0.94) !important;
  border-bottom: 1px solid rgba(255,255,255,0.05) !important;
}
.site-header .header-inner {
  padding-top: 4px !important;
  padding-bottom: 4px !important;
  padding-left: 20px !important;
  padding-right: 20px !important;
  max-width: 100% !important;
  width: 100% !important;
}
/* Nav links — cleaner, rounder */
.site-header .navbar-nav .nav-link {
  font-size: 13px !important;
  font-weight: 500 !important;
  padding: 6px 14px !important;
  border-radius: 6px !important;
  transition: all 0.15s !important;
  color: #8e9194 !important;
}
.site-header .navbar-nav .nav-link:hover {
  color: #edeeef !important;
  background: rgba(255,255,255,0.04) !important;
}
.site-header .navbar-nav .menu-item.active .nav-link,
.site-header .navbar-nav .nav-link.active {
  color: #edeeef !important;
  font-weight: 600 !important;
}
/* Brand text */
.site-header .brand strong {
  font-size: 15px !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em !important;
}
/* Secondary nav icons */
.site-header .navbar-secondary .nav-link {
  padding: 6px 8px !important;
  border-radius: 8px !important;
  transition: all 0.15s !important;
}
.site-header .navbar-secondary .nav-link:hover {
  background: rgba(255,255,255,0.05) !important;
}
/* User avatar in header */
.site-header .osimgavy {
  border: 2px solid rgba(255,255,255,0.1);
  border-radius: 50% !important;
  transition: border-color 0.15s;
}
.site-header .osimgavy:hover {
  border-color: rgba(255,255,255,0.2);
}
/* Dropdown menus — dark & rounded */
.site-header .dropdown-menu {
  background: #1a1a1a !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  border-radius: 10px !important;
  box-shadow: 0 12px 40px rgba(0,0,0,0.5) !important;
  padding: 8px 0 !important;
}
.site-header .dropdown-menu .dropdown-item,
.site-header .dropdown-menu .menu-item a {
  font-size: 13px !important;
  padding: 8px 16px !important;
  color: #b8babc !important;
  transition: all 0.15s !important;
}
.site-header .dropdown-menu .dropdown-item:hover,
.site-header .dropdown-menu .menu-item a:hover {
  background: #2a2824 !important;
  color: #fff !important;
}
.site-header .dropdown-menu h5 {
  font-size: 10px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
  color: #8e9194 !important;
  padding: 8px 16px 4px !important;
}
/* Mega menu */
.site-header .dropdown-mega-menu {
  border-radius: 10px !important;
  background: #1a1a1a !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  box-shadow: 0 12px 40px rgba(0,0,0,0.5) !important;
}
.site-header .dropdown-mega-menu .triangle { display: none !important; }
.site-header .dropdown-md .triangle { display: none !important; }

/* Notification & user dropdowns */
.notifications {
  background: #1a1a1a !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  border-radius: 10px !important;
  box-shadow: 0 12px 40px rgba(0,0,0,0.5) !important;
}
.user-settings-dropdown {
  background: #1a1a1a !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  border-radius: 10px !important;
  box-shadow: 0 12px 40px rgba(0,0,0,0.5) !important;
}
.oslogin-dd {
  background: #1a1a1a !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  border-radius: 10px !important;
  box-shadow: 0 12px 40px rgba(0,0,0,0.5) !important;
}
/* User settings menu */
.user-settings-menu a {
  display: flex !important;
  align-items: center;
  gap: 10px;
  padding: 8px 16px !important;
  font-size: 13px !important;
  color: #b8babc !important;
  transition: all 0.15s !important;
}
.user-settings-menu a:hover {
  background: #2a2824 !important;
  color: #fff !important;
}

/* ══════════════════════════════════════════
   Homepage Tab & Section Visual Override
   ══════════════════════════════════════════ */
/* Tab nav — cleaner underline style */
.os-tabbed-nav .nav-item a {
  font-size: 13px !important;
  font-weight: 500 !important;
  color: #8e9194 !important;
  padding: 10px 18px !important;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: all 0.15s !important;
}
.os-tabbed-nav .nav-item a:hover {
  color: #b8babc !important;
}
.os-tabbed-nav .nav-item a.active,
.os-tabbed-nav .nav-item a.loaded {
  color: #edeeef !important;
  font-weight: 600 !important;
  border-bottom-color: #e60000 !important;
}
/* Section titles */
.title-box .title {
  font-size: 17px !important;
  font-weight: 600 !important;
  color: #edeeef !important;
}
.title-box .sub-title {
  font-size: 11px !important;
  color: #8e9194 !important;
}
/* Content cards — cleaner image boxes */
.os-img-box .title {
  font-size: 12px !important;
  color: #b8babc !important;
  margin-bottom: 4px !important;
}
.os-img-box:hover .title {
  color: #e60000 !important;
}
.os-img-box .sub-title {
  font-size: 11px !important;
  color: #8e9194 !important;
}
/* Image boxes — rounded, with hover */
.os-img-box .img-box {
  border-radius: 8px !important;
  overflow: hidden !important;
  border: 2px solid transparent;
  transition: all 0.25s !important;
}
.os-img-box:hover .img-box {
  border-color: #e60000;
  transform: translateY(-2px);
}
/* Continue watching progress bar */
.os-img-box .img-box .progress-bar,
.os-img-box .progress-bar {
  background: #e60000 !important;
}
/* oscontent — remove dotted border, modernize */
.oscontent {
  border: 1px solid rgba(255,255,255,0.06) !important;
  border-radius: 10px !important;
  background: #1a1a1a !important;
  box-shadow: none !important;
}
/* Carousel items — clean spacing */
.owl-carousel .os-img-box {
  margin-bottom: 10px !important;
}

/* Notification dropdown — inner styling */
.notifications h5 {
  font-size: 14px !important;
  font-weight: 600 !important;
  color: #edeeef !important;
  padding-bottom: 10px !important;
  border-bottom: 1px solid rgba(255,255,255,0.06) !important;
  margin-bottom: 10px !important;
}
.notifications #notificationlist {
  max-height: 320px;
  overflow-y: auto;
  list-style: none;
  padding: 0;
  margin: 0;
}
.notifications #notificationlist::-webkit-scrollbar { width: 3px; }
.notifications #notificationlist::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 2px; }
.notifications #notificationlist li {
  padding: 10px 0;
  border-bottom: 1px solid rgba(255,255,255,0.04);
  font-size: 12px;
  line-height: 1.5;
  color: #b8babc;
}
.notifications #notificationlist li:last-child { border-bottom: none; }

/* User dropdown — inner styling */
.user-settings-dropdown .user-cover-image {
  border-radius: 10px 10px 0 0 !important;
  max-height: 80px;
  overflow: hidden;
}
.user-settings-dropdown .user-profile-image {
  border: 3px solid #1a1a1a !important;
  border-radius: 50% !important;
}
.user-settings-dropdown .user-name {
  font-size: 14px !important;
  font-weight: 600 !important;
  color: #edeeef !important;
}

/* PM modals — dark theme */
.modal-content.osmodal,
.modal-notify .modal-content {
  background: #1a1a1a !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  border-radius: 12px !important;
  box-shadow: 0 20px 60px rgba(0,0,0,0.6) !important;
}
.modal-content.osmodal .modal-header,
.modal-notify .modal-header {
  border-bottom: 1px solid rgba(255,255,255,0.06) !important;
}
.modal-content.osmodal .modal-footer,
.modal-notify .modal-footer {
  border-top: 1px solid rgba(255,255,255,0.06) !important;
}
.modal-content.osmodal .form-control {
  background: #2a2824 !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  border-radius: 8px !important;
  color: #edeeef !important;
}
.modal-content.osmodal .form-control:focus {
  border-color: rgba(230,0,0,0.3) !important;
  box-shadow: none !important;
}

/* ══════════════════════════════════════════
   Bugfix Batch: Modals, Notifications, PM, Header, Donation
   ══════════════════════════════════════════ */

/* Fix 1: Modals always on top */
.modal { z-index: 10050 !important; }
.modal-backdrop { z-index: 10040 !important; }
.os-modal-overlay { z-index: 10050 !important; }

/* TinyMCE 5 renders its menus / dropdowns / dialogs into .tox-tinymce-aux
   appended to <body> at a default z-index (~1300). Inside our modals
   (z-index 10050) that floating UI ends up BEHIND the editor. Lift the
   aux layer above every modal so menubar menus, toolbar dropdowns and
   link/image/table dialogs are clickable. */
.tox.tox-tinymce-aux,
.tox-tinymce-aux,
.tox .tox-menu,
.tox .tox-collection,
.tox .tox-dialog-wrap,
.tox-silver-sink { z-index: 100100 !important; }
/* The dialog MUST sit above its own dimming backdrop. Forcing both to the
   same z-index made the backdrop (later DOM sibling) paint over the dialog
   → an opaque sheet covered the color-picker / insert-image dialog and ate
   clicks. Backdrop just below + dim (not white); dialog on top. */
.tox .tox-dialog-wrap__backdrop {
  z-index: 100100 !important;
  background-color: rgba(0,0,0,.5) !important;
}
.tox .tox-dialog {
  position: relative;
  z-index: 100101 !important;
}

/* Fix 2: Donation mini — bigger & more visible */
.os-don-mini {
  padding: 6px 16px !important;
  background: rgba(230,0,0,0.1) !important;
  border: 1px solid rgba(230,0,0,0.2) !important;
  border-radius: 22px !important;
  gap: 10px !important;
}
.os-don-mini-bar {
  width: 100px !important;
  height: 6px !important;
  background: rgba(255,255,255,0.1) !important;
}
.os-don-mini-fill { height: 100%; background: linear-gradient(90deg,#c60000,#e60000) !important; }
.os-don-mini-text {
  font-size: 12px !important;
  font-weight: 600 !important;
  color: #ff6666 !important;
  white-space: nowrap;
}

/* Fix 3: Notification text & links visible */
.notifications { color: #b8babc !important; }
.notifications #notificationlist { padding: 0; margin: 0; list-style: none; }
.notifications #notificationlist li {
  padding: 10px 4px !important;
  border-bottom: 1px solid rgba(255,255,255,0.05) !important;
  font-size: 13px !important;
  color: #b8babc !important;
  line-height: 1.5 !important;
}
.notifications #notificationlist li:last-child { border-bottom: none !important; }
.notifications #notificationlist li a,
.notifications a,
.notifications .col-md-12 a {
  color: #edeeef !important;
  font-weight: 500 !important;
}
.notifications #notificationlist li a:hover { color: #e60000 !important; }
.notifications .osright,
.notifications .notification-time {
  font-size: 10px !important;
  color: #8e9194 !important;
}

/* Fix 4: Notification avatars — proper sizing & spacing */
.notifications .media {
  display: flex !important;
  align-items: flex-start !important;
  gap: 10px !important;
}
.notifications .media .img-box,
.notifications .media .img-box-sm,
.notifications .notification-avatar {
  width: 34px !important;
  height: 34px !important;
  min-width: 34px !important;
  border-radius: 50% !important;
  overflow: hidden !important;
  flex-shrink: 0 !important;
  margin-right: 0 !important;
}
.notifications .media .img-box img,
.notifications .media .img-box-sm img {
  width: 34px !important;
  height: 34px !important;
  object-fit: cover !important;
  border-radius: 50% !important;
}
.notifications .media .des { flex: 1; min-width: 0; }

/* Notification modal (full list view) */
.osnotif-modal .modal-content {
  background: #1a1a1a !important;
  border-radius: 12px !important;
}
.osnotiflist { padding: 0; margin: 0; list-style: none; }
.osnotiflist li {
  padding: 12px 16px !important;
  border-bottom: 1px solid rgba(255,255,255,0.05) !important;
  color: #b8babc !important;
  font-size: 13px !important;
}
.osnotiflist li a { color: #edeeef !important; font-weight: 500 !important; }
.osnotiflist li:hover { background: rgba(255,255,255,0.03) !important; }

/* Fix 5: Private Messages — visible & working */
#ospm .modal-content,
.modal-notify .modal-content {
  background: #1a1a1a !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  border-radius: 12px !important;
  color: #b8babc !important;
}
#ospm .modal-header,
.modal-notify .modal-header {
  background: transparent !important;
  border-bottom: 1px solid rgba(255,255,255,0.06) !important;
  color: #edeeef !important;
}
#ospm .modal-header h5,
.modal-notify .modal-header h5 {
  color: #edeeef !important;
}
#ospm .modal-body {
  background: transparent !important;
  color: #b8babc !important;
}
#pmlist {
  padding: 0 !important;
  margin: 0 !important;
  list-style: none !important;
}
#pmlist .list-group-item {
  background: transparent !important;
  border: none !important;
  border-bottom: 1px solid rgba(255,255,255,0.05) !important;
  padding: 12px 16px !important;
  color: #b8babc !important;
  cursor: pointer;
  transition: background 0.15s;
}
#pmlist .list-group-item:hover {
  background: rgba(255,255,255,0.03) !important;
}
#pmlist .msg-box {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  color: #b8babc !important;
}
#pmlist .msg-box .img-box,
#pmlist .msg-box .img-box-sm,
#pmlist .msg-box .img-box-don {
  width: 38px !important;
  height: 38px !important;
  min-width: 38px !important;
  border-radius: 50% !important;
  overflow: hidden !important;
  flex-shrink: 0 !important;
}
#pmlist .msg-box .img-box img,
#pmlist .msg-box .img-box-sm img,
#pmlist .msg-box .img-box-don img {
  width: 38px !important;
  height: 38px !important;
  object-fit: cover !important;
  border-radius: 50% !important;
}
#pmlist .msg-box .des { flex: 1; min-width: 0; }
#pmlist .msg-box .artist,
#pmlist .msg-box h5 {
  color: #edeeef !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  margin: 0 0 2px !important;
}
#pmlist .msg-box .des span {
  color: #8e9194 !important;
  font-size: 12px !important;
}
#pmlist .badge {
  background: #e60000 !important;
  color: #fff !important;
  border-radius: 10px !important;
  font-size: 10px !important;
  padding: 3px 8px !important;
  flex-shrink: 0;
}
#nolist {
  color: #8e9194 !important;
  padding: 30px !important;
}
#nolist h4,
#nolist h5 {
  color: #8e9194 !important;
}
/* PM thread modal */
#messageModal .modal-content {
  background: #1a1a1a !important;
  border-radius: 12px !important;
  color: #b8babc !important;
}
#messageModal .modal-header { border-bottom: 1px solid rgba(255,255,255,0.06) !important; }
#messageModal .modal-footer { border-top: 1px solid rgba(255,255,255,0.06) !important; }
.pmcontent { padding: 0; margin: 0; list-style: none; }
.pmcontent li {
  padding: 12px 16px !important;
  border-bottom: 1px solid rgba(255,255,255,0.05) !important;
  color: #b8babc !important;
  font-size: 13px !important;
  line-height: 1.6 !important;
}
.pmcontent li .user { color: #edeeef !important; font-weight: 600 !important; font-size: 12px !important; margin-bottom: 6px; }
.pmcontent li .user b { color: #8e9194 !important; font-weight: 400 !important; font-size: 10px !important; margin-left: 8px; }
/* Send message modal */
#sendMessageModal .modal-content {
  background: #1a1a1a !important;
  border-radius: 12px !important;
}
/* PM footer buttons */
#ospm .modal-footer,
.modal-notify .modal-footer,
#messageModal .modal-footer,
#sendMessageModal .modal-footer {
  border-top: 1px solid rgba(255,255,255,0.06) !important;
  background: transparent !important;
}

/* Fix 6: Header — more aggressive CSS to match mockup */
.site-header {
  position: sticky !important;
  top: 0 !important;
  z-index: 999 !important;
  background: #151412 !important;
  border-bottom: 1px solid rgba(255,255,255,0.06) !important;
  width: 100% !important;
  left: 0 !important;
  right: 0 !important;
}
.site-header .header-inner {
  padding-top: 6px !important;
  padding-bottom: 6px !important;
  padding-left: 20px !important;
  padding-right: 20px !important;
  max-width: 100% !important;
  width: 100% !important;
}
/* Force header row to single line — no wrapping */
.site-header .header-inner > .row {
  flex-wrap: nowrap !important;
  align-items: center !important;
}
/* Logo column — shrink to fit */
.site-header .header-inner > .row > [class*="col-"]:first-child {
  flex: 0 0 auto !important;
  width: auto !important;
  max-width: none !important;
}
/* Nav column — flexible, centered */
.site-header .header-inner > .row > [class*="col-"]:nth-child(2) {
  flex: 1 1 auto !important;
  width: auto !important;
  max-width: none !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
}
.site-header .header-inner > .row > [class*="col-"]:nth-child(2) .navbar {
  justify-content: center !important;
  width: auto !important;
}
.site-header #navbarSupportedContent {
  justify-content: center !important;
  flex-grow: 0 !important;
}
.site-header #navbarSupportedContent .navbar-nav {
  justify-content: center !important;
  margin: 0 auto !important;
}
/* Right icons column — shrink to fit */
.site-header .header-inner > .row > [class*="col-"]:last-child {
  flex: 0 0 auto !important;
  width: auto !important;
  max-width: none !important;
}
/* Donation mini — hide on smaller screens to prevent overflow */
@media (max-width: 1100px) {
  .os-don-mini { display: none !important; }
}
/* Hide brand text on small-medium screens, keep icon */
@media (max-width: 900px) {
  .site-header .brand strong { display: none !important; }
}
/* Compact brand */
.site-header .brand { gap: 6px; }
.site-header .brand .os-icon.icon-5x svg { height: 26px !important; width: auto !important; }
.site-header .brand strong { font-size: 14px !important; font-weight: 700 !important; }
.site-header .osversion { font-size: 9px !important; opacity: 0.4; }
/* Nav links — pill style from mockup */
.site-header .navbar-nav .nav-link {
  font-size: 13px !important;
  font-weight: 500 !important;
  padding: 7px 14px !important;
  border-radius: 7px !important;
  color: #9a9c9e !important;
  transition: all 0.15s !important;
}
.site-header .navbar-nav .nav-link:hover {
  color: #edeeef !important;
  background: rgba(255,255,255,0.05) !important;
}
/* Right icons — icon button style from mockup */
.site-header .navbar-secondary > div,
.site-header .navbar-secondary > .nav-item {
  margin-left: 2px;
}
.site-header .navbar-secondary .nav-link {
  width: 38px !important;
  height: 38px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  border-radius: 9px !important;
  color: #8e9194 !important;
  transition: all 0.15s !important;
}
.site-header .navbar-secondary .nav-link:hover {
  background: rgba(255,255,255,0.06) !important;
  color: #edeeef !important;
}
.site-header .navbar-secondary .nav-link .os-icon svg {
  width: 18px !important;
  height: 18px !important;
}
/* Notification badge dot — mockup style */
.notification-toggle.has-notification::before {
  width: 8px !important;
  height: 8px !important;
  border: 2px solid rgba(21,20,18,0.95) !important;
}
/* User avatar dropdown trigger */
.site-header #dropdownUserSettings {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 4px 10px 4px 4px !important;
  border-radius: 22px !important;
  width: auto !important;
  height: auto !important;
}
.site-header #dropdownUserSettings:hover {
  background: rgba(255,255,255,0.04) !important;
}
.site-header #dropdownUserSettings .osimgavy {
  width: 30px !important;
  height: 30px !important;
  border-radius: 50% !important;
  border: 2px solid rgba(255,255,255,0.1) !important;
}
.site-header #dropdownUserSettings .osimgavy img {
  border-radius: 50% !important;
}
.site-header #dropdownUserSettings .fs-1 {
  font-size: 12px !important;
  font-weight: 600 !important;
  color: #b8babc !important;
}
/* All dropdowns — dark rounded from mockup */
.site-header .dropdown-menu {
  background: #1a1a1a !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  border-radius: 10px !important;
  box-shadow: 0 12px 40px rgba(0,0,0,0.5) !important;
  padding: 8px 0 !important;
  margin-top: 6px !important;
}
.site-header .dropdown-mega-menu {
  background: #1a1a1a !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  border-radius: 10px !important;
  box-shadow: 0 12px 40px rgba(0,0,0,0.5) !important;
  margin-top: 6px !important;
}
.site-header .dropdown-mega-menu .triangle,
.site-header .dropdown-md .triangle { display: none !important; }
.site-header .dropdown-menu .menu-item a,
.site-header .dropdown-menu .dropdown-item {
  font-size: 13px !important;
  padding: 8px 16px !important;
  color: #b8babc !important;
  transition: all 0.15s !important;
  border-radius: 0 !important;
}
.site-header .dropdown-menu .menu-item a:hover,
.site-header .dropdown-menu .dropdown-item:hover {
  background: #2a2824 !important;
  color: #fff !important;
}
.site-header .dropdown-menu h5 {
  font-size: 10px !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
  color: #8e9194 !important;
  padding: 8px 16px 4px !important;
  font-weight: 600 !important;
}

/* ══════════════════════════════════════════
   Batch Fix: PM modal, nav submenu, text sizes
   ══════════════════════════════════════════ */

/* Fix 1: PM modal — force on top (uses modal-right which has its own positioning) */
#ospm { z-index: 10060 !important; }
#ospm + .modal-backdrop,
.modal-backdrop.show { z-index: 10040 !important; }
#messageModal { z-index: 10070 !important; }
#sendMessageModal { z-index: 10080 !important; }

/* Fix 3: Header nav submenu — cleaner mega menu & dropdown styling */
.site-header .dropdown-mega-menu {
  padding: 20px 24px !important;
  min-width: 400px !important;
  display: none;
}
.site-header .dropdown-mega-menu.show,
.site-header .menu-item:hover > .dropdown-mega-menu {
  display: flex !important;
  flex-direction: row !important;
  gap: 30px !important;
}
.site-header .dropdown-mega-menu .col {
  padding: 0 !important;
  min-width: 150px;
}
.site-header .dropdown-mega-menu h5 {
  margin-bottom: 10px !important;
  padding: 0 !important;
  font-size: 10px !important;
  text-transform: uppercase !important;
  letter-spacing: 1.5px !important;
  color: #666 !important;
  font-weight: 700 !important;
}
.site-header .dropdown-mega-menu ul {
  padding: 0 !important;
  margin: 0 !important;
  list-style: none !important;
}
.site-header .dropdown-mega-menu .menu-item {
  margin: 0 !important;
}
.site-header .dropdown-mega-menu .menu-item a {
  display: block !important;
  padding: 6px 10px !important;
  font-size: 13px !important;
  color: #b8babc !important;
  border-radius: 6px !important;
  transition: all 0.15s !important;
}
.site-header .dropdown-mega-menu .menu-item a:hover {
  background: rgba(255,255,255,0.06) !important;
  color: #fff !important;
}
/* Regular dropdown-md (More menu) */
.site-header .dropdown-md {
  padding: 8px 0 !important;
  min-width: 180px !important;
}
.site-header .dropdown-md ul {
  padding: 0 !important;
  margin: 0 !important;
  list-style: none !important;
}
.site-header .dropdown-md .menu-item a {
  display: block !important;
  padding: 8px 16px !important;
  font-size: 13px !important;
  color: #b8babc !important;
  transition: all 0.15s !important;
}
.site-header .dropdown-md .menu-item a:hover {
  background: #2a2824 !important;
  color: #fff !important;
}

/* Fix 5: Recent updates / discussions section — bigger, clearer text */
.os-carousel .title,
.os-carousel h6.title {
  font-size: 14px !important;
  color: #edeeef !important;
  font-weight: 500 !important;
  white-space: normal !important;
  line-height: 1.4 !important;
}
.os-carousel .sub-title,
.os-carousel p.sub-title {
  font-size: 12px !important;
  color: #8e9194 !important;
}

/* Fix 6: Homepage section titles and cards — bigger text */
/* Section headers */
.title-box .title.h3-md,
.title-box h2.title,
.title-box h3.title {
  font-size: 18px !important;
  font-weight: 600 !important;
  color: #edeeef !important;
}
.title-box .sub-title {
  font-size: 13px !important;
  color: #8e9194 !important;
}
/* Image box titles & subtitles — all carousels & grids */
.os-img-box h6.title,
.os-img-box .title {
  font-size: 14px !important;
  color: #c8cacc !important;
  font-weight: 500 !important;
  width: auto !important;
  max-width: 100% !important;
}
.os-img-box:hover .title,
.os-img-box:hover h6.title {
  color: #e60000 !important;
}
.os-img-box .sub-title,
.os-img-box p.sub-title {
  font-size: 12px !important;
  color: #8e9194 !important;
}
/* Continue watching / recommended card text */
.os-img-box .category {
  font-size: 12px !important;
}
/* Episode text in carousels */
.follower-box h5,
.follower-box .artist {
  font-size: 14px !important;
  color: #edeeef !important;
}
.follower-box .des span {
  font-size: 12px !important;
  color: #8e9194 !important;
}

/* ── End Batch Fix ── */

.totop {
  position:fixed;
  left:20px;
  bottom:20px;
  z-index: 500;
}

.topicon {
  -webkit-box-shadow: 0px 0px 4px 1px rgba(0,0,0,0.75);
  -moz-box-shadow: 0px 0px 4px 1px rgba(0,0,0,0.75);
  box-shadow: 0px 0px 4px 1px rgba(0,0,0,0.75);
  -webkit-border-radius: 25px;
  -moz-border-radius: 25px;
  border-radius: 25px;
  cursor:pointer;
  padding: 5px 10px;
  background: #333;
  float:left;
  font-size:20px;
}

.related li {
  list-style:none;
  padding-left:10px;
}

.related li span {
  font-weight:bold;
}

.related li a {
  text-decoration: #f0f4c3;
}
.donationprogress {
  overflow:unset;
}
.donationbar {
  position:relative;
}

.donationtext {
  position: absolute;
  right: -15px;
  top: 17px;
  font-size: 15px;
}

.donationtext:before {
  content: "";
  width: 0;
  height: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-bottom: 5px solid #e8e8e8;
  position: absolute;
  right: 10px;
}

.donsidebar .mt-0{
  margin-top: 30px !important;
  display: block;
  font-size: 12px;
}
.donsidebar .title span {
  display:block;
}

.osdonbutton:hover {
  cursor:pointer;
  font-weight:bold;
  color:#c60000;
}
.osnotif-btn {
  cursor:pointer;
}

.thread-ospagination {
  float: right;
  right: 0px;
  text-align: right;
  padding-right: 10px;
}

.pagebtns {
  background:#333;
}
.pagebtns:hover {
  color:#fff;
  background:#c60000;
}

.thread-ospagination .active{
  background:#e3e3e3;
  color:#000;
}
.thread-ospagination .active:hover{

}


.pagebtns {
  padding: 5px 10px;
  border: 1px solid #444;
  -webkit-box-shadow: 1px 1px 5px 0px rgba(0, 0, 0, 0.75);
  -moz-box-shadow:    1px 1px 5px 0px rgba(0, 0, 0, 0.75);
  box-shadow:         1px 1px 5px 0px rgba(0, 0, 0, 0.75);
}

/* Usergroup Color */
.osg_yuri{color:#f4abe1;text-shadow:3px 3px 5px #ff00e5}
.osg_yaoi{color:#d121aa;text-shadow:3px 3px 5px #f76767}
.osidol_css{background-image:url(//img.otaku-streamers.com/usergroups/osidol.jpg);width:136px;text-align:center;height:25px;padding-top:10px;display:inline-block}
.os-rainbow-grp{background-image:-webkit-gradient( linear,left top,right top,color-stop(0,#f22),color-stop(0.15,#f2f),color-stop(0.3,#22f),color-stop(0.45,#2ff),color-stop(0.6,#2f2),color-stop(0.75,#2f2),color-stop(0.9,#ff2),color-stop(1,#f22) );background-image:gradient( linear,left top,right top,color-stop(0,#f22),color-stop(0.15,#f2f),color-stop(0.3,#22f),color-stop(0.45,#2ff),color-stop(0.6,#2f2),color-stop(0.75,#2f2),color-stop(0.9,#ff2),color-stop(1,#f22) );color:transparent;-webkit-background-clip:text;background-clip:text}

@-webkit-keyframes pulse {to {box-shadow: 0 0 0 45px rgba(232, 76, 61, 0);}}
@-moz-keyframes pulse {to {box-shadow: 0 0 0 45px rgba(232, 76, 61, 0);}}
@-ms-keyframes pulse {to {box-shadow: 0 0 0 45px rgba(232, 76, 61, 0);}}
@keyframes pulse {to {box-shadow: 0 0 0 45px rgba(232, 76, 61, 0);}}

@media (max-width: 768px) {
  .ospagination{
    float: none;
    text-align: center;
    margin-top: 20px;
  }
  .ostitle {
    margin-left:10px;
  }
  .osright,.osleft {
    float: none;
    display: block;
  }
  .oswatched {
    float:right;
  }
  .deskonly {
    display:none;
  }
  .mobonly {
    display:block;
  }
  .mobright {
    display:inherit;
    float:right;
  }
  .oslist-letters {
    position:relative;
    right: 0px;
  }
  .oslist-letters ul{
    list-style:none;
    padding:0px;
    display: block;
    text-align: center;
  }
  .oslist-letters ul li{
    display:inline;
    line-height: 35px;
    padding: 4px;
  }
  .oslist-letters ul li:hover{
    background:#444;
  }

  .os-album-list > li .item-number {
    width:10%;
  }

  .os-album-list > li .item-title {
    width: 70%;
    max-width: 100%;
  }

}

/* ══════════════════════════════════════════════════════════
   LIGHT MODE OVERRIDES
   Applied when #wrap has class "os-light-mode"
   ══════════════════════════════════════════════════════════ */
#wrap.os-light-mode,
#wrap.os-light-mode body {
  background: #f0f2f5 !important;
  color: #2a2a2a !important;
}
#wrap.os-light-mode h1, #wrap.os-light-mode .h1,
#wrap.os-light-mode h2, #wrap.os-light-mode .h2,
#wrap.os-light-mode h3, #wrap.os-light-mode .h3,
#wrap.os-light-mode h4, #wrap.os-light-mode .h4,
#wrap.os-light-mode h5, #wrap.os-light-mode .h5,
#wrap.os-light-mode h6, #wrap.os-light-mode .h6 {
  color: #1a1a1a !important;
}
#wrap.os-light-mode .inactive-color { color: #555 !important; }
#wrap.os-light-mode a { color: #2a2a2a; }
#wrap.os-light-mode a:hover { color: #e60000; }

/* Header */
#wrap.os-light-mode .site-header,
#wrap.os-light-mode #site-header { background: #ffffff !important; border-bottom: 1px solid #e0e0e0; }
#wrap.os-light-mode .site-header .nav-link,
#wrap.os-light-mode .site-header strong { color: #1a1a1a !important; }
#wrap.os-light-mode .dropdown-menu,
#wrap.os-light-mode .dropdown-mega-menu { background: #fff !important; color: #1a1a1a; }
#wrap.os-light-mode .navbar-toggler-icon { background: #1a1a1a !important; }

/* Off-canvas */
#wrap.os-light-mode .off-canvas,
#wrap.os-light-mode #primary-menu-offcanvas { background: #ffffff !important; color: #1a1a1a; }
#wrap.os-light-mode .side-nav .nav-link { color: #1a1a1a !important; }

/* Cards & panels */
#wrap.os-light-mode .os-card,
#wrap.os-light-mode .osmodal .modal-content,
#wrap.os-light-mode .osthread,
#wrap.os-light-mode .ospost-content,
#wrap.os-light-mode .review-card,
#wrap.os-light-mode .review-hero,
#wrap.os-light-mode .h-g-bg,
#wrap.os-light-mode .search-inner { background: #ffffff !important; color: #2a2a2a; }

/* Content areas */
#wrap.os-light-mode .browse-content-overview,
#wrap.os-light-mode .oscontent,
#wrap.os-light-mode main#main { background: transparent !important; }

/* Section backgrounds */
#wrap.os-light-mode section,
#wrap.os-light-mode .master-container-fluid { background: transparent !important; }

/* Input/forms */
#wrap.os-light-mode .form-control {
  background: #ffffff !important;
  color: #1a1a1a !important;
  border-color: #ccc !important;
}
#wrap.os-light-mode .form-control::placeholder { color: #888 !important; }

/* Sidebar */
#wrap.os-light-mode .sidebar { background: #ffffff !important; }
#wrap.os-light-mode .side-nav-container { background: #fff !important; }

/* Preloaders / dividers */
#wrap.os-light-mode .border-hr { border-color: #ddd !important; }

/* Search overlay */
#wrap.os-light-mode .search-inner-down { background: #fff !important; color: #1a1a1a; }
#wrap.os-light-mode .search-form .search-input { color: #1a1a1a !important; }

/* Modals */
#wrap.os-light-mode .osmodal { background: #ffffff !important; color: #1a1a1a; }
#wrap.os-light-mode .modal-header,
#wrap.os-light-mode .modal-footer { border-color: #e0e0e0 !important; }

/* Footer */
#wrap.os-light-mode .site-footer { background: #e8eaed !important; color: #2a2a2a; }

/* Misc */
#wrap.os-light-mode .title-box h4,
#wrap.os-light-mode .title-box h2 { color: #1a1a1a !important; }
#wrap.os-light-mode .os-img-box h6.title a { color: #1a1a1a; }
#wrap.os-light-mode .sub-title { color: #666 !important; }
#wrap.os-light-mode .btn-primary { color: #fff !important; }
#wrap.os-light-mode .nav-link { color: #2a2a2a !important; }
#wrap.os-light-mode .moving-border .nav-link { color: #2a2a2a !important; }
#wrap.os-light-mode .img-box-horizontal { background: #fff !important; }
#wrap.os-light-mode .threaderr { background: #ffe0e0 !important; color: #c00 !important; }
#wrap.os-light-mode .osbtn { color: #333 !important; }
#wrap.os-light-mode #theme-toggle { opacity: 1 !important; }

/* ══════════════════════════════════════════════════════════
   SOCIAL FEED PAGE
   ══════════════════════════════════════════════════════════ */

/* --- Composer --- */
.os-feed-composer {
    background-color: rgba(0, 0, 0, 0.5);
    border: 1px dotted #333;
    border-radius: 12px;
    padding: 16px;
}
.os-feed-composer-trigger {
    border-radius: 20px !important;
    background: #2a2a2a !important;
    border: none !important;
    color: #aaa !important;
    cursor: pointer;
    padding: 10px 16px !important;
}
.os-feed-composer-trigger:hover {
    background: #333 !important;
}
.os-feed-composer-actions-bar {
    border-top: 1px solid #333;
}
.os-feed-composer-expanded .form-control {
    background: #2a2a2a !important;
    border: 1px solid #444 !important;
    border-radius: 8px !important;
    color: #ddd !important;
    resize: vertical;
}
.os-feed-action-btn {
    padding: 6px 12px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 13px;
    color: #bbb;
    transition: background 0.15s;
}
.os-feed-action-btn:hover {
    background: #333;
    color: #fff;
}

/* --- Post Card --- */
.os-feed-post {
    background-color: rgba(0, 0, 0, 0.5);
    border: 1px dotted #333;
    border-radius: 12px;
    padding: 16px;
}
.os-feed-username {
    font-weight: 600;
    font-size: 14px;
    color: #E2E3E4;
}
.os-feed-username:hover {
    color: #e60000;
    text-decoration: none;
}
.os-feed-timestamp {
    font-size: 12px;
    color: #777;
    display: block;
    margin-top: 1px;
}
.os-feed-post-body {
    font-size: 14px;
    line-height: 1.55;
    color: #D5D6D6;
}
.os-feed-post-body p {
    margin-bottom: 6px;
}
.os-feed-post-body p:last-child {
    margin-bottom: 0;
}

/* --- Media in posts --- */
.os-feed-post-media {
    margin-left: -16px;
    margin-right: -16px;
}
.os-feed-media-img {
    width: 100%;
    max-height: 500px;
    object-fit: cover;
    display: block;
}

/* --- Link Preview --- */
.os-feed-link-preview {
    border: 1px solid #333;
    border-radius: 8px;
    overflow: hidden;
    cursor: pointer;
    transition: border-color 0.15s;
}
.os-feed-link-preview:hover {
    border-color: #555;
}
.os-feed-link-preview .os-feed-link-image img {
    width: 100%;
    max-height: 250px;
    object-fit: cover;
    display: block;
}
.os-feed-link-info {
    padding: 10px 14px;
    background: #1a1a1a;
}
.os-feed-link-domain {
    font-size: 11px;
    color: #777;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.os-feed-link-title {
    font-size: 14px;
    font-weight: 600;
    color: #E2E3E4;
    margin-top: 2px;
}
.os-feed-link-desc {
    font-size: 12px;
    color: #999;
    margin-top: 4px;
}

/* --- Internal link cards inside feed posts (parseLink Bootstrap .card overrides) --- */
.os-feed-post-body [class*="col-md-"] {
    max-width: 100%;
    flex: 0 0 100%;
    padding-left: 0;
    padding-right: 0;
}
.os-feed-post-body .card {
    background: #1a1a1a;
    border: 1px solid #333;
    border-radius: 8px;
    margin-top: 12px;
    margin-bottom: 4px;
}
.os-feed-post-body .card .card-body {
    display: flex;
    gap: 12px;
}
.os-feed-post-body .card .card-body img {
    flex-shrink: 0;
}
.os-feed-post-body .os-feed-link-preview {
    margin-top: 12px;
}
.os-feed-post-body .card:hover {
    border-color: #555;
}
.os-feed-post-body .card .card-body {
    padding: 12px;
}
.os-feed-post-body .card h6,
.os-feed-post-body .card .fw-semibold {
    color: #E2E3E4;
}
.os-feed-post-body .card .text-muted {
    color: #999 !important;
}
.os-feed-post-body .thpblink {
    color: inherit;
}
.os-feed-post-body .thpblink:hover {
    color: inherit;
    text-decoration: none;
}
.os-feed-post-body a {
    color: #e60000;
}
.os-feed-post-body a:hover {
    color: #ff3333;
    text-decoration: none;
}

/* --- Post Stats Row --- */
.os-feed-post-stats {
    padding: 8px 0;
    font-size: 13px;
    color: #999;
}
.os-feed-stat-likes i {
    margin-right: 4px;
}

/* --- Action Buttons --- */
.os-feed-post-actions {
    border-top: 1px solid #333;
    border-bottom: 1px solid #333;
    padding: 4px 0;
    margin-top: 8px;
    position: relative;
}
.os-feed-post-actions .osbtn {
    flex: 1;
    text-align: center;
    padding: 8px 0;
    border-radius: 6px;
    font-size: 13px;
    color: #bbb;
    cursor: pointer;
    transition: background 0.15s;
}
.os-feed-post-actions .osbtn:hover {
    background: #333;
    color: #fff;
}
.os-feed-post-actions .osbtn i {
    margin-right: 5px;
}
.os-feed-count {
    font-size: 13px;
}

/* --- Activity Posts --- */
.os-feed-post-activity {
    background-color: rgba(0, 0, 0, 0.3);
}
.os-feed-activity-text {
    color: #999;
    font-size: 14px;
    margin: 0 4px;
}
.os-feed-activity-link {
    font-weight: 600;
    color: #E2E3E4;
}
.os-feed-activity-link:hover {
    color: #e60000;
    text-decoration: none;
}

/* --- Comments Section --- */
.os-feed-comments {
    padding-top: 10px;
}
.os-feed-comments-showmore {
    padding: 4px 0 6px 0;
}
.os-feed-view-comments {
    font-size: 13px;
    color: #999;
    font-weight: 600;
}
.os-feed-view-comments:hover {
    color: #e60000;
    text-decoration: none;
}
.os-feed-comment-bubble {
    background: #2a2a2a;
    border-radius: 12px;
    padding: 8px 12px;
    display: inline-block;
}
.os-feed-comment-user {
    font-weight: 600;
    font-size: 13px;
    color: #E2E3E4;
    margin-right: 6px;
}
.os-feed-comment-user:hover {
    color: #e60000;
    text-decoration: none;
}
.os-feed-comment-text {
    font-size: 13px;
    color: #D5D6D6;
}
.os-feed-comment-meta {
    padding: 2px 12px;
    font-size: 11px;
    color: #777;
}
.os-feed-comment-meta .os-feed-comment-action {
    margin-left: 10px;
    cursor: pointer;
    font-weight: 600;
}
.os-feed-comment-meta .os-feed-comment-action:hover {
    color: #e60000;
}

/* --- Comment Input --- */
.os-feed-comment-field {
    border-radius: 20px !important;
    background: #2a2a2a !important;
    border: 1px solid #444 !important;
    color: #ddd !important;
    padding: 6px 14px !important;
    font-size: 13px !important;
    height: 34px !important;
}
.os-feed-comment-field::placeholder {
    color: #777 !important;
}
.os-feed-comment-field:focus {
    border-color: #e60000 !important;
}

/* --- Load More --- */
.os-feed-load-more {
    padding: 10px 40px;
    border-radius: 20px;
}

/* --- New Posts Banner --- */
.os-feed-new-banner {
    background: linear-gradient(135deg, #c60000, #e60000);
    color: #fff;
    text-align: center;
    padding: 10px 16px;
    border-radius: 10px;
    margin-bottom: 16px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: opacity 0.15s;
    animation: osFeedBannerPulse 2s ease-in-out infinite;
}
.os-feed-new-banner:hover {
    opacity: 0.9;
}
.os-feed-new-banner i {
    margin-right: 6px;
}
@keyframes osFeedBannerPulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(230, 0, 0, 0.4); }
    50% { box-shadow: 0 0 0 8px rgba(230, 0, 0, 0); }
}

/* --- Profile Customization Swatches --- */
.os-cust-swatch {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    cursor: pointer;
    border: 2px solid transparent;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.15s;
}
.os-cust-swatch:hover { transform: scale(1.15); }
.os-cust-swatch.os-cust-active { border-color: #fff; box-shadow: 0 0 0 2px #e60000; }
.os-cust-swatch.locked { opacity: 0.35; cursor: not-allowed; }
.os-cust-frame {
    padding: 6px 12px;
    border-radius: 8px;
    background: #2a2a2a;
    font-size: 11px;
    color: #ccc;
    cursor: pointer;
    border: 2px solid transparent;
    transition: all 0.15s;
}
.os-cust-frame:hover { background: #333; }
.os-cust-frame.os-cust-active { border-color: #e60000; color: #fff; }
.os-cust-frame.locked { opacity: 0.35; cursor: not-allowed; }
#wrap.os-light-mode .os-cust-frame { background: #f0f2f5; color: #555; }

/* --- Watch Party Items --- */
.os-feed-wp-item {
    padding: 8px 0;
    border-bottom: 1px solid #222;
}
.os-feed-wp-item:last-child { border-bottom: none; }
.os-feed-wp-countdown {
    background: linear-gradient(135deg, #e60000, #c60000);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    padding: 3px 8px;
    border-radius: 10px;
    flex-shrink: 0;
}
#wrap.os-light-mode .os-feed-wp-item { border-color: #eee; }

/* --- Challenge Items --- */
.os-feed-challenge-item {
    padding: 8px 0;
    border-bottom: 1px solid #222;
}
.os-feed-challenge-item:last-child { border-bottom: none; }
.os-feed-challenge-item.completed { opacity: 0.7; }

/* --- Poll Widget --- */
.os-feed-poll-question {
    font-size: 14px;
    font-weight: 600;
    color: #E2E3E4;
    margin-bottom: 10px;
    line-height: 1.4;
}
.os-feed-poll-option {
    display: block;
    width: 100%;
    padding: 8px 12px;
    margin-bottom: 6px;
    background: #2a2a2a;
    border: 1px solid #444;
    border-radius: 8px;
    color: #ddd;
    font-size: 13px;
    cursor: pointer;
    transition: all 0.15s;
    text-align: left;
}
.os-feed-poll-option:hover {
    background: #333;
    border-color: #e60000;
    color: #fff;
}
.os-feed-poll-result {
    position: relative;
    padding: 8px 12px;
    margin-bottom: 6px;
    background: #2a2a2a;
    border-radius: 8px;
    overflow: hidden;
    font-size: 13px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.os-feed-poll-result.my-vote {
    border: 1px solid #e60000;
}
.os-feed-poll-bar {
    position: absolute;
    left: 0;
    top: 0;
    height: 100%;
    background: rgba(230, 0, 0, 0.15);
    border-radius: 8px;
    transition: width 0.5s ease;
}
.os-feed-poll-label {
    position: relative;
    z-index: 1;
    color: #ddd;
}
.os-feed-poll-pct {
    position: relative;
    z-index: 1;
    font-weight: 600;
    color: #E2E3E4;
    font-size: 12px;
}
.os-feed-poll-meta {
    margin-top: 8px;
    font-size: 11px;
    color: #777;
}
.os-feed-poll-announce {
    padding: 4px 0;
    color: #f39c12;
}
#wrap.os-light-mode .os-feed-poll-question { color: #1a1a1a; }
#wrap.os-light-mode .os-feed-poll-option { background: #f0f2f5; border-color: #ddd; color: #333; }
#wrap.os-light-mode .os-feed-poll-option:hover { background: #e4e6eb; }
#wrap.os-light-mode .os-feed-poll-result { background: #f0f2f5; }
#wrap.os-light-mode .os-feed-poll-label { color: #333; }
#wrap.os-light-mode .os-feed-poll-pct { color: #1a1a1a; }
#wrap.os-light-mode .os-feed-poll-bar { background: rgba(230, 0, 0, 0.1); }

/* --- What's New Banner --- */
.os-feed-whatsnew {
    background: linear-gradient(135deg, rgba(243,156,18,0.15), rgba(230,0,0,0.1));
    border: 1px solid rgba(243,156,18,0.3);
    border-radius: 10px;
    padding: 12px 16px;
    font-size: 13px;
    color: #E2E3E4;
}
.os-feed-whatsnew-close {
    cursor: pointer;
    color: #777;
    font-size: 18px;
    line-height: 1;
}
.os-feed-whatsnew-close:hover { color: #fff; }
#wrap.os-light-mode .os-feed-whatsnew {
    background: linear-gradient(135deg, rgba(243,156,18,0.1), rgba(230,0,0,0.05));
    border-color: rgba(243,156,18,0.2);
    color: #333;
}

/* --- Daily Reward Card --- */
.os-daily-reward-card {
    background: #1a1a1a;
    border: 1px solid #333;
    border-radius: 16px;
    padding: 30px 40px;
    text-align: center;
    max-width: 360px;
    box-shadow: 0 8px 32px rgba(0,0,0,0.5);
    animation: osDailyBounce 0.4s ease;
}
.os-daily-reward-card h5 {
    color: #E2E3E4;
    margin-top: 12px;
}
.os-daily-reward-icon {
    font-size: 48px;
    color: #f39c12;
    animation: osDailyPulse 1.5s ease-in-out infinite;
}
@keyframes osDailyBounce {
    0% { transform: scale(0.8); opacity: 0; }
    100% { transform: scale(1); opacity: 1; }
}
@keyframes osDailyPulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.1); }
}
#wrap.os-light-mode .os-daily-reward-card {
    background: #fff;
    border-color: #e0e0e0;
}
#wrap.os-light-mode .os-daily-reward-card h5 {
    color: #1a1a1a;
}

/* --- XP Progress Bar --- */
.os-feed-xp-progress {
    height: 4px;
    background: #2a2a2a;
    border-radius: 2px;
    overflow: hidden;
}
.os-feed-xp-fill {
    height: 100%;
    background: linear-gradient(90deg, #e60000, #ff6b6b);
    border-radius: 2px;
    transition: width 0.5s ease;
}

/* --- XP Toast --- */
.os-feed-xp-toast {
    position: fixed;
    bottom: 80px;
    left: 50%;
    transform: translateX(-50%);
    background: linear-gradient(135deg, #f39c12, #e67e22);
    color: #fff;
    padding: 8px 20px;
    border-radius: 20px;
    font-size: 14px;
    font-weight: 700;
    z-index: 99999;
    box-shadow: 0 4px 12px rgba(0,0,0,0.3);
}
.os-feed-xp-toast i { margin-right: 4px; }
#wrap.os-light-mode .os-feed-xp-progress {
    background: #e8e8e8;
}

/* --- User Activity Status Dot --- */
.os-feed-status-dot {
    position: absolute;
    bottom: 1px;
    right: 1px;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    border: 2px solid #1a1a1a;
}
.os-feed-status-dot.online {
    background: #3fb950;
}
.os-feed-status-dot.recently {
    background: #d29922;
}
#wrap.os-light-mode .os-feed-status-dot {
    border-color: #fff;
}

/* --- User Profile Popup --- */
.os-feed-user-popup {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 420px;
    max-width: 95vw;
    max-height: 85vh;
    overflow-y: auto;
    background: #1a1a1a;
    border: 1px solid #333;
    border-radius: 12px;
    box-shadow: 0 8px 32px rgba(0,0,0,0.6);
    z-index: 10000;
    padding: 20px;
}
.os-feed-popup-close {
    position: absolute;
    top: 12px;
    right: 16px;
    font-size: 22px;
    color: #777;
    cursor: pointer;
    line-height: 1;
}
.os-feed-popup-close:hover { color: #fff; }
.os-feed-popup-username {
    font-size: 16px;
    font-weight: 700;
    color: #E2E3E4;
}
.os-feed-popup-username:hover { color: #e60000; text-decoration: none; }
.os-feed-popup-stats {
    font-size: 12px;
    color: #999;
}
.os-feed-popup-stats span {
    margin-right: 12px;
}
.os-feed-popup-stats strong {
    color: #E2E3E4;
}
.os-feed-popup-section {
    margin-top: 14px;
    padding-top: 12px;
    border-top: 1px solid #2a2a2a;
}
.os-feed-popup-section-title {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: #777;
    margin-bottom: 8px;
}
.os-feed-popup-titles {
    display: flex;
    gap: 10px;
    overflow-x: auto;
    padding-bottom: 6px;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
}
.os-feed-popup-titles::-webkit-scrollbar { height: 3px; }
.os-feed-popup-titles::-webkit-scrollbar-thumb { background: #444; border-radius: 2px; }
.os-feed-popup-title-card {
    flex: 0 0 70px;
    scroll-snap-align: start;
    text-align: center;
    text-decoration: none;
    position: relative;
}
.os-feed-popup-title-card:hover { text-decoration: none; }
.os-feed-popup-title-card img {
    width: 70px;
    height: 95px;
    object-fit: cover;
    border-radius: 6px;
    display: block;
    margin-bottom: 4px;
}
.os-feed-popup-title-card span {
    display: block;
    font-size: 10px;
    color: #ccc;
    line-height: 1.2;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 70px;
}
.os-feed-popup-title-card:hover span { color: #e60000; }
.os-feed-popup-ep {
    position: absolute;
    top: 4px;
    right: 4px;
    background: rgba(0,0,0,0.75);
    color: #fff;
    font-size: 9px;
    padding: 1px 4px;
    border-radius: 3px;
}
.os-feed-popup-compat {
    font-size: 12px;
    color: #ccc;
    padding: 6px 10px;
    background: rgba(230,0,0,0.08);
    border-radius: 8px;
}
.os-feed-popup-footer {
    margin-top: 14px;
    padding-top: 12px;
    border-top: 1px solid #2a2a2a;
}

/* --- Share Dropdown --- */
.os-feed-share-dropdown {
    position: absolute;
    bottom: 100%;
    right: 0;
    background: #222;
    border: 1px solid #444;
    border-radius: 8px;
    padding: 6px 0;
    min-width: 180px;
    box-shadow: 0 -4px 16px rgba(0,0,0,0.4);
    z-index: 100;
    margin-bottom: 6px;
}
.os-feed-share-dropdown a {
    display: block;
    padding: 8px 14px;
    font-size: 13px;
    color: #ddd;
    text-decoration: none;
    transition: background 0.1s;
}
.os-feed-share-dropdown a:hover {
    background: #333;
    color: #fff;
    text-decoration: none;
}
.os-feed-share-dropdown a i {
    width: 20px;
    text-align: center;
    margin-right: 8px;
}
.os-feed-share-dropdown a .fa-x-twitter { color: #fff; }
.os-feed-share-dropdown a .fa-facebook { color: #1877f2; }
.os-feed-share-dropdown a .fa-discord { color: #5865f2; }
.os-feed-share-dropdown a .fa-link { color: #e60000; }
#wrap.os-light-mode .os-feed-share-dropdown {
    background: #fff;
    border-color: #ddd;
    box-shadow: 0 -4px 16px rgba(0,0,0,0.1);
}
#wrap.os-light-mode .os-feed-share-dropdown a {
    color: #333;
}
#wrap.os-light-mode .os-feed-share-dropdown a:hover {
    background: #f0f2f5;
}

/* --- Share Toast --- */
.os-feed-share-toast {
    position: fixed;
    bottom: 30px;
    left: 50%;
    transform: translateX(-50%);
    background: #3fb950;
    color: #fff;
    padding: 10px 24px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    z-index: 99999;
    box-shadow: 0 4px 12px rgba(0,0,0,0.3);
}
.os-feed-share-toast i { margin-right: 6px; }

/* --- @Mention Autocomplete --- */
.os-feed-mention-dropdown {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 100%;
    background: #222;
    border: 1px solid #444;
    border-radius: 8px;
    max-height: 240px;
    overflow-y: auto;
    z-index: 1000;
    box-shadow: 0 -4px 16px rgba(0,0,0,0.4);
    margin-bottom: 4px;
}
.os-feed-mention-item {
    padding: 8px 12px;
    cursor: pointer;
    font-size: 13px;
    color: #ddd;
    display: flex;
    align-items: center;
}
.os-feed-mention-item:hover {
    background: #333;
    color: #fff;
}
.os-feed-mention {
    color: #e60000;
    font-weight: 600;
    text-decoration: none;
}
.os-feed-mention:hover {
    color: #ff3333;
    text-decoration: none;
}

/* --- Shoutbox link cards --- */
.sb-msg-body .card {
    background: #1a1a1a;
    border: 1px solid #333;
    border-radius: 8px;
    margin-top: 6px;
}
.sb-msg-body .card:hover {
    border-color: #555;
}
.sb-msg-body .card .card-body {
    padding: 10px;
    display: flex;
    gap: 10px;
}
.sb-msg-body .card h6,
.sb-msg-body .card .fw-semibold {
    color: #E2E3E4;
    font-size: 13px;
}
.sb-msg-body .card .text-muted {
    color: #999 !important;
    font-size: 12px;
}
.sb-msg-body .thpblink {
    color: inherit;
}
.sb-msg-body .thpblink:hover {
    text-decoration: none;
}
.sb-msg-body [class*="col-md-"] {
    max-width: 100%;
    flex: 0 0 100%;
    padding: 0;
}
#wrap.os-light-mode .sb-msg-body .card {
    background: #fff;
    border-color: #e0e0e0;
}
#wrap.os-light-mode .sb-msg-body .card h6,
#wrap.os-light-mode .sb-msg-body .card .fw-semibold {
    color: #1a1a1a;
}

/* --- Feed User Badges --- */
.os-feed-badge-group {
    background: #333;
    color: #ccc;
    font-size: 10px;
    font-weight: 600;
    padding: 2px 6px;
    border-radius: 3px;
}
.os-feed-badge-system {
    background: #58a6ff;
    color: #fff;
    font-size: 10px;
    font-weight: 600;
    padding: 2px 6px;
    border-radius: 3px;
}
#wrap.os-light-mode .os-feed-badge-group {
    background: #e8e8e8;
    color: #555;
}

/* --- Suggested Label --- */
.os-feed-suggested-label {
    font-size: 11px;
    color: #999;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    margin-left: 6px;
}

/* --- Upload Digest Slider --- */
.os-feed-upload-digest {
    padding: 4px 0;
}
.os-feed-upload-digest strong {
    font-size: 14px;
    color: #E2E3E4;
}
.os-feed-upload-slider {
    display: flex;
    gap: 12px;
    overflow-x: auto;
    padding: 12px 0 8px 0;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
}
.os-feed-upload-slider::-webkit-scrollbar {
    height: 4px;
}
.os-feed-upload-slider::-webkit-scrollbar-track {
    background: transparent;
}
.os-feed-upload-slider::-webkit-scrollbar-thumb {
    background: #444;
    border-radius: 2px;
}
.os-feed-upload-card {
    flex: 0 0 120px;
    scroll-snap-align: start;
    text-decoration: none;
    text-align: center;
    transition: transform 0.15s;
}
.os-feed-upload-card:hover {
    transform: translateY(-2px);
    text-decoration: none;
}
.os-feed-upload-card img {
    width: 120px;
    height: 170px;
    object-fit: cover;
    border-radius: 8px;
    display: block;
    margin-bottom: 6px;
}
.os-feed-upload-card-title {
    display: block;
    font-size: 12px;
    font-weight: 600;
    color: #D5D6D6;
    line-height: 1.3;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 120px;
}
.os-feed-upload-card:hover .os-feed-upload-card-title {
    color: #e60000;
}
.os-feed-upload-card-ep {
    display: block;
    font-size: 11px;
    color: #999;
    margin-top: 2px;
}

/* --- Left Sidebar --- */
.os-feed-sidebar {
    position: sticky;
    top: 80px;
}
.os-feed-sidebar-card {
    background: rgba(0, 0, 0, 0.5);
    border: 1px dotted #333;
    border-radius: 12px;
    padding: 14px;
}
.os-feed-sidebar-title {
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: #777;
    margin-bottom: 10px;
}
.os-feed-sidebar-link {
    display: block;
    padding: 8px 10px;
    border-radius: 8px;
    font-size: 13px;
    color: #D5D6D6;
    transition: background 0.15s;
}
.os-feed-sidebar-link:hover,
.os-feed-sidebar-link.active {
    background: #2a2a2a;
    color: #fff;
    text-decoration: none;
}
.os-feed-sidebar-link i {
    width: 20px;
    text-align: center;
    margin-right: 8px;
    color: #999;
}
.os-feed-sidebar-link.active i {
    color: #e60000;
}
.os-feed-sidebar-tag {
    display: inline-block;
    padding: 4px 10px;
    margin: 0 4px 6px 0;
    border-radius: 12px;
    font-size: 12px;
    background: #2a2a2a;
    color: #ccc;
    transition: background 0.15s;
}
.os-feed-sidebar-tag:hover {
    background: #e60000;
    color: #fff;
    text-decoration: none;
}
.os-feed-sidebar-user-name {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: #E2E3E4;
    line-height: 1.2;
}
.os-feed-sidebar-user-name:hover {
    color: #e60000;
    text-decoration: none;
}
.os-feed-sidebar-user-meta {
    font-size: 11px;
    color: #777;
}
.os-feed-follow-btn {
    font-size: 11px;
    padding: 2px 10px;
    border-radius: 12px;
}
.os-feed-sidebar-stat {
    padding: 6px 0;
    font-size: 13px;
    color: #999;
}
.os-feed-sidebar-stat i {
    width: 18px;
    text-align: center;
    margin-right: 6px;
    color: #777;
}

/* --- Responsive --- */
@media (max-width: 767px) {
    .os-feed-post, .os-feed-composer {
        border-radius: 0;
        border-left: none;
        border-right: none;
        margin-left: -15px;
        margin-right: -15px;
        padding: 14px;
    }
    .os-feed-post-media {
        margin-left: -14px;
        margin-right: -14px;
    }
    .os-feed-post-actions .osbtn {
        font-size: 12px;
    }
}

/* ══════════════════════════════════════════════════════════
   SOCIAL FEED — LIGHT MODE OVERRIDES
   ══════════════════════════════════════════════════════════ */
#wrap.os-light-mode .os-feed-composer,
#wrap.os-light-mode .os-feed-post {
    background: #ffffff !important;
    border: 1px solid #e0e0e0 !important;
}
#wrap.os-light-mode .os-feed-composer-trigger {
    background: #f0f2f5 !important;
    color: #666 !important;
}
#wrap.os-light-mode .os-feed-composer-trigger:hover {
    background: #e4e6eb !important;
}
#wrap.os-light-mode .os-feed-composer-expanded .form-control {
    background: #f0f2f5 !important;
    border-color: #ccc !important;
    color: #1a1a1a !important;
}
#wrap.os-light-mode .os-feed-username,
#wrap.os-light-mode .os-feed-comment-user,
#wrap.os-light-mode .os-feed-activity-link,
#wrap.os-light-mode .os-feed-link-title {
    color: #1a1a1a !important;
}
#wrap.os-light-mode .os-feed-post-body,
#wrap.os-light-mode .os-feed-comment-text {
    color: #333 !important;
}
#wrap.os-light-mode .os-feed-comment-bubble {
    background: #f0f2f5 !important;
}
#wrap.os-light-mode .os-feed-post-actions {
    border-color: #e0e0e0 !important;
}
#wrap.os-light-mode .os-feed-post-actions .osbtn {
    color: #555 !important;
}
#wrap.os-light-mode .os-feed-post-actions .osbtn:hover {
    background: #f0f2f5 !important;
    color: #1a1a1a !important;
}
#wrap.os-light-mode .os-feed-comment-field {
    background: #f0f2f5 !important;
    border-color: #ccc !important;
    color: #1a1a1a !important;
}
#wrap.os-light-mode .os-feed-link-info {
    background: #f0f2f5 !important;
}
#wrap.os-light-mode .os-feed-link-preview {
    border-color: #e0e0e0 !important;
}
#wrap.os-light-mode .os-feed-post-body .card {
    background: #fff !important;
    border-color: #e0e0e0 !important;
}
#wrap.os-light-mode .os-feed-post-body .card h6,
#wrap.os-light-mode .os-feed-post-body .card .fw-semibold {
    color: #1a1a1a !important;
}
#wrap.os-light-mode .os-feed-post-body a {
    color: #c60000 !important;
}
#wrap.os-light-mode .os-feed-composer-actions-bar {
    border-color: #e0e0e0 !important;
}
#wrap.os-light-mode .os-feed-action-btn {
    color: #555 !important;
}
#wrap.os-light-mode .os-feed-action-btn:hover {
    background: #e4e6eb !important;
    color: #1a1a1a !important;
}
#wrap.os-light-mode .os-feed-post-activity {
    background: #f7f8fa !important;
}
#wrap.os-light-mode .os-feed-sidebar-card {
    background: #ffffff !important;
    border: 1px solid #e0e0e0 !important;
}
#wrap.os-light-mode .os-feed-sidebar-link {
    color: #333 !important;
}
#wrap.os-light-mode .os-feed-sidebar-link:hover,
#wrap.os-light-mode .os-feed-sidebar-link.active {
    background: #f0f2f5 !important;
    color: #1a1a1a !important;
}
#wrap.os-light-mode .os-feed-sidebar-tag {
    background: #f0f2f5 !important;
    color: #555 !important;
}
#wrap.os-light-mode .os-feed-sidebar-user-name {
    color: #1a1a1a !important;
}
#wrap.os-light-mode .os-feed-user-popup {
    background: #fff !important;
    border-color: #e0e0e0 !important;
}
#wrap.os-light-mode .os-feed-popup-username,
#wrap.os-light-mode .os-feed-popup-stats strong {
    color: #1a1a1a !important;
}
#wrap.os-light-mode .os-feed-popup-section {
    border-color: #eee !important;
}
#wrap.os-light-mode .os-feed-popup-title-card span {
    color: #555 !important;
}
#wrap.os-light-mode .os-feed-popup-footer {
    border-color: #eee !important;
}
#wrap.os-light-mode .os-feed-mention-dropdown {
    background: #fff !important;
    border-color: #ddd !important;
    box-shadow: 0 -4px 16px rgba(0,0,0,0.1) !important;
}
#wrap.os-light-mode .os-feed-mention-item {
    color: #333 !important;
}
#wrap.os-light-mode .os-feed-mention-item:hover {
    background: #f0f2f5 !important;
}
#wrap.os-light-mode .os-feed-upload-digest strong {
    color: #1a1a1a !important;
}
#wrap.os-light-mode .os-feed-upload-card-title {
    color: #333 !important;
}
#wrap.os-light-mode .os-feed-upload-slider::-webkit-scrollbar-thumb {
    background: #ccc !important;
}

/* ── Parsed link cards in discussion threads (dark mode default) ── */
.ospost-content .card {
    background: #1a1a1a;
    border: 1px solid #333;
    border-radius: 8px;
    margin-top: 8px;
    margin-bottom: 8px;
}
.ospost-content .card .card-body {
    padding: 12px;
}
.ospost-content .card h6,
.ospost-content .card .fw-semibold {
    color: #E2E3E4;
}
.ospost-content .card .text-muted {
    color: #999 !important;
}
.ospost-content .thpblink {
    color: inherit;
    text-decoration: none;
}
.ospost-content .thpblink:hover {
    color: inherit;
    text-decoration: none;
}
.ospost-content .thpblink:hover .card {
    border-color: #555;
    background: #222;
}

/* ── Parsed link cards in discussion threads (light mode) ── */
#wrap.os-light-mode .ospost-content .card {
    background: #fff;
    border-color: #e0e0e0;
}
#wrap.os-light-mode .ospost-content .card h6,
#wrap.os-light-mode .ospost-content .card .fw-semibold {
    color: #1a1a1a;
}
#wrap.os-light-mode .ospost-content .card .text-muted {
    color: #666 !important;
}
#wrap.os-light-mode .ospost-content .thpblink:hover .card {
    border-color: #ccc;
    background: #f8f8f8;
}

/* ══════════════════════════════════════════
   Airing Today sidebar widget (global)
   ══════════════════════════════════════════ */
.os-at-title-inner{display:flex;align-items:center;gap:7px}
.os-at-pulse{display:inline-block;width:7px;height:7px;border-radius:50%;background:#e60000;box-shadow:0 0 0 0 rgba(230,0,0,0.6);animation:os-at-pulse-ring 2s ease-out infinite;flex-shrink:0}
@keyframes os-at-pulse-ring{0%{box-shadow:0 0 0 0 rgba(230,0,0,0.55)}60%{box-shadow:0 0 0 5px rgba(230,0,0,0)}100%{box-shadow:0 0 0 0 rgba(230,0,0,0)}}
.os-at-list{display:flex;flex-direction:column;gap:1px}
.os-at-item{display:flex;align-items:center;gap:9px;padding:7px 5px;border-radius:7px;text-decoration:none;color:inherit;transition:background .12s;position:relative}
.os-at-item:hover{background:rgba(255,255,255,0.04);text-decoration:none;color:inherit}
.os-at-item--live{background:rgba(230,0,0,0.05)}
.os-at-item--live:hover{background:rgba(230,0,0,0.08)}
.os-at-thumb{width:36px;height:50px;border-radius:5px;overflow:hidden;flex-shrink:0;position:relative;background:#111}
.os-at-thumb img{width:100%;height:100%;object-fit:cover}
.os-at-live-badge{position:absolute;bottom:2px;left:0;right:0;text-align:center;font-size:7.5px;font-weight:800;letter-spacing:.5px;background:#e60000;color:#fff;padding:1px 0}
.os-at-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}
.os-at-name{font-size:11.5px;font-weight:600;color:#b8babc;line-height:1.3;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;transition:color .12s}
.os-at-item:hover .os-at-name{color:#edeeef}
.os-at-item--live .os-at-name{color:#edeeef}
.os-at-time{display:flex;align-items:center;gap:4px;font-size:10px;color:#8e9194}
.os-at-time i{font-size:9px}
em.os-at-on-air{font-style:normal;font-size:8.5px;font-weight:700;color:#e60000;background:rgba(230,0,0,0.1);border-radius:3px;padding:1px 4px;letter-spacing:.3px;text-transform:uppercase;margin-left:2px}
.os-at-arrow{font-size:8px;color:#444;flex-shrink:0;transition:color .12s,transform .12s}
.os-at-item:hover .os-at-arrow{color:#666;transform:translateX(2px)}

/* ══════════════════════════════════════════
   Donator list pagination
   ══════════════════════════════════════════ */
.os-donlist-pager{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 4px 2px;border-top:1px solid rgba(255,255,255,0.06);margin-top:8px}
.os-donlist-prev,.os-donlist-next{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:6px;border:1px solid rgba(255,255,255,0.08);background:#111;color:#8e9194;cursor:pointer;font-size:10px;transition:all .15s}
.os-donlist-prev:hover:not(:disabled),.os-donlist-next:hover:not(:disabled){background:rgba(255,255,255,0.08);color:#edeeef;border-color:rgba(255,255,255,0.14)}
.os-donlist-prev:disabled,.os-donlist-next:disabled{opacity:.3;cursor:default}
.os-donlist-pageinfo{font-size:10px;color:#8e9194;font-weight:600;min-width:40px;text-align:center}

/* === @mention links + autocomplete === */
a.mention,span.mention{color:#ff5050;font-weight:600;text-decoration:none}
a.mention:hover{color:#ff7777;text-decoration:none}
.mention-dropdown{list-style:none;margin:0;padding:4px 0;background:#1b1b1b;border:1px solid #2c2c2c;border-radius:8px;box-shadow:0 6px 24px rgba(0,0,0,.45);max-height:260px;overflow:auto;display:none;z-index:100000}
.mention-dropdown__item{display:flex;align-items:center;gap:10px;padding:6px 12px;cursor:pointer;color:#ddd;font-size:13px;line-height:1.3;white-space:nowrap}
.mention-dropdown__item.is-active,.mention-dropdown__item:hover{background:#2a2a2a;color:#fff}
.mention-dropdown__avatar{width:24px;height:24px;border-radius:50%;object-fit:cover;flex:none}
.mention-dropdown__name{font-weight:500}

/* ── Search Typeahead Dropdown (.os-search-ac-*) ─────────────────────── */
.os-search-ac-dropdown{
    position:absolute;
    z-index:9999;
    list-style:none;
    margin:0;
    padding:4px 0;
    background:#1b1b1b;
    border:1px solid #2c2c2c;
    border-radius:8px;
    box-shadow:0 8px 28px rgba(0,0,0,.55);
    max-height:360px;
    overflow-y:auto;
    display:none;
}
.os-search-ac-item{
    display:flex;
    align-items:center;
    gap:10px;
    padding:8px 12px;
    cursor:pointer;
    color:#ddd;
    font-size:13px;
    line-height:1.3;
    transition:background .1s;
}
.os-search-ac-item.is-active,
.os-search-ac-item:hover{ background:#2a2a2a; color:#fff; }
.os-search-ac-thumb{
    width:40px;
    height:56px;
    object-fit:cover;
    border-radius:4px;
    flex:none;
    background:#111;
}
.os-search-ac-info{ display:flex; flex-direction:column; gap:3px; min-width:0; }
.os-search-ac-title{
    font-weight:600;
    font-size:13px;
    color:inherit;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
}
.os-search-ac-meta{ font-size:11px; color:#888; }
.os-search-ac-item.is-active .os-search-ac-meta,
.os-search-ac-item:hover .os-search-ac-meta{ color:#bbb; }
/* Light mode — dropdown is appended to document.body (outside #wrap), so
   #wrap.os-light-mode cannot reach it. The theme JS also adds os-light-mode
   to <body>, so we target body.os-light-mode here instead. */
body.os-light-mode .os-search-ac-dropdown{ background:#fff; border-color:#e0e0e0; box-shadow:0 8px 28px rgba(0,0,0,.12); }
body.os-light-mode .os-search-ac-item{ color:#333; }
body.os-light-mode .os-search-ac-item.is-active,
body.os-light-mode .os-search-ac-item:hover{ background:#f4f4f4; color:#111; }
body.os-light-mode .os-search-ac-meta{ color:#888; }

/* ============================================================
   HOME · Recent Discussions + Recent Reviews  (editorial dark)
   Namespace: .osh-*
   ============================================================ */
.osh-section,
.osh-section * { box-sizing: border-box; }
.osh-section {
    --osh-bg:          #0a0a0a;
    --osh-card:        #141414;
    --osh-card-hi:     #181818;
    --osh-border:      rgba(255,255,255,0.06);
    --osh-border-hi:   rgba(255,255,255,0.12);
    --osh-text:        #ededed;
    --osh-muted:       #8a8a8a;
    --osh-dim:         #4a4a4a;
    --osh-accent:      #e60000;
    --osh-accent-soft: rgba(230,0,0,0.14);
    --osh-star:        #ffb648;
    position: relative;
    padding: 56px 0 64px;
    color: var(--osh-text);
}
.osh-section + .osh-section { border-top: 1px solid var(--osh-border); }

.osh-head { margin-bottom: 32px; }
.osh-kicker {
    display: inline-flex; align-items: center; gap: 10px;
    font-size: 11px; font-weight: 600;
    letter-spacing: 0.22em; text-transform: uppercase;
    color: var(--osh-muted);
    margin-bottom: 14px;
}
.osh-kicker-dot {
    width: 7px; height: 7px; border-radius: 50%;
    background: var(--osh-accent);
    box-shadow: 0 0 0 0 rgba(230,0,0,0.45);
    animation: osh-pulse 2.2s ease-in-out infinite;
}
@keyframes osh-pulse {
    0%,100% { box-shadow: 0 0 0 0 rgba(230,0,0,0.5); }
    50%     { box-shadow: 0 0 0 6px rgba(230,0,0,0);  }
}
.osh-head-row {
    display: flex; align-items: baseline; justify-content: space-between;
    gap: 24px; flex-wrap: wrap;
}
.osh-title {
    font-weight: 700;
    font-size: clamp(1.75rem, 3.5vw, 2.5rem);
    line-height: 1.1;
    color: #fff;
    margin: 0;
    letter-spacing: -0.01em;
}
.osh-title-dot { color: var(--osh-accent); }
.osh-more {
    display: inline-flex; align-items: center; gap: 10px;
    font-size: 12px; font-weight: 600;
    letter-spacing: 0.12em; text-transform: uppercase;
    color: var(--osh-muted); text-decoration: none;
    padding: 10px 16px; border: 1px solid var(--osh-border);
    border-radius: 999px; transition: color .2s, border-color .2s, background .2s;
}
.osh-more:hover {
    color: #fff; border-color: var(--osh-accent); background: var(--osh-accent-soft);
    text-decoration: none;
}
.osh-more svg { transition: transform .25s ease; }
.osh-more:hover svg { transform: translateX(4px); }

.osh-grid {
    display: grid !important;
    gap: 16px;
    grid-template-columns: 1fr;
}
@media (min-width: 540px) {
    .osh-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; }
}
@media (min-width: 900px) {
    .osh-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (min-width: 1280px) {
    .osh-grid--discuss { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}
.osh-card {
    position: relative;
    background: var(--osh-card);
    border: 1px solid var(--osh-border);
    border-radius: 14px;
    padding: 22px 22px 18px;
    display: flex; flex-direction: column;
    min-height: 220px;
    overflow: hidden;
    transition: background .2s, border-color .2s, transform .25s cubic-bezier(.2,.7,.2,1);
    opacity: 0; animation: osh-rise .5s cubic-bezier(.2,.7,.2,1) forwards;
    animation-delay: calc(var(--osh-i, 1) * 35ms);
}
.osh-card:hover {
    background: var(--osh-card-hi);
    border-color: var(--osh-border-hi);
    transform: translateY(-3px);
}
@keyframes osh-rise {
    from { opacity: 0; transform: translateY(14px); }
    to   { opacity: 1; transform: translateY(0); }
}
.osh-edge {
    position: absolute; left: 0; top: 18px; bottom: 18px; width: 2px;
    background: var(--osh-accent);
    transform: scaleY(0); transform-origin: top;
    transition: transform .28s cubic-bezier(.2,.7,.2,1);
}
.osh-card:hover .osh-edge { transform: scaleY(1); }

.osh-card-num {
    position: absolute; top: 16px; right: 20px;
    font-size: 13px; font-weight: 700;
    color: var(--osh-dim);
    letter-spacing: 0.08em;
    transition: color .2s;
}
.osh-card:hover .osh-card-num { color: var(--osh-accent); }

.osh-card-title {
    font-weight: 700;
    font-size: 1.05rem;
    line-height: 1.3;
    color: #f4f4f4;
    text-decoration: none;
    letter-spacing: -0.005em;
    margin: 4px 40px 10px 0;
    display: -webkit-box;
    -webkit-line-clamp: 2; -webkit-box-orient: vertical;
    overflow: hidden;
    transition: color .2s;
}
.osh-card-title:hover { color: #fff; text-decoration: none; }
.osh-card:hover .osh-card-title { color: #fff; }

.osh-card-excerpt {
    color: var(--osh-muted);
    font-size: 13px; line-height: 1.55;
    margin: 0 0 18px;
    display: -webkit-box;
    -webkit-line-clamp: 3; -webkit-box-orient: vertical;
    overflow: hidden;
}
.osh-card--review .osh-card-excerpt {
    position: relative;
    padding-left: 16px;
}

.osh-card-meta {
    margin-top: auto;
    display: flex; align-items: center; gap: 8px;
    font-size: 11px;
    color: var(--osh-muted);
    padding-top: 14px;
    border-top: 1px solid var(--osh-border);
}
.osh-avatar {
    width: 22px; height: 22px; border-radius: 50%;
    object-fit: cover; flex: none;
    border: 1px solid var(--osh-border);
}
.osh-by,
.osh-by:visited {
    color: var(--osh-text);
    font-weight: 500;
    text-decoration: none;
    letter-spacing: 0.01em;
    max-width: 120px;
    overflow: hidden; white-space: nowrap; text-overflow: ellipsis;
}
.osh-by:hover { color: var(--osh-accent); text-decoration: none; }
.osh-by-label {
    color: var(--osh-dim); font-size: 10px;
    letter-spacing: 0.04em;
}
.osh-meta-dot { color: var(--osh-dim); }
.osh-time { color: var(--osh-muted); letter-spacing: 0.02em; }

.osh-chip {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 3px 9px; border-radius: 999px;
    font-size: 10.5px; font-weight: 600;
    letter-spacing: 0.06em;
    border: 1px solid var(--osh-border);
    color: var(--osh-muted);
}
.osh-chip--accent { color: #ff6767; border-color: rgba(230,0,0,0.35); background: var(--osh-accent-soft); }
.osh-chip svg { opacity: 0.9; }

.osh-card--review {
    display: grid;
    grid-template-columns: 92px 1fr;
    gap: 16px;
    padding: 16px;
    min-height: 0;
    align-items: stretch;
}
.osh-review-cover {
    position: relative;
    display: block;
    width: 92px;
    aspect-ratio: 11 / 16;
    border-radius: 8px;
    overflow: hidden;
    background: #000;
    align-self: start;
}
.osh-review-cover img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform .5s cubic-bezier(.2,.7,.2,1), filter .3s;
    filter: saturate(0.95);
}
.osh-card--review:hover .osh-review-cover img { transform: scale(1.05); filter: saturate(1.15); }
.osh-review-cover::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(10,10,10,0) 50%, rgba(10,10,10,0.75) 100%);
    pointer-events: none;
}
.osh-review-rating {
    position: absolute; left: 6px; bottom: 6px; z-index: 2;
    display: inline-flex; align-items: baseline;
    font-weight: 700;
    font-size: 16px; line-height: 1;
    color: #fff;
    padding: 4px 8px; border-radius: 6px;
    background: rgba(230,0,0,0.88);
    letter-spacing: -0.01em;
}
.osh-rating-max {
    font-size: 9px; font-weight: 600;
    color: rgba(255,255,255,0.75); margin-left: 2px; letter-spacing: 0.05em;
}
.osh-review-body {
    display: flex; flex-direction: column;
    min-width: 0;
    padding: 0;
    flex: 1;
}
.osh-stars {
    display: inline-flex; gap: 2px;
    font-size: 12px; line-height: 1;
    margin: 0 0 6px;
    letter-spacing: 1px;
}
.osh-star { color: var(--osh-dim); }
.osh-star.is-on { color: var(--osh-star); filter: drop-shadow(0 0 2px rgba(245,179,1,0.3)); }
.osh-card--review .osh-card-title {
    font-size: 1rem;
    margin: 0 0 8px;
    -webkit-line-clamp: 2;
}
.osh-card--review .osh-card-excerpt {
    font-size: 12.5px;
    line-height: 1.5;
    -webkit-line-clamp: 3;
    padding-left: 14px;
    margin: 0 0 12px;
}
.osh-quote {
    color: var(--osh-accent);
    font-size: 1.6em;
    font-weight: 700;
    position: absolute; left: -3px; top: -4px;
    line-height: 1;
}
.osh-card--review .osh-card-meta {
    padding: 10px 0 0;
    border-top-color: var(--osh-border);
    font-size: 10.5px;
}
.osh-card--review .osh-avatar { width: 20px; height: 20px; }

.osh-empty {
    padding: 48px 24px; text-align: center;
    color: var(--osh-muted); font-size: 1rem;
    border: 1px dashed var(--osh-border); border-radius: 12px;
}

#wrap.os-light-mode .osh-section {
    --osh-card:      #ffffff;
    --osh-card-hi:   #f5f5f5;
    --osh-border:    rgba(0,0,0,0.08);
    --osh-border-hi: rgba(0,0,0,0.16);
    --osh-text:      #151515;
    --osh-muted:     #666;
    --osh-dim:       #aaa;
}
#wrap.os-light-mode .osh-title { color: #111; }
#wrap.os-light-mode .osh-card-title,
#wrap.os-light-mode .osh-card:hover .osh-card-title { color: #111; }

@media (max-width: 539px) {
    .osh-section { padding: 32px 0 40px; }
    .osh-title { font-size: 1.9rem; }
    .osh-more { padding: 8px 14px; font-size: 11px; }
    .osh-card { min-height: 0; padding: 16px 16px 12px; }
    .osh-card--review {
        grid-template-columns: 72px 1fr;
        gap: 12px;
        padding: 12px;
    }
    .osh-card--review .osh-review-cover { width: 72px; }
    .osh-card--discuss .osh-card-title { font-size: 1.05rem; }
}

/* ============================================================
   Title page · watchlist-state button coloring
   ============================================================ */
.tp-action-btn.wl-trigger[data-current-status]:not([data-current-status=""]) {
    border-left-width: 3px; border-left-style: solid;
    transition: background .18s, border-color .18s, color .18s;
}
.tp-action-btn.wl-trigger[data-current-status="watching"] {
    background: rgba(61,157,240,.14); border-color: rgba(61,157,240,.35); color: #7cc0ff;
    border-left-color: #3d9df0;
}
.tp-action-btn.wl-trigger[data-current-status="watching"] .wl-icon { color: #3d9df0; }
.tp-action-btn.wl-trigger[data-current-status="completed"] {
    background: rgba(62,196,109,.14); border-color: rgba(62,196,109,.35); color: #6fd68e;
    border-left-color: #3ec46d;
}
.tp-action-btn.wl-trigger[data-current-status="completed"] .wl-icon { color: #3ec46d; }
.tp-action-btn.wl-trigger[data-current-status="dropped"] {
    background: rgba(230,0,0,.14); border-color: rgba(230,0,0,.35); color: #ff6767;
    border-left-color: #e60000;
}
.tp-action-btn.wl-trigger[data-current-status="dropped"] .wl-icon { color: #e60000; }
.tp-action-btn.wl-trigger[data-current-status="plan_to_watch"] {
    background: rgba(255,182,72,.14); border-color: rgba(255,182,72,.35); color: #ffc97a;
    border-left-color: #ffb648;
}
.tp-action-btn.wl-trigger[data-current-status="plan_to_watch"] .wl-icon { color: #ffb648; }
.tp-action-btn.wl-trigger[data-current-status="on_hold"] {
    background: rgba(168,168,168,.14); border-color: rgba(168,168,168,.35); color: #cfcfcf;
    border-left-color: #a8a8a8;
}
.tp-action-btn.wl-trigger[data-current-status="on_hold"] .wl-icon { color: #a8a8a8; }

/* ============================================================
   Leaderboard · redesigned
   ============================================================ */
.os-lb-page {
    --lb-bg:          #0a0a0a;
    --lb-card:        #141414;
    --lb-card-hi:     #181818;
    --lb-border:      rgba(255,255,255,0.07);
    --lb-border-hi:   rgba(255,255,255,0.14);
    --lb-text:        #ededed;
    --lb-muted:       #8a8a8a;
    --lb-dim:         #4a4a4a;
    --lb-accent:      #e60000;
    --lb-accent-soft: rgba(230,0,0,0.14);
    --lb-gold:        #f1c40f;
    --lb-silver:      #c0c4c8;
    --lb-bronze:      #cd7f32;
    max-width: 900px;
    margin: 0 auto;
    padding: 40px 16px 80px;
    color: var(--lb-text);
}

/* Hero */
.os-lb-hero { margin-bottom: 28px; }
.os-lb-hero-kicker {
    display: inline-flex; align-items: center; gap: 10px;
    font-size: 11px; font-weight: 600;
    letter-spacing: 0.22em; text-transform: uppercase;
    color: var(--lb-muted);
    margin-bottom: 12px;
}
.os-lb-kicker-dot {
    width: 7px; height: 7px; border-radius: 50%;
    background: var(--lb-accent);
    box-shadow: 0 0 0 0 rgba(230,0,0,0.45);
    animation: os-lb-pulse 2.2s ease-in-out infinite;
}
@keyframes os-lb-pulse {
    0%,100% { box-shadow: 0 0 0 0 rgba(230,0,0,0.5); }
    50%     { box-shadow: 0 0 0 6px rgba(230,0,0,0);  }
}
.os-lb-hero-title {
    font-weight: 700;
    font-size: clamp(1.9rem, 3.5vw, 2.5rem);
    line-height: 1.05;
    color: #fff;
    margin: 0 0 10px;
    letter-spacing: -0.02em;
}
.os-lb-hero-dot { color: var(--lb-accent); }
.os-lb-hero-sub {
    color: var(--lb-muted);
    margin: 0;
    font-size: 14px;
}

/* Category pill bar */
.os-lb-catbar {
    display: flex; flex-wrap: wrap;
    gap: 8px;
    background: var(--lb-card);
    border: 1px solid var(--lb-border);
    border-radius: 14px;
    padding: 8px;
    margin-bottom: 12px;
}
.os-lb-catpill {
    flex: 1 1 auto;
    min-width: 0;
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    background: transparent;
    border: 1px solid transparent;
    color: var(--lb-muted);
    padding: 9px 14px;
    border-radius: 10px;
    font-size: 13px; font-weight: 600;
    letter-spacing: 0.02em;
    cursor: pointer;
    transition: background .18s, color .18s, border-color .18s;
    white-space: nowrap;
}
.os-lb-catpill i { font-size: 13px; }
.os-lb-catpill:hover { color: #fff; background: rgba(255,255,255,0.03); }
.os-lb-catpill.is-active {
    background: var(--lb-accent);
    color: #fff;
    box-shadow: 0 6px 18px rgba(230,0,0,0.28);
}
.os-lb-catpill.is-active:hover { background: var(--lb-accent); }

/* Period pill bar */
.os-lb-periodbar {
    display: flex;
    gap: 4px;
    margin-bottom: 28px;
}
.os-lb-periodpill {
    background: transparent;
    border: 1px solid var(--lb-border);
    color: var(--lb-muted);
    padding: 6px 14px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.08em; text-transform: uppercase;
    cursor: pointer;
    transition: background .18s, color .18s, border-color .18s;
}
.os-lb-periodpill:hover { color: #fff; border-color: var(--lb-border-hi); }
.os-lb-periodpill.is-active {
    color: #fff; border-color: var(--lb-accent); background: var(--lb-accent-soft);
}

/* Podium */
.os-lb-podium {
    display: grid;
    grid-template-columns: 1fr 1.15fr 1fr;
    gap: 12px;
    margin-bottom: 24px;
    align-items: end;
}
.os-lb-podium-skeleton {
    grid-column: 1 / -1;
    height: 220px;
    background: linear-gradient(90deg, rgba(255,255,255,0.02), rgba(255,255,255,0.05), rgba(255,255,255,0.02));
    border-radius: 14px;
    animation: os-lb-shimmer 1.4s ease-in-out infinite;
}
@keyframes os-lb-shimmer {
    0%,100% { opacity: 0.6; }
    50%     { opacity: 0.95; }
}
.os-lb-podium-card {
    position: relative;
    display: flex; flex-direction: column; align-items: center; justify-content: flex-end;
    gap: 10px;
    padding: 22px 14px 18px;
    background: var(--lb-card);
    border: 1px solid var(--lb-border);
    border-radius: 16px;
    color: var(--lb-text);
    text-decoration: none;
    overflow: hidden;
    transition: transform .25s cubic-bezier(.2,.7,.2,1), background .2s, border-color .2s;
    opacity: 0; animation: os-lb-rise .45s cubic-bezier(.2,.7,.2,1) forwards;
}
.os-lb-podium-card[data-rank="2"] { animation-delay: 60ms; }
.os-lb-podium-card[data-rank="1"] { animation-delay: 0ms; padding-top: 28px; padding-bottom: 22px; }
.os-lb-podium-card[data-rank="3"] { animation-delay: 120ms; }
@keyframes os-lb-rise {
    from { opacity: 0; transform: translateY(12px); }
    to   { opacity: 1; transform: translateY(0); }
}
.os-lb-podium-card:hover { transform: translateY(-4px); background: var(--lb-card-hi); color: var(--lb-text); text-decoration: none; border-color: var(--lb-border-hi); }
.os-lb-podium-card.is-empty { cursor: default; opacity: 0.5; }
.os-lb-podium-card.is-empty:hover { transform: none; background: var(--lb-card); }

.os-lb-podium-rank {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: 12px; font-weight: 700;
    letter-spacing: 0.08em; text-transform: uppercase;
    color: var(--lb-muted);
}
.os-lb-podium-rank i { font-size: 14px; }
.os-lb-podium-card[data-rank="1"] { border-color: rgba(241,196,15,0.3); background: linear-gradient(180deg, rgba(241,196,15,0.10), var(--lb-card) 60%); }
.os-lb-podium-card[data-rank="1"] .os-lb-podium-rank { color: var(--lb-gold); }
.os-lb-podium-card[data-rank="1"] .os-lb-podium-rank i { font-size: 18px; }
.os-lb-podium-card[data-rank="2"] .os-lb-podium-rank { color: var(--lb-silver); }
.os-lb-podium-card[data-rank="3"] .os-lb-podium-rank { color: var(--lb-bronze); }

.os-lb-podium-avatar-wrap {
    width: 80px; height: 80px; border-radius: 50%;
    padding: 3px;
    background: linear-gradient(135deg, var(--lb-border-hi), transparent);
    display: flex; align-items: center; justify-content: center;
    flex: none;
}
.os-lb-podium-card[data-rank="1"] .os-lb-podium-avatar-wrap {
    width: 96px; height: 96px;
    background: linear-gradient(135deg, var(--lb-gold), rgba(241,196,15,0.0));
}
.os-lb-podium-card[data-rank="2"] .os-lb-podium-avatar-wrap {
    background: linear-gradient(135deg, var(--lb-silver), rgba(189,195,199,0.0));
}
.os-lb-podium-card[data-rank="3"] .os-lb-podium-avatar-wrap {
    background: linear-gradient(135deg, var(--lb-bronze), rgba(205,127,50,0.0));
}
.os-lb-podium-avatar {
    width: 100%; height: 100%;
    border-radius: 50%;
    object-fit: cover;
    background: var(--lb-card);
}
.os-lb-podium-name {
    font-size: 14px; font-weight: 700;
    max-width: 100%;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.os-lb-podium-score {
    font-size: 13px;
    color: var(--lb-muted);
    letter-spacing: 0.04em;
}
.os-lb-podium-card[data-rank="1"] .os-lb-podium-score { color: var(--lb-gold); font-weight: 700; font-size: 15px; }
.os-lb-podium-placeholder { font-size: 28px; color: var(--lb-dim); }

/* Rank list */
.os-lb-list { margin-bottom: 24px; }
.os-lb-list-loading,
.os-lb-list-empty {
    text-align: center;
    color: var(--lb-muted);
    padding: 40px 20px;
    background: var(--lb-card);
    border: 1px dashed var(--lb-border);
    border-radius: 14px;
}
.os-lb-suggest-all {
    margin-left: 8px;
    background: rgba(230,0,0,0.15);
    border: 1px solid rgba(230,0,0,0.4);
    color: #ff9090;
    padding: 5px 12px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    cursor: pointer;
    transition: background .15s, color .15s;
}
.os-lb-suggest-all:hover { background: #e60000; color: #fff; }
.os-lb-list-wrap {
    background: var(--lb-card);
    border: 1px solid var(--lb-border);
    border-radius: 14px;
    overflow: hidden;
}
.os-lb-row {
    display: grid;
    grid-template-columns: 44px 36px 1fr auto;
    align-items: center;
    gap: 14px;
    padding: 12px 20px 12px 18px;
    border-bottom: 1px solid var(--lb-border);
    color: var(--lb-text);
    text-decoration: none;
    position: relative;
    transition: background .15s;
}
.os-lb-row:last-child { border-bottom: 0; }
.os-lb-row:hover { background: var(--lb-card-hi); color: var(--lb-text); text-decoration: none; }
.os-lb-row-num {
    font-size: 13px; font-weight: 700;
    color: var(--lb-dim);
    letter-spacing: 0.05em;
    text-align: center;
}
.os-lb-row:hover .os-lb-row-num { color: var(--lb-accent); }
.os-lb-row-avatar {
    width: 36px; height: 36px;
    border-radius: 50%;
    object-fit: cover;
    border: 1px solid var(--lb-border);
}
.os-lb-row-user { min-width: 0; overflow: hidden; }
.os-lb-row-name {
    font-size: 14px; font-weight: 600;
    display: block;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.os-lb-row-score {
    position: relative;
    min-width: 120px;
    text-align: right;
    font-size: 13px; font-weight: 700;
    color: var(--lb-text);
}
.os-lb-row-scorebar {
    position: absolute; inset: 50% 0 auto 0; transform: translateY(-50%);
    height: 4px;
    background: linear-gradient(90deg, transparent, rgba(230,0,0,0.18));
    width: var(--w, 0%);
    border-radius: 3px;
    right: 0; left: auto;
    max-width: 100%;
    pointer-events: none;
}
.os-lb-row-scorenum {
    position: relative; z-index: 1;
    padding: 4px 10px;
    background: rgba(0,0,0,0.3);
    border-radius: 999px;
    display: inline-block;
}
.os-lb-row-edge {
    position: absolute; left: 0; top: 10px; bottom: 10px; width: 2px;
    background: var(--lb-accent);
    transform: scaleY(0); transform-origin: top;
    transition: transform .22s cubic-bezier(.2,.7,.2,1);
}
.os-lb-row:hover .os-lb-row-edge { transform: scaleY(1); }

/* "Your position" sticky card */
.os-lb-mine {
    position: sticky;
    bottom: 14px;
    z-index: 5;
    display: flex; align-items: center; gap: 12px;
    padding: 10px 16px;
    background: linear-gradient(135deg, rgba(230,0,0,0.22), rgba(230,0,0,0.08));
    border: 1px solid rgba(230,0,0,0.35);
    border-radius: 999px;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    box-shadow: 0 10px 30px rgba(0,0,0,0.4);
    color: #fff;
}
.os-lb-mine-label {
    font-size: 11px; font-weight: 700; letter-spacing: 0.22em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.7);
}
.os-lb-mine-rank { font-weight: 700; font-size: 15px; }
.os-lb-mine-avatar {
    width: 32px; height: 32px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid rgba(255,255,255,0.25);
}
.os-lb-mine-name { flex: 1; font-weight: 600; font-size: 14px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.os-lb-mine-score { font-weight: 700; font-size: 15px; }

/* Light mode */
#wrap.os-light-mode .os-lb-page {
    --lb-bg:        #fafafa;
    --lb-card:      #ffffff;
    --lb-card-hi:   #f5f5f7;
    --lb-border:    rgba(0,0,0,0.08);
    --lb-border-hi: rgba(0,0,0,0.16);
    --lb-text:      #151515;
    --lb-muted:     #666;
    --lb-dim:       #a0a0a0;
}
#wrap.os-light-mode .os-lb-hero-title { color: #111; }
#wrap.os-light-mode .os-lb-row-scorenum { background: rgba(0,0,0,0.04); }

/* Mobile */
@media (max-width: 639px) {
    .os-lb-page { padding: 24px 10px 80px; }
    .os-lb-catbar { padding: 6px; gap: 6px; border-radius: 12px; }
    .os-lb-catpill { padding: 8px 10px; font-size: 12px; }
    .os-lb-catpill span { display: none; }          /* icons-only on mobile */
    .os-lb-catpill i { font-size: 14px; }
    .os-lb-catpill.is-active span { display: inline; } /* keep label on active pill */

    .os-lb-podium {
        grid-template-columns: minmax(70%, 80%);
        grid-auto-flow: column;
        grid-auto-columns: 75%;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        padding-bottom: 10px;
        gap: 10px;
    }
    .os-lb-podium-card { scroll-snap-align: start; }

    .os-lb-row { grid-template-columns: 34px 32px 1fr auto; padding: 10px 14px; gap: 10px; }
    .os-lb-row-avatar { width: 32px; height: 32px; }
    .os-lb-row-score { min-width: 90px; font-size: 12px; }
    .os-lb-mine { padding: 8px 12px; gap: 8px; }
    .os-lb-mine-label { display: none; }
}

/* ============================================================
   Profile · Anime Stats card (MAL/AniList-style stacked bar)
   ============================================================ */
.os-profile-stats-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
    margin: 0 0 28px;
}
@media (max-width: 899px) {
    .os-profile-stats-row { grid-template-columns: 1fr; gap: 14px; }
}
.os-profile-stats-row > section { margin: 0 !important; }
.os-watch-stats-card {
    padding: 20px 22px 18px;
    background: #141414;
    border: 1px solid rgba(255,255,255,0.07);
    border-radius: 14px;
}
.os-watch-stats-card .title-box { margin-bottom: 14px; }
.os-watch-stats-card .title {
    margin: 0;
    font-size: 1.05rem !important;
    font-weight: 700;
    color: #ededed;
    letter-spacing: -0.01em;
}
.os-watch-stats-card .mp-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(90px, 1fr));
    gap: 12px;
}
#wrap.os-light-mode .os-watch-stats-card { background: #fff; border-color: rgba(0,0,0,0.08); }
#wrap.os-light-mode .os-watch-stats-card .title { color: #111; }

/* ─────────────────────────────────────────────────────────────────
   Upload Stats card — hybrid: broadcaster header + editorial rows
   Renders only when the user has ≥1 active upload.
   ───────────────────────────────────────────────────────────────── */
.os-up-card {
    position: relative;
    margin-top: 18px;
    padding: 28px 28px 18px;
    background:
        radial-gradient(120% 80% at 50% 0%, rgba(230,0,0,0.08), transparent 60%),
        linear-gradient(180deg, #181412 0%, #141414 100%);
    border: 1px solid rgba(255,255,255,0.06);
    border-radius: 14px;
    overflow: hidden;
	margin-bottom:20px;
}
.os-up-card::before {
    /* Subtle red top-edge accent */
    content: '';
    position: absolute; top: 0; left: 0; right: 0; height: 2px;
    background: linear-gradient(90deg, transparent 0%, rgba(230,0,0,0.6) 30%, rgba(230,0,0,0.6) 70%, transparent 100%);
    opacity: 0.55;
}
/* Filmstrip sprocket-hole rows top + bottom */
.os-up-filmstrip {
    height: 12px;
    background-image: radial-gradient(circle at 6px 6px, rgba(255,255,255,0.06) 2.5px, transparent 3px);
    background-size: 14px 12px;
    background-repeat: repeat-x;
    opacity: 0.7;
}
.os-up-filmstrip-top { margin: -6px -28px 22px; }
.os-up-filmstrip-bot { margin: 18px -28px -6px; }

/* ── Header: eyebrow label + ON AIR badge ───────────────────────── */
.os-up-head {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 4px;
}
.os-up-eyebrow {
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.32em;
    text-transform: uppercase;
    color: #ededed;
}
.os-up-onair {
    display: inline-flex; align-items: center; gap: 7px;
    font-size: 10px; font-weight: 800;
    letter-spacing: 0.18em;
    color: #ff7a7a;
    padding: 4px 10px 4px 8px;
    border: 1px solid rgba(230,0,0,0.5);
    border-radius: 999px;
    background: rgba(230,0,0,0.08);
}
.os-up-onair-dot {
    width: 7px; height: 7px; border-radius: 50%;
    background: #ff3a3a;
    box-shadow: 0 0 10px rgba(255,58,58,0.9);
    animation: os-up-pulse 1.4s ease-in-out infinite;
}
@keyframes os-up-pulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50%      { opacity: 0.45; transform: scale(0.85); }
}

/* ── Hero: dramatic number + flourish ───────────────────────────── */
.os-up-hero {
    text-align: center;
    padding: 18px 0 6px;
}
.os-up-hero-num {
    font-family: 'Poppins', sans-serif;
    font-size: clamp(56px, 8vw, 84px);
    font-weight: 800;
    line-height: 1;
    color: #fff;
    letter-spacing: -0.04em;
    text-shadow: 0 0 28px rgba(230,0,0,0.35), 0 2px 0 rgba(0,0,0,0.4);
}
.os-up-hero-flourish {
    width: 56px; height: 2px;
    margin: 14px auto 12px;
    background: linear-gradient(90deg, transparent, #e60000, transparent);
}
.os-up-hero-sub {
    margin: 0;
    font-size: 13px; line-height: 1.5;
    color: rgba(255,255,255,0.55);
    font-style: italic;
}
.os-up-hero-sub strong {
    color: #ededed;
    font-weight: 700;
    font-style: normal;
}

/* ── Editorial stat rows ────────────────────────────────────────── */
.os-up-rows {
    list-style: none;
    margin: 18px 0 0;
    padding: 0;
}
.os-up-rows li {
    display: flex; align-items: baseline; justify-content: space-between;
    padding: 12px 2px;
    border-bottom: 1px solid rgba(255,255,255,0.05);
}
.os-up-rows li:last-child { border-bottom: 0; }
.os-up-row-label {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.42);
}
.os-up-row-val {
    font-size: 15px;
    font-weight: 700;
    color: #ededed;
    font-variant-numeric: tabular-nums;
}
/* Most-recent row: title + episode on top line, date below in small caps */
.os-up-row-recent {
    align-items: flex-start;
    gap: 12px;
}
.os-up-row-val-multi {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    text-align: right;
    gap: 3px;
    min-width: 0;
    flex: 1 1 auto;
}
.os-up-recent-title {
    font-size: 14px;
    font-weight: 700;
    color: #ededed;
    text-decoration: none;
    line-height: 1.3;
    transition: color .15s;
    overflow: hidden; text-overflow: ellipsis;
    max-width: 100%;
}
.os-up-recent-title:hover { color: #ff5050; text-decoration: none; }
.os-up-recent-ep {
    color: rgba(255,255,255,0.55);
    font-weight: 500;
}
.os-up-recent-date {
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.36);
    font-variant-numeric: tabular-nums;
}
#wrap.os-light-mode .os-up-recent-title { color: #111; }
#wrap.os-light-mode .os-up-recent-title:hover { color: #e60000; }
#wrap.os-light-mode .os-up-recent-ep { color: rgba(0,0,0,0.55); }
#wrap.os-light-mode .os-up-recent-date { color: rgba(0,0,0,0.4); }

/* Light-mode overrides */
#wrap.os-light-mode .os-up-card {
    background:
        radial-gradient(120% 80% at 50% 0%, rgba(230,0,0,0.06), transparent 60%),
        #fff;
    border-color: rgba(0,0,0,0.08);
}
#wrap.os-light-mode .os-up-eyebrow,
#wrap.os-light-mode .os-up-hero-num,
#wrap.os-light-mode .os-up-hero-sub strong,
#wrap.os-light-mode .os-up-row-val { color: #111; }
#wrap.os-light-mode .os-up-hero-num { text-shadow: 0 0 22px rgba(230,0,0,0.18); }
#wrap.os-light-mode .os-up-hero-sub { color: rgba(0,0,0,0.55); }
#wrap.os-light-mode .os-up-row-label { color: rgba(0,0,0,0.5); }
#wrap.os-light-mode .os-up-rows li { border-bottom-color: rgba(0,0,0,0.06); }
#wrap.os-light-mode .os-up-filmstrip {
    background-image: radial-gradient(circle at 6px 6px, rgba(0,0,0,0.08) 2.5px, transparent 3px);
}

/* Mobile tweaks */
@media (max-width: 575px) {
    .os-up-card { padding: 22px 18px 14px; }
    .os-up-filmstrip-top { margin: -6px -18px 18px; }
    .os-up-filmstrip-bot { margin: 14px -18px -6px; }
    .os-up-hero-num { font-size: 52px; }
    .os-up-row-val { font-size: 14px; }
}

.os-anime-stats {
    margin: 0;
    padding: 20px 22px 18px;
    background: #141414;
    border: 1px solid rgba(255,255,255,0.07);
    border-radius: 14px;
}
.os-as-head {
    display: flex; align-items: baseline; justify-content: space-between;
    margin-bottom: 14px;
}
.os-as-title {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 700;
    color: #ededed;
    letter-spacing: -0.01em;
}
.os-as-more {
    font-size: 12px; font-weight: 600;
    color: #3d9df0;
    text-decoration: none;
    letter-spacing: 0.02em;
}
.os-as-more i { font-size: 11px; margin-left: 4px; transition: transform .2s; }
.os-as-more:hover { color: #6bb3ff; text-decoration: none; }
.os-as-more:hover i { transform: translateX(3px); }

.os-as-topline {
    display: flex; justify-content: space-between;
    font-size: 13px;
    margin-bottom: 10px;
    color: #8a8a8a;
}
.os-as-topitem { display: inline-flex; align-items: baseline; gap: 8px; }
.os-as-topkey { color: #8a8a8a; }
.os-as-topval { color: #fff; font-weight: 700; font-size: 14px; }

.os-as-bar {
    display: flex;
    width: 100%; height: 10px;
    border-radius: 2px;
    background: rgba(255,255,255,0.04);
    overflow: hidden;
    gap: 3px;
    margin-bottom: 14px;
}
.os-as-seg {
    display: block;
    height: 100%;
    min-width: 2px;
    transition: filter .15s;
}
.os-as-seg:hover { filter: brightness(1.25); }
.os-as-seg-empty { background: rgba(255,255,255,0.05) !important; }

.os-as-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 32px;
}
.os-as-col { display: flex; flex-direction: column; gap: 4px; }
.os-as-row {
    display: grid;
    grid-template-columns: 10px 1fr auto;
    align-items: center;
    gap: 10px;
    padding: 4px 0;
    font-size: 13px;
}
.os-as-col-totals .os-as-row {
    grid-template-columns: 1fr auto;
    color: #bbb;
}
.os-as-col-totals .os-as-row .os-as-label { color: #8a8a8a; }
.os-as-dot { width: 10px; height: 10px; border-radius: 2px; }
.os-as-label { color: #cfcfcf; }
.os-as-count { color: #fff; font-weight: 700; font-variant-numeric: tabular-nums; }

a.os-as-row-link {
    text-decoration: none;
    color: inherit;
    border-radius: 4px;
    padding: 4px 6px;
    margin: 0 -6px;
    transition: background 160ms, transform 160ms;
}
a.os-as-row-link:hover {
    background: rgba(255,255,255,0.06);
    transform: translateX(2px);
}
a.os-as-row-link:hover .os-as-count { color: #fff; }

@media (max-width: 575px) {
    .os-as-grid { grid-template-columns: 1fr; gap: 12px; }
    .os-as-col-totals { padding-top: 12px; border-top: 1px solid rgba(255,255,255,0.06); }
}

/* Light-mode */
#wrap.os-light-mode .os-anime-stats { background: #fff; border-color: rgba(0,0,0,0.08); }
#wrap.os-light-mode .os-as-title { color: #111; }
#wrap.os-light-mode .os-as-topval { color: #111; }
#wrap.os-light-mode .os-as-label { color: #444; }
#wrap.os-light-mode .os-as-count { color: #111; }
#wrap.os-light-mode .os-as-bar { background: rgba(0,0,0,0.06); }

/* ============================================================
   Profile · Otaku tier badge (small pill next to Level N)
   ============================================================ */
.os-tier-line { display: inline-flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.os-tier-badge {
    display: inline-flex; align-items: center;
    padding: 3px 10px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 700;
    color: #fff;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    line-height: 1.4;
}
.os-tier-level {
    font-weight: 700;
    color: #ededed;
    font-size: 14px;
}
.os-tier-info {
    color: #777;
    font-size: 12px;
    text-decoration: none;
    transition: color .15s;
}
.os-tier-info:hover { color: #ff5050; text-decoration: none; }
#wrap.os-light-mode .os-tier-level { color: #111; }

/* ============================================================
   /levels page
   ============================================================ */
.os-lv-page {
    --lv-card:   #141414;
    --lv-border: rgba(255,255,255,0.07);
    --lv-text:   #ededed;
    --lv-muted:  #8a8a8a;
    --lv-dim:    #4a4a4a;
    --lv-accent: #e60000;
    max-width: 900px;
    margin: 0 auto;
    padding: 40px 16px 80px;
    color: var(--lv-text);
}
.os-lv-hero { margin-bottom: 24px; }
.os-lv-kicker {
    display: inline-flex; align-items: center; gap: 10px;
    font-size: 11px; font-weight: 600;
    letter-spacing: 0.22em; text-transform: uppercase;
    color: var(--lv-muted);
    margin-bottom: 12px;
}
.os-lv-kicker-dot {
    width: 7px; height: 7px; border-radius: 50%;
    background: var(--lv-accent);
    box-shadow: 0 0 0 0 rgba(230,0,0,0.45);
    animation: os-lv-pulse 2.2s ease-in-out infinite;
}
@keyframes os-lv-pulse {
    0%,100% { box-shadow: 0 0 0 0 rgba(230,0,0,0.5); }
    50%     { box-shadow: 0 0 0 6px rgba(230,0,0,0);  }
}
.os-lv-title {
    font-weight: 700;
    font-size: clamp(1.9rem, 3.5vw, 2.5rem);
    line-height: 1.05;
    color: #fff;
    margin: 0 0 10px;
    letter-spacing: -0.02em;
}
.os-lv-dot { color: var(--lv-accent); }
.os-lv-sub {
    color: var(--lv-muted);
    margin: 0; max-width: 640px;
    font-size: 14px; line-height: 1.55;
}

/* "You" card */
.os-lv-you {
    background: var(--lv-card);
    border: 1px solid var(--lv-border);
    border-radius: 14px;
    padding: 20px;
    margin-bottom: 32px;
}
.os-lv-you-row {
    display: flex; align-items: center; gap: 14px;
    flex-wrap: wrap;
    margin-bottom: 14px;
}
.os-lv-you-tier {
    padding: 5px 14px;
    border-radius: 999px;
    font-size: 11px; font-weight: 700;
    letter-spacing: 0.12em; text-transform: uppercase;
    color: #fff;
}
.os-lv-you-level { font-weight: 700; font-size: 1.2rem; color: #fff; }
.os-lv-you-xp {
    margin-left: auto;
    font-weight: 600; font-size: 14px;
    color: var(--lv-muted);
}
.os-lv-progress {
    height: 8px;
    background: rgba(255,255,255,0.05);
    border-radius: 4px;
    overflow: hidden;
    margin-bottom: 8px;
}
.os-lv-progress-fill {
    height: 100%;
    background: linear-gradient(90deg, #e60000, #ff5050);
    border-radius: 4px;
    transition: width .5s cubic-bezier(.2,.7,.2,1);
}
.os-lv-progress-meta {
    display: flex; justify-content: space-between;
    font-size: 12px; color: var(--lv-muted);
}

/* Generic h2 */
.os-lv-h2 {
    font-size: 1.1rem; font-weight: 700;
    margin: 0 0 16px;
    color: #fff;
    letter-spacing: -0.01em;
}

/* Earn grid */
.os-lv-section { margin-bottom: 32px; }
.os-lv-earn-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 10px;
}
.os-lv-earn {
    display: flex; align-items: center; gap: 12px;
    padding: 12px 14px;
    background: var(--lv-card);
    border: 1px solid var(--lv-border);
    border-radius: 12px;
}
.os-lv-earn i {
    color: var(--lv-accent);
    font-size: 16px;
    width: 22px;
    text-align: center;
    flex: none;
}
.os-lv-earn > div { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.os-lv-earn b { font-size: 13px; font-weight: 700; color: #fff; }
.os-lv-earn span { font-size: 11px; color: var(--lv-muted); }

/* Tier legend */
.os-lv-tiers {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 10px;
}
.os-lv-tier {
    background: var(--lv-card);
    border: 1px solid var(--lv-border);
    border-radius: 12px;
    padding: 14px;
    display: flex; align-items: center; justify-content: space-between;
    gap: 10px;
}
.os-lv-tier-chip {
    display: inline-flex;
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 10px;
    font-weight: 700;
    color: #fff;
    letter-spacing: 0.1em; text-transform: uppercase;
}
.os-lv-tier-range {
    font-size: 11px;
    color: var(--lv-muted);
    letter-spacing: 0.02em;
}

/* Threshold table */
.os-lv-table-wrap {
    background: var(--lv-card);
    border: 1px solid var(--lv-border);
    border-radius: 12px;
    overflow: hidden;
}
.os-lv-table {
    width: 100%;
    border-collapse: collapse;
}
.os-lv-table th,
.os-lv-table td {
    padding: 10px 18px;
    text-align: left;
    font-size: 13px;
}
.os-lv-table th {
    font-size: 11px; font-weight: 600;
    letter-spacing: 0.12em; text-transform: uppercase;
    color: var(--lv-muted);
    background: rgba(255,255,255,0.02);
    border-bottom: 1px solid var(--lv-border);
}
.os-lv-table td { border-bottom: 1px solid var(--lv-border); color: var(--lv-text); }
.os-lv-table tbody tr:last-child td { border-bottom: 0; }
.os-lv-table .os-lv-td-level {
    font-weight: 700;
    color: #fff;
    width: 80px;
}
.os-lv-table .os-lv-td-xp {
    font-weight: 600;
    font-variant-numeric: tabular-nums;
    text-align: right;
    color: #fff;
}
.os-lv-table tr.is-mine td {
    background: rgba(230,0,0,0.08);
    position: relative;
}
.os-lv-table tr.is-mine .os-lv-td-level::before {
    content: "▸ ";
    color: var(--lv-accent);
    font-weight: 900;
}
.os-lv-table tr.os-lv-table-beyond td {
    color: var(--lv-muted);
    font-style: italic;
}

/* Light mode */
#wrap.os-light-mode .os-lv-page {
    --lv-card:   #ffffff;
    --lv-border: rgba(0,0,0,0.08);
    --lv-text:   #151515;
    --lv-muted:  #666;
    --lv-dim:    #999;
}
#wrap.os-light-mode .os-lv-title { color: #111; }
#wrap.os-light-mode .os-lv-table td,
#wrap.os-light-mode .os-lv-table .os-lv-td-level,
#wrap.os-light-mode .os-lv-table .os-lv-td-xp { color: #111; }

@media (max-width: 539px) {
    .os-lv-page { padding: 24px 10px 80px; }
    .os-lv-you-xp { margin-left: 0; width: 100%; }
    .os-lv-table th,
    .os-lv-table td { padding: 8px 12px; font-size: 12px; }
}

/* ============================================================
   Profile · Legacy OS Medals (award / award_user tables)
   ============================================================ */
.osu-legacy-medals {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
    padding: 14px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 10px;
    margin-bottom: 16px;
}
.osu-legacy-medals img {
    object-fit: contain;
    border-radius: 6px;
    transition: transform .15s;
    cursor: help;
}
.osu-legacy-medals img:hover {
    transform: translateY(-2px) scale(1.05);
}
.osu-legacy-medals .medal-fallback {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border-radius: 6px;
    background: rgba(230, 0, 0, 0.12);
    color: #e60000;
    font-size: 22px;
    cursor: help;
    transition: transform .15s;
}
.osu-legacy-medals .medal-fallback:hover {
    transform: translateY(-2px) scale(1.05);
}
.os-light-mode .osu-legacy-medals {
    background: rgba(0, 0, 0, 0.03);
    border-color: rgba(0, 0, 0, 0.08);
}

/* ============================================================
   Profile · Badges grid (Activity tab)
   ============================================================ */
.osu-badges-section {
    margin-bottom: 28px;
}
.osu-badges-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 10px;
}
@media (max-width: 899px) {
    .osu-badges-grid { grid-template-columns: repeat(4, 1fr); gap: 8px; }
}
@media (max-width: 599px) {
    .osu-badges-grid { grid-template-columns: repeat(3, 1fr); gap: 8px; }
}
@media (max-width: 399px) {
    .osu-badges-grid { grid-template-columns: repeat(2, 1fr); gap: 8px; }
}

.osu-badge-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    padding: 12px 6px 10px;
    border-radius: 10px;
    border: 1px solid rgba(255,255,255,0.07);
    background: #1a1a1a;
    cursor: default;
    transition: transform .15s ease, border-color .15s ease;
}
.osu-badge-card:hover {
    transform: translateY(-2px);
    border-color: rgba(255,255,255,0.15);
}
.osu-badge-icon-wrap {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    background: rgba(255,255,255,0.06);
    flex-shrink: 0;
}
.osu-badge-unlocked .osu-badge-icon-wrap {
    color: #fff;
}
.osu-badge-locked .osu-badge-icon-wrap {
    background: rgba(255,255,255,0.04);
    filter: grayscale(1);
}
.osu-badge-lock-icon {
    font-size: 15px;
    color: rgba(255,255,255,0.2);
}
.osu-badge-name {
    font-size: 10px;
    font-weight: 600;
    color: #8e9194;
    text-align: center;
    line-height: 1.3;
    letter-spacing: .2px;
    word-break: break-word;
}
.osu-badge-unlocked .osu-badge-name {
    color: #c8cacc;
}
.osu-badge-locked {
    opacity: .55;
}
/* light-mode overrides */
#wrap.os-light-mode .osu-badge-card {
    background: #f4f4f5;
    border-color: rgba(0,0,0,0.08);
}
#wrap.os-light-mode .osu-badge-name { color: #555; }
#wrap.os-light-mode .osu-badge-unlocked .osu-badge-name { color: #111; }

/* ── Watch Streak ── */
.os-streak-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    font-weight: 600;
    color: #e2e3e4;
    background: rgba(255, 80, 0, 0.10);
    border: 1px solid rgba(255, 80, 0, 0.20);
    border-radius: 20px;
    padding: 5px 14px;
    margin-bottom: 12px;
}
.os-streak-profile {
    font-size: 13px;
    font-weight: 600;
    color: #ff8c42;
}
.os-streak-profile i {
    color: #ff5500;
    margin-right: 4px;
}
.os-streak-none {
    color: #777;
    font-weight: 400;
}
.os-streak-none i {
    color: #555;
}
#wrap.os-light-mode .os-streak-badge {
    color: #333;
    background: rgba(255, 80, 0, 0.08);
    border-color: rgba(255, 80, 0, 0.18);
}
#wrap.os-light-mode .os-streak-profile {
    color: #c94400;
}
#wrap.os-light-mode .os-streak-none {
    color: #999;
}

/* ── Series-finished celebration ─────────────────────────────────────────── */

/* Confetti dots */
.os-confetti-wrap {
    position: fixed;
    top: 0; left: 0; width: 100%; height: 0;
    pointer-events: none;
    z-index: 9997;
    overflow: visible;
}
.os-confetti-dot {
    position: absolute;
    top: -10px;
    animation: os-confetti-fall linear forwards;
}
@keyframes os-confetti-fall {
    0%   { transform: translateY(0) rotate(0deg);   opacity: 1; }
    80%  { opacity: 1; }
    100% { transform: translateY(90vh) rotate(540deg); opacity: 0; }
}

/* Simple "already reviewed" toast */
.os-finish-toast {
    position: fixed;
    bottom: 24px; right: 24px;
    background: #1e2130;
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 10px;
    padding: 14px 18px;
    display: flex;
    align-items: center;
    gap: 10px;
    color: #e0e0e0;
    font-size: 14px;
    box-shadow: 0 8px 24px rgba(0,0,0,0.4);
    z-index: 9998;
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 0.3s ease, transform 0.3s ease;
    max-width: 340px;
}
.os-finish-toast.os-finish-toast-in {
    opacity: 1;
    transform: translateY(0);
}
.os-finish-toast-icon { font-size: 20px; flex-shrink: 0; }
.os-finish-toast-close {
    background: none; border: none; cursor: pointer;
    color: #888; font-size: 18px; line-height: 1;
    margin-left: auto; padding: 0 2px;
    flex-shrink: 0;
}
.os-finish-toast-close:hover { color: #ccc; }

/* Rating modal overlay */
.os-finish-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.65);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9998;
    opacity: 0;
    transition: opacity 0.3s ease;
}
.os-finish-overlay.os-finish-overlay-in { opacity: 1; }

.os-finish-modal {
    background: #1a1d2e;
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 14px;
    padding: 32px 28px 24px;
    width: 100%;
    max-width: 400px;
    text-align: center;
    position: relative;
    box-shadow: 0 20px 60px rgba(0,0,0,0.5);
    transform: scale(0.95) translateY(10px);
    transition: transform 0.3s cubic-bezier(0.34,1.56,0.64,1);
    margin: 16px;
}
.os-finish-overlay.os-finish-overlay-in .os-finish-modal {
    transform: scale(1) translateY(0);
}

.os-finish-modal-close {
    position: absolute; top: 12px; right: 14px;
    background: none; border: none; cursor: pointer;
    color: #777; font-size: 20px; line-height: 1;
    padding: 2px 6px; border-radius: 4px;
}
.os-finish-modal-close:hover { color: #bbb; background: rgba(255,255,255,0.05); }

.os-finish-modal-icon { font-size: 42px; margin-bottom: 8px; }

.os-finish-modal h3 {
    color: #edeeef; font-size: 20px; font-weight: 700;
    margin: 0 0 6px;
}
.os-finish-modal-sub {
    color: #a0a3b1; font-size: 14px; margin: 0 0 14px;
}
.os-finish-modal-sub strong { color: #d0d2db; }
.os-finish-modal-prompt {
    color: #c0c2cc; font-size: 13px; margin: 0 0 12px;
}

/* Stars */
.os-finish-stars {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-bottom: 20px;
}
.os-finish-star {
    font-size: 32px;
    color: #3a3c50;
    cursor: pointer;
    transition: color 0.15s, transform 0.1s;
    line-height: 1;
    user-select: none;
}
.os-finish-star.os-finish-star-hover,
.os-finish-star.os-finish-star-sel {
    color: #ffd93d;
}
.os-finish-star:active { transform: scale(0.9); }

/* Action buttons */
.os-finish-modal-actions {
    display: flex;
    gap: 10px;
    justify-content: center;
    flex-wrap: wrap;
}
.os-finish-btn-submit {
    background: #4d96ff;
    color: #fff;
    border: none;
    border-radius: 8px;
    padding: 9px 22px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.2s, opacity 0.2s;
}
.os-finish-btn-submit:hover:not(:disabled) { background: #3a84f0; }
.os-finish-btn-submit:disabled { opacity: 0.45; cursor: default; }
.os-finish-btn-skip {
    background: transparent;
    color: #777;
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 8px;
    padding: 9px 18px;
    font-size: 14px;
    cursor: pointer;
    transition: color 0.2s, border-color 0.2s;
}
.os-finish-btn-skip:hover { color: #aaa; border-color: rgba(255,255,255,0.2); }

.os-finish-modal-msg {
    margin-top: 12px;
    font-size: 13px;
    min-height: 18px;
}
.os-finish-msg-ok  { color: #6bcb77; }
.os-finish-msg-err { color: #ff6b6b; }

/* Light-mode overrides */
#wrap.os-light-mode .os-finish-toast { background: #fff; color: #1a1a1a; border-color: rgba(0,0,0,.1); }
#wrap.os-light-mode .os-finish-toast-close { color: #555; }
#wrap.os-light-mode .os-finish-modal { background: #fff; color: #1a1a1a; }
#wrap.os-light-mode .os-finish-modal h3,
#wrap.os-light-mode .os-finish-modal .os-finish-modal-sub { color: #1a1a1a; }
#wrap.os-light-mode .os-finish-btn-skip { color: #555; border-color: rgba(0,0,0,.2); }
/* ── end series-finished celebration ─────────────────────────────────────── */

/* ── Onboarding Tour ──────────────────────────────────────────────────────── */
#obOverlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.72);
    z-index: 99999;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 16px;
}
#obCard {
    background: #1a1a1a;
    border: 1px solid #2e2e2e;
    border-radius: 18px;
    padding: 32px 28px 24px;
    max-width: 480px;
    width: 100%;
    box-shadow: 0 12px 40px rgba(0,0,0,0.6);
    animation: obFadeIn 0.3s ease;
    text-align: center;
    position: relative;
    max-height: 90vh;
    overflow-y: auto;
}
@keyframes obFadeIn {
    from { opacity: 0; transform: scale(0.94); }
    to   { opacity: 1; transform: scale(1); }
}
/* Steps — hidden by default; shown when .ob-step-active */
.ob-step { display: none; }
.ob-step.ob-step-active { display: block; }

/* Progress pips */
.ob-progress { display: flex; justify-content: center; gap: 6px; margin-bottom: 16px; }
.ob-pip {
    width: 8px; height: 8px; border-radius: 50%;
    background: #333; transition: background 0.2s;
}
.ob-pip.ob-pip-active  { background: #e60000; }
.ob-pip.ob-pip-done    { background: #5a5a5a; }

/* Intro icon */
.ob-icon { font-size: 46px; margin-bottom: 12px; }

/* Headings */
.ob-heading { color: #E2E3E4; font-size: 1.1rem; margin-bottom: 6px; }
.ob-sub     { color: #888; font-size: 13px; margin-bottom: 16px; }

/* Actions row */
.ob-actions { display: flex; flex-direction: column; align-items: center; gap: 8px; margin-top: 18px; }

/* Buttons */
.ob-btn {
    display: inline-block;
    border: none;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 600;
    padding: 9px 22px;
    cursor: pointer;
    transition: background 0.15s, opacity 0.15s;
}
.ob-btn-primary { background: #e60000; color: #fff; min-width: 140px; }
.ob-btn-primary:hover { background: #cc0000; }
.ob-btn-primary:disabled { opacity: 0.5; cursor: default; }
.ob-btn-skip {
    background: transparent;
    color: #666;
    font-size: 12px;
    font-weight: 400;
    padding: 4px 10px;
    text-decoration: underline;
}
.ob-btn-skip:hover { color: #999; }

/* Genre chips */
.ob-genre-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 6px;
    margin: 12px 0 6px;
    max-height: 180px;
    overflow-y: auto;
}
.ob-genre-chip {
    display: inline-block;
    padding: 5px 13px;
    border-radius: 20px;
    background: #252525;
    color: #aaa;
    font-size: 12px;
    cursor: pointer;
    transition: all 0.15s;
    border: 1px solid transparent;
    user-select: none;
}
.ob-genre-chip:hover  { background: #333; color: #fff; }
.ob-genre-chip.ob-genre-active { background: #e60000; color: #fff; border-color: #e60000; }

/* Shake animation for validation nudge */
@keyframes obShake {
    0%,100% { transform: translateX(0); }
    20%      { transform: translateX(-6px); }
    40%      { transform: translateX(6px); }
    60%      { transform: translateX(-4px); }
    80%      { transform: translateX(4px); }
}
.ob-shake { animation: obShake 0.45s ease; }

/* User list */
.ob-user-list { display: flex; flex-direction: column; gap: 10px; margin: 12px 0; text-align: left; }
.ob-user-row  { display: flex; align-items: center; gap: 10px; }
.ob-user-avatar {
    width: 36px; height: 36px; border-radius: 50%;
    object-fit: cover; flex-shrink: 0;
    border: 1px solid #333;
}
.ob-user-name  { flex: 1; color: #ddd; font-size: 13px; text-decoration: none; }
.ob-user-name:hover { color: #fff; }
.ob-btn-follow  { background: transparent; color: #e60000; border: 1px solid #e60000; border-radius: 8px; font-size: 11px; padding: 3px 12px; }
.ob-btn-follow:hover { background: #e60000; color: #fff; }
.ob-btn-followed { background: #2a2a2a !important; color: #888 !important; border-color: #444 !important; cursor: default !important; }

/* Title list */
.ob-title-list { display: flex; flex-direction: column; gap: 10px; margin: 12px 0; text-align: left; }
.ob-title-row  { display: flex; align-items: center; gap: 10px; }
.ob-title-poster {
    width: 44px; height: 62px; object-fit: cover;
    border-radius: 5px; flex-shrink: 0;
    border: 1px solid #333;
}
.ob-title-info { flex: 1; min-width: 0; }
.ob-title-name {
    color: #ddd; font-size: 13px; font-weight: 600;
    text-decoration: none; display: block;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.ob-title-name:hover { color: #fff; }
.ob-btn-wl { background: transparent; color: #4da8ff; border: 1px solid #4da8ff; border-radius: 8px; font-size: 11px; padding: 3px 10px; white-space: nowrap; }
.ob-btn-wl:hover { background: #4da8ff; color: #fff; }
.ob-btn-added { background: #2a2a2a !important; color: #888 !important; border-color: #444 !important; cursor: default !important; }

/* Done screen XP badge */
.ob-xp-badge { margin: 16px auto 0; padding: 12px 20px; background: rgba(230,0,0,0.1); border-radius: 10px; display: inline-block; }
.ob-xp-val   { color: #f39c12; font-size: 22px; font-weight: 700; }
.ob-xp-label { color: #888; font-size: 12px; }

/* Empty state */
.ob-empty { color: #666; font-size: 12px; text-align: center; margin: 8px 0; }

/* ── Light-mode overrides ── */
#wrap.os-light-mode #obCard {
    background: #fff;
    border-color: #e0e0e0;
    box-shadow: 0 8px 32px rgba(0,0,0,0.12);
}
#wrap.os-light-mode .ob-heading { color: #1a1a1a; }
#wrap.os-light-mode .ob-sub     { color: #666; }
#wrap.os-light-mode .ob-genre-chip { background: #f0f2f5; color: #555; border-color: transparent; }
#wrap.os-light-mode .ob-genre-chip:hover { background: #e0e4ea; color: #222; }
#wrap.os-light-mode .ob-genre-chip.ob-genre-active { background: #e60000; color: #fff; }
#wrap.os-light-mode .ob-user-name  { color: #333; }
#wrap.os-light-mode .ob-user-name:hover { color: #000; }
#wrap.os-light-mode .ob-title-name { color: #333; }
#wrap.os-light-mode .ob-title-name:hover { color: #000; }
#wrap.os-light-mode .ob-btn-skip   { color: #999; }
#wrap.os-light-mode .ob-pip        { background: #ddd; }
#wrap.os-light-mode .ob-pip.ob-pip-done { background: #aaa; }
#wrap.os-light-mode .ob-user-avatar,
#wrap.os-light-mode .ob-title-poster { border-color: #ddd; }
#wrap.os-light-mode .ob-xp-badge { background: rgba(230,0,0,0.07); }
#wrap.os-light-mode .ob-empty { color: #999; }
/* ── end Onboarding Tour ──────────────────────────────────────────────────── */

/* ── Watchlist cover normalization ───────────────────────────────────────────
   Uniform 2:3 cards. Portrait covers fill normally; landscape/odd-ratio covers
   are centered (object-fit:contain) over a blurred copy of the SAME image, so
   the backdrop is color-matched to the art (no canvas/CORS needed). */
.img-box.wl-cover {
    position: relative;
    width: 100%;
    aspect-ratio: 2 / 3;
    overflow: hidden;
    background: #0f0f0f;
}
.wl-cover .wl-cover-bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform: scale(1.15);
    filter: blur(18px) saturate(1.2);
    opacity: .55;
    z-index: 0;
    pointer-events: none;
}
.wl-cover .wl-cover-img {
    position: relative;
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
    z-index: 1;
}
/* ── end Watchlist cover normalization ───────────────────────────────────── */

/* ── Profile Watch/Rewatch stats tabs ────────────────────────────────────── */
.os-ws-tabs { display:flex; gap:8px; margin-bottom:18px; border-bottom:1px solid rgba(255,255,255,.08); }
.os-ws-tab {
    background:none; border:none; cursor:pointer; padding:8px 4px; margin-bottom:-1px;
    font-size:1.05rem; font-weight:700; color:rgba(255,255,255,.45);
    border-bottom:2px solid transparent; transition:color .15s ease, border-color .15s ease;
}
.os-ws-tab:hover { color:rgba(255,255,255,.75); }
.os-ws-tab.is-active { color:#fff; border-bottom-color:#e60000; }
.os-rw-list { display:flex; flex-direction:column; gap:2px; }
.os-rw-row { display:flex; align-items:center; gap:12px; padding:8px 6px; border-radius:8px; transition:background .15s ease; }
.os-rw-row:hover { background:rgba(255,255,255,.05); }
.os-rw-cover { width:34px; height:48px; border-radius:5px; object-fit:cover; flex-shrink:0; background:#2a2824; }
.os-rw-name { flex:1; min-width:0; font-size:.86rem; font-weight:600; color:#e7e8ea; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.os-rw-row:hover .os-rw-name { color:#fff; }
.os-rw-count { font-size:.78rem; font-weight:700; color:#ff9b3d; flex-shrink:0; }
.os-rw-empty { font-size:.82rem; color:rgba(255,255,255,.5); line-height:1.5; margin:4px 0 0; }
/* ── end Profile Watch/Rewatch stats tabs ────────────────────────────────── */
