/* Flex container for the leaderboard layout */
.leaderboard-layout {
    display: flex;
    gap: 20px;
    margin-top: 20px;
}

/* Buttons sidebar */
.leaderboard-buttons-vertical {
    display: flex;
    flex-direction: column;
    gap: 10px;
    width: 200px;
    flex-shrink: 0;
}

/* Styling for the buttons */
.leaderboard-buttons-vertical button {
    background-color: #333;
    color: #fff;
    border: none;
    border-radius: 5px;
    padding: 10px 15px;
    font-size: 16px;
    font-weight: bold;
    cursor: pointer;
    text-align: left;
    transition: background-color 0.3s ease, transform 0.2s ease;
    min-height: 44px;
}

.leaderboard-buttons-vertical button:hover {
    background-color: #555;
    transform: scale(1.05);
}

.leaderboard-buttons-vertical button:active {
    transform: scale(0.98);
}

/* Leaderboard table container */
.leaderboard-container {
    flex: 1;
    background-color: #222;
    padding: 20px;
    border-radius: 10px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.3);
    overflow-x: auto;
}

.leaderboard-container table {
    width: 100%;
    border-collapse: collapse;
}

.leaderboard-container th, .leaderboard-container td {
    border: 1px solid #444;
    padding: 10px;
    text-align: left;
}

.leaderboard-container th {
    background-color: #333;
    color: #fff;
    font-weight: bold;
}

.leaderboard-container td {
    background-color: #282828;
    color: #fff;
}

/* Special styling for the rank column */
.rank-gold {
    color: gold;
    font-weight: bold;
}

.rank-silver {
    color: silver;
    font-weight: bold;
}

.rank-bronze {
    color: #cd7f32;
    font-weight: bold;
}

/* TABLET - Responsive Design (768px and below) */
@media screen and (max-width: 768px) {
    .leaderboard-layout {
        flex-direction: column;
        gap: 15px;
        margin-top: 15px;
    }

    .leaderboard-buttons-vertical {
        flex-direction: row;
        flex-wrap: wrap;
        gap: 8px;
        width: auto;
    }

    .leaderboard-buttons-vertical button {
        flex: 1;
        min-width: 100px;
        padding: 10px 12px;
        font-size: 14px;
        text-align: center;
    }

    .leaderboard-container {
        padding: 16px;
        overflow-x: auto;
    }

    .leaderboard-container th, .leaderboard-container td {
        padding: 8px;
        font-size: 13px;
    }
}

/* MOBILE - Small Phones (480px and below) */
@media screen and (max-width: 480px) {
    .leaderboard-layout {
        gap: 12px;
        margin-top: 12px;
    }

    .leaderboard-buttons-vertical {
        gap: 6px;
    }

    .leaderboard-buttons-vertical button {
        flex: 1 1 45%;
        min-width: 70px;
        padding: 9px 8px;
        font-size: 12px;
        min-height: 44px;
    }

    .leaderboard-container {
        padding: 12px;
    }

    .leaderboard-container th, .leaderboard-container td {
        padding: 6px;
        font-size: 11px;
    }

    .leaderboard-container table {
        min-width: 600px;
    }
}