.public-dashboard-page {
    --dashboard-ink: #183b35;
    --dashboard-muted: #6b8a84;
    --dashboard-line: rgba(122, 167, 156, 0.2);
    --dashboard-panel: rgba(255, 255, 255, 0.82);
    --dashboard-shadow: 0 22px 60px rgba(76, 116, 108, 0.12);
}

.public-dashboard-page .site-shell {
    max-width: 1440px;
    padding: 22px 26px 40px;
}

.public-dashboard-page .page-content {
    gap: 28px;
}

.dashboard-hero {
    display: grid;
    grid-template-columns: minmax(0, 1.45fr) minmax(320px, 0.9fr);
    gap: 24px;
    align-items: stretch;
}

.dashboard-hero-copy,
.dashboard-hero-focus,
.dashboard-stat-card,
.dashboard-panel {
    position: relative;
    overflow: hidden;
    border: 1px solid var(--dashboard-line);
    border-radius: 30px;
    background: var(--dashboard-panel);
    box-shadow: var(--dashboard-shadow);
    backdrop-filter: blur(14px);
}

.dashboard-hero-copy {
    padding: 36px 38px;
    background:
        radial-gradient(circle at top left, rgba(156, 242, 220, 0.48), transparent 32%),
        radial-gradient(circle at 88% 24%, rgba(255, 246, 214, 0.85), transparent 22%),
        linear-gradient(135deg, rgba(248, 255, 252, 0.94), rgba(255, 255, 255, 0.92));
}

.dashboard-kicker,
.dashboard-panel-kicker,
.dashboard-focus-label {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 0 14px;
    border-radius: 999px;
    background: rgba(24, 154, 128, 0.1);
    color: #12836f;
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.dashboard-hero-copy h1 {
    margin: 16px 0 14px;
    color: var(--dashboard-ink);
    font-size: clamp(2rem, 3.2vw, 3.4rem);
    line-height: 1.08;
}

.dashboard-hero-copy p {
    max-width: 700px;
    margin: 0;
    color: var(--dashboard-muted);
    font-size: 1.05rem;
    line-height: 1.9;
}

.dashboard-hero-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 24px;
}

.dashboard-hero-meta span {
    display: inline-flex;
    align-items: center;
    min-height: 40px;
    padding: 0 16px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(130, 205, 187, 0.35);
    color: #3f6d66;
    font-weight: 700;
}

.dashboard-hero-focus {
    padding: 30px;
    display: grid;
    gap: 18px;
    background:
        radial-gradient(circle at top right, rgba(255, 214, 163, 0.42), transparent 34%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(245, 252, 249, 0.94));
}

.dashboard-hero-focus strong {
    color: #153a34;
    font-size: clamp(2rem, 2.8vw, 2.8rem);
    line-height: 1;
}

.dashboard-hero-focus p {
    margin: 0;
    color: var(--dashboard-muted);
    line-height: 1.8;
}

.dashboard-focus-stats {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.dashboard-focus-stats div {
    padding: 18px 16px;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.8);
    border: 1px solid rgba(130, 205, 187, 0.28);
}

.dashboard-focus-stats span,
.dashboard-stat-card span,
.dashboard-panel-note,
.dashboard-ranking-user small,
.dashboard-empty,
.dashboard-subject-copy small,
.dashboard-level-label small {
    color: var(--dashboard-muted);
}

.dashboard-focus-stats strong {
    display: block;
    margin-top: 10px;
    font-size: 1.45rem;
}

.dashboard-summary-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px;
}

.dashboard-stat-card {
    padding: 24px 24px 22px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(247, 252, 250, 0.94));
}

.dashboard-stat-card.is-primary {
    background:
        radial-gradient(circle at top left, rgba(174, 243, 225, 0.52), transparent 34%),
        linear-gradient(180deg, rgba(247, 255, 252, 0.98), rgba(240, 252, 248, 0.94));
}

.dashboard-stat-card strong {
    display: block;
    margin-top: 16px;
    color: var(--dashboard-ink);
    font-size: clamp(2rem, 2.6vw, 2.8rem);
    line-height: 1;
}

.dashboard-stat-card p {
    margin: 12px 0 0;
    color: var(--dashboard-muted);
    line-height: 1.75;
}

.dashboard-layout {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 20px;
}

.dashboard-panel {
    padding: 26px;
}

.dashboard-panel--wide,
.dashboard-panel--distribution {
    grid-column: 1 / -1;
}

.dashboard-panel-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 20px;
}

.dashboard-panel-head h2 {
    margin: 10px 0 0;
    color: var(--dashboard-ink);
    font-size: 1.55rem;
}

.dashboard-level-list,
.dashboard-subject-list,
.dashboard-trend-list,
.dashboard-ranking-table {
    display: grid;
    gap: 14px;
}

.dashboard-level-row,
.dashboard-subject-row,
.dashboard-trend-row,
.dashboard-ranking-row {
    display: grid;
    align-items: center;
    gap: 14px;
    padding: 14px 16px;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(132, 190, 177, 0.18);
}

.dashboard-level-row,
.dashboard-subject-row {
    grid-template-columns: 140px minmax(0, 1fr) auto;
}

.dashboard-trend-row {
    grid-template-columns: minmax(0, 1fr) auto;
}

.dashboard-ranking-row {
    grid-template-columns: minmax(0, 1fr) auto;
}

.dashboard-level-label,
.dashboard-subject-copy,
.dashboard-ranking-user {
    display: flex;
    align-items: center;
    gap: 14px;
}

.dashboard-level-badge,
.dashboard-ranking-order {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 60px;
    min-height: 40px;
    padding: 0 12px;
    border-radius: 999px;
    background: rgba(24, 154, 128, 0.08);
    color: #15806d;
    font-weight: 800;
}

.dashboard-progress-track {
    position: relative;
    min-height: 14px;
    border-radius: 999px;
    background: rgba(176, 226, 214, 0.3);
    overflow: hidden;
}

.dashboard-progress-track span {
    position: absolute;
    inset: 0 auto 0 0;
    border-radius: inherit;
    background: linear-gradient(90deg, #35b89a, #7bd8b4);
}

.dashboard-progress-track.is-warm span {
    background: linear-gradient(90deg, #ffb14b, #ff8a4d);
}

.dashboard-ranking-user strong,
.dashboard-subject-copy strong,
.dashboard-trend-row span {
    color: var(--dashboard-ink);
}

.dashboard-ranking-score,
.dashboard-subject-score {
    color: #16453d;
    font-size: 1.15rem;
}

.dashboard-empty {
    margin: 0;
    padding: 12px 0;
    line-height: 1.8;
}

@media (max-width: 1360px) {
    .dashboard-layout {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 1180px) {
    .dashboard-summary-grid,
    .dashboard-hero {
        grid-template-columns: 1fr;
    }

    .dashboard-layout {
        grid-template-columns: 1fr;
    }

    .dashboard-summary-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 760px) {
    .public-dashboard-page .site-shell {
        padding: 16px 14px 28px;
    }

    .dashboard-hero-copy,
    .dashboard-hero-focus,
    .dashboard-panel,
    .dashboard-stat-card {
        padding-left: 18px;
        padding-right: 18px;
    }

    .dashboard-summary-grid {
        grid-template-columns: 1fr;
    }

    .dashboard-level-row,
    .dashboard-subject-row,
    .dashboard-ranking-row,
    .dashboard-trend-row {
        grid-template-columns: 1fr;
    }

    .dashboard-panel-head,
    .dashboard-level-label,
    .dashboard-subject-copy,
    .dashboard-ranking-user,
    .dashboard-focus-stats {
        grid-template-columns: 1fr;
        display: grid;
    }
}
