.xpgm-widget,
.xpgm-leaderboard {
    margin-top: 1.25rem;
}

.xpgm-widget {
    --xpgm-accent: #5f84b5;
    --xpgm-accent-soft: rgba(95, 132, 181, 0.18);
    --xpgm-accent-strong: #3f6796;
}

.xpgm-dashboard-center {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.xpgm-dashboard-center > .panel {
    margin-bottom: 0;
    margin-top: 0;
}

.xpgm-dashboard-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}

.xpgm-dashboard-grid-item {
    min-width: 0;
}

.xpgm-dashboard-grid-item > .panel {
    margin-bottom: 0;
    margin-top: 0;
}

.xpgm-experience-page {
    display: block;
}

.xpgm-journey-switch {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 1rem;
}

.xpgm-journey-switch .journey-option {
    white-space: nowrap;
}

.xpgm-journey-switch .journey-option.active {
    font-weight: 600;
}

.xpgm-hero-row,
.xpgm-section-row {
    margin-bottom: 1rem;
}

.xpgm-hero-card,
.xpgm-progress-shell,
.xpgm-progress-card,
.xpgm-podium-card,
.xpgm-award-card,
.xpgm-mission-card,
.xpgm-streak-card,
.xpgm-feed-item {
    border: 1px solid rgba(0, 0, 0, 0.08);
    background: rgba(255, 255, 255, 0.75);
}

.xpgm-hero-card,
.xpgm-progress-shell {
    position: relative;
    overflow: hidden;
    border-radius: 1.5rem;
    background:
        radial-gradient(circle at top right, rgba(255, 255, 255, 0.95) 0, rgba(255, 255, 255, 0.72) 28%, rgba(255, 255, 255, 0.9) 100%),
        linear-gradient(135deg, var(--xpgm-accent-soft), rgba(255, 255, 255, 0.18));
    box-shadow: 0 18px 36px rgba(37, 57, 84, 0.08);
}

.xpgm-hero-card {
    height: 100%;
}

.xpgm-hero-card-body {
    position: relative;
    z-index: 1;
    height: 100%;
    padding: 1.25rem;
}

.xpgm-hero-card-glow {
    position: absolute;
    inset: auto -3rem -3rem auto;
    width: 11rem;
    height: 11rem;
    border-radius: 50%;
    background: radial-gradient(circle, var(--xpgm-accent-soft) 0, rgba(255, 255, 255, 0) 70%);
    pointer-events: none;
}

.xpgm-progress-shell {
    margin-bottom: 1rem;
}

.xpgm-progress-header {
    position: relative;
    z-index: 1;
    padding: 1.35rem 1.35rem 0;
}

.xpgm-progress-header-copy {
    display: flex;
    flex-direction: column;
    gap: 0.7rem;
}

.xpgm-progress-header-top {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.8rem 1rem;
}

.xpgm-dashboard-summary-right .xpgm-progress-layout {
    gap: 1rem;
    padding-top: 1rem;
}

.xpgm-dashboard-summary-right .xpgm-progress-copy {
    gap: 0.75rem;
}

.xpgm-dashboard-summary-right .xpgm-progress-description {
    font-size: 0.92em;
}

.xpgm-dashboard-summary-right .xpgm-progress-stats {
    gap: 0.55rem;
}

.xpgm-dashboard-summary-right .xpgm-progress-stat-card {
    padding: 0.75rem 0.7rem;
}

.xpgm-dashboard-summary-right .xpgm-progress-stat-value {
    font-size: 1.6em;
}

.xpgm-progress-layout {
    position: relative;
    z-index: 1;
    display: grid;
    gap: 1.25rem;
    padding: 1rem 1.35rem 1.35rem;
}

.xpgm-progress-layout-wide {
    grid-template-columns: minmax(0, 2fr) minmax(0, 3fr);
    align-items: stretch;
}

.xpgm-progress-layout-stack {
    grid-template-columns: 1fr;
}

.xpgm-progress-info,
.xpgm-progress-track-pane {
    min-width: 0;
}

.xpgm-progress-info {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.xpgm-progress-copy {
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
    min-height: 100%;
}

.xpgm-progress-copy.is-compact {
    gap: 0.75rem;
}

.xpgm-progress-meta-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.xpgm-progress-chip {
    display: inline-flex;
    align-items: center;
    padding: 0.35rem 0.75rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.82);
    box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.05);
    color: #666;
    font-size: 0.82em;
    font-weight: 600;
}

.xpgm-progress-description {
    max-width: 38rem;
    color: #4b4b4b;
    font-size: 0.98em;
    line-height: 1.55;
}

.xpgm-progress-summary-card {
    padding: 0.8rem 0.85rem;
    border: 1px solid rgba(0, 0, 0, 0.06);
    border-radius: 1.15rem;
    background: rgba(255, 255, 255, 0.8);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.35);
}

.xpgm-progress-summary-head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.55rem;
}

.xpgm-progress-summary-main,
.xpgm-progress-summary-side {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

.xpgm-progress-summary-value,
.xpgm-progress-summary-side-value {
    color: #253954;
    font-weight: 700;
    line-height: 1;
}

.xpgm-progress-summary-value {
    font-size: 1.72em;
}

.xpgm-progress-summary-side {
    align-items: flex-end;
    text-align: right;
}

.xpgm-progress-summary-side-label {
    color: #666;
    font-size: 0.78em;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.xpgm-progress-summary-side-value {
    font-size: 1.24em;
}

.xpgm-progress-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.65rem;
}

.xpgm-progress-stat-card {
    min-width: 0;
    padding: 0.75rem 0.8rem;
    border: 1px solid rgba(0, 0, 0, 0.06);
    border-radius: 1.1rem;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(247, 249, 252, 0.92));
    box-shadow: 0 12px 24px rgba(37, 57, 84, 0.05);
}

.xpgm-progress-stat-label {
    color: #666;
    font-size: 0.78em;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.xpgm-progress-stat-value {
    margin-top: 0.35rem;
    color: #1f2e44;
    font-size: 1.78em;
    font-weight: 700;
    line-height: 1;
}

.xpgm-progress-stat-meta {
    margin-top: 0.25rem;
    color: #666;
    font-size: 0.86em;
    line-height: 1.25;
}

.xpgm-progress-track-pane {
    display: flex;
    align-items: center;
}

.xpgm-level-track {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(7.1rem, 1fr));
    gap: 0.9rem;
    width: 100%;
}

.xpgm-level-track.is-compact {
    grid-template-columns: repeat(auto-fit, minmax(5.75rem, 1fr));
    gap: 0.75rem;
}

.xpgm-level-gauge {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.55rem;
}

.xpgm-level-gauge-ring {
    --xpgm-progress: 0;
    position: relative;
    width: 7.6rem;
    height: 7.6rem;
}

.xpgm-level-track.is-compact .xpgm-level-gauge-ring {
    width: 5.9rem;
    height: 5.9rem;
}

.xpgm-level-gauge-svg {
    width: 100%;
    height: 100%;
    transform: rotate(-90deg);
    overflow: visible;
}

.xpgm-level-gauge-track,
.xpgm-level-gauge-indicator {
    fill: none;
    stroke-width: 10;
}

.xpgm-level-gauge-track {
    stroke: rgba(37, 57, 84, 0.1);
}

.xpgm-level-gauge-indicator {
    stroke: var(--xpgm-accent);
    stroke-linecap: round;
    stroke-dasharray: 301.5929;
    stroke-dashoffset: calc(301.5929 - (301.5929 * var(--xpgm-progress)) / 100);
    transition: stroke-dashoffset 0.25s ease;
}

.xpgm-level-gauge.is-complete .xpgm-level-gauge-indicator,
.xpgm-level-gauge.is-current .xpgm-level-gauge-indicator {
    stroke-dashoffset: 0;
}

.xpgm-level-gauge.is-complete .xpgm-level-gauge-indicator {
    stroke: #5f84b5;
}

.xpgm-level-gauge.is-current .xpgm-level-gauge-indicator {
    stroke: #2e8a8c;
}

.xpgm-level-gauge.is-progress .xpgm-level-gauge-indicator {
    stroke: var(--xpgm-accent-strong);
}

.xpgm-level-gauge-center {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.18rem;
    padding: 1.05rem;
    text-align: center;
}

.xpgm-level-gauge-main {
    color: #253954;
    font-size: 1.45em;
    line-height: 1;
}

.xpgm-level-track.is-compact .xpgm-level-gauge-main {
    font-size: 1.1em;
}

.xpgm-level-gauge-title {
    max-width: 100%;
    color: #666;
    font-size: 0.75em;
    font-weight: 600;
    line-height: 1.15;
    overflow-wrap: anywhere;
}

.xpgm-level-track.is-compact .xpgm-level-gauge-title {
    font-size: 0.68em;
}

.xpgm-level-gauge-foot {
    min-height: 1.2em;
    color: #666;
    font-size: 0.8em;
    font-weight: 600;
    line-height: 1.2;
    text-align: center;
}

.xpgm-hero-card.is-early,
.xpgm-progress-shell.is-early,
.xpgm-progress-card.is-early {
    --xpgm-accent: #5f84b5;
    --xpgm-accent-soft: rgba(95, 132, 181, 0.2);
    --xpgm-accent-strong: #426c9e;
}

.xpgm-hero-card.is-rising,
.xpgm-progress-shell.is-rising,
.xpgm-progress-card.is-rising {
    --xpgm-accent: #2e8a8c;
    --xpgm-accent-soft: rgba(46, 138, 140, 0.2);
    --xpgm-accent-strong: #1f6d6f;
}

.xpgm-hero-card.is-ready,
.xpgm-progress-shell.is-ready,
.xpgm-progress-card.is-ready {
    --xpgm-accent: #c4871e;
    --xpgm-accent-soft: rgba(196, 135, 30, 0.22);
    --xpgm-accent-strong: #9a6611;
}

.xpgm-section-kicker {
    margin-bottom: 0.5rem;
    color: #666;
    font-size: 0.82em;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.xpgm-journey-title {
    margin: 0 0 0.6rem;
    font-size: 1.7em;
    line-height: 1.2;
}

.xpgm-hero-kicker,
.xpgm-progress-card-kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    margin-bottom: 0.75rem;
    color: var(--xpgm-accent-strong);
    font-size: 0.78em;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.xpgm-panel-desc {
    display: flex;
    flex-wrap: wrap;
    gap: 0.25rem 1rem;
    margin: 0 0 0.75rem;
}

.xpgm-progress-ribbon {
    display: inline-flex;
    align-items: baseline;
    gap: 0.65rem;
    padding: 0.5rem 0.8rem;
    margin: 0;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.82);
    box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.04);
}

.xpgm-progress-ribbon-label {
    color: #666;
    font-size: 0.8em;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.xpgm-progress-ribbon-value {
    color: var(--xpgm-accent-strong);
    font-size: 1.25em;
    line-height: 1;
}

.xpgm-progress {
    height: 0.9rem;
    margin: 0.8rem 0 0;
    overflow: hidden;
    border-radius: 999px;
    background: rgba(37, 57, 84, 0.1);
    box-shadow: inset 0 0 0 1px rgba(37, 57, 84, 0.07);
}

.xpgm-progress .progress-bar {
    display: block;
    float: left;
    height: 100%;
    min-width: 1.5rem;
    background: linear-gradient(90deg, var(--xpgm-accent), var(--xpgm-accent-strong));
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.12);
    opacity: 1;
}

.xpgm-progress-card {
    position: relative;
    margin-bottom: 0.85rem;
    padding: 1rem 1rem 1.1rem;
    border-radius: 1.5rem;
    background:
        radial-gradient(circle at top, rgba(255, 255, 255, 0.96) 0, rgba(255, 255, 255, 0.78) 54%, rgba(255, 255, 255, 0.92) 100%),
        linear-gradient(180deg, var(--xpgm-accent-soft), rgba(255, 255, 255, 0));
    box-shadow: 0 18px 36px rgba(37, 57, 84, 0.08);
}

.xpgm-progress-card-header {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.85rem;
}

.xpgm-progress-card-level {
    color: var(--xpgm-accent-strong);
    font-size: 1.75em;
    line-height: 1;
}

.xpgm-progress-ring-wrap {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.xpgm-progress-ring {
    --xpgm-progress: 0;
    flex: 0 0 auto;
    position: relative;
    width: 8.75rem;
    height: 8.75rem;
}

.xpgm-dashboard-summary-right .xpgm-progress-ring {
    width: 7.5rem;
    height: 7.5rem;
}

.xpgm-progress-ring-svg {
    width: 100%;
    height: 100%;
    transform: rotate(-90deg);
    overflow: visible;
}

.xpgm-progress-ring-track,
.xpgm-progress-ring-indicator {
    fill: none;
    stroke-width: 10;
}

.xpgm-progress-ring-track {
    stroke: rgba(0, 0, 0, 0.08);
}

.xpgm-progress-ring-indicator {
    stroke: var(--xpgm-accent);
    stroke-linecap: round;
    stroke-dasharray: 301.5929;
    stroke-dashoffset: calc(301.5929 - (301.5929 * var(--xpgm-progress)) / 100);
    filter: drop-shadow(0 0 6px rgba(0, 0, 0, 0.12));
}

.xpgm-progress-ring-center {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.2rem;
    text-align: center;
}

.xpgm-progress-ring-center strong {
    color: #253954;
    font-size: 1.65em;
    line-height: 1;
}

.xpgm-progress-ring-center span,
.xpgm-progress-ring-next,
.xpgm-podium-score-label {
    color: #666;
    font-size: 0.8em;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.xpgm-progress-ring-meta {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    min-width: 0;
}

.xpgm-progress-ring-meta strong {
    color: #253954;
    font-size: 1.5em;
    line-height: 1.1;
}

.xpgm-progress-ring-meta span {
    color: #666;
    font-size: 0.88em;
}

.xpgm-progress-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    font-size: 0.92em;
}

.xpgm-stat-grid > div {
    margin-bottom: 0.75rem;
}

.xpgm-stat-card {
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: 8.9rem;
    margin-bottom: 0;
    padding: 1rem 0.85rem;
    text-align: center;
    border-radius: 1.2rem;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(245, 248, 252, 0.94));
    box-shadow: 0 12px 24px rgba(37, 57, 84, 0.05);
}

.xpgm-stat-label,
.xpgm-streak-meta,
.xpgm-award-date,
.xpgm-feed-type {
    color: #666;
    font-size: 0.82em;
}

.xpgm-stat-value,
.xpgm-streak-value,
.xpgm-podium-score {
    margin: 0.3rem 0;
    font-size: 1.7em;
    font-weight: 700;
    line-height: 1;
}

.xpgm-stat-meta {
    min-height: 1.2em;
    font-size: 0.85em;
}

.xpgm-section-card {
    height: 100%;
    margin-bottom: 0;
}

.xpgm-awards-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 0.85rem;
}

.xpgm-award-card {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    min-height: 6.25rem;
    padding: 0.95rem;
}

.xpgm-award-visual {
    flex: 0 0 3.4rem;
    width: 3.4rem;
    height: 3.4rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: rgba(0, 0, 0, 0.06);
    font-weight: 700;
    font-size: 1rem;
}

.xpgm-award-visual-image {
    max-width: 2rem;
    max-height: 2rem;
}

.xpgm-award-visual-fallback {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}

.xpgm-award-content {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    min-width: 0;
}

.xpgm-award-title {
    line-height: 1.2;
}

.xpgm-award-code {
    width: fit-content;
}

.xpgm-feed {
    display: grid;
    gap: 0.75rem;
}

.xpgm-feed-item {
    padding: 0.85rem 0.95rem;
    border-left-width: 4px;
}

.xpgm-feed-item.is-xp {
    border-left-color: #4c6586;
}

.xpgm-feed-item.is-level {
    border-left-color: #b54f00;
}

.xpgm-feed-item.is-badge,
.xpgm-feed-item.is-challenge {
    border-left-color: #6ea03c;
}

.xpgm-feed-item.is-streak {
    border-left-color: #307c88;
}

.xpgm-feed-message {
    margin-top: 0.2rem;
}

.xpgm-mission-list,
.xpgm-streak-list {
    display: grid;
    gap: 0.75rem;
}

.xpgm-mission-card,
.xpgm-streak-card {
    padding: 0.9rem 1rem;
}

.xpgm-mission-meta {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    margin-top: 0.4rem;
    color: #666;
    font-size: 0.88em;
}

.xpgm-podium-wrap {
    margin-bottom: 1.25rem;
}

.xpgm-podium-row > div {
    margin-bottom: 1rem;
}

.xpgm-leaderboard-compact .xpgm-podium-row > div {
    width: 100%;
    float: none;
}

.xpgm-leaderboard-compact .xpgm-podium-card {
    min-height: 9.1rem;
    padding: 0.75rem 0.85rem;
    border-radius: 1.3rem;
}

.xpgm-leaderboard-compact .xpgm-podium-topline {
    margin-bottom: 0.55rem;
}

.xpgm-leaderboard-compact .xpgm-podium-rank {
    width: 2.2rem;
    height: 2.2rem;
    font-size: 0.92em;
}

.xpgm-leaderboard-compact .xpgm-podium-badge-total {
    padding: 0.25rem 0.55rem;
    font-size: 0.72em;
}

.xpgm-leaderboard-compact .xpgm-podium-identity {
    gap: 0.7rem;
    margin-bottom: 0.55rem;
}

.xpgm-leaderboard-compact .xpgm-podium-orb {
    flex: 0 0 2.45rem;
    width: 2.45rem;
    height: 2.45rem;
}

.xpgm-leaderboard-compact .xpgm-podium-name {
    margin-bottom: 0.15rem;
    font-size: 0.98em;
}

.xpgm-leaderboard-compact .xpgm-podium-level {
    font-size: 0.82em;
}

.xpgm-leaderboard-compact .xpgm-podium-score-wrap {
    margin-bottom: 0;
}

.xpgm-leaderboard-compact .xpgm-podium-score-line {
    gap: 0.65rem;
}

.xpgm-leaderboard-compact .xpgm-podium-score-stack {
    gap: 0.1rem;
}

.xpgm-leaderboard-compact .xpgm-podium-score {
    margin: 0;
    font-size: 1.38em;
}

.xpgm-leaderboard-compact .xpgm-podium-score-label {
    font-size: 0.7em;
}

.xpgm-leaderboard-compact .xpgm-podium-badges {
    gap: 0.25rem;
}

.xpgm-leaderboard-compact .xpgm-podium-badges .xpgm-mini-award {
    min-width: 1.85rem;
    height: 1.85rem;
    padding: 0 0.32rem;
    font-size: 0.76em;
}

.xpgm-podium-card {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-height: 15rem;
    padding: 1.1rem;
    border-radius: 1.6rem;
    background:
        radial-gradient(circle at top, rgba(255, 255, 255, 0.98) 0, rgba(255, 255, 255, 0.78) 52%, rgba(255, 255, 255, 0.94) 100%),
        linear-gradient(180deg, rgba(95, 132, 181, 0.1), rgba(255, 255, 255, 0));
    box-shadow: 0 18px 34px rgba(37, 57, 84, 0.08);
}

.xpgm-podium-card.is-first {
    transform: translateY(-0.45rem);
}

.xpgm-podium-card.is-first .xpgm-podium-rank {
    font-size: 1.05em;
}

.xpgm-podium-card.is-first {
    background:
        radial-gradient(circle at top, rgba(255, 255, 255, 0.98) 0, rgba(255, 250, 232, 0.82) 52%, rgba(255, 255, 255, 0.94) 100%),
        linear-gradient(180deg, rgba(203, 164, 61, 0.22), rgba(255, 255, 255, 0));
}

.xpgm-podium-card.is-second {
    background:
        radial-gradient(circle at top, rgba(255, 255, 255, 0.98) 0, rgba(240, 243, 248, 0.88) 52%, rgba(255, 255, 255, 0.94) 100%),
        linear-gradient(180deg, rgba(134, 151, 173, 0.18), rgba(255, 255, 255, 0));
}

.xpgm-podium-card.is-third {
    background:
        radial-gradient(circle at top, rgba(255, 255, 255, 0.98) 0, rgba(247, 237, 230, 0.9) 52%, rgba(255, 255, 255, 0.94) 100%),
        linear-gradient(180deg, rgba(165, 106, 65, 0.18), rgba(255, 255, 255, 0));
}

.xpgm-podium-card.is-current {
    background-color: rgba(76, 101, 134, 0.06);
}

.xpgm-podium-topline {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.xpgm-podium-rank {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.8rem;
    height: 2.8rem;
    border-radius: 50%;
    background: rgba(37, 57, 84, 0.08);
    font-weight: 700;
}

.xpgm-podium-badge-total {
    display: inline-flex;
    align-items: center;
    padding: 0.35rem 0.7rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.76);
    color: #666;
    font-size: 0.8em;
    font-weight: 700;
}

.xpgm-podium-identity {
    display: flex;
    align-items: center;
    gap: 0.9rem;
    margin-bottom: 1rem;
}

.xpgm-podium-orb {
    flex: 0 0 3.2rem;
    width: 3.2rem;
    height: 3.2rem;
    border-radius: 50%;
    background:
        radial-gradient(circle at 35% 35%, rgba(255, 255, 255, 0.95), rgba(255, 255, 255, 0.25) 42%, transparent 43%),
        linear-gradient(135deg, rgba(95, 132, 181, 0.95), rgba(63, 103, 150, 0.95));
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.45), 0 10px 20px rgba(63, 103, 150, 0.25);
}

.xpgm-podium-card.is-first .xpgm-podium-orb {
    background:
        radial-gradient(circle at 35% 35%, rgba(255, 255, 255, 0.98), rgba(255, 255, 255, 0.25) 42%, transparent 43%),
        linear-gradient(135deg, #d8b357, #b97f1f);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.45), 0 10px 24px rgba(185, 127, 31, 0.24);
}

.xpgm-podium-card.is-second .xpgm-podium-orb {
    background:
        radial-gradient(circle at 35% 35%, rgba(255, 255, 255, 0.98), rgba(255, 255, 255, 0.25) 42%, transparent 43%),
        linear-gradient(135deg, #9eaec4, #6a7f9d);
}

.xpgm-podium-card.is-third .xpgm-podium-orb {
    background:
        radial-gradient(circle at 35% 35%, rgba(255, 255, 255, 0.98), rgba(255, 255, 255, 0.25) 42%, transparent 43%),
        linear-gradient(135deg, #c88f69, #905a39);
}

.xpgm-podium-person {
    min-width: 0;
}

.xpgm-podium-name {
    display: block;
    margin-bottom: 0.35rem;
    font-size: 1.1em;
    line-height: 1.2;
}

.xpgm-podium-level {
    color: #666;
}

.xpgm-podium-score-wrap {
    display: block;
    margin-bottom: 1rem;
}

.xpgm-podium-score-line {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
}

.xpgm-podium-score-stack {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.2rem;
}

.xpgm-podium-badges,
.xpgm-award-cell {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
}

.xpgm-podium-badges {
    align-items: center;
    justify-content: flex-end;
    margin-left: auto;
}

.xpgm-award-cell {
    align-items: center;
    min-height: 100%;
}

.xpgm-mini-award {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.85rem;
    height: 1.85rem;
    padding: 0 0.35rem;
    border-radius: 999px;
    background: rgba(0, 0, 0, 0.08);
    font-size: 0.72em;
    font-weight: 700;
}

.xpgm-mini-award-image {
    display: block;
    max-width: 1.2rem;
    max-height: 1.2rem;
}

.xpgm-podium-badges .xpgm-mini-award {
    min-width: 2.22rem;
    height: 2.22rem;
    padding: 0 0.42rem;
    font-size: 0.85em;
}

.xpgm-table-wrap {
    margin-bottom: 0;
}

.xpgm-ranking-table {
    margin-bottom: 0;
    border-collapse: separate;
    border-spacing: 0 0.32rem;
}

.xpgm-ranking-table td,
.xpgm-ranking-table th {
    vertical-align: middle;
}

.xpgm-ranking-table thead th {
    border-top: none !important;
    border-bottom: 1px solid rgba(37, 57, 84, 0.12) !important;
    background: transparent;
    color: #667282;
    font-size: 0.8em;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.xpgm-ranking-table tbody td {
    border-top: none !important;
    border-bottom: none !important;
    background: rgba(255, 255, 255, 0.98);
    padding-top: 0.9rem;
    padding-bottom: 0.9rem;
}

.xpgm-ranking-table tbody tr td:first-child {
    border-top-left-radius: 0.9rem;
    border-bottom-left-radius: 0.9rem;
}

.xpgm-ranking-table tbody tr td:last-child {
    border-top-right-radius: 0.9rem;
    border-bottom-right-radius: 0.9rem;
}

.xpgm-ranking-table tbody tr.leaderboard-first td {
    background: rgba(216, 179, 87, 0.14);
}

.xpgm-ranking-table tbody tr.leaderboard-second td {
    background: rgba(158, 174, 196, 0.16);
}

.xpgm-ranking-table tbody tr.leaderboard-third td {
    background: rgba(200, 143, 105, 0.16);
}

.xpgm-ranking-table tbody tr.leaderboard-even td {
    background: rgba(245, 248, 252, 0.96);
}

.xpgm-ranking-table tbody tr.leaderboard-odd td {
    background: rgba(250, 252, 255, 0.96);
}

.xpgm-rank-pill,
.xpgm-value-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.4rem;
    padding: 0.35rem 0.7rem;
    border-radius: 999px;
    background: rgba(37, 57, 84, 0.08);
    font-weight: 700;
}

.xpgm-rank-cell {
    width: 1%;
    white-space: nowrap;
}

.xpgm-player-name-wrap {
    display: flex;
    align-items: center;
    min-width: 0;
}

.xpgm-player-name {
    display: block;
    font-weight: 700;
    line-height: 1.25;
}

.xpgm-value-pill-points {
    background: rgba(63, 103, 150, 0.1);
    color: #253954;
}

.xpgm-value-pill-level {
    background: rgba(196, 135, 30, 0.12);
    color: #734a0c;
}

.xpgm-empty-state {
    padding: 1rem;
    border: 1px dashed rgba(0, 0, 0, 0.15);
    color: #666;
    text-align: center;
}

.xpgm-course-competition {
    height: auto;
    margin: 0 0 1rem;
}

.xpgm-course-competition .panel-body {
    padding: 1rem;
}

.xpgm-course-competition .xpgm-journey-switch {
    margin-bottom: 0.75rem;
}

.xpgm-course-panel-meta {
    display: flex;
    justify-content: space-between;
    gap: 0.75rem;
    flex-wrap: wrap;
    margin: 0 0 0.85rem;
    color: #66768f;
    font-size: 0.9em;
}

.xpgm-course-panel-title {
    color: #2b3c5a;
    font-size: 1em;
    font-weight: 600;
}

.xpgm-course-summary {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.7rem;
    margin-bottom: 0;
}

.xpgm-course-stat-card {
    padding: 0.8rem 0.85rem;
    border-radius: 0.85rem;
    border: 1px solid rgba(118, 140, 172, 0.14);
    background: rgba(249, 251, 255, 0.86);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.xpgm-course-stat-label {
    display: block;
    margin-bottom: 0.25rem;
    color: #6b7c97;
    font-size: 0.74em;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.xpgm-course-stat-value {
    display: block;
    color: #263957;
    font-size: 1.18em;
    font-weight: 700;
    line-height: 1.15;
}

.xpgm-course-summary + .xpgm-course-top {
    margin-top: 0.9rem;
}

.xpgm-course-top-title {
    margin-bottom: 0.55rem;
    color: #6b7c97;
    font-size: 0.76em;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.xpgm-course-top-list {
    display: grid;
    gap: 0.4rem;
}

.xpgm-course-top-row {
    display: grid;
    grid-template-columns: 2rem minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.55rem;
    padding: 0.55rem 0.7rem;
    border-radius: 0.8rem;
    background: rgba(247, 250, 255, 0.88);
    border: 1px solid rgba(114, 136, 165, 0.14);
}

.xpgm-course-top-row.is-current {
    background: rgba(235, 243, 255, 0.94);
    border-color: rgba(77, 122, 190, 0.26);
}

.xpgm-course-top-rank {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border-radius: 999px;
    background: rgba(225, 232, 243, 0.9);
    color: #2f4361;
    font-weight: 700;
    font-size: 0.92em;
}

.xpgm-course-top-name {
    min-width: 0;
    color: #2a3b59;
    font-weight: 600;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.xpgm-course-top-points {
    color: #49688f;
    font-weight: 700;
    white-space: nowrap;
    font-size: 0.92em;
}

.xpgm-course-top-meta {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.45rem;
    min-width: 0;
}

.xpgm-course-top-badges {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.24rem;
    flex-wrap: wrap;
}

.xpgm-course-top-badges .xpgm-mini-award {
    width: 1.35rem;
    height: 1.35rem;
    font-size: 0.64em;
}

.xpgm-course-top-badges .xpgm-mini-award-image {
    max-width: 0.9rem;
    max-height: 0.9rem;
}

@media (max-width: 991px) {
    .xpgm-progress-layout-wide {
        grid-template-columns: 1fr;
    }

    .xpgm-progress-track-pane {
        align-items: flex-start;
    }

    .xpgm-section-card {
        margin-bottom: 1rem;
    }

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

    .xpgm-course-top-row {
        grid-template-columns: 1.9rem minmax(0, 1fr);
    }

    .xpgm-course-top-meta {
        grid-column: 2;
        justify-content: flex-start;
        flex-wrap: wrap;
    }

    .xpgm-course-top-badges {
        justify-content: flex-start;
    }
}

@media (min-width: 992px) {
    .xpgm-dashboard-grid-cols-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .xpgm-dashboard-grid-cols-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 767px) {
    .xpgm-progress-meta,
    .xpgm-mission-meta,
    .xpgm-panel-desc {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.25rem;
    }

    .xpgm-podium-card.is-first {
        transform: none;
    }

    .xpgm-awards-grid {
        grid-template-columns: 1fr;
    }

    .xpgm-progress-layout {
        padding: 1.1rem;
    }

    .xpgm-progress-header {
        padding: 1.1rem 1.1rem 0;
    }

    .xpgm-progress-stats {
        grid-template-columns: 1fr;
    }

    .xpgm-level-track {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .xpgm-level-track.is-compact {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .xpgm-progress-summary-head {
        flex-direction: column;
        align-items: flex-start;
    }

    .xpgm-progress-summary-side {
        align-items: flex-start;
        text-align: left;
    }

    .xpgm-progress-ring-wrap {
        flex-direction: column;
        align-items: flex-start;
    }

    .xpgm-progress-ring {
        width: 7.2rem;
        height: 7.2rem;
    }

    .xpgm-summary-hero-row > div + div {
        margin-top: 1rem;
    }
}

@media (max-width: 480px) {
    .xpgm-stat-value,
    .xpgm-streak-value,
    .xpgm-podium-score {
        font-size: 1.4em;
    }

    .xpgm-progress-stat-value {
        font-size: 1.6em;
    }

    .xpgm-level-track,
    .xpgm-level-track.is-compact {
        grid-template-columns: 1fr 1fr;
        gap: 0.65rem;
    }

    .xpgm-level-gauge-ring {
        width: 6.25rem;
        height: 6.25rem;
    }

    .xpgm-level-track.is-compact .xpgm-level-gauge-ring {
        width: 5.35rem;
        height: 5.35rem;
    }

    .xpgm-award-card {
        align-items: flex-start;
    }

    .xpgm-progress-ribbon {
        width: 100%;
        justify-content: space-between;
    }

    .xpgm-podium-topline {
        flex-direction: column;
        align-items: flex-start;
    }

    .xpgm-progress-header-top {
        align-items: flex-start;
    }

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

    .xpgm-course-top-row {
        grid-template-columns: 1.9rem minmax(0, 1fr);
    }

    .xpgm-course-top-points {
        grid-column: 2;
    }
}
