/**
 * Skeleton(加载占位)组件。
 *
 * 来源:从 assets/css/style.css 复制(P1.4 第一刀)。仅复制不删原。
 * 注意:style.css 里有两处 .skeleton-title(行 1729 / 行 2391),后者宽度 60% 用于
 * 文档列表骨架。两段都复制过来,以保留 cascade 顺序;由 style.css 兜底。
 */

.skeleton {
    background: linear-gradient(90deg, var(--bg-tertiary) 25%, var(--bg-secondary) 50%, var(--bg-tertiary) 75%);
    background-size: 200% 100%;
    animation: skeleton-loading 1.5s ease-in-out infinite;
    border-radius: 4px;
}

.skeleton-text {
    height: 16px;
    margin-bottom: 8px;
}

.skeleton-title {
    height: 24px;
    margin-bottom: 12px;
}

.skeleton-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
}

@keyframes skeleton-loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* 文档列表骨架 */
.skeleton-item {
    padding: 14px 16px;
    border-bottom: 1px solid var(--border-color);
}

.skeleton-line {
    height: 14px;
    border-radius: 4px;
    background: linear-gradient(90deg, var(--bg-tertiary) 25%, var(--bg-secondary) 50%, var(--bg-tertiary) 75%);
    background-size: 200% 100%;
    animation: skeleton-shimmer 1.5s infinite;
}

.skeleton-meta {
    width: 35%;
    height: 10px;
}

@keyframes skeleton-shimmer {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}
