.dash-wrap {
    min-height: 100vh;
    padding-top: 90px;
    padding-bottom: 4rem;
    position: relative;
    z-index: 2;
    background: rgba(245,240,232,0.85);
}

.dash-sidebar {
    background: rgba(255,255,255,0.93);
    border: 1px solid var(--border);
    border-radius: var(--r-md);
    padding: 1.5rem;
    box-shadow: var(--shadow-sm);
    position: sticky;
    top: 90px;
}

.dash-nav-item {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .65rem 1rem;
    border-radius: var(--r);
    font-family: 'Nunito', sans-serif;
    font-size: .95rem;
    font-weight: 600;
    color: var(--text-soft);
    text-decoration: none;
    transition: all .2s;
    margin-bottom: .25rem;
}

.dash-nav-item:hover,
.dash-nav-item.active {
    background: var(--rot-glow);
    color: var(--rot);
}

.dash-nav-item i { font-size: 1rem; width: 20px; text-align: center; }

.dash-card {
    background: rgba(255,255,255,0.93);
    border: 1px solid var(--border);
    border-radius: var(--r-md);
    padding: 1.75rem;
    box-shadow: var(--shadow-sm);
    margin-bottom: 1.25rem;
    position: relative;
    overflow: hidden;
}

.dash-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: var(--rot);
}

.dash-card-title {
    font-family: 'Playfair Display', Georgia, serif;
    font-size: 1.2rem;
    font-weight: 700;
    color: var(--text);
    margin-bottom: 1rem;
    display: flex;
    align-items: center;
    gap: .6rem;
}

.dash-card-title i { color: var(--rot); font-size: 1.1rem; }

.dash-stat-row {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    padding: .55rem 0;
    border-bottom: 1px solid rgba(184,134,11,0.1);
    font-family: 'Nunito', sans-serif;
}

.dash-stat-row:last-child { border-bottom: none; }
.dash-stat-label { font-size: .95rem; color: var(--text-soft); }
.dash-stat-val { font-family: 'Playfair Display', Georgia, serif; font-size: 1.2rem; font-weight: 700; color: var(--rot); }

/* Skill Tree */
.skill-category {
    margin-bottom: 2rem;
}

.skill-category-title {
    font-family: 'Playfair Display', Georgia, serif;
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--text);
    margin-bottom: 1rem;
    display: flex;
    align-items: center;
    gap: .6rem;
    padding-bottom: .5rem;
    border-bottom: 2px solid var(--border);
}

.skill-node {
    background: rgba(255,255,255,0.93);
    border: 1px solid var(--border);
    border-radius: var(--r-md);
    padding: 1.25rem;
    position: relative;
    transition: all .3s cubic-bezier(.16,1,.3,1);
    box-shadow: var(--shadow-sm);
    height: 100%;
}

.skill-node::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: transparent;
    transition: background .3s;
    border-radius: var(--r-md) var(--r-md) 0 0;
}

.skill-node.purchased { border-color: var(--gold); background: rgba(184,134,11,0.05); }
.skill-node.purchased::before { background: var(--gold); }

.skill-node.can-buy { border-color: rgba(192,57,43,0.3); cursor: pointer; }
.skill-node.can-buy:hover { border-color: var(--rot); transform: translateY(-3px); box-shadow: var(--shadow-md); }
.skill-node.can-buy::before { background: var(--rot); }

.skill-node.locked { opacity: .5; }

.skill-name {
    font-family: 'Playfair Display', Georgia, serif;
    font-size: 1rem;
    font-weight: 700;
    color: var(--text);
    margin-bottom: .35rem;
}

.skill-desc {
    font-family: 'Nunito', sans-serif;
    font-size: .82rem;
    color: var(--text-soft);
    line-height: 1.5;
    margin-bottom: .75rem;
}

.skill-cost {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    font-family: 'Nunito', sans-serif;
    font-size: .78rem;
    font-weight: 700;
    padding: .25rem .6rem;
    border-radius: 100px;
    background: var(--rot-glow);
    color: var(--rot);
    border: 1px solid var(--border-rot);
}

.skill-node.purchased .skill-cost {
    background: var(--gold-glow);
    color: var(--gold-dim);
    border-color: rgba(184,134,11,0.3);
}

.points-banner {
    background: linear-gradient(135deg, var(--rot) 0%, var(--rot-dark) 100%);
    border-radius: var(--r-md);
    padding: 1.25rem 1.75rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1.75rem;
    color: white;
    box-shadow: 0 4px 20px rgba(192,57,43,0.25);
}

.points-val {
    font-family: 'Playfair Display', Georgia, serif;
    font-size: 2rem;
    font-weight: 700;
}

.points-label {
    font-family: 'Nunito', sans-serif;
    font-size: .75rem;
    letter-spacing: .1em;
    text-transform: uppercase;
    opacity: .75;
}

/* Alert */
.dash-alert {
    padding: .75rem 1rem;
    border-radius: var(--r);
    font-family: 'Nunito', sans-serif;
    font-size: .9rem;
    margin-bottom: 1rem;
    display: none;
}

.dash-alert.show { display: block; }
.dash-alert-success { background: rgba(39,174,96,.1); border: 1px solid rgba(39,174,96,.3); color: #1e7e34; }
.dash-alert-error { background: var(--rot-glow); border: 1px solid var(--border-rot); color: var(--rot-dark); }

/* Upload */
.upload-zone {
    border: 2px dashed var(--border);
    border-radius: var(--r-md);
    padding: 3rem;
    text-align: center;
    transition: all .3s;
    cursor: pointer;
}

.upload-zone:hover, .upload-zone.drag-over {
    border-color: var(--rot);
    background: var(--rot-glow);
}

.upload-zone i { font-size: 2.5rem; color: var(--text-dim); margin-bottom: 1rem; }
.upload-zone p { font-family: 'Nunito', sans-serif; color: var(--text-soft); margin: 0; }

/* User table */
.dash-table {
    width: 100%;
    border-collapse: collapse;
    font-family: 'Nunito', sans-serif;
    font-size: .9rem;
}

.dash-table th {
    font-size: .65rem;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--text-dim);
    padding: .6rem 1rem;
    border-bottom: 2px solid var(--border);
    text-align: left;
}

.dash-table td {
    padding: .75rem 1rem;
    border-bottom: 1px solid rgba(184,134,11,0.1);
    color: var(--text-soft);
    vertical-align: middle;
}

.dash-table tr:last-child td { border-bottom: none; }
.dash-table tr:hover td { background: rgba(184,134,11,0.03); }

.badge-role {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    padding: .2rem .6rem;
    border-radius: 100px;
    font-size: .7rem;
    font-weight: 700;
}

.badge-admin { background: var(--rot-glow); color: var(--rot); border: 1px solid var(--border-rot); }
.badge-mod { background: var(--gold-glow); color: var(--gold-dim); border: 1px solid rgba(184,134,11,0.3); }
.badge-player { background: rgba(39,174,96,.1); color: #1a7a3a; border: 1px solid rgba(39,174,96,.25); }

.btn-rot {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    padding: .5rem 1.2rem;
    background: var(--rot);
    color: white;
    border: none;
    border-radius: var(--r);
    font-family: 'Nunito', sans-serif;
    font-size: .88rem;
    font-weight: 700;
    cursor: pointer;
    transition: all .2s;
}

.btn-rot:hover { background: var(--rot-dark); transform: translateY(-1px); }
.btn-gold {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    padding: .5rem 1.2rem;
    background: var(--gold-dim);
    color: white;
    border: none;
    border-radius: var(--r);
    font-family: 'Nunito', sans-serif;
    font-size: .88rem;
    font-weight: 700;
    cursor: pointer;
    transition: all .2s;
}
.btn-gold:hover { background: var(--gold); transform: translateY(-1px); }

/* Loading spinner */
.dash-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 3rem;
    color: var(--text-dim);
    font-family: 'Nunito', sans-serif;
    gap: .75rem;
}

.dash-input {
    width: 100%;
    padding: .65rem .9rem;
    border: 1px solid var(--border);
    border-radius: var(--r);
    font-family: 'Nunito', sans-serif;
    font-size: .95rem;
    background: rgba(245,240,232,0.6);
    color: var(--text);
    outline: none;
    transition: border .2s;
}

.dash-label {
    font-family: 'Nunito', sans-serif;
    font-size: .82rem;
    font-weight: 600;
    color: var(--text-soft);
    display: block;
    margin-bottom: .4rem;
}

.spinner {
    width: 20px; height: 20px;
    border: 2px solid var(--border);
    border-top-color: var(--rot);
    border-radius: 50%;
    animation: spin .7s linear infinite;
}

@keyframes spin { to { transform: rotate(360deg); } }