/*!
 * Project: Online Radio
 * Version: 3.0.0
 * ---------------------------------------------------------------- */

/*!
 * CSS Table of contents
 *
 * 01. CSS variables
 * 02. Common styling
 * 03. Components
 * 04. Header
 * 05. Core
 * 06. Player
 * 07. Footer
 * 08. Dark skin
 * 09. Responsive
 *
**/


/*!
 *  CSS variables
 * ----------------------------------------------- */
:root {
    /* Override Bootstrap variables */
    --bs-body-font-family: 'Open Sans', sans-serif;
    --bs-body-font-size: 14px;
    --bs-body-bg: var(--bs-gray-100);
    --bs-body-color: var(--bs-gray-700);
    --bs-heading-color: var(--bs-gray-900);

    --bs-link-color: #dc3545;
    --bs-link-hover-color: #dc3545;

    /* Theme variables */
    --primary: #dc3545;
    --primary-hover: #dc3545;
    --primary-rgb: 222, 14, 2;

    --btn-icon-size: 40px;
    --btn-icon-font-size: 24px;

    --header-bg: #fff;
    --header-height: 105px;

    --player-bg: #fff;
    --player-height: 64px;
    --player-control-width: 540px;

    --footer-bg: #fff;

    --section-icon-color: #000;

    --cover-bg: #fff;
    --cover-bg-rgb: 255, 255, 255;
    --cover-spacing: 8px;
    --cover-border-radius: 8px;
    --cover-title-color: var(--bs-gray-900);
    --cover-title-font-size: 14px;
    --cover-subtitle-color: var(--bs-gray-600);
}


/*!
 * 	Common styling
 * ----------------------------------------------- */
[class^="ri-"],
[class*=" ri-"] {
    line-height: 1;
    font-size: 16px;
}

p:last-child {
    margin-bottom: 0;
}

.text-primary {
    color: var(--primary) !important;
}

.section .section__subtitle {
    display: block;
    text-transform: uppercase;
    font-size: 12px;
    font-weight: 500;
}

.section .section__head,
.section .section__icon {
    display: -webkit-flex;
    display: -ms-flex;
    display: flex;
    -webkit-align-items: center;
    align-items: center;
}

.section .section__head {
    position: relative;
    margin-bottom: 24px;
}

.section .section__icon {
    justify-content: center;
    width: 48px;
    height: 48px;
    border-radius: 8px;
    background-color: var(--primary);
    color: #fff;
    border: 2px solid #fff;
    box-shadow: 0 1px 8px rgba(0, 0, 0, 0.1);
}

.section .section__icon [class^="ri-"],
.section .section__icon [class*=" ri-"] {
    font-size: 24px;
}


/*!
 * 	Components
 * ----------------------------------------------- */

/* Forms */
.form-control,
.form-select {
    font-size: var(--bs-body-font-size);
    min-height: 36px;
}

.btn {
    --bs-btn-font-size: var(--bs-body-font-size);
    --bs-btn-line-height: 1.572;
}

.btn-sm {
    --bs-btn-font-size: 12px;
    --bs-btn-line-height: 1.5;
    font-weight: 600;
}

.btn-icon {
    width: var(--btn-icon-size);
    height: var(--btn-icon-size);
    padding: 0;
    display: inline-flex;
    -webkit-align-items: center;
    align-items: center;
    justify-content: center;
}

.btn-icon [class^="ri-"],
.btn-icon [class*=" ri-"] {
    font-size: var(--btn-icon-font-size);
}

.btn-icon.btn-sm {
    --btn-icon-size: 32px;
    --btn-icon-font-size: 16px;
}

.btn-default {
    background-color: var(--bs-gray-200);
    border-color: var(--bs-gray-200);
    color: var(--bs-gray-800);
}

.btn-default:hover,
.btn-default:focus,
.btn-default:active,
.btn-default.active {
    background-color: var(--bs-gray-300);
    border-color: var(--bs-gray-300);
    color: var(--bs-gray-900);
}

.btn-default[data-favorite-id].active {
    background-color: var(--primary);
    border-color: var(--primary);
    color: #fff;
}

.btn-red {
    --bs-btn-color: #fff;
    --bs-btn-bg: var(--primary);
    --bs-btn-border-color: var(--primary);
}

.btn-red:hover,
.btn-red:active,
.btn-red:focus,
.btn-red.active {
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: var(--primary-hover);
    --bs-btn-hover-border-color: var(--primary-hover);
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: var(--primary-hover);
    --bs-btn-active-border-color: var(--primary-hover);
}

.btn-red:hover,
.btn-red:active,
.btn-red:focus {
    -webkit-box-shadow: 0 0 0 0.25rem rgba(var(--primary-rgb), 0.25);
    box-shadow: 0 0 0 0.25rem rgba(var(--primary-rgb), 0.25);
}

.btn-wrap {
    display: inline-flex;
    -webkit-align-items: center;
    align-items: center;
}

.btn-wrap>*:not(:first-child) {
    margin-left: 6px;
}

/* Card */
.card {
    --bs-card-cap-bg: transparent;
    --bs-card-border-color: var(--bs-gray-200);
    --bs-card-spacer-x: 24px;
    --bs-card-spacer-y: 24px;
    --bs-card-cap-padding-y: 16px;
    --bs-card-cap-padding-x: 24px;
    --bs-card-border-radius: 8px;
    border: none;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1);
}

.card-header .card-header__icon {
    background-color: rgba(var(--primary-rgb), .1);
    color: var(--primary);
    display: -webkit-flex;
    display: -ms-flex;
    display: flex;
    -webkit-align-items: center;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
}

/* Dropdown */
.dropdown-menu {
    --bs-dropdown-font-size: 13px;
    --bs-dropdown-min-width: 120px;
    --bs-dropdown-divider-bg: var(--bs-gray-200);
    --bs-dropdown-border-width: 0;
    box-shadow: 0 1px 16px rgba(0, 0, 0, 0.15);
}

/* Navbar */
.navbar {
    --bs-navbar-padding-y: 0;
    --bs-navbar-toggler-padding-y: 0;
    --bs-navbar-toggler-padding-x: 0;
    --bs-navbar-toggler-focus-width: 0;
    --bs-border-width: 0;
    --bs-navbar-toggler-font-size: 24px;
    --bs-navbar-color: var(--bs-gray-900);
}

.navbar-nav .nav-link {
    --bs-nav-link-padding-y: 19px;
    --bs-navbar-nav-link-padding-x: 16px;
    --bs-nav-link-font-weight: 600;
    --bs-navbar-active-color: var(--primary);
    --bs-nav-link-hover-color: var(--primary);
    position: relative;
    line-height: 1;
}

.navbar-nav .nav-link:before {
    content: '';
    position: absolute;
    left: 4px;
    right: 4px;
    bottom: 3px;
    height: 2px;
}

.navbar-nav .nav-item .nav-link:hover:before,
.navbar-nav .nav-item .nav-link:focus:before,
.navbar-nav .nav-item .nav-link:active:before,
.navbar-nav .nav-item .nav-link.active:before {
    background-color: currentColor;
}

.navbar-toggler [class^="ri-"],
.navbar-toggler [class*=" ri-"] {
    font-size: 24px;
}

/* List group */
.list-group {
    --bs-list-group-border-color: var(--bs-gray-200);
}

.list-group .list-group__cover {
    position: relative;
    border-radius: 4px;
    overflow: hidden;
    flex: 0 0 auto;
    width: 48px;
    height: 48px;
}

.list-group .list-group__cover img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.list-group .list-group__cover .btn {
    position: absolute;
    top: 50%;
    left: 50%;
    margin: -16px 0 0 -16px;
}

.list-group .list-group__cover .btn {
    --bs-btn-bg: #fff;
    --bs-btn-color: var(--bs-gray-900);
    opacity: 0;
    visibility: hidden;
}

.list-group .list-group__cover .btn:hover,
.list-group .list-group__cover .btn:focus,
.list-group .list-group__cover .btn:active {
    --bs-btn-hover-bg: #fff;
    --bs-btn-hover-color: var(--bs-gray-900);
    --bs-btn-hover-border-color: #fff;
}

.list-group .list-group__content {
    flex-grow: 1;
    flex-basis: 0;
    min-width: 0;
}

.list-group .list-group__title {
    display: block;
    font-weight: 600;
    color: var(--cover-title-color);
    text-decoration: none;
}

.list-group .list-group__subtitle {
    display: block;
    color: var(--cover-subtitle-color);
    font-size: 13px;
}

.list-group .list-group__fav {
    text-decoration: none;
    color: inherit;
}

.list-group .list-group-item {
    --bs-list-group-bg: transparent;
}

.list-group .list-group-item:hover .list-group__cover .btn {
    opacity: 1;
    visibility: visible;
}

.list-group .list-group__number {
    color: var(--bs-gray-600);
    font-weight: 600;
}

.list-group.list-group--embedded .list-group__cover {
    width: 120px;
    height: 120px;
}

.list-group.list-group--fav [data-radio-id] {
    text-decoration: none;
    width: 24px;
    height: 24px;
    color: var(--bs-gray-900);
    margin: 0 16px;
}

.list-group.list-group--fav [data-radio-id] [class^="ri-"],
.list-group.list-group--fav [data-radio-id] [class*=" ri-"] {
    font-size: 24px;
}

.list-group.list-group--fav .list-group__cover {
    width: 64px;
    height: 64px;
}

.list-group.list-group--fav [data-favorite-id] {
    text-decoration: none;
    width: 16px;
    height: 16px;
}

/* Modal */
.modal {
    --bs-modal-padding: 16px 24px;
    --bs-modal-header-padding: 16px 24px;
    --bs-modal-border-color: transparent;
}

/* Pagination */
.pagination {
    --bs-pagination-font-size: 12px;
    --bs-pagination-color: var(--bs-gray-900);
    --bs-pagination-bg: var(--bs-gray-200);
    --bs-pagination-border-width: 0;
    --bs-pagination-hover-color: #fff;
    --bs-pagination-hover-bg: var(--primary);
    --bs-pagination-focus-color: var(--bs-pagination-hover-color);
    --bs-pagination-focus-bg: var(--bs-pagination-hover-bg);
    --bs-pagination-focus-box-shadow: none;
    --bs-pagination-active-color: var(--bs-pagination-hover-color);
    --bs-pagination-active-bg: var(--bs-pagination-hover-bg);
    --bs-pagination-border-radius: 4px;
}

.pagination .page-item:not(:first-child) {
    margin-left: 8px;
}

.pagination .page-link {
    border-radius: var(--bs-pagination-border-radius);
    font-weight: 500;
    text-transform: uppercase;
}

/* Tooltip */
.tooltip {
    --bs-tooltip-padding-x: 12px;
    --bs-tooltip-padding-y: 5px;
}

/* Swiper */
.swiper-carousel {
    position: relative;
}

.swiper-button-prev,
.swiper-button-next {
    --swiper-navigation-color: var(--bs-gray-900);
    --swiper-navigation-size: 20px;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    margin-top: -32px;
    background-color: #fff;
    box-shadow: 0 1px 12px rgba(0, 0, 0, 0.1);
    visibility: hidden;
    -webkit-transition: all .15s ease-in;
    transition: all .15s ease-in;
}

.swiper-button-prev {
    left: -15px;
}

.swiper-button-next {
    right: -15px;
}

.swiper-button-arrow {
    border-radius: 8px;
}

.swiper-button-arrow:after {
    display: none;
}

.swiper-carousel:hover .swiper-button-prev,
.swiper-carousel:hover .swiper-button-next {
    visibility: visible;
}

.swiper-button-next.swiper-button-disabled,
.swiper-button-prev.swiper-button-disabled {
    opacity: 0.5;
}

.swiper-scrollbar,
.swiper-button-inline .swiper-button-next,
.swiper-button-inline .swiper-button-prev {
    position: relative !important;
    top: initial !important;
    left: initial !important;
    right: initial !important;
}

.swiper-pagination {
    --swiper-pagination-color: var(--primary);
    position: relative;
    bottom: initial !important;
    margin-top: 16px;
}

.swiper-scrollbar {
    width: 100% !important;
    bottom: initial !important;
    height: 2px !important;
    border-radius: 1px !important;
    background-color: var(--bs-gray-300);
}

.swiper-scrollbar-drag {
    border-radius: 1px !important;
    background-color: var(--bs-gray-900);
}

.swiper-button-inline {
    display: -webkit-flex;
    display: -ms-flex;
    display: flex;
    -webkit-align-items: center;
    align-items: center;
}

.swiper-button-inline .swiper-button-next,
.swiper-button-inline .swiper-button-prev {
    margin-top: initial;
    background-color: var(--bs-gray-300);
    visibility: visible;
    -webkit-box-shadow: none;
    box-shadow: none;
}

.swiper-button-inline .swiper-button-next [class^="ri-"],
.swiper-button-inline .swiper-button-next [class*=" ri-"],
.swiper-button-inline .swiper-button-prev [class^="ri-"],
.swiper-button-inline .swiper-button-prev [class*=" ri-"] {
    font-size: 20px;
}

.swiper-slide .cover.cover--air {
    margin: 4px;
}

/* Cover */
.cover {
    position: relative;
    border-radius: var(--cover-border-radius);
    background-color: var(--cover-bg);
    overflow: hidden;
    padding: var(--cover-spacing);
}

.cover img {
    width: 100%;
    transition: transform .25s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    /* filter: saturate(0.5); */
}

.cover:not(.cover--details):hover .cover__hero img,
.cover:not(.cover--details):hover .cover__image:not(.cover__image--flag) img {
    -webkit-transform: scale(1.1);
    -moz-transform: scale(1.1);
    transform: scale(1.1);
}

.cover .cover__hero {
    border-radius: var(--cover-border-radius);
    display: block;
    position: relative;
    margin: calc(-1 * var(--cover-spacing));
}

.cover .cover__hero .cover__hero__content {
    --cover-title-color: #fff;
    --cover-title-font-size: 20px;
    --cover-subtitle-color: var(--bs-gray-200);
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    padding: 40px 24px 24px;
    background: -webkit-linear-gradient(0deg, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 0) 100%);
    background: linear-gradient(0deg, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 0) 100%);
    border-bottom-left-radius: var(--cover-border-radius);
    border-bottom-right-radius: var(--cover-border-radius);
}

.cover .cover__head {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    padding: 16px 24px;
    display: -webkit-flex;
    display: -ms-flex;
    display: flex;
    -webkit-align-items: center;
    align-items: center;
    color: #fff;
}

.cover .cover__label {
    margin: 0;
    padding: 0;
    list-style: none;
    display: -webkit-flex;
    display: -ms-flex;
    display: flex;
    -webkit-align-items: center;
    align-items: center;
    z-index: 10;
    position: relative;
}

.cover .cover__label li:not(:first-child) {
    margin-left: 6px;
}

.cover .cover__label .cover__label__view {
    border-radius: 4px;
    padding: 4px 7px;
    display: inline-flex;
    -webkit-align-items: center;
    align-items: center;
    text-decoration: none;
    line-height: 1;
    color: #fff;
    background: #00000054;
    backdrop-filter: blur(10px);
    filter: hue-rotate(143deg);
}

.cover .cover__label .cover__label__view span {
    padding-left: 4px;
    font-weight: 600;
}

.cover .cover__image {
    overflow: hidden;
    position: relative;
    display: block;
    border-radius: calc(var(--cover-border-radius) * .75);
}

.cover .cover__image .cover__head {
    padding: 16px;
}

.cover .cover__image.cover__image--flag {
    width: 64px;
    height: 64px;
    border-radius: 50%;
}

.cover .cover__image.cover__image--flag img {
    position: absolute;
    width: 160%;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}

.cover .cover__image [data-play-id] {
    position: absolute;
    top: 55%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    z-index: 1;
}

.cover .cover__body {
    padding: 8px;
}

.cover .cover__image+.cover__body {
    padding-bottom: 0;
}

.cover .cover__title {
    display: block;
    font-size: var(--cover-title-font-size);
    font-weight: 600;
    color: var(--cover-title-color);
    text-decoration: none;
}

.cover .cover__subtitle {
    display: block;
    color: var(--cover-subtitle-color);
    font-size: 13px;
}

.cover .cover__visualizer {
    position: absolute;
    width: 100%;
    height: 120px;
    left: 0;
    bottom: -14px;
    z-index: 1;
    opacity: .85;
}

.cover .cover__desc {
    margin-left: calc(-1 * var(--cover-spacing));
    margin-right: calc(-1 * var(--cover-spacing));
    padding: var(--cover-spacing) var(--cover-spacing) 0;
}

.cover .cover__desc+.cover__desc {
    margin-top: var(--cover-spacing);
}

.cover.cover--air {
    border: 1px solid #e9e9e9 !important;
    box-shadow: 0 1px 4px rgb(0 0 0 / 3%);
}

.cover.cover--flag .cover__image {
    height: 125px;
}

.cover.cover--flag .cover__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.cover.cover--details {
    --cover-spacing: 10px;
}

.cover.cover--details .cover__hero {
    height: 240px;
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
}

.cover.cover--details .cover__hero:after {
    content: '';
    position: absolute;
    left: 0;
    top: 2px;
    width: 100%;
    height: 100%;
    background: -webkit-linear-gradient(0deg, rgba(var(--cover-bg-rgb), 1) 0%, rgba(var(--cover-bg-rgb), 0) 100%);
    background: linear-gradient(0deg, rgba(var(--cover-bg-rgb), 1) 0%, rgba(var(--cover-bg-rgb), 0) 100%);
}

.cover.cover--details .cover__hero img,
.cover.cover--details .cover__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.cover.cover--details .cover__image {
    width: 200px;
    height: 200px;
}

.cover.cover--details .cover__body {
    padding: 0 0 0 20px;
    flex: 1;
}

[data-radio-id]:not(.active) .icon-pause,
[data-radio-id].active .icon-play,
[data-favorite-id]:not(.active) .heart-fill,
[data-favorite-id].active .heart-empty {
    display: none;
}

[data-radio-id].active .icon-pause,
[data-favorite-id].active .heart-fill {
    display: block;
}


/*!
 * 	Header
 * ----------------------------------------------- */
#header {
    background: var(--header-bg);
    position: fixed;
    z-index: 1000;
    height: var(--header-height);
    -webkit-box-shadow: 0px 0px 10px 2px rgba(0, 0, 0, 0.05);
    box-shadow: 0px 0px 10px 2px rgba(0, 0, 0, 0.05);
    left: 0px;
    top: 0px;
    right: 0px;
    border: 1px solid #e9e9e9 !important;
    border-bottom-left-radius: 20px;
    border-bottom-right-radius: 20px;
}

.header-top {
    padding-top: 8px;
    padding-bottom: 7px;
    border-bottom: 1px solid #e9e9e9 !important;
}


.navbar-brand-text {
    margin-left: 1px;
    font-size: 24px;
    font-weight: 800;
}

.search {
    position: relative;
    min-width: 25%;
}

.search .btn {
    position: absolute;
    top: 0;
    right: 8px;
    padding: 0;
    background: none !important;
    border: none !important;
    height: 100%;
    width: 36px;
    display: -webkit-flex;
    display: -ms-flex;
    display: flex;
    -webkit-align-items: center;
    align-items: center;
    justify-content: center;
}

.search .form-control {
    padding-right: 40px;
    padding-left: 16px;
}

.has-menu,
.has-menu>.nav-link {
    position: relative;
}

.has-menu>.nav-link:after {
    content: '';
    display: inline-block;
    margin-left: 6px;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 4px solid currentColor;
    position: relative;
    top: -2px;
    opacity: 0.4;
    -webkit-transition: opacity .15s ease-in-out;
    transition: opacity .15s ease-in-out;
}

.submenu {
    flex-direction: column !important;
    position: absolute;
    top: 100%;
    left: 0;
    background-color: var(--header-bg);
    min-width: 185px;
    -webkit-box-shadow: 0 1px 30px rgba(0, 0, 0, 0.1);
    box-shadow: 0 1px 30px rgba(0, 0, 0, 0.1);
    padding: 8px 0;
    opacity: 0;
    visibility: hidden;
    -webkit-transition: all .25s ease-in-out;
    transition: all .25s ease-in-out;
    z-index: 10;
    border-radius: 8px;
}

.submenu.navbar-nav .nav-link {
    --bs-nav-link-padding-y: 11px;
    --bs-navbar-nav-link-padding-x: 24px;
    display: block;
}

.submenu.navbar-nav .nav-link:hover {
    background-color: rgba(var(--primary-rgb), 0.05);
}

.submenu.navbar-nav .nav-link:before {
    display: none;
}

.submenu .has-menu>.nav-link {
    display: -webkit-flex;
    display: -ms-flex;
    display: flex;
    -webkit-align-items: center;
    align-items: center;
    justify-content: space-between;
}

.submenu .has-menu>.nav-link:after {
    border-top: 4px solid transparent;
    border-left: 4px solid currentColor;
    border-bottom: 4px solid transparent;
    border-right: none;
}

.submenu .submenu {
    left: 100%;
    top: 0;
}

.has-menu:hover>.submenu {
    visibility: visible;
    opacity: 1;
}

.has-menu:hover>a:after {
    opacity: 1;
}


/*!
 * 	Core
 * ----------------------------------------------- */
#dark_mode .icon-light,
#dark_mode.active .icon-dark,
#embedded_play .icon-pause,
#embedded_play.active .icon-play {
    display: none;
}

#dark_mode.active .icon-light,
#embedded_play.active .icon-pause {
    display: block;
}

#embedded_play {
    min-width: 110px;
}

#embedded_player {
    position: absolute;
    top: -1000px;
    left: -10000px;
}

#loader {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1001;
    background-color: var(--header-bg);
    display: -webkit-flex;
    display: -ms-flex;
    display: flex;
    -webkit-align-items: center;
    align-items: center;
    justify-content: center;
    text-align: center;
}

#loader_progress {
    position: relative;
    overflow: hidden;
    background-color: rgba(var(--primary-rgb), .1);
    width: 240px;
    height: 4px;
}

#loader_progress:before {
    content: '';
    position: absolute;
    left: -32px;
    width: 90px;
    height: 100%;
    background-color: var(--primary);
    -webkit-animation: loader 1.5s infinite ease;
    animation: loader 1.5s infinite ease;
}

@-webkit-keyframes loader {
    50% {
        left: 192px;
    }
}

@keyframes loader {
    50% {
        left: 192px;
    }
}

#line_loader {
    position: fixed;
    top: 0;
    left: 0;
    width: 0;
    height: 2px;
    display: none;
    background-color: #ff005e;
    z-index: 999;
}

.under-header {
    margin-top: var(--header-height);
    padding-top: 64px;
}

.main {
    flex: 0 0 auto;
    width: 70%;
}

.sidebar {
    flex: 0 0 auto;
    width: 30%;
}

.sticky {
    will-change: min-height;
}

.sticky .sticky__content {
    -webkit-transform: translate(0, 0);
    -moz-transform: translate(0, 0);
    transform: translate(0, 0);
    -webkit-transform: translate3d(0, 0, 0);
    -moz-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    will-change: position, transform;
}

.playlist-sidebar+.playlist-sidebar {
    margin-top: 24px;
}

.radio-info,
.radio-info li,
.radio-info .radio-info__icon {
    display: -webkit-flex;
    display: -ms-flex;
    display: flex;
    -webkit-align-items: center;
    align-items: center;
}

.radio-info {
    margin: 0;
    padding: 0;
    list-style: none;
}

.radio-info li:not(:first-child) {
    margin-left: 16px;
}

.radio-info .radio-info__icon {
    flex: 0 0 auto;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    justify-content: center;
    background-color: var(--bs-gray-200);
}

.radio-info.radio-info--share .radio-info__icon {
    width: 40px;
    height: 40px;
}

.radio-info.radio-info--share .radio-info__icon [class^="ri-"],
.radio-info.radio-info--share .radio-info__icon [class*=" ri-"] {
    font-size: 20px;
}

#visualizer_wrap {
    position: fixed;
    left: 63px;
    top: 303px;
    overflow: hidden;
    visibility: hidden;
}

#visualizer {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
}

.code-view {
    padding: 16px;
    border-radius: 4px;
    background-color: var(--bs-gray-100);
}

.code-view .code-view__pre {
    padding-left: 8px;
    padding-right: 16px;
    margin: 0;
    flex: 1;
    overflow: visible;
    white-space: normal;
    word-break: break-all;
}

.code-view .code-view__copy {
    display: inline-flex;
    text-decoration: none;
    color: var(--bs-gray-900);
}

.alert-wrap {
    position: fixed;
    bottom: 0;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -moz-transform: translateX(-50%);
    transform: translateX(-50%);
    max-width: 380px;
    width: 100%;
    z-index: 2000;
    padding: 16px;
}


/*!
 * 	Player
 * ----------------------------------------------- */
#player,
#player_info {
    -webkit-box-shadow: 0 1px 16px rgba(0, 0, 0, 0.25);
    box-shadow: 0 1px 16px rgba(0, 0, 0, 0.25);
}

#player {
    position: fixed;
    bottom: 64px;
    left: -100%;
    z-index: 99;
    display: -webkit-flex;
    display: -ms-flex;
    display: flex;
    height: var(--player-height);
    border-top-right-radius: 4px;
    border-bottom-right-radius: 4px;
    -webkit-transition: left .25s cubic-bezier(0.075, 0.82, 0.165, 1);
    transition: left .25s cubic-bezier(0.075, 0.82, 0.165, 1);
}

#player.visible {
    left: calc(-1 * var(--player-control-width));
}

#player.show {
    left: 0;
}

#player_toggler {
    color: inherit;
    text-decoration: none;
    display: -webkit-flex;
    display: -ms-flex;
    display: flex;
    -webkit-align-items: center;
    align-items: center;
    justify-content: center;
    background-color: var(--player-bg);
    border-top-right-radius: 4px;
    border-bottom-right-radius: 4px;
    border: 1px solid #e9e9e9 !important;
}

#player.show #player_toggler {
    background-color: var(--bs-gray-100);
}

#player #player_toggler .arrow-left,
#player.show #player_toggler .arrow-right,
#player .mejs__play .icon-pause,
#player .mejs__pause .icon-play,
#player .mejs__unmute .volume,
#player .mejs__mute .mute {
    display: none;
}

#player.show #player_toggler .arrow-left {
    display: block;
}

#player .mejs__controls,
#player .mejs__container>* {
    height: 100%;
}

#player .mejs__container {
    background: var(--player-bg);
    color: var(--bs-gray-900);
    min-height: var(--player-height);
    min-width: initial !important;
    width: initial !important;
    height: initial !important;
    flex: 1;
    font-family: inherit;
}

#player .mejs__controls {
    background: transparent;
    width: var(--player-control-width);
    position: relative;
    bottom: initial;
    -webkit-align-items: center;
    align-items: center;
    padding: 0 16px;
}

#player .mejs__button {
    width: 24px;
    height: 24px;
}

#player .mejs__button.mejs__playpause-button {
    margin-left: 12px;
    margin-right: 12px;
}

#player .mejs__time {
    color: inherit;
    padding: 0 16px 0 0;
    height: initial;
    font-size: 12px;
    font-weight: 600;
}

#player .mejs__button>button {
    width: 24px;
    height: 24px;
    background: transparent;
    outline: none;
    margin: 0;
    color: inherit;
    position: relative;
}

#player .mejs__button>button:disabled {
    opacity: 0.6;
    cursor: default;
}

#player .mejs__button>button [class^="ri-"],
#player .mejs__button>button [class*=" ri-"] {
    font-size: 24px;
}

#player .mejs__horizontal-volume-slider {
    width: 64px;
    height: initial;
    margin-left: 12px;
    margin-right: 24px;
}

#player .mejs__horizontal-volume-total {
    position: relative;
    top: initial;
    width: 100%;
    height: 4px;
    background: rgba(0, 0, 0, .3);
}

#player .mejs__horizontal-volume-current {
    color: var(--bs-gray-900);
    background-color: currentColor;
}

#player .mejs__horizontal-volume-current:after {
    content: '';
    position: absolute;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background-color: currentColor;
    top: -3px;
    right: -2px;
}

#player .list-group .list-group__cover {
    width: 40px;
    height: 40px;
}

#player .list-group .list-group__content {
    width: 140px;
}

#player_info {
    position: absolute;
    left: 0;
    right: 20px;
    bottom: 100%;
    background-color: var(--player-bg);
    padding: 24px 24px 10px;
    flex-wrap: wrap;
    display: none;
}

#player_info.show {
    display: -webkit-flex;
    display: -ms-flex;
    display: flex;
}

#player_info .cover {
    padding: 0;
    width: 200px;
    height: 200px;
    flex: 0 0 auto;
    border-radius: 4px;
}

#player_info .cover:hover img {
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    transform: scale(1);
}

.playlist {
    flex: 1;
    padding-left: 24px;
}

#playlist {
    line-height: 1.25;
    background-color: var(--bs-gray-100);
    counter-reset: number;
    max-height: 164px;
    overflow: auto;
}

#playlist::-webkit-scrollbar {
    width: 4px;
}

#playlist::-webkit-scrollbar-track {
    background: var(--bs-gray-400);
}

#playlist::-webkit-scrollbar-thumb {
    background: var(--bs-gray-900);
}

#playlist a {
    text-decoration: none;
    color: var(--bs-gray-900);
}

#playlist.list-group .list-group-item {
    counter-increment: number;
}

#playlist.list-group .list-group__cover {
    width: 36px;
    height: 36px;
}

#playlist .remove-radio,
#playlist [data-radio-id] {
    line-height: 16px;
    display: block;
    height: 16px;
}

#playlist .remove-radio {
    font-size: 16px;
    text-align: center;
    visibility: hidden;
    opacity: 0;
}

#playlist [data-radio-id] {
    display: none;
}

#playlist [data-radio-id],
#playlist.list-group .list-group-item .list-group__number {
    width: 24px;
    text-align: right;
}

#playlist.list-group .list-group-item .list-group__number:before {
    content: "#" counter(number);
    font-size: 11px;
}

#playlist.list-group .list-group-item .active[data-radio-id],
#playlist.list-group .list-group-item:hover [data-radio-id] {
    display: block;
}

#playlist.list-group .list-group-item:hover .list-group__number,
#playlist.list-group .list-group-item .active[data-radio-id]+.list-group__number {
    display: none;
}

#playlist.list-group .list-group-item:hover .remove-radio {
    visibility: visible;
    opacity: 1;
}

#clear_playlist {
    text-decoration: none;
    color: var(--bs-gray-900);
    font-size: 12px;
    font-weight: 600;
}

#close_playlist {
    position: absolute;
    top: -6px;
    right: -6px;
    border-radius: 50%;
    background-color: var(--bs-gray-900);
    color: var(--bs-gray-100);
    display: block;
    width: 20px;
    height: 20px;
    text-align: center;
    line-height: 18px;
    font-size: 18px;
    text-decoration: none;
}


/*!
 * 	Footer
 * ----------------------------------------------- */
#footer {
    background-color: var(--footer-bg);
    padding-top: 30px;
    margin-top: 50px;
    -webkit-box-shadow: 0px 0px 10px 2px rgb(0 0 0 / 2%);
    box-shadow: 0px 0px 10px 2px rgb(0 0 0 / 2%);
    border: 1px solid #e9e9e9 !important;
    border-top-left-radius: 20px;
    border-top-right-radius: 20px;
}

.last-footer {
    background-color: var(--bs-body-bg);
    border-bottom-left-radius: 8px;
    border-bottom-right-radius: 8px;
}

.footer-data>* {
    display: inline-flex;
    line-height: 1;
}

.footer-data a {
    color: inherit;
    text-decoration: none;
}

.footer-title {
    display: block;
    font-weight: 600;
}

.footer-link {
    margin: 0;
    padding: 0;
    list-style: none;
}

.footer-link li:not(:first-child) {
    margin-top: 8px;
}

.footer-link li a {
    text-decoration: none;
    font-weight: 500;
    color: inherit;
    display: inline-flex;
    -webkit-align-items: center;
    align-items: center;
}

.footer-link li a:before {
    content: '';
    display: inline-block;
    width: 4px;
    height: 1px;
    background-color: currentColor;
    margin-right: 4px;
    -webkit-transition: all .25s ease;
    transition: all .25s ease;
}

.footer-link li a:hover {
    color: var(--primary);
}

.footer-link li a:hover:before {
    width: 12px;
}

.app-download .btn {
    --bs-btn-bg: var(--bs-gray-900);
    --bs-btn-color: #fff;
}

.app-download .btn:hover,
.app-download .btn:focus,
.app-download .btn:active {
    --bs-btn-hover-bg: #fff;
    --bs-btn-hover-color: #131518;
    --bs-btn-hover-border-color: #131518;
}

.last-footer {
    border-top: 1px solid var(--bs-gray-200);
}


.banner_image>img {
    height: 230px;
    object-fit: cover;
}

/* cookie */
.cookie {
    width: 410px;
    height: 72px;
    background-color: #fff;
    position: fixed;
    bottom: 4%;
    border-radius: 10px;
    left: 35px;
    padding: 10px 20px;
    z-index: 10;
    border: 1px solid #f3f3f3;
}

.cookie.active {
    display: none;
}

.cookie .txt {
    float: left;
    width: 65%;
}

.txt p {
    color: #1D2D35;
    margin: 2%;
}

.cookie .accept {
    background-color: #40CC79;
    color: #fff !important;
    border-radius: 32px;
    padding: 3px 23px;
    font-size: 19px;
    margin: 2%;
    margin-left: 3%;
}

.cookie .accept:hover {
    background-color: #30b867;
}

.nsofts-setting {
    flex-wrap: wrap;
    display: flex;
}

.nsofts-setting .nsofts-setting__sidebar {
    flex: 0 0 auto;
    width: 240px;
    padding: 24px;
    border-right: 1px solid rgba(0, 0, 0, .125);
}

.nsofts-setting .nsofts-setting__sidebar .nav-link {
    display: flex;
    align-items: center;
    color: var(--color-grey-400);
    font-weight: 500;
}

.nsofts-setting .nsofts-setting__sidebar .nav-link.active,
.nsofts-setting .nsofts-setting__sidebar .nav-link:hover {
    background-color: rgb(0 0 0 / 5%);
}

.nsofts-setting .nsofts-setting__sidebar .nav-link span {
    padding-left: 8px;
}

.nsofts-setting .nsofts-setting__content {
    flex: 1;
    padding: 24px 24px 24px 32px;
}

.banner_image>img {
    height: 230px;
    object-fit: cover;
}

.bg_blur {
    position: absolute;
    width: 100%;
    height: 100%;
    left: 0;
    bottom: 0px;
    z-index: 0;
    backdrop-filter: blur(8px);
    filter: saturate(0.5);
}

.nav-icon {
    margin-right: 8px !important;
}

.scroll-top {
    width: 40px;
    height: 40px;
    line-height: 40px;
    position: fixed;
    top: 100%;
    right: 50px;
    font-size: 16px;
    border-radius: 4px;
    z-index: 99;
    text-align: center;
    cursor: pointer;
    -webkit-transition: 1s ease;
    transition: 1s ease;
    border: none
}

.scroll-top:after {
    position: absolute;
    z-index: -1;
    content: "";
    top: 100%;
    left: 5%;
    height: 10px;
    width: 90%;
    opacity: 1;
    background: radial-gradient(ellipse at center, rgba(0, 0, 0, 0.25) 0%, rgba(0, 0, 0, 0) 80%)
}

.primary-bg {
    background: var(--primary) !important;
}

.alert.alert-secondary {
    background-color: var(--bs-body-bg);
    border-color: var(--bs-gray-200);
    color: var(--bs-body-color);
}

#share_radio {
    background-color: rgb(0 0 0 / 0%);
    backdrop-filter: blur(10px);
}

/*!
 * 	Dark skin
 * ----------------------------------------------- */
body[data-theme="dark"] {
    --bs-body-bg: #131518;
    --bs-body-color: #adb5bd;

    --bs-heading-color: #fff;

    --bs-gray-100: #212529;
    --bs-gray-200: #343a40;
    --bs-gray-300: #495057;
    --bs-gray-400: #6c757d;
    --bs-gray-500: #adb5bd;
    --bs-gray-600: #ced4da;
    --bs-gray-700: #dee2e6;
    --bs-gray-800: #e9ecef;
    --bs-gray-900: #ffffff;

    --bs-border-color: #495057;

    --header-bg: #212529;
    --footer-bg: #212529;
    --player-bg: #212529;

    --cover-bg: #212529;
    --cover-bg-rgb: 33, 37, 41;
    --cover-title-color: #fff;
    --cover-subtitle-color: #adb5bd;

    --swiper-pagination-bullet-inactive-color: #ffffff;
}

body[data-theme="dark"] .navbar-brand {
    --bs-navbar-brand-color: #fff;
    --bs-navbar-brand-hover-color: #fff;
}

body[data-theme="dark"] .search .btn {
    color: inherit;
}

body[data-theme="dark"] .card {
    --bs-card-bg: #212529;
}

body[data-theme="dark"] .cover .cover__hero .cover__hero__content {
    --cover-subtitle-color: #adb5bd;
}

body[data-theme="dark"] .form-control,
body[data-theme="dark"] .form-select {
    background-color: var(--bs-body-bg);
    border-color: var(--bs-gray-200);
    color: var(--bs-body-color);
}

body[data-theme="dark"] .form-select {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23adb5bd' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
}

body[data-theme="dark"] .swiper-scrollbar-drag {
    background-color: var(--bs-gray-500);
}

body[data-theme="dark"] .app-download .btn {
    --bs-btn-bg: #131518;
}

body[data-theme="dark"] .app-download .btn:hover,
body[data-theme="dark"] .app-download .btn:focus,
body[data-theme="dark"] .app-download .btn:active {
    --bs-btn-hover-bg: #343a40;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-border-color: #343a40;
    --bs-btn-active-bg: #343a40;
    --bs-btn-active-color: #fff;
    --bs-btn-active-border-color: #343a40;
}

body[data-theme="dark"] .modal {
    --bs-modal-bg: #131518;
    --bs-modal-header-border-color: var(--bs-gray-100);
    background: rgba(0, 0, 0, .4);
}

body[data-theme="dark"] .modal .btn-close {
    background: transparent url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23fff'%3e%3cpath d='M.293.293a1 1 0 0 1 1.414 0L8 6.586 14.293.293a1 1 0 1 1 1.414 1.414L9.414 8l6.293 6.293a1 1 0 0 1-1.414 1.414L8 9.414l-6.293 6.293a1 1 0 0 1-1.414-1.414L6.586 8 .293 1.707a1 1 0 0 1 0-1.414z'/%3e%3c/svg%3e") center/1em auto no-repeat;
}

body[data-theme="dark"] .text-dark {
    color: #fff !important;
}

body[data-theme="dark"] #player,
body[data-theme="dark"] #player_info {
    -webkit-box-shadow: 0 1px 16px rgb(0 0 0 / 25%);
    box-shadow: 0 1px 16px rgb(0 0 0 / 25%);
}

body[data-theme="dark"] #playlist {
    background-color: #282d32;
}

body[data-theme="dark"] #player.show #player_toggler {
    background-color: var(--bs-gray-200);
}

body[data-theme="dark"] #player .mejs__horizontal-volume-total {
    background: rgba(255, 255, 255, .3);
}


body[data-theme="dark"] .cookie {
    background-color: #212529 !important;
    border: 1px solid #2d2d2d !important;
}

body[data-theme="dark"] .txt p {
    color: #ebebeb !important;
}

body[data-theme="dark"] #header {
    border: 1px solid #2d2d2d !important;
    webkit-box-shadow: 0px 0px 10px 2px rgb(0 0 0 / 8%);
    box-shadow: 0px 0px 10px 2px rgb(0 0 0 / 8%);
}

body[data-theme="dark"] #footer {
    border: 1px solid #2d2d2d !important;
    webkit-box-shadow: 0px 0px 10px 2px rgb(0 0 0 / 5%);
    box-shadow: 0px 0px 10px 2px rgb(0 0 0 / 5%);
}

body[data-theme="dark"] .header-top {
    border-bottom: 1px solid #2d2d2d !important;
}

body[data-theme="dark"] .cover.cover--air {
    border: 1px solid #2d2d2d !important;
    webkit-box-shadow: 0px 0px 10px 2px rgb(0 0 0 / 8%);
    box-shadow: 0px 0px 10px 2px rgb(0 0 0 / 8%);
}

body[data-theme="dark"] .card {
    border: 1px solid #2d2d2d !important;
    webkit-box-shadow: 0px 0px 10px 2px rgb(0 0 0 / 8%);
    box-shadow: 0px 0px 10px 2px rgb(0 0 0 / 8%);
}

body[data-theme="dark"] .nsofts-setting .nsofts-setting__sidebar {
    border-color: #2d2f32;
}

body[data-theme="dark"] .nsofts-setting .nsofts-setting__sidebar .nav-link,
body[data-theme="dark"] .select2-container--default .select2-search--inline .select2-search__field {
    color: inherit;
}

body[data-theme="dark"] .nsofts-setting .nsofts-setting__sidebar .nav-link.active,
body[data-theme="dark"] .nsofts-setting .nsofts-setting__sidebar .nav-link:hover {
    background-color: rgb(255 255 255 / 3%);
}

body[data-theme="dark"] #player_toggler {
    border: 1px solid #2d2d2d !important;
}

#pb-search-input {
    background-color: var(--bs-body-bg);
}

/*!
 * 	Responsive
 * ----------------------------------------------- */

@media (max-width: 991.98px) {
    #header {
        height: initial;
    }

    .search {
        width: 100%;
    }

    .search label {
        left: 16px;
    }

    #main_navbar {
        max-height: calc(100vh - var(--header-height));
        overflow: auto;
    }

    .navbar-nav .nav-link {
        --bs-nav-link-padding-y: 16px;
    }

    .navbar-nav .nav-link:not(.active) {
        border-bottom: 1px solid var(--bs-gray-200);
    }

    .navbar-nav .nav-link:before {
        left: 0;
        right: 0;
    }

    .has-menu>.nav-link {
        display: -webkit-flex;
        display: -ms-flex;
        display: flex;
        -webkit-align-items: center;
        align-items: center;
        justify-content: space-between;
    }

    .submenu {
        position: relative;
        top: initial !important;
        left: initial !important;
        opacity: 1;
        visibility: visible;
        -webkit-box-shadow: none;
        box-shadow: none;
        padding: 0;
        display: none;
        background-color: var(--bs-gray-100);
    }

    .submenu .nav-link {
        padding-left: 16px;
        padding-right: 16px;
    }

    .submenu .submenu .nav-link {
        padding-left: 32px;
        padding-right: 32px;
    }

    .submenu .has-menu>.nav-link:after {
        border: none;
    }

    .has-menu:hover .submenu,
    .has-menu:focus .submenu,
    .has-menu:active .submenu {
        display: block;
    }

    .submenu.navbar-nav .nav-link:hover {
        background: transparent;
    }

    .main,
    .sidebar {
        width: 100%;
    }

    .sidebar {
        margin-top: 48px;
    }
}

@media (max-width: 575.98px) {
    body {
        --player-control-width: 372px;
    }

    .container {
        --bs-gutter-x: 32px;
    }

    .g-4,
    .gx-4 {
        --bs-gutter-x: 16px;
    }

    .cover.cover--details .cover__image {
        width: initial;
        height: initial;
    }

    .cover.cover--details .cover__body {
        padding: 0;
    }

    #player {
        bottom: 32px;
    }

    #player_info .cover,
    #player .mejs__volume-button,
    #player .mejs__horizontal-volume-slider {
        display: none;
    }

    .playlist {
        padding-left: 0;
    }

    #player .mejs__button.mejs__playpause-button {
        margin-left: 8px;
        margin-right: 8px;
    }

    #player .list-group .list-group__content {
        width: 100px;
    }

    .list-group.list-group--fav .list-group__cover {
        width: 48px;
        height: 48px;
    }

    .bg_blur {
        display: none;
    }

    .nsofts-setting .nsofts-setting__sidebar {
        border: none;
    }
}

@media (max-width: 479.98px) {
    body {
        --player-control-width: 300px;
    }

    #header .navbar-brand-text {
        display: none;
    }

    .under-header {
        padding-top: 48px;
    }

    .cover .cover__head {
        padding: 16px;
    }

    #visualizer_wrap {
        top: 287px;
    }

    #player .mejs__button.mejs__playpause-button {
        margin-left: 4px;
        margin-right: 4px;
    }

    #player .mejs__controls {
        padding-left: 8px;
        padding-right: 8px;
    }

    #player .mejs__time {
        display: none;
    }

    #player_info {
        padding-left: 16px;
        padding-right: 16px;
    }

    .list-group.list-group--fav [data-radio-id] {
        margin: 0 8px;
    }

    .cookie {
        width: 350px !important;
        height: auto !important;
        left: 12px !important;
    }

    .cookie .txt {
        width: 60% !important;
    }

    .bg_blur {
        display: none;
    }

    .nsofts-setting .nsofts-setting__sidebar {
        border: none;
    }
}