#app {
    max-width: 1180px;
    min-height: 100vh;
    min-height: 100dvh;
    margin: 0 auto;
    padding: clamp(14px, 2.4vw, 26px);
    display: flex;
    flex-direction: column;
}

.home-shell {
    flex: 1;
    gap: 18px;
}

.home-topbar,
.planet-hero,
.dashboard-card {
    border-radius: 32px;
}

.home-topbar {
    position: relative;
    padding: clamp(14px, 2vw, 18px) clamp(18px, 2.8vw, 26px);
    align-items: flex-end;
    min-height: 184px;
}

.page-heading {
    max-width: 780px;
}

.hero-badge {
    display: inline-flex;
    align-items: center;
    padding: 7px 14px;
    border-radius: 999px;
    border: 1px solid rgba(112,214,255,.28);
    background: linear-gradient(135deg, rgba(112,214,255,.18), rgba(110,242,194,.12));
    color: #dff7ff;
    font-size: 13px;
    font-weight: 800;
    box-shadow: 0 0 28px rgba(112,214,255,.12);
}

.hero-title {
    margin: 10px 0 8px;
    font-size: clamp(34px, 6vw, 60px);
}

.hero-title span {
    display: inline-block;
    margin-left: .14em;
    color: var(--primary-yellow);
    text-shadow: 0 0 16px rgba(255,226,122,.32);
}

.hero-copy {
    max-width: 720px;
    font-size: 15px;
}

.planet-hero {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(220px, .8fr);
    gap: 18px;
    align-items: center;
    padding: clamp(22px, 4vw, 34px);
    overflow: hidden;
}

.planet-hero::after {
    content: "";
    position: absolute;
    inset: auto -8% -28% auto;
    width: 320px;
    height: 320px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(110,242,194,.12), transparent 62%);
    filter: blur(10px);
}

.planet-hero-copy,
.planet-hero-orbit,
.hero-stat-strip {
    position: relative;
    z-index: 1;
}

.planet-hero-copy h2 {
    margin: 0;
    font-size: clamp(30px, 4vw, 44px);
    letter-spacing: -.05em;
}

.planet-hero-copy p {
    margin: 12px 0 0;
    max-width: 540px;
    color: var(--text-muted);
    line-height: 1.72;
}

.planet-hero-orbit {
    position: relative;
    min-height: 240px;
    display: grid;
    place-items: center;
}

.planet-core {
    width: 128px;
    height: 128px;
    border-radius: 50%;
    background:
        radial-gradient(circle at 34% 30%, rgba(255,255,255,.84), transparent 16%),
        radial-gradient(circle at 42% 38%, rgba(255,226,122,.78), rgba(112,214,255,.32) 42%, rgba(31,95,166,.95) 74%, rgba(8,28,67,.96) 100%);
    box-shadow: 0 0 48px rgba(112,214,255,.24), 0 0 84px rgba(110,242,194,.18);
}

.orbit {
    position: absolute;
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 50%;
}

.orbit-a { width: 176px; height: 176px; }
.orbit-b { width: 228px; height: 228px; border-color: rgba(112,214,255,.18); }
.orbit-c { width: 284px; height: 178px; transform: rotate(-24deg); border-color: rgba(110,242,194,.22); }

.hero-stat-strip {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.hero-stat-pill {
    padding: 14px 16px;
    border-radius: 20px;
    border: 1px solid rgba(255,255,255,.1);
    background: rgba(255,255,255,.055);
}

.hero-stat-pill span {
    display: block;
    color: var(--text-muted);
    font-size: 12px;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.hero-stat-pill strong {
    display: block;
    margin-top: 6px;
    font-size: clamp(22px, 3vw, 30px);
}

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

.dashboard-card {
    position: relative;
    display: flex;
    flex-direction: column;
    min-height: 320px;
    padding: clamp(20px, 3vw, 28px);
    overflow: hidden;
}

.dashboard-card::after {
    content: "";
    position: absolute;
    top: -20%;
    right: -10%;
    width: 180px;
    height: 180px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(255,255,255,.08), transparent 70%);
    pointer-events: none;
}

.streak-card::before,
.score-card::before,
.task-card::before,
.reward-card::before {
    content: "";
    position: absolute;
    inset: auto auto 0 0;
    width: 100%;
    height: 5px;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,.18), transparent);
    opacity: .5;
}

.dashboard-card-head,
.dashboard-card-body,
.task-launch-row {
    position: relative;
    z-index: 1;
}

.dashboard-card-head {
    display: flex;
    justify-content: space-between;
    gap: 14px;
    align-items: flex-start;
    margin-bottom: 18px;
}

.dashboard-card h2 {
    margin: 4px 0 0;
    font-size: clamp(28px, 4vw, 40px);
    letter-spacing: -.05em;
}

.nav-meta {
    color: var(--primary-cyan);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .18em;
    text-transform: uppercase;
}

.card-glow-badge {
    padding: 7px 12px;
    border-radius: 999px;
    border: 1px solid rgba(112,214,255,.22);
    background: rgba(112,214,255,.12);
    color: #dff1ff;
    font-size: 12px;
    font-weight: 800;
    box-shadow: 0 0 18px rgba(112,214,255,.16);
}

.card-glow-badge.score {
    border-color: rgba(255,226,122,.24);
    background: rgba(255,226,122,.12);
    color: #fff2bd;
}

.card-glow-badge.task {
    border-color: rgba(110,242,194,.24);
    background: rgba(110,242,194,.12);
    color: #d8fff1;
}

.card-glow-badge.reward {
    border-color: rgba(146,167,255,.26);
    background: rgba(146,167,255,.14);
    color: #ecedff;
}

.dashboard-card-body {
    display: grid;
    gap: 12px;
    flex: 1;
}

.metric-main {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 14px;
    align-items: end;
    padding: 18px;
    border-radius: 24px;
    border: 1px solid rgba(255,255,255,.1);
    background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
}

.metric-main-label {
    color: var(--text-muted);
    font-size: 13px;
}

.metric-main-value {
    display: block;
    margin-top: 6px;
    font-size: clamp(34px, 6vw, 52px);
    font-weight: 900;
    line-height: .96;
    letter-spacing: -.06em;
}

.metric-chip {
    align-self: start;
    padding: 8px 12px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 800;
    color: #dffaff;
    background: rgba(110,242,194,.14);
    border: 1px solid rgba(110,242,194,.18);
}

.metric-chip.pending {
    color: #e7eeff;
    background: rgba(112,214,255,.12);
    border-color: rgba(112,214,255,.18);
}

.metric-grid,
.trend-mini-list,
.reward-mini-list,
.task-module-list {
    display: grid;
    gap: 10px;
}

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

.mini-panel,
.task-module-item,
.reward-mini-item,
.trend-mini-item,
.dashboard-empty {
    padding: 14px 16px;
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,.08);
    background: rgba(255,255,255,.05);
}

.mini-panel strong,
.task-module-item strong,
.reward-mini-item strong,
.trend-mini-item strong {
    display: block;
    font-size: 15px;
    color: var(--text-main);
}

.mini-panel span,
.task-module-item span,
.reward-mini-item span,
.trend-mini-item span,
.dashboard-empty {
    display: block;
    margin-top: 4px;
    color: var(--text-muted);
    font-size: 13px;
    line-height: 1.58;
}

.trend-mini-item,
.task-module-item,
.reward-mini-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.trend-mini-item div,
.task-module-item div,
.reward-mini-item div {
    min-width: 0;
}

.trend-dot,
.task-status-dot,
.reward-status-dot {
    flex: 0 0 auto;
    min-width: 72px;
    text-align: center;
    padding: 7px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 900;
}

.trend-dot,
.task-status-dot.done,
.reward-status-dot.ready {
    background: rgba(110,242,194,.14);
    color: var(--primary-green);
}

.trend-dot.pending,
.task-status-dot.pending,
.reward-status-dot.pending {
    background: rgba(112,214,255,.12);
    color: #dcebff;
}

.score-card .metric-main-value {
    color: var(--primary-yellow);
    text-shadow: 0 0 18px rgba(255,226,122,.18);
}

.streak-card .metric-main-value {
    color: var(--primary-cyan);
}

.task-card .metric-main-value,
.reward-card .metric-main-value {
    color: var(--primary-green);
}

.task-launch-row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin-top: 16px;
}

.nav-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 56px;
    padding: 0 20px;
    border-radius: 18px;
    background: linear-gradient(135deg, var(--primary-green), #95ffd9);
    color: #072219;
    font-weight: 900;
    box-shadow: 0 0 32px rgba(110,242,194,.22), 0 18px 34px rgba(0,0,0,.30);
    transition: transform .18s ease, box-shadow .18s ease, filter .18s ease, opacity .18s ease;
}

.nav-link:hover {
    transform: translateY(-2px);
    filter: brightness(1.04);
}

.nav-link.secondary {
    background: linear-gradient(135deg, var(--primary-cyan), #b7e8ff);
    color: #081727;
    box-shadow: 0 0 32px rgba(112,214,255,.18), 0 18px 34px rgba(0,0,0,.30);
}

.top-auth {
    position: absolute;
    top: 16px;
    right: 20px;
    z-index: 5;
    display: flex;
    align-items: center;
    gap: 8px;
}

.top-auth-link,
.top-auth-status {
    border: 0;
    background: transparent;
    color: #dceaff;
    font-size: 13px;
    font-weight: 700;
    cursor: pointer;
    padding: 4px 1px;
}

.top-auth-link:hover {
    color: #9fd8ff;
}

#login-entry,
#register-entry { color: #8ed8ff; }
#activate-entry { color: #ffe082; }
#account-entry { color: #62f0b6; }
.top-auth-status#activated-label { color: #dceaff; }
#logout-btn { color: #ffb7b7; }

.auth-modal {
    position: fixed;
    inset: 0;
    z-index: 30;
}

.auth-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(4, 10, 20, 0.42);
    backdrop-filter: blur(2px);
    pointer-events: none;
}

.auth-dialog {
    position: absolute;
    z-index: 1;
    width: min(320px, calc(100vw - 28px));
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    padding: 14px;
    border-radius: 18px;
    background: rgba(7, 16, 36, 0.96);
    border: 1px solid rgba(126, 182, 255, 0.2);
    box-shadow: 0 18px 50px rgba(0,0,0,.35);
    backdrop-filter: blur(14px);
}

.auth-modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
}

.auth-modal-title {
    color: #8ed8ff;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .18em;
    text-transform: uppercase;
}

.auth-modal-close {
    width: 28px;
    height: 28px;
    border: 1px solid rgba(255,255,255,.16);
    border-radius: 50%;
    background: rgba(255,255,255,.05);
    color: #fff;
    font-size: 18px;
    line-height: 1;
    cursor: pointer;
}

.auth-modal-close:hover { background: rgba(255,255,255,.1); }

.auth-status {
    color: #dceaff;
    font-weight: 700;
    font-size: 13px;
    margin-bottom: 12px;
}

.auth-form-card,
.redeem-box {
    display: grid;
    gap: 10px;
    padding: 0;
    border: 0;
    background: transparent;
}

.auth-form-card h2 { margin: 0; font-size: 18px; }

.info-line {
    padding: 8px 0;
    border-bottom: 1px solid rgba(255,255,255,.08);
    color: rgba(220, 234, 255, 0.72);
    font-size: 13px;
}

.info-line strong {
    display: block;
    margin-bottom: 4px;
    color: #ffffff;
    font-size: 13px;
}

.info-line span {
    color: #dceaff;
    font-weight: 700;
}

.auth-text-btn {
    border: 0;
    background: transparent;
    color: #9fd8ff;
    cursor: pointer;
    padding: 4px 0;
    text-align: left;
    font-weight: 700;
    font-size: 13px;
}

.auth-text-btn:hover { color: var(--primary-green); }

.auth-submit-btn {
    width: 100%;
    border: 0;
    border-radius: 12px;
    padding: 12px 14px;
    color: #07111f;
    font-weight: 800;
    font-size: 14px;
    background: linear-gradient(135deg, #8ed8ff, #62f0b6);
    box-shadow: 0 10px 24px rgba(78, 186, 255, .18);
    cursor: pointer;
    transition: transform .15s ease, filter .15s ease;
}

.auth-submit-btn:hover {
    transform: translateY(-1px);
    filter: brightness(1.04);
}

.auth-popover input {
    width: 100%;
    box-sizing: border-box;
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 12px;
    padding: 10px 12px;
    color: #fff;
    background: rgba(255, 255, 255, 0.08);
}

.nav-link.disabled {
    opacity: 0.55;
    cursor: not-allowed;
}

.hidden {
    display: none !important;
}

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

    .planet-hero-orbit {
        order: -1;
        min-height: 180px;
    }
}

@media (max-width: 760px) {
    #app { padding: 14px 12px; }

    .home-topbar,
    .planet-hero,
    .dashboard-card { border-radius: 24px; }

    .home-topbar,
    .planet-hero,
    .dashboard-card { padding: 18px; }

    .home-topbar { padding-top: 48px; min-height: 0; }

    .hero-stat-strip,
    .metric-grid,
    .task-launch-row {
        grid-template-columns: 1fr;
    }

    .top-auth {
        top: 10px;
        right: 12px;
        gap: 6px;
        flex-wrap: nowrap;
        max-width: calc(100vw - 24px);
        justify-content: flex-end;
        overflow-x: auto;
        padding-left: 8px;
    }

    .top-auth-link,
    .top-auth-status {
        font-size: 12px;
        white-space: nowrap;
        flex: 0 0 auto;
    }

    .metric-main {
        grid-template-columns: 1fr;
        align-items: start;
    }

    .trend-mini-item,
    .task-module-item,
    .reward-mini-item {
        align-items: flex-start;
        flex-direction: column;
    }

    .trend-dot,
    .task-status-dot,
    .reward-status-dot {
        min-width: 0;
    }
}
