/**
 * 全站内页 — 列表 / 详情 / 专辑 / 歌单 / 制作人 / 榜单 / 搜索 / 播放
 */
.dj-page,
#f2.dj-page,
#f2.genre-list-page {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 0.75rem 2rem;
    color: var(--dj-text);
}

.dj-page .page_body,
.dj-page .page_body > div {
    padding: 0 !important;
    max-width: 100% !important;
}

.dj-breadcrumb {
    font-size: 13px;
    color: var(--dj-text-muted);
    margin-bottom: 1rem;
    line-height: 1.65;
    white-space: normal;
}

.dj-breadcrumb a {
    color: var(--dj-primary);
    text-decoration: none;
    display: inline;
    white-space: nowrap;
}

.dj-breadcrumb a.dj-tip,
.dj-breadcrumb a.tooltip {
    display: inline !important;
}

.dj-breadcrumb a:hover {
    text-decoration: underline;
}

/* ---------- 页头 ---------- */
.dj-page-head {
    margin-bottom: 1rem;
}

.dj-page-head h1,
.dj-page-head .dj-page-title {
    margin: 0 0 0.2rem;
    font-size: 1.35rem;
    font-weight: 600;
    color: var(--dj-text);
}

.dj-page-head .dj-page-sub {
    margin: 0;
    font-size: 12px;
    color: var(--dj-text-muted);
}

/* ---------- 筛选标签 ---------- */
.dj-page-tabs,
#hothaomenu.dj-page-tabs,
.radio_list_left_title ul.dj-page-tabs,
.djshow_content_type ul.dj-page-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    margin: 0 0 1rem;
    padding: 0;
    list-style: none;
    background: transparent !important;
    overflow: visible !important;
    border-radius: 0 !important;
}

.dj-page-tabs a,
.radio_list_left_title .dj-page-tabs li a,
.djshow_content_type .dj-page-tabs li a,
#hothaomenu.dj-page-tabs a {
    display: inline-block;
    padding: 0.4rem 0.75rem;
    font-size: 12px;
    color: var(--dj-text-muted) !important;
    background: var(--dj-surface) !important;
    border: 1px solid var(--dj-border) !important;
    border-radius: 6px !important;
    text-decoration: none !important;
    width: auto !important;
    height: auto !important;
    line-height: 1.35 !important;
    float: none !important;
    opacity: 1 !important;
}

.dj-page-tabs a:hover,
#hothaomenu.dj-page-tabs a:hover {
    color: var(--dj-primary) !important;
    border-color: var(--dj-primary) !important;
}

.dj-page-tabs .flon a,
.dj-page-tabs a.is-active,
.dj-page-tabs a.pxon,
#hothaomenu .pxon {
    color: #fff !important;
    background: var(--dj-primary) !important;
    border-color: var(--dj-primary) !important;
}

.dj-page-tabs .wave {
    display: none !important;
}

.dj-page-tabs li {
    float: none !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none;
}

/* ---------- 卡片网格（专辑/歌单） ---------- */
.dj-card-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.85rem;
    list-style: none;
    margin: 0;
    padding: 0;
}

@media (min-width: 576px) {
    .dj-card-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (min-width: 768px) {
    .dj-card-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

.dj-card-grid > li {
    float: none !important;
    width: auto !important;
    padding: 0 !important;
    margin: 0 !important;
}

.dj-media-card {
    background: var(--dj-surface);
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius-lg);
    overflow: hidden;
    transition: border-color 0.15s, box-shadow 0.15s;
}

.dj-media-card:hover {
    border-color: var(--dj-primary-muted);
    box-shadow: var(--dj-shadow);
}

.dj-media-card a {
    display: block;
    color: var(--dj-text);
    text-decoration: none;
}

.dj-media-card img {
    width: 100%;
    aspect-ratio: 1;
    object-fit: cover;
    display: block;
}

.dj-media-card .dj-media-card__meta {
    display: flex;
    justify-content: space-between;
    padding: 0.35rem 0.5rem;
    font-size: 11px;
    color: var(--dj-text-muted);
    background: var(--dj-surface-2);
}

.dj-media-card .dj-media-card__title {
    padding: 0.5rem 0.6rem;
    font-size: 13px;
    font-weight: 500;
    line-height: 1.35;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.radio_list_left_c_img,
.radio_list_left_content ul {
    all: unset;
    display: contents;
}

.radio_list_left_content .radio_list_left_c_img {
    display: block;
}

.radio_list_left_content ul.clearfix {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.85rem;
    list-style: none;
    padding: 0;
    margin: 0;
    width: 100% !important;
}

@media (min-width: 576px) {
    .radio_list_left_content ul.clearfix {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (min-width: 768px) {
    .radio_list_left_content ul.clearfix {
        grid-template-columns: repeat(4, 1fr);
    }
}

.radio_list_left_content ul.clearfix > li {
    float: none !important;
    width: auto !important;
    padding: 0 !important;
}

.radio_list_left_content .radio_list_left_c_img {
    background: var(--dj-surface);
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius-lg);
    overflow: hidden;
}

.radio_list_left_content .radio_list_left_c_img img {
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 1;
    object-fit: cover;
}

.radio_list_left_content .bg-title {
    display: flex;
    justify-content: space-between;
    padding: 0.35rem 0.5rem;
    font-size: 11px;
    color: var(--dj-text-muted);
    background: var(--dj-surface-2);
    position: static !important;
}

.radio_list_left_c_playicon {
    display: none;
}

.radio_list_left_c_title {
    padding: 0.5rem 0.6rem !important;
    font-size: 13px !important;
    color: var(--dj-text) !important;
    background: transparent !important;
    position: static !important;
    height: auto !important;
}

/* ---------- 制作人列表 ---------- */
.dj-artist-cards {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
}

.dj-artist-card {
    display: flex;
    gap: 1rem;
    padding: 1rem;
    background: var(--dj-surface);
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius-lg);
}

.dj-artist-card__avatar img {
    width: 96px;
    height: 96px;
    border-radius: var(--dj-radius);
    object-fit: cover;
    border: 1px solid var(--dj-border);
}

.dj-artist-card__body {
    flex: 1;
    min-width: 0;
}

.dj-artist-card__head {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 0.5rem 1rem;
    margin-bottom: 0.5rem;
}

.dj-artist-card__name {
    font-size: 15px;
    font-weight: 600;
    color: var(--dj-text);
    text-decoration: none;
}

.dj-artist-card__name:hover {
    color: var(--dj-primary);
}

.dj-artist-card__meta {
    font-size: 12px;
    color: var(--dj-text-muted);
}

.dj-artist-card__songs {
    list-style: none;
    margin: 0;
    padding: 0;
}

.dj-artist-card__songs > li {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    padding: 0.35rem 0;
    border-top: 1px solid var(--dj-border);
    font-size: 13px;
}

.dj-artist-card__song {
    flex: 1;
    min-width: 0;
    color: var(--dj-text);
    text-decoration: none;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.dj-artist-card__song:hover {
    color: var(--dj-primary);
}

.dj-artist-card__acts {
    display: flex;
    gap: 0.35rem;
    flex-shrink: 0;
}

.dj-artist-card__acts a {
    color: var(--dj-text-muted);
    font-size: 14px;
}

.dj-artist-card__acts a:hover {
    color: var(--dj-primary);
}

.dj-sidebar-songs {
    list-style: none;
    margin: 0;
    padding: 0;
}

.dj-sidebar-songs li {
    border-bottom: 1px solid var(--dj-border);
}

.dj-sidebar-songs a {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.45rem 0;
    color: var(--dj-text);
    font-size: 12px;
    text-decoration: none;
}

.dj-sidebar-songs a:hover {
    color: var(--dj-primary);
}

.dj-sidebar-songs img {
    border-radius: 4px;
    flex-shrink: 0;
}

.dj-sidebar-songs span {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.dj-artist-list .djshow_contentlist > table {
    width: 100% !important;
    display: block;
    margin-bottom: 1rem;
    background: var(--dj-surface);
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius-lg);
    padding: 0.85rem;
}

.dj-artist-list .djshow_contentlist_name {
    font-size: 15px;
    font-weight: 600;
    color: var(--dj-text) !important;
}

.dj-artist-list .djshow_contentlist_msg {
    color: var(--dj-text-muted) !important;
    font-size: 12px;
}

.dj-search-inline {
    max-width: 280px;
}

.dj-search-inline .form-control,
.dj-search-inline .inputx_dj {
    border-radius: 8px;
    border: 1px solid var(--dj-border);
    background: var(--dj-surface-2);
    font-size: 13px;
}

.dj-search-inline .bt_dj,
.dj-search-inline .btn-dj {
    background: var(--dj-primary) !important;
    border-color: var(--dj-primary) !important;
    color: #fff !important;
    border-radius: 8px;
}

/* ---------- 实体详情头（专辑/制作人） ---------- */
.dj-entity-hero {
    position: relative;
    border-radius: var(--dj-radius-lg);
    overflow: hidden;
    margin-bottom: 1rem;
    border: 1px solid var(--dj-border);
    background: var(--dj-surface-2);
}

.dj-entity-hero .dishow_djmsg_bg,
.dj-entity-hero .djshow_djmsg_content .blur {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.2;
    filter: blur(16px);
}

.dj-entity-hero .djshow_djmsg_box {
    position: relative;
    display: flex;
    gap: 1rem;
    padding: 1.25rem;
    z-index: 1;
}

.dj-entity-hero .djshow_djmsg_icon img {
    width: 120px;
    height: 120px;
    border-radius: var(--dj-radius);
    object-fit: cover;
    border: 2px solid var(--dj-border);
}

.dj-entity-hero h1 {
    margin: 0 0 0.5rem;
    font-size: 1.35rem;
    color: var(--dj-text);
}

.dj-entity-hero p {
    margin: 0 0 0.35rem;
    font-size: 13px;
    color: var(--dj-text-muted);
}

.dj-entity-intro {
    max-height: 4.5em;
    overflow: hidden;
    line-height: 1.5;
}

.dj-sidebar-albums {
    list-style: none;
    margin: 0;
    padding: 0;
}

.dj-sidebar-albums li {
    border-bottom: 1px solid var(--dj-border);
}

.dj-sidebar-albums a {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0;
    color: var(--dj-text);
    text-decoration: none;
    font-size: 12px;
}

.dj-sidebar-albums a:hover {
    color: var(--dj-primary);
}

.dj-sidebar-albums img {
    border-radius: 4px;
    flex-shrink: 0;
}

.dj-sidebar-albums strong {
    display: block;
    font-weight: 500;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.dj-sidebar-albums small {
    color: var(--dj-text-muted);
}

/* 作者页侧栏 — 热门制作人卡片网格 */
.dj-sidebar-producer-card {
    overflow: hidden;
}

.dj-sidebar-producer-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem 0.55rem;
    padding: 0.85rem 0.75rem 1rem;
}

.dj-sidebar-producer-cell {
    display: block;
    min-width: 0;
    text-decoration: none;
    color: var(--dj-text);
    transition: transform 0.18s ease, color 0.18s ease;
}

.dj-sidebar-producer-cell:hover {
    color: var(--dj-primary);
    transform: translateY(-2px);
    text-decoration: none;
}

.dj-sidebar-producer-cell__cover {
    position: relative;
    aspect-ratio: 1;
    overflow: hidden;
    border-radius: var(--dj-radius-lg);
    border: 1px dashed var(--dj-border);
    background: var(--dj-surface-2);
    transition: border-color 0.18s ease, box-shadow 0.18s ease;
}

.dj-sidebar-producer-cell:hover .dj-sidebar-producer-cell__cover {
    border-color: var(--dj-primary-muted);
    box-shadow: 0 6px 16px rgba(124, 58, 237, 0.12);
}

.dj-sidebar-producer-cell__cover img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.22s ease;
}

.dj-sidebar-producer-cell:hover .dj-sidebar-producer-cell__cover img {
    transform: scale(1.04);
}

.dj-sidebar-producer-hot {
    position: absolute;
    left: 6px;
    bottom: 6px;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    gap: 2px;
    max-width: calc(100% - 12px);
    padding: 2px 7px;
    border-radius: 999px;
    background: rgba(0, 0, 0, 0.58);
    color: #fff;
    font-size: 10px;
    line-height: 1.3;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.dj-sidebar-producer-hot .bi-fire {
    color: #ff5a5f;
    flex-shrink: 0;
    font-size: 10px;
}

.dj-sidebar-producer-cell__name {
    margin-top: 0.4rem;
    font-size: 12px;
    font-weight: 600;
    line-height: 1.35;
    text-align: center;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

@media (max-width: 991.98px) {
    .dj-sidebar-producer-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 0.85rem 0.65rem;
        padding: 0.85rem 1rem 1rem;
    }
}

@media (max-width: 575.98px) {
    .dj-sidebar-producer-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* 侧栏 — 嗨友歌单 */
.dj-sidebar-radio-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.65rem;
    padding: 0 0.15rem;
}

.dj-sidebar-radio-head .index-rank-title {
    flex: 1;
    min-width: 0;
    margin: 0;
    border-bottom: 0;
    padding: 0.85rem 0 0.85rem 0.75rem;
}

.dj-sidebar-radio-refresh {
    flex-shrink: 0;
    align-self: center;
    margin-right: 0.65rem;
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.28rem 0.55rem;
    border: 1px dashed var(--dj-border);
    border-radius: 999px;
    background: var(--dj-surface);
    color: var(--dj-text-muted);
    font-size: 11px;
    line-height: 1.2;
    cursor: pointer;
    transition: border-color 0.15s, color 0.15s, background 0.15s;
}

.dj-sidebar-radio-refresh:hover {
    border-color: var(--dj-primary-muted);
    color: var(--dj-primary);
    background: var(--dj-primary-soft);
}

.dj-sidebar-radio-count .bi-music-note-list {
    color: #a78bfa;
    flex-shrink: 0;
    font-size: 10px;
}

.dj-page--ranks .dj-ranks-layout {
    align-items: start;
}

.dj-ranks-time .dropdown-menu {
    max-height: 280px;
    overflow-y: auto;
}

.dj-tag-cloud {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    padding: 1rem;
    background: var(--dj-surface);
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius-lg);
}

.dj-tag-chip {
    display: inline-block;
    padding: 0.4rem 0.85rem;
    font-size: 13px;
    color: var(--dj-text);
    background: var(--dj-surface-2);
    border: 1px solid var(--dj-border);
    border-radius: 999px;
    text-decoration: none;
}

.dj-tag-chip:hover {
    color: var(--dj-primary);
    border-color: var(--dj-primary);
    background: var(--dj-primary-soft);
}

.dj-page--ranks-chart.rank-chart-page {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 0.75rem 2rem;
}

/* ---------- 榜单页左侧导航 ---------- */
.dj-ranks-nav {
    background: var(--dj-surface);
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius-lg);
    padding: 0.75rem;
    margin-bottom: 1rem;
}

.dj-ranks-nav #top_fl_list,
.dj-ranks-nav ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.dj-ranks-nav #top_fl_list li,
.dj-ranks-nav li {
    margin: 0;
    padding: 0;
    float: none !important;
    width: 100% !important;
}

.dj-ranks-nav a {
    display: block;
    padding: 0.45rem 0.65rem;
    border-radius: 6px;
    color: var(--dj-text);
    font-size: 13px;
    text-decoration: none;
}

.dj-ranks-nav .top_flon a,
.dj-ranks-nav a:hover {
    background: var(--dj-primary-soft);
    color: var(--dj-primary);
}

.dj-ranks-nav .top_floff a {
    color: var(--dj-text-muted);
}

.dj-ranks-mobile-filters {
    display: none;
}

.dj-ranks-mobile-filter {
    min-width: 0;
}

.dj-ranks-mobile-label {
    display: block;
    margin-bottom: 0.35rem;
    font-size: 12px;
    font-weight: 600;
    color: var(--dj-text-muted);
}

.dj-ranks-select {
    width: 100%;
    font-size: 14px;
    border-color: var(--dj-border);
    background-color: var(--dj-surface);
    color: var(--dj-text);
}

.dj-ranks-select:focus {
    border-color: var(--dj-primary);
    box-shadow: 0 0 0 0.15rem var(--dj-primary-soft);
}

@media (max-width: 991.98px) {
    .dj-ranks-mobile-filters {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 0.65rem;
        padding: 0.75rem;
        margin-bottom: 0.75rem;
        background: var(--dj-surface);
        border: 1px solid var(--dj-border);
        border-radius: var(--dj-radius-lg);
    }

    .dj-ranks-nav .dj-page-head,
    .dj-ranks-nav #top_fl_list {
        display: none;
    }

    .dj-ranks-nav {
        padding: 0;
        border: none;
        background: transparent;
    }

    .dj-page--ranks .dj-ranks-time.dropdown {
        display: none !important;
    }
}

@media (max-width: 575.98px) {
    .dj-ranks-mobile-filters {
        grid-template-columns: 1fr;
    }
}

/* ---------- 布局：左右栏统一 ---------- */
.dj-page .row.g-3,
.dj-page-layout.row {
    --bs-gutter-x: 1rem;
}

.dj-page-main {
    min-width: 0;
}

.dj-page-sidebar .dj-card-side,
.dj-genre-sidebar .dj-card-side {
    background: var(--dj-surface);
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius-lg);
    padding: 0.85rem;
    margin-bottom: 1rem;
}

.dj-page-sidebar .dj-sidebar-slider-slot:not(:has(.dj-mix-slider)),
.dj-page-sidebar .dj-sidebar-slider-slot.is-empty {
    display: none !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    min-height: 0 !important;
}

.dj-page-sidebar .dj-sidebar-slider-slot {
    padding: 0;
    overflow: hidden;
}

.dj-page-sidebar .dj-sidebar-slider-slot .dj-mix-slider,
.dj-page-sidebar .dj-sidebar-slider-slot img,
.dj-page-sidebar .dj-sidebar-slider img,
#playBox img {
    display: block;
    width: 100%;
    max-width: 100%;
    height: auto;
    border-radius: var(--dj-radius-lg);
}

.dj-page-sidebar .index-rank-title,
.dj-genre-sidebar .index-rank-title {
    font-weight: 600;
    border-bottom: 1px solid var(--dj-border);
    padding-bottom: 0.5rem;
    margin-bottom: 0.5rem;
}

.dj-page-sidebar .list_hot_down dl,
.dj-genre-sidebar .list_hot_down dl {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin: 0;
    padding: 0.4rem 0;
    border-bottom: 1px solid var(--dj-border);
}

.dj-page-sidebar .list_hot_down dt.num1,
.dj-page-sidebar .list_hot_down dt.num2,
.dj-page-sidebar .list_hot_down dt.num3 {
    background: var(--dj-primary);
    color: #fff;
    border-radius: 4px;
    padding: 2px 5px;
    font-size: 11px;
}

/* ---------- 歌曲表格（全站） ---------- */
.dj-page .dj-genre-table-wrap,
.dj-page .list_musiclist {
    width: 100% !important;
}

.dj-page table.list_musiclist {
    width: 100% !important;
    max-width: 100% !important;
}

.dj-page .list_musiclist th {
    background: var(--dj-surface-2) !important;
    color: var(--dj-text-muted) !important;
    font-weight: 600;
    font-size: 12px;
    border-bottom: 1px solid var(--dj-border) !important;
    background-image: none !important;
}

.dj-page .list_musiclist td {
    border-bottom: 1px solid var(--dj-border) !important;
    background-image: none !important;
    vertical-align: middle;
}

.dj-page .list_musiclist tr:hover td {
    background: var(--dj-primary-soft) !important;
}

.dj-page .list_controllbox,
.dj-page .dj-genre-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem 1rem;
    margin: 1rem 0;
    background: var(--dj-surface-2);
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius);
}

.dj-page .list_controllbox .index-typeicon {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.dj-page .playall,
.dj-page .addall {
    display: inline-block;
    padding: 0.35rem 0.85rem;
    font-size: 13px;
    color: #fff;
    background: var(--dj-primary);
    border-radius: 6px;
    cursor: pointer;
}

.dj-page .addall {
    background: var(--dj-surface);
    color: var(--dj-primary);
    border: 1px solid var(--dj-primary);
}

/* ---------- 搜索页 ---------- */
.dj-page--search .search_list_left,
.dj-page--search .search_list_right {
    float: none !important;
    width: 100% !important;
}

.dj-page--search .list_fenlei {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 0.5rem;
    margin-bottom: 1rem;
}

.dj-page--search .list_fenlei .list_tl {
    flex: 0 0 52px;
    float: none !important;
    width: auto !important;
    text-indent: 0 !important;
    background: none !important;
    font-weight: 600;
    color: var(--dj-text-muted);
}

.dj-page--search .list_fenlei .list_tr {
    flex: 1;
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    float: none !important;
    width: auto !important;
}

.dj-page--search .list_fenlei .list_tr li {
    float: none !important;
}

.dj-page--search .list_fenlei .flon a,
.dj-page--search .list_fenlei .flof a {
    display: inline-block;
    padding: 0.3rem 0.65rem;
    border-radius: 6px;
    font-size: 12px;
    border: 1px solid var(--dj-border);
    background: var(--dj-surface);
    color: var(--dj-text-muted);
    text-decoration: none;
}

.dj-page--search .list_fenlei .flon a {
    background: var(--dj-primary);
    color: #fff;
    border-color: var(--dj-primary);
}

.dj-search-summary {
    font-size: 14px;
    color: var(--dj-text-muted);
    margin-bottom: 0.75rem;
}

.dj-search-summary .fbold {
    color: var(--dj-primary) !important;
    font-weight: 600;
}

.dj-search-log {
    font-size: 13px;
}

.dj-search-log-row {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.35rem 0;
    border-bottom: 1px dashed var(--dj-border);
}

.dj-search-log-row:last-child {
    border-bottom: none;
}

.dj-search-log-item {
    flex: 1 1 auto;
    min-width: 0;
    color: var(--dj-text);
    text-decoration: none;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.dj-search-log-item:hover {
    color: var(--dj-primary);
}

.dj-search-log-del {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    color: var(--dj-text-muted);
    text-decoration: none;
    border-radius: 4px;
    transition: color 0.15s, background 0.15s;
}

.dj-search-log-del:hover {
    color: var(--dj-primary);
    background: var(--dj-primary-soft);
}

.dj-page--search .search_list_ct {
    padding: 0 !important;
    min-width: 0;
}

.dj-page--search .search_list_ct .dj-search-summary {
    margin-bottom: 0.75rem;
}

.dj-page--search .search_list_ct .list_fenlei {
    margin-bottom: 0.75rem;
    padding: 0;
    background: transparent;
    border: none;
}

.dj-page--search .search_list_ct .dj-page-tabs {
    margin-bottom: 0.75rem !important;
}

.dj-page--search .search_list_ct .h10,
.dj-page--search .search_list_ct .lines {
    display: none !important;
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
}

.dj-page--search .list_musiclist .isgood_list.dj-genre-song-cell {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    min-width: 0;
}

.dj-page--search .list_musiclist .isgood_list.dj-genre-song-cell > li {
    display: block;
    padding: 0;
    border: none;
    background: transparent;
}

.dj-page--search .list_musiclist .isgood_list.dj-genre-song-cell > li.list_play_img_title {
    flex: 1 1 auto;
    min-width: 0;
}

.dj-page--search .list_controllbox.dj-genre-toolbar {
    margin-top: 0.75rem;
}

.dj-page--search .list_split_page {
    margin-top: 1rem;
}

.dj-search-log a {
    display: block;
    padding: 0.35rem 0;
    color: var(--dj-text);
}

/* ---------- 播放页 ---------- */
.dj-play-page .page_body,
.dj-play-page .page_body.dj-play-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.25rem;
}

@media (min-width: 992px) {
    .dj-play-page .page_body,
    .dj-play-page .page_body.dj-play-grid {
        grid-template-columns: 260px minmax(0, 1fr) 280px;
        align-items: start;
    }
}

.dj-play-page .play_p1_left,
.dj-play-page .dj-play-col-main,
.dj-play-page .play_p1_right,
.dj-play-page .play_p1_center {
    float: none !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0;
}

@media (min-width: 992px) {
    .dj-play-page .play_p1_left {
        grid-column: 1;
        grid-row: 1;
    }

    .dj-play-page .dj-play-col-main {
        grid-column: 2;
        grid-row: 1;
    }

    .dj-play-page .play_p1_right {
        grid-column: 3;
        grid-row: 1;
    }
}

.dj-play-page .dj-play-col-main {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.dj-play-page .play_p2 {
    grid-column: auto;
    width: 100%;
}

.dj-play-page .play_ct h1 {
    color: var(--dj-text);
}

.dj-play-page .play_ct > div[style*="rgba"] {
    background: var(--dj-surface-2) !important;
    border-radius: var(--dj-radius);
    padding: 1rem !important;
}

.dj-play-page .borp1 {
    color: var(--dj-text-muted);
    font-size: 13px;
}

.dj-play-page .play_p2 {
    background: transparent;
    border: none;
    border-radius: 0;
    overflow: visible;
}

.dj-play-page .play_background {
    display: none;
}

.dj-play-page .play_ct {
    position: relative;
    z-index: 1;
    padding: 0;
}

.dj-play-page .playcz {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.dj-play-page .playcz > a {
    flex: 0 1 auto;
    min-width: 96px;
    text-align: center;
}

.dj-play-page .playcz .wave { display: none !important; }

.dj-play-page .dj-play-hero-panel {
    background: transparent;
    padding: 0 0 1rem;
    border-bottom: 2px solid var(--dj-border);
    border-radius: 0;
    color: var(--dj-text);
}

.dj-play-page .dj-play-hero-panel h1 {
    color: var(--dj-text);
}

.dj-play-page .play_ct_bg {
    background: transparent;
    padding-top: 0.5rem;
}

.dj-play-page .dj-play-meta {
    color: var(--dj-text);
}

.dj-play-page .playcz .btn-outline-light,
.dj-play-page .playcz .btn-outline-secondary {
    border-color: var(--dj-border);
    color: var(--dj-text);
}

.dj-play-page .playcz .btn-outline-light:hover,
.dj-play-page .playcz .btn-outline-secondary:hover {
    border-color: var(--dj-primary);
    color: var(--dj-primary);
    background: var(--dj-primary-soft);
}

.dj-play-page .dj-play-playlist-panel {
    background: transparent;
    border: none;
    border-top: 2px solid var(--dj-border);
    border-radius: 0;
    margin-top: 0.75rem;
    overflow: visible;
}

.dj-play-page .playlist_title {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    padding: 0.65rem 0;
    background: transparent;
}

.dj-play-page .dj-playlist-toolbar {
    background: transparent;
    border-bottom: 1px solid var(--dj-border);
    padding-left: 0;
    padding-right: 0;
}

.dj-play-page .dj-playlist-toolbar .t3 a:hover {
    color: #adf722 !important;
}

.dj-play-page .playlist_title ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.dj-play-page .playlist_menu ul {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem 0.75rem;
    padding: 0.5rem 0;
    margin: 0;
    list-style: none;
    background: transparent;
    border-bottom: 1px solid var(--dj-border);
}

.dj-play-page .playlist_menu ul li {
    padding: 0.25rem 0.35rem;
    border-radius: 0;
    font-size: 12px;
    cursor: pointer;
    color: var(--dj-text-muted);
    background: transparent;
    border-bottom: 2px solid transparent;
}

.dj-play-page .playlist_menu ul li.pton {
    background: transparent;
    color: var(--dj-primary);
    border-bottom-color: var(--dj-primary);
    font-weight: 600;
}

.dj-play-page .playlist_menu ul li.ptoff:hover {
    color: var(--dj-primary);
    background: transparent;
}

.dj-play-page #playlist_ct {
    max-height: 360px;
    overflow: auto;
}

.dj-play-page .dj-play-section-head .play-typeicon {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    list-style: none;
    margin: 0;
    padding: 0;
}

.dj-play-page .play-typeicon li,
.dj-play-page .play-typeicon button,
.dj-play-page .play-typeicon .playall,
.dj-play-page .play-typeicon .addall,
.dj-play-page .play-typeicon .changeall {
    display: inline-flex;
    align-items: center;
    padding: 0.35rem 0.75rem;
    border-radius: var(--dj-radius);
    font-size: 12px;
    cursor: pointer;
    border: 1px solid var(--dj-border);
    background: var(--dj-surface-2);
    color: var(--dj-text);
}

.dj-play-page .play-typeicon button {
    line-height: 1.4;
}

.dj-play-page .play-typeicon li:hover,
.dj-play-page .play-typeicon button:hover,
.dj-play-page .play-typeicon .playall:hover,
.dj-play-page .play-typeicon .addall:hover,
.dj-play-page .play-typeicon .changeall:hover {
    border-color: var(--dj-primary);
    color: var(--dj-primary);
}

.dj-play-page .dj-play-promo-card {
    background: var(--dj-surface);
    border: 1px solid var(--dj-border) !important;
}

.dj-play-page .dj-play-love-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

@media (max-width: 767.98px) {
    .dj-play-page .dj-play-love-grid {
        grid-template-columns: 1fr;
    }
}

.dj-play-page .play_recommended-list ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.dj-play-page .play_recommended-list ul li {
    margin-bottom: 0;
    border-bottom: 1px solid var(--dj-border);
}

.dj-play-page .play_recommended-list ul li:last-child {
    border-bottom: none;
}

.dj-play-page .play-music-bg {
    display: flex;
    gap: 0.75rem;
    align-items: flex-start;
    padding: 0.65rem 0;
    border-radius: 0;
    border: none;
    background: transparent;
}

.dj-play-page .play-music-sm {
    padding: 0.5rem 0;
    border-radius: 0;
    background: transparent;
    border: none;
    border-bottom: 1px solid var(--dj-border);
    font-size: 13px;
    cursor: pointer;
    color: var(--dj-text);
}

.dj-play-page .play-music-img img {
    width: 56px;
    height: 56px;
    object-fit: cover;
    border-radius: var(--dj-radius);
}

.dj-play-page .play-music-title {
    font-size: 14px;
    margin: 0 0 0.25rem;
    overflow: hidden;
    min-width: 0;
}

.dj-play-page .play-music-title a {
    color: var(--dj-text);
    text-decoration: none;
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 100%;
}

.dj-play-page .play-music-title a:hover {
    color: var(--dj-primary);
}

.dj-play-page .play-music-hit {
    font-size: 12px;
    color: var(--dj-text-muted);
}

.dj-play-page .dj-play-artist-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.75rem;
    list-style: none;
    margin: 0;
    padding: 0;
}

.dj-play-page .dj-play-artist-grid li {
    text-align: center;
}

.dj-play-page .dj-play-artist-grid li.is-featured {
    grid-row: span 2;
    grid-column: span 1;
}

.dj-play-page .dj-play-artist-grid .ra-img img {
    width: 100%;
    aspect-ratio: 1;
    object-fit: cover;
    border-radius: var(--dj-radius-lg);
    border: 1px solid var(--dj-border);
}

.dj-play-page .dj-play-artist-grid li.is-featured .ra-img img {
    aspect-ratio: auto;
    min-height: 196px;
}

.dj-play-page .dj-play-artist-grid p {
    margin: 0.35rem 0 0;
    font-size: 13px;
    color: var(--dj-text);
}

.dj-play-page .play_love span,
.dj-play-page .index-producer-title span {
    font-weight: 600;
    color: var(--dj-text);
    font-size: 1rem;
}

.dj-play-page .play_love p,
.dj-play-page .index-producer-title p {
    font-size: 12px;
    color: var(--dj-text-muted);
    margin: 0;
}

.dj-play-page .dj-play-love-panel,
.dj-play-page .dj-play-producer-panel {
    background: transparent;
    border: none;
    border-top: 2px solid var(--dj-border);
    border-radius: 0;
    padding: 1.25rem 0 0;
    margin-top: 0;
}

.dj-play-page .dj-play-info-panel {
    background: transparent;
    border: none;
    border-top: 2px solid var(--dj-border);
    border-radius: 0;
    padding: 1.25rem 0 0;
    margin-top: 0;
    box-shadow: none !important;
}

.dj-play-page .dj-play-info-panel .card-header,
.dj-play-page .dj-play-info-panel .card-body {
    padding-left: 0;
    padding-right: 0;
}

.dj-play-page .dj-play-info-panel .txtblack {
    color: var(--dj-text-muted);
    font-size: 13px;
    line-height: 1.65;
}

.dj-page--bounty .dj-breadcrumb {
    margin-bottom: 0.75rem;
}

.dj-page--bounty .dj-breadcrumb a {
    color: #ccc;
}

.dj-page--bounty .dj-breadcrumb a:hover {
    color: var(--dj-primary-muted);
}

.dj-page--bounty .dj-breadcrumb span {
    color: var(--dj-primary-muted);
}

.dj-page--car .page_bai_ct .card,
.dj-page--car .page_bai .card {
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius-lg);
    overflow: hidden;
    background: var(--dj-surface);
}

.dj-page--car .page_bai_ct .card-header {
    background: var(--dj-surface-2);
}

.dj-play-page .dj-play-sidebar-card {
    background: transparent;
    border: none !important;
    border-radius: 0;
    box-shadow: none !important;
    margin-bottom: 1.25rem;
}

.dj-play-page .dj-play-sidebar-card .index-radio-title span {
    font-weight: 600;
    color: var(--dj-text);
}

.dj-play-page .dj-play-sidebar-card .changeall {
    font-size: 12px;
    padding: 0.25rem 0.65rem;
    border-radius: var(--dj-radius);
    border: 1px solid var(--dj-border);
    cursor: pointer;
    color: var(--dj-text-muted);
}

.dj-play-page .dj-play-sidebar-card .changeall:hover {
    border-color: var(--dj-primary);
    color: var(--dj-primary);
    background: rgba(124, 58, 237, 0.08);
}

.dj-play-page .dj-play-sidebar-card .play_p4 ul {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.5rem;
    list-style: none;
    margin: 0;
    padding: 0;
}

.dj-play-page .dj-play-sidebar-card .play_p4 li {
    margin: 0 !important;
    float: none !important;
}

.dj-play-page .dj-play-sidebar-card .play_p4 .ra-img {
    border-radius: var(--dj-radius);
    overflow: hidden;
    aspect-ratio: 1;
    background: var(--dj-surface-2);
}

.dj-play-page .dj-play-sidebar-card .play_p4 .ra-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.2s ease;
}

.dj-play-page .dj-play-sidebar-card .play_p4 .ra-img:hover img {
    transform: scale(1.04);
}

.dj-play-page .dj-play-sidebar-card .play_p4 li p {
    font-size: 12px;
    margin-top: 0.35rem;
    color: var(--dj-text-muted);
}

.dj-page-tabs .badge {
    font-size: 10px;
    vertical-align: middle;
}

.dj-member-form-page .regdiv {
    margin-bottom: 1rem;
}

.dj-member-form-page .regdiv ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.dj-member-form-page .regdiv .u1 {
    width: auto;
    min-width: 6rem;
    font-size: 13px;
    color: var(--dj-text-muted);
}

.dj-member-form-page .regdiv .u2 {
    width: auto;
    flex: 1;
}

.dj-member-form-page .regdiv .u3 {
    width: 100%;
    margin-top: 0.25rem;
}

.dj-member-form-page .inputs {
    border-radius: var(--dj-radius);
    width: 100%;
    max-width: 320px;
    height: 38px;
    background: var(--dj-surface);
    border: 1px solid var(--dj-border);
    padding: 0 0.75rem;
}

.dj-member-detail-page dl dt {
    font-weight: 500;
}

.dj-member-form-page .card {
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius-lg);
    overflow: hidden;
}

.dj-member-form-page .card-header {
    background: var(--dj-surface-2);
    font-size: 14px;
}

.dj-member-form-page .form-text.regsuccess,
.dj-member-form-page #usernameinfo.regsuccess,
.dj-member-form-page #codeinfo.regsuccess,
.dj-member-form-page #passwordinfo.regsuccess,
.dj-member-form-page #repasswordinfo.regsuccess {
    color: #16a34a;
}

.dj-member-form-page .form-text.regerr,
.dj-member-form-page #usernameinfo.regerr,
.dj-member-form-page #codeinfo.regerr,
.dj-member-form-page #passwordinfo.regerr,
.dj-member-form-page #repasswordinfo.regerr {
    color: #dc2626;
}

.dj-page--mall .mall-top > table > tbody > tr {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
}

.dj-page--mall .mall-top > table > tbody > tr > td {
    display: block;
    width: 100%;
}

@media (min-width: 768px) {
    .dj-page--mall .mall-top > table > tbody > tr > td:first-child {
        flex: 0 0 320px;
        max-width: 320px;
    }

    .dj-page--mall .mall-top > table > tbody > tr > td:last-child {
        flex: 1;
        min-width: 0;
    }
}

.dj-page--article .dj-article-table a {
    color: var(--dj-text);
    text-decoration: none;
}

.dj-page--article .dj-article-table a:hover {
    color: var(--dj-primary);
}

.dj-page--radio-detail .radio_box {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 0.75rem 2rem;
}

.dj-page--radio-detail body > div[style*="height:800px"] {
    display: none !important;
}

/* ---------- 歌单详情 /radio/{id} ---------- */
.dj-radio-hero {
    position: relative;
    overflow: hidden;
    background: var(--dj-surface);
    border: 1px solid var(--dj-border) !important;
}

.dj-radio-hero__bg {
    position: absolute;
    inset: 0;
    pointer-events: none;
    overflow: hidden;
}

.dj-radio-hero__bg .blur {
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.18;
    filter: blur(18px);
    transform: scale(1.08);
}

.dj-radio-hero__body {
    position: relative;
    z-index: 1;
}

.dj-radio-hero__cover {
    width: 160px;
    height: 160px;
    object-fit: cover;
    border: 2px solid var(--dj-border);
    box-shadow: var(--dj-shadow);
}

.dj-radio-hero__title a {
    color: var(--dj-text);
    text-decoration: none;
}

.dj-radio-hero__title a:hover {
    color: var(--dj-primary);
}

.dj-radio-hero__now a {
    color: var(--dj-primary);
    font-size: 14px;
    font-weight: 500;
    text-decoration: none;
}

.dj-radio-hero__now a:hover {
    color: var(--dj-primary-hover);
}

.dj-radio-player {
    min-height: 70px;
    position: relative;
}

.dj-radio-controls #ico-radio_gz.is-followed a {
    background: var(--dj-primary);
    border-color: var(--dj-primary);
    color: #fff;
}

.dj-radio-side-card,
.dj-radio-playlist-card {
    background: var(--dj-surface);
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius-lg);
}

.dj-radio-side-card .card-header,
.dj-radio-playlist-card .card-header {
    background: var(--dj-surface-2);
    border-bottom: 1px solid var(--dj-border);
    font-size: 13px;
}

.dj-radio-ref {
    font-size: 12px;
    text-decoration: none;
}

.dj-radio-mini-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.65rem;
}

.dj-radio-mini {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    color: var(--dj-text);
    text-decoration: none;
    font-size: 11px;
    line-height: 1.3;
}

.dj-radio-mini img {
    width: 100%;
    aspect-ratio: 1;
    object-fit: cover;
    border-radius: 6px;
    border: 1px solid var(--dj-border);
}

.dj-radio-mini span {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.dj-radio-mini:hover {
    color: var(--dj-primary);
}

.dj-radio-playlist {
    max-height: 520px;
    overflow-y: auto;
}

.dj-radio-playlist .nonere {
    padding: 2rem 1rem;
    text-align: center;
    color: var(--dj-text-muted);
    font-size: 13px;
}

.dj-radio-playlist ul {
    list-style: none;
    margin: 0;
    padding: 0;
    border-bottom: 1px solid var(--dj-border);
}

.dj-radio-playlist ul:last-child {
    border-bottom: none;
}

.dj-radio-playlist .bt a {
    display: block;
    padding: 0.55rem 0.85rem;
    color: var(--dj-text);
    text-decoration: none;
    font-size: 13px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.dj-radio-playlist .td1 .bt a {
    background: var(--dj-surface);
}

.dj-radio-playlist .td2 .bt a {
    background: var(--dj-surface-2);
}

.dj-radio-playlist .td3 .bt a {
    background: var(--dj-primary-soft);
    color: var(--dj-primary);
    font-weight: 600;
}

.dj-radio-playlist .bt a:hover {
    background: var(--dj-primary-soft);
    color: var(--dj-primary);
}

.dj-page--radio-detail .index-radio-title {
    background: none;
    padding: 0;
    min-height: 0;
}

.dj-page--radio-detail .index-radio-title span {
    display: block;
    font-size: 15px;
    font-weight: 600;
    color: var(--dj-text);
}

.dj-page--radio-detail .index-radio-title p {
    font-size: 11px;
    color: var(--dj-text-muted);
    margin: 0;
}

/* 嗨友歌单（歌单播放页侧栏） */
.dj-page--radio-detail .dj-mix-panel__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    margin-bottom: 0.75rem;
    padding-bottom: 0.55rem;
    border-bottom: 2px solid var(--dj-primary);
}

.dj-page--radio-detail .dj-mix-panel__title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--dj-text);
    margin: 0;
    line-height: 1.3;
}

.dj-page--radio-detail .dj-mix-panel__action {
    flex-shrink: 0;
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius);
    background: var(--dj-surface-2);
    color: var(--dj-text-muted);
    font-size: 12px;
    line-height: 1.3;
    padding: 0.2rem 0.55rem;
    cursor: pointer;
}

.dj-page--radio-detail .dj-mix-panel__action:hover {
    border-color: var(--dj-primary);
    color: var(--dj-primary);
}

.dj-page--radio-detail .dj-mix-radio-body {
    background: transparent;
    border-radius: 0;
    padding: 0;
    min-height: 0;
}

.dj-page--radio-detail .dj-sidebar-producer-card .index-rank-title {
    border-bottom: 1px solid var(--dj-border);
}

.dj-page--radio-detail .dj-sidebar-radio-head {
    border-bottom: 1px dashed var(--dj-border);
}

.dj-page--radio-detail .dj-sidebar-radio-head .index-rank-title {
    border-bottom: 0;
}

.dj-page--radio-detail .dj-mix-radio-panel.is-empty {
    display: none !important;
    margin: 0 !important;
    padding: 0 !important;
    min-height: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}

.dj-card-grid--radio {
    grid-template-columns: repeat(2, 1fr);
    gap: 0.65rem;
}

@media (min-width: 1200px) {
    .dj-card-grid--radio {
        grid-template-columns: 1fr;
    }
}

.dj-search-hero .form-control { border-color: var(--dj-border); }
.dj-search-empty { background: var(--dj-surface) !important; color: var(--dj-text-muted); }

.dj-member-main .dj-account-card {
    background: var(--dj-surface);
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius-lg);
    margin-bottom: 1rem;
    overflow: hidden;
}

.dj-member-main .dj-account-card .card-header {
    background: var(--dj-surface-2);
    border-bottom: 1px solid var(--dj-border);
    font-weight: 600;
    font-size: 14px;
}

.dj-member-main .dj-follow-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}

@media (min-width: 768px) {
    .dj-member-main .dj-follow-grid { grid-template-columns: repeat(3, 1fr); }
}

.dj-member-main .guanzhu {
    display: flex;
    gap: 0.5rem;
    padding: 0.5rem 0;
    border-bottom: 1px solid var(--dj-border);
}

.dj-member-main .guanzhu .gzimg {
    width: 48px;
    height: 48px;
    border-radius: 6px;
    object-fit: cover;
}

/* ---------- 详情/列表双栏网格（legacy page_body，排除 Bootstrap row） ---------- */
@media (min-width: 992px) {
    .dj-page .page_body:not(.row) {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) 280px;
        gap: 1rem;
        align-items: start;
    }

    .dj-page .djshow_list_left,
    .dj-page .sort_list_left,
    .dj-page .radio_list_left,
    .dj-page .search_list_right,
    .dj-page .top_list_left + .search_list_right,
    .dj-page .page_body > .djshow_list_left,
    .dj-page .page_body > .sort_list_left,
    .dj-page .page_body > .radio_list_left {
        grid-column: 1;
        grid-row: 1;
    }

    .dj-page .djshow_list_right,
    .dj-page .sort_list_right,
    .dj-page .radio_list_right,
    .dj-page .search_list_left,
    .dj-page .search_list_right {
        grid-column: 2;
        grid-row: 1;
    }

    .dj-page .top_list_left {
        grid-column: 1;
        grid-row: 1 / span 2;
        max-width: 220px;
    }

    .dj-page--ranks .search_list_right {
        grid-column: 2;
    }
}

.dj-page #hothaomenu {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    background: transparent !important;
}

.dj-page #hothaomenu a {
    display: inline-block;
    padding: 0.4rem 0.75rem;
    font-size: 12px;
    color: var(--dj-text-muted) !important;
    background: var(--dj-surface) !important;
    border: 1px solid var(--dj-border) !important;
    border-radius: 6px !important;
    width: auto !important;
    height: auto !important;
    float: none !important;
}

.dj-page #hothaomenu a.pxon,
.dj-page #hothaomenu a.is-active {
    color: #fff !important;
    background: var(--dj-primary) !important;
    border-color: var(--dj-primary) !important;
}

.dj-page #hothaomenu .wave {
    display: none !important;
}

.dj-page .dj-genre-table-wrap {
    background: var(--dj-surface);
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius-lg);
    overflow: hidden;
}

/* ---------- 清除旧版固定宽度 ---------- */
.dj-page .lines[style*="width"],
.dj-page .radio_list_left,
.dj-page .radio_list_right,
.dj-page .djshow_list_left,
.dj-page .sort_list_left,
.dj-page .sort_list_right,
.dj-page .top_list_left,
.dj-page .search_list_left,
.dj-page .search_list_right {
    width: 100% !important;
    max-width: 100% !important;
    float: none !important;
}

.dj-page .radio_list_left_ct,
.dj-page .djshow_list_left_ct,
.dj-page .sort_list_left_ct {
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
}

.dj-page .radio_list_left_title ._left span,
.dj-page .djshow_content_type ._left span,
.dj-page .top_list_title span {
    font-size: 1.2rem;
    font-weight: 600;
    color: var(--dj-text);
}

.dj-page .radio_list_left_title ._left p,
.dj-page .djshow_content_type ._left p {
    font-size: 12px;
    color: var(--dj-text-muted);
    margin: 0;
}

.dj-page .radio_list_left_title {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.dj-page .radio_list_left_title ul {
    margin: 0;
}

/* 分页 */
.dj-page .list_split_page {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 0.35rem;
    margin: 1.25rem 0;
    float: none !important;
    height: auto !important;
    border: none !important;
}

/* 控制图标 */
.dj-page .contorl_menu_ico .icodown a {
    background-position: -32px -188px;
}

.dj-page .contorl_menu_ico .icocar a {
    background-position: -57px -188px;
}

.dj-page .contorl_menu_ico .icofav a {
    background-position: -82px -188px;
}

.dj-page .djshow_icodown a {
    background-position: -32px -188px;
}

.dj-page .djshow_icocar a {
    background-position: -57px -188px;
}

.dj-page .djshow_icofav a {
    background-position: -82px -188px;
}

.dj-member-list-page .card {
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius-lg);
    overflow: hidden;
}

.dj-member-list-page .card-header-tabs .nav-link {
    font-size: 13px;
    color: var(--dj-text-muted);
}

.dj-member-list-page .card-header-tabs .nav-link.active {
    color: var(--dj-primary);
    font-weight: 600;
}

.dj-member-list-page .table thead th {
    background: var(--dj-surface-2);
    font-weight: 600;
    font-size: 13px;
    white-space: nowrap;
}

/* ---------- 财务类会员页（兑换/提现/收入） ---------- */
.dj-member-finance-page .dj-member-finance-tabs {
    display: flex;
    flex-wrap: nowrap;
    gap: 0.35rem;
    margin-bottom: 1rem;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 0.2rem;
    scrollbar-width: none;
}

.dj-member-finance-page .dj-member-finance-tabs::-webkit-scrollbar {
    display: none;
}

.dj-member-finance-page .dj-member-finance-tabs a {
    flex-shrink: 0;
    white-space: nowrap;
}

.dj-member-finance-page .dj-finance-summary__stats {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem 0.85rem;
    color: var(--dj-text-muted);
    line-height: 1.6;
}

.dj-member-finance-page .dj-finance-summary__stats strong {
    color: var(--dj-text);
}

.dj-member-finance-page .dj-finance-summary__stats .text-primary {
    color: var(--dj-primary) !important;
}

.dj-member-finance-page .dj-finance-rules {
    background: var(--dj-surface-2);
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius);
    padding: 0.75rem 1rem;
    font-size: 13px;
    color: var(--dj-text-muted);
}

.dj-member-finance-page .dj-finance-rules ul {
    margin: 0;
    padding-left: 1.15rem;
}

.dj-member-finance-page .dj-finance-rules li + li {
    margin-top: 0.25rem;
}

.dj-member-finance-page .dj-finance-preview {
    display: flex;
    align-items: center;
    min-height: 38px;
    padding: 0.55rem 0.85rem;
    background: var(--dj-primary-soft);
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius);
}

.dj-member-finance-page .dj-finance-form-list {
    display: flex;
    flex-direction: column;
    gap: 0;
    margin: 0;
}

.dj-member-finance-page .dj-finance-form-list > [class*="col-"] {
    width: 100%;
    max-width: 100%;
    flex: 0 0 auto;
    padding-top: 0.85rem;
    padding-bottom: 0.85rem;
    border-bottom: 1px solid var(--dj-border);
}

.dj-member-finance-page .dj-finance-form-list > [class*="col-"]:first-child {
    padding-top: 0;
}

.dj-member-finance-page .dj-finance-form-list > [class*="col-"]:last-child {
    border-bottom: none;
    padding-bottom: 0;
    padding-top: 1rem;
}

.dj-member-finance-page .dj-finance-form-list .form-label {
    display: block;
    margin-bottom: 0.45rem;
}

.dj-member-finance-page .dj-finance-field-value {
    min-height: 38px;
    display: flex;
    align-items: center;
    padding: 0.5rem 0.85rem;
    background: var(--dj-surface-2);
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius);
}

.dj-member-finance-page .dj-finance-form-list .form-select,
.dj-member-finance-page .dj-finance-form-list > [class*="col-"] > .form-control,
.dj-member-finance-page .dj-finance-form-list .dj-finance-preview {
    width: 100%;
    max-width: 100%;
}

.dj-member-finance-page .dj-finance-form-list .input-group {
    display: flex;
    flex-wrap: nowrap;
    align-items: stretch;
    width: 100%;
    max-width: 100%;
}

.dj-member-finance-page .dj-finance-form-list .input-group > .form-control {
    flex: 1 1 auto;
    width: 1%;
    min-width: 0;
}

.dj-member-finance-page .dj-finance-form-list .input-group > .input-group-text {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    white-space: nowrap;
}

.dj-member-finance-page .form-control-plaintext {
    min-height: 38px;
    display: flex;
    align-items: center;
}

.dj-member-finance-page .card .table-responsive {
    border: none !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}

.dj-member-finance-page .dj-finance-log-card .card-header {
    background: var(--dj-surface-2);
    border-bottom: 1px solid var(--dj-border);
    font-size: 14px;
}

.dj-member-finance-page .input-group-text {
    background: var(--dj-surface-2);
    border-color: var(--dj-border);
    color: var(--dj-text-muted);
}

@media (max-width: 767.98px) {
    .dj-member-finance-page .dj-finance-summary .card-body {
        align-items: flex-start;
    }

    .dj-member-finance-page .dj-finance-summary__stats {
        flex-direction: column;
        gap: 0.2rem;
    }

    .dj-member-finance-page .dj-finance-form-card .row > [class*="col-"] {
        min-width: 0;
    }
}

.dj-radio-box-card .card-header {
    background: var(--dj-surface-2);
}

.dj-radio-box-card .card-footer a {
    color: var(--dj-text-muted);
}

.dj-radio-box-card .card-footer a:hover {
    color: var(--dj-primary);
}

.dj-page--car .page_bai,
.dj-page--upan .page_bai {
    background: transparent;
    box-shadow: none;
    padding: 0;
}

/* VIP 升级套餐 / 支付方式 */
.dj-vip-plans,
.dj-vip-pays {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.dj-member-form-page .vipboxoff,
.dj-member-form-page .vipboxon {
    float: none;
    width: auto;
    min-width: 200px;
    max-width: 100%;
    height: auto;
    min-height: 54px;
    margin: 0;
    padding: 0.65rem 1rem 0.65rem 2.25rem;
    border-radius: var(--dj-radius-lg);
    border: 2px solid var(--dj-border);
    background: var(--dj-surface-2);
    cursor: pointer;
    transition: border-color 0.15s, box-shadow 0.15s, background 0.15s;
    position: relative;
}

.dj-member-form-page .vipboxoff::before,
.dj-member-form-page .vipboxon::before {
    content: "";
    position: absolute;
    left: 0.75rem;
    top: 50%;
    transform: translateY(-50%);
    width: 14px;
    height: 14px;
    border-radius: 50%;
    border: 2px solid var(--dj-border);
    background: var(--dj-surface);
}

.dj-member-form-page .vipboxon {
    border-color: var(--dj-primary);
    background: rgba(124, 58, 237, 0.08);
    box-shadow: 0 0 0 1px rgba(124, 58, 237, 0.15);
}

.dj-member-form-page .vipboxon::before {
    border-color: var(--dj-primary);
    background: var(--dj-primary);
    box-shadow: inset 0 0 0 2px var(--dj-surface);
}

.dj-member-form-page .vipboxoff p,
.dj-member-form-page .vipboxon p {
    margin: 0;
    padding: 0;
    line-height: 1.35;
    font-size: 15px;
    color: var(--dj-text);
}

.dj-member-form-page .vipboxoff p .t1,
.dj-member-form-page .vipboxon p .t1 {
    font-size: 14px;
    font-weight: 600;
    color: var(--dj-primary);
}

.dj-member-form-page .vipboxoff p .t2,
.dj-member-form-page .vipboxon p .t2 {
    font-size: 12px;
    font-style: normal;
    color: var(--dj-text-muted);
}

.dj-member-form-page .vipboxoff img,
.dj-member-form-page .vipboxon img {
    margin: 0;
    max-height: 36px;
    width: auto;
}

.dj-member-form-page .vipboxoff:has(img),
.dj-member-form-page .vipboxon:has(img) {
    min-width: 140px;
    padding-left: 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

.dj-member-form-page .vipboxoff:has(img)::before,
.dj-member-form-page .vipboxon:has(img)::before {
    display: none;
}

/* 前台支付页套餐选择（与会员 VIP 同风格） */
.dj-vip-pays .vipboxoff,
.dj-vip-pays .vipboxon {
    float: none;
    width: auto;
    min-width: 140px;
    max-width: 100%;
    height: auto;
    min-height: 54px;
    margin: 0;
    padding: 0.65rem 1rem;
    border-radius: var(--dj-radius-lg);
    border: 2px solid var(--dj-border);
    background: var(--dj-surface-2);
    cursor: pointer;
    transition: border-color 0.15s, box-shadow 0.15s, background 0.15s;
    display: flex;
    align-items: center;
    justify-content: center;
}

.dj-vip-pays .vipboxon {
    border-color: var(--dj-primary);
    background: rgba(124, 58, 237, 0.08);
    box-shadow: 0 0 0 1px rgba(124, 58, 237, 0.15);
}

.dj-vip-pays .vipboxoff img,
.dj-vip-pays .vipboxon img {
    margin: 0;
    max-height: 36px;
    width: auto;
}

.dj-page--car .paycdtb,
.dj-page--mall .paycdtb {
    margin: 0;
}

.dj-page--car .paycdtb .ddt,
.dj-page--mall .paycdtb .ddt {
    background: var(--dj-surface-2);
    font-weight: 600;
    font-size: 13px;
    white-space: nowrap;
}

.dj-page--car .paycdtb td,
.dj-page--mall .paycdtb td {
    vertical-align: middle;
    font-size: 13px;
}

.dj-page--car .card .jg,
.dj-page--mall .card .jg {
    color: var(--dj-primary);
    font-weight: 700;
    font-size: 1.1rem;
}

.dj-page--car .dj-car-toolbar .btn-group .btn.active,
.dj-page--car .dj-car-toolbar .btn-group .btn-success {
    background: var(--dj-primary);
    border-color: var(--dj-primary);
    color: #fff;
}

.dj-page--car .dj-car-notice {
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius-lg);
    background: var(--dj-surface);
    overflow: hidden;
}

.dj-page--car .dj-car-notice-hd {
    background: var(--dj-surface-2);
    font-weight: 600;
    padding: 0.65rem 1rem;
    border-bottom: 1px solid var(--dj-border);
}

.dj-page--car .dj-car-notice-bd {
    padding: 1rem;
    font-size: 13px;
    line-height: 1.65;
    color: var(--dj-text-muted);
}

.dj-page--car .dj-unpaid-alert .table {
    margin: 0;
    font-size: 13px;
}

/* 下单 / 确认订单 — 收货地址 */
.dj-order-form .card {
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius-lg);
    overflow: hidden;
    background: var(--dj-surface);
}

.dj-order-form .card-header {
    background: var(--dj-surface-2);
    font-size: 14px;
}

.dj-address-pick {
    background: var(--dj-surface-2);
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius-lg);
    padding: 1rem;
}

.dj-address-pick ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.dj-address-pick li {
    margin-bottom: 0.5rem;
}

.dj-address-pick-item {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    padding: 0.65rem 0.75rem;
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius);
    background: var(--dj-surface);
}

.dj-address-pick-item:hover {
    border-color: var(--dj-primary-muted);
}

.dj-address-pick-label {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    margin: 0;
    flex: 1;
    min-width: 0;
    cursor: pointer;
}

.dj-address-pick-text {
    font-size: 13px;
    line-height: 1.45;
    color: var(--dj-text-muted);
}

.dj-address-pick-text strong {
    color: var(--dj-text);
}

.dj-address-pick-del {
    flex-shrink: 0;
}

.dj-address-form table,
.dj-order-form .dj-address-form table {
    width: 100% !important;
    border: 0;
    color: var(--dj-text-muted);
}

.dj-address-form table tr,
.dj-order-form .dj-address-form table tr {
    display: block;
    margin-bottom: 0.85rem;
}

.dj-address-form table td,
.dj-order-form .dj-address-form table td {
    display: block;
    width: 100% !important;
    height: auto !important;
    padding: 0;
    border: 0;
    font-size: 13px;
}

.dj-address-form #address3,
.dj-order-form .dj-address-form #address3 {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem 0.5rem;
}

.dj-address-form .inputord,
.dj-address-form .inputmo,
.dj-address-form select,
.dj-order-form .dj-address-form .inputord,
.dj-order-form .dj-address-form .inputmo,
.dj-order-form .dj-address-form select {
    display: inline-block;
    max-width: 100%;
    padding: 0.35rem 0.65rem;
    font-size: 13px;
    line-height: 1.5;
    color: var(--dj-text);
    background: var(--dj-surface);
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius);
}

.dj-address-form #address,
.dj-address-form #consignee,
.dj-address-form #mobile,
.dj-address-form #tencentqq,
.dj-address-form #phone1,
.dj-address-form #phone2,
.dj-address-form #phone3,
.dj-order-form .dj-address-form #address,
.dj-order-form .dj-address-form #consignee,
.dj-order-form .dj-address-form #mobile,
.dj-order-form .dj-address-form #tencentqq {
    width: 100%;
    max-width: 100%;
    margin-top: 0.25rem;
}

.dj-address-form .cor33,
.dj-order-form .dj-address-form .cor33 {
    display: block;
    margin-top: 0.25rem;
    font-size: 12px;
    color: var(--dj-text-muted);
}

.dj-page--car .dj-order-search-body {
    min-height: 500px;
}

.dj-member-detail-page .list-group-item,
.dj-member-list-page .list-group-item {
    background: transparent;
    color: var(--dj-text-muted);
    border-color: var(--dj-border);
}

.dj-member-detail-page .list-group-item:hover,
.dj-member-list-page .list-group-item:hover {
    background: rgba(124, 58, 237, 0.06);
    color: var(--dj-primary-light, #a78bfa);
}

.dj-product-table {
    margin: 0;
    font-size: 13px;
}

.dj-product-table thead th {
    background: var(--dj-surface-2);
    font-weight: 600;
    white-space: nowrap;
}

.dj-product-table tfoot td {
    background: var(--dj-surface-2);
}

.dj-page--mall .paybutton {
    display: inline-block;
    padding: 0.55rem 1.25rem;
    font-size: 14px;
    font-weight: 600;
    border-radius: var(--dj-radius);
    border: 1px solid var(--dj-primary);
    background: var(--dj-primary);
    color: #fff;
    cursor: pointer;
}

.dj-page--mall .paybutton:hover {
    filter: brightness(1.05);
}

.dj-page--mall .paybutton--dark {
    background: var(--dj-surface-2);
    border-color: var(--dj-border);
    color: var(--dj-text);
}

.dj-page--upan .dj-car-toolbar .btn-group .btn.active,
.dj-page--upan .dj-car-toolbar .btn-group .btn-success {
    background: var(--dj-primary);
    border-color: var(--dj-primary);
    color: #fff;
}

.dj-page--upan .upboxoff,
.dj-page--upan .upboxon {
    float: left;
    width: auto;
    min-width: 190px;
    height: auto !important;
    margin: 0 0.75rem 0.75rem 0;
    padding: 0.75rem;
    border: 2px solid var(--dj-border);
    border-radius: var(--dj-radius-lg);
    background: var(--dj-surface-2) !important;
    background-image: none !important;
    cursor: pointer;
    transition: border-color 0.15s, box-shadow 0.15s, background 0.15s;
    line-height: 1.4;
    overflow: visible;
}

.dj-page--upan .upboxon {
    border-color: var(--dj-primary);
    background: rgba(124, 58, 237, 0.08) !important;
    box-shadow: 0 0 0 1px rgba(124, 58, 237, 0.15);
}

.dj-page--upan .upboxoff p,
.dj-page--upan .upboxon p {
    margin: 0;
    padding: 0;
}

.dj-page--upan .seege {
    background: var(--dj-primary);
    color: #fff;
    text-align: center;
    width: 60px;
    line-height: 25px;
    position: absolute;
    z-index: 2;
    margin-left: 199px;
    margin-top: 28px;
    cursor: pointer;
    border-radius: 4px;
    font-size: 12px;
}

.dj-page--upan #upan_music,
.dj-page--upan .dj-upan-music-area {
    background: var(--dj-surface-2) !important;
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius-lg);
    width: 100% !important;
    max-width: 100%;
    min-height: 120px;
    padding: 0.75rem;
    overflow: visible;
}

.dj-upan-music-empty {
    color: var(--dj-text-muted);
    font-size: 13px;
    text-align: center;
    padding: 2rem 1rem;
}

.dj-upan-music-list {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

/* 歌曲行 — CD / U盘共用（对齐 dj93） */
.dj-song-row {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    padding: 0.85rem 1rem;
    border: 1px solid var(--dj-border);
    border-radius: 14px;
    background: var(--dj-surface);
}

.dj-song-row--empty {
    opacity: 0.55;
}

.dj-song-row__idx {
    flex-shrink: 0;
    width: 38px;
    height: 38px;
    border-radius: 10px;
    background: rgba(236, 72, 153, 0.12);
    color: #db2777;
    font-size: 13px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
}

.dj-song-row__body {
    flex: 1;
    min-width: 0;
}

.dj-song-row__title-line {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.dj-song-row__title {
    color: var(--dj-text);
    font-size: 14px;
    line-height: 1.45;
    text-decoration: none;
    word-break: break-word;
}

.dj-song-row__title:hover {
    color: var(--dj-primary);
}

.dj-song-row__title--muted {
    color: var(--dj-text-muted);
}

.dj-song-row__tag {
    flex-shrink: 0;
    font-size: 12px;
    line-height: 1;
    padding: 0.2rem 0.55rem;
    border-radius: 999px;
    font-weight: 600;
}

.dj-song-row__tag--mix {
    background: rgba(236, 72, 153, 0.12);
    color: #e11d48;
}

.dj-song-row__tag--single {
    background: rgba(124, 58, 237, 0.12);
    color: var(--dj-primary);
}

.dj-song-row__meta {
    margin-top: 0.25rem;
    font-size: 12px;
    color: var(--dj-text-muted);
}

.dj-song-row__ops {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.dj-song-row__btn {
    width: 34px;
    height: 34px;
    padding: 0;
    border: 0;
    border-radius: 10px;
    background: var(--dj-surface-2);
    color: var(--dj-text-muted);
    cursor: pointer;
    font-size: 15px;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background 0.15s, color 0.15s;
}

.dj-song-row__btn:hover {
    background: rgba(124, 58, 237, 0.12);
    color: var(--dj-primary);
}

.dj-song-row__btn--up::before {
    content: "↑";
}

.dj-song-row__btn--down::before {
    content: "↓";
}

.dj-song-row__btn--del::before {
    content: "×";
    font-size: 20px;
}

.dj-song-row__btn--del:hover {
    background: rgba(239, 68, 68, 0.1);
    color: #dc2626;
}

.dj-upan-price-old {
    color: var(--dj-text-muted);
    text-decoration: line-through;
    margin-right: 0.35rem;
}

.dj-page--upan .music_subtotal,
.dj-page--upan .remix_subtotal,
.dj-page--upan .upan_subtotal {
    text-align: right;
    color: var(--dj-text-muted);
}

.dj-page--upan .music_subtotal b,
.dj-page--upan .remix_subtotal b,
.dj-page--upan .upan_subtotal b,
.dj-page--upan .upan_total b {
    color: var(--dj-primary);
}

/* CD 购物车 */
.dj-page--car .dj-car-summary {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem 1rem;
    padding: 0.85rem 1rem;
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius-lg);
    background: var(--dj-surface-2);
}

.dj-page--car .dj-car-summary__info,
.dj-page--car .dj-car-summary__price {
    font-size: 14px;
    color: var(--dj-text-muted);
}

.dj-page--car .dj-car-summary__info span,
.dj-page--car .dj-car-summary__price span {
    color: var(--dj-primary);
    font-weight: 700;
}

.dj-page--car .dj-car-summary__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin: 0;
}

.dj-page--car .dj-car-cart {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.dj-page--car .dj-car-disc {
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius-lg);
    overflow: hidden;
    background: var(--dj-surface);
}

.dj-page--car .dj-car-disc__label {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    padding: 0.55rem 0.85rem;
    background: var(--dj-surface-2);
    border-bottom: 1px solid var(--dj-border);
}

.dj-page--car .dj-car-disc__num {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--dj-text-muted);
    min-width: 2rem;
}

.dj-page--car .dj-car-disc__badge {
    display: inline-block;
    font-size: 12px;
    line-height: 1;
    padding: 0.25rem 0.55rem;
    border-radius: 999px;
    background: rgba(124, 58, 237, 0.12);
    color: var(--dj-primary);
    font-weight: 600;
}

.dj-page--car .dj-car-disc--mix .dj-car-disc__badge {
    background: rgba(234, 179, 8, 0.15);
    color: #ca8a04;
}

.dj-page--car .dj-car-disc--partial .dj-car-disc__badge {
    background: rgba(239, 68, 68, 0.12);
    color: #dc2626;
}

.dj-page--car .dj-car-disc__tracks {
    padding: 0.35rem 0;
}

.dj-page--car .dj-car-disc__tracks {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
    padding: 0.75rem;
}

.dj-page--car .dj-car-disc__tracks .dj-song-row {
    margin: 0;
}

.dj-page--car .dj-car-track {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    padding: 0.35rem 0.85rem;
    font-size: 13px;
    min-height: 32px;
}

.dj-page--car .dj-car-track:nth-child(even) {
    background: var(--dj-surface-2);
}

.dj-page--car .dj-car-track--empty {
    opacity: 0.55;
}

.dj-page--car .dj-car-track__idx {
    flex-shrink: 0;
    width: 22px;
    height: 18px;
    line-height: 16px;
    text-align: center;
    font-size: 11px;
    border: 1px solid #886e08;
    background: #ffcc00;
    color: #000;
    border-radius: 2px;
}

.dj-page--car .dj-car-track__idx--off {
    border-color: var(--dj-border);
    background: var(--dj-surface-2);
    color: var(--dj-text-muted);
}

.dj-page--car .dj-car-track__id {
    flex-shrink: 0;
    width: 52px;
    text-align: center;
    color: var(--dj-text-muted);
    font-size: 12px;
}

.dj-page--car .dj-car-track__name {
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: var(--dj-text);
    text-decoration: none;
}

.dj-page--car .dj-car-track__name:hover {
    color: var(--dj-primary);
}

.dj-page--car .dj-car-track__name--muted {
    color: var(--dj-text-muted);
}

.dj-page--car .dj-car-track__ops {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
}

.dj-page--car .dj-car-track__sort,
.dj-page--car .dj-car-track__del {
    width: 22px;
    height: 22px;
    padding: 0;
    border: 0;
    border-radius: 4px;
    cursor: pointer;
    background: transparent;
    color: var(--dj-text-muted);
    font-size: 14px;
    line-height: 20px;
    text-align: center;
}

.dj-page--car .dj-car-track__sort--up::before {
    content: "↑";
}

.dj-page--car .dj-car-track__sort--down::before {
    content: "↓";
}

.dj-page--car .dj-car-track__del::before {
    content: "×";
    font-size: 18px;
}

.dj-page--car .dj-car-track__sort:hover,
.dj-page--car .dj-car-track__del:hover {
    color: var(--dj-primary);
    background: rgba(124, 58, 237, 0.08);
}

.dj-page--car .dj-car-track__del:hover {
    color: #dc2626;
    background: rgba(239, 68, 68, 0.08);
}

.dj-page--upan .upan-order-table td {
    vertical-align: middle;
}

.dj-page--car .dj-order-search .table thead th,
.dj-page--car .dj-order-search .table td {
    font-size: 13px;
    vertical-align: middle;
}

.dj-page--mall .dj-mall-info {
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius-lg);
    overflow: hidden;
}

.dj-page--mall .dj-mall-info-tabs .nav-link {
    border: 1px solid var(--dj-border);
    color: var(--dj-text-muted);
    font-size: 13px;
    padding: 0.5rem 0.75rem;
}

.dj-page--mall .dj-mall-info-tabs .nav-link.cttitleon {
    background: var(--dj-primary);
    border-color: var(--dj-primary);
    color: #fff;
}

.dj-page--mall .dj-mall-info-tabs .nav-link.cttitleoff {
    background: var(--dj-surface-2);
}

.dj-page--mall .mall-info-pane {
    font-size: 14px;
    line-height: 1.65;
    color: var(--dj-text-muted);
}

.dj-page--mall .mall-info-pane img {
    max-width: 100%;
    height: auto;
}

.dj-page--car .page_bai_ct .list-group-item {
    background: transparent;
    color: var(--dj-text-muted);
    border-color: var(--dj-border);
}

.dj-page--car .page_bai_ct .list-group-item:hover,
.dj-page--car .page_bai_ct .list-group-item:focus {
    background: rgba(124, 58, 237, 0.06);
    color: var(--dj-primary-light, #a78bfa);
}

.dj-page--mall .dj-product-table tr.carct2 td,
.dj-page--mall .dj-product-table tbody tr:has(input:checked) td {
    background: rgba(124, 58, 237, 0.06);
}

/* ========== 下载弹窗 music_down ========== */
:root,
[data-theme="light"] {
    --dl-page-bg: var(--dj-bg, #f6f5fa);
    --dl-card-bg: var(--dj-surface, #ffffff);
    --dl-head-bg: var(--dj-surface-2, #efedf5);
    --dl-notice-bg: var(--dj-surface-2, #efedf5);
    --dl-text: var(--dj-text, #1a1625);
    --dl-muted: var(--dj-text-muted, #6b6578);
    --dl-border: var(--dj-border, #ddd6f3);
    --dl-item-bg: rgba(124, 58, 237, 0.06);
    --dl-item-border: rgba(124, 58, 237, 0.12);
    --dl-item-hover-bg: rgba(124, 58, 237, 0.1);
    --dl-item-hover-border: rgba(124, 58, 237, 0.22);
    --dl-item-hover-text: var(--dj-primary, #7c3aed);
    --dl-item-value: var(--dj-primary, #7c3aed);
    --dl-title-hover: var(--dj-primary-hover, #6d28d9);
    --dl-status-bg: rgba(124, 58, 237, 0.08);
    --dl-status-text: var(--dj-text-muted, #6b6578);
    --dl-id-bg: rgba(124, 58, 237, 0.1);
    --dl-id-label: var(--dj-primary, #7c3aed);
    --dl-id-num: var(--dj-text, #1a1625);
    --dl-shadow: var(--dj-shadow, 0 25px 70px -20px rgba(26, 22, 37, 0.12));
    --dl-link: var(--dj-primary, #7c3aed);
    --dl-input-bg: var(--dj-surface, #ffffff);
    --dl-input-border: var(--dj-border, #ddd6f3);
    --dl-input-text: var(--dj-text, #1a1625);
    --dl-layer-bg: var(--dj-bg, #f6f5fa);
    --dl-layer-title-bg: var(--dj-surface, #ffffff);
    --dl-layer-title-text: var(--dj-text, #1a1625);
    --dl-layer-close-filter: none;
}

[data-theme="dark"] {
    --dl-page-bg: #0f0f12;
    --dl-card-bg: #141417;
    --dl-head-bg: #0f0f12;
    --dl-notice-bg: #0f0f12;
    --dl-text: #f0f0f5;
    --dl-muted: #9a9aa3;
    --dl-border: rgba(255, 255, 255, 0.08);
    --dl-item-bg: rgba(255, 255, 255, 0.04);
    --dl-item-border: rgba(255, 255, 255, 0.06);
    --dl-item-hover-bg: rgba(255, 45, 85, 0.08);
    --dl-item-hover-border: rgba(255, 45, 85, 0.3);
    --dl-item-hover-text: #c3cfff;
    --dl-item-value: #ff2d55;
    --dl-title-hover: #ff2d55;
    --dl-status-bg: rgba(255, 255, 255, 0.04);
    --dl-status-text: #a0a0a8;
    --dl-id-bg: rgba(255, 45, 85, 0.08);
    --dl-id-label: #ff6b8a;
    --dl-id-num: #babce0;
    --dl-shadow: 0 25px 70px -20px rgba(0, 0, 0, 0.55);
    --dl-link: #ff2d55;
    --dl-input-bg: rgba(255, 255, 255, 0.05);
    --dl-input-border: rgba(255, 255, 255, 0.1);
    --dl-input-text: #e3e3e7;
    --dl-layer-bg: #0f0f12;
    --dl-layer-title-bg: #141417;
    --dl-layer-title-text: #f0f0f5;
    --dl-layer-close-filter: invert(1);
}

@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]) {
        --dl-page-bg: #0f0f12;
        --dl-card-bg: #141417;
        --dl-head-bg: #0f0f12;
        --dl-notice-bg: #0f0f12;
        --dl-text: #f0f0f5;
        --dl-muted: #9a9aa3;
        --dl-border: rgba(255, 255, 255, 0.08);
        --dl-item-bg: rgba(255, 255, 255, 0.04);
        --dl-item-border: rgba(255, 255, 255, 0.06);
        --dl-item-hover-bg: rgba(255, 45, 85, 0.08);
        --dl-item-hover-border: rgba(255, 45, 85, 0.3);
        --dl-item-hover-text: #c3cfff;
        --dl-item-value: #ff2d55;
        --dl-title-hover: #ff2d55;
        --dl-status-bg: rgba(255, 255, 255, 0.04);
        --dl-status-text: #a0a0a8;
        --dl-id-bg: rgba(255, 45, 85, 0.08);
        --dl-id-label: #ff6b8a;
        --dl-id-num: #babce0;
        --dl-shadow: 0 25px 70px -20px rgba(0, 0, 0, 0.55);
        --dl-link: #ff2d55;
        --dl-input-bg: rgba(255, 255, 255, 0.05);
        --dl-input-border: rgba(255, 255, 255, 0.1);
        --dl-input-text: #e3e3e7;
        --dl-layer-bg: #0f0f12;
        --dl-layer-title-bg: #141417;
        --dl-layer-title-text: #f0f0f5;
        --dl-layer-close-filter: invert(1);
    }
}

@media (prefers-color-scheme: light) {
    :root:not([data-theme="dark"]) {
        --dl-page-bg: var(--dj-bg, #f6f5fa);
        --dl-card-bg: var(--dj-surface, #ffffff);
        --dl-head-bg: var(--dj-surface-2, #efedf5);
        --dl-notice-bg: var(--dj-surface-2, #efedf5);
        --dl-text: var(--dj-text, #1a1625);
        --dl-muted: var(--dj-text-muted, #6b6578);
        --dl-border: var(--dj-border, #ddd6f3);
        --dl-item-bg: rgba(124, 58, 237, 0.06);
        --dl-item-border: rgba(124, 58, 237, 0.12);
        --dl-item-hover-bg: rgba(124, 58, 237, 0.1);
        --dl-item-hover-border: rgba(124, 58, 237, 0.22);
        --dl-item-hover-text: var(--dj-primary, #7c3aed);
        --dl-item-value: var(--dj-primary, #7c3aed);
        --dl-title-hover: var(--dj-primary-hover, #6d28d9);
        --dl-status-bg: rgba(124, 58, 237, 0.08);
        --dl-status-text: var(--dj-text-muted, #6b6578);
        --dl-id-bg: rgba(124, 58, 237, 0.1);
        --dl-id-label: var(--dj-primary, #7c3aed);
        --dl-id-num: var(--dj-text, #1a1625);
        --dl-shadow: var(--dj-shadow, 0 25px 70px -20px rgba(26, 22, 37, 0.12));
        --dl-link: var(--dj-primary, #7c3aed);
        --dl-input-bg: var(--dj-surface, #ffffff);
        --dl-input-border: var(--dj-border, #ddd6f3);
        --dl-input-text: var(--dj-text, #1a1625);
        --dl-layer-bg: var(--dj-bg, #f6f5fa);
        --dl-layer-title-bg: var(--dj-surface, #ffffff);
        --dl-layer-title-text: var(--dj-text, #1a1625);
        --dl-layer-close-filter: none;
    }
}

body .demo-black-class {
    border-radius: 12px !important;
    overflow: hidden !important;
    box-shadow: 0 25px 70px -20px rgba(0, 0, 0, 0.35);
}

body .demo-black-class .layui-layer-title {
    background: var(--dl-layer-title-bg, #141417);
    color: var(--dl-layer-title-text, #f0f0f5);
    border: none;
    border-bottom: 1px solid var(--dl-border, rgba(255, 255, 255, 0.08));
    font-size: 14px;
    border-radius: 0;
}

body .demo-black-class .layui-layer-content {
    background: var(--dl-layer-bg, #0f0f12);
    overflow: hidden;
}

body .demo-black-class .layui-layer-content iframe {
    display: block;
    border: 0;
    background: var(--dl-page-bg, #0f0f12);
}

body .demo-black-class .layui-layer-close {
    filter: var(--dl-layer-close-filter, invert(1));
    opacity: 0.7;
}

/* ========== 加入音乐盒弹窗 ========== */
body .demo-black-class.dj-fav-layer .layui-layer-content {
    padding: 0;
    background: var(--dj-fav-bg, var(--dl-layer-bg, #0f0f12));
}

.dj-fav-modal {
    padding: 1rem 1.1rem 1.1rem;
    color: var(--dj-fav-text, var(--dj-text, #1a1625));
    font-size: 13px;
    line-height: 1.5;
}

.dj-fav-modal__song {
    margin-bottom: 0.75rem;
    padding: 0.65rem 0.75rem;
    border-radius: 10px;
    background: var(--dj-fav-song-bg, rgba(124, 58, 237, 0.08));
    border: 1px solid var(--dj-fav-border, rgba(124, 58, 237, 0.14));
    font-weight: 600;
    word-break: break-word;
}

.dj-fav-modal__target {
    margin-bottom: 0.55rem;
    color: var(--dj-fav-muted, var(--dj-text-muted, #6b6578));
    font-size: 12px;
}

.dj-fav-modal__target strong {
    color: var(--dj-fav-accent, var(--dj-primary, #7c3aed));
    font-weight: 600;
}

.dj-fav-modal__list {
    max-height: 132px;
    overflow-y: auto;
    border: 1px solid var(--dj-fav-border, var(--dj-border, #ddd6f3));
    border-radius: 10px;
    background: var(--dj-fav-list-bg, var(--dj-surface-2, #efedf5));
}

.dj-fav-modal__item a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    padding: 0.55rem 0.75rem;
    color: var(--dj-fav-text, var(--dj-text, #1a1625));
    text-decoration: none;
    transition: background 0.15s, color 0.15s;
}

.dj-fav-modal__item a span {
    flex-shrink: 0;
    color: var(--dj-fav-count, #00aa50);
    font-size: 12px;
    font-weight: 600;
}

.dj-fav-modal__item a:hover {
    background: var(--dj-fav-item-hover, rgba(124, 58, 237, 0.08));
}

.dj-fav-modal__item.is-active a {
    background: var(--dj-fav-item-active, rgba(124, 58, 237, 0.14));
    color: var(--dj-fav-accent, var(--dj-primary, #7c3aed));
    font-weight: 600;
}

.dj-fav-modal__new {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 0.75rem;
}

.dj-fav-modal__input {
    flex: 1 1 220px;
    min-width: 0;
    height: 38px;
    padding: 0 0.75rem;
    border-radius: 10px;
    border: 1px solid var(--dj-fav-border, var(--dj-border, #ddd6f3));
    background: var(--dj-fav-input-bg, var(--dj-surface, #fff));
    color: var(--dj-fav-text, var(--dj-text, #1a1625));
    font-size: 13px;
    outline: none;
    transition: border-color 0.15s, box-shadow 0.15s;
}

.dj-fav-modal__input:focus {
    border-color: var(--dj-fav-accent, var(--dj-primary, #7c3aed));
    box-shadow: 0 0 0 3px var(--dj-fav-focus, rgba(124, 58, 237, 0.15));
}

.dj-fav-modal__actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.55rem;
    margin-top: 0.85rem;
}

.dj-fav-modal__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 40px;
    padding: 0.5rem 0.85rem;
    border: 0;
    border-radius: 10px;
    font-size: 13px;
    font-weight: 600;
    line-height: 1.2;
    cursor: pointer;
    transition: transform 0.15s, opacity 0.15s, box-shadow 0.15s;
}

.dj-fav-modal__btn:hover {
    transform: translateY(-1px);
}

.dj-fav-modal__btn--primary {
    background: linear-gradient(135deg, #ff2d55, #e61e45);
    color: #fff;
    box-shadow: 0 6px 16px rgba(255, 45, 85, 0.22);
}

.dj-fav-modal__btn--primary:hover {
    color: #fff;
    box-shadow: 0 8px 20px rgba(255, 45, 85, 0.3);
}

.dj-fav-modal__btn--secondary {
    background: var(--dj-fav-btn-secondary-bg, var(--dj-surface-2, #efedf5));
    color: var(--dj-fav-text, var(--dj-text, #1a1625));
    border: 1px solid var(--dj-fav-border, var(--dj-border, #ddd6f3));
}

.dj-fav-modal__btn--ghost {
    flex: 0 0 auto;
    min-width: 108px;
    background: var(--dj-fav-btn-ghost-bg, var(--dj-surface-3, #e8e4f3));
    color: var(--dj-fav-text, var(--dj-text, #1a1625));
    border: 1px solid var(--dj-fav-border, var(--dj-border, #ddd6f3));
}

.dj-fav-modal__msg {
    margin-top: 0.65rem;
    min-height: 0;
}

.dj-fav-modal__msg:empty {
    display: none;
}

.dj-fav-modal__tip {
    padding: 0.55rem 0.7rem;
    border-radius: 8px;
    font-size: 12px;
    line-height: 1.5;
}

.dj-fav-modal__tip--err {
    background: rgba(239, 68, 68, 0.1);
    color: #dc2626;
}

.dj-fav-modal__tip--ok {
    background: rgba(34, 197, 94, 0.1);
    color: #16a34a;
}

.dj-fav-modal__loading {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.45rem 0.65rem;
    border-radius: 8px;
    background: rgba(124, 58, 237, 0.08);
    color: var(--dj-fav-accent, var(--dj-primary, #7c3aed));
    font-size: 12px;
}

.dj-fav-modal__loading::before {
    content: "";
    width: 14px;
    height: 14px;
    border: 2px solid currentColor;
    border-top-color: transparent;
    border-radius: 50%;
    animation: dl-spin 0.7s linear infinite;
}

[data-theme="dark"] {
    --dj-fav-bg: #141417;
    --dj-fav-text: #f0f0f5;
    --dj-fav-muted: #9a9aa3;
    --dj-fav-border: rgba(255, 255, 255, 0.08);
    --dj-fav-song-bg: rgba(255, 255, 255, 0.04);
    --dj-fav-list-bg: rgba(255, 255, 255, 0.03);
    --dj-fav-item-hover: rgba(255, 45, 85, 0.08);
    --dj-fav-item-active: rgba(255, 45, 85, 0.14);
    --dj-fav-accent: #ff6b8a;
    --dj-fav-count: #3ecf6e;
    --dj-fav-input-bg: rgba(255, 255, 255, 0.05);
    --dj-fav-btn-secondary-bg: rgba(255, 255, 255, 0.06);
    --dj-fav-btn-ghost-bg: rgba(255, 255, 255, 0.08);
    --dj-fav-focus: rgba(255, 45, 85, 0.18);
}

@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]) {
        --dj-fav-bg: #141417;
        --dj-fav-text: #f0f0f5;
        --dj-fav-muted: #9a9aa3;
        --dj-fav-border: rgba(255, 255, 255, 0.08);
        --dj-fav-song-bg: rgba(255, 255, 255, 0.04);
        --dj-fav-list-bg: rgba(255, 255, 255, 0.03);
        --dj-fav-item-hover: rgba(255, 45, 85, 0.08);
        --dj-fav-item-active: rgba(255, 45, 85, 0.14);
        --dj-fav-accent: #ff6b8a;
        --dj-fav-count: #3ecf6e;
        --dj-fav-input-bg: rgba(255, 255, 255, 0.05);
        --dj-fav-btn-secondary-bg: rgba(255, 255, 255, 0.06);
        --dj-fav-btn-ghost-bg: rgba(255, 255, 255, 0.08);
        --dj-fav-focus: rgba(255, 45, 85, 0.18);
    }
}

@media (max-width: 480px) {
    .dj-fav-modal {
        padding: 0.85rem;
    }

    .dj-fav-modal__new {
        flex-direction: column;
    }

    .dj-fav-modal__btn--ghost {
        width: 100%;
    }
}

/* ========== 下载弹窗（对齐 dj93 dl-* 布局） ========== */
body.dj-down-page {
    margin: 0;
    padding: 0;
    min-width: 0;
    overflow: hidden;
    background: var(--dl-page-bg);
    color: var(--dl-text);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Microsoft YaHei", sans-serif;
    font-size: 13px;
    line-height: 1.5;
}

body.dj-down-page *,
body.dj-down-page *::before,
body.dj-down-page *::after {
    box-sizing: border-box;
}

.dl-wrapper {
    width: 100%;
    max-width: 560px;
    border-radius: 12px;
    height: auto;
    min-height: auto;
    margin: 0 auto;
}

body.dj-down-page .dl-wrapper {
    max-width: 100%;
    border-radius: 0;
    margin: 0;
}

body.dj-down-page .dl-card {
    border-radius: 0;
    box-shadow: none;
    animation: none;
}

body.dj-down-page .dl-card-head {
    border-radius: 0;
}

body.dj-down-page .dl-notice {
    border-radius: 0;
}

.dl-card {
    background: var(--dl-card-bg);
    border-radius: 12px;
    overflow: hidden;
    box-shadow: var(--dl-shadow);
    animation: dl-fade-in 0.5s ease forwards;
}

@keyframes dl-fade-in {
    from {
        opacity: 0;
        transform: translateY(20px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.dl-card-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px;
    background: var(--dl-head-bg);
    border-radius: 12px 12px 0 0;
    border-bottom: 1px solid var(--dl-border);
}

.dl-logo img {
    height: 34px;
    object-fit: contain;
}

[data-theme="dark"] .dl-logo img {
    filter: brightness(1.2);
}

@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]) .dl-logo img {
        filter: brightness(1.2);
    }
}

.dl-song-id {
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.5px;
    background: var(--dl-id-bg);
    color: var(--dl-id-label);
    padding: 5px 15px;
    border-radius: 50px;
    white-space: nowrap;
}

.dl-song-id span {
    color: var(--dl-id-num);
    font-weight: 600;
    margin-left: 4px;
}

.dl-song-info {
    padding: 22px 20px 0;
    text-align: center;
}

.dl-song-title {
    margin-bottom: 24px;
    width: 100%;
    overflow: hidden;
}

.dl-song-title a {
    color: var(--dl-text);
    font-size: 20px;
    font-weight: 600;
    text-decoration: none;
    transition: color 0.25s ease;
    display: block;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    width: 100%;
}

.dl-song-title a:hover {
    color: var(--dl-title-hover);
}

.dl-info-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
}

.dl-info-item {
    background: var(--dl-item-bg);
    padding: 8px 6px;
    border-radius: 12px;
    font-size: 11px;
    color: var(--dl-muted);
    border: 1px solid var(--dl-item-border);
    transition: all 0.25s ease;
    text-align: center;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    word-break: keep-all;
}

.dl-info-item:hover {
    background: var(--dl-item-hover-bg);
    border-color: var(--dl-item-hover-border);
    color: var(--dl-item-hover-text);
}

.dl-info-item span {
    color: var(--dl-item-value);
    font-weight: 600;
    margin-left: 4px;
    white-space: nowrap;
}

.dl-action-area {
    padding: 16px 20px 18px;
    text-align: center;
}

#dl-downstr {
    display: contents;
    justify-content: center;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    width: 100%;
}

#dl-downstr > span:first-child {
    display: block;
    padding: 12px 20px;
    background: var(--dl-status-bg);
    border-radius: 12px;
    color: var(--dl-status-text);
    font-size: 13px;
    text-align: center;
    width: 100%;
    margin-bottom: 10px;
}

#dl-downstr > div > span {
    display: block;
    padding: 12px 20px;
    background: var(--dl-status-bg);
    border-radius: 12px;
    color: var(--dl-status-text);
    font-size: 13px;
    text-align: center;
    width: 100%;
    margin-bottom: 16px;
}

#dl-downstr:has(>:nth-child(3)) {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 12px !important;
}

#dl-downstr:has(>:nth-child(3)) > :first-child {
    grid-column: span 2;
}

#dl-downstr:has(> a:first-child + a:last-child),
#dl-downstr:has(> span:first-child + a:last-child) {
    display: contents !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 12px !important;
}

#dl-downstr:has(> a:first-child + span:last-child) {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 12px !important;
}

#dl-downstr:has(> a:first-child + span:last-child) > a,
#dl-downstr:has(> a:first-child + span:last-child) > .upanstyle {
    width: 100%;
}

#dl-downstr:has(> .dl-code-group + .upanstyle) {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
}

#dl-downstr:has(> .dl-code-group + .upanstyle) .upanstyle,
#dl-downstr:has(> .dl-code-group + .upanstyle) .dl-btn-disk {
    width: 100%;
}

#dl-downstr:has(> span:first-child + a + span:last-child) {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 12px !important;
}

#dl-downstr:has(> span:first-child + a + span:last-child) > span:first-child {
    grid-column: span 2;
}

#dl-downstr:has(> span:first-child + a + span:last-child) > a,
#dl-downstr:has(> span:first-child + a + span:last-child) > span:last-child {
    width: 100%;
}

#dl-downstr:has(>:only-child) {
    justify-content: center;
}

#dl-downstr:has(>:only-child) > a {
    width: 100%;
}

#dl-downstr > div > div {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 12px !important;
    width: 100% !important;
}

.dl-btn-ok,
.dl-btn-login {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 20px;
    border-radius: 12px;
    font-size: 13px;
    font-weight: 500;
    color: #fff;
    cursor: pointer;
    transition: all 0.25s ease;
    border: none;
    text-decoration: none;
    background: linear-gradient(135deg, #ff2d55, #e61e45);
    box-shadow: 0 8px 20px rgba(255, 45, 85, 0.25);
    width: 100%;
}

.dl-btn-ok:hover,
.dl-btn-login:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 26px rgba(255, 45, 85, 0.35);
    color: #fff;
    background: linear-gradient(135deg, #ff4d6f, #ff2d55);
}

.dl-btn-pay {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 20px;
    border-radius: 12px;
    font-size: 13px;
    font-weight: 500;
    color: #fff;
    cursor: pointer;
    transition: all 0.25s ease;
    border: none;
    text-decoration: none;
    background: linear-gradient(135deg, #ff9f2d, #e67e1e);
    box-shadow: 0 8px 20px rgba(255, 159, 45, 0.25);
    width: 100%;
}

.dl-btn-pay:hover {
    transform: translateY(-2px);
    color: #fff;
    box-shadow: 0 12px 26px rgba(255, 159, 45, 0.35);
    background: linear-gradient(135deg, #ffae4d, #ff8c2d);
}

.dl-btn-disk {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 20px;
    border-radius: 12px;
    font-size: 13px;
    font-weight: 500;
    color: #fff;
    cursor: pointer;
    transition: all 0.25s ease;
    border: none;
    text-decoration: none;
    background: linear-gradient(135deg, #00d26a, #00aa50);
    box-shadow: 0 8px 20px rgba(0, 210, 106, 0.25);
    width: 100%;
}

.dl-btn-disk:hover {
    background: linear-gradient(135deg, #00e07a, #00c060);
    transform: translateY(-2px);
    box-shadow: 0 12px 26px rgba(0, 210, 106, 0.35);
    color: #fff;
}

.dl-code-group {
    display: flex;
    gap: 10px;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    width: 100%;
}

.dl-code-input {
    padding: 13px 16px;
    border: 1px solid var(--dl-input-border);
    background: var(--dl-input-bg);
    color: var(--dl-input-text);
    width: 120px;
    text-align: center;
    font-size: 14px;
    outline: none;
    border-radius: 12px;
    transition: all 0.25s ease;
}

.dl-code-input:focus {
    border-color: #ff2d55;
    background: rgba(255, 45, 85, 0.06);
}

#dl-code-img {
    cursor: pointer;
    height: 44px;
    border-radius: 12px;
    border: 1px solid var(--dl-input-border);
}

#dl-code-submit {
    background: linear-gradient(135deg, #ff2d55, #e61e45);
    border-radius: 12px;
    padding: 13px 26px;
    color: #fff;
    font-weight: 600;
    cursor: pointer;
    box-shadow: 0 6px 16px rgba(255, 45, 85, 0.25);
    border: none;
}

.dl-loading {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #ff2d55;
    padding: 12px 24px;
    background: rgba(255, 45, 85, 0.08);
    border-radius: 12px;
    font-size: 13px;
}

.dl-loading::before {
    content: "";
    width: 16px;
    height: 16px;
    border: 2px solid #ff2d55;
    border-top-color: transparent;
    border-radius: 50%;
    animation: dl-spin 0.7s linear infinite;
}

@keyframes dl-spin {
    to {
        transform: rotate(360deg);
    }
}

.dl-notice {
    padding: 16px 20px 18px;
    background: var(--dl-notice-bg);
    font-size: 12px;
    line-height: 1.8;
    border-radius: 0 0 12px 12px;
    color: var(--dl-muted);
    border-top: 1px solid var(--dl-border);
}

.dl-notice a {
    color: var(--dl-link);
    text-decoration: none;
    font-weight: 500;
}

.dl-notice a:hover {
    text-decoration: underline;
}

.dl-notice font[color="#e6a700"] {
    color: #f5bc00 !important;
    font-weight: 600;
}

.dl-notice font[color="#ff2d55"] {
    color: #ff2d55 !important;
    font-weight: 600;
}

.dl-divider {
    margin-top: 18px;
    padding-top: 18px;
    border-top: 1px solid var(--dl-border);
}

/* ========== 首页 legacy 布局重构 ========== */
.dj-page--legacy-home {
    overflow-x: clip;
}

.dj-home-shell {
    width: min(1200px, 100%);
    margin: 0 auto;
    padding: 0 0.75rem 1.5rem;
}

.dj-page--legacy-home .poster-host {
    width: 100%;
    margin: 0 0 1rem;
    padding: 0;
}

.dj-page--legacy-home .dj-index-body {
    overflow: visible;
}

.dj-page--legacy-home .index_ct {
    padding: 0;
}

.dj-page--legacy-home .index_ct_p1 {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 300px);
    gap: 1.25rem;
    align-items: start;
}

.dj-page--legacy-home .index_ct_p1_left,
.dj-page--legacy-home .index_ct_p1_right,
.dj-page--legacy-home .recommended-ct,
.dj-page--legacy-home .recommended-list {
    float: none;
    width: auto;
    min-width: 0;
}

.dj-page--legacy-home .index_ct_p1_right_ct {
    width: 100%;
    padding: 0.85rem 1rem;
    background: var(--dj-surface);
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius-lg);
    box-shadow: var(--dj-shadow);
}

.dj-page--legacy-home .dj-index-sidebar-block {
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--dj-border);
}

.dj-page--legacy-home .dj-index-sidebar-block:first-child {
    padding-top: 0;
}

.dj-page--legacy-home .dj-index-sidebar-block:last-child {
    padding-bottom: 0;
    border-bottom: 0;
}

.dj-page--legacy-home .h10,
.dj-page--legacy-home .h15 {
    display: none !important;
    height: 0 !important;
    margin: 0 !important;
}

.dj-page--legacy-home .dj-index-block-head {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem 0.75rem;
    margin-bottom: 0.75rem;
}

.dj-page--legacy-home .dj-index-block-label {
    float: none;
    flex-shrink: 0;
}

.dj-page--legacy-home .index-typeicon,
.dj-page--legacy-home .dj-index-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 0.35rem;
    float: none;
    margin-left: auto;
}

.dj-page--legacy-home .index_ct_p1_right .lines {
    margin: 0.65rem 0;
}

.dj-page--legacy-home .index_ct_p2 {
    margin-top: 1rem;
}

.dj-page--legacy-home .dj-index-section,
.dj-page--legacy-home .recommended,
.dj-page--legacy-home .index-radio {
    background: var(--dj-surface);
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius-lg);
    padding: 1rem;
    margin-bottom: 1rem;
}

.dj-page--legacy-home .recommended-title,
.dj-page--legacy-home .index-radio-title,
.dj-page--legacy-home .index-hot-title,
.dj-page--legacy-home .index-rank-title,
.dj-page--legacy-home .index-producer-title {
    float: none;
    width: auto;
    height: auto;
    background: none;
    line-height: 1.3;
    margin-bottom: 0.75rem;
    color: var(--dj-text);
}

.dj-page--legacy-home .recommended-type,
.dj-page--legacy-home .index-radio-type,
.dj-page--legacy-home .index-rank-type {
    margin-bottom: 0.5rem;
}

.dj-page--legacy-home .recommended-type .dj-index-tabs,
.dj-page--legacy-home .index-radio-type .dj-index-tabs,
.dj-page--legacy-home .index-rank-type .dj-index-tabs {
    width: 100%;
}

.dj-page--legacy-home .recommended-title span,
.dj-page--legacy-home .index-radio-title span,
.dj-page--legacy-home .index-hot-title span,
.dj-page--legacy-home .index-rank-title span,
.dj-page--legacy-home .index-producer-title span {
    display: block;
    font-size: 1.05rem;
    font-weight: 600;
    margin-left: 0;
    line-height: 1.35;
    padding-left: 0.65rem;
    border-left: 3px solid var(--dj-primary);
}

.dj-page--legacy-home .recommended-title p,
.dj-page--legacy-home .index-radio-title p,
.dj-page--legacy-home .index-hot-title p,
.dj-page--legacy-home .index-rank-title p,
.dj-page--legacy-home .index-producer-title p {
    margin: 0.15rem 0 0;
    font-size: 11px;
    color: var(--dj-text-muted);
    margin-left: 0;
}

.dj-page--legacy-home .dj-index-tabs {
    gap: 0.35rem;
    margin-bottom: 0.75rem;
}

.dj-page--legacy-home .dj-index-tabs .nav-link {
    padding: 0.35rem 0.75rem;
    font-size: 13px;
    color: var(--dj-text-muted);
    background: var(--dj-surface-2);
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius);
}

.dj-page--legacy-home .dj-index-tabs .nav-link:hover {
    color: var(--dj-text);
    border-color: var(--dj-primary-muted);
}

.dj-page--legacy-home .dj-index-tabs .nav-link.is-active {
    background: var(--dj-primary);
    border-color: var(--dj-primary);
    color: #fff;
    font-weight: 600;
}

.dj-page--legacy-home .recommended-more .nav-link {
    background: transparent;
    border-color: transparent;
    color: var(--dj-primary-light, #a78bfa);
}

.dj-page--legacy-home .dj-index-recs-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    gap: 1rem;
    align-items: stretch;
}

.dj-page--legacy-home .dj-index-recs-divider {
    width: 1px;
    flex-shrink: 0;
    background: var(--dj-border);
    align-self: stretch;
    min-height: 120px;
}

.dj-page--legacy-home .recommended-ct {
    flex: 1;
    min-width: 0;
}

.dj-page--legacy-home .dj-index-block-label {
    float: none;
}

.dj-page--legacy-home .index-typeicon,
.dj-page--legacy-home .dj-index-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 0.35rem;
    float: none;
}

.dj-page--legacy-home .index-typeicon .playall,
.dj-page--legacy-home .index-typeicon .addall,
.dj-page--legacy-home .index-typeicon .changeall,
.dj-page--legacy-home .dj-index-toolbar .playall,
.dj-page--legacy-home .dj-index-toolbar .addall,
.dj-page--legacy-home .dj-index-toolbar .changeall,
.dj-page--legacy-home .index-radio-type .changeall,
.dj-page--legacy-home .index-hot .changeall,
.dj-page--legacy-home .dj-index-tab-action .changeall {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.65rem;
    font-size: 12px;
    line-height: 1.4;
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius);
    background: var(--dj-surface-2);
    color: var(--dj-text-muted);
    cursor: pointer;
    transition: background 0.15s, border-color 0.15s, color 0.15s;
}

.dj-page--legacy-home .index-typeicon .playall:hover,
.dj-page--legacy-home .index-typeicon .addall:hover,
.dj-page--legacy-home .index-typeicon .changeall:hover,
.dj-page--legacy-home .dj-index-toolbar .playall:hover,
.dj-page--legacy-home .dj-index-toolbar .addall:hover,
.dj-page--legacy-home .dj-index-toolbar .changeall:hover,
.dj-page--legacy-home .index-radio-type .changeall:hover,
.dj-page--legacy-home .index-hot .changeall:hover,
.dj-page--legacy-home .dj-index-tab-action .changeall:hover {
    background: var(--dj-primary);
    border-color: var(--dj-primary);
    color: #fff;
}

.dj-page--legacy-home .recommended-type a[data-cls="clstype"],
.dj-page--legacy-home .index-radio-type a[data-cls="ratype"],
.dj-page--legacy-home .index-rank-type a[data-cls="ranktype"],
.dj-page--legacy-home .index-radio-type a[data-cls="pcertype"] {
    transition: color 0.15s, background 0.15s, border-color 0.15s;
}

.dj-page--legacy-home .is-new {
    color: #94d500 !important;
}

.dj-page--legacy-home .recommended-list ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.dj-page--legacy-home .recommended-list ul li {
    margin: 0.65rem 0;
    width: 100%;
}

.dj-page--legacy-home .index-music-sm {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    min-height: 1.5rem;
    font-size: 13px;
}

.dj-page--legacy-home .index-music-sm span {
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.dj-page--legacy-home .index-music-bg {
    display: none;
    gap: 0.65rem;
    align-items: flex-start;
    min-height: 77px;
}

.dj-page--legacy-home .index-music-img {
    width: 77px;
    height: 77px;
    flex-shrink: 0;
    position: relative;
    overflow: hidden;
    border-radius: var(--dj-radius);
}

.dj-page--legacy-home .index-music-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.dj-page--legacy-home .index-music-img p {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    margin: 0;
    padding: 0.15rem 0.25rem;
    font-size: 11px;
    text-align: center;
    background: rgba(124, 58, 237, 0.85);
    color: #fff;
}

.dj-page--legacy-home .index-music-ct {
    flex: 1;
    min-width: 0;
}

.dj-page--legacy-home .index-music-title {
    margin: 0;
    font-size: 14px;
    font-weight: 600;
    line-height: 1.35;
    overflow: hidden;
    min-width: 0;
}

.dj-page--legacy-home .index-music-title a {
    color: var(--dj-text);
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 100%;
}

.dj-page--legacy-home .index-music-hit p {
    margin: 0.35rem 0 0;
    font-size: 12px;
    color: var(--dj-text-muted);
}

.dj-page--legacy-home .index-radio-list ul {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
    gap: 0.75rem;
    list-style: none;
    margin: 0;
    padding: 0;
}

.dj-page--legacy-home .index-radio-list ul li {
    float: none;
    margin: 0;
    width: auto;
    height: auto;
    position: relative;
}

.dj-page--legacy-home .index-radio-list .ra-img {
    border-radius: var(--dj-radius);
    overflow: hidden;
    aspect-ratio: 1;
    background: var(--dj-surface-2);
}

.dj-page--legacy-home .index-radio-list .ra-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.dj-page--legacy-home .index-radio-list li h2,
.dj-page--legacy-home .index-radio-list li p {
    font-size: 12px;
    line-height: 1.35;
    margin: 0.35rem 0 0;
    color: var(--dj-text-muted);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.dj-page--legacy-home .index-radio-list li h2 {
    color: var(--dj-text);
    font-size: 13px;
    font-weight: 600;
}

.dj-page--legacy-home .dj-index-slider img {
    width: 100%;
    max-width: 100%;
    height: auto;
    display: block;
    margin: 0 auto;
    border-radius: var(--dj-radius);
}

.dj-page--legacy-home .dj-index-hot-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.5rem;
}

.dj-page--legacy-home .index-hot-list ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.dj-page--legacy-home .index-hot-list li {
    padding: 0.35rem 0;
    border-bottom: 1px dashed var(--dj-border);
    font-size: 13px;
}

.dj-page--legacy-home .index-hot-list li:last-child {
    border-bottom: 0;
}

.dj-page--legacy-home .index-hot-list a {
    color: var(--dj-text-muted);
}

.dj-page--legacy-home .index-hot-list a:hover {
    color: var(--dj-primary-light, #a78bfa);
}

.dj-page--legacy-home .dj-index-rank-toolbar {
    display: flex;
    justify-content: center;
    margin-bottom: 0.5rem;
}

.dj-page--legacy-home .dj-index-rank-tabs {
    gap: 0.25rem;
}

.dj-page--legacy-home .dj-index-rank-tabs .nav-link {
    padding: 0.3rem 0.85rem;
    font-size: 12px;
    color: var(--dj-text-muted);
    background: var(--dj-surface-2);
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius);
    cursor: pointer;
}

.dj-page--legacy-home .dj-index-rank-tabs .nav-link.is-active {
    background: var(--dj-primary);
    border-color: var(--dj-primary);
    color: #fff;
}

.dj-page--legacy-home .rank-list dl {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin: 0;
    padding: 0.35rem 0;
    border-bottom: 1px dashed var(--dj-border);
}

.dj-page--legacy-home .rank-list dl:last-child {
    border-bottom: 0;
}

.dj-page--legacy-home .rank-list dt {
    flex-shrink: 0;
    width: 1.75rem;
    font-size: 12px;
    font-weight: 700;
    color: var(--dj-primary-light, #a78bfa);
}

.dj-page--legacy-home .rank-list dd {
    margin: 0;
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 13px;
}

.dj-page--legacy-home .rank-list dd a {
    color: var(--dj-text-muted);
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 100%;
}

.dj-page--legacy-home .rank-list dd a:hover {
    color: var(--dj-text);
}

.dj-page--legacy-home .index_ct_p2 .index-radio {
    margin-top: 0;
}

.dj-page--legacy-home .dj-index-producer-row {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    align-items: flex-start;
    margin-bottom: 0.5rem;
}

.dj-page--legacy-home .best-producer-a {
    display: block;
    flex: 0 0 220px;
    max-width: 100%;
    text-decoration: none;
    color: inherit;
    border-radius: var(--dj-radius-lg);
    overflow: hidden;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.dj-page--legacy-home .best-producer-a:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(124, 58, 237, 0.2);
    color: inherit;
}

.dj-page--legacy-home .best-producer {
    background: linear-gradient(160deg, var(--dj-surface-2) 0%, rgba(124, 58, 237, 0.12) 100%);
    border: 1px solid var(--dj-border);
    border-radius: var(--dj-radius-lg);
    padding: 1rem;
    text-align: center;
}

.dj-page--legacy-home .best-producer .bp-img {
    width: 100%;
    aspect-ratio: 1;
    border-radius: var(--dj-radius);
    overflow: hidden;
    background: var(--dj-surface);
}

.dj-page--legacy-home .best-producer .bp-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.dj-page--legacy-home .best-producer-name {
    margin: 0.75rem 0 0.35rem;
    font-weight: 600;
    color: var(--dj-text);
}

.dj-page--legacy-home .best-producer-meta {
    display: flex;
    justify-content: center;
    gap: 0.75rem;
    font-size: 12px;
    color: var(--dj-text-muted);
}

.dj-page--legacy-home .bp-hits,
.dj-page--legacy-home .bp-musicicon {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
}

.dj-page--legacy-home .bp-hits::before {
    content: "♫";
    color: var(--dj-primary-light, #a78bfa);
}

.dj-page--legacy-home .bp-musicicon::before {
    content: "★";
    color: var(--dj-primary-light, #a78bfa);
}

.dj-page--legacy-home .dj-index-producer-grid {
    flex: 1;
    min-width: min(100%, 520px);
}

.dj-page--legacy-home .index-radio-list[data-pcer="1"] ul li {
    cursor: pointer;
}

.dj-page--legacy-home .index-radio-list .hits-white {
    position: relative;
    z-index: 2;
    margin: -1.65rem 0 0;
    padding: 0.15rem 0.35rem;
    font-size: 11px;
    text-align: center;
    color: #fff;
    background: rgba(0, 0, 0, 0.55);
    border-radius: 0 0 var(--dj-radius) var(--dj-radius);
}

.dj-page--legacy-home .producer-detail-box {
    display: none;
    position: absolute;
    left: 50%;
    bottom: calc(100% + 0.5rem);
    transform: translateX(-50%);
    z-index: 30;
    width: min(300px, 92vw);
    padding: 0.75rem;
    border-radius: var(--dj-radius-lg);
    border: 1px solid var(--dj-primary);
    background: linear-gradient(145deg, var(--dj-surface) 0%, rgba(124, 58, 237, 0.18) 100%);
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.35);
    overflow: hidden;
}

.dj-page--legacy-home .producer-detail-box::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: -6px;
    width: 12px;
    height: 12px;
    margin-left: -6px;
    background: var(--dj-surface);
    border-right: 1px solid var(--dj-primary);
    border-bottom: 1px solid var(--dj-primary);
    transform: rotate(45deg);
}

.dj-page--legacy-home .producer-detail-avatar {
    float: left;
    width: 72px;
    height: 72px;
    margin-right: 0.65rem;
    border-radius: var(--dj-radius);
    overflow: hidden;
}

.dj-page--legacy-home .producer-detail-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.dj-page--legacy-home .producer-detail-box .ra-hover-detail {
    float: none;
    width: auto;
    height: auto;
    margin: 0;
    padding: 0;
    overflow: hidden;
}

.dj-page--legacy-home .producer-detail-box .ra-hover-detail h3 {
    margin: 0 0 0.2rem;
    font-size: 12px;
    font-weight: 500;
    line-height: 1.35;
    color: var(--dj-text-muted);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.dj-page--legacy-home .producer-detail-box .ra-hover-detail h3:first-child {
    font-size: 14px;
    font-weight: 600;
    color: var(--dj-text);
}

.dj-page--legacy-home .producer-detail-box .ra-hover-music {
    float: none;
    width: 100%;
    padding: 0.5rem 0 0;
    border-top: 1px dashed var(--dj-border);
    clear: both;
}

.dj-page--legacy-home .producer-detail-box .ra-hover-music h4 {
    margin: 0 0 0.25rem;
    font-size: 12px;
    font-weight: 400;
    line-height: 1.35;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.dj-page--legacy-home .producer-detail-box .ra-hover-music a {
    color: var(--dj-text-muted);
    text-decoration: none;
}

.dj-page--legacy-home .producer-detail-box .ra-hover-music a:hover {
    color: var(--dj-primary-light, #a78bfa);
}

.dj-page--legacy-home .best-producer-bg {
    display: none;
}

.dj-page--legacy-home .lines {
    border: 0;
    border-top: 1px solid var(--dj-border);
    margin: 0.75rem 0;
    opacity: 1;
    clear: both;
}

.dj-page--legacy-home .poster-host {
    width: 100%;
    margin: 0 0 1rem;
    padding: 0;
}

@media (min-width: 992px) {
    .dj-page--legacy-home .index_ct_p1_right_ct {
        position: sticky;
        top: calc(var(--dj-nav-h) + var(--dj-subnav-h) + 0.75rem);
    }
}

@media (max-width: 991.98px) {
    .dj-page--legacy-home .index_ct_p1 {
        grid-template-columns: 1fr;
    }

    .dj-page--legacy-home .index_ct_p1_right_ct {
        position: static;
    }

    .dj-page--legacy-home .dj-index-recs-row {
        grid-template-columns: 1fr;
    }

    .dj-page--legacy-home .dj-index-recs-divider {
        width: 100%;
        height: 1px;
        min-height: 0;
    }

    .dj-page--legacy-home .dj-index-block-head {
        flex-direction: column;
        align-items: stretch;
    }

    .dj-page--legacy-home .index-typeicon,
    .dj-page--legacy-home .dj-index-toolbar {
        justify-content: flex-start;
        margin-left: 0;
    }
}

/* ========== 支付结果页 ========== */
body.dj-pay-result {
    min-height: 100vh;
    padding: 2rem 0.75rem;
    background: var(--dj-bg) !important;
    color: var(--dj-text);
}

.dj-pay-result-page {
    max-width: 640px;
    margin: 0 auto;
}

.dj-pay-result-logo {
    max-height: 48px;
    width: auto;
}

.dj-pay-result-card {
    background: var(--dj-surface);
    border: 1px solid var(--dj-border) !important;
    border-radius: var(--dj-radius-lg);
    overflow: hidden;
}

.dj-pay-result-hd {
    background: linear-gradient(90deg, var(--dj-primary) 0%, rgba(124, 58, 237, 0.75) 100%);
    border-bottom: 0 !important;
    color: #fff;
}

.dj-pay-result .card.bg-body-tertiary {
    background: var(--dj-surface-2) !important;
    border: 1px solid var(--dj-border) !important;
}

.dj-pay-result-status .bi-check-circle-fill {
    color: #22c55e !important;
}

@media (max-width: 767.98px) {
    body.dj-down-popup {
        padding: 0;
    }

    body.dj-down-popup .dj-down-header {
        flex-direction: row;
        align-items: flex-start !important;
        gap: 0.5rem;
    }

    body.dj-down-popup .dj-down-meta-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .dj-page--legacy-home .index-radio-list ul {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

/* ---------- 会员 · 前台音乐上传 ---------- */
.dj-member-form-page.dj-music-upload {
    padding-bottom: 1.5rem;
}

.dj-member-form-page.dj-music-upload .dj-music-upload-hero.card {
    background: transparent;
    border: 1px solid var(--dj-border, #ddd6f3);
    box-shadow: none;
    overflow: hidden;
}

.dj-member-form-page.dj-music-upload .dj-music-upload-hero > .card-body {
    background: var(--dj-primary-soft, #ede9fe);
    color: var(--dj-text, #1a1625);
}

.dj-member-form-page.dj-music-upload .dj-music-upload-hero .text-muted {
    color: var(--dj-text-muted, #6b6578) !important;
}

.dj-member-form-page.dj-music-upload .dj-music-upload-hero h1,
.dj-member-form-page.dj-music-upload .dj-music-upload-hero h2 {
    color: var(--dj-primary, #7c3aed);
}

[data-bs-theme="dark"] .dj-member-form-page.dj-music-upload .dj-music-upload-hero > .card-body,
[data-theme="dark"] .dj-member-form-page.dj-music-upload .dj-music-upload-hero > .card-body {
    background: var(--dj-surface-2, #252131);
}

[data-bs-theme="dark"] .dj-member-form-page.dj-music-upload .dj-music-upload-hero h1,
[data-bs-theme="dark"] .dj-member-form-page.dj-music-upload .dj-music-upload-hero h2,
[data-theme="dark"] .dj-member-form-page.dj-music-upload .dj-music-upload-hero h1,
[data-theme="dark"] .dj-member-form-page.dj-music-upload .dj-music-upload-hero h2 {
    color: var(--dj-primary-muted, #a78bfa);
}

.dj-member-form-page.dj-music-upload .dj-music-upload-panel .card-body {
    padding: 1rem;
}

@media (min-width: 768px) {
    .dj-member-form-page.dj-music-upload .dj-music-upload-panel .card-body {
        padding: 1.25rem;
    }
}

.dj-member-form-page.dj-music-upload .dj-upload-block {
    margin-bottom: 1rem;
    padding: 1rem;
    border: 1px solid var(--dj-border, #ddd6f3);
    background: var(--dj-surface-2, #efedf5);
    border-radius: var(--dj-radius-lg, 12px);
}

.dj-member-form-page.dj-music-upload .dj-upload-block:last-child {
    margin-bottom: 0;
}

.dj-member-form-page.dj-music-upload .dj-upload-block-title {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.75rem;
}

.dj-member-form-page.dj-music-upload .dj-upload-block-title h4 {
    margin: 0;
    font-size: 0.95rem;
    font-weight: 600;
}

.dj-member-form-page.dj-music-upload .dj-upload-block-title em {
    font-style: normal;
    font-size: 12px;
    color: var(--dj-text-muted, #8b95a6);
}

.dj-member-form-page.dj-music-upload .dj-upload-row {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 0.5rem;
    margin-bottom: 0.75rem;
}

.dj-member-form-page.dj-music-upload .dj-upload-row:last-child {
    margin-bottom: 0;
}

.dj-member-form-page.dj-music-upload .dj-upload-row > label,
.dj-member-form-page.dj-music-upload .dj-upload-label {
    width: 88px;
    min-width: 88px;
    line-height: 32px;
    color: var(--dj-text-muted, #6b6578);
    font-weight: 600;
    font-size: 13px;
    margin: 0;
}

.dj-member-form-page.dj-music-upload .dj-upload-ops {
    flex: 1;
    min-width: 0;
}

.dj-member-form-page.dj-music-upload .dj-upload-ops > i {
    display: block;
    margin-top: 4px;
    color: var(--dj-text-muted, #99a3b1);
    font-style: normal;
    font-size: 12px;
}

.dj-member-form-page.dj-music-upload .dj-upload-ops .btn {
    margin: 0 0.5rem 0.5rem 0;
}

.dj-member-form-page.dj-music-upload #second_genre .second-genre-group {
    display: none;
}

.dj-member-form-page.dj-music-upload .dj-upload-qbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.65rem;
    padding: 0.875rem;
    background: var(--dj-surface, #fff);
    border: 1px dashed var(--dj-border, #ddd6f3);
    border-radius: var(--dj-radius-lg, 12px);
}

.dj-member-form-page.dj-music-upload .dj-upload-status,
.dj-member-form-page.dj-music-upload #upload-status {
    display: inline-flex;
    align-items: center;
    padding: 0.35rem 0.75rem;
    border-radius: 999px;
    background: var(--dj-surface-3, #e8e4f3);
    color: var(--dj-text-muted, #6b6578);
    font-size: 12px;
}

.dj-member-form-page.dj-music-upload .dj-upload-qbar .tip {
    font-size: 12px;
    color: var(--dj-text-muted, #96a0ae);
}

.dj-member-form-page.dj-music-upload .fileinput-button {
    position: relative;
    overflow: hidden;
}

.dj-member-form-page.dj-music-upload .fileinput-button input[type="file"] {
    position: absolute;
    inset: 0;
    opacity: 0;
    cursor: pointer;
    font-size: 200px;
}

.dj-member-form-page.dj-music-upload .dj-upload-table-wrap {
    margin-top: 0.75rem;
    border: 1px solid var(--dj-border, #ddd6f3);
    border-radius: var(--dj-radius-lg, 12px);
    overflow: hidden;
    background: var(--dj-surface, #fff);
}

.dj-member-form-page.dj-music-upload .files th {
    background: var(--dj-surface-2, #efedf5);
    color: var(--dj-text-muted, #6b6578);
    white-space: nowrap;
    font-size: 12px;
}

.dj-member-form-page.dj-music-upload .files td {
    color: var(--dj-text, #1a1625);
}

.dj-member-form-page.dj-music-upload .files td,
.dj-member-form-page.dj-music-upload .files th {
    vertical-align: middle !important;
}

.dj-member-form-page.dj-music-upload .status-text {
    display: inline-block;
    min-width: 84px;
    font-weight: 600;
    font-size: 12px;
}

.dj-member-form-page.dj-music-upload .empty {
    padding: 1.75rem 0.5rem !important;
    color: var(--dj-text-muted, #96a0ae);
}

.dj-member-form-page.dj-music-upload .au-choice-wrap {
    margin-top: 0.25rem;
}

.dj-member-form-page.dj-music-upload .au-choice-card {
    display: block;
    margin: 0;
    cursor: pointer;
    user-select: none;
}

.dj-member-form-page.dj-music-upload .au-choice-input {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
    pointer-events: none;
}

.dj-member-form-page.dj-music-upload .au-choice-card-inner {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 16px;
    border: 1px solid var(--dj-border, #ddd6f3);
    border-radius: var(--dj-radius-lg, 12px);
    background: var(--dj-surface, #fff);
    transition: border-color 0.2s, background 0.2s, box-shadow 0.2s;
}

.dj-member-form-page.dj-music-upload .au-choice-card:hover .au-choice-card-inner {
    border-color: var(--dj-primary-muted, #a78bfa);
    background: var(--dj-surface, #fff);
}

.dj-member-form-page.dj-music-upload .au-choice-switch {
    flex-shrink: 0;
    width: 46px;
    height: 26px;
    border-radius: 999px;
    background: var(--dj-border, #ddd6f3);
    position: relative;
    transition: background 0.22s ease;
}

.dj-member-form-page.dj-music-upload .au-choice-switch::after {
    content: "";
    position: absolute;
    top: 3px;
    left: 3px;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 2px 6px rgba(15, 35, 95, 0.18);
    transition: transform 0.22s ease;
}

.dj-member-form-page.dj-music-upload .au-choice-text {
    flex: 1;
    min-width: 0;
}

.dj-member-form-page.dj-music-upload .au-choice-text strong {
    display: block;
    font-size: 14px;
    font-weight: 600;
    color: var(--dj-text, #1a1625);
    margin-bottom: 3px;
    line-height: 1.35;
}

.dj-member-form-page.dj-music-upload .au-choice-text span {
    display: block;
    font-size: 12px;
    color: var(--dj-text-muted, #8b95a6);
    line-height: 1.5;
}

.dj-member-form-page.dj-music-upload .au-choice-badge {
    flex-shrink: 0;
    padding: 5px 12px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.04em;
    color: var(--dj-primary, #7c3aed);
    background: rgba(124, 58, 237, 0.1);
    border: 1px solid rgba(124, 58, 237, 0.18);
    transition: all 0.22s ease;
}

.dj-member-form-page.dj-music-upload .au-choice-input:checked + .au-choice-card-inner {
    border-color: var(--dj-primary, #7c3aed);
    background: var(--dj-primary-soft, #ede9fe);
    box-shadow: 0 4px 14px rgba(124, 58, 237, 0.1);
}

.dj-member-form-page.dj-music-upload .au-choice-input:checked + .au-choice-card-inner .au-choice-switch {
    background: var(--dj-primary, #7c3aed);
}

.dj-member-form-page.dj-music-upload .au-choice-input:checked + .au-choice-card-inner .au-choice-switch::after {
    transform: translateX(20px);
}

.dj-member-form-page.dj-music-upload .au-choice-input:checked + .au-choice-card-inner .au-choice-text strong {
    color: var(--dj-primary-active, #5b21b6);
}

.dj-member-form-page.dj-music-upload .au-choice-input:checked + .au-choice-card-inner .au-choice-badge {
    color: #fff;
    background: var(--dj-primary, #7c3aed);
    border-color: transparent;
    box-shadow: 0 2px 8px rgba(124, 58, 237, 0.28);
}

.dj-member-form-page.dj-music-upload .au-choice-inline {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin: 0;
    padding: 8px 12px;
    border-radius: 999px;
    border: 1px solid var(--dj-border, #e3eaf4);
    background: var(--dj-surface-muted, #f8fbff);
    cursor: pointer;
    user-select: none;
    transition: all 0.2s ease;
}

.dj-member-form-page.dj-music-upload .au-choice-inline:hover {
    border-color: #c5d4ea;
    background: #fff;
}

.dj-member-form-page.dj-music-upload .au-choice-switch--sm {
    width: 38px;
    height: 22px;
}

.dj-member-form-page.dj-music-upload .au-choice-switch--sm::after {
    width: 16px;
    height: 16px;
}

.dj-member-form-page.dj-music-upload .au-choice-input:checked ~ .au-choice-switch--sm {
    background: var(--dj-primary, #7c3aed);
}

.dj-member-form-page.dj-music-upload .au-choice-input:checked ~ .au-choice-switch--sm::after {
    transform: translateX(16px);
}

.dj-member-form-page.dj-music-upload .au-choice-inline-text {
    font-size: 13px;
    color: var(--dj-text, #1a1625);
    font-weight: 500;
    line-height: 1;
}

.dj-member-form-page.dj-music-upload .au-choice-input:checked ~ .au-choice-inline-text {
    color: var(--dj-primary-active, #5b21b6);
    font-weight: 600;
}

.dj-member-form-page.dj-music-upload .au-choice-inline:has(.au-choice-input:checked) {
    border-color: var(--dj-primary, #7c3aed);
    background: var(--dj-primary-soft, #ede9fe);
    box-shadow: 0 2px 10px rgba(124, 58, 237, 0.1);
}

@media (max-width: 767.98px) {
    .dj-member-form-page.dj-music-upload .dj-upload-row {
        flex-direction: column;
        align-items: stretch;
    }

    .dj-member-form-page.dj-music-upload .dj-upload-row > label,
    .dj-member-form-page.dj-music-upload .dj-upload-label {
        width: 100%;
        min-width: 0;
        line-height: 1.4;
    }

    .dj-member-form-page.dj-music-upload .dj-upload-qbar .tip {
        width: 100%;
    }

    .dj-member-form-page.dj-music-upload .files .dj-col-size,
    .dj-member-form-page.dj-music-upload .files .dj-col-bpm {
        display: none;
    }
}
