/*
 * EXILIUM — RBG Strategy Hub
 */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

@font-face {
    font-family: 'Sport Break';
    src: url('../assets/Sport_Break_Free_Version.otf') format('opentype');
    unicode-range: U+0020-007E;
}

:root {
    --bg-color: #06060b;
    --bg-secondary: #0e0e16;
    --bg-tertiary: #16161f;
    --bg-card: rgba(14, 14, 22, 0.9);
    --text-color: #e8e8ed;
    --text-muted: #7a7a8e;
    --accent-color: #d4a017;
    --accent-hover: #f0b90b;
    --accent-glow: rgba(212, 160, 23, 0.3);
    --border-color: rgba(255, 255, 255, 0.06);
    --border-glow: rgba(212, 160, 23, 0.2);
    --green: #22c55e;
    --blue: #3b82f6;
    --red: #ef4444;
    --orange: #f97316;
    --purple: #a855f7;
    --radius-sm: 6px;
    --radius-md: 10px;
    --radius-lg: 16px;
    --shadow-md: 0 4px 20px rgba(0,0,0,0.4);
    --transition: 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
    font-family: 'Inter', -apple-system, sans-serif;
    background: var(--bg-color);
    color: var(--text-color);
    line-height: 1.6;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
}

a { text-decoration: none; color: inherit; }

/* ── HEADER ── */
.rbg-header {
    position: sticky;
    top: 0;
    z-index: 100;
    background: rgba(6, 6, 11, 0.94);
    backdrop-filter: blur(16px);
    border-bottom: 1px solid var(--border-glow);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.8rem 2rem;
}

.rbg-header-logo {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.rbg-header-logo img { height: 36px; width: auto; }

.rbg-header-logo span {
    font-family: 'Sport Break', sans-serif;
    color: var(--accent-color);
    font-size: 1rem;
    letter-spacing: 2px;
    text-transform: uppercase;
}

.rbg-header-nav {
    display: flex;
    align-items: center;
    gap: 1.5rem;
}

.rbg-header-nav a {
    color: var(--text-muted);
    font-size: 0.88rem;
    font-weight: 500;
    transition: color var(--transition);
}

.rbg-header-nav a:hover { color: var(--accent-color); }

.rbg-header-nav .btn-discord {
    background: #5865F2;
    color: #fff;
    padding: 0.45rem 1rem;
    border-radius: var(--radius-sm);
    font-weight: 600;
    font-size: 0.82rem;
    transition: opacity var(--transition);
}

.rbg-header-nav .btn-discord:hover { opacity: 0.85; }

/* ── HERO ── */
.rbg-hero {
    position: relative;
    padding: 4rem 2rem 3rem;
    text-align: center;
    overflow: hidden;
    background: radial-gradient(ellipse 80% 60% at 50% 0%, rgba(212,160,23,0.12) 0%, transparent 70%);
    border-bottom: 1px solid var(--border-glow);
}

.rbg-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background: url('../assets/rbg/arena_3v3.webp') center/cover no-repeat;
    opacity: 0.07;
    z-index: 0;
    pointer-events: none;
}

.rbg-hero > * { position: relative; z-index: 1; }

.rbg-hero h1 {
    font-family: 'Sport Break', sans-serif;
    font-size: clamp(1.8rem, 5vw, 3rem);
    color: var(--accent-color);
    text-transform: uppercase;
    letter-spacing: 4px;
    margin-bottom: 0.75rem;
    text-shadow: 0 0 40px rgba(212,160,23,0.4);
}

.rbg-hero p {
    color: var(--text-muted);
    font-size: 1rem;
    max-width: 700px;
    margin: 0 auto;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

@media (max-width: 800px) {
    .rbg-hero p {
        white-space: normal;
    }
}

.rbg-hero-badge {
    display: inline-block;
    background: rgba(212,160,23,0.12);
    border: 1px solid var(--border-glow);
    color: var(--accent-color);
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    padding: 0.35rem 1rem;
    border-radius: 20px;
    margin-bottom: 1rem;
}

/* ── LAYOUT ── */
.rbg-layout {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 0;
    min-height: calc(100vh - 140px);
    position: relative;
}

.rbg-layout::after {
    content: '';
    position: fixed;
    inset: 0;
    background: url('../assets/rbg/Deephaul_Ravine.png?v=20260509tactical2') center/cover no-repeat;
    opacity: 0.08;
    z-index: 0;
    pointer-events: none;
}

/* ── SIDEBAR ── */
.rbg-sidebar {
    background: var(--bg-secondary);
    border-right: 1px solid var(--border-color);
    padding: 1.5rem 0;
    position: sticky;
    top: 58px;
    height: calc(100vh - 58px);
    overflow-y: auto;
}

.rbg-sidebar-title {
    font-family: 'Sport Break', sans-serif;
    font-size: 0.72rem;
    color: var(--accent-color);
    letter-spacing: 2px;
    text-transform: uppercase;
    padding: 0.75rem 1.25rem;
    border-bottom: 1px solid var(--border-color);
    margin-bottom: 0.5rem;
    background: rgba(212,160,23,0.04);
}

.map-btn {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    width: 100%;
    padding: 0.75rem 1.25rem;
    background: none;
    border: none;
    cursor: pointer;
    text-align: left;
    transition: background var(--transition);
    border-left: 3px solid transparent;
}

.map-btn:hover {
    background: rgba(212,160,23,0.06);
}

.map-btn.active {
    background: rgba(212,160,23,0.1);
    border-left-color: var(--accent-color);
}

.map-btn-img {
    width: 44px;
    height: 44px;
    border-radius: var(--radius-sm);
    object-fit: cover;
    border: 1px solid var(--border-color);
    flex-shrink: 0;
    overflow: hidden;
}

.map-btn-info { flex: 1; min-width: 0; }

.map-btn-name {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--text-color);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.map-btn.active .map-btn-name { color: var(--accent-color); }

.map-btn-status {
    font-size: 0.7rem;
    margin-top: 0.15rem;
}

.status-confirmed { color: var(--green); }
.status-review { color: var(--orange); }
.status-empty { color: var(--text-muted); }

/* ── MAIN CONTENT ── */
.rbg-content {
    padding: 2rem;
    min-height: 500px;
}

.rbg-content-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1.5rem;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.rbg-content-header h2 {
    font-family: 'Sport Break', sans-serif;
    font-size: 1.3rem;
    color: var(--accent-color);
    text-transform: uppercase;
    letter-spacing: 2px;
}

.status-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.3rem 0.8rem;
    border-radius: 20px;
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.status-badge.confirmed {
    background: rgba(34,197,94,0.12);
    color: var(--green);
    border: 1px solid rgba(34,197,94,0.25);
}

.status-badge.review {
    background: rgba(249,115,22,0.12);
    color: var(--orange);
    border: 1px solid rgba(249,115,22,0.25);
}

.status-badge.empty {
    background: rgba(122,122,142,0.12);
    color: var(--text-muted);
    border: 1px solid rgba(122,122,142,0.2);
}

/* ── INTERACTIVE TACTICAL MAP ── */
.rbg-map-card {
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    overflow: hidden;
    margin-bottom: 1rem;
}

.map-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.6rem 1rem;
    background: var(--bg-tertiary);
    border-bottom: 1px solid var(--border-color);
    gap: 0.75rem;
    flex-wrap: wrap;
}

.map-toolbar-title {
    font-size: 0.78rem;
    color: var(--text-muted);
    font-weight: 500;
}

.map-toolbar-title strong { color: var(--accent-color); }

.map-controls {
    display: flex;
    align-items: center;
    gap: 0.35rem;
}

.map-controls button {
    background: var(--bg-color);
    border: 1px solid var(--border-color);
    color: var(--text-muted);
    width: 28px;
    height: 28px;
    border-radius: var(--radius-sm);
    cursor: pointer;
    font-size: 0.75rem;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all var(--transition);
}

.map-controls button:hover { color: var(--accent-color); border-color: var(--border-glow); }

.draw-tool-btn { width: 32px !important; height: 32px !important; font-size: 0.85rem !important; position: relative; }
.draw-tool-btn.active { background: rgba(212,160,23,0.2) !important; border-color: var(--accent-color) !important; color: var(--accent-color) !important; }
.map-tool-sep { color: rgba(255,255,255,0.1); margin: 0 0.2rem; font-size: 0.8rem; user-select: none; }

/* ── Role marker buttons ── */
.draw-tool-role-tank { border-color: rgba(59,130,246,0.35) !important; }
.draw-tool-role-tank:hover { border-color: #3b82f6 !important; background: rgba(59,130,246,0.1) !important; }
.draw-tool-role-tank.active { background: rgba(59,130,246,0.22) !important; border-color: #3b82f6 !important; }
.draw-tool-role-healer { border-color: rgba(34,197,94,0.35) !important; }
.draw-tool-role-healer:hover { border-color: #22c55e !important; background: rgba(34,197,94,0.1) !important; }
.draw-tool-role-healer.active { background: rgba(34,197,94,0.22) !important; border-color: #22c55e !important; }
.draw-tool-role-dps { border-color: rgba(239,68,68,0.35) !important; }
.draw-tool-role-dps:hover { border-color: #ef4444 !important; background: rgba(239,68,68,0.1) !important; }
.draw-tool-role-dps.active { background: rgba(239,68,68,0.22) !important; border-color: #ef4444 !important; }

/* ── Custom tooltips ── */
[data-tooltip] { position: relative; }
[data-tooltip]::after {
    content: attr(data-tooltip);
    position: absolute;
    top: calc(100% + 10px);
    left: 50%;
    transform: translateX(-50%);
    background: rgba(10,10,16,0.97);
    color: #f0e6c8;
    padding: 0.55rem 1rem;
    border-radius: 8px;
    font-size: 0.82rem;
    white-space: nowrap;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.2s;
    z-index: 200;
    border: 1px solid rgba(212,160,23,0.35);
    font-weight: 600;
    letter-spacing: 0.3px;
    box-shadow: 0 6px 20px rgba(0,0,0,0.55);
}
[data-tooltip]:hover::after { opacity: 1; }

.map-canvas { pointer-events: none !important; z-index: 5; }

.map-zoom-label {
    font-size: 0.7rem;
    color: var(--text-muted);
    min-width: 36px;
    text-align: center;
    font-weight: 600;
}

.map-viewport {
    width: 100%;
    height: clamp(520px, 64vh, 760px);
    overflow: hidden;
    cursor: grab;
    background: #000;
    position: relative;
}

.map-viewport:active { cursor: grabbing; }

.map-layer {
    position: absolute;
    top: 0;
    left: 0;
    transform-origin: 0 0;
    width: 100%;
    height: 100%;
}

.rbg-map-image {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
    user-select: none;
    pointer-events: none;
}

.map-markers-layer {
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.map-marker {
    position: absolute;
    width: 26px;
    height: 26px;
    border-radius: 50%;
    border: 2px solid rgba(255,255,255,0.9);
    color: #fff;
    font-size: 0.65rem;
    font-weight: 800;
    display: flex;
    align-items: center;
    justify-content: center;
    transform: translate(-50%,-50%);
    cursor: move;
    pointer-events: auto;
    box-shadow: 0 0 10px rgba(0,0,0,0.6);
    z-index: 10;
    transition: transform 0.15s;
}

.map-marker:hover { transform: translate(-50%,-50%) scale(1.25); z-index: 20; }

.map-marker-role {
    width: 30px;
    height: 30px;
    font-size: 0.82rem;
    border-width: 2.5px;
}

.map-card-footer {
    padding: 0.55rem 1rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 0.7rem;
    color: var(--text-muted);
    border-top: 1px solid var(--border-color);
    background: var(--bg-tertiary);
}

.map-card-footer strong { color: var(--text-color); }

/* ── TACTICAL PANEL ── */
.tac-panel {
    display: grid;
    grid-template-columns: 1fr 280px;
    gap: 1rem;
    margin-bottom: 1rem;
}

@media (max-width: 900px) { .tac-panel { grid-template-columns: 1fr; } }

.tac-section-title {
    font-family: 'Sport Break', sans-serif;
    font-size: 0.72rem;
    color: var(--accent-color);
    text-transform: uppercase;
    letter-spacing: 1.5px;
    margin-bottom: 0.75rem;
}

.tac-groups-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.6rem;
}

.tac-group {
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    overflow: hidden;
}

.tac-group-header {
    padding: 0.5rem 0.7rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: var(--bg-tertiary);
}

.tac-group-header span {
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--text-color);
}

.tac-group-header small {
    font-size: 0.62rem;
    color: var(--text-muted);
}

.tac-group-slots {
    padding: 0.4rem;
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.tac-slot {
    padding: 0.4rem 0.55rem;
    border-radius: var(--radius-sm);
    font-size: 0.72rem;
    display: flex;
    align-items: center;
    gap: 0.4rem;
    cursor: pointer;
    transition: all var(--transition);
    min-height: 32px;
}

.tac-slot.filled {
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    color: var(--text-color);
    font-weight: 600;
}

.tac-slot.filled:hover { border-color: #ef4444; background: rgba(239,68,68,0.08); }

.tac-slot.empty {
    border: 1px dashed rgba(255,255,255,0.08);
    color: var(--text-muted);
    justify-content: center;
    font-size: 1rem;
    font-weight: 300;
}

.tac-slot.empty:hover { border-color: var(--accent-color); color: var(--accent-color); background: rgba(212,160,23,0.06); }

.tac-slot-icon {
    width: 20px;
    height: 20px;
    border-radius: 3px;
    object-fit: cover;
    flex-shrink: 0;
}

.tac-role-tag {
    font-size: 0.55rem;
    font-weight: 700;
    color: #fff;
    padding: 1px 5px;
    border-radius: 3px;
    margin-left: auto;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.tac-save-btn {
    margin-top: 0.5rem;
    width: 100%;
    padding: 0.5rem;
    background: var(--accent-color);
    color: #000;
    border: none;
    border-radius: var(--radius-sm);
    font-weight: 700;
    font-size: 0.78rem;
    cursor: pointer;
    transition: all var(--transition);
}
.tac-save-btn:hover { background: var(--accent-hover); }

.tac-admin-note {
    margin-top: 0.5rem;
    font-size: 0.65rem;
    color: var(--text-muted);
    font-style: italic;
    text-align: center;
}

.tac-clear-btn {
    margin-left: 8px;
    background: none;
    border: 1px solid rgba(255,255,255,.2);
    color: #fff;
    padding: 2px 8px;
    border-radius: 4px;
    cursor: pointer;
    font-size: .7rem;
}

.tac-selected-info {
    margin-top: 0.5rem;
    padding: 0.4rem 0.6rem;
    background: rgba(212,160,23,0.1);
    border: 1px solid var(--border-glow);
    border-radius: var(--radius-sm);
    font-size: 0.7rem;
    color: var(--text-muted);
    display: flex;
    align-items: center;
}

.tac-selected-info strong { color: var(--accent-color); }

/* ── PLAYER ROSTER ── */
.tac-panel-right {
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    padding: 0.75rem;
}

.tac-roster {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    max-height: 380px;
    overflow-y: auto;
}

.tac-player {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.35rem 0.5rem;
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: all var(--transition);
    border: 1px solid transparent;
}

.tac-player:hover { background: var(--bg-tertiary); border-color: var(--border-color); }

.tac-player.selected { background: rgba(212,160,23,0.12); border-color: var(--border-glow); }

.tac-player-icon {
    width: 22px;
    height: 22px;
    border-radius: 3px;
    object-fit: cover;
    flex-shrink: 0;
}

.tac-player span {
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--text-color);
    flex: 1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.tac-player small {
    font-size: 0.6rem;
    color: var(--text-muted);
    flex-shrink: 0;
}

.tac-empty-msg {
    color: var(--text-muted);
    font-size: 0.75rem;
    text-align: center;
    padding: 1rem;
    font-style: italic;
}

.header-type {
    font-size: .8rem;
    opacity: .5;
    font-family: 'Inter',sans-serif;
    letter-spacing: 0;
    text-transform: none;
}

.rbg-notes-card {
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    padding: 1.25rem;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.rbg-notes-card h3 {
    font-family: 'Sport Break', sans-serif;
    font-size: 0.8rem;
    color: var(--accent-color);
    text-transform: uppercase;
    letter-spacing: 1.5px;
}

.notes-text {
    color: var(--text-muted);
    font-size: 0.88rem;
    line-height: 1.7;
    white-space: pre-wrap;
    flex: 1;
}

.notes-empty {
    color: var(--text-muted);
    font-size: 0.85rem;
    font-style: italic;
    opacity: 0.6;
}

.notes-updated {
    font-size: 0.72rem;
    color: var(--text-muted);
    opacity: 0.6;
    padding-top: 0.5rem;
    border-top: 1px solid var(--border-color);
}

/* ── COMPOSITION ── */
.rbg-comp-card {
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    padding: 1.25rem;
    margin-bottom: 1.5rem;
}

.rbg-comp-card h3 {
    font-family: 'Sport Break', sans-serif;
    font-size: 0.8rem;
    color: var(--accent-color);
    text-transform: uppercase;
    letter-spacing: 1.5px;
    margin-bottom: 1rem;
}

.comp-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 0.75rem;
}

.comp-slot {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    padding: 0.65rem 0.9rem;
    transition: border-color var(--transition);
}

.comp-slot:hover { border-color: var(--border-glow); }

.comp-slot-num {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: rgba(212,160,23,0.12);
    border: 1px solid var(--border-glow);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.7rem;
    font-weight: 700;
    color: var(--accent-color);
    flex-shrink: 0;
}

.comp-slot-class-icon {
    width: 28px;
    height: 28px;
    border-radius: 4px;
    object-fit: cover;
    flex-shrink: 0;
}

.comp-slot-class-placeholder {
    width: 28px;
    height: 28px;
    border-radius: 4px;
    background: var(--bg-color);
    border: 1px dashed rgba(255,255,255,0.1);
    flex-shrink: 0;
}

.comp-slot-info { flex: 1; min-width: 0; }

.comp-slot-player {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--text-color);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.comp-slot-empty .comp-slot-player {
    color: var(--text-muted);
    font-weight: 400;
    font-style: italic;
}

.comp-slot-role {
    font-size: 0.7rem;
    margin-top: 0.1rem;
}

.role-fc { color: #f59e0b; }
.role-healer { color: #22c55e; }
.role-offense { color: #ef4444; }
.role-defense { color: #3b82f6; }
.role-roamer { color: #a855f7; }
.role-empty { color: var(--text-muted); opacity: 0.5; }

/* ── EMPTY STATE ── */
.rbg-empty {
    text-align: center;
    padding: 5rem 2rem;
    color: var(--text-muted);
}

.rbg-empty .empty-icon {
    font-size: 3.5rem;
    margin-bottom: 1rem;
    display: block;
    opacity: 0.4;
}

.rbg-empty h3 {
    font-family: 'Sport Break', sans-serif;
    font-size: 1rem;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 2px;
    margin-bottom: 0.5rem;
}

.rbg-empty p { font-size: 0.85rem; opacity: 0.7; }

/* ── SKELETON LOADER ── */
.skeleton {
    background: linear-gradient(90deg, var(--bg-secondary) 25%, var(--bg-tertiary) 50%, var(--bg-secondary) 75%);
    background-size: 200% 100%;
    animation: skeleton-loading 1.4s infinite;
    border-radius: var(--radius-sm);
}

@keyframes skeleton-loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* ── SCROLLBAR ── */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--bg-color); }
::-webkit-scrollbar-thumb { background: rgba(212,160,23,0.3); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--accent-color); }

/* ── RESPONSIVE ── */
@media (max-width: 768px) {
    .rbg-layout {
        grid-template-columns: 1fr;
    }

    .rbg-sidebar {
        position: static;
        height: auto;
        border-right: none;
        border-bottom: 1px solid var(--border-color);
        display: flex;
        flex-wrap: wrap;
        gap: 0.5rem;
        padding: 1rem;
    }

    .rbg-sidebar-title { display: none; }

    .map-btn {
        flex-direction: column;
        align-items: center;
        text-align: center;
        padding: 0.5rem;
        width: auto;
        min-width: 80px;
        border-left: none;
        border-bottom: 2px solid transparent;
        border-radius: var(--radius-sm);
    }

    .map-btn.active { border-bottom-color: var(--accent-color); }

    .map-btn-img { width: 36px; height: 36px; }
    .map-btn-name { font-size: 0.65rem; }
    .map-btn-status { display: none; }

    .rbg-content { padding: 1rem; }
    .rbg-header { padding: 0.7rem 1rem; }
    .rbg-header-nav { gap: 0.75rem; }
    .comp-grid { grid-template-columns: 1fr 1fr; }
    .tracker-stats-grid { grid-template-columns: repeat(3, 1fr) !important; }
    .tracker-panels { grid-template-columns: 1fr !important; }
    .tracker-addon-banner { flex-direction: column; text-align: center; }
}

/* ══════════════════════════════════════════════════════════════
   RBG Tracker Dashboard
   ══════════════════════════════════════════════════════════════ */
.rbg-tracker-section {
    max-width: 1200px;
    margin: 2.5rem auto 3rem;
    padding: 0 1.5rem;
}

.tracker-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1.2rem;
}
.tracker-header h2 {
    font-family: 'Sport Break', sans-serif;
    font-size: 1.4rem;
    color: var(--accent-color);
    letter-spacing: 1px;
    display: flex;
    align-items: center;
}
.tracker-badge {
    background: rgba(34,197,94,0.15);
    color: #22c55e;
    font-size: 0.65rem;
    font-weight: 700;
    padding: 0.25rem 0.7rem;
    border-radius: 20px;
    border: 1px solid rgba(34,197,94,0.3);
    letter-spacing: 1px;
    animation: pulse-badge 2s ease-in-out infinite;
}
@keyframes pulse-badge {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.6; }
}

/* ── Addon Download Banner ── */
.tracker-addon-banner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: linear-gradient(135deg, rgba(196,30,58,0.12), rgba(10,10,18,0.9));
    border: 1px solid rgba(196,30,58,0.4);
    border-radius: var(--radius-lg);
    padding: 1rem 1.2rem;
    margin-bottom: 1.2rem;
    gap: 1rem;
}
.addon-info {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}
.addon-icon { font-size: 1.6rem; }
.addon-info strong { color: #FFD700; font-size: 0.9rem; display: block; }
.addon-version {
    display: inline-block;
    background: rgba(196,30,58,0.35);
    color: #fff;
    font-size: 0.62rem;
    padding: 1px 5px;
    border-radius: 4px;
    margin-left: 6px;
}
.addon-desc { color: var(--text-muted); font-size: 0.78rem; }
.addon-download-btn {
    background: linear-gradient(135deg, #C41E3A, #8B0000);
    color: #FFD700;
    font-weight: bold;
    padding: 0.6rem 1.2rem;
    border-radius: 6px;
    text-decoration: none;
    white-space: nowrap;
    transition: all 0.2s;
    border: 1px solid rgba(255,215,0,0.25);
    font-size: 0.82rem;
}
.addon-download-btn:hover {
    background: linear-gradient(135deg, #E5253E, #C41E3A);
    transform: translateY(-1px);
    box-shadow: 0 4px 16px rgba(196,30,58,0.4);
}

/* ── Stats Grid ── */
.tracker-stats-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 0.75rem;
    margin-bottom: 1.2rem;
}
.tracker-stat-card {
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    padding: 1rem;
    text-align: center;
}
.tracker-stat-card.win { border-color: rgba(34,197,94,0.25); }
.tracker-stat-card.loss { border-color: rgba(239,68,68,0.25); }
.stat-label {
    font-size: 0.68rem;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 0.3rem;
}
.stat-value {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--text-color);
    font-family: 'Sport Break', sans-serif;
}
.tracker-stat-card.win .stat-value { color: #22c55e; }
.tracker-stat-card.loss .stat-value { color: #ef4444; }

/* ── Panels ── */
.tracker-panels {
    display: grid;
    grid-template-columns: 1.5fr 1fr;
    gap: 1rem;
}
.tracker-panel {
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    overflow: hidden;
}
.tracker-panel h3 {
    padding: 0.7rem 1rem;
    font-size: 0.8rem;
    font-weight: 700;
    color: var(--accent-color);
    background: var(--bg-tertiary);
    border-bottom: 1px solid var(--border-color);
    margin: 0;
}

/* ── Match History Table ── */
.tracker-table-wrap { overflow-x: auto; }
.tracker-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.75rem;
}
.tracker-table th {
    padding: 0.5rem 0.6rem;
    text-align: left;
    font-weight: 600;
    color: var(--text-muted);
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    border-bottom: 1px solid var(--border-color);
}
.tracker-table td {
    padding: 0.45rem 0.6rem;
    color: var(--text-color);
    border-bottom: 1px solid rgba(255,255,255,0.03);
}
.tracker-table tr:hover td { background: rgba(255,255,255,0.02); }

/* ── Top Players ── */
.top-players-list { padding: 0.5rem; }
.top-player-row {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.4rem 0.5rem;
    border-radius: var(--radius-sm);
    font-size: 0.72rem;
}
.top-player-row:nth-child(odd) { background: rgba(255,255,255,0.02); }
.top-rank {
    color: var(--accent-color);
    font-weight: 700;
    min-width: 28px;
    font-size: 0.7rem;
}
.top-name {
    font-weight: 600;
    color: var(--text-color);
    min-width: 80px;
    flex: 1;
}
.top-stat {
    color: var(--text-muted);
    font-size: 0.65rem;
    min-width: 55px;
}

/* ── Map Stats ── */
.map-stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 0.6rem;
    padding: 0.75rem;
}
.map-stat-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem;
    border-radius: var(--radius-sm);
    background: rgba(255,255,255,0.02);
}
.map-stat-name {
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--text-color);
    min-width: 90px;
}
.map-stat-bar {
    flex: 1;
    height: 6px;
    background: rgba(255,255,255,0.06);
    border-radius: 3px;
    overflow: hidden;
}
.map-stat-fill {
    height: 100%;
    border-radius: 3px;
    transition: width 0.4s ease;
}
.map-stat-wr {
    font-size: 0.68rem;
    color: var(--text-muted);
    min-width: 75px;
    text-align: right;
}
.map-stat-wr small { color: var(--text-muted); font-size: 0.6rem; }
