/*!
 * WorkRelease 统一样式文件 - CG作品展示系统
 * 专为CG作品展示和发布设计，与zibll主题完美兼容
 * Version: 1.0.0
 */

/* ================================
   CSS 变量定义 - 与子比主题兼容
   ================================ */
   :root {
    /* 主要配色 - 基于子比主题 */
    --wr-primary-color: #1f1f1f;
    --wr-secondary-color: #667eea;
    --wr-accent-color: #764ba2;
    
    /* 渐变色彩 */
    --wr-primary-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    --wr-secondary-gradient: linear-gradient(135deg, #f093fb 0%, #2e2e2e 100%);
    --wr-glass-gradient: linear-gradient(135deg, rgba(255,255,255,0.1) 0%, rgba(255,255,255,0.05) 100%);
    
    /* 阴影效果 */
    --wr-shadow-light: 0 2px 12px rgba(0, 0, 0, 0.08);
    --wr-shadow-medium: 0 6px 24px rgba(0, 0, 0, 0.12);
    --wr-shadow-heavy: 0 12px 48px rgba(0, 0, 0, 0.18);
    --wr-shadow-glow: 0 0 20px rgba(102, 126, 234, 0.2);
    
    /* 布局间距 */
    --wr-spacing-xs: 4px;
    --wr-spacing-sm: 8px;
    --wr-spacing-md: 16px;
    --wr-spacing-lg: 24px;
    --wr-spacing-xl: 32px;
    --wr-spacing-xxl: 48px;
    
    /* 圆角 */
    --wr-radius-sm: 6px;
    --wr-radius-md: 12px;
    --wr-radius-lg: 16px;
    --wr-radius-xl: 20px;
    --wr-radius-full: 50%;
    
    /* 过渡动画 */
    --wr-transition-fast: 0.2s ease;
    --wr-transition-normal: 0.3s ease;
    --wr-transition-slow: 0.5s ease;
    --wr-transition-bounce: 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    
    /* 字体权重 */
    --wr-weight-normal: 400;
    --wr-weight-medium: 500;
    --wr-weight-semibold: 600;
    --wr-weight-bold: 700;
    
    /* 字体大小 */
    --wr-text-xs: 12px;
    --wr-text-sm: 14px;
    --wr-text-base: 16px;
    --wr-text-lg: 18px;
    --wr-text-xl: 20px;
    --wr-text-2xl: 24px;
    --wr-text-3xl: 32px;
}

/* ================================
   动画效果定义
   ================================ */
@keyframes wr-fadeInUp {
    from {
        opacity: 0;
        transform: translate3d(0, 30px, 0);
    }
    to {
        opacity: 1;
        transform: translate3d(0, 0, 0);
    }
}

@keyframes wr-fadeInLeft {
    from {
        opacity: 0;
        transform: translate3d(-30px, 0, 0);
    }
    to {
        opacity: 1;
        transform: translate3d(0, 0, 0);
    }
}

@keyframes wr-pulse {
    0% { transform: scale(1); }
    50% { transform: scale(1.05); }
    100% { transform: scale(1); }
}

@keyframes wr-shine {
    0% { transform: translateX(-100%); }
    100% { transform: translateX(100%); }
}

@keyframes wr-gradientFlow {
    0% { background-position: 0% 50%; }
    50% { background-position: 100% 50%; }
    100% { background-position: 0% 50%; }
}

@keyframes wr-float {
    0%, 100% { transform: translateY(0px); }
    50% { transform: translateY(-10px); }
}

/* ================================
   全局样式重置和优化
   ================================ */
.workrelease-container {
    position: relative;
    z-index: 1;
}

.workrelease-container * {
    box-sizing: border-box;
}

.workrelease-container img {
    max-width: 100%;
    height: auto;
    border-radius: var(--wr-radius-sm);
}

/* ================================
   CG作品展示核心样式
   ================================ */

/* 作品画廊头部 */
.wr-gallery-header {
    background: var(--wr-primary-gradient);
    color: white;
    border-radius: var(--wr-radius-xl);
    padding: var(--wr-spacing-xxl);
    margin-bottom: var(--wr-spacing-xl);
    box-shadow: var(--wr-shadow-medium);
    position: relative;
    overflow: hidden;
    animation: wr-fadeInUp 0.8s ease-out;
}

.wr-gallery-header::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -50%;
    width: 200%;
    height: 200%;
    background: radial-gradient(circle, rgba(255,255,255,0.1) 0%, rgba(255,255,255,0) 70%);
    transform: rotate(30deg);
    animation: wr-float 6s ease-in-out infinite;
}

/* 头部顶部布局 */
.wr-header-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--wr-spacing-lg);
    position: relative;
    z-index: 2;
}

.wr-title-wrapper {
    flex: 1;
}

.wr-header-actions {
    flex-shrink: 0;
    margin-left: var(--wr-spacing-lg);
}

/* 发布作品按钮样式 */
.wr-publish-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--wr-spacing-sm);
    padding: 12px 24px;
    background: rgba(255, 255, 255, 0.15);
    color: white;
    text-decoration: none;
    border-radius: var(--wr-radius-lg);
    font-weight: var(--wr-weight-semibold);
    font-size: var(--wr-text-base);
    transition: all 0.3s ease;
    border: 1px solid rgba(255, 255, 255, 0.2);
    backdrop-filter: blur(10px);
    position: relative;
    z-index: 2;
}

.wr-publish-btn:hover {
    background: rgba(255, 255, 255, 0.25);
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.2);
    color: white;
    text-decoration: none;
    border-color: rgba(255, 255, 255, 0.3);
}

.wr-publish-btn:active {
    transform: translateY(-1px);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
}

.wr-publish-btn i {
    font-size: 1.1rem;
}

.wr-gallery-title {
    margin: 0 0 var(--wr-spacing-md) 0;
    font-size: var(--wr-text-3xl);
    font-weight: var(--wr-weight-bold);
    color: white;
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    gap: var(--wr-spacing-md);
}

.wr-gallery-subtitle {
    margin: 0;
    font-size: var(--wr-text-lg);
    opacity: 0.9;
    color: white;
    position: relative;
    z-index: 1;
    line-height: 1.6;
}

/* 作品网格布局 */
.wr-works-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: var(--wr-spacing-xl);
    margin-bottom: var(--wr-spacing-xxl);
    padding: 0 var(--wr-spacing-md);
}

.wr-works-grid.wr-grid-large {
    grid-template-columns: repeat(auto-fill, minmax(400px, 1fr));
}

.wr-works-grid.wr-grid-small {
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}

/* 作品卡片样式 */
.wr-work-card {
    background: var(--main-bg-color, #ffffff);
    border-radius: var(--wr-radius-lg);
    overflow: hidden;
    box-shadow: var(--wr-shadow-light);
    border: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.08));
    transition: all var(--wr-transition-bounce);
    position: relative;
    height: 100%;
    display: flex;
    flex-direction: column;
    animation: wr-fadeInUp 0.6s ease-out;
    backface-visibility: hidden;
    transform: translateZ(0);
}

.wr-work-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 4px;
    background: var(--wr-primary-gradient);
    opacity: 0;
    transition: opacity var(--wr-transition-normal);
}

.wr-work-card:hover::before {
    opacity: 1;
}

.wr-work-card:hover {
    transform: translateY(-8px);
    box-shadow: var(--wr-shadow-heavy);
    border-color: var(--wr-primary-color);
}

/* 作品缩略图 */
.wr-work-thumbnail {
    position: relative;
    width: 100%;
    padding-top: 60%; /* 16:10 宽高比，适合CG作品展示 */
    overflow: hidden;
    background: var(--muted-bg-color, #f8f9fa);
}

.wr-work-thumbnail img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--wr-transition-slow);
}

.wr-work-card:hover .wr-work-thumbnail img {
    transform: scale(1.05);
}

/* 作品悬停遮罩 */
.wr-work-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, rgba(31, 31, 31, 0.9), rgba(102, 126, 234, 0.9));
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transition: all var(--wr-transition-bounce);
    backdrop-filter: blur(4px);
    z-index: 10;
}

.wr-work-card:hover .wr-work-overlay {
    opacity: 1;
    visibility: visible;
}

.wr-work-actions {
    display: flex;
    gap: var(--wr-spacing-lg);
    transform: translateY(20px);
    transition: transform var(--wr-transition-bounce);
}

.wr-work-card:hover .wr-work-actions {
    transform: translateY(0);
}

.wr-action-btn {
    width: 50px;
    height: 50px;
    border-radius: var(--wr-radius-full);
    background: rgba(255, 255, 255, 0.95);
    border: 2px solid rgba(255, 255, 255, 0.4);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--wr-primary-color);
    font-size: var(--wr-text-lg);
    cursor: pointer;
    transition: all var(--wr-transition-bounce);
    text-decoration: none;
    box-shadow: var(--wr-shadow-medium);
    position: relative;
    overflow: hidden;
}

.wr-action-btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.4), transparent);
    transition: all 0.6s ease;
}

.wr-action-btn:hover::before {
    left: 100%;
}

.wr-action-btn:hover {
    background: white;
    color: var(--wr-primary-color);
    transform: scale(1.15) translateY(-2px);
    box-shadow: var(--wr-shadow-heavy);
}

.wr-action-btn.wr-liked {
    background: var(--wr-primary-color);
    color: white;
}

/* 无缩略图状态 */
.wr-no-thumbnail {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--muted-bg-color, #f8f9fa), var(--muted-bg-color, #e9ecef));
    color: var(--muted-color, #6c757d);
    text-align: center;
}

.wr-no-thumbnail i {
    font-size: 48px;
    margin-bottom: var(--wr-spacing-md);
    color: var(--muted-2-color, #adb5bd);
    transition: all var(--wr-transition-normal);
}

.wr-no-thumbnail span {
    font-size: var(--wr-text-sm);
    font-weight: var(--wr-weight-medium);
}

.wr-work-card:hover .wr-no-thumbnail {
    background: linear-gradient(135deg, rgba(240, 68, 148, 0.1), rgba(102, 126, 234, 0.1));
}

.wr-work-card:hover .wr-no-thumbnail i {
    color: var(--wr-primary-color);
    transform: scale(1.1);
}

/* 作品信息区域 */
.wr-work-info {
    padding: var(--wr-spacing-lg);
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--wr-spacing-md);
}

.wr-work-title {
    margin: 0;
    font-size: var(--wr-text-lg);
    font-weight: var(--wr-weight-bold);
    color: var(--key-color, #333);
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    min-height: 2.8em;
}

.wr-work-title a {
    color: inherit;
    text-decoration: none;
    transition: all var(--wr-transition-normal);
    display: block;
    padding: 2px 0;
}

.wr-work-title a:hover {
    color: var(--wr-primary-color);
    transform: translateY(-1px);
}

/* 作品元信息 */
.wr-work-meta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--wr-spacing-sm);
    font-size: var(--wr-text-xs);
    color: var(--muted-color, #6c757d);
}

.wr-meta-item {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 4px var(--wr-spacing-sm);
    background: rgba(240, 68, 148, 0.08);
    border-radius: 12px;
    transition: all var(--wr-transition-normal);
    border: 1px solid rgba(240, 68, 148, 0.05);
}

.wr-meta-item:hover {
    background: rgba(240, 68, 148, 0.15);
    transform: translateY(-1px);
}

.wr-meta-item i {
    color: var(--wr-primary-color);
    font-size: 11px;
    width: 12px;
    text-align: center;
}

.wr-meta-item span {
    font-weight: var(--wr-weight-medium);
    color: var(--muted-color, #6c757d);
}

/* 作品统计信息 */
.wr-work-stats {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: auto;
    padding-top: var(--wr-spacing-md);
    border-top: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.06));
}

.wr-stat-item {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px var(--wr-spacing-md);
    background: var(--muted-bg-color, #f8f9fa);
    border-radius: 20px;
    font-size: var(--wr-text-xs);
    font-weight: var(--wr-weight-semibold);
    color: var(--muted-color, #6c757d);
    transition: all var(--wr-transition-bounce);
    border: 1px solid transparent;
}

.wr-stat-item:hover {
    background: var(--wr-primary-color);
    color: white;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(240, 68, 148, 0.3);
}

.wr-stat-item i {
    color: var(--wr-primary-color);
    font-size: var(--wr-text-sm);
    transition: color var(--wr-transition-normal);
}

.wr-stat-item:hover i {
    color: white;
}

/* ================================
   学员信息卡片样式
   ================================ */

/* 学员卡片网格 */
.wr-students-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: var(--wr-spacing-xl);
    margin-bottom: var(--wr-spacing-xxl);
    padding: 0 var(--wr-spacing-md);
}

/* 学员卡片 */
.wr-student-card {
    background: var(--main-bg-color, #ffffff);
    border-radius: var(--wr-radius-lg);
    overflow: hidden;
    box-shadow: var(--wr-shadow-light);
    border: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.08));
    transition: all var(--wr-transition-bounce);
    position: relative;
    height: 100%;
    display: flex;
    flex-direction: column;
    animation: wr-fadeInUp 0.6s ease-out;
}

.wr-student-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 4px;
    background: var(--wr-primary-gradient);
    opacity: 0;
    transition: opacity var(--wr-transition-normal);
}

.wr-student-card:hover::before {
    opacity: 1;
}

.wr-student-card:hover {
    transform: translateY(-8px);
    box-shadow: var(--wr-shadow-heavy);
}

/* 学员头像区域 */
.wr-student-header {
    padding: var(--wr-spacing-lg);
    text-align: center;
    background: rgba(255, 255, 255, 0.03);
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}

.wr-student-avatar {
    width: 80px;
    height: 80px;
    border-radius: var(--wr-radius-full);
    margin: 0 auto var(--wr-spacing-md);
    overflow: hidden;
    box-shadow: var(--wr-shadow-medium);
    position: relative;
}

.wr-student-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--wr-transition-normal);
}

.wr-student-card:hover .wr-student-avatar img {
    transform: scale(1.1);
}

.wr-student-name {
    margin: 0 0 var(--wr-spacing-sm) 0;
    font-size: var(--wr-text-xl);
    font-weight: var(--wr-weight-bold);
    color: var(--key-color, #333);
    position: relative;
    display: inline-block;
}

.wr-student-name::after {
    content: '';
    position: absolute;
    bottom: -4px;
    left: 50%;
    transform: translateX(-50%);
    width: 30px;
    height: 2px;
    background: var(--wr-primary-gradient);
    border-radius: 2px;
    opacity: 0;
    transition: all var(--wr-transition-normal);
}

.wr-student-card:hover .wr-student-name::after {
    opacity: 1;
    width: 50px;
}

/* 学员统计信息 */
.wr-student-stats {
    display: flex;
    justify-content: center;
    gap: var(--wr-spacing-md);
    margin-top: var(--wr-spacing-sm);
}

.wr-student-stat {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: var(--wr-text-xs);
    font-weight: var(--wr-weight-medium);
    color: var(--muted-color, #6c757d);
    padding: 4px var(--wr-spacing-sm);
    background: rgba(102, 126, 234, 0.08);
    border-radius: 12px;
    transition: all var(--wr-transition-normal);
}

.wr-student-card:hover .wr-student-stat {
    background: rgba(102, 126, 234, 0.15);
    color: var(--wr-primary-color);
}

/* 学员封面作品 */
.wr-student-cover {
    position: relative;
    width: 100%;
    padding-top: 60%;
    overflow: hidden;
}

.wr-cover-image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.wr-cover-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--wr-transition-slow);
}

.wr-student-card:hover .wr-cover-image img {
    transform: scale(1.05);
}

.wr-cover-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0) 50%);
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: var(--wr-spacing-lg);
    opacity: 1;
    transition: opacity var(--wr-transition-normal);
}

.wr-cover-title {
    font-size: var(--wr-text-base);
    font-weight: var(--wr-weight-bold);
    color: white;
    margin: 0 0 var(--wr-spacing-sm) 0;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.wr-cover-stats {
    display: flex;
    gap: var(--wr-spacing-sm);
}

.wr-cover-likes {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px var(--wr-spacing-sm);
    background: rgba(255, 255, 255, 0.15);
    border-radius: 12px;
    color: white;
    font-size: var(--wr-text-xs);
    font-weight: var(--wr-weight-semibold);
    backdrop-filter: blur(5px);
}

.wr-cover-likes i {
    color: var(--wr-primary-color);
}

/* 学员信息区域 */
.wr-student-info {
    padding: var(--wr-spacing-lg);
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--wr-spacing-md);
}

/* 学员统计信息 */
.wr-student-stats {
    display: flex;
    justify-content: space-around;
    padding: var(--wr-spacing-md) 0;
    margin-bottom: var(--wr-spacing-md);
    background: linear-gradient(135deg, rgba(52, 152, 219, 0.1) 0%, rgba(155, 89, 182, 0.1) 100%);
    border-radius: var(--wr-radius-md);
    border: 1px solid rgba(52, 152, 219, 0.15);
}

/* 内联筛选器样式 - 用于学员作品页面 */
.inline-filters {
    display: flex;
    align-items: center;
    gap: var(--wr-spacing-md);
    margin-left: var(--wr-spacing-lg);
    padding-left: var(--wr-spacing-lg);
    border-left: 2px solid var(--wr-border-light);
}

.inline-filters .wr-filter-group {
    display: flex;
    align-items: center;
    gap: var(--wr-spacing-xs);
    margin: 0;
}

.inline-filters .wr-filter-group label {
    font-size: var(--wr-text-sm);
    font-weight: var(--wr-weight-medium);
    color: var(--wr-text-muted);
    margin: 0;
    white-space: nowrap;
}

.inline-filters .wr-filter-select {
    min-width: 120px;
    padding: 6px 12px;
    font-size: var(--wr-text-sm);
    border: 1px solid var(--wr-border-light);
    border-radius: var(--wr-radius-sm);
    background: white;
    color: var(--wr-text-dark);
    transition: all 0.3s ease;
    cursor: pointer;
}

.inline-filters .wr-filter-select:hover {
    border-color: var(--wr-primary-color);
    box-shadow: 0 2px 4px rgba(52, 152, 219, 0.1);
}

.inline-filters .wr-filter-select:focus {
    outline: none;
    border-color: var(--wr-primary-color);
    box-shadow: 0 0 0 3px rgba(52, 152, 219, 0.1);
}

/* 响应式设计 - 内联筛选器 */
@media (max-width: 768px) {
    .inline-filters {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--wr-spacing-sm);
        margin-left: 0;
        padding-left: 0;
        border-left: none;
        padding-top: var(--wr-spacing-md);
        border-top: 1px solid var(--wr-border-light);
    }
    
    .inline-filters .wr-filter-group {
        width: 100%;
        justify-content: space-between;
    }
    
    .inline-filters .wr-filter-select {
        min-width: 140px;
        flex: 1;
        max-width: 200px;
    }
}

/* 画廊操作区域样式 */
.gallery-actions {
    display: flex;
    align-items: center;
    gap: var(--wr-spacing-md);
}

.gallery-actions .wr-publish-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--wr-spacing-xs);
    padding: 8px 16px;
    background: linear-gradient(135deg, #28a745 0%, #20c997 100%);
    color: white;
    text-decoration: none;
    border-radius: var(--wr-radius-md);
    font-weight: var(--wr-weight-semibold);
    font-size: var(--wr-text-sm);
    transition: all 0.3s ease;
    box-shadow: 0 2px 4px rgba(40, 167, 69, 0.2);
    border: none;
    cursor: pointer;
}

.gallery-actions .wr-publish-btn:hover {
    background: linear-gradient(135deg, #218838 0%, #1e7e34 100%);
    transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(40, 167, 69, 0.3);
    color: white;
    text-decoration: none;
}

.gallery-actions .wr-publish-btn:active {
    transform: translateY(0);
    box-shadow: 0 2px 4px rgba(40, 167, 69, 0.2);
}

.gallery-actions .wr-publish-btn i {
    font-size: 1rem;
}

/* 响应式设计 - 画廊操作区域 */
@media (max-width: 768px) {
    .gallery-actions {
        flex-direction: column;
        align-items: stretch;
        gap: var(--wr-spacing-sm);
    }
    
    .gallery-actions .wr-publish-btn {
        justify-content: center;
        margin-bottom: var(--wr-spacing-sm);
    }
    
    .gallery-actions .gallery-layout-controls {
        justify-content: center;
    }
}

/* 画廊头部控制区域 - 单行布局 */
.gallery-header-controls {
    display: flex;
    align-items: center;
    gap: var(--wr-spacing-sm);
    padding: var(--wr-spacing-xs) 0;
    margin-bottom: var(--wr-spacing-sm);
    border-bottom: 1px solid var(--wr-border-light);
    flex-wrap: wrap;
}

/* 标题样式 */
.gallery-header-controls .section-title {
    margin: 0;
    font-size: var(--wr-text-xl);
    font-weight: var(--wr-weight-bold);
    color: var(--wr-text-dark);
    display: flex;
    align-items: center;
    gap: var(--wr-spacing-sm);
    white-space: nowrap;
}

.gallery-header-controls .section-title i {
    color: var(--wr-primary-color);
    font-size: 1.2em;
}

/* 筛选器组样式 */
.gallery-header-controls .wr-filter-group {
    display: flex;
    align-items: center;
    margin: 0;
}

.gallery-header-controls .wr-filter-select {
    min-width: 120px;
    padding: 8px 12px;
    font-size: var(--wr-text-sm);
    border: 1px solid var(--wr-border-light);
    border-radius: var(--wr-radius-sm);
    background: white;
    color: var(--wr-text-dark);
    transition: all 0.3s ease;
    cursor: pointer;
}

.gallery-header-controls .wr-filter-select:hover {
    border-color: var(--wr-primary-color);
    box-shadow: 0 2px 4px rgba(52, 152, 219, 0.1);
}

.gallery-header-controls .wr-filter-select:focus {
    outline: none;
    border-color: var(--wr-primary-color);
    box-shadow: 0 0 0 3px rgba(52, 152, 219, 0.1);
}

/* 作品数量标签 */
.gallery-header-controls .works-count-badge {
    display: inline-flex;
    align-items: center;
    padding: 6px 12px;
    color: var(--wr-text-muted);
    font-size: var(--wr-text-sm);
    font-weight: var(--wr-weight-medium);
    white-space: nowrap;
    background: rgba(108, 117, 125, 0.1);
    border-radius: var(--wr-radius-sm);
}

/* 发布按钮样式 */
.gallery-header-controls .wr-publish-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--wr-spacing-xs);
    padding: 8px 16px;
    background: linear-gradient(135deg, #28a745 0%, #20c997 100%);
    color: white;
    text-decoration: none;
    border-radius: var(--wr-radius-md);
    font-weight: var(--wr-weight-semibold);
    font-size: var(--wr-text-sm);
    transition: all 0.3s ease;
    box-shadow: 0 2px 4px rgba(40, 167, 69, 0.2);
    border: none;
    cursor: pointer;
    white-space: nowrap;
}

.gallery-header-controls .wr-publish-btn:hover {
    background: linear-gradient(135deg, #218838 0%, #1e7e34 100%);
    transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(40, 167, 69, 0.3);
    color: white;
    text-decoration: none;
}

.gallery-header-controls .wr-publish-btn:active {
    transform: translateY(0);
    box-shadow: 0 2px 4px rgba(40, 167, 69, 0.2);
}

.gallery-header-controls .wr-publish-btn i {
    font-size: 1rem;
}

/* 响应式设计 */
@media (max-width: 1200px) {
    .gallery-header-controls {
        gap: var(--wr-spacing-xs);
    }
    
    .gallery-header-controls .wr-filter-select {
        min-width: 100px;
    }
}

@media (max-width: 768px) {
    .gallery-header-controls {
        flex-direction: column;
        align-items: stretch;
        gap: var(--wr-spacing-xs);
        padding: 4px 0;
    }
    
    .gallery-header-controls .section-title {
        justify-content: center;
        font-size: var(--wr-text-lg);
    }
    
    .gallery-header-controls .wr-filter-group {
        justify-content: center;
    }
    
    .gallery-header-controls .wr-filter-select {
        min-width: auto;
        flex: 1;
        max-width: 200px;
    }
    
    .gallery-header-controls .works-count-badge {
        text-align: center;
        justify-content: center;
    }
    
    .gallery-header-controls .wr-publish-btn {
        justify-content: center;
    }
    
    .gallery-header-controls .gallery-layout-controls {
        justify-content: center;
        margin-left: 0;
    }
}

.wr-stat-item {
    text-align: center;
    padding: var(--wr-spacing-sm);
    min-width: 60px;
}

.wr-stat-number {
    display: block;
    font-size: var(--wr-text-xl);
    font-weight: var(--wr-weight-bold);
    color: var(--wr-primary-color);
    line-height: 1.2;
    margin-bottom: 2px;
}

.wr-stat-label {
    display: block;
    font-size: var(--wr-text-xs);
    color: var(--wr-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    font-weight: var(--wr-weight-medium);
}

/* 最新作品预览 */
.wr-latest-works {
    margin: var(--wr-spacing-md) 0;
    position: relative;
    padding: 0 var(--wr-spacing-md);
}

.wr-latest-works-title {
    font-size: var(--wr-text-sm);
    font-weight: var(--wr-weight-bold);
    color: var(--key-color, #333);
    margin-bottom: var(--wr-spacing-md);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.wr-preview-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--wr-spacing-sm);
}

.wr-preview-item {
    position: relative;
    width: 100%;
    padding-top: 100%;
    overflow: hidden;
    border-radius: var(--wr-radius-sm);
    box-shadow: var(--wr-shadow-light);
    transition: transform var(--wr-transition-normal);
    cursor: pointer;
}

.wr-preview-item:hover {
    transform: translateY(-2px);
}

.wr-preview-item img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* 查看全部作品按钮 */
.wr-view-all-btn {
    display: inline-block;
    padding: var(--wr-spacing-md) var(--wr-spacing-xl);
    background: var(--wr-primary-gradient);
    color: white;
    text-align: center;
    border-radius: 25px;
    text-decoration: none;
    font-weight: var(--wr-weight-semibold);
    font-size: var(--wr-text-sm);
    transition: all var(--wr-transition-bounce);
    border: 2px solid transparent;
    position: relative;
    overflow: hidden;
    box-shadow: 0 4px 15px rgba(102, 126, 234, 0.3);
}

.wr-view-all-btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);
    transition: all 0.6s ease;
}

.wr-view-all-btn:hover::before {
    left: 100%;
}

.wr-view-all-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(102, 126, 234, 0.4);
    background: var(--wr-secondary-gradient);
}

/* ================================
   图片画廊组件
   ================================ */

/* 画廊容器 */
.wr-gallery-container {
    background: var(--main-bg-color, #ffffff);
    border-radius: var(--wr-radius-md);
    overflow: hidden;
    box-shadow: var(--wr-shadow-medium);
    width: 100%;
    margin: var(--wr-spacing-xl) 0;
}

.wr-gallery-main {
    position: relative;
    background: #000;
    width: 100%;
}

.wr-gallery-viewer {
    position: relative;
    width: 100%;
    height: 500px;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}

.wr-gallery-image-container {
    position: relative;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}

.wr-gallery-main-image {
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: auto;
    object-fit: contain;
    transition: transform var(--wr-transition-normal);
    display: block;
    margin: 0 auto;
}

/* 画廊控制按钮 */
.wr-gallery-btn {
    background: rgba(255, 255, 255, 0.9);
    border: none;
    border-radius: var(--wr-radius-full);
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all var(--wr-transition-normal);
    color: var(--wr-primary-color);
    font-size: var(--wr-text-base);
    box-shadow: var(--wr-shadow-light);
}

.wr-gallery-btn:hover {
    background: white;
    transform: scale(1.1);
    color: var(--wr-primary-color);
    box-shadow: var(--wr-shadow-medium);
}

.wr-gallery-prev,
.wr-gallery-next {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
}

.wr-gallery-prev {
    left: var(--wr-spacing-lg);
}

.wr-gallery-next {
    right: var(--wr-spacing-lg);
}

.wr-gallery-fullscreen,
.wr-gallery-play {
    position: absolute;
    top: var(--wr-spacing-lg);
    z-index: 10;
}

.wr-gallery-fullscreen {
    right: var(--wr-spacing-lg);
}

.wr-gallery-play {
    left: var(--wr-spacing-lg);
}

/* 画廊计数器 */
.wr-gallery-counter {
    position: absolute;
    bottom: var(--wr-spacing-lg);
    left: 50%;
    transform: translateX(-50%);
    background: rgba(0, 0, 0, 0.7);
    color: white;
    padding: var(--wr-spacing-sm) var(--wr-spacing-md);
    border-radius: 16px;
    font-size: var(--wr-text-sm);
    font-weight: var(--wr-weight-medium);
}

/* 缩略图区域 */
.wr-gallery-thumbnails {
    display: flex;
    padding: var(--wr-spacing-lg);
    gap: var(--wr-spacing-sm);
    overflow-x: auto;
    background: var(--muted-bg-color, #f8f9fa);
    border-top: 1px solid var(--main-border-color, #e9ecef);
}

.wr-thumbnail-item {
    flex-shrink: 0;
    width: 70px;
    height: 70px;
    border-radius: var(--wr-radius-sm);
    overflow: hidden;
    cursor: pointer;
    border: 3px solid transparent;
    transition: all var(--wr-transition-normal);
    position: relative;
}

.wr-thumbnail-item:hover {
    transform: translateY(-2px);
    box-shadow: var(--wr-shadow-light);
}

.wr-thumbnail-item.active {
    border-color: var(--wr-primary-color);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(240, 68, 148, 0.3);
}

.wr-thumbnail-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* ================================
   筛选和排序组件
   ================================ */

.wr-filters {
    margin-top: var(--wr-spacing-xl);
    padding-top: var(--wr-spacing-lg);
    border-top: 1px solid rgba(255,255,255,0.2);
    display: flex;
    gap: var(--wr-spacing-lg);
    flex-wrap: wrap;
    position: relative;
    z-index: 1;
}

.wr-filter-group {
    display: flex;
    align-items: center;
    gap: var(--wr-spacing-sm);
}

.wr-filter-group label {
    color: rgba(255,255,255,0.9);
    font-size: var(--wr-text-sm);
    font-weight: var(--wr-weight-medium);
    white-space: nowrap;
}

.wr-filter-select {
    background: rgba(255,255,255,0.15);
    border: 2px solid rgba(255,255,255,0.2);
    color: white;
    padding: var(--wr-spacing-sm) var(--wr-spacing-md);
    border-radius: var(--wr-radius-sm);
    font-size: var(--wr-text-sm);
    cursor: pointer;
    transition: all var(--wr-transition-normal);
    backdrop-filter: blur(10px);
    min-width: 120px;
}

.wr-filter-select:hover {
    background: rgba(255,255,255,0.25);
    border-color: rgba(255,255,255,0.3);
}

.wr-filter-select:focus {
    outline: none;
    background: rgba(255,255,255,0.3);
    border-color: white;
    box-shadow: 0 0 0 2px rgba(255,255,255,0.2);
}

.wr-filter-select option {
    background: var(--main-bg-color, #ffffff);
    color: var(--key-color, #333);
    padding: var(--wr-spacing-sm);
}

.wr-filter-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: var(--wr-spacing-sm) var(--wr-spacing-md);
    background: var(--muted-bg-color, #f8f9fa);
    border: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.1));
    border-radius: var(--wr-radius-sm);
    color: var(--muted-color, #6c757d);
    font-size: var(--wr-text-sm);
    cursor: pointer;
    transition: all var(--wr-transition-normal);
    text-decoration: none;
}

.wr-filter-btn:hover,
.wr-filter-btn.active {
    background: var(--wr-primary-color);
    border-color: var(--wr-primary-color);
    color: white;
    transform: translateY(-1px);
}

/* ================================
   统计信息组件
   ================================ */

.wr-stats-section {
    margin: var(--wr-spacing-xxl) 0;
    padding: var(--wr-spacing-xl);
    background: linear-gradient(135deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01));
    border-radius: var(--wr-radius-xl);
    box-shadow: var(--wr-shadow-light);
    border: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.05));
}

.wr-stats-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--wr-spacing-lg);
}

.wr-stat-card {
    background: linear-gradient(135deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02));
    border-radius: var(--wr-radius-md);
    padding: var(--wr-spacing-lg);
    text-align: center;
    box-shadow: var(--wr-shadow-light);
    border: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.04));
    transition: all var(--wr-transition-normal);
    position: relative;
    overflow: hidden;
}

.wr-stat-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 4px;
    height: 100%;
    background: var(--wr-primary-gradient);
}

.wr-stat-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--wr-shadow-medium);
}

.wr-stat-icon {
    font-size: var(--wr-text-2xl);
    color: var(--wr-primary-color);
    margin-bottom: var(--wr-spacing-md);
    transition: transform var(--wr-transition-normal);
}

.wr-stat-card:hover .wr-stat-icon {
    transform: scale(1.1) rotate(5deg);
}

.wr-stat-number {
    font-size: var(--wr-text-3xl);
    font-weight: var(--wr-weight-bold);
    color: var(--key-color, #333);
    margin-bottom: var(--wr-spacing-sm);
    line-height: 1;
    font-family: 'Arial', sans-serif;
}

.wr-stat-label {
    font-size: var(--wr-text-sm);
    color: var(--muted-color, #6c757d);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    font-weight: var(--wr-weight-medium);
}

/* ================================
   分页导航
   ================================ */

.wr-pagination {
    display: flex;
    justify-content: center;
    margin-top: var(--wr-spacing-xxl);
}

.wr-page-numbers {
    display: flex;
    gap: 4px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.wr-page-numbers li {
    margin: 0;
}

.wr-page-numbers a,
.wr-page-numbers span {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    padding: 0 var(--wr-spacing-sm);
    background: var(--main-bg-color, #ffffff);
    color: var(--muted-color, #6c757d);
    text-decoration: none;
    border: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.1));
    border-radius: var(--wr-radius-sm);
    font-size: var(--wr-text-sm);
    font-weight: var(--wr-weight-medium);
    transition: all var(--wr-transition-normal);
}

.wr-page-numbers a:hover,
.wr-page-numbers .current {
    background: var(--wr-primary-color);
    color: white;
    border-color: var(--wr-primary-color);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(240, 68, 148, 0.3);
}

.wr-page-numbers .current {
    cursor: default;
}

/* ================================
   响应式设计
   ================================ */

/* 大屏幕优化 (1400px+) */
@media (min-width: 1400px) {
    .wr-works-grid {
        grid-template-columns: repeat(auto-fill, minmax(380px, 1fr));
        gap: var(--wr-spacing-xxl);
    }
    
    .wr-students-grid {
        grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
        gap: var(--wr-spacing-xxl);
    }
}

/* 中等屏幕 (992px - 1399px) */
@media (max-width: 1399px) and (min-width: 992px) {
    .wr-works-grid,
    .wr-students-grid {
        grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
        gap: var(--wr-spacing-lg);
    }
    
    .wr-stats-cards {
        grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
        gap: var(--wr-spacing-md);
    }
}

/* 平板设备 (768px - 991px) */
@media (max-width: 991px) and (min-width: 768px) {
    .wr-gallery-header {
        padding: var(--wr-spacing-xl);
    }
    
    .wr-gallery-title {
        font-size: var(--wr-text-2xl);
    }
    
    .wr-filters {
        flex-direction: column;
        gap: var(--wr-spacing-md);
    }
    
    .wr-filter-group {
        flex-direction: column;
        align-items: flex-start;
        gap: 4px;
    }
    
    .wr-filter-select {
        min-width: 200px;
    }
    
    .wr-works-grid,
    .wr-students-grid {
        grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
        gap: var(--wr-spacing-lg);
    }
    
    .wr-stats-cards {
        grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
        gap: var(--wr-spacing-md);
    }
}

/* 手机设备 (最大 767px) */
@media (max-width: 767px) {
    .wr-gallery-header {
        padding: var(--wr-spacing-lg) var(--wr-spacing-md);
    }
    
    .wr-header-top {
        flex-direction: column;
        align-items: stretch;
        gap: var(--wr-spacing-lg);
    }
    
    .wr-title-wrapper {
        text-align: center;
    }
    
    .wr-header-actions {
        margin-left: 0;
        display: flex;
        justify-content: center;
    }
    
    .wr-gallery-title {
        font-size: var(--wr-text-xl);
        flex-direction: column;
        gap: var(--wr-spacing-sm);
    }
    
    .wr-gallery-subtitle {
        font-size: var(--wr-text-base);
    }
    
    .wr-publish-btn {
        padding: 10px 20px;
        font-size: var(--wr-text-sm);
    }
    
    .wr-student-stats {
        padding: var(--wr-spacing-sm) 0;
    }
    
    .wr-stat-number {
        font-size: var(--wr-text-lg);
    }
    
    .wr-stat-label {
        font-size: 10px;
    }
    
    .wr-works-grid,
    .wr-students-grid {
        grid-template-columns: 1fr;
        gap: var(--wr-spacing-lg);
        padding: 0 var(--wr-spacing-sm);
    }
    
    .wr-work-card,
    .wr-student-card {
        max-width: 100%;
    }
    
    .wr-gallery-viewer {
        height: 300px;
    }
    
    .wr-gallery-btn {
        width: 36px;
        height: 36px;
        font-size: var(--wr-text-sm);
    }
    
    .wr-gallery-prev {
        left: var(--wr-spacing-sm);
    }
    
    .wr-gallery-next {
        right: var(--wr-spacing-sm);
    }
    
    .wr-gallery-fullscreen,
    .wr-gallery-play {
        top: var(--wr-spacing-sm);
    }
    
    .wr-gallery-fullscreen {
        right: var(--wr-spacing-sm);
    }
    
    .wr-gallery-play {
        left: var(--wr-spacing-sm);
    }
    
    .wr-gallery-thumbnails {
        padding: var(--wr-spacing-md);
        gap: var(--wr-spacing-xs);
    }
    
    .wr-thumbnail-item {
        width: 50px;
        height: 50px;
    }
    
    .wr-stats-cards {
        grid-template-columns: 1fr 1fr;
        gap: var(--wr-spacing-sm);
    }
    
    .wr-page-numbers a,
    .wr-page-numbers span {
        min-width: 36px;
        height: 36px;
        padding: 0 var(--wr-spacing-xs);
        font-size: var(--wr-text-xs);
    }
}

/* 小屏手机 (最大 480px) */
@media (max-width: 480px) {
    .wr-gallery-title {
        font-size: var(--wr-text-lg);
    }
    
    .wr-work-thumbnail,
    .wr-student-cover {
        padding-top: 70%;
    }
    
    .wr-gallery-viewer {
        height: 250px;
    }
    
    .wr-work-title {
        font-size: var(--wr-text-base);
        min-height: 2.4em;
    }
    
    .wr-work-meta {
        gap: 4px;
    }
    
    .wr-meta-item {
        padding: 2px var(--wr-spacing-xs);
        font-size: 11px;
    }
    
    .wr-work-stats {
        padding-top: var(--wr-spacing-sm);
    }
    
    .wr-stat-item {
        padding: 4px var(--wr-spacing-sm);
        font-size: 11px;
    }
    
    .wr-action-btn {
        width: 42px;
        height: 42px;
        font-size: var(--wr-text-base);
    }
    
    .wr-work-actions {
        gap: var(--wr-spacing-sm);
    }
}

/* ================================
   暗色主题适配
   ================================ */

.dark-theme .wr-work-card,
.dark-theme .wr-student-card,
.dark-theme .wr-stat-card {
    background: var(--main-bg-color);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
    border-color: var(--main-border-color);
}

.dark-theme .wr-gallery-container {
    background: var(--main-bg-color);
    box-shadow: 0 6px 30px rgba(0, 0, 0, 0.3);
}

.dark-theme .wr-gallery-thumbnails {
    background: var(--muted-bg-color);
    border-top-color: var(--main-border-color);
}

.dark-theme .wr-no-thumbnail {
    background: linear-gradient(135deg, rgba(240, 68, 148, 0.08), rgba(102, 126, 234, 0.08));
}

.dark-theme .wr-work-card:hover .wr-no-thumbnail {
    background: linear-gradient(135deg, rgba(240, 68, 148, 0.15), rgba(102, 126, 234, 0.15));
}

.dark-theme .wr-filter-select {
    background: var(--main-bg-color);
    border-color: var(--main-border-color);
    color: var(--key-color);
}

.dark-theme .wr-filter-btn {
    background: var(--muted-bg-color);
    border-color: var(--main-border-color);
    color: var(--muted-color);
}

.dark-theme .wr-page-numbers a,
.dark-theme .wr-page-numbers span {
    background: var(--main-bg-color);
    border-color: var(--main-border-color);
    color: var(--muted-color);
}

.dark-theme .wr-meta-item {
    background: rgba(240, 68, 148, 0.1);
    border-color: rgba(240, 68, 148, 0.08);
}

.dark-theme .wr-work-card:hover {
    box-shadow: 0 16px 48px rgba(0, 0, 0, 0.4);
}

/* ================================
   特殊效果和装饰
   ================================ */

/* 发光效果 */
.wr-glow {
    animation: wr-glow 2s ease-in-out infinite alternate;
}

@keyframes wr-glow {
    from {
        box-shadow: var(--wr-shadow-light);
    }
    to {
        box-shadow: var(--wr-shadow-glow), var(--wr-shadow-medium);
    }
}

/* 闪光效果 */
.wr-shine {
    position: relative;
    overflow: hidden;
}

.wr-shine::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.4), transparent);
    transition: left 0.6s ease;
}

.wr-shine:hover::before {
    left: 100%;
}

/* 玻璃态效果 */
.wr-glass {
    background: var(--wr-glass-gradient);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.2);
}

/* ================================
   实用工具类
   ================================ */

.wr-text-center { text-align: center; }
.wr-text-left { text-align: left; }
.wr-text-right { text-align: right; }

.wr-hidden { display: none !important; }
.wr-visible { display: block !important; }

.wr-no-scroll { overflow: hidden; }

.wr-pointer { cursor: pointer; }

.wr-relative { position: relative; }
.wr-absolute { position: absolute; }

.wr-w-full { width: 100%; }
.wr-h-full { height: 100%; }

.wr-flex { display: flex; }
.wr-flex-col { flex-direction: column; }
.wr-flex-wrap { flex-wrap: wrap; }
.wr-items-center { align-items: center; }
.wr-justify-center { justify-content: center; }
.wr-justify-between { justify-content: space-between; }

.wr-gap-sm { gap: var(--wr-spacing-sm); }
.wr-gap-md { gap: var(--wr-spacing-md); }
.wr-gap-lg { gap: var(--wr-spacing-lg); }

.wr-p-sm { padding: var(--wr-spacing-sm); }
.wr-p-md { padding: var(--wr-spacing-md); }
.wr-p-lg { padding: var(--wr-spacing-lg); }

.wr-m-sm { margin: var(--wr-spacing-sm); }
.wr-m-md { margin: var(--wr-spacing-md); }
.wr-m-lg { margin: var(--wr-spacing-lg); }

.wr-mt-sm { margin-top: var(--wr-spacing-sm); }
.wr-mt-md { margin-top: var(--wr-spacing-md); }
.wr-mt-lg { margin-top: var(--wr-spacing-lg); }

.wr-mb-sm { margin-bottom: var(--wr-spacing-sm); }
.wr-mb-md { margin-bottom: var(--wr-spacing-md); }
.wr-mb-lg { margin-bottom: var(--wr-spacing-lg); }

/* ================================
   打印样式
   ================================ */

@media print {
    .wr-gallery-btn,
    .wr-action-btn,
    .wr-filter-btn,
    .wr-view-all-btn {
        display: none !important;
    }
    
    .wr-work-card,
    .wr-student-card {
        break-inside: avoid;
        box-shadow: none !important;
        border: 1px solid #ddd !important;
    }
    
    .wr-gallery-header {
        background: none !important;
        color: #333 !important;
        box-shadow: none !important;
    }
    
    .wr-gallery-title,
    .wr-gallery-subtitle {
        color: #333 !important;
    }
}

/* ================================
   辅助功能增强
   ================================ */

/* 高对比度模式 */
@media (prefers-contrast: high) {
    .wr-work-card,
    .wr-student-card {
        border-width: 2px;
        border-color: #000;
    }
    
    .wr-action-btn,
    .wr-gallery-btn {
        border: 2px solid #000;
    }
}

/* 减少动画 */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* 焦点可见性 */
.wr-action-btn:focus,
.wr-gallery-btn:focus,
.wr-filter-btn:focus,
.wr-view-all-btn:focus {
    outline: 2px solid var(--wr-primary-color);
    outline-offset: 2px;
}

/* ================================
   作品展示页面布局优化
   ================================ */

/* 作品展示主容器 */
.work-display-container {
    max-width: 1400px;
    margin: 0 auto;
    padding: var(--wr-spacing-lg) var(--wr-spacing-md);
}

.work-display-container .content-wrap {
    width: 100%;
}

.work-display-container .content-layout {
    display: flex;
    flex-direction: column;
    gap: var(--wr-spacing-lg);
    width: 100%;
}

/* 作品展示头部优化 */
.work-display-header {
    background: var(--main-bg-color, #ffffff);
    border-radius: var(--wr-radius-lg);
    padding: var(--wr-spacing-lg);
    box-shadow: var(--wr-shadow-light);
    border: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.05));
    margin-bottom: var(--wr-spacing-md);
}

/* 面包屑导航 */
.work-breadcrumb {
    display: flex;
    align-items: center;
    gap: var(--wr-spacing-sm);
    margin-bottom: var(--wr-spacing-md);
    font-size: var(--wr-text-sm);
    color: var(--muted-color, #6c757d);
}

.work-breadcrumb a {
    color: var(--muted-color, #6c757d);
    text-decoration: none;
    transition: color var(--wr-transition-normal);
}

.work-breadcrumb a:hover {
    color: var(--wr-primary-color);
}

.work-breadcrumb .separator {
    color: var(--muted-3-color, #adb5bd);
}

.work-breadcrumb .current {
    color: var(--key-color, #333);
    font-weight: var(--wr-weight-medium);
}

/* 学员信息栏 - 紧凑设计 */
.student-info-bar {
    display: flex;
    align-items: flex-start;
    gap: var(--wr-spacing-md);
    padding: var(--wr-spacing-md);
    background: linear-gradient(135deg, rgba(102, 126, 234, 0.03), rgba(118, 75, 162, 0.02));
    border-radius: var(--wr-radius-md);
    border: 1px solid rgba(102, 126, 234, 0.1);
    margin-bottom: var(--wr-spacing-md);
}

.student-info-bar .student-avatar {
    flex-shrink: 0;
    border-radius: var(--wr-radius-full);
    overflow: hidden;
    box-shadow: var(--wr-shadow-light);
}

.student-info-bar .student-avatar img {
    width: 50px;
    height: 50px;
    object-fit: cover;
    display: block;
}

.student-info-bar .student-details {
    flex: 1;
    min-width: 0;
}

.student-info-bar .student-name {
    font-size: var(--wr-text-base);
    font-weight: var(--wr-weight-bold);
    color: var(--key-color, #333);
    margin: 0 0 4px 0;
    line-height: 1.3;
}

.student-info-bar .student-meta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--wr-spacing-sm);
    margin-bottom: var(--wr-spacing-xs);
}

.student-info-bar .student-meta > span {
    font-size: var(--wr-text-xs);
    color: var(--muted-color, #6c757d);
    background: rgba(102, 126, 234, 0.08);
    padding: 2px var(--wr-spacing-xs);
    border-radius: 10px;
    white-space: nowrap;
}

/* 角色验证状态样式 */
.student-role.verified {
    background: rgba(39, 174, 96, 0.1);
    color: #27ae60;
}

.student-role.pending {
    background: rgba(243, 156, 18, 0.1);
    color: #f39c12;
}

.student-role.none {
    background: rgba(149, 165, 166, 0.1);
    color: #95a5a6;
}

/* 详细信息区域 - 内联布局 */
.student-details-full.inline-info {
    display: flex;
    flex-wrap: wrap;
    gap: var(--wr-spacing-sm);
    margin-top: var(--wr-spacing-xs);
}

.student-details-full.inline-info > * {
    font-size: var(--wr-text-xs);
    color: var(--muted-color, #6c757d);
    text-decoration: none;
    padding: 2px var(--wr-spacing-xs);
    border-radius: 8px;
    background: rgba(240, 68, 148, 0.05);
    transition: all var(--wr-transition-normal);
    white-space: nowrap;
}

.student-details-full.inline-info a:hover {
    background: rgba(240, 68, 148, 0.1);
    color: var(--wr-primary-color);
}

.student-details-full.inline-info .restricted {
    color: var(--muted-3-color, #adb5bd);
    font-style: italic;
}

/* 个人简介和技能 - 紧凑显示 */
.student-bio {
    margin-top: var(--wr-spacing-sm);
    padding: var(--wr-spacing-xs) var(--wr-spacing-sm);
    background: rgba(36, 36, 36, 0.699);
    border-radius: var(--wr-radius-sm);
    /* border-left: 3px solid var(--wr-primary-color); */
}

.student-bio p {
    margin: 0;
    font-size: var(--wr-text-xs);
    color: var(--muted-color, #6c757d);
    line-height: 1.4;
}

.student-skills {
    margin-top: var(--wr-spacing-sm);
}

.student-skills .skills-label {
    font-size: var(--wr-text-xs);
    color: var(--key-color, #333);
    font-weight: var(--wr-weight-medium);
    margin-bottom: 4px;
    display: block;
}

.student-skills .skills-list {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
}

.student-skills .skill-tag {
    font-size: 10px;
    padding: 2px 6px;
    background: var(--wr-primary-gradient);
    color: white;
    border-radius: 8px;
    white-space: nowrap;
}

/* 作品标题优化 */
.work-title {
    font-size: var(--wr-text-2xl);
    font-weight: var(--wr-weight-bold);
    color: var(--key-color, #333);
    margin: var(--wr-spacing-md) 0;
    line-height: 1.3;
}

/* 作品元信息 */
.work-meta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--wr-spacing-md);
    margin-bottom: var(--wr-spacing-md);
}

.work-meta .meta-item {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: var(--wr-text-sm);
    color: var(--muted-color, #6c757d);
    padding: 4px var(--wr-spacing-sm);
    background: var(--muted-bg-color, #f8f9fa);
    border-radius: 12px;
    border: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.05));
}

.work-meta .meta-item i {
    color: var(--wr-primary-color);
    font-size: var(--wr-text-sm);
}

.work-meta .topic-category {
    background: rgba(102, 126, 234, 0.08);
    color: var(--wr-secondary-color);
}

/* 作者操作按钮 */
.author-actions {
    margin-top: var(--wr-spacing-md);
    display: flex;
    gap: var(--wr-spacing-sm);
    flex-wrap: wrap;
}

.author-actions .but {
    font-size: var(--wr-text-sm);
    padding: var(--wr-spacing-sm) var(--wr-spacing-lg);
    border-radius: var(--wr-radius-sm);
    display: inline-flex;
    align-items: center;
    gap: var(--wr-spacing-xs);
    text-decoration: none;
    transition: all var(--wr-transition-normal);
    box-shadow: var(--wr-shadow-light);
    border: none;
    cursor: pointer;
    font-weight: var(--wr-weight-medium);
}

.author-actions .but:hover {
    transform: translateY(-2px);
    box-shadow: var(--wr-shadow-medium);
    text-decoration: none;
}

/* 按钮颜色样式 */
.author-actions .but.jb-blue {
    background: var(--wr-primary-color);
    color: white;
}

.author-actions .but.jb-blue:hover {
    background: var(--wr-secondary-color);
    color: white;
}

.author-actions .but.jb-green {
    background: #2ecc71;
    color: white;
}

.author-actions .but.jb-green:hover {
    background: #27ae60;
    color: white;
}

.author-actions .but.jb-orange {
    background: #f39c12;
    color: white;
}

.author-actions .but.jb-orange:hover {
    background: #e67e22;
    color: white;
}

/* 下载按钮特殊样式 */
.author-actions .but.download-btn {
    background: #28a745;
    color: white;
    position: relative;
    overflow: hidden;
}

.author-actions .but.download-btn:hover {
    background: #218838;
    color: white;
    transform: translateY(-2px) scale(1.05);
    box-shadow: 0 6px 20px rgba(40, 167, 69, 0.3);
}

.author-actions .but.download-btn:active {
    transform: translateY(0) scale(1);
    box-shadow: 0 2px 8px rgba(40, 167, 69, 0.2);
}

.author-actions .but.download-btn i {
    animation: downloadPulse 2s infinite;
}

@keyframes downloadPulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.1); }
}

/* 作品集和发布按钮样式已整合到作者操作按钮中 */

/* ================================
   3D模型对比查看器样式
   ================================ */

/* 3D控制面板 */
.work-3d-controls-panel {
    background: var(--main-bg-color, #ffffff);
    border-radius: var(--wr-radius-md);
    padding: var(--wr-spacing-lg);
    margin-bottom: var(--wr-spacing-lg);
    border: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.1));
    box-shadow: var(--wr-shadow-light);
    min-height: 80px; /* 设置最小高度，防止内容变化时容器高度跳动 */
    overflow: hidden; /* 防止内容溢出导致布局问题 */
}

/* 对比控制行布局 */
.comparison-controls-row {
    display: flex;
    flex-direction: column;
    gap: var(--wr-spacing-lg);
    align-items: stretch; /* 确保子元素高度一致 */
}

@media (min-width: 1024px) {
    .comparison-controls-row {
        flex-direction: row;
        align-items: flex-start;
        gap: var(--wr-spacing-xxl);
    }
    
    .comparison-toggle-section {
        flex: 0 0 auto;
        min-width: 200px;
        display: flex;
        align-items: flex-start; /* 与材质选项对齐 */
    }
    
    .material-comparison-controls {
        flex: 1;
        display: flex;
        align-items: flex-start;
    }
}

.comparison-toggle-section {
    display: flex;
    flex-direction: column;
    gap: var(--wr-spacing-sm);
    min-height: 44px; /* 与材质选项容器保持一致的最小高度 */
}

.comparison-checkbox-input {
    display: none; /* 隐藏复选框，使用按钮样式 */
}

/* 对比查看模式复选框将继承 .material-option 的样式 */

/* 设置按钮样式 */
.settings-checkbox-input {
    display: none; /* 隐藏复选框，使用按钮样式 */
}

.settings-toggle-section {
    display: flex;
    flex-direction: column;
    gap: var(--wr-spacing-sm);
    min-height: 44px; /* 与其他选项容器保持一致的最小高度 */
}

/* 物体打散控制器覆盖层样式 */
.explode-control-overlay {
    position: absolute;        /* 绝对定位，相对于3D容器 */
    top: 50%;                  /* 垂直居中定位 */
    left: 25px;                /* 距离左边25像素，避免太靠近边缘 */
    transform: translateY(-50%); /* 垂直居中对齐 */
    display: flex;             /* 弹性布局 */
    flex-direction: column;    /* 垂直排列子元素 */
    align-items: center;       /* 子元素水平居中 */
    gap: 12px;                 /* 子元素间距12像素 */
    z-index: 15;               /* 层级高于3D内容 */
    pointer-events: auto;      /* 允许鼠标事件 */
    user-select: none;         /* 禁止文本选择 */
}

/* 物体打散滑块样式 - 垂直排列，优化高度 */
.explode-slider-overlay {
    width: 3px;                      /* 滑块宽度3像素（较窄） */
    height: 80px;                    /* 滑块高度80像素（减少到原来的2/3） */
    -webkit-appearance: none;        /* 移除WebKit默认样式 */
    appearance: none;                /* 移除浏览器默认样式 */
    background: transparent;         /* 透明背景 */
    border: none;                    /* 移除边框 */
    border-radius: 0;                /* 移除圆角 */
    outline: none;                   /* 移除焦点轮廓 */
    transition: all 0.2s ease;       /* 平滑过渡效果 */
    cursor: pointer;                 /* 鼠标指针样式 */
    position: relative;              /* 相对定位，用于添加中间线条 */
    writing-mode: bt-lr;             /* IE兼容：垂直书写模式 */
    -webkit-writing-mode: vertical-lr; /* WebKit：垂直书写模式 */
    writing-mode: vertical-lr;       /* 标准：垂直书写模式 */
    -webkit-transform: rotate(180deg); /* WebKit：旋转180度 */
    -moz-transform: rotate(180deg);  /* Firefox：旋转180度 */
    -o-transform: rotate(180deg);    /* Opera：旋转180度 */
    transform: rotate(180deg);       /* 标准：旋转180度，使滑块方向正确 */
}

/* 滑块中间线条 - 使用伪元素 */
.explode-slider-overlay::before {
    content: '';
    position: absolute;
    left: 50%;
    top: 0;
    bottom: 0;
    width: 3px;                      /* 中间线条宽度3像素，与容器匹配 */
    background: rgba(255, 255, 255, 0.4); /* 半透明白色线条 */
    transform: translateX(-50%);     /* 居中对齐 */
    pointer-events: none;            /* 不阻止滑块交互 */
}

/* WebKit浏览器滑块拖拽按钮样式 */
.explode-slider-overlay::-webkit-slider-thumb {
    -webkit-appearance: none;        /* 移除默认样式 */
    appearance: none;                /* 移除默认样式 */
    width: 10px;                     /* 按钮宽度10像素 */
    height: 10px;                    /* 按钮高度10像素 */
    background: #3498db;             /* 蓝色背景 */
    border-radius: 50%;              /* 圆形按钮 */
    cursor: pointer;                 /* 鼠标指针样式 */
    box-shadow: 0 2px 8px rgba(52, 152, 219, 0.4), 0 0 0 2px rgba(255, 255, 255, 0.8); /* 阴影和白色边框 */
    transition: all 0.2s ease;       /* 平滑过渡效果 */
}

/* WebKit滑块按钮悬停效果 */
.explode-slider-overlay::-webkit-slider-thumb:hover {
    background: #2980b9;            /* 悬停时深蓝色背景 */
    transform: scale(1.2);          /* 放大1.2倍 */
    box-shadow: 0 4px 12px rgba(52, 152, 219, 0.6), 0 0 0 3px rgba(255, 255, 255, 0.9); /* 增强阴影和边框 */
}

/* WebKit滑块按钮激活（点击）效果 */
.explode-slider-overlay::-webkit-slider-thumb:active {
    transform: scale(1.3);          /* 点击时放大1.3倍 */
}

/* Firefox浏览器滑块拖拽按钮样式 */
.explode-slider-overlay::-moz-range-thumb {
    width: 16px;                     /* 按钮宽度16像素 */
    height: 16px;                    /* 按钮高度16像素 */
    background: #3498db;             /* 蓝色背景 */
    border-radius: 50%;              /* 圆形按钮 */
    cursor: pointer;                 /* 鼠标指针样式 */
    border: 2px solid rgba(255, 255, 255, 0.8); /* 白色边框 */
    box-shadow: 0 2px 8px rgba(52, 152, 219, 0.4); /* 阴影效果 */
    transition: all 0.2s ease;       /* 平滑过渡效果 */
}

/* Firefox滑块按钮悬停效果 */
.explode-slider-overlay::-moz-range-thumb:hover {
    background: #2980b9;            /* 悬停时深蓝色背景 */
    transform: scale(1.2);          /* 放大1.2倍 */
    border: 3px solid rgba(255, 255, 255, 0.9); /* 增强白色边框 */
    box-shadow: 0 4px 12px rgba(52, 152, 219, 0.6); /* 增强阴影效果 */
}

/* 滑块悬停效果 - 中间线条变亮 */
.explode-slider-overlay:hover::before {
    background: rgba(255, 255, 255, 0.7); /* 悬停时中间线条变亮 */
}

/* Firefox浏览器滑块轨道样式 - 中间线条 */
.explode-slider-overlay::-moz-range-track {
    background: rgba(255, 255, 255, 0.4); /* 半透明白色线条 */
    height: 3px;                      /* 轨道高度3像素，与线条宽度匹配 */
    border-radius: 0;                 /* 移除圆角 */
    border: none;                     /* 移除边框 */
}

/* 滑块数值显示样式 */
.explode-value-overlay {
    font-size: 11px;                 /* 字体大小11像素 */
    color: #ffffff;                  /* 白色文字 */
    font-weight: 600;                /* 字体加粗 */
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.8); /* 黑色文字阴影，增强可读性 */
    min-width: 35px;                 /* 最小宽度35像素 */
    text-align: center;              /* 文字居中对齐 */
}

/* 移动端适配 - 优化触控体验 */
@media (max-width: 768px) {
    /* 移动端控制器位置调整 - 缩小占用空间 */
    .explode-control-overlay {
        left: 15px;                /* 移动端距离左边减少到15像素，节省空间 */
        gap: 6px;                  /* 元素间距减少到6像素，更紧凑 */
        padding: 8px 4px;          /* 添加内边距提供更大触控区域 */
    }
    
    /* 移动端滑块样式 - 优化尺寸和触控 */
    .explode-slider-overlay {
        width: 0.1px;                /* 移动端宽度2像素，更细线条 */
        height: 100px;              /* 移动端高度54像素（原来80px的2/3），进一步减少空间占用 */
        background: transparent;   /* 透明背景 */
        border: none;              /* 移除边框 */
        border-radius: 1;          /* 移除圆角 */
        position: relative;        /* 相对定位，用于中间线条 */
        /* 扩大触控区域 */
        padding: 10px;             /* 增加内边距扩大触控区域 */
        margin: -10px;             /* 负边距补偿内边距，保持视觉尺寸 */
        min-width: 44px;           /* iOS推荐最小触控尺寸44px */
        min-height: 44px;          /* 保证足够的触控面积 */
    }
    
    /* 移动端滑块中间线条 - 优化视觉 */
    .explode-slider-overlay::before {
        width: 10px;                /* 移动端中间线条宽度2像素，与容器匹配 */
        background: rgba(255, 255, 255, 0.6); /* 移动端线条稍亮一些，提高可见性 */
        left: 50%;                 /* 居中定位 */
        transform: translateX(-50%); /* 精确居中 */
    }
    
    /* 移动端WebKit滑块轨道 - 触控优化 */
    .explode-slider-overlay::-webkit-slider-runnable-track {
        background: rgba(255, 255, 255, 0.021); /* 半透明白色线条，提高可见性 */
        height: 10px;               /* 轨道高度2像素，与线条匹配 */
        border-radius: 1px;        /* 轻微圆角，更精致 */
        border: none;              /* 移除边框 */
    }
    
    /* 移动端WebKit滑块按钮 - 触控友好 */
    .explode-slider-overlay::-webkit-slider-thumb {
        width: 10px;               /* 移动端按钮宽度20像素，便于触摸 */
        height: 10px;              /* 移动端按钮高度20像素，符合触控标准 */
        background: #3498db;       /* 蓝色背景 */
        border-radius: 50%;        /* 圆形按钮 */
        box-shadow: 0 3px 12px rgba(52, 152, 219, 0.5), 0 0 0 3px rgba(255, 255, 255, 0.9); /* 增强阴影和边框 */
        margin-top: -9px;          /* 调整按钮位置，使其居中对齐轨道 */
        border: none;              /* 移除默认边框 */
        transition: all 0.2s ease; /* 平滑过渡 */
    }
    
    /* 移动端WebKit滑块按钮触控反馈 */
    .explode-slider-overlay::-webkit-slider-thumb:active {
        transform: scale(1.15);    /* 触摸时轻微放大 */
        background: #2980b9;       /* 触摸时深蓝色 */
        box-shadow: 0 4px 16px rgba(52, 152, 219, 0.7), 0 0 0 4px rgba(255, 255, 255, 1); /* 增强触摸反馈 */
    }
    
    /* 移动端Firefox滑块按钮 - 触控友好 */
    .explode-slider-overlay::-moz-range-thumb {
        width: 20px;               /* 移动端按钮宽度20像素 */
        height: 20px;              /* 移动端按钮高度20像素 */
        background: #3498db;       /* 蓝色背景 */
        border-radius: 50%;        /* 圆形按钮 */
        border: 1px solid rgba(255, 255, 255, 0.9); /* 增强白色边框 */
        box-shadow: 0 1px 12px rgba(52, 152, 219, 0.5); /* 增强阴影效果 */
        cursor: pointer;           /* 指针样式 */
    }
    
    /* 移动端Firefox滑块按钮触控反馈 */
    .explode-slider-overlay::-moz-range-thumb:active {
        transform: scale(1.15);    /* 触摸时轻微放大 */
        background: #2980b9;       /* 触摸时深蓝色 */
        border: 4px solid rgba(255, 255, 255, 1); /* 触摸时增强边框 */
    }
    
    /* 移动端Firefox滑块轨道 - 触控优化 */
    .explode-slider-overlay::-moz-range-track {
        background: rgba(255, 255, 255, 0.6); /* 半透明白色线条，提高可见性 */
        height: 0.1px;               /* 轨道高度2像素，与线条宽度匹配 */
        border-radius: 1px;        /* 轻微圆角 */
        border: none;              /* 移除边框 */
    }
    
    /* 移动端滑块交互状态 - 触控反馈 */
    .explode-slider-overlay:hover::before,
    .explode-slider-overlay:active::before,
    .explode-slider-overlay:focus::before {
        background: rgba(255, 255, 255, 0.9); /* 激活时中间线条更亮 */
        transform: translateX(-50%) scaleY(1.1); /* 轻微拉伸，提供视觉反馈 */
    }
    
    /* 移动端数值显示 - 优化可读性 */
    .explode-value-overlay {
        font-size: 11px;           /* 移动端字体11像素，保持可读性 */
        min-width: 28px;           /* 移动端最小宽度28像素，更紧凑 */
        text-shadow: 0 2px 4px rgba(0, 0, 0, 0.8); /* 增强文字阴影，确保可读性 */
        padding: 2px 4px;          /* 添加内边距，提高触控体验 */
        background: rgba(0, 0, 0, 0.3); /* 半透明背景，提高文字对比度 */
        border-radius: 3px;        /* 轻微圆角，更现代 */
    }
    
    /* 移动端触控区域扩展 - 优化触控交互 */
    .explode-slider-overlay::after {
        content: '';
        position: absolute;
        top: -15px;
        bottom: -15px;
        left: -15px;
        right: -15px;
        pointer-events: auto;      /* 扩大触控区域 */
    }
    
    /* 滑块触控优化 - 防止浏览器滚动 */
    .explode-slider-overlay {
        touch-action: none;        /* 完全禁用默认触控行为 */
        -webkit-touch-callout: none; /* 禁用iOS长按菜单 */
        -webkit-user-select: none; /* 禁用文本选择 */
        -moz-user-select: none;
        -ms-user-select: none;
        user-select: none;
        
        /* 确保滑块在触控时有足够的优先级 */
        z-index: 20;
        position: relative;
    }
    
    /* 滑块容器触控优化 */
    .explode-control-overlay {
        touch-action: none;        /* 完全禁用容器的触控手势 */
        -webkit-overflow-scrolling: auto; /* 禁用惯性滚动 */
        isolation: isolate;        /* 创建新的层叠上下文 */
    }
    
    /* 滑块触控区域增强 - 确保触控响应 */
    .explode-slider-overlay::after {
        /* 已有样式保持不变，添加触控优化 */
        touch-action: none;        /* 扩展区域也禁用默认触控 */
        -webkit-tap-highlight-color: transparent; /* 禁用点击高亮 */
        z-index: 21;              /* 确保触控区域在最上层 */
    }
    
    /* 防止整个页面在滑块操作时滚动 */
    body.slider-active {
        overflow: hidden !important;
        position: fixed !important;
        width: 100% !important;
        height: 100vh !important;
        touch-action: none !important;
    }
    
    /* 移动端3D查看器控制按钮优化 */
    .gallery-btn {
        width: 36px;               /* 移动端稍大的触控区域 */
        height: 36px;
        font-size: 18px;           /* 移动端稍大的图标 */
        background: rgba(0, 0, 0, 0.3); /* 移动端半透明暗色背景 */
        backdrop-filter: blur(5px); /* 轻微模糊效果 */
    }
    
    .gallery-btn:hover {
        background: rgba(255, 255, 255, 0.2); /* 移动端悬停效果 */
    }
    
    /* 移动端画廊按钮布局调整 */
    .gallery-overlay {
        grid-template-areas: 
            "auto-rotate . fullscreen"
            ". . ."
            "prev . next";
        grid-template-columns: auto 1fr auto;
        gap: var(--wr-spacing-xs); /* 移动端更小的间距 */
        padding: var(--wr-spacing-sm); /* 移动端更小的内边距 */
    }
}

.comparison-help-text {
    display: none; /* 隐藏帮助文本，保持布局简洁 */
}

/* 环境和背景设置面板 */
.environment-background-controls {
    background: var(--main-bg-color, #ffffff);
    border-radius: var(--wr-radius-md);
    padding: var(--wr-spacing-lg);
    margin-bottom: var(--wr-spacing-lg);
    border: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.1));
    box-shadow: var(--wr-shadow-light);
    transition: opacity 0.2s ease-in-out;
    opacity: 1;
}

.env-bg-controls-row {
    display: flex;
    flex-direction: column;
    gap: var(--wr-spacing-xl);
}

@media (min-width: 768px) {
    .env-bg-controls-row {
        flex-direction: row;
        gap: var(--wr-spacing-xxl);
    }
    
    .environment-controls,
    .background-controls,
    .lighting-controls {
        flex: 1;
        min-width: 0;
    }
}

.control-section-title {
    font-size: var(--wr-text-md);
    font-weight: var(--wr-weight-semibold);
    color: var(--key-color, #333);
    margin: 0 0 var(--wr-spacing-md) 0;
    display: flex;
    align-items: center;
    gap: var(--wr-spacing-sm);
}

.control-section-title i {
    color: var(--wr-primary-color);
}

/* 环境选项 */
.environment-options,
.background-options {
    display: flex;
    flex-wrap: wrap;
    gap: var(--wr-spacing-sm);
    margin-bottom: var(--wr-spacing-md);
}

.env-option,
.bg-option,
.hdr-option {
    display: flex;
    align-items: center;
    padding: var(--wr-spacing-sm) var(--wr-spacing-md);
    border: 2px solid var(--main-border-color, rgba(0, 0, 0, 0.1));
    border-radius: var(--wr-radius-sm);
    cursor: pointer;
    transition: var(--wr-transition-normal);
    background: var(--main-bg-color, #ffffff);
    user-select: none;
    flex: 0 0 auto;
    white-space: nowrap;
    min-height: 36px;
    justify-content: center;
}

.env-option:hover,
.bg-option:hover,
.hdr-option:hover {
    border-color: var(--wr-primary-color);
    background: var(--wr-primary-color, rgba(102, 126, 234, 0.05));
    transform: translateY(-2px);
    box-shadow: var(--wr-shadow-medium);
}

.env-option.active,
.bg-option.active,
.hdr-option.active {
    border-color: var(--wr-primary-color);
    background: var(--wr-primary-color, rgba(102, 126, 234, 0.1));
    box-shadow: var(--wr-shadow-glow);
}

.env-option input[type="radio"],
.bg-option input[type="radio"],
.hdr-option input[type="radio"] {
    display: none;
}

/* 颜色选择器 */
.environment-color-picker,
.background-color-picker {
    margin-bottom: var(--wr-spacing-md);
}

.color-picker-label,
.hdr-picker-label,
.slider-label {
    display: block;
    font-weight: var(--wr-weight-medium);
    color: var(--key-color, #333);
    margin-bottom: var(--wr-spacing-sm);
    font-size: var(--wr-text-sm);
}

.color-input {
    width: 100%;
    max-width: 80px;
    height: 40px;
    border: 2px solid var(--main-border-color, rgba(0, 0, 0, 0.1));
    border-radius: var(--wr-radius-sm);
    cursor: pointer;
    background: none;
    padding: 2px;
}

.color-input::-webkit-color-swatch-wrapper {
    padding: 0;
    border-radius: calc(var(--wr-radius-sm) - 2px);
}

.color-input::-webkit-color-swatch {
    border: none;
    border-radius: calc(var(--wr-radius-sm) - 2px);
}

/* HDR选择器 */
.environment-hdr-picker,
.background-hdr-picker {
    animation: wr-fadeInUp 0.3s ease-out;
}

.hdr-options {
    display: flex;
    flex-wrap: wrap;
    gap: var(--wr-spacing-sm);
}

/* 灯光设置 */
.lighting-options {
    display: flex;
    flex-direction: column;
    gap: var(--wr-spacing-md);
}

.lighting-slider-group {
    display: flex;
    flex-direction: column;
    gap: var(--wr-spacing-sm);
}

.lighting-slider {
    width: 100%;
    height: 6px;
    border-radius: 3px;
    background: var(--main-border-color, rgba(0, 0, 0, 0.1));
    outline: none;
    cursor: pointer;
    transition: var(--wr-transition-normal);
}

.lighting-slider::-webkit-slider-thumb {
    appearance: none;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: var(--wr-primary-color);
    cursor: pointer;
    border: 2px solid #ffffff;
    box-shadow: var(--wr-shadow-medium);
    transition: var(--wr-transition-normal);
}

.lighting-slider::-webkit-slider-thumb:hover {
    transform: scale(1.1);
    box-shadow: var(--wr-shadow-glow);
}

.lighting-slider::-moz-range-thumb {
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: var(--wr-primary-color);
    cursor: pointer;
    border: 2px solid #ffffff;
    box-shadow: var(--wr-shadow-medium);
    transition: var(--wr-transition-normal);
}

.slider-value {
    font-weight: var(--wr-weight-medium);
    color: var(--wr-primary-color);
    font-size: var(--wr-text-sm);
    text-align: center;
    min-width: 40px;
    padding: var(--wr-spacing-xs) var(--wr-spacing-sm);
    background: var(--wr-primary-color, rgba(102, 126, 234, 0.1));
    border-radius: var(--wr-radius-sm);
    border: 1px solid var(--wr-primary-color, rgba(102, 126, 234, 0.2));
}

/* 材质对比控制面板 */
.material-comparison-controls {
    animation: wr-fadeInUp 0.3s ease-out;
    min-height: 44px; /* 与对比查看模式选项保持一致的最小高度 */
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
}

.controls-description {
    font-size: var(--wr-text-sm);
    color: var(--muted-color, #6c757d);
    margin-bottom: var(--wr-spacing-sm); /* 减少间距 */
}

.material-options {
    display: flex;
    flex-wrap: wrap;
    gap: var(--wr-spacing-sm);
    justify-content: flex-start;
    min-height: 36px; /* 与单个选项高度保持一致 */
    align-items: flex-start;
}

.material-option {
    display: flex;
    align-items: center;
    padding: var(--wr-spacing-sm) var(--wr-spacing-md);
    border: 2px solid var(--main-border-color, rgba(0, 0, 0, 0.1));
    border-radius: var(--wr-radius-sm);
    cursor: pointer;
    transition: var(--wr-transition-normal);
    background: var(--main-bg-color, #ffffff);
    user-select: none;
    flex: 0 0 auto;
    white-space: nowrap;
    min-height: 36px; /* 确保所有选项都有相同的最小高度 */
    justify-content: center;
}

.material-option:hover {
    border-color: var(--wr-primary-color);
    background: var(--wr-primary-color, rgba(102, 126, 234, 0.05));
    transform: translateY(-2px);
    box-shadow: var(--wr-shadow-medium);
}

.material-option.active {
    border-color: var(--wr-primary-color);
    background: var(--wr-primary-color, rgba(102, 126, 234, 0.1));
    box-shadow: var(--wr-shadow-glow);
}

.material-option input[type="radio"],
.material-option input[type="checkbox"] {
    display: none;
}

.option-text {
    font-weight: var(--wr-weight-medium);
    color: var(--key-color, #333);
    font-size: var(--wr-text-sm);
}

/* 对比查看器容器 */
.work-3d-container {
    position: relative;
    width: 100%;
    height: 600px;
    border-radius: var(--wr-radius-md);
    overflow: hidden;
    background: #323335;
}

/* 分隔线样式 - 参考model-comparison.html */
.comparison-divider {
    position: absolute;
    top: 0;
    height: 100%;
    width: 1px;
    background: white;
    left: 50%;
    transform: translateX(-50%);
    cursor: ew-resize;
    z-index: 30;
    box-shadow: 0 0 4px rgba(0, 0, 0, 0.3);
    will-change: transform;
    transition: width 0.2s ease, background 0.2s ease;
}

.comparison-divider:hover {
    width: 1.5px;
    background: var(--wr-primary-color);
}

.comparison-divider::before {
    content: '';
    position: absolute;
    left: -12px;
    top: 50%;
    transform: translateY(-50%);
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--wr-primary-color);
    border: 2px solid white;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
    transition: all 0.2s ease;
}

.comparison-divider:hover::before {
    transform: translateY(-50%) scale(1.1);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

.comparison-divider::after {
    content: '⇄';
    position: absolute;
    left: -12px;
    top: 50%;
    transform: translateY(-50%);
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--wr-primary-color);
    border: 2px solid white;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 12px;
    font-weight: bold;
    pointer-events: none;
    transition: all 0.2s ease;
}

/* 模型标签 */
.model-label {
    position: absolute;
    top: var(--wr-spacing-lg);
    background: rgba(0, 0, 0, 0.7);
    color: white;
    padding: var(--wr-spacing-sm) var(--wr-spacing-md);
    border-radius: var(--wr-radius-sm);
    font-size: var(--wr-text-sm);
    font-weight: var(--wr-weight-medium);
    z-index: 20;
    backdrop-filter: blur(4px);
}

.model-label-left {
    left: var(--wr-spacing-lg);
}

.model-label-right {
    right: var(--wr-spacing-lg);
}

/* 响应式设计 */
@media (max-width: 768px) {
    .comparison-controls-row {
        flex-direction: column;
        gap: var(--wr-spacing-md);
    }
    
    .material-options {
        flex-direction: column;
    }
    
    .material-option {
        justify-content: center;
        width: 100%;
        min-height: 40px; /* 移动端稍微减少高度 */
    }
    
    /* 移动端分割线优化 */
    .comparison-divider {
        width: 2px; /* 移动端增加分割线宽度以便拖拽 */
        background: var(--wr-primary-color);
        cursor: ew-resize;
        touch-action: none; /* 禁用原生触摸手势 */
        -webkit-touch-callout: none;
        -webkit-user-select: none;
        user-select: none;
    }
    
    .comparison-divider::before {
        width: 32px; /* 移动端增大拖拽区域 */
        height: 32px;
        left: -15px; /* 调整位置适应更大的拖拽区域 */
        background: var(--wr-primary-color);
        opacity: 0.9;
    }
    
    .comparison-divider::after {
        width: 32px;
        height: 32px;
        left: -15px;
        font-size: 16px; /* 移动端增大图标 */
        line-height: 28px;
        background: var(--wr-primary-color);
        color: white;
        opacity: 1;
    }
    
    /* 移动端分割线悬停状态 */
    .comparison-divider:hover {
        width: 3px;
    }
    
    .comparison-divider:hover::before,
    .comparison-divider:hover::after {
        transform: translateY(-50%) scale(1.05);
    }
    
    .work-3d-controls-panel {
        padding: var(--wr-spacing-md);
    }
    
    .comparison-checkbox {
        min-height: 40px; /* 移动端与材质选项保持一致 */
    }
    
    .work-3d-container {
        height: 400px;
    }
}

@media (max-width: 480px) {
    .comparison-checkbox-label {
        font-size: var(--wr-text-sm);
    }
    
    .material-option {
        padding: var(--wr-spacing-sm);
    }
    
    .option-icon {
        width: 28px;
        height: 28px;
    }
    
    .work-3d-container {
        height: 350px;
    }
}

/* 作品内容区域 */
.work-content-section {
    background: var(--main-bg-color, #ffffff);
    border-radius: var(--wr-radius-lg);
    box-shadow: var(--wr-shadow-light);
    border: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.05));
    overflow: hidden;
}

.work-content {
    padding: var(--wr-spacing-xl);
}

/* 作品描述区域 */
.work-description {
    margin-bottom: var(--wr-spacing-xl);
}

.work-description .section-title {
    display: flex;
    align-items: center;
    gap: var(--wr-spacing-sm);
    font-size: var(--wr-text-lg);
    font-weight: var(--wr-weight-bold);
    color: var(--key-color, #333);
    margin-bottom: var(--wr-spacing-lg);
    padding-bottom: var(--wr-spacing-sm);
    border-bottom: 2px solid var(--wr-primary-color);
}

.work-description .section-title i {
    color: var(--wr-primary-color);
    font-size: var(--wr-text-lg);
}

.work-description .description-content {
    line-height: 1.6;
    color: var(--key-color, #333);
}

.work-description .description-content p {
    margin-bottom: var(--wr-spacing-md);
}

.work-description .description-content img {
    display: none; /* 隐藏描述中的图片，只在画廊中显示 */
}

/* 3D模型展示区域 */
.work-model-section {
    margin-bottom: var(--wr-spacing-xl);
}

.model-display-container {
    /* background: #00000000;
    border-radius: var(--wr-radius-md);
    overflow: hidden;
    box-shadow: var(--wr-shadow-medium); */
    margin-bottom: var(--wr-spacing-lg);
    width: 100%;
    position: relative;
}

.work-3d-container {
    width: 100%;
    height: 500px;
    background: linear-gradient(135deg, #1a1a1a, #2d2d2d);
    position: relative;
    display: block;
    margin: 0;
    padding: 0;
    border: none;
    overflow: hidden;
    /* 移动端优化 */
    touch-action: manipulation;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    user-select: none;
}

/* 确保3D容器内的canvas占满整个容器 */
.work-3d-container canvas {
    width: 100% !important;
    height: 100% !important;
    display: block !important;
    border: none !important;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
}

/* 3D容器加载状态 */
.work-3d-container .loading-placeholder {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
    color: #fff;
    z-index: 10;
}

.work-3d-container .loading-icon {
    margin-bottom: var(--wr-spacing-md);
}

.work-3d-container .loading-text {
    font-size: var(--wr-text-sm);
    color: rgba(255, 255, 255, 0.8);
    margin: 0;
}

/* 作品集展示区域 */
.work-gallery-section {
    background: var(--main-bg-color, #ffffff);
    border-radius: var(--wr-radius-lg);
    overflow: hidden;
    margin-bottom: var(--wr-spacing-md);
    box-shadow: var(--wr-shadow-light);
    border: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.05));
}

.work-gallery-section .section-title {
    display: flex;
    align-items: center;
    gap: var(--wr-spacing-sm);
    font-size: var(--wr-text-lg);
    font-weight: var(--wr-weight-bold);
    color: var(--key-color, #333);
    margin: 0;
    padding: var(--wr-spacing-md) var(--wr-spacing-lg);
    background: linear-gradient(135deg, rgba(102, 126, 234, 0.08), rgba(118, 75, 162, 0.05));
    border-bottom: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.05));
    position: relative;
}

.work-gallery-section .section-title::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: var(--wr-spacing-lg);
    right: var(--wr-spacing-lg);
    height: 2px;
    background: var(--wr-primary-gradient);
    border-radius: 1px;
}

.work-gallery-section .section-title i {
    color: var(--wr-primary-color);
    font-size: var(--wr-text-xl);
}

/* 优化画廊容器布局 */
.gallery-container {
    background: var(--main-bg-color, #ffffff);
    width: 100%;
    position: relative;
}

/* 不规则瀑布流布局 CSS */
.gallery-masonry-container {
    position: relative;
    width: 100%;
    background: var(--main-bg-color, #ffffff);
    padding: var(--wr-spacing-md);
    border-radius: var(--wr-radius-lg);
    box-shadow: var(--wr-shadow-soft);
}

.gallery-masonry-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    grid-auto-rows: 16px;
    gap: var(--wr-spacing-sm);
    margin-bottom: var(--wr-spacing-lg);
    transition: all var(--wr-transition-normal);
}

.gallery-masonry-item {
    position: relative;
    border-radius: var(--wr-radius-md);
    overflow: hidden;
    background: var(--main-bg-color, #ffffff);
    box-shadow: var(--wr-shadow-soft);
    transition: all var(--wr-transition-bounce);
    cursor: pointer;
    transform: scale(1);
}

.gallery-masonry-item:hover {
    transform: scale(1.03) translateY(-8px);
    box-shadow: var(--wr-shadow-hover);
    z-index: 10;
}

.masonry-item-content {
    position: relative;
    width: 100%;
    height: 100%;
    border-radius: var(--wr-radius-md);
    overflow: hidden;
    display: flex;
    align-items: stretch;
}

.gallery-masonry-item img {
    width: 100%;
    height: 100%;
    display: block;
    border-radius: var(--wr-radius-md);
    transition: transform var(--wr-transition-bounce);
    object-fit: cover;
}

.gallery-masonry-item:hover img {
    transform: scale(1.05);
}

.masonry-item-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(
        to bottom,
        rgba(0, 0, 0, 0.1) 0%,
        rgba(0, 0, 0, 0.3) 50%,
        rgba(0, 0, 0, 0.8) 100%
    );
    opacity: 0;
    transition: opacity var(--wr-transition-normal);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: var(--wr-spacing-md);
    border-radius: var(--wr-radius-md);
}

.gallery-masonry-item:hover .masonry-item-overlay {
    opacity: 1;
}

.masonry-click-hint {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    color: white;
    text-align: center;
    opacity: 0;
    transition: all var(--wr-transition-bounce);
    pointer-events: none;
    background: rgba(0, 0, 0, 0.5);
    padding: 8px 12px;
    border-radius: var(--wr-radius-md);
    backdrop-filter: blur(8px);
}

.masonry-click-hint i {
    font-size: 16px;
    margin-bottom: 2px;
}

.masonry-click-hint span {
    font-size: 12px;
    font-weight: 400;
    white-space: nowrap;
}

.gallery-masonry-item:hover .masonry-click-hint {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1);
}

.masonry-item-info {
    color: white;
    text-align: left;
    transform: translateY(20px);
    transition: transform var(--wr-transition-normal);
}

.gallery-masonry-item:hover .masonry-item-info {
    transform: translateY(0);
}

.masonry-item-title {
    font-size: var(--wr-text-base);
    font-weight: 600;
    margin-bottom: var(--wr-spacing-xs);
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.5);
}

.masonry-item-index {
    font-size: var(--wr-text-sm);
    opacity: 0.9;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.5);
}

/* 布局控制器 */
.gallery-layout-controls {
    display: flex;
}

.layout-control-btn {
    background: transparent;
    border: 2px solid transparent;
    border-radius: var(--wr-radius-md);
    padding: var(--wr-spacing-sm) var(--wr-spacing-md);
    cursor: pointer;
    transition: all var(--wr-transition-bounce);
    color: var(--muted-color, #6c757d);
    font-size: var(--wr-text-base);
    display: flex;
    align-items: center;
    gap: var(--wr-spacing-xs);
    position: relative;
    overflow: hidden;
}

.layout-control-btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: var(--wr-primary-gradient);
    opacity: 0;
    transition: opacity var(--wr-transition-normal);
    border-radius: var(--wr-radius-md);
}

.layout-control-btn.active,
.layout-control-btn:hover {
    color: white;
    border-color: var(--wr-primary-color);
    transform: translateY(-2px);
}

.layout-control-btn.active::before,
.layout-control-btn:hover::before {
    opacity: 1;
}

.layout-control-btn > * {
    position: relative;
    z-index: 1;
}

/* 不同布局模式 */
.gallery-masonry-grid.layout-grid {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    grid-auto-rows: 240px;
}

.gallery-masonry-grid.layout-grid .gallery-masonry-item {
    height: 100%;
}

.gallery-masonry-grid.layout-grid .gallery-masonry-item img {
    height: 100%;
    object-fit: cover;
}

.gallery-masonry-grid.layout-list {
    grid-template-columns: 1fr;
    grid-auto-rows: auto;
}

.gallery-masonry-grid.layout-list .gallery-masonry-item {
    display: flex;
    height: 160px;
}

.gallery-masonry-grid.layout-list .masonry-item-content {
    flex-direction: row;
    display: flex;
}

.gallery-masonry-grid.layout-list .gallery-masonry-item img {
    width: 240px;
    height: 100%;
    object-fit: cover;
}

.gallery-masonry-grid.layout-list .masonry-item-overlay {
    position: static;
    background: var(--main-bg-color, #ffffff);
    opacity: 1;
    flex: 1;
    padding: var(--wr-spacing-lg);
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.gallery-masonry-grid.layout-list .masonry-item-info {
    color: var(--key-color, #333);
    transform: none;
}

.gallery-masonry-grid.layout-list .masonry-item-controls {
    justify-content: flex-start;
    margin-top: var(--wr-spacing-md);
}

.gallery-masonry-grid.layout-list .masonry-btn {
    opacity: 1;
    transform: none;
    background: var(--wr-primary-color);
    color: white;
}

/* 响应式设计 */
@media (max-width: 1200px) {
    .gallery-masonry-grid {
        grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
        gap: var(--wr-spacing-md);
    }
}

@media (max-width: 992px) {
    .gallery-masonry-container {
        padding: var(--wr-spacing-sm);
    }
    
    .gallery-masonry-grid {
        grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
        gap: var(--wr-spacing-sm);
    }
    
    .gallery-layout-controls {
        padding: var(--wr-spacing-sm);
        gap: var(--wr-spacing-xs);
    }
}

@media (max-width: 768px) {
    .gallery-masonry-container {
        padding: var(--wr-spacing-xs);
        border-radius: var(--wr-radius-md);
    }
    
    .gallery-masonry-grid {
        grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
        gap: var(--wr-spacing-xs);
        margin-bottom: var(--wr-spacing-md);
    }
    
    .gallery-layout-controls {
        flex-wrap: wrap;
        gap: var(--wr-spacing-xs);
        padding: var(--wr-spacing-sm);
    }
    
    .layout-control-btn {
        padding: var(--wr-spacing-xs) var(--wr-spacing-sm);
        font-size: var(--wr-text-sm);
        min-width: 80px;
    }
    
    .masonry-item-overlay {
        padding: var(--wr-spacing-sm);
    }
    
    .masonry-click-hint {
        padding: 6px 10px;
    }
    
    .masonry-click-hint i {
        font-size: 14px;
    }
    
    .masonry-click-hint span {
        font-size: 11px;
    }
    
    .masonry-item-title {
        font-size: var(--wr-text-sm);
    }
    
    .masonry-item-index {
        font-size: var(--wr-text-xs);
    }
    
    /* 列表布局移动端优化 */
    .gallery-masonry-grid.layout-list .gallery-masonry-item {
        flex-direction: column;
        height: auto;
    }
    
    .gallery-masonry-grid.layout-list .masonry-item-content {
        flex-direction: column;
    }
    
    .gallery-masonry-grid.layout-list .gallery-masonry-item img {
        width: 100%;
        height: 200px;
    }
    
    .gallery-masonry-grid.layout-list .masonry-item-overlay {
        position: static;
        padding: var(--wr-spacing-md);
    }
}

@media (max-width: 480px) {
    .gallery-masonry-container {
        padding: 8px;
        margin: 0 -8px;
        border-radius: var(--wr-radius-sm);
    }
    
    .gallery-masonry-grid {
        grid-template-columns: 1fr 1fr;
        gap: 8px;
        margin-bottom: var(--wr-spacing-sm);
    }
    
    .gallery-masonry-item {
        border-radius: var(--wr-radius-sm);
    }
    
    .masonry-item-content,
    .gallery-masonry-item img {
        border-radius: var(--wr-radius-sm);
    }
    
    .masonry-item-overlay {
        padding: var(--wr-spacing-xs);
        border-radius: var(--wr-radius-sm);
    }
    
    .masonry-click-hint {
        padding: 4px 8px;
    }
    
    .masonry-click-hint i {
        font-size: 12px;
    }
    
    .masonry-click-hint span {
        font-size: 10px;
    }
    
    .masonry-item-title {
        font-size: 12px;
        margin-bottom: 2px;
    }
    
    .masonry-item-index {
        font-size: 10px;
    }
    
    .gallery-layout-controls {
        flex-direction: row;
        justify-content: space-around;
        gap: var(--wr-spacing-xxs);
        padding: var(--wr-spacing-xs);
    }
    
    .layout-control-btn {
        padding: var(--wr-spacing-xxs) var(--wr-spacing-xs);
        font-size: 12px;
        min-width: 60px;
        flex: 1;
        max-width: 80px;
    }
    
    .layout-control-btn i {
        margin-right: 0;
    }
    
    /* 单列布局适配 */
    .gallery-masonry-grid.layout-list {
        grid-template-columns: 1fr;
    }
    
    /* 网格布局适配 */
    .gallery-masonry-grid.layout-grid {
        grid-template-columns: 1fr 1fr;
        grid-auto-rows: 160px;
    }
}

@media (max-width: 360px) {
    .gallery-masonry-container {
        padding: 8px;
    }
    
    .gallery-masonry-grid {
        gap: 8px;
    }
    
    .masonry-click-hint {
        padding: 3px 6px;
    }
    
    .masonry-click-hint i {
        font-size: 10px;
    }
    
    .masonry-click-hint span {
        font-size: 8px;
    }
    
    .layout-control-btn {
        padding: 6px 8px;
        font-size: 10px;
        min-width: 50px;
    }
    
    .masonry-item-title {
        font-size: 11px;
    }
    
    .masonry-item-index {
        font-size: 9px;
    }
}

/* 触摸设备优化 */
@media (hover: none) and (pointer: coarse) {
    .gallery-masonry-item .masonry-item-overlay {
        opacity: 0;
        transition: opacity var(--wr-transition-fast);
    }
    
    .gallery-masonry-item.touched .masonry-item-overlay {
        opacity: 1;
    }
    
    .masonry-click-hint {
        min-width: 60px;
        min-height: 44px;
        padding: 6px 10px;
    }
    
    .layout-control-btn {
        min-height: 44px;
        padding: var(--wr-spacing-sm) var(--wr-spacing-md);
    }
}

/* 学员作品集页面特殊样式 */
.gallery-header-controls {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--wr-spacing-lg);
    padding: var(--wr-spacing-md);
    background: var(--muted-bg-color, #f8f9fa);
    border-radius: var(--wr-radius-lg);
    border: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.1));
}

.gallery-title-info {
    display: flex;
    align-items: center;
    gap: var(--wr-spacing-md);
}

.gallery-title-info .section-title {
    margin: 0;
    font-size: var(--wr-text-xl);
    font-weight: 600;
    color: var(--key-color, #333);
}

.gallery-title-info .works-count {
    background: var(--wr-primary-color);
    color: white;
    padding: 4px 12px;
    border-radius: var(--wr-radius-full);
    font-size: var(--wr-text-sm);
    font-weight: 500;
}

/* 作品集项目特殊样式 */
.portfolio-item {
    cursor: pointer;
    transition: all var(--wr-transition-bounce);
}

.portfolio-item.clicking {
    transform: scale(0.98);
}

.portfolio-item .portfolio-link {
    display: block;
    width: 100%;
    height: 100%;
    text-decoration: none;
}

.portfolio-item .no-cover-image {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: var(--muted-bg-color, #f8f9fa);
    color: var(--muted-color, #6c757d);
    padding: var(--wr-spacing-xl);
    text-align: center;
    min-height: 200px;
}

.portfolio-item .no-cover-image i {
    font-size: 48px;
    margin-bottom: var(--wr-spacing-sm);
    opacity: 0.5;
}

.portfolio-item .no-cover-image span {
    font-size: var(--wr-text-sm);
    opacity: 0.7;
}

/* 作品集信息样式 */
.portfolio-item .masonry-item-meta {
    display: flex;
    gap: var(--wr-spacing-xs);
    margin: var(--wr-spacing-xs) 0;
    flex-wrap: wrap;
}

.work-type-tag {
    background: var(--wr-primary-color);
    color: white;
    padding: 2px 8px;
    border-radius: var(--wr-radius-sm);
    font-size: 10px;
    font-weight: 500;
}

.difficulty-tag {
    padding: 2px 8px;
    border-radius: var(--wr-radius-sm);
    font-size: 10px;
    font-weight: 500;
    color: white;
}

.difficulty-tag.difficulty-beginner {
    background: #28a745;
}

.difficulty-tag.difficulty-intermediate {
    background: #ffc107;
    color: #333;
}

.difficulty-tag.difficulty-advanced {
    background: #fd7e14;
}

.difficulty-tag.difficulty-expert {
    background: #dc3545;
}

.portfolio-item .masonry-item-stats {
    display: flex;
    gap: var(--wr-spacing-sm);
    font-size: 11px;
    opacity: 0.9;
}

.portfolio-item .stat-item {
    display: flex;
    align-items: center;
    gap: 3px;
}

.portfolio-item .stat-item i {
    font-size: 10px;
}

/* 作品集布局模式 */
.portfolio-grid.layout-grid .gallery-masonry-item {
    height: 240px;
}

.portfolio-grid.layout-list .gallery-masonry-item {
    height: 160px;
    display: flex;
}

.portfolio-grid.layout-list .masonry-item-content {
    flex-direction: row;
}

.portfolio-grid.layout-list .portfolio-link {
    width: 240px;
    flex-shrink: 0;
}

.portfolio-grid.layout-list .masonry-item-overlay {
    position: static;
    background: var(--main-bg-color, #ffffff);
    opacity: 1;
    flex: 1;
    padding: var(--wr-spacing-lg);
    justify-content: center;
}

.portfolio-grid.layout-list .masonry-item-info {
    color: var(--key-color, #333);
    transform: none;
}

.portfolio-grid.layout-list .masonry-click-hint {
    position: absolute;
    bottom: var(--wr-spacing-sm);
    right: var(--wr-spacing-sm);
    background: var(--wr-primary-color);
    color: white;
    opacity: 1;
    transform: none;
}

/* 响应式优化 */
@media (max-width: 768px) {
    .gallery-header-controls {
        flex-direction: column;
        gap: var(--wr-spacing-md);
        align-items: stretch;
    }
    
    .gallery-title-info {
        justify-content: space-between;
    }
    
    .portfolio-grid.layout-list .gallery-masonry-item {
        flex-direction: column;
        height: auto;
    }
    
    .portfolio-grid.layout-list .portfolio-link {
        width: 100%;
        height: 200px;
    }
}

@media (max-width: 480px) {
    .gallery-title-info {
        flex-direction: column;
        gap: var(--wr-spacing-sm);
        align-items: flex-start;
    }
    
    .gallery-title-info .section-title {
        font-size: var(--wr-text-lg);
    }
}

.gallery-main {
    position: relative;
    background: #000;
    width: 100%;
    border-radius: 0;
}

.gallery-viewer {
    position: relative;
    width: 100%;
    height: 450px;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #000;
}

.gallery-image-container {
    position: relative;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}

#gallery-main-image {
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: auto;
    object-fit: contain;
    transition: transform var(--wr-transition-normal);
    display: block;
    margin: 0 auto;
    border-radius: 0;
}

/* 画廊控制按钮优化 - 已移至下方统一管理 */

/* 3D查看器控制按钮优化 - 缩小尺寸，仅保留图标 */
.gallery-btn {
    background: transparent;        /* 移除背景，只保留图标 */
    border: none;
    border-radius: var(--wr-radius-full);
    width: 32px;                   /* 缩小到32px */
    height: 32px;                  /* 缩小到32px */
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s ease;     /* 更快的过渡动画 */
    color: rgba(255, 255, 255, 0.8); /* 半透明白色图标 */
    font-size: 16px;               /* 调整图标大小 */
    box-shadow: none;              /* 移除阴影 */
    backdrop-filter: none;         /* 移除模糊效果 */
    position: relative;
    overflow: visible;             /* 允许悬停效果溢出 */
}

/* 移除伪元素背景 */
.gallery-btn::before {
    display: none;              /* 完全移除背景伪元素 */
}

/* 3D控制按钮悬停效果 - 仅图标变化 */
.gallery-btn:hover {
    background: rgba(255, 255, 255, 0.1); /* 轻微半透明背景 */
    transform: scale(1.1);      /* 轻微放大 */
    color: white;               /* 悬停时图标变为纯白色 */
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2); /* 轻微阴影 */
}

.gallery-btn:hover::before {
    opacity: 0;                 /* 确保伪元素不显示 */
}

.gallery-btn > * {
    position: relative;
    z-index: 1;
}

/* 特殊3D控制按钮优化样式 - 删除复杂效果 */
.gallery-btn.gallery-fullscreen:hover {
    color: #3498db;             /* 最大化按钮：蓝色图标 */
    background: rgba(52, 152, 219, 0.1); /* 轻微蓝色背景 */
}

.gallery-btn.gallery-zoom:hover {
    color: #2ecc71;             /* 缩放按钮：绿色图标 */
    background: rgba(46, 204, 113, 0.1); /* 轻微绿色背景 */
}

.gallery-btn.gallery-prev:hover,
.gallery-btn.gallery-next:hover {
    color: #9b59b6;             /* 导航按钮：紫色图标 */
    background: rgba(155, 89, 182, 0.1); /* 轻微紫色背景 */
}

/* 自动旋转按钮特殊样式 */
.gallery-btn.auto-rotate:hover {
    color: #e67e22;             /* 橙色图标表示旋转 */
    background: rgba(230, 126, 34, 0.1); /* 轻微橙色背景 */
}

/* 活跃状态的自动旋转按钮 */
.gallery-btn.auto-rotate.active {
    color: #e67e22;             /* 激活时保持橙色 */
    background: rgba(230, 126, 34, 0.2); /* 更明显的背景 */
    animation: rotate 2s linear infinite; /* 旋转动画 */
}

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

/* 按钮定位已移至Grid布局中管理 */

/* 画廊按钮组布局优化 */
.gallery-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.3);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity var(--wr-transition-normal);
    pointer-events: none;
}

.gallery-viewer:hover .gallery-overlay {
    opacity: 1;
    pointer-events: all;
}

/* 按钮组布局 - 左右导航 + 右上角功能按钮，优化间距 */
.gallery-overlay {
    display: grid;
    grid-template-areas: 
        "auto-rotate zoom . fullscreen"
        ". . . ."
        "prev . . next";
    grid-template-columns: auto auto 1fr auto;
    grid-template-rows: auto 1fr auto;
    gap: var(--wr-spacing-sm);     /* 缩小按钮间距 */
    padding: var(--wr-spacing-md); /* 缩小整体内边距 */
}

.gallery-prev {
    grid-area: prev;
    justify-self: start;
    align-self: end;
}

.gallery-next {
    grid-area: next;
    justify-self: end;
    align-self: end;
}

.gallery-fullscreen {
    grid-area: fullscreen;
    justify-self: end;
    align-self: start;
    position: static;
}

.gallery-zoom {
    grid-area: zoom;
    justify-self: start;
    align-self: start;
    position: static;
}

/* 添加自动旋转按钮定位 */
.gallery-btn.auto-rotate {
    grid-area: auto-rotate;
    justify-self: start;
    align-self: start;
    position: static;
}

/* ================================
   3D窗口控制按钮样式重写 - 完全透明化
   ================================ */

/* 3D控制面板按钮组样式 */
#work-3d-controls {
    background: transparent !important;  /* 移除面板背景 */
    padding: 0 !important;              /* 移除内边距 */
    gap: 4px !important;                /* 缩小按钮间距 */
}

/* 3D控制按钮基础样式 - 完全透明 */
#auto-rotate-btn,
#maximize-btn,
#resource-download-btn {
    background: transparent !important;  /* 完全透明背景 */
    border: none !important;
    width: 28px !important;             /* 缩小按钮尺寸 */
    height: 28px !important;
    color: rgba(255, 255, 255, 0.8) !important; /* 半透明白色图标 */
    transition: all 0.2s ease !important;
    box-shadow: none !important;        /* 移除阴影 */
    border-radius: 0 !important;        /* 移除圆角 */
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.8) !important; /* 图标阴影确保可见性 */
}

/* 按钮悬停效果 - 仅图标变化 */
#auto-rotate-btn:hover,
#maximize-btn:hover,
#resource-download-btn:hover {
    background: transparent !important; /* 悬停时保持透明 */
    color: white !important;            /* 悬停时图标变为纯白 */
    transform: scale(1.1) !important;   /* 轻微放大 */
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.9) !important; /* 增强阴影 */
}

/* 特定按钮颜色 */
#auto-rotate-btn:hover {
    color: #e67e22 !important;          /* 自动旋转：橙色 */
}

#maximize-btn:hover {
    color: #3498db !important;          /* 最大化：蓝色 */
}

#resource-download-btn:hover {
    color: #2ecc71 !important;          /* 下载：绿色 */
}

/* 自动旋转激活状态 */
#auto-rotate-btn.active {
    color: #e67e22 !important;
    background: transparent !important;
    animation: rotateIcon 2s linear infinite !important;
}

@keyframes rotateIcon {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

/* 画廊计数器 */
.gallery-counter {
    position: absolute;
    bottom: var(--wr-spacing-lg);
    left: 50%;
    transform: translateX(-50%);
    background: rgba(0, 0, 0, 0.7);
    color: white;
    padding: var(--wr-spacing-xs) var(--wr-spacing-sm);
    border-radius: 16px;
    font-size: var(--wr-text-sm);
    font-weight: var(--wr-weight-medium);
    backdrop-filter: blur(5px);
    z-index: 10;
}

/* 缩略图区域优化 */
.gallery-thumbnails {
    display: flex;
    padding: var(--wr-spacing-lg);
    gap: var(--wr-spacing-sm);
    overflow-x: auto;
    background: linear-gradient(135deg, rgba(248, 249, 250, 0.8), rgba(240, 242, 247, 0.6));
    border-top: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.05));
    scrollbar-width: thin;
    scrollbar-color: var(--wr-primary-color) transparent;
}

.gallery-thumbnails::-webkit-scrollbar {
    height: 6px;
}

.gallery-thumbnails::-webkit-scrollbar-track {
    background: rgba(0, 0, 0, 0.05);
    border-radius: 3px;
}

.gallery-thumbnails::-webkit-scrollbar-thumb {
    background: var(--wr-primary-gradient);
    border-radius: 3px;
}

.gallery-thumbnails::-webkit-scrollbar-thumb:hover {
    background: var(--wr-secondary-gradient);
}

.thumbnail-item {
    flex-shrink: 0;
    width: 70px;
    height: 70px;
    border-radius: var(--wr-radius-sm);
    overflow: hidden;
    cursor: pointer;
    border: 3px solid transparent;
    transition: all var(--wr-transition-bounce);
    position: relative;
    background: #fff;
    box-shadow: var(--wr-shadow-light);
}

.thumbnail-item:hover {
    transform: translateY(-2px);
    box-shadow: var(--wr-shadow-medium);
    border-color: rgba(102, 126, 234, 0.3);
}

.thumbnail-item.active {
    border-color: var(--wr-primary-color);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(240, 68, 148, 0.3);
}

.thumbnail-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--wr-transition-normal);
}

.thumbnail-item:hover img {
    transform: scale(1.05);
}

/* 无画廊状态 */
.no-gallery {
    text-align: center;
    padding: var(--wr-spacing-xxl);
    /* background: var(--muted-bg-color, #f8f9fa); */
    color: var(--muted-color, #6c757d);
    border-radius: var(--wr-radius-md);
    margin: var(--wr-spacing-lg);
}

.no-gallery p {
    margin: 0;
    font-size: var(--wr-text-base);
    color: var(--muted-color, #6c757d);
}

.no-gallery i {
    font-size: 48px;
    color: var(--muted-3-color, #adb5bd);
    margin-bottom: var(--wr-spacing-md);
    display: block;
}

/* 作品详细信息区域 */
.work-details-section {
    margin-top: var(--wr-spacing-xl);
    padding-top: var(--wr-spacing-xl);
    border-top: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.1));
}

.work-details-section .section-title {
    display: flex;
    align-items: center;
    gap: var(--wr-spacing-sm);
    font-size: var(--wr-text-lg);
    font-weight: var(--wr-weight-bold);
    color: var(--key-color, #333);
    margin-bottom: var(--wr-spacing-lg);
    padding-bottom: var(--wr-spacing-sm);
    border-bottom: 2px solid var(--wr-primary-color);
}

.work-details-section .section-title i {
    color: var(--wr-primary-color);
}

/* 专题分类区域 */
.topic-category-section {
    margin-bottom: var(--wr-spacing-xl);
}

.topic-category-section .subsection-title {
    font-size: var(--wr-text-base);
    font-weight: var(--wr-weight-semibold);
    color: var(--key-color, #333);
    margin-bottom: var(--wr-spacing-md);
}

.topic-category-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--wr-spacing-lg);
    background: linear-gradient(135deg, rgba(102, 126, 234, 0.08), rgba(118, 75, 162, 0.05));
    border-radius: var(--wr-radius-md);
    border: 1px solid rgba(102, 126, 234, 0.15);
}

.topic-category-info {
    flex: 1;
}

.topic-category-name {
    font-size: var(--wr-text-base);
    font-weight: var(--wr-weight-semibold);
    color: var(--wr-secondary-color);
    margin: 0 0 4px 0;
}

.topic-category-description {
    font-size: var(--wr-text-sm);
    color: var(--muted-color, #6c757d);
    margin: 0;
    line-height: 1.4;
}

.topic-category-link {
    flex-shrink: 0;
    margin-left: var(--wr-spacing-lg);
}

/* 作品详情网格 */
.work-details-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--wr-spacing-lg);
    margin-bottom: var(--wr-spacing-xl);
}

.detail-item {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: var(--wr-spacing-md);
    background: var(--muted-bg-color, #f8f9fa);
    border-radius: var(--wr-radius-sm);
    /* border-left: 3px solid var(--wr-primary-color); */
}

.detail-label {
    font-size: var(--wr-text-xs);
    color: var(--muted-color, #6c757d);
    font-weight: var(--wr-weight-medium);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.detail-value {
    font-size: var(--wr-text-sm);
    color: var(--key-color, #333);
    font-weight: var(--wr-weight-semibold);
}

/* 难度等级颜色 */
.detail-value.difficulty-beginner {
    color: #27ae60;
}

.detail-value.difficulty-intermediate {
    color: #f39c12;
}

.detail-value.difficulty-advanced {
    color: #e67e22;
}

.detail-value.difficulty-expert {
    color: #e74c3c;
}

/* 工具列表区域 */
.tools-section {
    margin-bottom: var(--wr-spacing-xl);
}

.tools-section .subsection-title {
    font-size: var(--wr-text-base);
    font-weight: var(--wr-weight-semibold);
    color: var(--key-color, #333);
    margin-bottom: var(--wr-spacing-md);
}

.tools-list {
    display: flex;
    flex-wrap: wrap;
    gap: var(--wr-spacing-sm);
}

.tool-tag {
    padding: var(--wr-spacing-xs) var(--wr-spacing-sm);
    background: var(--wr-primary-gradient);
    color: white;
    border-radius: 16px;
    font-size: var(--wr-text-xs);
    font-weight: var(--wr-weight-medium);
    white-space: nowrap;
}

/* 创作灵感区域 */
.inspiration-section {
    margin-bottom: var(--wr-spacing-xl);
}

.inspiration-section .subsection-title {
    font-size: var(--wr-text-base);
    font-weight: var(--wr-weight-semibold);
    color: var(--key-color, #333);
    margin-bottom: var(--wr-spacing-md);
}

.inspiration-text {
    padding: var(--wr-spacing-lg);
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.8), rgba(248, 249, 255, 0.6));
    border-radius: var(--wr-radius-md);
    /* border-left: 4px solid var(--wr-primary-color); */
    font-size: var(--wr-text-sm);
    line-height: 1.6;
    color: var(--key-color, #333);
    margin: 0;
    font-style: italic;
}

/* 标签区域 */
.tags-section {
    margin-bottom: var(--wr-spacing-xl);
}

.tags-section .subsection-title {
    font-size: var(--wr-text-base);
    font-weight: var(--wr-weight-semibold);
    color: var(--key-color, #333);
    margin-bottom: var(--wr-spacing-md);
}

.tags-list {
    display: flex;
    flex-wrap: wrap;
    gap: var(--wr-spacing-xs);
}

.tag-item {
    padding: 4px var(--wr-spacing-sm);
    background: rgba(102, 126, 234, 0.1);
    color: var(--wr-secondary-color);
    border-radius: 12px;
    font-size: var(--wr-text-xs);
    font-weight: var(--wr-weight-medium);
    border: 1px solid rgba(102, 126, 234, 0.2);
}

/* 无作品信息状态 */
.no-work-info {
    text-align: center;
    padding: var(--wr-spacing-xxl);
    background: var(--muted-bg-color, #f8f9fa);
    border-radius: var(--wr-radius-md);
    color: var(--muted-color, #6c757d);
}

.no-work-info p {
    margin: 0 0 var(--wr-spacing-sm) 0;
}

/* 作品集互动区域 - 紧跟在画廊下方 */
.work-gallery-interaction {
    background: linear-gradient(135deg, rgba(102, 126, 234, 0.03), rgba(118, 75, 162, 0.02));
    border-top: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.05));
    padding: var(--wr-spacing-lg);
    margin-top: 0;
}

.gallery-interaction-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--wr-spacing-md);
}

.gallery-interaction-title {
    font-size: var(--wr-text-base);
    font-weight: var(--wr-weight-semibold);
    color: var(--key-color, #333);
    display: flex;
    align-items: center;
    gap: var(--wr-spacing-sm);
}

.gallery-interaction-title i {
    color: var(--wr-primary-color);
    font-size: var(--wr-text-base);
}

.gallery-stats {
    display: flex;
    gap: var(--wr-spacing-lg);
    font-size: var(--wr-text-sm);
    color: var(--muted-color, #6c757d);
}

.gallery-stat-item {
    display: flex;
    align-items: center;
    gap: 4px;
}

.gallery-stat-item i {
    color: var(--wr-primary-color);
    font-size: var(--wr-text-sm);
}

/* 互动按钮重新设计 */
.interaction-buttons {
    display: flex;
    gap: var(--wr-spacing-sm);
    justify-content: center;
    flex-wrap: wrap;
}

.interaction-btn {
    display: flex;
    align-items: center;
    gap: var(--wr-spacing-sm);
    padding: var(--wr-spacing-md) var(--wr-spacing-lg);
    background: var(--main-bg-color, #ffffff);
    border: 2px solid var(--main-border-color, rgba(0, 0, 0, 0.1));
    border-radius: var(--wr-radius-md);
    cursor: pointer;
    transition: all var(--wr-transition-bounce);
    color: var(--muted-color, #6c757d);
    text-decoration: none;
    font-size: var(--wr-text-sm);
    font-weight: var(--wr-weight-medium);
    min-width: 100px;
    justify-content: center;
    position: relative;
    overflow: hidden;
    box-shadow: var(--wr-shadow-light);
}

.interaction-btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: var(--wr-primary-gradient);
    transition: all 0.4s ease;
    z-index: 0;
}

.interaction-btn:hover::before {
    left: 0;
}

.interaction-btn > * {
    position: relative;
    z-index: 1;
}

.interaction-btn:hover {
    color: white;
    border-color: var(--wr-primary-color);
    transform: translateY(-2px);
    box-shadow: var(--wr-shadow-medium);
}

.interaction-btn i {
    font-size: var(--wr-text-lg);
    transition: all var(--wr-transition-normal);
}

.interaction-btn:hover i {
    transform: scale(1.1) rotate(5deg);
}

.interaction-btn .btn-text {
    font-weight: var(--wr-weight-medium);
    white-space: nowrap;
}

.interaction-btn .like-count {
    font-weight: var(--wr-weight-bold);
    margin-left: 2px;
}

/* 点赞按钮特殊效果 */
.interaction-btn.like-btn:hover i {
    animation: wr-pulse 0.6s ease-in-out;
    color: #ff6b6b;
}

.interaction-btn.like-btn.liked {
    background: linear-gradient(135deg, #ff6b6b, #ff8e8e);
    color: white;
    border-color: #ff6b6b;
}

.interaction-btn.like-btn.liked::before {
    left: 0;
    background: linear-gradient(135deg, #ff8e8e, #ffa8a8);
}

/* 分享按钮特殊效果 */
.interaction-btn.share-btn:hover i {
    animation: wr-float 1s ease-in-out infinite;
    color: #4CAF50;
}

/* 收藏按钮特殊效果 */
.interaction-btn.collect-btn:hover i {
    animation: wr-pulse 0.8s ease-in-out;
    color: #FFC107;
}

.interaction-btn.collect-btn.collected {
    background: linear-gradient(135deg, #FFC107, #FFD54F);
    color: white;
    border-color: #FFC107;
}

/* 互动统计显示 */
.interaction-stats {
    display: flex;
    justify-content: center;
    gap: var(--wr-spacing-xl);
    margin-top: var(--wr-spacing-md);
    padding-top: var(--wr-spacing-md);
    border-top: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.05));
}

.interaction-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
}

.interaction-stat-number {
    font-size: var(--wr-text-lg);
    font-weight: var(--wr-weight-bold);
    color: var(--key-color, #333);
    line-height: 1;
}

.interaction-stat-label {
    font-size: var(--wr-text-xs);
    color: var(--muted-color, #6c757d);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* 互动区域独立显示 - 如果需要在其他位置 */
.work-interaction-section {
    background: var(--main-bg-color, #ffffff);
    border-radius: var(--wr-radius-lg);
    padding: var(--wr-spacing-lg);
    box-shadow: var(--wr-shadow-light);
    border: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.05));
    margin-top: var(--wr-spacing-lg);
    display: none; /* 默认隐藏，因为现在整合到画廊区域 */
}

/* 响应式优化 */
@media (max-width: 992px) {
    .work-display-container {
        padding: var(--wr-spacing-md) var(--wr-spacing-sm);
    }
    
    .work-details-grid {
        grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
        gap: var(--wr-spacing-md);
    }
    
    .topic-category-card {
        flex-direction: column;
        align-items: stretch;
        gap: var(--wr-spacing-md);
    }
    
    .topic-category-link {
        margin-left: 0;
        align-self: flex-end;
    }
}

@media (max-width: 768px) {
    .work-display-header {
        padding: var(--wr-spacing-md);
    }
    
    .student-info-bar {
        flex-direction: column;
        text-align: center;
        gap: var(--wr-spacing-sm);
    }
    
    .student-info-bar .student-details {
        text-align: center;
    }
    
    .student-info-bar .student-meta {
        justify-content: center;
    }
    
    .student-details-full.inline-info {
        justify-content: center;
    }
    
    .work-title {
        font-size: var(--wr-text-xl);
        text-align: center;
    }
    
    .work-meta {
        justify-content: center;
    }
    
    .work-content {
        padding: var(--wr-spacing-lg);
    }
    
    .work-details-grid {
        grid-template-columns: 1fr;
        gap: var(--wr-spacing-sm);
    }
    
    .interaction-buttons {
        flex-wrap: wrap;
        gap: var(--wr-spacing-sm);
    }
    
    .interaction-btn {
        flex: 1;
        min-width: 70px;
        padding: var(--wr-spacing-sm);
    }
    
    .work-3d-container {
        height: 350px;
        /* 移动端特殊处理 */
        min-height: 300px;
    }
    
    .gallery-viewer {
        height: 300px;
    }
    
    .gallery-interaction-header {
        flex-direction: column;
        gap: var(--wr-spacing-sm);
        text-align: center;
    }
    
    .gallery-stats {
        justify-content: center;
    }
    
    .interaction-buttons {
        gap: var(--wr-spacing-xs);
    }
    
    .interaction-btn {
        flex: 1;
        min-width: 80px;
        padding: var(--wr-spacing-sm);
        font-size: var(--wr-text-xs);
    }
    
    .interaction-btn i {
        font-size: var(--wr-text-base);
    }
    
    .interaction-stats {
        gap: var(--wr-spacing-lg);
    }
    
    .author-actions {
        flex-direction: column;
        gap: var(--wr-spacing-xs);
    }
    
    .author-actions .but {
        justify-content: center;
        width: 100%;
    }
}

@media (max-width: 480px) {
    .student-info-bar .student-avatar img {
        width: 40px;
        height: 40px;
    }
    
    .work-title {
        font-size: var(--wr-text-lg);
    }
    
    .work-meta .meta-item {
        font-size: var(--wr-text-xs);
        padding: 2px var(--wr-spacing-xs);
    }
    
    .work-description .section-title,
    .work-details-section .section-title {
        font-size: var(--wr-text-base);
        flex-direction: column;
        gap: 4px;
        text-align: center;
    }
    
    .work-content {
        padding: var(--wr-spacing-md);
    }
    
    .topic-category-card {
        padding: var(--wr-spacing-md);
    }
    
    .interaction-btn {
        padding: var(--wr-spacing-xs) var(--wr-spacing-sm);
    }
    
    .interaction-btn i {
        font-size: var(--wr-text-base);
    }
    
    .work-3d-container {
        height: 280px;
        /* 小屏幕设备特殊处理 */
        min-height: 250px;
    }
    
    .gallery-viewer {
        height: 250px;
    }
    
    .gallery-btn {
        width: 40px;
        height: 40px;
        font-size: var(--wr-text-sm);
    }
    
    .gallery-overlay {
        padding: var(--wr-spacing-sm);
        gap: var(--wr-spacing-sm);
    }
    
    .gallery-thumbnails {
        padding: var(--wr-spacing-md);
        gap: var(--wr-spacing-xs);
    }
    
    .thumbnail-item {
        width: 50px;
        height: 50px;
    }
    
    .work-gallery-interaction {
        padding: var(--wr-spacing-md);
    }
    
    .gallery-interaction-title {
        font-size: var(--wr-text-sm);
    }
    
    .gallery-stats {
        gap: var(--wr-spacing-md);
        font-size: var(--wr-text-xs);
    }
    
    .interaction-btn {
        padding: var(--wr-spacing-xs) var(--wr-spacing-sm);
        font-size: 11px;
        min-width: 70px;
    }
    
    .interaction-btn i {
        font-size: var(--wr-text-sm);
    }
    
    .interaction-stats {
        gap: var(--wr-spacing-md);
        margin-top: var(--wr-spacing-sm);
        padding-top: var(--wr-spacing-sm);
    }
    
    .interaction-stat-number {
        font-size: var(--wr-text-base);
    }
    
    .author-actions .but {
        font-size: var(--wr-text-xs);
        padding: var(--wr-spacing-xs) var(--wr-spacing-sm);
    }
    
    /* 固定互动面板响应式 */
    .fixed-interaction-panel {
        bottom: 15px;
        left: 15px;
    }
    
    .interaction-toggle {
        width: 50px;
        height: 50px;
    }
    
    .interaction-toggle i {
        font-size: 16px;
    }
    
    .toggle-text {
        font-size: 9px;
    }
    
    .interaction-panel-content {
        min-width: 260px;
        max-width: 280px;
        bottom: 60px;
    }
    
    .interaction-panel-header {
        padding: 12px;
    }
    
    .panel-title {
        font-size: 14px;
    }
    
    .interaction-panel-buttons {
        padding: 12px;
        gap: 6px;
    }
    
    .panel-btn {
        padding: 10px 12px;
        gap: 10px;
    }
    
    .panel-btn i {
        font-size: 16px;
    }
    
    .btn-label {
        font-size: 13px;
    }
    
    .interaction-panel-stats {
        padding: 12px;
    }
    
    .stat-number {
        font-size: 16px;
    }
}

/* 暗色主题适配 */
.dark-theme .work-display-header,
.dark-theme .work-content-section,
.dark-theme .work-gallery-section {
    background: var(--main-bg-color);
    border-color: var(--main-border-color);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
}

.dark-theme .student-info-bar {
    background: linear-gradient(135deg, rgba(102, 126, 234, 0.12), rgba(118, 75, 162, 0.08));
    border-color: rgba(102, 126, 234, 0.25);
}

.dark-theme .topic-category-card {
    background: linear-gradient(135deg, rgba(102, 126, 234, 0.15), rgba(118, 75, 162, 0.1));
    border-color: rgba(102, 126, 234, 0.3);
}

.dark-theme .detail-item {
    background: var(--muted-bg-color);
    /* border-left-color: var(--wr-primary-color); */
}

.dark-theme .inspiration-text {
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.05), rgba(248, 249, 255, 0.03));
    /* border-left-color: var(--wr-primary-color); */
}

/* 暗色主题无内容状态样式已注释 */

.dark-theme .work-gallery-interaction {
    background: linear-gradient(135deg, rgba(102, 126, 234, 0.08), rgba(118, 75, 162, 0.05));
    border-top-color: var(--main-border-color);
}

.dark-theme .gallery-thumbnails {
    background: linear-gradient(135deg, rgba(30, 30, 30, 0.8), rgba(40, 40, 40, 0.6));
    border-top-color: var(--main-border-color);
}

.dark-theme .thumbnail-item {
    background: var(--muted-bg-color);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

.dark-theme .interaction-btn {
    background: var(--main-bg-color);
    border-color: var(--main-border-color);
    color: var(--muted-color);
}

.dark-theme .interaction-btn:hover {
    color: white;
    border-color: var(--wr-primary-color);
}

.dark-theme .gallery-btn {
    background: rgba(255, 255, 255, 0.15);
    color: white;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
}

.dark-theme .gallery-btn:hover {
    background: rgba(255, 255, 255, 0.25);
    color: white;
    box-shadow: 0 8px 25px rgba(102, 126, 234, 0.3);
}

.dark-theme .gallery-btn::before {
    background: linear-gradient(135deg, rgba(102, 126, 234, 0.8), rgba(118, 75, 162, 0.6));
}

/* 暗色主题按钮样式已整合到作者操作按钮中 */

/* 固定互动面板暗色主题 */
.dark-theme .interaction-panel-content {
    background: var(--main-bg-color);
    border-color: var(--main-border-color);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.4);
}

.dark-theme .interaction-panel-header {
    background: linear-gradient(135deg, rgba(102, 126, 234, 0.08), rgba(118, 75, 162, 0.05));
    border-bottom-color: var(--main-border-color);
}

.dark-theme .panel-title {
    color: var(--key-color);
}

.dark-theme .panel-close {
    color: var(--muted-color);
}

.dark-theme .panel-close:hover {
    background: var(--muted-bg-color);
    color: var(--key-color);
}

.dark-theme .panel-btn {
    background: var(--muted-bg-color);
    border-color: transparent;
}

.dark-theme .btn-label {
    color: var(--key-color);
}

.dark-theme .interaction-panel-stats {
    background: linear-gradient(135deg, rgba(30, 30, 30, 0.8), rgba(40, 40, 40, 0.6));
    border-top-color: var(--main-border-color);
}

.dark-theme .stat-number {
    color: var(--key-color);
}

.dark-theme .stat-label {
    color: var(--muted-color);
}

/* ================================
   固定位置互动面板 - 左下角
   ================================ */

.fixed-interaction-panel {
    position: fixed;
    bottom: 20px;
    left: 20px;
    z-index: 1000;
    font-family: inherit;
}

/* 防止与其他元素冲突 */
.fixed-interaction-panel * {
    box-sizing: border-box;
}

.fixed-interaction-panel button {
    outline: none;
    border: none;
}

.fixed-interaction-panel button:focus {
    outline: 2px solid rgba(102, 126, 234, 0.5);
    outline-offset: 2px;
}

.interaction-toggle {
    background: #1f1f1f;
    color: white;
    border: none;
    border-radius: 50%;
    width: 60px;
    height: 60px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.4);
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
    user-select: none;
}

.interaction-toggle::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, #667eea, #764ba2);
    opacity: 0;
    transition: opacity 0.3s ease;
}

.interaction-toggle:hover::before {
    opacity: 1;
}

.interaction-toggle > * {
    position: relative;
    z-index: 1;
}

.interaction-toggle:hover {
    transform: scale(1.05);
    box-shadow: 0 6px 25px rgba(0, 0, 0, 0.5);
}

.interaction-toggle i {
    font-size: 18px;
    margin-bottom: 2px;
    display: block;
}

.toggle-text {
    font-size: 10px;
    font-weight: 600;
    line-height: 1;
    display: block;
}

/* 互动面板内容 */
.interaction-panel-content {
    position: absolute;
    bottom: 70px;
    left: 0;
    background: var(--main-bg-color, #ffffff);
    border-radius: 12px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.2);
    border: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.1));
    min-width: 280px;
    max-width: 320px;
    opacity: 0;
    visibility: hidden;
    transform: translateY(20px) scale(0.95);
    transition: all 0.3s cubic-bezier(0.68, -0.55, 0.265, 1.55);
    backdrop-filter: blur(10px);
}

.interaction-panel-content.active {
    opacity: 1;
    visibility: visible;
    transform: translateY(0) scale(1);
}

.interaction-panel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px;
    border-bottom: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.05));
    background: linear-gradient(135deg, rgba(102, 126, 234, 0.05), rgba(118, 75, 162, 0.03));
    border-radius: 12px 12px 0 0;
}

.panel-title {
    font-size: 16px;
    font-weight: 600;
    color: var(--key-color, #333);
    margin: 0;
}

.panel-close {
    background: none;
    border: none;
    color: var(--muted-color, #6c757d);
    cursor: pointer;
    width: 28px;
    height: 28px;
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    font-size: 14px;
}

.panel-close:hover {
    background: var(--muted-bg-color, #f8f9fa);
    color: var(--key-color, #333);
    transform: scale(1.1);
}

/* 面板按钮 */
.interaction-panel-buttons {
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.panel-btn {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    background: var(--muted-bg-color, #f8f9fa);
    border: 2px solid transparent;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.2s ease;
    text-align: left;
    width: 100%;
    position: relative;
    overflow: hidden;
    font-size: 14px;
}

.panel-btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: var(--wr-primary-gradient);
    opacity: 0;
    transition: opacity 0.2s ease;
}

.panel-btn:hover::before {
    opacity: 0.08;
}

.panel-btn > * {
    position: relative;
    z-index: 1;
}

.panel-btn i {
    font-size: 18px;
    width: 20px;
    text-align: center;
    transition: all 0.2s ease;
    flex-shrink: 0;
}

.btn-label {
    flex: 1;
    font-size: 14px;
    font-weight: 500;
    color: var(--key-color, #333);
    margin: 0;
}

.btn-count {
    font-size: 12px;
    background: #1f1f1f;
    color: white;
    padding: 4px 8px;
    border-radius: 12px;
    min-width: 24px;
    text-align: center;
    font-weight: 600;
    flex-shrink: 0;
}

/* 按钮特殊效果 */
.panel-btn.like-btn:hover {
    border-color: #ff6b6b;
    background: rgba(255, 107, 107, 0.1);
    transform: translateY(-1px);
}

.panel-btn.like-btn:hover i {
    color: #ff6b6b;
    transform: scale(1.1);
}

.panel-btn.share-btn:hover {
    border-color: #4CAF50;
    background: rgba(76, 175, 80, 0.1);
    transform: translateY(-1px);
}

.panel-btn.share-btn:hover i {
    color: #4CAF50;
    transform: scale(1.1);
}

.panel-btn.collect-btn:hover {
    border-color: #FFC107;
    background: rgba(255, 193, 7, 0.1);
    transform: translateY(-1px);
}

.panel-btn.collect-btn:hover i {
    color: #FFC107;
    transform: scale(1.1);
}

/* 面板统计 */
.interaction-panel-stats {
    display: flex;
    padding: 16px;
    border-top: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.05));
    background: linear-gradient(135deg, rgba(248, 249, 250, 0.8), rgba(240, 242, 247, 0.6));
    border-radius: 0 0 12px 12px;
}

.stat-item {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
}

.stat-number {
    font-size: 18px;
    font-weight: 700;
    color: var(--key-color, #333);
    line-height: 1;
    margin: 0;
}

.stat-label {
    font-size: 11px;
    color: var(--muted-color, #6c757d);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    font-weight: 500;
    margin: 0;
}

/* ================================
   全屏画廊模态框样式
   ================================ */

.gallery-modal {
    display: none;
    position: fixed;
    z-index: 9999;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.95);
    backdrop-filter: blur(5px);
}

.gallery-modal.show {
    display: flex;
    align-items: center;
    justify-content: center;
}

.gallery-modal-content {
    position: relative;
    width: 90%;
    max-width: 1200px;
    height: 90vh;
    background: var(--main-bg-color, #ffffff);
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
    display: flex;
    flex-direction: column;
}

.gallery-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    background: linear-gradient(135deg, rgba(102, 126, 234, 0.05), rgba(118, 75, 162, 0.03));
    border-bottom: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.1));
    flex-shrink: 0;
}

.gallery-modal-title {
    font-size: 18px;
    font-weight: 600;
    color: var(--key-color, #333);
    display: flex;
    align-items: center;
    gap: 8px;
}

.gallery-modal-controls {
    display: flex;
    align-items: center;
    gap: 8px;
}

.gallery-modal-btn {
    width: 40px;
    height: 40px;
    border: none;
    border-radius: 8px;
    background: var(--muted-bg-color, #f8f9fa);
    color: var(--key-color, #333);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    transition: all 0.2s ease;
}

.gallery-modal-btn:hover {
    background: var(--wr-primary-color);
    color: white;
    transform: scale(1.05);
}

.gallery-modal-body {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #000;
    position: relative;
    overflow: hidden;
}

.gallery-modal-image-container {
    position: relative;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

#modal-main-image {
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: auto;
    object-fit: contain;
    display: block;
}

.gallery-modal-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 50px;
    height: 50px;
    border: none;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.9);
    color: var(--key-color, #333);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    transition: all 0.2s ease;
    backdrop-filter: blur(10px);
}

.gallery-modal-nav:hover {
    background: white;
    transform: translateY(-50%) scale(1.1);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

.gallery-modal-prev {
    left: 20px;
}

.gallery-modal-next {
    right: 20px;
}

.gallery-modal-footer {
    flex-shrink: 0;
    background: var(--main-bg-color, #ffffff);
    border-top: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.1));
    max-height: 120px;
    overflow: hidden;
}

.gallery-modal-thumbnails {
    display: flex;
    padding: 12px;
    gap: 8px;
    overflow-x: auto;
    scrollbar-width: thin;
    scrollbar-color: var(--wr-primary-color) transparent;
}

.gallery-modal-thumbnails::-webkit-scrollbar {
    height: 6px;
}

.gallery-modal-thumbnails::-webkit-scrollbar-track {
    background: rgba(0, 0, 0, 0.05);
    border-radius: 3px;
}

.gallery-modal-thumbnails::-webkit-scrollbar-thumb {
    background: var(--wr-primary-color);
    border-radius: 3px;
}

.modal-thumbnail-item {
    flex-shrink: 0;
    width: 80px;
    height: 80px;
    border-radius: 8px;
    overflow: hidden;
    cursor: pointer;
    border: 3px solid transparent;
    transition: all 0.2s ease;
    background: #fff;
}

.modal-thumbnail-item:hover {
    border-color: rgba(102, 126, 234, 0.5);
    transform: translateY(-2px);
}

.modal-thumbnail-item.active {
    border-color: var(--wr-primary-color);
    transform: translateY(-2px);
}

.modal-thumbnail-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* 简化分享面板 - 直接在互动面板中 */
.share-panel {
    display: none;
    position: absolute;
    bottom: 70px;
    left: 0;
    background: var(--main-bg-color, #ffffff);
    border-radius: 12px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.2);
    border: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.1));
    min-width: 320px;
    max-width: 380px;
    opacity: 0;
    visibility: hidden;
    transform: translateY(20px) scale(0.95);
    transition: all 0.3s cubic-bezier(0.68, -0.55, 0.265, 1.55);
    backdrop-filter: blur(10px);
    z-index: 1001;
}

.share-panel.active {
    display: block;
    opacity: 1;
    visibility: visible;
    transform: translateY(0) scale(1);
}

.share-panel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    background: linear-gradient(135deg, rgba(102, 126, 234, 0.05), rgba(118, 75, 162, 0.03));
    border-bottom: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.05));
    border-radius: 12px 12px 0 0;
}

.share-panel-title {
    font-size: 16px;
    font-weight: 600;
    color: var(--key-color, #333);
    margin: 0;
    display: flex;
    align-items: center;
    gap: 8px;
}

.share-panel-close {
    background: none;
    border: none;
    color: var(--muted-color, #6c757d);
    cursor: pointer;
    width: 28px;
    height: 28px;
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    font-size: 14px;
}

.share-panel-close:hover {
    background: var(--muted-bg-color, #f8f9fa);
    color: var(--key-color, #333);
    transform: scale(1.1);
}

.share-panel-body {
    padding: 20px;
}

.share-options {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
    margin-bottom: 20px;
}

.share-option {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 16px 12px;
    background: var(--muted-bg-color, #f8f9fa);
    border: 2px solid transparent;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.2s ease;
    text-decoration: none;
    color: var(--key-color, #333);
    position: relative;
    overflow: hidden;
}

.share-option::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    opacity: 0;
    transition: opacity 0.2s ease;
}

.share-option:hover::before {
    opacity: 0.1;
}

.share-option > * {
    position: relative;
    z-index: 1;
}

.share-option i {
    font-size: 24px;
    transition: all 0.2s ease;
}

.share-option span {
    font-size: 12px;
    font-weight: 500;
    margin: 0;
}

/* QQ分享 */
.share-option.qq-share:hover {
    background: rgba(18, 183, 245, 0.1);
    border-color: #12b7f5;
    color: #12b7f5;
}

.share-option.qq-share:hover::before {
    background: #12b7f5;
}

/* 微信分享 */
.share-option.wechat-share:hover {
    background: rgba(7, 193, 96, 0.1);
    border-color: #07c160;
    color: #07c160;
}

.share-option.wechat-share:hover::before {
    background: #07c160;
}

/* 复制链接 */
.share-option.copy-link:hover {
    background: rgba(102, 126, 234, 0.1);
    border-color: #667eea;
    color: #667eea;
}

.share-option.copy-link:hover::before {
    background: #667eea;
}

/* 二维码 */
.share-option.qrcode-share:hover {
    background: rgba(118, 75, 162, 0.1);
    border-color: #764ba2;
    color: #764ba2;
}

.share-option.qrcode-share:hover::before {
    background: #764ba2;
}

/* 链接输入框 */
.share-url {
    margin-top: 16px;
}

.share-url-label {
    font-size: 14px;
    font-weight: 500;
    color: var(--key-color, #333);
    margin-bottom: 8px;
    display: block;
}

.share-url-input {
    display: flex;
    gap: 8px;
}

.share-url .form-control {
    flex: 1;
    padding: 12px;
    border: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.1));
    border-radius: 6px;
    background: var(--muted-bg-color, #f8f9fa);
    font-size: 14px;
    color: var(--muted-color, #6c757d);
    font-family: monospace;
}

.copy-url-btn {
    padding: 12px 16px;
    background: var(--wr-primary-color);
    color: white;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    font-size: 12px;
    font-weight: 500;
    transition: all 0.2s ease;
    white-space: nowrap;
}

.copy-url-btn:hover {
    background: var(--wr-secondary-color);
    transform: translateY(-1px);
}

.copy-url-btn.copied {
    background: #28a745;
}

/* 二维码显示区域 */
.qrcode-container {
    display: none;
    text-align: center;
    padding: 20px;
    border-top: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.05));
    margin-top: 16px;
}

.qrcode-container.show {
    display: block;
}

/* 二维码边框容器 */
.qrcode-wrapper {
    display: inline-block;
    position: relative;
    margin: 0 auto 12px;
    padding: 8px;
    background: #ffffff;
    border-radius: 12px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
    border: 3px solid #ffffff;
    transition: all 0.3s ease;
}

.qrcode-wrapper::before {
    content: '';
    position: absolute;
    top: -2px;
    left: -2px;
    right: -2px;
    bottom: -2px;
    background: linear-gradient(45deg, #667eea, #764ba2, #667eea);
    border-radius: 14px;
    z-index: -1;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.qrcode-wrapper:hover::before {
    opacity: 1;
}

.qrcode-wrapper:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.2);
}

/* 二维码角标装饰 */
.qrcode-wrapper::after {
    content: '';
    position: absolute;
    top: 4px;
    right: 4px;
    width: 16px;
    height: 16px;
    background: var(--wr-primary-color);
    border-radius: 50%;
    opacity: 0.8;
    animation: qrPulse 2s infinite;
}

@keyframes qrPulse {
    0%, 100% {
        transform: scale(1);
        opacity: 0.8;
    }
    50% {
        transform: scale(1.2);
        opacity: 0.6;
    }
}

.qrcode-canvas {
    display: block;
    border-radius: 8px;
    background: #ffffff !important;
    border: 1px solid rgba(0, 0, 0, 0.05);
    transition: all 0.3s ease;
}

.qrcode-text {
    font-size: 12px;
    color: var(--muted-color, #6c757d);
    margin: 8px 0 0 0;
    font-weight: 500;
}

/* 微信二维码特殊样式 */
.wechat-qrcode .qrcode-wrapper::after {
    background: #07c160;
}

/* QQ二维码特殊样式 */
.qq-qrcode .qrcode-wrapper::after {
    background: #12b7f5;
}

/* 响应式优化 */
@media (max-width: 768px) {
    .gallery-modal-content {
        width: 95%;
        height: 95vh;
    }
    
    .gallery-modal-header {
        padding: 12px 16px;
    }
    
    .gallery-modal-title {
        font-size: 16px;
    }
    
    .gallery-modal-btn {
        width: 36px;
        height: 36px;
        font-size: 14px;
    }
    
    .gallery-modal-nav {
        width: 44px;
        height: 44px;
        font-size: 16px;
    }
    
    .gallery-modal-prev {
        left: 12px;
    }
    
    .gallery-modal-next {
        right: 12px;
    }
    
    .modal-thumbnail-item {
        width: 60px;
        height: 60px;
    }
    
    .share-options {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .share-panel {
        min-width: 280px;
        max-width: 320px;
        bottom: 60px;
    }
    
    .share-panel-header {
        padding: 12px 16px;
    }
    
    .share-panel-title {
        font-size: 14px;
    }
    
    .share-panel-body {
        padding: 16px;
    }
    
    .share-options {
        gap: 8px;
        margin-bottom: 16px;
    }
    
    .share-option {
        padding: 12px 8px;
    }
    
    .share-option i {
        font-size: 20px;
    }
    
    .qrcode-container {
        padding: 16px;
    }
    
    .qrcode-canvas {
        width: 100px;
        height: 100px;
    }
}

/* 暗色主题适配 */
.dark-theme .gallery-modal-content {
    background: var(--main-bg-color);
    border: 1px solid var(--main-border-color);
}

.dark-theme .gallery-modal-header {
    background: linear-gradient(135deg, rgba(102, 126, 234, 0.08), rgba(118, 75, 162, 0.05));
    border-bottom-color: var(--main-border-color);
}

.dark-theme .gallery-modal-title {
    color: var(--key-color);
}

.dark-theme .gallery-modal-btn {
    background: var(--muted-bg-color);
    color: var(--key-color);
}

.dark-theme .gallery-modal-footer {
    background: var(--main-bg-color);
    border-top-color: var(--main-border-color);
}

.dark-theme .modal-thumbnail-item {
    background: var(--muted-bg-color);
}

.dark-theme #shareModal .modal-content {
    background: var(--main-bg-color);
}

.dark-theme #shareModal .modal-header {
    background: linear-gradient(135deg, rgba(102, 126, 234, 0.08), rgba(118, 75, 162, 0.05));
    border-bottom-color: var(--main-border-color);
}

.dark-theme .share-option {
    background: var(--muted-bg-color);
    color: var(--key-color);
}

.dark-theme .share-url .form-control {
    background: var(--muted-bg-color);
    border-color: var(--main-border-color);
    color: var(--key-color);
}

.dark-theme .share-panel {
    background: var(--main-bg-color);
    border-color: var(--main-border-color);
}

.dark-theme .share-panel-header {
    background: linear-gradient(135deg, rgba(102, 126, 234, 0.08), rgba(118, 75, 162, 0.05));
    border-bottom-color: var(--main-border-color);
}

.dark-theme .share-panel-title {
    color: var(--key-color);
}

.dark-theme .share-panel-close {
    color: var(--muted-color);
}

.dark-theme .share-panel-close:hover {
    background: var(--muted-bg-color);
    color: var(--key-color);
}

.dark-theme .share-option {
    background: var(--muted-bg-color);
    color: var(--key-color);
}

.dark-theme .share-url-label {
    color: var(--key-color);
}

/* 暗色主题二维码适配 */
.dark-theme .qrcode-wrapper {
    background: #ffffff;
    border-color: #ffffff;
}

.dark-theme .qrcode-canvas {
    background: #ffffff !important;
}

.dark-theme .qrcode-text {
    color: var(--muted-color);
}

.dark-theme .qrcode-modal .qrcode-wrapper {
    background: #ffffff;
    border-color: #ffffff;
}

/* QQ二维码弹窗样式 */
.qrcode-modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.8);
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(5px);
    -webkit-backdrop-filter: blur(5px);
}

.qrcode-modal {
    background: var(--main-bg-color, #ffffff);
    border-radius: 16px;
    padding: 30px;
    max-width: 400px;
    width: 90%;
    text-align: center;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
    position: relative;
    border: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.1));
}

.qrcode-modal h3 {
    margin: 0 0 20px 0;
    font-size: 20px;
    font-weight: 600;
    color: var(--key-color, #333);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
}

.qrcode-modal button {
    position: absolute;
    top: 15px;
    right: 15px;
    background: none;
    border: none;
    font-size: 18px;
    color: var(--muted-color, #6c757d);
    cursor: pointer;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
}

.qrcode-modal button:hover {
    background: var(--muted-bg-color, #f8f9fa);
    color: var(--key-color, #333);
}

/* QQ弹窗二维码容器 */
.qrcode-modal .qrcode-wrapper {
    margin: 20px auto;
    padding: 12px;
    background: #ffffff;
    border-radius: 16px;
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.2);
    border: 4px solid #ffffff;
    position: relative;
    display: inline-block;
}

.qrcode-modal .qrcode-wrapper::before {
    content: '';
    position: absolute;
    top: -3px;
    left: -3px;
    right: -3px;
    bottom: -3px;
    background: linear-gradient(45deg, #12b7f5, #667eea, #12b7f5);
    border-radius: 18px;
    z-index: -1;
    opacity: 0.8;
    animation: qqGradientFlow 3s linear infinite;
}

@keyframes qqGradientFlow {
    0% {
        background-position: 0% 50%;
    }
    50% {
        background-position: 100% 50%;
    }
    100% {
        background-position: 0% 50%;
    }
}

.qrcode-modal .qrcode-wrapper::after {
    content: '';
    position: absolute;
    top: 8px;
    right: 8px;
    width: 20px;
    height: 20px;
    background: #12b7f5;
    border-radius: 50%;
    opacity: 0.9;
    animation: qqPulse 2s infinite;
}

@keyframes qqPulse {
    0%, 100% {
        transform: scale(1);
        opacity: 0.9;
    }
    50% {
        transform: scale(1.3);
        opacity: 0.6;
    }
}

.qrcode-modal canvas {
    border-radius: 12px;
    background: #ffffff !important;
    border: 1px solid rgba(0, 0, 0, 0.05);
    display: block;
}

.qrcode-modal p {
    margin: 20px 0 10px 0;
    color: var(--muted-color, #6c757d);
    font-size: 14px;
}

.qrcode-modal .url-display {
    background: var(--muted-bg-color, #f8f9fa);
    border-radius: 8px;
    padding: 12px;
    margin-top: 15px;
    font-size: 12px;
    color: var(--muted-color, #6c757d);
    word-break: break-all;
    border: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.1));
}

/* 暗色主题适配 */
.dark-theme .qrcode-modal {
    background: var(--main-bg-color);
    border-color: var(--main-border-color);
}

.dark-theme .qrcode-modal h3 {
    color: var(--key-color);
}

.dark-theme .qrcode-modal button {
    color: var(--muted-color);
}

.dark-theme .qrcode-modal button:hover {
    background: var(--muted-bg-color);
    color: var(--key-color);
}

.dark-theme .qrcode-modal p {
    color: var(--muted-color);
}

.dark-theme .qrcode-modal .url-display {
    background: var(--muted-bg-color);
    border-color: var(--main-border-color);
    color: var(--muted-color);
}

/* 响应式优化 */
@media (max-width: 480px) {
    .qrcode-modal {
        padding: 20px;
        margin: 20px;
    }
    
    .qrcode-modal canvas {
        width: 160px;
        height: 160px;
    }
    
    .qrcode-modal h3 {
        font-size: 18px;
    }
}

/* ================================
   表单样式 - 学员信息和作品发布
   ================================ */

/* 学员信息完善提示 */
.wr-student-info-notice {
    margin-bottom: var(--wr-spacing-lg);
    background: var(--wr-primary-gradient);
    color: white;
    border-radius: var(--wr-radius-md);
    overflow: hidden;
}

/* 学员信息模态框样式 - 配合子比主题 */
.modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(4px);
    z-index: 10000;
    display: none;
    opacity: 0;
    transition: opacity 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.modal.show {
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 1;
}

.modal.fade {
    transition: opacity 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.modal-dialog {
    position: relative;
    width: 90%;
    max-width: 800px;
    margin: 0 auto;
    transform: scale(0.95) translateY(-20px);
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.modal.show .modal-dialog {
    transform: scale(1) translateY(0);
}

.modal-content {
    position: relative;
    background: var(--main-bg-color, #ffffff);
    border: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.08));
    border-radius: 12px;
    box-shadow: 
        0 20px 40px rgba(0, 0, 0, 0.15),
        0 8px 16px rgba(0, 0, 0, 0.1);
    display: flex;
    flex-direction: column;
    max-height: 85vh;
    overflow: hidden;
}

.modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 24px;
    border-bottom: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.08));
    background: var(--main-bg-color, #ffffff);
    border-top-left-radius: 12px;
    border-top-right-radius: 12px;
    flex-shrink: 0;
    position: relative;
}

.modal-title {
    margin: 0;
    font-size: 18px;
    font-weight: 600;
    color: var(--key-color, #333);
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 1;
}

.modal-title::before {
    content: '\f007';
    font-family: 'Font Awesome';
    font-size: 16px;
    color: var(--theme-color, #007cba);
}

.modal-body {
    flex: 1;
    padding: 0;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.modal-footer {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 12px;
    padding: 20px 24px;
    border-top: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.08));
    background: var(--muted-bg-color, #f8f9fa);
    border-bottom-left-radius: 12px;
    border-bottom-right-radius: 12px;
    flex-shrink: 0;
}

.close {
    background: none;
    border: none;
    font-size: 18px;
    font-weight: 300;
    color: var(--muted-color, #999);
    cursor: pointer;
    padding: 8px;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    transition: all 0.2s ease;
    line-height: 1;
    flex-shrink: 0;
    margin-left: auto;
}

.close:hover {
    color: var(--key-color, #333);
    background: var(--muted-bg-color, rgba(0, 0, 0, 0.08));
    transform: scale(1.05);
}

.close:active {
    transform: scale(0.95);
}

/* 学员信息表单样式 */
.student-info-form {
    padding: 24px;
    height: 100%;
    overflow-y: auto;
    /* 隐藏滚动条但保持滚动功能 */
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.student-info-form::-webkit-scrollbar {
    display: none;
}

.form-section {
    margin-bottom: 28px;
}

.form-section:last-child {
    margin-bottom: 0;
}

.section-title {
    font-size: 15px;
    font-weight: 600;
    color: var(--key-color, #333);
    margin: 0 0 16px 0;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.08));
    display: flex;
    align-items: center;
    gap: 8px;
}

.section-title i {
    color: var(--theme-color, #007cba);
    font-size: 14px;
}

.form-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 16px;
}

.form-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.form-label {
    font-size: 13px;
    font-weight: 500;
    color: var(--key-color, #333);
    margin: 0;
}

.required {
    color: #e74c3c;
    margin-left: 2px;
}

.line-form-input {
    width: 100%;
    padding: 12px 14px;
    border: 2px solid var(--main-border-color, rgba(0, 0, 0, 0.2));
    border-radius: 8px;
    background: var(--main-bg-color, #ffffff);
    color: var(--key-color, #333);
    font-size: 14px;
    transition: all 0.2s ease;
    box-sizing: border-box;
    position: relative;
    box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.05);
}

.line-form-input:hover {
    border-color: var(--theme-color, rgba(0, 124, 186, 0.5));
    box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.05), 0 0 0 1px rgba(0, 124, 186, 0.1);
}

.line-form-input:focus {
    outline: none;
    border-color: var(--theme-color, #007cba);
    box-shadow: 0 0 0 2px rgba(0, 124, 186, 0.1);
}

.line-form-input[readonly] {
    background: var(--muted-bg-color, #f8f9fa);
    color: var(--muted-color, #666);
    cursor: not-allowed;
    border-color: var(--main-border-color, rgba(0, 0, 0, 0.15));
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.03);
}

.line-form-input[readonly]:hover {
    border-color: var(--main-border-color, rgba(0, 0, 0, 0.15));
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.03);
}

/* 占位符样式 */
.line-form-input::placeholder {
    color: var(--muted-color, #999);
    opacity: 0.8;
}

.line-form-input:focus::placeholder {
    opacity: 0.5;
}

/* 选择框特殊样式 */
select.line-form-input {
    background-image: url('data:image/svg+xml;charset=US-ASCII,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 4 5"><path fill="%23666" d="M2 0L0 2h4zm0 5L0 3h4z"/></svg>');
    background-repeat: no-repeat;
    background-position: right 14px center;
    background-size: 12px;
    padding-right: 40px;
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    border: 2px solid var(--main-border-color, rgba(0, 0, 0, 0.25)) !important;
    box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.08);
}

select.line-form-input:hover {
    background-image: url('data:image/svg+xml;charset=US-ASCII,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 4 5"><path fill="%23007cba" d="M2 0L0 2h4zm0 5L0 3h4z"/></svg>');
    border-color: var(--theme-color, rgba(0, 124, 186, 0.6)) !important;
    box-shadow: 
        inset 0 1px 3px rgba(0, 0, 0, 0.08), 
        0 0 0 1px rgba(0, 124, 186, 0.15);
}

select.line-form-input:focus {
    background-image: url('data:image/svg+xml;charset=US-ASCII,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 4 5"><path fill="%23007cba" d="M2 0L0 2h4zm0 5L0 3h4z"/></svg>');
    border-color: var(--theme-color, #007cba) !important;
    box-shadow: 
        inset 0 1px 3px rgba(0, 0, 0, 0.08),
        0 0 0 4px rgba(0, 124, 186, 0.2);
}

/* 选择框选项样式 */
select.line-form-input option {
    padding: 14px 16px;
    font-size: 14px;
    color: var(--key-color, #333);
    background: var(--main-bg-color, #ffffff);
    border: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.1));
    border-bottom: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.05));
    line-height: 1.5;
    min-height: 44px;
    font-weight: 500;
}

select.line-form-input option:hover,
select.line-form-input option:focus {
    background: rgba(0, 124, 186, 0.08);
    color: var(--key-color, #333);
    border-color: var(--theme-color, rgba(0, 124, 186, 0.3));
}

select.line-form-input option:checked {
    background: var(--theme-color, #007cba);
    color: white;
    font-weight: 700;
    border-color: var(--theme-color, #007cba);
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1);
}

select.line-form-input option[value=""] {
    color: var(--muted-color, #999);
    font-style: italic;
    background: var(--muted-bg-color, #f8f9fa);
    border-color: var(--main-border-color, rgba(0, 0, 0, 0.08));
}

/* 选择框的第一个选项（占位符） */
select.line-form-input option:first-child {
    border-top-left-radius: 6px;
    border-top-right-radius: 6px;
}

select.line-form-input option:last-child {
    border-bottom-left-radius: 6px;
    border-bottom-right-radius: 6px;
    border-bottom: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.1));
}

/* 增强角色选择的可读性 */
select.line-form-input[name="role"] {
    font-weight: 500;
    color: var(--key-color, #333);
    min-height: 48px;
    line-height: 1.4;
}

select.line-form-input[name="role"]:invalid {
    color: var(--muted-color, #999);
}

/* 文本域样式增强 */
textarea.line-form-input {
    resize: vertical;
    min-height: 80px;
    font-family: inherit;
    line-height: 1.5;
    border: 2px solid var(--main-border-color, rgba(0, 0, 0, 0.25)) !important;
    box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.06);
}

textarea.line-form-input:hover {
    border-color: var(--theme-color, rgba(0, 124, 186, 0.5)) !important;
    box-shadow: 
        inset 0 2px 4px rgba(0, 0, 0, 0.06), 
        0 0 0 1px rgba(0, 124, 186, 0.1);
}

textarea.line-form-input:focus {
    border-color: var(--theme-color, #007cba) !important;
    box-shadow: 0 0 0 2px rgba(0, 124, 186, 0.1);
}

.form-help {
    font-size: 12px;
    color: var(--muted-color, #666);
    margin: 2px 0 0 0;
    line-height: 1.4;
}

.form-help-inline {
    font-size: 11px;
    color: var(--muted-color, #999);
    font-weight: 400;
    margin-left: 4px;
}

/* 文件上传区域样式增强 */
.file-upload-area {
    border: 2px dashed var(--main-border-color, rgba(0, 0, 0, 0.25)) !important;
    background: var(--main-bg-color, #ffffff);
    transition: all 0.2s ease;
    box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.05);
}

.file-upload-area:hover {
    border-color: var(--theme-color, rgba(0, 124, 186, 0.5)) !important;
    background: rgba(0, 124, 186, 0.02);
    box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.05), 0 0 0 1px rgba(0, 124, 186, 0.1);
}

.file-upload-area.dragover {
    border-color: var(--theme-color, #007cba) !important;
    background: rgba(0, 124, 186, 0.05);
    box-shadow: 
        inset 0 1px 3px rgba(0, 0, 0, 0.05),
        0 0 0 2px rgba(0, 124, 186, 0.2);
}

/* 输入文件按钮样式 */
input[type="file"].line-form-input {
    border: 2px solid var(--main-border-color, rgba(0, 0, 0, 0.25)) !important;
    padding: 10px 12px;
    background: var(--main-bg-color, #ffffff);
    cursor: pointer;
}

input[type="file"].line-form-input:hover {
    border-color: var(--theme-color, rgba(0, 124, 186, 0.5)) !important;
    background: rgba(0, 124, 186, 0.02);
}

input[type="file"].line-form-input:focus {
    border-color: var(--theme-color, #007cba) !important;
    box-shadow: 0 0 0 4px rgba(0, 124, 186, 0.15);
}

/* 确保所有基本输入框类型都有统一的边框样式 */
input[type="text"].line-form-input,
input[type="tel"].line-form-input,
input[type="email"].line-form-input,
input[type="password"].line-form-input,
input[type="url"].line-form-input,
input[type="number"].line-form-input {
    border: 2px solid var(--main-border-color, rgba(0, 0, 0, 0.25)) !important;
    box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.06);
}

input[type="text"].line-form-input:hover,
input[type="tel"].line-form-input:hover,
input[type="email"].line-form-input:hover,
input[type="password"].line-form-input:hover,
input[type="url"].line-form-input:hover,
input[type="number"].line-form-input:hover {
    border-color: var(--theme-color, rgba(0, 124, 186, 0.6)) !important;
    box-shadow: 
        inset 0 1px 3px rgba(0, 0, 0, 0.06), 
        0 0 0 1px rgba(0, 124, 186, 0.15);
}

input[type="text"].line-form-input:focus,
input[type="tel"].line-form-input:focus,
input[type="email"].line-form-input:focus,
input[type="password"].line-form-input:focus,
input[type="url"].line-form-input:focus,
input[type="number"].line-form-input:focus {
    border-color: var(--theme-color, #007cba) !important;
    box-shadow: 
        inset 0 1px 3px rgba(0, 0, 0, 0.06),
        0 0 0 4px rgba(0, 124, 186, 0.2);
}

/* 只读输入框的特殊样式 */
input[type="email"].line-form-input[readonly] {
    background: var(--muted-bg-color, #f8f9fa) !important;
    border-color: var(--main-border-color, rgba(0, 0, 0, 0.2)) !important;
    color: var(--muted-color, #666) !important;
    cursor: not-allowed;
}

input[type="email"].line-form-input[readonly]:hover {
    border-color: var(--main-border-color, rgba(0, 0, 0, 0.2)) !important;
    box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.06);
}

/* 表单网格布局中的输入框确保边框显示 */
.form-grid .form-group .line-form-input {
    border: 2px solid var(--main-border-color, rgba(0, 0, 0, 0.25)) !important;
    box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.06) !important;
}

.form-grid .form-group .line-form-input:hover {
    border-color: var(--theme-color, rgba(0, 124, 186, 0.6)) !important;
    box-shadow: 
        inset 0 1px 3px rgba(0, 0, 0, 0.06), 
        0 0 0 1px rgba(0, 124, 186, 0.15) !important;
}

.form-grid .form-group .line-form-input:focus {
    border-color: var(--theme-color, #007cba) !important;
    box-shadow: 
        inset 0 1px 3px rgba(0, 0, 0, 0.06),
        0 0 0 4px rgba(0, 124, 186, 0.2) !important;
}

/* 基本信息区域特殊强调 */
.form-section:first-child .form-grid .line-form-input {
    border-width: 2px !important;
    border-style: solid !important;
    border-color: var(--main-border-color, rgba(0, 0, 0, 0.3)) !important;
}

/* 联系方式区域特殊强调 */
.form-section:nth-child(2) .form-grid .line-form-input {
    border-width: 2px !important;
    border-style: solid !important;
    border-color: var(--main-border-color, rgba(0, 0, 0, 0.3)) !important;
}

/* 工具选择复选框样式优化 */
.tools-checkbox {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 8px;
    margin-top: 12px;
    padding: 12px;
    background: var(--main-bg-color, #ffffff);
    border: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.1));
    border-radius: 6px;
}

/* 工具选择项样式 */
.tools-checkbox .checkbox-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    background: var(--main-bg-color, #ffffff);
    border: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.1));
    border-radius: 4px;
    cursor: pointer;
    transition: border-color 0.2s ease;
    font-weight: 400;
    color: var(--key-color, #333);
    font-size: 14px;
}

.tools-checkbox .checkbox-item:hover {
    border-color: var(--theme-color, rgba(0, 124, 186, 0.4));
}

/* 工具选择复选框输入框样式 */
.tools-checkbox .checkbox-item input[type="checkbox"] {
    width: 16px;
    height: 16px;
    margin: 0;
    cursor: pointer;
    flex-shrink: 0;
    accent-color: var(--theme-color, #007cba);
}

/* 选中状态的工具选择项 */
.tools-checkbox .checkbox-item:has(input:checked),
.tools-checkbox .checkbox-item.checked {
    background: rgba(0, 124, 186, 0.05);
    border-color: var(--theme-color, #007cba);
    color: var(--theme-color, #007cba);
    font-weight: 500;
}

/* 工具选择标签文本 */
.tools-checkbox .checkbox-item span {
    font-size: 14px;
    font-weight: inherit;
    color: inherit;
    user-select: none;
    transition: color 0.3s ease;
}

/* 响应式布局 */
@media (max-width: 768px) {
    .tools-checkbox {
        grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
        gap: 6px;
        padding: 10px;
    }
    
    .tools-checkbox .checkbox-item {
        padding: 6px 10px;
        font-size: 13px;
    }
    
    .tools-checkbox .checkbox-item input[type="checkbox"] {
        width: 14px;
        height: 14px;
    }
}

@media (max-width: 480px) {
    .tools-checkbox {
        grid-template-columns: repeat(2, 1fr);
        gap: 4px;
        padding: 8px;
    }
    
    .tools-checkbox .checkbox-item {
        padding: 6px 8px;
        font-size: 12px;
    }
}

/* 技能特长复选框样式 */
.skills-checkbox {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 10px;
    margin-top: 12px;
}

.checkbox-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    border: 2px solid var(--main-border-color, rgba(0, 0, 0, 0.12));
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.2s ease;
    background: var(--main-bg-color, #ffffff);
    font-size: 14px;
    color: var(--key-color, #333);
    user-select: none;
    position: relative;
}

.checkbox-item:hover {
    border-color: var(--theme-color, #007cba);
    background: rgba(0, 124, 186, 0.04);
    transform: translateY(-1px);
    box-shadow: 0 2px 8px rgba(0, 124, 186, 0.1);
}

.checkbox-item input[type="checkbox"] {
    margin: 0;
    width: 18px;
    height: 18px;
    accent-color: var(--theme-color, #007cba);
    cursor: pointer;
    flex-shrink: 0;
}

.checkbox-item input[type="checkbox"]:checked {
    transform: scale(1.1);
}

.checkbox-item span {
    flex: 1;
    cursor: pointer;
    transition: all 0.2s ease;
}

.checkbox-item input[type="checkbox"]:checked + span {
    color: var(--theme-color, #007cba);
    font-weight: 600;
}

.checkbox-item:has(input[type="checkbox"]:checked),
.checkbox-item.checked {
    border-color: var(--theme-color, #007cba);
    background: rgba(0, 124, 186, 0.08);
    box-shadow: 0 0 0 2px rgba(0, 124, 186, 0.1);
}

/* 为不支持 :has() 的浏览器提供备用样式 */
.checkbox-item.checked span {
    color: var(--theme-color, #007cba);
    font-weight: 600;
}

/* 响应式设计 */
@media (max-width: 768px) {
    .modal-dialog {
        width: 95%;
        margin: 10px auto;
    }
    
    .modal-content {
        max-height: 90vh;
    }
    
    .modal-header,
    .modal-footer {
        padding: 16px 20px;
    }
    
    .student-info-form {
        padding: 20px;
    }
    
    .form-grid {
        grid-template-columns: 1fr;
        gap: 12px;
    }
    
    .skills-checkbox {
        grid-template-columns: repeat(2, 1fr);
        gap: 8px;
    }
    
    .checkbox-item {
        padding: 10px 12px;
        font-size: 13px;
    }
}

@media (max-width: 480px) {
    .modal-dialog {
        width: 98%;
        margin: 5px auto;
    }
    
    .modal-content {
        max-height: 95vh;
        border-radius: 8px;
    }
    
    .modal-header,
    .modal-footer {
        padding: 12px 16px;
    }
    
    .student-info-form {
        padding: 16px;
    }
    
    .skills-checkbox {
        grid-template-columns: 1fr;
    }
    
    .modal-title {
        font-size: 16px;
    }
}

/* 防止页面滚动 */
.modal-open {
    overflow: hidden;
}

/* 暗色主题适配 */
.dark-theme .modal {
    background: rgba(0, 0, 0, 0.8);
}

.dark-theme .modal-content {
    background: var(--main-bg-color);
    border-color: var(--main-border-color);
}

.dark-theme .modal-header,
.dark-theme .modal-footer {
    background: var(--main-bg-color);
    border-color: var(--main-border-color);
}

.dark-theme .section-title {
    border-color: var(--main-border-color);
}

.dark-theme .line-form-input {
    background: var(--main-bg-color);
    border-color: var(--main-border-color);
    color: var(--key-color);
}

.dark-theme .line-form-input:focus {
    border-color: var(--theme-color);
    box-shadow: 0 0 0 3px rgba(102, 126, 234, 0.1);
}

.dark-theme .checkbox-item {
    background: var(--main-bg-color);
    border-color: var(--main-border-color);
    color: var(--key-color);
}

.dark-theme .checkbox-item:hover {
    background: rgba(102, 126, 234, 0.05);
    border-color: var(--theme-color);
}

.wr-notice-content {
    display: flex;
    align-items: center;
    padding: var(--wr-spacing-lg);
    gap: var(--wr-spacing-lg);
}

.wr-notice-icon {
    font-size: 48px;
    opacity: 0.8;
}

.wr-notice-text {
    flex: 1;
}

.wr-notice-text h3 {
    margin: 0 0 var(--wr-spacing-sm) 0;
    font-size: var(--wr-text-xl);
    font-weight: var(--wr-weight-semibold);
}

.wr-notice-text p {
    margin: 0;
    opacity: 0.9;
    line-height: 1.5;
}

/* 表单组样式 */
.wr-form-group {
    margin-bottom: var(--wr-spacing-lg);
}

.wr-form-label {
    display: block;
    margin-bottom: var(--wr-spacing-sm);
    font-weight: var(--wr-weight-medium);
    color: var(--key-color, #333);
    font-size: var(--wr-text-sm);
}

.wr-required {
    color: #e74c3c;
    margin-left: 4px;
}

.wr-form-input {
    width: 100%;
    padding: var(--wr-spacing-md);
    border: 2px solid var(--main-border-color, rgba(0, 0, 0, 0.1));
    border-radius: var(--wr-radius-sm);
    font-size: var(--wr-text-sm);
    color: var(--key-color, #333);
    background: var(--main-bg-color, #ffffff);
    transition: all var(--wr-transition-normal);
}

.wr-form-input:focus {
    outline: none;
    border-color: var(--wr-primary-color);
    box-shadow: 0 0 0 3px rgba(240, 68, 148, 0.1);
}

.wr-form-input::placeholder {
    color: var(--muted-3-color, #adb5bd);
}

/* 下拉选择框样式 */
.wr-select {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right 12px center;
    background-size: 16px;
    padding-right: 40px;
}

.wr-select:focus {
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23f04496' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e");
}

.wr-select option {
    background: var(--main-bg-color, #ffffff);
    color: var(--key-color, #333);
    padding: var(--wr-spacing-sm);
}

/* 工具和技能选择 */
.wr-tools-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
    gap: var(--wr-spacing-sm);
    margin-top: var(--wr-spacing-sm);
}

.wr-tool-item {
    position: relative;
}

.wr-tool-label {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: var(--wr-spacing-md);
    background: var(--muted-bg-color, #f8f9fa);
    border: 2px solid transparent;
    border-radius: var(--wr-radius-md);
    cursor: pointer;
    transition: all var(--wr-transition-bounce);
    text-align: center;
    position: relative;
    overflow: hidden;
    min-height: 80px;
}

.wr-tool-label:hover {
    transform: translateY(-2px);
    box-shadow: var(--wr-shadow-light);
    border-color: var(--wr-primary-color);
    background: linear-gradient(135deg, #ffffff 0%, #f8f9ff 100%);
}

.wr-tool-icon {
    font-size: 24px;
    margin-bottom: var(--wr-spacing-sm);
    transition: all var(--wr-transition-normal);
}

.wr-tool-name {
    font-size: var(--wr-text-xs);
    font-weight: var(--wr-weight-medium);
    color: var(--key-color, #333);
    transition: all var(--wr-transition-normal);
}

.wr-tool-item input[type="checkbox"]:checked + .wr-tool-label {
    background: var(--wr-primary-gradient);
    border-color: var(--wr-primary-color);
    box-shadow: 0 6px 25px rgba(240, 68, 148, 0.25);
}

.wr-tool-item input[type="checkbox"]:checked + .wr-tool-label .wr-tool-icon,
.wr-tool-item input[type="checkbox"]:checked + .wr-tool-label .wr-tool-name {
    color: white;
}

/* 上传区域样式 */
.wr-upload-area {
    border: 2px dashed var(--main-border-color, rgba(0, 0, 0, 0.1));
    border-radius: var(--wr-radius-sm);
    padding: var(--wr-spacing-xxl) var(--wr-spacing-lg);
    text-align: center;
    cursor: pointer;
    transition: all var(--wr-transition-normal);
    background: var(--muted-bg-color, #f8f9fa);
}

.wr-upload-area:hover {
    border-color: var(--wr-primary-color);
    background: rgba(0, 0, 0, 0);
}

.wr-upload-area.dragover {
    border-color: var(--wr-primary-color);
    background: rgba(240, 68, 148, 0.1);
    transform: scale(1.02);
}

.wr-upload-placeholder i {
    font-size: 48px;
    color: var(--muted-color, #6c757d);
    margin-bottom: var(--wr-spacing-md);
    display: block;
}

.wr-upload-placeholder p {
    margin: 5px 0;
    color: var(--muted-color, #6c757d);
}

.wr-upload-hint {
    font-size: var(--wr-text-xs);
    color: var(--muted-3-color, #adb5bd);
}

/* 图片预览网格 */
.wr-images-preview {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
    gap: var(--wr-spacing-md);
    margin-top: var(--wr-spacing-lg);
}

.wr-image-item {
    position: relative;
    border-radius: var(--wr-radius-sm);
    overflow: hidden;
    box-shadow: var(--wr-shadow-light);
    transition: transform var(--wr-transition-normal);
}

.wr-image-item:hover {
    transform: scale(1.05);
}

.wr-image-item img {
    width: 100%;
    height: 120px;
    object-fit: cover;
    display: block;
}

.wr-image-remove {
    position: absolute;
    top: 5px;
    right: 5px;
    width: 24px;
    height: 24px;
    background: rgba(231, 76, 60, 0.9);
    color: white;
    border: none;
    border-radius: var(--wr-radius-full);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--wr-text-xs);
    transition: all var(--wr-transition-normal);
}

.wr-image-remove:hover {
    background: #e74c3c;
    transform: scale(1.1);
}

/* 按钮样式 */
.wr-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: var(--wr-spacing-sm) var(--wr-spacing-lg);
    border: none;
    border-radius: var(--wr-radius-sm);
    font-size: var(--wr-text-sm);
    font-weight: var(--wr-weight-medium);
    cursor: pointer;
    transition: all var(--wr-transition-normal);
    text-decoration: none;
    white-space: nowrap;
}

.wr-btn:focus {
    outline: none;
    box-shadow: 0 0 0 3px rgba(240, 68, 148, 0.3);
}

.wr-btn-primary {
    background: var(--wr-primary-color);
    color: white;
}

.wr-btn-primary:hover {
    background: var(--focus-color, #252525);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(240, 68, 148, 0.3);
}

.wr-btn-secondary {
    background: var(--muted-bg-color, #f8f9fa);
    color: var(--muted-color, #6c757d);
    border: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.1));
}

.wr-btn-secondary:hover {
    background: var(--main-border-color, #e9ecef);
    color: var(--key-color, #333);
}

/* 模态框样式 */
.wr-modal {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    z-index: 9999;
    opacity: 0;
    transition: opacity var(--wr-transition-normal);
}

.wr-modal.show {
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 1;
}

.wr-modal-dialog {
    max-width: 600px;
    width: 90%;
    max-height: 90vh;
    overflow-y: auto;
}

.wr-modal-content {
    background: var(--main-bg-color, #ffffff);
    border-radius: var(--wr-radius-md);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
    overflow: hidden;
}

.wr-modal-header {
    padding: var(--wr-spacing-lg) var(--wr-spacing-xl);
    border-bottom: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.1));
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.wr-modal-title {
    margin: 0;
    font-size: var(--wr-text-lg);
    font-weight: var(--wr-weight-semibold);
    color: var(--key-color, #333);
}

.wr-modal-close {
    background: none;
    border: none;
    font-size: 24px;
    color: var(--muted-color, #6c757d);
    cursor: pointer;
    padding: 0;
    width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--wr-radius-full);
    transition: all var(--wr-transition-normal);
}

.wr-modal-close:hover {
    background: var(--muted-bg-color, #f8f9fa);
    color: var(--key-color, #333);
}

.wr-modal-body {
    padding: var(--wr-spacing-xl);
}

.wr-modal-footer {
    padding: var(--wr-spacing-lg) var(--wr-spacing-xl);
    border-top: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.1));
    display: flex;
    gap: var(--wr-spacing-sm);
    justify-content: flex-end;
}

/* 表单帮助文本 */
.wr-form-help {
    display: block;
    margin-top: 4px;
    font-size: var(--wr-text-xs);
    color: var(--muted-color, #6c757d);
}

/* 表单验证状态 */
.wr-form-input:invalid {
    border-color: #e74c3c;
}

.wr-form-input:valid {
    border-color: #27ae60;
}

/* 上传进度 */
.wr-upload-progress {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: rgba(0, 0, 0, 0.8);
    color: white;
    padding: var(--wr-spacing-lg) var(--wr-spacing-xl);
    border-radius: var(--wr-radius-sm);
    z-index: 9999;
    text-align: center;
    font-size: var(--wr-text-base);
    min-width: 200px;
}

.wr-upload-progress .wr-spinner {
    display: inline-block;
    width: 20px;
    height: 20px;
    border: 2px solid rgba(255, 255, 255, 0.3);
    border-radius: var(--wr-radius-full);
    border-top-color: #fff;
    animation: wr-spin 1s ease-in-out infinite;
    margin-right: var(--wr-spacing-sm);
}

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

/* 响应式表单设计 */
@media (max-width: 768px) {
    .wr-notice-content {
        flex-direction: column;
        text-align: center;
        gap: var(--wr-spacing-md);
    }
    
    .wr-notice-icon {
        font-size: 36px;
    }
    
    .wr-tools-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: var(--wr-spacing-xs);
    }
    
    .wr-tool-label {
        padding: var(--wr-spacing-sm);
        min-height: 70px;
    }
    
    .wr-tool-icon {
        font-size: 20px;
        margin-bottom: 6px;
    }
    
    .wr-tool-name {
        font-size: 11px;
    }
    
    .wr-modal-dialog {
        width: 95%;
        margin: var(--wr-spacing-lg) auto;
    }
    
    .wr-modal-body {
        padding: var(--wr-spacing-lg);
    }
    
    .wr-modal-header,
    .wr-modal-footer {
        padding: var(--wr-spacing-md) var(--wr-spacing-lg);
    }
}

@media (max-width: 480px) {
    .wr-tools-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--wr-spacing-xs);
    }
    
    .wr-tool-label {
        padding: var(--wr-spacing-xs) 6px;
        min-height: 65px;
    }
    
    .wr-tool-icon {
        font-size: 18px;
    }
    
    .wr-tool-name {
        font-size: 10px;
    }
    
    .wr-form-input {
        padding: var(--wr-spacing-sm);
        font-size: 16px; /* 防止iOS缩放 */
    }
    
    .wr-select {
        padding: var(--wr-spacing-sm) 40px var(--wr-spacing-sm) var(--wr-spacing-sm);
        font-size: 16px;
        background-size: 20px;
        background-position: right 10px center;
    }
}

/* ================================
   兼容性修复
   ================================ */

/* Safari兼容性 */
@supports (-webkit-backdrop-filter: blur(10px)) {
    .wr-glass {
        -webkit-backdrop-filter: blur(10px);
        backdrop-filter: blur(10px);
    }
    
    .wr-cover-likes,
    .wr-filter-select {
        -webkit-backdrop-filter: blur(5px);
        backdrop-filter: blur(5px);
    }
}

/* 旧浏览器Grid支持 */
@supports not (display: grid) {
    .wr-works-grid,
    .wr-students-grid {
        display: flex;
        flex-wrap: wrap;
        margin: 0 -15px;
    }
    
    .wr-work-card,
    .wr-student-card {
        flex: 0 0 calc(33.333% - 30px);
        margin: 0 15px 30px;
    }
    
    @media (max-width: 991px) {
        .wr-work-card,
        .wr-student-card {
            flex: 0 0 calc(50% - 30px);
        }
    }
    
    @media (max-width: 767px) {
        .wr-work-card,
        .wr-student-card {
            flex: 0 0 calc(100% - 30px);
        }
    }
}

/* Internet Explorer兼容性 */
@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
    .wr-work-card,
    .wr-student-card {
        display: block;
    }
}

/* ================================
   学员作品集页面优化样式
   ================================ */

/* 筛选控制区域 */
.wr-filter-controls {
    display: flex;
    flex-wrap: wrap;
    gap: var(--wr-spacing-lg);
    align-items: center;
    margin-top: var(--wr-spacing-xl);
    padding: var(--wr-spacing-lg);
    background: rgba(255, 255, 255, 0.1);
    border-radius: var(--wr-radius-md);
    backdrop-filter: blur(10px);
}

.wr-filter-group {
    display: flex;
    align-items: center;
    gap: var(--wr-spacing-sm);
}

.wr-filter-group label {
    color: rgba(255, 255, 255, 0.9);
    font-weight: var(--wr-weight-medium);
    white-space: nowrap;
    font-size: var(--wr-text-sm);
}

.wr-filter-select {
    background: rgba(255, 255, 255, 0.15);
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: var(--wr-radius-sm);
    color: white;
    padding: var(--wr-spacing-sm) var(--wr-spacing-md);
    font-size: var(--wr-text-sm);
    min-width: 120px;
    transition: all var(--wr-transition-normal);
}

.wr-filter-select:focus,
.wr-filter-select:hover {
    background: rgba(255, 255, 255, 0.25);
    border-color: rgba(255, 255, 255, 0.4);
    outline: none;
}

.wr-filter-btn {
    background: rgba(255, 255, 255, 0.15);
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: var(--wr-radius-sm);
    color: rgba(255, 255, 255, 0.8);
    padding: var(--wr-spacing-sm) var(--wr-spacing-md);
    font-size: var(--wr-text-sm);
    transition: all var(--wr-transition-normal);
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: var(--wr-spacing-xs);
}

.wr-filter-btn:hover,
.wr-filter-btn.active {
    background: rgba(255, 255, 255, 0.25);
    color: white;
    border-color: rgba(255, 255, 255, 0.4);
}

/* 统计卡片网格 */
.wr-stats-overview {
    margin: var(--wr-spacing-xl) 0 var(--wr-spacing-xxl) 0;
}

.wr-stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--wr-spacing-lg);
}

.wr-stat-card {
    background: var(--main-bg-color, #ffffff);
    border-radius: var(--wr-radius-lg);
    padding: var(--wr-spacing-lg);
    box-shadow: var(--wr-shadow-light);
    border: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.1));
    transition: all var(--wr-transition-normal);
    display: flex;
    align-items: center;
    gap: var(--wr-spacing-md);
    position: relative;
    overflow: hidden;
}

.wr-stat-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: var(--wr-primary-gradient);
    transform: scaleX(0);
    transition: transform var(--wr-transition-normal);
}

.wr-stat-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--wr-shadow-medium);
}

.wr-stat-card:hover::before {
    transform: scaleX(1);
}

.wr-stat-icon {
    width: 50px;
    height: 50px;
    border-radius: var(--wr-radius-full);
    background: var(--wr-primary-gradient);
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: var(--wr-text-lg);
    flex-shrink: 0;
}

.wr-stat-content {
    flex: 1;
}

.wr-stat-number {
    font-size: var(--wr-text-2xl);
    font-weight: var(--wr-weight-bold);
    color: var(--key-color, #333);
    line-height: 1;
}

.wr-stat-label {
    font-size: var(--wr-text-sm);
    color: var(--minor-color, #666);
    margin-top: 4px;
}

/* 分页信息 */
.wr-pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: var(--wr-spacing-xl) 0;
    padding: var(--wr-spacing-lg);
    background: var(--main-bg-color, #ffffff);
    border-radius: var(--wr-radius-md);
    box-shadow: var(--wr-shadow-light);
}

.wr-pagination-info {
    color: var(--minor-color, #666);
    font-size: var(--wr-text-sm);
}

/* 精选作品区域 */
.wr-featured-section {
    margin: var(--wr-spacing-xxl) 0;
}

.wr-section-header {
    margin-bottom: var(--wr-spacing-xl);
    text-align: center;
}

.wr-section-title {
    font-size: var(--wr-text-2xl);
    font-weight: var(--wr-weight-bold);
    color: var(--key-color, #333);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--wr-spacing-sm);
    margin: 0 0 var(--wr-spacing-md) 0;
}

.wr-section-title i {
    color: var(--wr-secondary-color);
}

.wr-section-divider {
    width: 60px;
    height: 3px;
    background: var(--wr-primary-gradient);
    border-radius: var(--wr-radius-sm);
    margin: 0 auto;
}

.wr-featured-works {
    position: relative;
}

.wr-work-card-mini {
    transform-origin: center;
}

.wr-work-card-mini:hover {
    transform: translateY(-6px) scale(1.02);
}

.wr-empty-featured {
    text-align: center;
    padding: var(--wr-spacing-xxl);
    color: var(--minor-color, #666);
}

.wr-empty-featured i {
    font-size: var(--wr-text-3xl);
    margin-bottom: var(--wr-spacing-md);
    opacity: 0.5;
}

/* 空状态样式 */
.wr-empty-state {
    text-align: center;
    padding: var(--wr-spacing-xxl);
    background: var(--main-bg-color, #ffffff);
    border-radius: var(--wr-radius-lg);
    box-shadow: var(--wr-shadow-light);
    margin: var(--wr-spacing-xl) 0;
}

.wr-empty-icon {
    font-size: 4rem;
    color: var(--minor-color, #ccc);
    margin-bottom: var(--wr-spacing-lg);
}

.wr-empty-title {
    font-size: var(--wr-text-xl);
    color: var(--key-color, #333);
    margin: 0 0 var(--wr-spacing-md) 0;
}

.wr-empty-desc {
    color: var(--minor-color, #666);
    font-size: var(--wr-text-base);
    line-height: 1.6;
    margin: 0;
}

/* 列表视图样式 */
.wr-students-grid.wr-list-view {
    display: flex;
    flex-direction: column;
    gap: var(--wr-spacing-lg);
}

.wr-students-grid.wr-list-view .wr-student-card {
    display: flex;
    flex-direction: row;
    align-items: center;
    max-width: none;
    height: auto;
    padding: var(--wr-spacing-lg);
}

.wr-students-grid.wr-list-view .wr-student-header {
    flex: 0 0 200px;
    padding: 0;
    margin-right: var(--wr-spacing-xl);
    background: none;
    border: none;
}

.wr-students-grid.wr-list-view .wr-student-cover {
    flex: 0 0 300px;
    padding-top: 0;
    height: 200px;
    margin-right: var(--wr-spacing-xl);
}

.wr-students-grid.wr-list-view .wr-student-info {
    flex: 1;
    padding: 0;
}

.wr-students-grid.wr-list-view .wr-works-preview {
    display: flex;
    gap: var(--wr-spacing-sm);
    margin-bottom: var(--wr-spacing-md);
}

.wr-students-grid.wr-list-view .wr-work-thumb {
    width: 60px;
    height: 60px;
    flex-shrink: 0;
}

/* 响应式优化 - 学员作品集页面 */
@media (max-width: 768px) {
    .wr-filter-controls {
        flex-direction: column;
        gap: var(--wr-spacing-md);
        align-items: stretch;
        padding: var(--wr-spacing-md);
    }
    
    .wr-filter-group {
        justify-content: space-between;
    }
    
    .wr-stats-grid {
        grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
        gap: var(--wr-spacing-md);
    }
    
    .wr-stat-card {
        padding: var(--wr-spacing-md);
        flex-direction: column;
        text-align: center;
    }
    
    .wr-stat-icon {
        width: 40px;
        height: 40px;
        font-size: var(--wr-text-base);
    }
    
    .wr-section-title {
        font-size: var(--wr-text-xl);
        flex-direction: column;
        gap: var(--wr-spacing-xs);
    }
    
    /* 列表视图响应式 */
    .wr-students-grid.wr-list-view .wr-student-card {
        flex-direction: column;
        text-align: center;
    }
    
    .wr-students-grid.wr-list-view .wr-student-header,
    .wr-students-grid.wr-list-view .wr-student-cover {
        flex: none;
        margin-right: 0;
        margin-bottom: var(--wr-spacing-md);
    }
    
    .wr-students-grid.wr-list-view .wr-student-cover {
        height: 150px;
    }
}

@media (max-width: 480px) {
    .wr-stats-grid {
        grid-template-columns: 1fr 1fr;
    }
    
    .wr-stat-number {
        font-size: var(--wr-text-xl);
    }
}

/* ===============================================
   作品标题输入框优化样式
   =============================================== */

/* 作品标题容器样式 */
.newposts-title {
    position: relative;
    margin-bottom: 20px;
    background: var(--main-bg-color, #ffffff);
    border: 1px solid var(--main-border-color, rgba(0, 0, 0, 0.15));
    border-radius: 6px;
    padding: 0;
    transition: border-color 0.2s ease;
}

.newposts-title:hover {
    border-color: var(--theme-color, rgba(0, 124, 186, 0.5));
}

.newposts-title:focus-within {
    border-color: var(--theme-color, #007cba);
}

/* 作品标题输入框样式 */
.new-title {
    width: 100%;
    min-height: 32px;
    padding: 8px 12px;
    border: none;
    outline: none;
    background: transparent;
    font-size: 14px;
    font-weight: 400;
    color: var(--key-color, #333);
    line-height: 1.3;
    resize: none;
    font-family: inherit;
    transition: none;
    overflow: hidden;
}

.new-title::placeholder {
    color: var(--muted-color, #999);
    font-weight: 400;
}

/* 大尺寸标题输入框 */
.input-lg.new-title {
    font-size: 16px;
    font-weight: 500;
    min-height: 36px;
    padding: 10px 14px;
}

/* 标题输入框动态高度调整 */
.new-title[autoHeight="true"] {
    overflow-y: hidden;
    transition: height 0.2s ease;
}

/* 标题输入框底部装饰线 - 简化版本 */
.line-form-line {
    display: none;
}

/* 响应式设计 */
@media (max-width: 768px) {
    .new-title {
        font-size: 14px;
        min-height: 30px;
        padding: 6px 10px;
    }
    
    .input-lg.new-title {
        font-size: 15px;
        min-height: 32px;
        padding: 8px 12px;
    }
}

@media (max-width: 480px) {
    .newposts-title {
        border-radius: 4px;
    }
    
    .new-title {
        font-size: 13px;
        min-height: 28px;
        padding: 5px 8px;
    }
    
    .input-lg.new-title {
        font-size: 14px;
        min-height: 30px;
        padding: 6px 10px;
    }
}

/* ================================
   图片选择模态框样式
   ================================ */
#imageSelectModal {
    z-index: 1050;
}

#imageSelectModal .modal-dialog {
    max-width: 800px;
}

#imageSelectModal .modal-body {
    max-height: 70vh;
    padding: 20px;
    display: flex;
    flex-direction: column;
}

/* 图片网格布局 */
.image-grid-container {
    position: relative;
    min-height: 200px;
    flex: 1;
    overflow-y: auto;
    margin-bottom: 10px;
}

/* 美化滚动条 */
.image-grid-container::-webkit-scrollbar {
    width: 8px;
}

.image-grid-container::-webkit-scrollbar-track {
    background: var(--wr-bg-secondary);
    border-radius: 4px;
}

.image-grid-container::-webkit-scrollbar-thumb {
    background: var(--wr-border-color);
    border-radius: 4px;
}

.image-grid-container::-webkit-scrollbar-thumb:hover {
    background: var(--wr-secondary-color);
}

.image-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: 16px;
    padding: 10px 0 20px 0;
}

.image-item {
    position: relative;
    border-radius: var(--wr-radius-md);
    overflow: hidden;
    background: var(--wr-bg-secondary);
    border: 2px solid transparent;
    transition: all var(--wr-transition-normal);
    cursor: pointer;
}

.image-item:hover {
    transform: translateY(-2px);
    box-shadow: var(--wr-shadow-medium);
    border-color: var(--wr-secondary-color);
}

.image-item.selected {
    border-color: var(--wr-secondary-color);
    box-shadow: 0 0 0 4px rgba(102, 126, 234, 0.2);
}

.image-container {
    position: relative;
    aspect-ratio: 1;
    overflow: hidden;
}

.thumbnail-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--wr-transition-normal);
}

.image-item:hover .thumbnail-image {
    transform: scale(1.05);
}

/* 图片悬停遮罩 */
.image-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.7);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity var(--wr-transition-normal);
}

.image-item:hover .image-overlay,
.image-item.selected .image-overlay {
    opacity: 1;
}

.select-image-btn {
    background: var(--wr-secondary-color);
    color: white;
    border: none;
    padding: 8px 16px;
    border-radius: var(--wr-radius-sm);
    font-size: 14px;
    font-weight: var(--wr-weight-medium);
    cursor: pointer;
    transition: all var(--wr-transition-fast);
}

.select-image-btn:hover {
    background: var(--wr-accent-color);
    transform: scale(1.05);
}

/* 图片信息 */
.image-info {
    padding: 12px;
    text-align: center;
    background: var(--wr-bg-secondary);
}

.image-info small {
    color: var(--wr-text-muted);
    display: block;
    line-height: 1.4;
}

/* 加载和空状态 */
.loading-indicator,
.no-images-message {
    padding: 60px 20px;
    text-align: center;
    color: var(--wr-text-muted);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 200px;
}

.loading-indicator i {
    font-size: 24px;
    margin-bottom: 10px;
    color: var(--wr-secondary-color);
}

.no-images-message i {
    font-size: 48px;
    margin-bottom: 16px;
    color: var(--wr-text-light);
}

.no-images-message p {
    font-size: 16px;
    margin: 0;
}

/* 分页样式 */
.pagination-container {
    margin-top: auto;
    padding: 15px 0 5px 0;
    border-top: 1px solid var(--wr-border-color);
    background: var(--wr-bg-primary);
    flex-shrink: 0;
    position: sticky;
    bottom: 0;
    z-index: 10;
}

.pagination-container .but {
    margin: 0 5px;
    min-width: 40px;
    padding: 8px 12px;
    font-size: 14px;
}

.pagination-ellipsis {
    display: inline-block;
    padding: 8px 4px;
    color: var(--wr-text-muted);
    font-size: 14px;
    line-height: 1;
    vertical-align: middle;
    user-select: none;
}

/* 特色封面按钮行 */
.featured-buttons-row {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.featured-buttons-row .but {
    flex: 1;
    min-width: 120px;
}

/* 灰色禁用按钮样式 */
.but.jb-gray {
    background: #6c757d;
    border-color: #6c757d;
    color: white;
}

.but.jb-gray:hover {
    background: #5a6268;
    border-color: #545b62;
}

.but.jb-gray:disabled,
.but.jb-gray[disabled] {
    background: #6c757d;
    border-color: #6c757d;
    opacity: 0.7;
    cursor: not-allowed;
}

.but.jb-gray:disabled:hover,
.but.jb-gray[disabled]:hover {
    background: #6c757d;
    border-color: #6c757d;
    transform: none;
}

/* 响应式设计 */
@media (max-width: 768px) {
    #imageSelectModal .modal-dialog {
        max-width: 95%;
        margin: 10px auto;
    }
    
    #imageSelectModal .modal-body {
        max-height: 60vh;
        padding: 15px;
    }
    
    .image-grid {
        grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
        gap: 12px;
        padding: 10px 0 15px 0;
    }
    
    .pagination-container {
        padding: 12px 0 3px 0;
    }
    
    .pagination-container .but {
        margin: 0 3px;
        padding: 6px 10px;
        font-size: 13px;
        min-width: 35px;
    }
    
    .pagination-ellipsis {
        padding: 6px 3px;
        font-size: 13px;
    }
    
    .featured-buttons-row {
        flex-direction: column;
    }
    
    .featured-buttons-row .but {
        width: 100%;
    }
}

@media (max-width: 480px) {
    #imageSelectModal .modal-body {
        max-height: 50vh;
        padding: 12px;
    }
    
    .image-grid {
        grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
        gap: 8px;
        padding: 8px 0 12px 0;
    }
    
    .pagination-container {
        padding: 10px 0 2px 0;
    }
    
    .pagination-container .but {
        margin: 0 2px;
        padding: 5px 8px;
        font-size: 12px;
        min-width: 30px;
    }
    
    .pagination-ellipsis {
        padding: 5px 2px;
        font-size: 12px;
    }
    
    .select-image-btn {
        padding: 6px 12px;
        font-size: 12px;
    }
}

/* ================================
   瀑布流布局样式
   ================================ */

/* 瀑布流控制区域 */
.wr-waterfall-controls {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 30px;
    padding: 20px;
    background: var(--wr-glass-bg);
    backdrop-filter: blur(10px);
    border-radius: 15px;
    border: 1px solid rgba(255,255,255,0.1);
}

.wr-filter-tabs {
    display: flex;
    gap: 10px;
}

.wr-filter-tab {
    padding: 10px 20px;
    border: none;
    background: transparent;
    color: var(--wr-text-muted);
    border-radius: 25px;
    cursor: pointer;
    transition: all 0.3s ease;
    font-size: 14px;
    font-weight: 500;
}

.wr-filter-tab:hover,
.wr-filter-tab.active {
    background: var(--wr-primary-gradient);
    color: white;
    transform: translateY(-2px);
}

.wr-view-controls {
    display: flex;
    gap: 8px;
}

.wr-view-btn {
    width: 40px;
    height: 40px;
    border: none;
    background: rgba(255,255,255,0.1);
    color: var(--wr-text-muted);
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
}

.wr-view-btn:hover,
.wr-view-btn.active {
    background: var(--wr-secondary-color);
    color: white;
    transform: scale(1.1);
}

/* 瀑布流容器 */
.wr-waterfall-container {
    position: relative;
    margin: 0 auto;
}

.wr-waterfall-container[data-columns="2"] {
    column-count: 2;
    column-gap: 20px;
}

.wr-waterfall-container[data-columns="3"] {
    column-count: 3;
    column-gap: 20px;
}

.wr-waterfall-container[data-columns="4"] {
    column-count: 4;
    column-gap: 15px;
}

.wr-waterfall-sizer,
.wr-waterfall-gutter {
    display: none;
}

/* 瀑布流项目 */
.wr-waterfall-item {
    break-inside: avoid;
    margin-bottom: 20px;
    opacity: 0;
    animation: waterfallFadeIn 0.6s ease forwards;
}

.wr-waterfall-item:nth-child(1) { animation-delay: 0.1s; }
.wr-waterfall-item:nth-child(2) { animation-delay: 0.2s; }
.wr-waterfall-item:nth-child(3) { animation-delay: 0.3s; }
.wr-waterfall-item:nth-child(4) { animation-delay: 0.4s; }
.wr-waterfall-item:nth-child(5) { animation-delay: 0.5s; }
.wr-waterfall-item:nth-child(6) { animation-delay: 0.6s; }

@keyframes waterfallFadeIn {
    from {
        opacity: 0;
        transform: translateY(30px) scale(0.95);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

/* 瀑布流卡片 */
.wr-waterfall-card {
    background: var(--wr-card-bg);
    border-radius: 15px;
    overflow: hidden;
    box-shadow: var(--wr-shadow-light);
    transition: all 0.4s ease;
    border: 1px solid rgba(255,255,255,0.1);
}

.wr-waterfall-card:hover {
    transform: translateY(-8px);
    box-shadow: var(--wr-shadow-heavy);
}

.wr-waterfall-link {
    display: block;
    text-decoration: none;
    color: inherit;
}

/* 图片区域 */
.wr-waterfall-image {
    position: relative;
    overflow: hidden;
}

.wr-waterfall-img {
    width: 100%;
    height: auto;
    display: block;
    transition: transform 0.4s ease;
}

.wr-waterfall-card:hover .wr-waterfall-img {
    transform: scale(1.05);
}

.wr-waterfall-placeholder {
    aspect-ratio: 4/3;
    background: var(--wr-primary-gradient);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 14px;
}

.wr-waterfall-placeholder i {
    font-size: 32px;
    margin-bottom: 10px;
    opacity: 0.7;
}

/* 高度变化类 - 增大落差 */
.wr-height-small .wr-waterfall-placeholder {
    aspect-ratio: 4/2;
}

.wr-height-medium .wr-waterfall-placeholder {
    aspect-ratio: 4/3.2;
}

.wr-height-large .wr-waterfall-placeholder {
    aspect-ratio: 4/5;
}

/* 为真实图片也应用高度变化 */
.wr-height-small .wr-waterfall-img {
    aspect-ratio: 4/2;
    object-fit: cover;
}

.wr-height-medium .wr-waterfall-img {
    aspect-ratio: 4/3.2;
    object-fit: cover;
}

.wr-height-large .wr-waterfall-img {
    aspect-ratio: 4/5;
    object-fit: cover;
}

/* 悬浮遮罩 */
.wr-waterfall-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(to bottom, transparent 0%, rgba(0,0,0,0.8) 100%);
    opacity: 0;
    transition: all 0.3s ease;
    display: flex;
    align-items: flex-end;
    padding: 20px;
}

.wr-waterfall-card:hover .wr-waterfall-overlay {
    opacity: 1;
}

.wr-waterfall-actions {
    display: flex;
    gap: 10px;
    width: 100%;
    justify-content: center;
}

.wr-action-btn {
    background: rgba(255,255,255,0.2);
    backdrop-filter: blur(10px);
    border: none;
    padding: 8px 12px;
    border-radius: 20px;
    color: white;
    cursor: pointer;
    transition: all 0.3s ease;
    font-size: 12px;
    display: flex;
    align-items: center;
    gap: 5px;
}

.wr-action-btn:hover {
    background: var(--wr-secondary-color);
    transform: translateY(-2px);
}

/* 标签徽章 */
.wr-waterfall-badge {
    position: absolute;
    top: 12px;
    padding: 4px 8px;
    border-radius: 12px;
    font-size: 11px;
    font-weight: 600;
    color: white;
    display: flex;
    align-items: center;
    gap: 4px;
}

.wr-hot-badge {
    right: 12px;
    background: linear-gradient(135deg, #ff6b6b, #ee5a24);
}

.wr-new-badge {
    left: 12px;
    background: linear-gradient(135deg, #4834d4, #686de0);
}

/* 内容区域 */
.wr-waterfall-content {
    padding: 15px;
}

.wr-waterfall-title {
    font-size: 14px;
    font-weight: 600;
    margin: 0 0 6px 0;
    line-height: 1.3;
    color: var(--wr-text-primary);
}

.wr-waterfall-excerpt {
    font-size: 12px;
    color: var(--wr-text-muted);
    line-height: 1.4;
    margin: 0 0 12px 0;
}

/* 作者信息 */
.wr-waterfall-author {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 12px;
}

.wr-author-avatar {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    overflow: hidden;
}

.wr-avatar-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.wr-author-info {
    flex: 1;
    min-width: 0;
}

.wr-author-name {
    display: block;
    font-size: 12px;
    font-weight: 600;
    color: var(--wr-text-primary);
    margin-bottom: 1px;
}

.wr-publish-date {
    font-size: 10px;
    color: var(--wr-text-muted);
}

/* 统计信息 */
.wr-waterfall-stats {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 10px;
    border-top: 1px solid rgba(255,255,255,0.1);
}

.wr-stat-item {
    display: flex;
    align-items: center;
    gap: 3px;
    font-size: 11px;
    color: var(--wr-text-muted);
}

.wr-stat-item i {
    font-size: 10px;
}

/* 加载更多按钮 */
.wr-waterfall-footer {
    text-align: center;
    margin-top: 40px;
}

.wr-load-more-btn {
    background: var(--wr-primary-gradient);
    color: white;
    border: none;
    padding: 15px 30px;
    border-radius: 25px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.wr-load-more-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(102, 126, 234, 0.3);
}

.wr-load-more-btn:active {
    transform: translateY(0);
}

/* 瀑布流响应式设计 */
@media (max-width: 1400px) {
    .wr-waterfall-container[data-columns="4"] {
        column-count: 3;
    }
}

@media (max-width: 1024px) {
    .wr-waterfall-container[data-columns="4"] {
        column-count: 3;
    }
    
    .wr-waterfall-container[data-columns="3"] {
        column-count: 2;
    }
}

@media (max-width: 768px) {
    .wr-waterfall-container[data-columns="3"],
    .wr-waterfall-container[data-columns="4"] {
        column-count: 2;
    }
    
    .wr-waterfall-controls {
        flex-direction: column;
        gap: 15px;
    }
    
    .wr-filter-tabs {
        flex-wrap: wrap;
        justify-content: center;
    }
    
    .wr-waterfall-content {
        padding: 12px;
    }
}

@media (max-width: 480px) {
    .wr-waterfall-container {
        column-count: 1 !important;
    }
    
    .wr-filter-tab {
        padding: 8px 15px;
        font-size: 13px;
    }
}

/* ================================
   瀑布流交互效果样式
   ================================ */

/* 点赞按钮动画 */
.wr-like-btn.animate-like {
    animation: likeAnimation 0.6s ease;
}

@keyframes likeAnimation {
    0% { transform: scale(1); }
    50% { transform: scale(1.2); color: #ff6b6b; }
    100% { transform: scale(1); }
}

.wr-like-btn.liked {
    background: #ff6b6b !important;
    color: white !important;
}

/* 涟漪效果 */
.wr-action-btn {
    position: relative;
    overflow: hidden;
}

.ripple {
    position: absolute;
    border-radius: 50%;
    background: rgba(255,255,255,0.6);
    transform: scale(0);
    animation: rippleAnimation 0.6s linear;
    pointer-events: none;
}

@keyframes rippleAnimation {
    to {
        transform: scale(4);
        opacity: 0;
    }
}

/* Toast 提示样式 */
.wr-toast {
    position: fixed;
    top: 20px;
    right: 20px;
    background: var(--wr-primary-gradient);
    color: white;
    padding: 12px 20px;
    border-radius: 25px;
    font-size: 14px;
    font-weight: 500;
    z-index: 10000;
    transform: translateX(100%);
    transition: transform 0.3s ease;
    box-shadow: 0 4px 20px rgba(0,0,0,0.2);
}

.wr-toast.show {
    transform: translateX(0);
}

/* 加载状态样式 */
.wr-load-more-btn.loading {
    pointer-events: none;
    opacity: 0.7;
}

.wr-load-more-btn:disabled {
    background: #28a745;
    cursor: not-allowed;
}

/* 悬浮遮罩增强 */
.wr-waterfall-overlay.show {
    opacity: 1;
}

/* 瀑布流项目隐藏动画 */
.wr-waterfall-item.filtering {
    transition: opacity 0.3s ease, transform 0.3s ease;
}

.wr-waterfall-item.hidden {
    opacity: 0;
    transform: scale(0.8);
}

/* ================================
   资源下载按钮样式
   ================================ */
.resource-download-section {
    margin: var(--wr-spacing-lg) 0;
    padding: var(--wr-spacing-lg);
    background: linear-gradient(135deg, rgba(102, 126, 234, 0.05) 0%, rgba(118, 75, 162, 0.05) 100%);
    border: 1px solid rgba(102, 126, 234, 0.1);
    border-radius: var(--wr-radius-lg);
    position: relative;
    overflow: hidden;
}

.resource-download-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.1), transparent);
    animation: downloadShimmer 3s infinite;
}

@keyframes downloadShimmer {
    0% { left: -100%; }
    50% { left: 100%; }
    100% { left: 100%; }
}

.download-button-container {
    text-align: center;
    position: relative;
    z-index: 1;
}

/* 优化下载按钮 - 缩小尺寸，仅保留图标 */
.resource-download-btn {
    display: inline-flex;
    flex-direction: row;           /* 改为行排列，图标和文字并排 */
    align-items: center;
    justify-content: center;
    padding: 8px 12px;             /* 大幅缩小内边距 */
    background: transparent;       /* 移除背景渐变 */
    color: rgba(255, 255, 255, 0.8) !important; /* 半透明白色 */
    text-decoration: none !important;
    border-radius: var(--wr-radius-sm); /* 使用更小的圆角 */
    font-weight: var(--wr-weight-medium);
    min-width: auto;               /* 移除最小宽度限制 */
    transition: all 0.2s ease;     /* 更快的过渡 */
    box-shadow: none;              /* 移除阴影 */
    position: relative;
    overflow: visible;
    transform: translateY(0);
    gap: 6px;                      /* 图标和文字间距 */
}

/* 下载按钮悬停效果 - 简化 */
.resource-download-btn:hover {
    transform: scale(1.05);        /* 轻微放大 */
    color: #3498db !important;     /* 悬停时蓝色 */
    background: rgba(52, 152, 219, 0.1); /* 轻微蓝色背景 */
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1); /* 轻微阴影 */
}

.resource-download-btn:active {
    transform: scale(0.98);        /* 点击时轻微缩小 */
    background: rgba(52, 152, 219, 0.2); /* 点击时更明显的背景 */
}

/* 下载图标优化 */
.resource-download-btn i {
    font-size: 16px;              /* 缩小图标 */
    margin-bottom: 0;             /* 移除底边距，因为现在是水平布局 */
    animation: none;              /* 移除跳动动画 */
}

@keyframes downloadBounce {
    0%, 20%, 50%, 80%, 100% {
        transform: translateY(0);
    }
    40% {
        transform: translateY(-4px);
    }
    60% {
        transform: translateY(-2px);
    }
}

/* 下载按钮文字优化 */
.resource-download-btn .btn-text {
    font-size: 13px;              /* 缩小文字 */
    font-weight: var(--wr-weight-medium);
    margin-bottom: 0;             /* 移除底边距 */
    letter-spacing: 0.3px;        /* 减少字母间距 */
    white-space: nowrap;          /* 防止文字换行 */
}

/* 隐藏按钮描述文字，只保留主要文字 */
.resource-download-btn .btn-desc {
    display: none;                /* 完全隐藏描述文字 */
}

.download-info {
    margin-top: var(--wr-spacing-md);
}

.download-tip {
    display: inline-flex;
    align-items: center;
    gap: var(--wr-spacing-xs);
    color: var(--muted-color, #6c757d);
    font-size: 12px;
    padding: var(--wr-spacing-sm) var(--wr-spacing-md);
    background: rgba(108, 117, 125, 0.1);
    border-radius: var(--wr-radius-sm);
}

.download-tip i {
    font-size: 14px;
    opacity: 0.8;
}

/* 响应式设计 - 优化移动端下载按钮 */
@media (max-width: 768px) {
    .resource-download-section {
        margin: var(--wr-spacing-sm) 0;  /* 减少边距 */
        padding: var(--wr-spacing-sm);   /* 减少内边距 */
    }
    
    .resource-download-btn {
        min-width: auto;             /* 移除最小宽度 */
        padding: 6px 10px;           /* 进一步缩小内边距 */
        font-size: 12px;             /* 缩小整体字体 */
    }
    
    .resource-download-btn i {
        font-size: 14px;             /* 移动端图标稍小 */
    }
    
    .resource-download-btn .btn-text {
        font-size: 12px;             /* 移动端文字更小 */
    }
    
    .resource-download-btn .btn-desc {
        display: none;               /* 移动端继续隐藏描述 */
    }
}

/* ================================
   滑块触控交互优化脚本
   ================================ */

/* 
使用说明：
1. 已创建 slider-touch-optimization.js 文件来处理滑块触控优化
2. 请在页面中引入该JavaScript文件：
   <script src="wp-content/plugins/WorkRelease/js/slider-touch-optimization.js"></script>
3. 或者将以下简化代码直接添加到页面：

<script>
document.addEventListener('DOMContentLoaded', function() {
    const sliders = document.querySelectorAll('.explode-slider-overlay');
    let scrollPosition = 0;
    
    sliders.forEach(function(slider) {
        slider.addEventListener('touchstart', function(e) {
            scrollPosition = window.pageYOffset;
            document.body.classList.add('slider-active');
            document.body.style.top = '-' + scrollPosition + 'px';
        }, { passive: true });
        
        slider.addEventListener('touchend', function(e) {
            document.body.classList.remove('slider-active');
            document.body.style.top = '';
            window.scrollTo(0, scrollPosition);
        }, { passive: true });
        
        slider.addEventListener('touchcancel', function(e) {
            document.body.classList.remove('slider-active');
            document.body.style.top = '';
            window.scrollTo(0, scrollPosition);
        }, { passive: true });
    });
});
</script>

*/

/* 暗色主题适配 */
@media (prefers-color-scheme: dark) {
    .resource-download-section {
        background: linear-gradient(135deg, rgba(102, 126, 234, 0.08) 0%, rgba(118, 75, 162, 0.08) 100%);
        border-color: rgba(102, 126, 234, 0.15);
    }
    
    .download-tip {
        background: rgba(255, 255, 255, 0.05);
        color: rgba(255, 255, 255, 0.7);
    }
}

/* ================================
   表单字段标签样式
   ================================ */
.form-label .optional {
    color: var(--muted-color, #6c757d);
    font-weight: var(--wr-weight-normal);
    font-size: 0.9em;
    margin-left: var(--wr-spacing-xs);
}

.form-label .required {
    color: #dc3545;
    font-weight: bold;
    margin-left: var(--wr-spacing-xs);
}

.form-help {
    display: block;
    margin-top: var(--wr-spacing-xs);
    font-size: 12px;
    color: var(--muted-color, #6c757d);
    line-height: 1.4;
}

/* 错误输入框样式 */
.error-input {
    border-color: #dc3545 !important;
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25) !important;
}

.domain-error {
    display: flex;
    align-items: center;
    gap: var(--wr-spacing-xs);
    animation: errorSlideIn 0.3s ease-out;
}

@keyframes errorSlideIn {
    from {
        opacity: 0;
        transform: translateY(-5px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.domain-error i {
    flex-shrink: 0;
}

/* ================================
   审核状态相关样式
   ================================ */

/* 审核状态标签页 */
.review-status-tabs {
    margin-bottom: var(--wr-spacing-lg);
    background: white;
    border-radius: var(--wr-radius-lg);
    box-shadow: var(--wr-shadow-light);
    overflow: hidden;
}

.status-tabs-nav {
    display: flex;
    background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
    border-bottom: 2px solid #dee2e6;
}

.status-tab {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--wr-spacing-sm);
    padding: var(--wr-spacing-md) var(--wr-spacing-lg);
    color: #6c757d;
    text-decoration: none;
    font-weight: var(--wr-weight-medium);
    border-bottom: 3px solid transparent;
    transition: all var(--wr-transition-normal);
    position: relative;
    overflow: hidden;
}

.status-tab::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, rgba(102, 126, 234, 0.1) 0%, rgba(118, 75, 162, 0.1) 100%);
    transition: left var(--wr-transition-normal);
}

.status-tab:hover::before {
    left: 0;
}

.status-tab:hover {
    color: var(--wr-secondary-color);
    background-color: rgba(102, 126, 234, 0.05);
}

.status-tab.active {
    color: var(--wr-secondary-color);
    background: linear-gradient(135deg, rgba(102, 126, 234, 0.15) 0%, rgba(118, 75, 162, 0.15) 100%);
    border-bottom-color: var(--wr-secondary-color);
    font-weight: var(--wr-weight-semibold);
}

.status-tab i {
    font-size: 16px;
    z-index: 2;
    position: relative;
}

.status-tab span {
    z-index: 2;
    position: relative;
}

.status-count {
    background: rgba(102, 126, 234, 0.1);
    color: var(--wr-secondary-color);
    padding: 2px 8px;
    border-radius: var(--wr-radius-full);
    font-size: 12px;
    font-weight: var(--wr-weight-bold);
    min-width: 20px;
    text-align: center;
}

.status-count.pending {
    background: rgba(255, 193, 7, 0.15);
    color: #e67e22;
}

.status-count.rejected {
    background: rgba(220, 53, 69, 0.15);
    color: #dc3545;
}

.status-tab.active .status-count {
    background: var(--wr-secondary-color);
    color: white;
}

.status-tab.active .status-count.pending {
    background: #e67e22;
    color: white;
}

.status-tab.active .status-count.rejected {
    background: #dc3545;
    color: white;
}

/* 状态说明区域 */
.status-description {
    padding: var(--wr-spacing-md) var(--wr-spacing-lg);
    background: linear-gradient(135deg, #f8f9fa 0%, #ffffff 100%);
}

.status-info {
    display: flex;
    align-items: center;
    gap: var(--wr-spacing-sm);
    padding: var(--wr-spacing-sm) var(--wr-spacing-md);
    border-radius: var(--wr-radius-sm);
    font-size: 14px;
    line-height: 1.5;
}

.status-info.published {
    background: rgba(40, 167, 69, 0.1);
    color: #28a745;
    border-left: 4px solid #28a745;
}

.status-info.pending {
    background: rgba(255, 193, 7, 0.1);
    color: #e67e22;
    border-left: 4px solid #e67e22;
}

.status-info.rejected {
    background: rgba(220, 53, 69, 0.1);
    color: #dc3545;
    border-left: 4px solid #dc3545;
}

.status-info i {
    font-size: 16px;
    flex-shrink: 0;
}

/* 作品状态标识 */
.work-status-badge {
    position: absolute;
    top: var(--wr-spacing-sm);
    right: var(--wr-spacing-sm);
    z-index: 10;
    display: flex;
    align-items: center;
    gap: var(--wr-spacing-xs);
    padding: var(--wr-spacing-xs) var(--wr-spacing-sm);
    border-radius: var(--wr-radius-sm);
    font-size: 11px;
    font-weight: var(--wr-weight-bold);
    text-transform: uppercase;
    backdrop-filter: blur(8px);
    box-shadow: var(--wr-shadow-light);
    animation: statusBadgeAppear 0.5s ease-out;
}

@keyframes statusBadgeAppear {
    from {
        opacity: 0;
        transform: scale(0.8) translateY(-10px);
    }
    to {
        opacity: 1;
        transform: scale(1) translateY(0);
    }
}

.work-status-badge.status-pending {
    background: linear-gradient(135deg, rgba(255, 193, 7, 0.9) 0%, rgba(230, 126, 34, 0.9) 100%);
    color: white;
}

.work-status-badge.status-rejected {
    background: linear-gradient(135deg, rgba(220, 53, 69, 0.9) 0%, rgba(231, 76, 60, 0.9) 100%);
    color: white;
}

.work-status-badge i {
    font-size: 12px;
}

/* 作品状态样式 */
.work-status-pending .masonry-item-content {
    position: relative;
    overflow: hidden;
}

.work-status-pending .masonry-item-content::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, rgba(255, 193, 7, 0.1) 0%, rgba(230, 126, 34, 0.1) 100%);
    z-index: 1;
    pointer-events: none;
}

.work-status-rejected .masonry-item-content {
    position: relative;
    overflow: hidden;
}

.work-status-rejected .masonry-item-content::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, rgba(220, 53, 69, 0.1) 0%, rgba(231, 76, 60, 0.1) 100%);
    z-index: 1;
    pointer-events: none;
}

.work-status-pending .portfolio-link img,
.work-status-rejected .portfolio-link img {
    filter: grayscale(0.3) brightness(0.9);
}

/* 审核状态信息 */
.review-status-info {
    margin: var(--wr-spacing-sm) 0;
    padding: var(--wr-spacing-sm);
    border-radius: var(--wr-radius-sm);
    background: rgba(255, 255, 255, 0.9);
    backdrop-filter: blur(4px);
    z-index: 2;
    position: relative;
}

.status-text {
    display: flex;
    align-items: center;
    gap: var(--wr-spacing-xs);
    font-size: 12px;
    font-weight: var(--wr-weight-medium);
    margin-bottom: var(--wr-spacing-xs);
}

.status-text.pending {
    color: #e67e22;
}

.status-text.rejected {
    color: #dc3545;
}

.status-text i {
    font-size: 14px;
    flex-shrink: 0;
}

.review-feedback {
    margin-top: var(--wr-spacing-xs);
    padding: var(--wr-spacing-xs) var(--wr-spacing-sm);
    background: rgba(220, 53, 69, 0.05);
    border-left: 3px solid #dc3545;
    border-radius: 0 var(--wr-radius-sm) var(--wr-radius-sm) 0;
    font-size: 11px;
    line-height: 1.4;
    color: #721c24;
}

.review-feedback strong {
    color: #dc3545;
    font-weight: var(--wr-weight-semibold);
}

/* 悬停效果增强 */
.work-status-pending:hover .masonry-item-content::before {
    background: linear-gradient(135deg, rgba(255, 193, 7, 0.15) 0%, rgba(230, 126, 34, 0.15) 100%);
}

.work-status-rejected:hover .masonry-item-content::before {
    background: linear-gradient(135deg, rgba(220, 53, 69, 0.15) 0%, rgba(231, 76, 60, 0.15) 100%);
}

/* 点击提示文字调整 */
.work-status-rejected .masonry-click-hint {
    background: linear-gradient(135deg, rgba(220, 53, 69, 0.9) 0%, rgba(231, 76, 60, 0.9) 100%);
}

.work-status-pending .masonry-click-hint {
    background: linear-gradient(135deg, rgba(255, 193, 7, 0.9) 0%, rgba(230, 126, 34, 0.9) 100%);
}

/* 响应式设计 */
@media (max-width: 768px) {
    .status-tabs-nav {
        flex-direction: column;
    }
    
    .status-tab {
        justify-content: flex-start;
        padding: var(--wr-spacing-sm) var(--wr-spacing-md);
    }
    
    .status-description {
        padding: var(--wr-spacing-sm) var(--wr-spacing-md);
    }
    
    .work-status-badge {
        top: var(--wr-spacing-xs);
        right: var(--wr-spacing-xs);
        padding: 2px var(--wr-spacing-xs);
        font-size: 10px;
    }
    
    .work-status-badge span {
        display: none;
    }
    
    .review-feedback {
        font-size: 10px;
    }
}

/* 暗色主题适配 */
@media (prefers-color-scheme: dark) {
    .review-status-tabs {
        background: var(--dark-bg, #1f1f1f);
    }
    
    .status-tabs-nav {
        background: linear-gradient(135deg, #2c2c2c 0%, #3c3c3c 100%);
        border-bottom-color: #4a4a4a;
    }
    
    .status-tab {
        color: #adb5bd;
    }
    
    .status-tab:hover {
        background-color: rgba(102, 126, 234, 0.1);
    }
    
    .status-tab.active {
        background: linear-gradient(135deg, rgba(102, 126, 234, 0.2) 0%, rgba(118, 75, 162, 0.2) 100%);
    }
    
    .status-description {
        background: linear-gradient(135deg, #2c2c2c 0%, #1f1f1f 100%);
    }
    
    .status-info.published {
        background: rgba(40, 167, 69, 0.15);
        color: #4caf50;
    }
    
    .status-info.pending {
        background: rgba(255, 193, 7, 0.15);
        color: #ff9800;
    }
    
    .status-info.rejected {
        background: rgba(220, 53, 69, 0.15);
        color: #f44336;
    }
    
    .review-status-info {
        background: rgba(255, 255, 255, 0.05);
    }
    
    .review-feedback {
        background: rgba(220, 53, 69, 0.1);
        color: #ffcdd2;
    }
    
    .review-feedback strong {
        color: #f44336;
    }
}

/* ================================
   用户中心管理员面板样式 - 子比主题风格
   ================================ */

/* 管理员面板主容器 - 暗色现代简约扁平风格 */
.user-center-admin-panel {
    background: #1a1a1a;
    border-radius: 8px;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.4);
    border: 1px solid #2d2d2d;
    margin-bottom: 24px;
    overflow: hidden;
    width: 100%;
    transition: all 0.3s ease;
}

.user-center-admin-panel:hover {
    box-shadow: 0 6px 32px rgba(0, 0, 0, 0.5);
    border-color: #3a3a3a;
}

/* 面板头部 - 暗色现代简约扁平风格 */
.admin-panel-header {
    background: #2a2a2a;
    color: #ffffff;
    padding: 20px 24px;
    font-weight: 500;
    font-size: 18px;
    display: flex;
    align-items: center;
    gap: 10px;
    position: relative;
    border-bottom: 1px solid #3a3a3a;
}

.admin-panel-header i {
    font-size: 20px;
    opacity: 0.8;
    color: #00d4aa;
}

.panel-title {
    font-weight: 500;
    color: #ffffff;
}

/* 面板内容区 - 暗色现代简约扁平风格 */
.admin-panel-content {
    padding: 24px;
    background: #1a1a1a;
    color: #e5e5e5;
}

/* 统计网格 - 暗色现代简约扁平风格 */
.admin-stats {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
    margin-bottom: 24px;
}

/* 统计卡片 - 暗色现代简约扁平风格 */
.stat-item {
    background: #2a2a2a;
    border: 1px solid #3a3a3a;
    border-radius: 6px;
    padding: 20px 16px;
    text-align: center;
    transition: all 0.2s ease;
    position: relative;
}

.stat-item::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: #00d4aa;
}

.stat-item:nth-child(1)::before { background: #00d4aa; }
.stat-item:nth-child(2)::before { background: #ff6b6b; }
.stat-item:nth-child(3)::before { background: #4ecdc4; }
.stat-item:nth-child(4)::before { background: #45b7d1; }

.stat-item:hover {
    background: #333333;
    border-color: #4a4a4a;
}

/* 统计数字 - 暗色现代简约扁平风格 */
.stat-number {
    font-size: 28px;
    font-weight: 600;
    color: #ffffff;
    margin-bottom: 6px;
    line-height: 1;
}

.stat-label {
    font-size: 12px;
    color: #cccccc;
    letter-spacing: 0.3px;
    font-weight: 400;
}

/* 操作按钮组 */
.admin-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

/* 操作按钮 - 子比按钮风格 */
.admin-action-btn {
    flex: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 16px;
    background: #00d4aa;
    color: #ffffff;
    text-decoration: none;
    border-radius: 4px;
    font-size: 14px;
    font-weight: 500;
    transition: all 0.2s ease;
    min-height: 40px;
    border: none;
    cursor: pointer;
}

.admin-action-btn:hover {
    background: #00b894;
    color: #ffffff;
    text-decoration: none;
}

.admin-action-btn.pending {
    background: #ff6b6b;
}

.admin-action-btn.pending:hover {
    background: #e55555;
}

.admin-action-btn i {
    font-size: 16px;
}

/* 作品列表容器 - 暗色现代简约扁平风格 */
.recent-works-list {
    max-height: 320px;
    overflow-y: auto;
    margin-top: 20px;
    border: 1px solid #3a3a3a;
    border-radius: 6px;
    background: #2a2a2a;
}

/* 自定义滚动条 - 暗色现代简约扁平风格 */
.recent-works-list::-webkit-scrollbar {
    width: 6px;
}

.recent-works-list::-webkit-scrollbar-track {
    background: #1a1a1a;
}

.recent-works-list::-webkit-scrollbar-thumb {
    background: #4a4a4a;
    border-radius: 3px;
}

.recent-works-list::-webkit-scrollbar-thumb:hover {
    background: #5a5a5a;
}

/* 作品项 - 暗色现代简约扁平风格 */
.work-item {
    padding: 16px;
    border-bottom: 1px solid #3a3a3a;
    transition: all 0.2s ease;
    position: relative;
    color: #e5e5e5;
}

.work-item:last-child {
    border-bottom: none;
}

.work-item:hover {
    background: #333333;
}

/* 作品头部 */
.work-header {
    margin-bottom: 8px;
}

/* 作品标题 - 暗色现代简约扁平风格 */
.work-title {
    font-size: 15px;
    font-weight: 500;
    color: #ffffff;
    margin: 0 0 8px 0;
    line-height: 1.4;
}

/* 作品元信息 - 暗色现代简约扁平风格 */
.work-meta {
    display: flex;
    gap: 12px;
    font-size: 12px;
    color: #cccccc;
    margin-bottom: 8px;
}

.work-meta span {
    display: flex;
    align-items: center;
    gap: 4px;
}

/* 反馈消息 - 暗色现代简约扁平风格 */
.feedback-message {
    background: #3a2a2a;
    border: 1px solid #ff6b6b;
    border-radius: 4px;
    padding: 8px 10px;
    margin-top: 8px;
    font-size: 12px;
    color: #ffcccc;
    display: flex;
    align-items: flex-start;
    gap: 6px;
}

.feedback-message i {
    margin-top: 1px;
}

/* 快速操作按钮 */
.work-actions {
    display: flex;
    gap: 6px;
    margin-top: 8px;
    flex-wrap: wrap;
}

.quick-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    font-size: 12px;
    font-weight: 500;
    border: none;
    border-radius: 3px;
    cursor: pointer;
    text-decoration: none;
    transition: all 0.2s ease;
    min-height: 28px;
    white-space: nowrap;
}

.quick-btn.approve {
    background: #00d4aa;
    color: #ffffff;
}

.quick-btn.approve:hover {
    background: #00b894;
    color: #ffffff;
}

.quick-btn.reject {
    background: #ff6b6b;
    color: #ffffff;
}

.quick-btn.reject:hover {
    background: #e55555;
    color: #ffffff;
}

.quick-btn.edit {
    background: #4ecdc4;
    color: #ffffff;
}

.quick-btn.edit:hover {
    background: #26a69a;
    color: #ffffff;
    text-decoration: none;
}

.quick-btn.view {
    background: #4a4a4a;
    color: #ffffff;
}

.quick-btn.view:hover {
    background: #5a5a5a;
    color: #ffffff;
}

.quick-btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

/* 空状态 */
.no-works-message {
    text-align: center;
    padding: 32px 20px;
    color: #999;
    background: #f8f9fa;
    border-radius: 6px;
    font-style: italic;
}

/* 侧边栏适配 - 子比响应式风格 */
.user-center-sidebar .user-center-admin-panel,
.user-center-right .user-center-admin-panel,
.sidebar .user-center-admin-panel,
.col-right .user-center-admin-panel,
.col-md-4 .user-center-admin-panel,
.col-lg-4 .user-center-admin-panel {
    margin-bottom: 16px;
}

.user-center-sidebar .admin-panel-content,
.user-center-right .admin-panel-content,
.sidebar .admin-panel-content,
.col-right .admin-panel-content,
.col-md-4 .admin-panel-content,
.col-lg-4 .admin-panel-content {
    padding: 16px;
}

.user-center-sidebar .admin-stats,
.user-center-right .admin-stats,
.sidebar .admin-stats,
.col-right .admin-stats,
.col-md-4 .admin-stats,
.col-lg-4 .admin-stats {
    gap: 8px;
}

.user-center-sidebar .stat-item,
.user-center-right .stat-item,
.sidebar .stat-item,
.col-right .stat-item,
.col-md-4 .stat-item,
.col-lg-4 .stat-item {
    padding: 12px 8px;
}

.user-center-sidebar .stat-number,
.user-center-right .stat-number,
.sidebar .stat-number,
.col-right .stat-number,
.col-md-4 .stat-number,
.col-lg-4 .stat-number {
    font-size: 18px;
}

.user-center-sidebar .stat-label,
.user-center-right .stat-label,
.sidebar .stat-label,
.col-right .stat-label,
.col-md-4 .stat-label,
.col-lg-4 .stat-label {
    font-size: 10px;
}

.user-center-sidebar .admin-actions,
.user-center-right .admin-actions,
.sidebar .admin-actions,
.col-right .admin-actions,
.col-md-4 .admin-actions,
.col-lg-4 .admin-actions {
    flex-direction: column;
    gap: 4px;
}

.user-center-sidebar .admin-action-btn,
.user-center-right .admin-action-btn,
.sidebar .admin-action-btn,
.col-right .admin-action-btn,
.col-md-4 .admin-action-btn,
.col-lg-4 .admin-action-btn {
    padding: 8px 12px;
    font-size: 12px;
    min-height: 28px;
}

.user-center-sidebar .work-item,
.user-center-right .work-item,
.sidebar .work-item,
.col-right .work-item,
.col-md-4 .work-item,
.col-lg-4 .work-item {
    padding: 12px;
}

.user-center-sidebar .quick-btn,
.user-center-right .quick-btn,
.sidebar .quick-btn,
.col-right .quick-btn,
.col-md-4 .quick-btn,
.col-lg-4 .quick-btn {
    padding: 3px 6px;
    font-size: 10px;
    min-height: 20px;
}

/* 响应式设计 */
@media (max-width: 768px) {
    .admin-stats {
        grid-template-columns: repeat(2, 1fr);
        gap: 8px;
    }
    
    .admin-actions {
        flex-direction: column;
        gap: 6px;
    }
    
    .work-item {
        padding: 12px;
    }
    
    .work-actions {
        flex-wrap: wrap;
        gap: 4px;
    }
    
    .quick-btn {
        padding: 3px 6px;
        font-size: 10px;
    }
}

/* ==========================================
   拒绝作品模态框样式 - 黑暗主题
   ========================================== */

/* 模态框遮罩层 */
.workrelease-reject-modal-overlay {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background: rgba(0, 0, 0, 0.8) !important;
    z-index: 10001 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    backdrop-filter: blur(4px);
}

/* 模态框主体 */
.workrelease-reject-modal {
    background: #1a1a1a !important;
    border: 1px solid #333 !important;
    border-radius: 12px !important;
    max-width: 520px !important;
    width: 90% !important;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.5) !important;
    position: relative !important;
    overflow: hidden !important;
    animation: workrelease-modal-fade-in 0.3s ease;
}

@keyframes workrelease-modal-fade-in {
    from {
        opacity: 0;
        transform: scale(0.9) translateY(-20px);
    }
    to {
        opacity: 1;
        transform: scale(1) translateY(0);
    }
}

/* 模态框头部 */
.workrelease-modal-header {
    padding: 24px 60px 20px 24px !important;
    border-bottom: 1px solid #333 !important;
    display: block !important;
    background: linear-gradient(135deg, #2a2a2a, #1f1f1f) !important;
    position: relative !important;
}

/* 模态框标题 */
.workrelease-modal-title {
    margin: 0 !important;
    color: #ffffff !important;
    background: linear-gradient(135deg, #ef4444, #dc2626) !important;
    padding: 10px 18px !important;
    border-radius: 8px !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    box-shadow: 0 2px 8px rgba(239, 68, 68, 0.3) !important;
}

/* 关闭按钮 */
.workrelease-close-modal {
    background: none !important;
    border: none !important;
    font-size: 24px !important;
    color: #999 !important;
    cursor: pointer !important;
    padding: 4px !important;
    width: 32px !important;
    height: 32px !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: all 0.2s ease !important;
    line-height: 1 !important;
    position: absolute !important;
    top: 16px !important;
    right: 16px !important;
    margin: 0 !important;
}

.workrelease-close-modal:hover {
    background-color: #333 !important;
    color: #fff !important;
    transform: rotate(90deg) !important;
}

/* 模态框内容 */
.workrelease-modal-content {
    padding: 24px !important;
    background: #1a1a1a !important;
}

/* 描述文本 */
.workrelease-modal-description {
    margin-bottom: 20px !important;
    color: #cccccc !important;
    line-height: 1.6 !important;
    font-size: 14px !important;
}

/* 文本域 */
.workrelease-reject-textarea {
    width: 100% !important;
    height: 120px !important;
    padding: 14px !important;
    border: 2px solid #333 !important;
    border-radius: 8px !important;
    resize: vertical !important;
    box-sizing: border-box !important;
    font-family: inherit !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
    background: #2a2a2a !important;
    color: #ffffff !important;
    transition: border-color 0.2s ease !important;
}

.workrelease-reject-textarea:focus {
    outline: none !important;
    border-color: #ef4444 !important;
    box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.1) !important;
}

.workrelease-reject-textarea::placeholder {
    color: #888 !important;
}

/* 按钮容器 */
.workrelease-modal-actions {
    margin-top: 24px !important;
    display: flex !important;
    gap: 12px !important;
    justify-content: flex-end !important;
}

/* 取消按钮 */
.workrelease-cancel-reject {
    padding: 12px 20px !important;
    background: linear-gradient(135deg, #4a5568, #2d3748) !important;
    color: #ffffff !important;
    border: none !important;
    border-radius: 8px !important;
    cursor: pointer !important;
    font-weight: 500 !important;
    transition: all 0.2s ease !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3) !important;
}

.workrelease-cancel-reject:hover {
    background: linear-gradient(135deg, #2d3748, #1a202c) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.4) !important;
}

/* 确认拒绝按钮 */
.workrelease-confirm-reject {
    padding: 12px 20px !important;
    background: linear-gradient(135deg, #ef4444, #dc2626) !important;
    color: #ffffff !important;
    border: none !important;
    border-radius: 8px !important;
    cursor: pointer !important;
    font-weight: 500 !important;
    transition: all 0.2s ease !important;
    box-shadow: 0 2px 4px rgba(239, 68, 68, 0.3) !important;
}

.workrelease-confirm-reject:hover {
    background: linear-gradient(135deg, #dc2626, #b91c1c) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 8px rgba(239, 68, 68, 0.4) !important;
}

/* 响应式适配 */
@media (max-width: 768px) {
    .workrelease-reject-modal {
        width: 95% !important;
        max-width: none !important;
    }
    
    .workrelease-modal-header {
        padding: 20px 50px 16px 20px !important;
    }
    
    .workrelease-modal-content {
        padding: 20px !important;
    }
    
    .workrelease-close-modal {
        top: 12px !important;
        right: 12px !important;
        width: 28px !important;
        height: 28px !important;
        font-size: 20px !important;
    }
    
    .workrelease-modal-actions {
        flex-direction: column !important;
        gap: 8px !important;
    }
    
    .workrelease-cancel-reject,
    .workrelease-confirm-reject {
        width: 100% !important;
        justify-content: center !important;
    }
}

/* ==========================================
   作品列表模态框样式 - 暗色现代简约扁平风格
   ========================================== */

/* 模态框遮罩层 */
.workrelease-works-modal-overlay {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background: rgba(0, 0, 0, 0.8) !important;
    z-index: 10000 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    backdrop-filter: blur(4px);
}

/* 模态框主体 */
.workrelease-works-modal {
    background: #1a1a1a !important;
    border: 1px solid #333 !important;
    border-radius: 12px !important;
    max-width: 800px !important;
    max-height: 80% !important;
    width: 90% !important;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.5) !important;
    position: relative !important;
    overflow: hidden !important;
    animation: workrelease-works-modal-fade-in 0.3s ease;
}

@keyframes workrelease-works-modal-fade-in {
    from {
        opacity: 0;
        transform: scale(0.9) translateY(-20px);
    }
    to {
        opacity: 1;
        transform: scale(1) translateY(0);
    }
}

/* 模态框头部 */
.workrelease-works-modal-header {
    padding: 24px 60px 20px 24px !important;
    border-bottom: 1px solid #333 !important;
    display: block !important;
    background: linear-gradient(135deg, #2a2a2a, #1f1f1f) !important;
    position: relative !important;
}

/* 模态框标题 */
.workrelease-works-modal-title {
    margin: 0 !important;
    color: #ffffff !important;
    background: linear-gradient(135deg, #00d4aa, #00b894) !important;
    padding: 10px 18px !important;
    border-radius: 8px !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    box-shadow: 0 2px 8px rgba(0, 212, 170, 0.3) !important;
}

/* 关闭按钮 */
.workrelease-works-close-modal {
    background: none !important;
    border: none !important;
    font-size: 24px !important;
    color: #999 !important;
    cursor: pointer !important;
    padding: 4px !important;
    width: 32px !important;
    height: 32px !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: all 0.2s ease !important;
    line-height: 1 !important;
    position: absolute !important;
    top: 16px !important;
    right: 16px !important;
    margin: 0 !important;
}

.workrelease-works-close-modal:hover {
    background-color: #333 !important;
    color: #fff !important;
    transform: rotate(90deg) !important;
}

/* 模态框内容 */
.workrelease-works-modal-content {
    padding: 24px !important;
    background: #1a1a1a !important;
    color: #e5e5e5 !important;
    max-height: 60vh !important;
    overflow-y: auto !important;
}

/* 加载状态 */
.workrelease-loading {
    text-align: center !important;
    padding: 40px 20px !important;
    color: #cccccc !important;
    font-size: 14px !important;
}

.workrelease-loading i {
    font-size: 20px !important;
    margin-right: 8px !important;
    color: #00d4aa !important;
}

/* 响应式适配 */
@media (max-width: 768px) {
    .workrelease-works-modal {
        width: 95% !important;
        max-width: none !important;
        max-height: 85% !important;
    }
    
    .workrelease-works-modal-header {
        padding: 20px 50px 16px 20px !important;
    }
    
    .workrelease-works-modal-content {
        padding: 20px !important;
        max-height: 50vh !important;
    }
    
    .workrelease-works-close-modal {
        top: 12px !important;
        right: 12px !important;
        width: 28px !important;
        height: 28px !important;
        font-size: 20px !important;
    }
}

/* ================================
   3D查看器后期渲染设置样式
   ================================ */

/* 后期渲染控制面板 - 使用与其他控制面板相同的样式 */

/* 后期渲染选项 */
.post-processing-options {
    display: flex;
    gap: var(--wr-spacing-sm);
    margin-bottom: var(--wr-spacing-md);
    flex-wrap: wrap;
}

.post-processing-option {
    display: flex;
    align-items: center;
    gap: var(--wr-spacing-xs);
    padding: var(--wr-spacing-xs) var(--wr-spacing-sm);
    border-radius: var(--wr-radius-sm);
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.1);
    cursor: pointer;
    transition: var(--wr-transition-fast);
    color: #b0b0b0;
    font-size: 12px;
    min-width: 60px;
    justify-content: center;
}

.post-processing-option.active {
    background: rgba(102, 126, 234, 0.2);
    border-color: var(--wr-secondary-color);
    color: #ffffff;
}

.post-processing-option:hover {
    background: rgba(255, 255, 255, 0.12);
    border-color: rgba(255, 255, 255, 0.2);
}

.post-processing-option input[type="checkbox"] {
    display: none;
}

/* 后期渲染所有控制区域 */
.post-processing-all-controls {
    margin-top: var(--wr-spacing-sm);
}

/* 后期渲染区段 */
.post-processing-section {
    margin-bottom: var(--wr-spacing-md);
}

.post-processing-section:last-child {
    margin-bottom: 0;
}

/* Bloom复选框标签样式已移除，现在使用单一的发光效果开关 */

/* 后期渲染参数行 */
.post-processing-row {
    display: flex;
    gap: var(--wr-spacing-md);
    align-items: flex-start;
    flex-wrap: wrap;
    margin-bottom: var(--wr-spacing-sm);
}

/* 后期渲染参数项 */
.post-processing-param {
    flex: 1;
    min-width: 100px;
    max-width: 180px;
}

/* 参数标签 */
.param-label {
    display: block;
    color: #c0c0c0;
    font-size: 11px;
    margin-bottom: var(--wr-spacing-xs);
    font-weight: var(--wr-weight-medium);
    line-height: 1.2;
}

/* 参数值 */
.param-value {
    color: #ffd700;
    font-weight: var(--wr-weight-medium);
}

/* 色调映射曝光度参数值使用不同颜色 */
.param-label:has(#exposureValue) .param-value,
#exposureValue {
    color: var(--wr-accent-color);
}

.tone-mapping-select {
    width: 100%;
    padding: var(--wr-spacing-xs) var(--wr-spacing-sm);
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: var(--wr-radius-sm);
    color: #e0e0e0;
    font-size: 12px;
    cursor: pointer;
    outline: none;
    transition: var(--wr-transition-fast);
}

.tone-mapping-select:hover {
    background: rgba(255, 255, 255, 0.12);
    border-color: rgba(255, 255, 255, 0.2);
}

.tone-mapping-select:focus {
    background: rgba(255, 255, 255, 0.12);
    border-color: var(--wr-accent-color);
    box-shadow: 0 0 4px rgba(118, 75, 162, 0.3);
}

.tone-mapping-select option {
    background: #2a2a2a;
    color: #e0e0e0;
    padding: var(--wr-spacing-xs);
}

/* 移动端响应式设计 */
@media (max-width: 768px) {
    .post-processing-row {
        flex-direction: column;
        gap: var(--wr-spacing-sm);
    }
    
    .post-processing-param {
        flex: none;
        min-width: auto;
        max-width: none;
        width: 100%;
    }
    
    .param-label {
        font-size: 12px;
    }
}

/* 小平板端适配 - 2行布局 */
@media (max-width: 1024px) and (min-width: 769px) {
    .post-processing-row {
        gap: var(--wr-spacing-xs);
    }
    
    .post-processing-param {
        min-width: 90px;
        max-width: 150px;
    }
    
    .param-label {
        font-size: 10px;
    }
}

/* 大屏幕优化 - 5个参数一行 */
@media (min-width: 1200px) {
    .post-processing-param {
        min-width: 120px;
        max-width: 200px;
    }
    
    .post-processing-row {
        gap: var(--wr-spacing-md);
    }
}

