/* ========================================
   审查进度页 — Ivory Pixel 皮肤
   复用 report.css 的 --elg-* token，与报告页 / Landing 统一为同一套
   "大理石复古像素"语言。全部 #page-progress 作用域，以 ID 特异性
   覆盖 style.css 的旧 SaaS 默认（无需改类名 / 改 JS）。
   ======================================== */

/* ── 页面底：大理石 + 圆点网格（与 #page-result 一致）── */
#page-progress {
    background-color: var(--elg-bg-marble);
    background-image: radial-gradient(circle, rgba(0, 0, 0, 0.03) 1px, transparent 1px);
    background-size: 16px 16px;
    font-family: var(--elg-font-body);
    color: var(--elg-text-body);
    align-items: flex-start;
    -webkit-font-smoothing: auto;
    -moz-osx-font-smoothing: auto;
}

#page-progress .progress-container {
    width: 100%;
    max-width: 880px;
    margin-top: 24px;
}

/* ── 标题：像素字 + 末尾闪烁青光标（机器运转中）── */
#page-progress .page-header {
    margin-bottom: 28px;
}

/* 标题与报告页 .elg-header-title 对齐：思源黑体 700。
   不用像素字——DotGothic16 无简中字形，中文会回退成等宽体、与正文割裂。
   shimmer 扫光：一道极淡高光(#8f8f88)沿字面左→右缓扫，扫完停一拍再扫，
   表达"处理中"而不抢焦点（background-clip:text）。 */
#page-progress .page-header h2 {
    display: inline-block;       /* 让扫光范围贴合文字宽度，而非整行 */
    font-family: var(--elg-font-body);
    font-size: 26px;
    font-weight: 700;
    letter-spacing: 2px;
    color: var(--elg-text-title);   /* 不支持 background-clip:text 时的兜底色 */
    background-image: linear-gradient(
        110deg,
        var(--elg-text-title) 0%,
        var(--elg-text-title) 42%,
        #8f8f88 50%,
        var(--elg-text-title) 58%,
        var(--elg-text-title) 100%
    );
    background-size: 250% 100%;
    background-position: 120% 0;
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    animation: pgx-title-shimmer 3.4s ease-in-out infinite;
}

/* 扫一遍约 1.9s，剩余约 1.5s 静止——节奏松弛、不烦躁 */
@keyframes pgx-title-shimmer {
    0%        { background-position: 120% 0; }
    55%, 100% { background-position: -40% 0; }
}

/* ── 顶部统计栏：白底硬边 + 硬投影 + 两枚顶角小方块（复用 health-box 语言）── */
#page-progress .review-stats-bar {
    display: flex;
    align-items: stretch;
    background: var(--elg-panel-white);
    border: 2px solid var(--elg-border);
    border-radius: 0;
    box-shadow: 4px 4px 0 rgba(0, 0, 0, 0.03);
    padding: 30px 16px 24px;
    position: relative;
    margin-bottom: 28px;
}

#page-progress .review-stats-bar::before,
#page-progress .review-stats-bar::after {
    content: "";
    position: absolute;
    top: 12px;
    width: 6px;
    height: 6px;
    background: var(--elg-border);
    box-shadow: inset 1px 1px 0 #FFF, inset -1px -1px 0 rgba(0, 0, 0, 0.1);
}

#page-progress .review-stats-bar::before { left: 14px; }
#page-progress .review-stats-bar::after { right: 14px; }

#page-progress .review-stat {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
}

/* 数值行：统一高度的垂直居中带——30px 像素数字与 17px 中文('<1分钟')
   都在同一条 band 内居中，避免大小字号导致的高度不齐 */
#page-progress .review-stat-value {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 36px;
    font-family: var(--elg-font-pixel);
    font-size: 30px;
    line-height: 1;
    color: var(--elg-text-title);
}

/* 数字统计沿用报告页风险色：修改处=红、批注=蓝 */
#page-progress .review-stat-value.stat-modify { color: var(--elg-risk-high-text); }
#page-progress .review-stat-value.stat-comment { color: var(--elg-risk-low-text); }

/* "预计剩余"是中文文案，像素字无简中字形，改用正文体保证可读 */
#page-progress .review-stat-value.stat-time {
    font-family: var(--elg-font-body);
    font-size: 17px;
    font-weight: 700;
    color: var(--elg-text-title);
}

#page-progress .review-stat-label {
    font-size: 12px;
    letter-spacing: 1px;
    color: var(--elg-text-muted);
}

#page-progress .review-stat-divider {
    width: 2px;
    background: var(--elg-shadow-soft);
    margin: 4px 0;
}

/* ── 进度条：粗壮像素条 + 凹槽 + 青色分段填充 ── */
#page-progress .progress-bar-wrapper {
    margin-bottom: 4px;
}

#page-progress .progress-bar {
    height: 22px;
    background: var(--elg-panel-white);
    border: 2px solid var(--elg-border);
    border-radius: 0;
    box-shadow: var(--elg-bevel-in);
    padding: 2px;
    overflow: hidden;
}

#page-progress .progress-bar-fill {
    height: 100%;
    border-radius: 0;
    background-color: #008080;
    background-image: repeating-linear-gradient(90deg,
        #008080 0 14px,
        #00a8a8 14px 16px);
    transition: width 0.4s var(--ease, ease);
}

/* 干掉 SaaS 版的流光高光 */
#page-progress .progress-bar-fill::after { display: none; }

#page-progress .progress-stats {
    display: flex;
    justify-content: space-between;
    margin-top: 10px;
    font-family: var(--elg-font-pixel);
    font-size: 13px;
    color: var(--elg-text-muted);
}

/* ── 审查区域列表：像素卡片，逐块二进制点亮 ── */
#page-progress .blocks-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: 28px;
}

#page-progress .block-card {
    background: var(--elg-panel-white);
    border: 2px solid var(--elg-border);
    border-radius: 0;
    box-shadow: 3px 3px 0 rgba(0, 0, 0, 0.03);
    padding: 14px 16px;
    transition: none;
}

/* 等待中：虚线、半透明、无实体感（还没"通电"）*/
#page-progress .block-card.waiting {
    background: transparent;
    border-style: dashed;
    box-shadow: none;
    opacity: 0.5;
}

/* 审查中：青色边 + 青色硬投影（"啪"地选中）。
   关掉旧 SaaS 的蓝色 pulseGlow 动画，否则它会盖掉这里的硬投影 */
#page-progress .block-card.active {
    border-color: #008080;
    box-shadow: 3px 3px 0 rgba(0, 128, 128, 0.18);
    animation: none;
}

/* 完成：左缘一道青实条 */
#page-progress .block-card.completed {
    border-left: 5px solid #008080;
}

#page-progress .block-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
}

#page-progress .block-title {
    font-family: var(--elg-font-body);
    font-size: 14px;
    font-weight: 600;
    color: var(--elg-text-title);
}

#page-progress .block-card.waiting .block-title {
    color: var(--elg-text-muted);
    font-weight: 500;
}

#page-progress .block-status-icon {
    display: flex;
    align-items: center;
    color: var(--elg-text-muted);
    flex-shrink: 0;
}

#page-progress .block-card.active .block-status-icon,
#page-progress .block-card.completed .block-status-icon {
    color: #008080;
}

#page-progress .block-meta {
    margin-top: 8px;
    font-size: 12px;
    color: var(--elg-text-muted);
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    text-align: left;
    gap: 6px;
}

/* ── 风险徽章：复用报告页风险色，硬边方块（清掉旧 margin-left:auto）── */
#page-progress .block-risk-badges {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    margin-left: 0;
}

#page-progress .risk-badge {
    font-size: 11px;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 0;
    border: 1px solid;
    line-height: 1.6;
}

#page-progress .risk-badge.high {
    background: var(--elg-risk-high-bg);
    border-color: var(--elg-risk-high-border);
    color: var(--elg-risk-high-text);
}

#page-progress .risk-badge.medium {
    background: var(--elg-risk-med-bg);
    border-color: var(--elg-risk-med-border);
    color: var(--elg-risk-med-text);
}

#page-progress .risk-badge.low {
    background: var(--elg-risk-low-bg);
    border-color: var(--elg-risk-low-border);
    color: var(--elg-risk-low-text);
}

/* ── 预分析加载态：区块骨架(skeleton) ──
   一进来就落在区块列表视图，先放几张微光占位卡；pre-analyze 返回后
   由 realReview 的 init 事件整片替换为真实区块。无单独自检动画、无光标。 */
#page-progress .pgx-skel {
    background: var(--elg-panel-white);
    border: 2px solid var(--elg-border);
    box-shadow: 3px 3px 0 rgba(0, 0, 0, 0.03);
    padding: 18px 16px;
    margin-bottom: 10px;
}

#page-progress .pgx-skel-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

#page-progress .pgx-skel-bar {
    display: block;
    border-radius: 0;
    background: var(--elg-shadow-soft);
    background-image: linear-gradient(90deg,
        var(--elg-shadow-soft) 0%, #EFEFEA 50%, var(--elg-shadow-soft) 100%);
    background-size: 200% 100%;
    animation: pgx-shimmer 1.3s ease-in-out infinite;
}

#page-progress .pgx-skel-title { height: 15px; }
#page-progress .pgx-skel-meta { width: 26%; height: 11px; margin-top: 16px; }

#page-progress .pgx-skel-spin {
    color: var(--elg-text-muted);
    flex-shrink: 0;
}

@keyframes pgx-shimmer {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}
