/* ── Dashboard Design Tokens ───────────────────────────────────────────────── */
:root {
    --dash-bg: #0d0f14;
    --dash-surface: #141720;
    --dash-surface-2: #1c1f2e;
    --dash-surface-hover: #232736;
    --dash-border: rgba(255, 255, 255, 0.07);
    --dash-text: #e2e4ec;
    --dash-text-muted: #6b7280;
    --dash-text-subtle: #4b5563;
    --dash-accent: #5865f2;
    --dash-accent-hover: #4752c4;
    --dash-danger: #e94560;
    --dash-success: #3ecf8e;
    --dash-warning: #f59e0b;
    --dash-font: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Inter', sans-serif;
    --dash-font-display: 'Trajan', 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    --dash-gold: #c0923a;
    --dash-gold-light: #d4a84e;
    --dash-gold-dark: #a07028;
    --dash-gold-glow: rgba(192, 146, 58, 0.4);
    --dash-silver: #b0b0b0;
    --dash-sidebar-width: 240px;
    --dash-radius: 10px;
    --dash-radius-sm: 6px;
}

/* ── Hide top bar and game background on account page ──────────────────────── */
body[data-page="account"] .top_bar_wrap { display: none; }
body[data-page="account"] .fullpage-wrapper { background: var(--dash-bg); }

/* ── Dashboard Root Layout ─────────────────────────────────────────────────── */
.dashboard {
    display: flex;
    min-height: 100vh;
    background: var(--dash-bg);
    font-family: var(--dash-font);
    color: var(--dash-text);
}

/* ── Sidebar ───────────────────────────────────────────────────────────────── */
.dashboard-sidebar {
    width: var(--dash-sidebar-width);
    background: var(--dash-surface);
    border-right: 1px solid var(--dash-border);
    display: flex;
    flex-direction: column;
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    z-index: 100;
    overflow-y: auto;
}

.dashboard-user {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 24px 20px 20px;
    border-bottom: 1px solid var(--dash-border);
}

.dashboard-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--dash-surface-2), var(--dash-surface));
    border: 2px solid var(--dash-gold);
    box-shadow: 0 0 12px var(--dash-gold-glow);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--dash-font-display);
    font-size: 16px;
    font-weight: 700;
    color: #fff;
    flex-shrink: 0;
    text-transform: uppercase;
}

.dashboard-user-info {
    overflow: hidden;
}

.dashboard-username {
    font-size: 14px;
    font-weight: 600;
    color: var(--dash-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.dashboard-user-email {
    font-size: 12px;
    color: var(--dash-text-muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-top: 2px;
}

/* ── Sidebar Navigation ────────────────────────────────────────────────────── */
.dashboard-nav {
    flex: 1;
    padding: 12px 10px;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.dashboard-nav-item {
    position: relative;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    border-radius: var(--dash-radius-sm);
    border: none;
    background: transparent;
    color: var(--dash-text-muted);
    font-family: var(--dash-font);
    font-size: 13.5px;
    font-weight: 500;
    cursor: pointer;
    text-align: left;
    width: 100%;
    transition: background 0.15s, color 0.15s;
}

.dashboard-nav-item:hover {
    background: var(--dash-surface-hover);
    color: var(--dash-text);
}

.dashboard-nav-item.active {
    background: rgba(88, 101, 242, 0.08);
    color: var(--dash-accent);
}

.dashboard-nav-item.active::before {
    content: '';
    position: absolute;
    left: 0;
    top: 4px;
    bottom: 4px;
    width: 3px;
    border-radius: 0 2px 2px 0;
    background: linear-gradient(180deg, var(--dash-accent), var(--dash-gold));
}

.dashboard-nav-item.active .nav-icon svg {
    color: var(--dash-accent);
}

.nav-icon {
    width: 18px;
    height: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    opacity: 0.75;
}

.dashboard-nav-item.active .nav-icon {
    opacity: 1;
}

/* ── Sidebar Footer ────────────────────────────────────────────────────────── */
.dashboard-sidebar-footer {
    padding: 12px 10px 20px;
    border-top: 1px solid var(--dash-border);
}

.dashboard-logout {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    border-radius: var(--dash-radius-sm);
    border: none;
    background: transparent;
    color: var(--dash-text-muted);
    font-family: var(--dash-font);
    font-size: 13.5px;
    font-weight: 500;
    cursor: pointer;
    width: 100%;
    text-align: left;
    transition: background 0.15s, color 0.15s;
}

.dashboard-logout:hover {
    background: rgba(233, 69, 96, 0.1);
    color: var(--dash-danger);
}

/* ── Main Content Area ─────────────────────────────────────────────────────── */
.dashboard-content {
    flex: 1;
    margin-left: var(--dash-sidebar-width);
    padding: 32px 40px;
    min-height: 100vh;
    box-sizing: border-box;
    background:
        radial-gradient(ellipse at 30% 0%, rgba(88, 101, 242, 0.04) 0%, transparent 60%),
        radial-gradient(ellipse at 80% 100%, rgba(192, 146, 58, 0.03) 0%, transparent 60%),
        var(--dash-bg);
}

/* ── Panels ────────────────────────────────────────────────────────────────── */
.dashboard-panel {
    display: none;
    animation: dashFadeIn 0.2s ease;
}

.dashboard-panel.active {
    display: block;
}

@keyframes dashFadeIn {
    from { opacity: 0; transform: translateY(6px); }
    to { opacity: 1; transform: translateY(0); }
}

.dashboard-panel-title {
    font-family: var(--dash-font-display);
    font-size: 20px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 2px;
    color: var(--dash-text);
    margin: 0 0 24px;
}

/* ── Cards ─────────────────────────────────────────────────────────────────── */
.dash-card {
    background: var(--dash-surface);
    border: 1px solid var(--dash-border);
    border-top: 2px solid var(--dash-accent);
    border-radius: var(--dash-radius);
    padding: 24px;
    margin-bottom: 20px;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.25);
}

.dash-card-title {
    font-size: 13px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--dash-text-muted);
    margin: 0 0 16px;
}

/* ── Overview Panel ────────────────────────────────────────────────────────── */
.dash-profile-header {
    display: flex;
    align-items: center;
    gap: 20px;
    margin-bottom: 24px;
}

.dash-profile-avatar {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--dash-surface-2), var(--dash-surface));
    border: 2.5px solid var(--dash-gold);
    box-shadow: 0 0 16px var(--dash-gold-glow);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--dash-font-display);
    font-size: 24px;
    font-weight: 700;
    color: #fff;
    flex-shrink: 0;
    text-transform: uppercase;
}

.dash-profile-name {
    font-size: 22px;
    font-weight: 700;
    color: var(--dash-text);
    margin: 0 0 4px;
}

.dash-profile-email {
    font-size: 13px;
    color: var(--dash-text-muted);
    margin: 0;
}

.dash-info-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 12px;
}

.dash-info-item {
    background: var(--dash-surface-2);
    border-radius: var(--dash-radius-sm);
    padding: 14px 16px;
}

.dash-info-label {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--dash-text-subtle);
    margin-bottom: 6px;
}

.dash-info-value {
    font-size: 14px;
    font-weight: 500;
    color: var(--dash-text);
}

/* ── Balance currency widget ──────────────────────────────────────────────── */
.dash-balance-item {
    background: linear-gradient(135deg, rgba(192, 146, 58, 0.08), rgba(192, 146, 58, 0.03));
    border: 1px solid rgba(192, 146, 58, 0.2);
    grid-column: 1 / -1;
}

.dash-balance-value {
    font-family: var(--dash-font-display);
    font-size: 18px;
    letter-spacing: 1px;
}

.dash-gold-amount { color: var(--dash-gold-light); }
.dash-silver-amount { color: var(--dash-silver); }

/* ── Status badge ──────────────────────────────────────────────────────────── */
.dash-status {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    font-weight: 500;
}

.dash-status::before {
    content: '';
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--dash-text-muted);
}

.dash-status.active::before { background: var(--dash-success); }
.dash-status.active { color: var(--dash-success); }
.dash-status.banned::before { background: var(--dash-danger); }
.dash-status.banned { color: var(--dash-danger); }

/* ── Discord section ───────────────────────────────────────────────────────── */
.dash-discord-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

.dash-discord-info {
    display: flex;
    align-items: center;
    gap: 10px;
}

.dash-discord-icon {
    color: #5865f2;
    display: flex;
    align-items: center;
}

.dash-discord-name {
    font-size: 14px;
    color: var(--dash-text);
    font-weight: 500;
}

.dash-discord-unlinked {
    font-size: 13px;
    color: var(--dash-text-muted);
}

/* ── Quick Actions ─────────────────────────────────────────────────────────── */
.dash-quick-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 20px;
}

/* ── Buttons ───────────────────────────────────────────────────────────────── */
.dash-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 9px 16px;
    border-radius: var(--dash-radius-sm);
    border: none;
    font-family: var(--dash-font);
    font-size: 13.5px;
    font-weight: 500;
    cursor: pointer;
    text-decoration: none;
    transition: background 0.15s, opacity 0.15s;
    white-space: nowrap;
}

.dash-btn-primary {
    background: var(--dash-accent);
    color: #fff;
}

.dash-btn-primary:hover { background: var(--dash-accent-hover); }

.dash-btn-secondary {
    background: var(--dash-surface-2);
    color: var(--dash-text);
    border: 1px solid var(--dash-border);
}

.dash-btn-secondary:hover { background: var(--dash-surface-hover); }

.dash-quick-actions .dash-btn-secondary {
    text-transform: uppercase;
    letter-spacing: 1px;
    font-size: 12px;
    padding: 11px 20px;
    border: 1px solid rgba(88, 101, 242, 0.25);
    transition: border-color 0.25s ease, box-shadow 0.25s ease, transform 0.25s ease, color 0.25s ease;
}

.dash-quick-actions .dash-btn-secondary:hover {
    border-color: var(--dash-accent);
    box-shadow: 0 0 12px rgba(88, 101, 242, 0.2);
    transform: translateY(-1px);
    color: #fff;
}

.dash-btn-discord {
    background: #5865f2;
    color: #fff;
}

.dash-btn-discord:hover { background: #4752c4; }

.dash-btn-danger {
    background: rgba(233, 69, 96, 0.12);
    color: var(--dash-danger);
    border: 1px solid rgba(233, 69, 96, 0.2);
}

.dash-btn-danger:hover { background: rgba(233, 69, 96, 0.2); }

.dash-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

/* ── Characters Panel ──────────────────────────────────────────────────────── */
.dash-characters-placeholder {
    text-align: center;
    padding: 60px 20px;
    color: var(--dash-text-muted);
}

.dash-characters-placeholder-icon {
    font-size: 48px;
    margin-bottom: 16px;
    opacity: 0.4;
}

.dash-characters-placeholder-title {
    font-size: 16px;
    font-weight: 600;
    color: var(--dash-text);
    margin: 0 0 8px;
}

.dash-characters-placeholder-text {
    font-size: 13px;
    color: var(--dash-text-muted);
    margin: 0;
}

.dash-characters-table {
    width: 100%;
    border-collapse: collapse;
}

.dash-characters-table th {
    text-align: left;
    padding: 10px 12px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--dash-text-muted);
    border-bottom: 1px solid var(--dash-border);
}

.dash-characters-table td {
    padding: 12px;
    font-size: 13.5px;
    color: var(--dash-text);
    border-bottom: 1px solid var(--dash-border);
}

.dash-characters-table tr:last-child td { border-bottom: none; }
.dash-characters-table tr:hover td { background: var(--dash-surface-hover); }

/* ── Settings Panel ────────────────────────────────────────────────────────── */
.dash-settings-section {
    margin-bottom: 24px;
}

.dash-settings-section:last-child { margin-bottom: 0; }

.dash-form-group {
    margin-bottom: 14px;
}

.dash-form-label {
    display: block;
    font-size: 12px;
    font-weight: 600;
    color: var(--dash-text-muted);
    margin-bottom: 6px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.dash-form-input {
    width: 100%;
    padding: 10px 14px;
    background: var(--dash-surface-2);
    border: 1px solid var(--dash-border);
    border-radius: var(--dash-radius-sm);
    color: var(--dash-text);
    font-family: var(--dash-font);
    font-size: 14px;
    box-sizing: border-box;
    transition: border-color 0.15s;
    outline: none;
}

.dash-form-input:focus {
    border-color: var(--dash-accent);
}

.dash-form-input::placeholder { color: var(--dash-text-subtle); }

.dash-form-max-width {
    max-width: 380px;
}

/* ── Alerts ────────────────────────────────────────────────────────────────── */
.dash-alert {
    padding: 10px 14px;
    border-radius: var(--dash-radius-sm);
    font-size: 13px;
    margin-top: 12px;
}

.dash-alert-success {
    background: rgba(62, 207, 142, 0.1);
    border: 1px solid rgba(62, 207, 142, 0.2);
    color: var(--dash-success);
}

.dash-alert-error {
    background: rgba(233, 69, 96, 0.1);
    border: 1px solid rgba(233, 69, 96, 0.2);
    color: var(--dash-danger);
}

/* ── Donate Panel ──────────────────────────────────────────────────────────── */
.dash-donate-wrapper {
    max-width: 520px;
}

.dash-donate-wrapper .donate-title {
    font-family: var(--dash-font);
    font-size: 22px;
    font-weight: 700;
    color: var(--dash-text);
    margin: 0 0 6px;
}

.dash-donate-wrapper .donate-subtitle {
    font-family: var(--dash-font);
    font-size: 13px;
    color: var(--dash-text-muted);
    margin: 0 0 24px;
}

/* Override donate form styles for dashboard context */
.dash-donate-wrapper .donate-card {
    background: var(--dash-surface);
    border: 1px solid var(--dash-border);
}

.dash-donate-wrapper .donate-input,
.dash-donate-wrapper .btn-submit {
    font-family: var(--dash-font);
}

/* ── Loading state ─────────────────────────────────────────────────────────── */
.dash-loading {
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--dash-text-muted);
    font-size: 13px;
    padding: 20px 0;
}

.dash-spinner {
    width: 16px;
    height: 16px;
    border: 2px solid var(--dash-border);
    border-top-color: var(--dash-accent);
    border-radius: 50%;
    animation: dashSpin 0.7s linear infinite;
    flex-shrink: 0;
}

@keyframes dashSpin {
    to { transform: rotate(360deg); }
}

/* ── Mobile Responsive ─────────────────────────────────────────────────────── */
@media (max-width: 768px) {
    .dashboard {
        flex-direction: column;
    }

    .dashboard-sidebar {
        width: 100%;
        position: static;
        height: auto;
        border-right: none;
        border-bottom: 1px solid var(--dash-border);
    }

    .dashboard-user {
        padding: 16px;
    }

    .dashboard-nav {
        flex-direction: row;
        overflow-x: auto;
        padding: 8px;
        gap: 4px;
        scrollbar-width: none;
    }

    .dashboard-nav::-webkit-scrollbar { display: none; }

    .dashboard-nav-item {
        flex-shrink: 0;
        padding: 8px 12px;
    }

    .dashboard-nav-item.active::before {
        left: 8px;
        right: 8px;
        bottom: 0;
        top: auto;
        width: auto;
        height: 2px;
        border-radius: 2px 2px 0 0;
    }

    .nav-label {
        font-size: 13px;
    }

    .dashboard-sidebar-footer {
        display: none;
    }

    .dashboard-content {
        margin-left: 0;
        padding: 20px 16px;
    }

    .dash-info-grid {
        grid-template-columns: 1fr 1fr;
    }

    .dash-profile-header {
        gap: 14px;
    }

    .dash-profile-avatar {
        width: 48px;
        height: 48px;
        font-size: 20px;
    }

    .dash-form-max-width {
        max-width: 100%;
    }

    .dash-quick-actions {
        flex-direction: column;
    }

    .dash-btn { width: 100%; justify-content: center; }

    /* Show logout in nav on mobile */
    .dashboard-nav::after {
        content: '';
        flex-shrink: 0;
        width: 1px;
    }
}

@media (max-width: 480px) {
    .dash-info-grid {
        grid-template-columns: 1fr;
    }
}

/* ── Vote Panel ───────────────────────────────────────────────────────────── */

.vote-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 20px;
}

.vote-reward-info {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.vote-reward-label {
    font-size: 13px;
    color: var(--dash-text-muted);
}

.vote-reward-amount {
    font-family: var(--dash-font-display);
    font-size: 20px;
    color: var(--dash-gold);
}

.vote-action {
    text-align: center;
    padding: 20px 0;
}

.vote-btn-primary {
    display: inline-block;
    padding: 14px 32px;
    background: linear-gradient(135deg, var(--dash-gold), var(--dash-gold-dark));
    color: #fff;
    font-family: var(--dash-font-display);
    font-size: 16px;
    border-radius: var(--dash-radius);
    text-decoration: none;
    transition: all 0.2s;
    border: 1px solid var(--dash-gold-light);
    box-shadow: 0 0 20px var(--dash-gold-glow);
}

.vote-btn-primary:hover {
    background: linear-gradient(135deg, var(--dash-gold-light), var(--dash-gold));
    box-shadow: 0 0 30px var(--dash-gold-glow);
    transform: translateY(-1px);
}

.vote-hint {
    margin-top: 12px;
    font-size: 13px;
    color: var(--dash-text-muted);
}

.vote-cooldown {
    text-align: center;
    padding: 20px 0;
}

.vote-cooldown-timer {
    font-family: var(--dash-font-display);
    font-size: 28px;
    color: var(--dash-gold);
    letter-spacing: 2px;
    margin-bottom: 8px;
}

.vote-cooldown-text {
    font-size: 13px;
    color: var(--dash-text-muted);
}

.vote-stats {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
}

.vote-stat-item {
    text-align: center;
    padding: 16px;
    background: var(--dash-surface-2);
    border-radius: var(--dash-radius-sm);
    border: 1px solid var(--dash-border);
}

.vote-stat-value {
    font-family: var(--dash-font-display);
    font-size: 24px;
    color: var(--dash-gold);
    margin-bottom: 4px;
}

.vote-stat-label {
    font-size: 12px;
    color: var(--dash-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.vote-gold-cell {
    color: var(--dash-gold-light);
    font-weight: 600;
}

.vote-pagination {
    display: flex;
    gap: 6px;
    justify-content: center;
    margin-top: 16px;
}

.vote-page-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: var(--dash-radius-sm);
    border: 1px solid var(--dash-border);
    background: var(--dash-surface-2);
    color: var(--dash-text-muted);
    font-size: 13px;
    cursor: pointer;
    transition: all 0.15s;
}

.vote-page-btn:hover {
    background: var(--dash-surface-hover);
    color: var(--dash-text);
}

.vote-page-btn.active {
    background: var(--dash-accent);
    color: #fff;
    border-color: var(--dash-accent);
    cursor: default;
}
