/* ============================================
   ERA RAID - UI Panel Styles
   Boss frame, party frame, action bar, meters, etc.
   ============================================ */

/* ============================================
   SHARED PANEL STYLES
   ============================================ */

.game-panel {
    background: var(--bg-panel);
    border: 1px solid var(--border-dark);
    border-radius: var(--radius-lg);
    backdrop-filter: blur(10px);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.4);
}

.panel-title {
    font-size: var(--font-sm);
    font-weight: 600;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 1px;
    padding: var(--spacing-sm) var(--spacing-md);
    border-bottom: 1px solid var(--border-dark);
}

/* ============================================
   BOSS FRAME - Split Layout (Top/Bottom)
   ============================================ */

/* ============================================
   COMPACT STATS BAR - Level, Block, Timers
   ============================================ */
.combat-stats-bar {
    position: fixed;
    top: calc(var(--header-height) + var(--spacing-sm));
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-md);
    padding: 8px 16px;
    background: linear-gradient(180deg, rgba(0, 0, 0, 0.9) 0%, rgba(0, 0, 0, 0.75) 100%);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 50px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.6);
    z-index: var(--z-panels);
    backdrop-filter: blur(10px);
}

/* Status message (Connecting, Countdown) */
.stats-status {
    font-size: 12px;
    font-weight: 600;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 1px;
}

.stats-status.queuing { color: var(--accent-gold); }
.stats-status.combat { display: none; }
.stats-status.countdown { color: var(--accent-cyan); }

/* Individual stat items */
.stats-item {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 4px 10px;
    background: rgba(255, 255, 255, 0.05);
    border-radius: 20px;
    border: 1px solid rgba(255, 255, 255, 0.08);
}

/* Boss Level */
.stats-level {
    gap: 4px;
}

.stats-level .stats-icon {
    font-size: 14px;
}

.stats-level .stats-value {
    font-size: 14px;
    font-weight: 700;
    color: var(--accent-gold);
}

.stats-level .stats-divider {
    font-size: 12px;
    color: var(--text-muted);
}

.stats-level .stats-max {
    font-size: 12px;
    color: var(--text-muted);
}

.stats-level .stats-best {
    font-size: 10px;
    color: var(--accent-cyan);
    margin-left: 6px;
    padding-left: 6px;
    border-left: 1px solid rgba(255, 255, 255, 0.15);
}

/* Block Timer Mini */
.stats-block {
    gap: 8px;
    padding: 4px 12px;
}

.block-mini-circle {
    position: relative;
    width: 28px;
    height: 28px;
}

.block-mini-svg {
    width: 28px;
    height: 28px;
    transform: rotate(-90deg);
}

.block-mini-bg {
    fill: none;
    stroke: rgba(255, 255, 255, 0.1);
    stroke-width: 3;
}

.block-mini-progress {
    fill: none;
    stroke: var(--accent-cyan);
    stroke-width: 3;
    stroke-linecap: round;
    stroke-dasharray: 94.25; /* 2 * PI * 15 */
    stroke-dashoffset: 0;
    transition: stroke-dashoffset 0.1s linear;
}

.block-mini-text {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 10px;
    font-weight: 700;
    color: #fff;
}

.block-mini-info {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
    line-height: 1.1;
}

.block-mini-label {
    font-size: 9px;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.block-mini-number {
    font-size: 12px;
    font-weight: 600;
    color: #fff;
}

.block-mini-proc {
    font-size: 11px;
    font-weight: 600;
    color: var(--accent-gold);
    padding: 2px 6px;
    background: rgba(255, 215, 0, 0.15);
    border-radius: 10px;
}

/* Timers (Enrage, Next Boss) */
.stats-timer {
    gap: 6px;
}

.stats-timer .stats-icon {
    font-size: 14px;
}

.stats-timer .timer-icon {
    animation: pulse-icon 1s ease-in-out infinite;
}

@keyframes pulse-icon {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.6; }
}

.stats-timer-value {
    font-size: 16px;
    font-weight: 700;
    color: #fff;
    min-width: 24px;
    text-align: center;
}

.stats-timer-label {
    font-size: 10px;
    color: var(--text-muted);
    text-transform: uppercase;
}

/* Enrage state */
.stats-timer.enraged {
    background: rgba(255, 50, 50, 0.2);
    border-color: rgba(255, 50, 50, 0.4);
}

.stats-timer.enraged .stats-timer-value {
    color: var(--accent-red);
}

/* Legacy support */
.boss-frame-top {
    display: none;
}

/* Bottom section: Boss abilities - positioned below sprite */
.boss-frame-bottom {
    position: fixed;
    bottom: 180px;
    left: 50%;
    transform: translateX(-50%);
    padding: var(--spacing-sm) var(--spacing-md);
    background: linear-gradient(0deg, rgba(0, 0, 0, 0.85) 0%, rgba(0, 0, 0, 0.7) 100%);
    border: 1px solid var(--border-dark);
    border-radius: var(--radius-md);
    box-shadow: 0 -2px 16px rgba(0, 0, 0, 0.5);
    z-index: var(--z-panels);
    backdrop-filter: blur(8px);
}

/* Legacy class support */
.boss-frame {
    position: fixed;
    top: calc(var(--header-height) + var(--spacing-lg));
    left: 50%;
    transform: translateX(-50%);
    width: 420px;
    max-width: calc(100% - 32px);
    padding: var(--spacing-md);
    background: var(--bg-panel);
    border: 1px solid var(--border-dark);
    border-radius: var(--radius-lg);
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.5);
    z-index: var(--z-panels);
    text-align: center;
}

.boss-frame.solo-boss {
    width: 500px;
    padding: var(--spacing-lg);
}

.boss-status {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-sm);
    font-size: var(--font-xs);
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 1px;
}

.boss-status.queuing { color: var(--accent-gold); }
.boss-status.combat { color: var(--accent-green); }
.boss-status.victory { color: var(--accent-gold); }
.boss-status.defeat { color: var(--accent-red); }

.boss-level {
    font-size: var(--font-sm);
    font-weight: 600;
    color: var(--accent-gold);
    text-align: center;
    margin-bottom: var(--spacing-xs);
    padding: 4px 12px;
    background: linear-gradient(135deg, rgba(255, 215, 0, 0.15) 0%, rgba(255, 165, 0, 0.1) 100%);
    border: 1px solid rgba(255, 215, 0, 0.3);
    border-radius: 4px;
    display: inline-block;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.5);
    letter-spacing: 0.5px;
}

.boss-name {
    font-size: var(--font-lg);
    font-weight: 700;
    color: var(--accent-red);
    text-align: center;
    margin-bottom: var(--spacing-xs);
}

.boss-tier {
    font-size: var(--font-xs);
    color: var(--text-muted);
    text-align: center;
    margin-bottom: var(--spacing-md);
}

/* Boss Stats */
.boss-stats {
    display: flex;
    justify-content: center;
    gap: var(--spacing-md);
    flex-wrap: wrap;
    margin-bottom: var(--spacing-md);
    padding: var(--spacing-sm) var(--spacing-md);
    background: rgba(0, 0, 0, 0.3);
    border-radius: var(--radius-sm);
}

.boss-stats.hidden {
    display: none;
}

.boss-stat {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    font-size: var(--font-xs);
    color: var(--text-secondary);
}

.boss-stat .stat-icon {
    font-size: var(--font-sm);
}

.boss-stat .stat-label {
    color: var(--text-muted);
}

.boss-stat .stat-value {
    color: var(--accent-cyan);
    font-weight: 600;
}

/* Health Bar */
.health-bar {
    position: relative;
    height: 24px;
    background: var(--bg-primary);
    border-radius: var(--radius-md);
    overflow: hidden;
    border: 1px solid var(--border-dark);
}

.health-bar.large {
    height: 32px;
}

.health-bar-fill {
    position: absolute;
    top: 2px;
    left: 2px;
    bottom: 2px;
    background: linear-gradient(180deg, #ff5555 0%, #cc3333 100%);
    border-radius: var(--radius-sm);
    transition: width 0.3s ease;
}

.health-bar-fill.low {
    background: linear-gradient(180deg, #ffcc00 0%, #cc9900 100%);
}

.health-bar-fill.critical {
    background: linear-gradient(180deg, #ff3333 0%, #990000 100%);
    animation: pulse-critical 1s infinite;
}

.health-bar-fill.player {
    background: linear-gradient(180deg, #55ff55 0%, #33cc33 100%);
}

@keyframes pulse-critical {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.7; }
}

.health-bar-text {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: var(--font-sm);
    font-weight: 600;
    color: var(--text-primary);
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.8);
    white-space: nowrap;
}

/* Boss Abilities */
.boss-abilities {
    display: flex;
    justify-content: center;
    gap: var(--spacing-sm);
    margin-top: var(--spacing-lg);
}

.boss-ability {
    width: 36px;
    height: 36px;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-dark);
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--font-md);
    font-weight: 600;
    color: var(--text-primary);
    cursor: pointer;
    transition: all var(--transition-fast);
    position: relative;
}

.boss-ability:hover {
    border-color: var(--accent-orange);
    transform: scale(1.1);
}

.boss-ability.damage { background: rgba(255, 75, 75, 0.3); }
.boss-ability.aoe { background: rgba(255, 135, 0, 0.3); }
.boss-ability.heal { background: rgba(75, 255, 75, 0.3); }
.boss-ability.buff { background: rgba(75, 159, 255, 0.3); }

.boss-ability.on-cooldown {
    opacity: 0.5;
}

.boss-ability-cooldown {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.7);
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    font-weight: 700;
    color: #fff;
}

/* Enrage Timer */
.enrage-timer {
    margin-top: var(--spacing-md);
    text-align: center;
    font-size: var(--font-sm);
    color: var(--accent-orange);
}

.enrage-timer.warning {
    color: var(--accent-red);
    font-weight: 600;
    animation: pulse 1s infinite;
}

.enrage-timer.countdown {
    color: #64c8ff;
    font-weight: 700;
    font-size: var(--font-lg);
    background: rgba(100, 200, 255, 0.15);
    border: 1px solid rgba(100, 200, 255, 0.3);
    border-radius: var(--radius-md);
    padding: var(--spacing-sm);
    animation: countdown-flash 1s ease-in-out infinite;
}

@keyframes countdown-flash {
    0%, 100% { opacity: 1; transform: scale(1); }
    50% { opacity: 0.8; transform: scale(1.02); }
}

@keyframes pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.6; }
}

/* ============================================
   PLAYER HUD
   ============================================ */

.player-hud {
    position: fixed;
    bottom: calc(var(--spacing-lg) + 28px + 200px + var(--spacing-md)); /* Above XP bar + combat log + gap */
    left: var(--spacing-lg);
    width: 240px;
    padding: var(--spacing-md);
    background: var(--bg-panel);
    border: 2px solid var(--border-dark);
    border-radius: var(--radius-lg);
    z-index: var(--z-panels);
}

.player-hud.tank { border-color: var(--class-tank); }
.player-hud.melee { border-color: var(--class-melee); }
.player-hud.ranged { border-color: var(--class-ranged); }
.player-hud.healer { border-color: var(--class-healer); }

.player-info {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-sm);
}

.player-avatar {
    width: 48px;
    height: 48px;
    background: var(--bg-tertiary);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
}

.player-details {
    flex: 1;
}

.player-name {
    font-size: var(--font-md);
    font-weight: 600;
    color: var(--text-primary);
}

.player-class {
    font-size: var(--font-xs);
    color: var(--text-muted);
}

.player-level {
    font-size: var(--font-xs);
    color: var(--accent-gold);
    font-weight: 600;
}

.player-health {
    height: 20px;
}

.player-health .health-bar-fill {
    background: linear-gradient(180deg, #55ff55 0%, #33cc33 100%);
}

/* Single Player Status */
.sp-player-status {
    position: fixed;
    left: var(--spacing-lg);
    bottom: 110px;
    width: 220px;
    padding: var(--spacing-md);
    background: var(--bg-panel);
    border: 2px solid var(--border-dark);
    border-radius: var(--radius-lg);
    z-index: var(--z-panels);
}

.sp-player-status.tank { border-color: var(--class-tank); }
.sp-player-status.melee { border-color: var(--class-melee); }
.sp-player-status.ranged { border-color: var(--class-ranged); }
.sp-player-status.healer { border-color: var(--class-healer); }

.sp-player-status .player-info {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-sm);
}

.sp-player-status .player-avatar {
    width: 48px;
    height: 48px;
    min-width: 48px;
    background: var(--bg-tertiary);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
}

.sp-player-status .player-details {
    flex: 1;
    min-width: 0;
}

.sp-player-status .player-name {
    font-size: var(--font-md);
    font-weight: 600;
    color: var(--text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.sp-player-status .player-level {
    font-size: var(--font-sm);
    color: var(--accent-gold);
    font-weight: 600;
}

.sp-player-status .health-bar {
    height: 20px;
}

.sp-player-status .health-bar .health-bar-fill {
    background: linear-gradient(180deg, #55ff55 0%, #33cc33 100%);
}

/* ============================================
   ACTION BAR
   ============================================ */

.action-bar {
    position: fixed;
    bottom: var(--spacing-lg);
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: var(--spacing-sm);
    padding: var(--spacing-md);
    background: var(--bg-panel);
    border: 1px solid var(--border-dark);
    border-radius: var(--radius-lg);
    box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.4);
    z-index: var(--z-panels);
}

.ability-button {
    position: relative;
    width: 64px;
    height: 64px;
    background: linear-gradient(180deg, var(--bg-tertiary) 0%, var(--bg-secondary) 100%);
    border: 2px solid var(--border-dark);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all var(--transition-fast);
    overflow: hidden;
}

.ability-button:hover:not(.on-cooldown) {
    border-color: var(--accent-orange);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(255, 139, 75, 0.3);
}

.ability-button:active:not(.on-cooldown):not(.disabled) {
    transform: translateY(0);
}

.ability-button.on-cooldown {
    opacity: 0.6;
    cursor: not-allowed;
}

/* Disabled action bar (loading / session ended) */
.action-bar.disabled {
    opacity: 0.5;
    pointer-events: none;
}

.action-bar.disabled .ability-button {
    cursor: not-allowed;
    filter: grayscale(50%);
}

.ability-button.disabled {
    opacity: 0.4;
    cursor: not-allowed;
    pointer-events: none;
    filter: grayscale(50%);
}

.ability-icon {
    width: 100%;
    height: calc(100% - 18px);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    color: var(--text-primary);
}

.ability-icon.potion-icon {
    color: var(--accent-green);
    height: 100%;
}

.ability-name {
    position: absolute;
    bottom: 2px;
    left: 2px;
    right: 2px;
    font-size: 8px;
    font-weight: 600;
    color: var(--text-secondary);
    text-align: center;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    background: rgba(0, 0, 0, 0.6);
    padding: 1px 2px;
    border-radius: 2px;
}

.cooldown-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.75);
    display: flex;
    align-items: center;
    justify-content: center;
}

.cooldown-overlay.hidden {
    display: none;
}

.cooldown-text {
    font-size: var(--font-xl);
    font-weight: 700;
    color: var(--text-primary);
}

.keybind-label {
    position: absolute;
    bottom: 2px;
    right: 4px;
    font-size: 9px;
    color: var(--text-muted);
    background: rgba(0, 0, 0, 0.6);
    padding: 1px 4px;
    border-radius: var(--radius-sm);
}

/* Potion Button */
.potion-btn {
    border-color: var(--accent-green);
}

.potion-btn:hover:not(.on-cooldown) {
    border-color: var(--accent-green);
    box-shadow: 0 4px 12px rgba(75, 255, 75, 0.3);
}

/* ============================================
   PARTY FRAME
   ============================================ */

.party-frame {
    position: fixed;
    top: calc(var(--header-height) + 200px);
    left: var(--spacing-lg);
    width: 220px;
    max-height: 400px;
    background: var(--bg-panel);
    border: 1px solid var(--border-dark);
    border-radius: var(--radius-lg);
    overflow: hidden;
    z-index: var(--z-panels);
}

.party-title {
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--font-sm);
    font-weight: 600;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 1px;
    border-bottom: 1px solid var(--border-dark);
}

/* Raid Requirements */
.raid-requirements {
    padding: var(--spacing-sm);
    background: var(--bg-tertiary);
    border-bottom: 1px solid var(--border-dark);
}

.raid-requirements.hidden {
    display: none;
}

.raid-requirements .requirement {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: 4px 0;
    font-size: var(--font-xs);
}

.raid-requirements .req-icon {
    width: 20px;
    text-align: center;
}

.raid-requirements .req-text {
    flex: 1;
    color: var(--text-secondary);
}

.raid-requirements .req-count {
    font-weight: 600;
    color: var(--text-primary);
}

.raid-requirements .req-status {
    width: 18px;
    height: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    font-size: 10px;
    font-weight: 700;
}

.raid-requirements .req-status.pending {
    background: rgba(255, 100, 100, 0.2);
    color: #ff6464;
}

.raid-requirements .req-status.met {
    background: rgba(100, 255, 100, 0.2);
    color: #64ff64;
}

/* Raid Start Countdown */
.raid-countdown {
    margin-top: var(--spacing-sm);
    padding: var(--spacing-sm);
    background: linear-gradient(135deg, rgba(100, 200, 255, 0.2), rgba(100, 150, 255, 0.1));
    border: 1px solid rgba(100, 200, 255, 0.4);
    border-radius: var(--radius-md);
    text-align: center;
    animation: countdown-pulse 1s ease-in-out infinite;
}

.raid-countdown.hidden {
    display: none;
}

@keyframes countdown-pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.7; }
}

.raid-countdown .countdown-label {
    display: block;
    font-size: var(--font-xs);
    color: var(--text-muted);
    margin-bottom: 2px;
}

.raid-countdown .countdown-time {
    display: block;
    font-size: var(--font-xl);
    font-weight: 700;
    color: #64c8ff;
}

.party-list {
    max-height: 350px;
    overflow-y: auto;
    padding: var(--spacing-sm);
}

.party-member {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm);
    margin-bottom: var(--spacing-xs);
    background: var(--bg-secondary);
    border-radius: var(--radius-sm);
    transition: background var(--transition-fast);
    cursor: pointer;
}

.party-member:hover {
    background: var(--bg-tertiary);
}

.party-member.dead {
    opacity: 0.5;
}

.party-member.targeted {
    border-left: 3px solid var(--accent-red);
}

.party-member.self {
    border-left: 3px solid var(--accent-gold);
}

.member-class {
    width: 28px;
    height: 28px;
    min-width: 28px;
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 700;
    color: white;
    flex-shrink: 0;
}

.member-class.tank { background: var(--class-tank); }
.member-class.melee { background: var(--class-melee); }
.member-class.ranged { background: var(--class-ranged); }
.member-class.healer { background: var(--class-healer); }

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

.member-name {
    font-size: var(--font-sm);
    color: var(--text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.member-level {
    font-size: var(--font-xs);
    color: var(--accent-gold);
}

.member-health-bar {
    height: 20px;
    background: var(--bg-primary);
    border-radius: 4px;
    overflow: hidden;
    margin-top: var(--spacing-xs);
    position: relative;
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.member-health-text {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 12px;
    font-weight: 700;
    color: #ffffff;
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.9), 0 0 4px rgba(0, 0, 0, 0.5);
    white-space: nowrap;
    z-index: 1;
    letter-spacing: 0.5px;
}

.member-health-fill {
    height: 100%;
    background: var(--accent-green);
    transition: width 0.3s ease;
}

.member-health-fill.medium { background: var(--accent-gold); }
.member-health-fill.low { background: var(--accent-red); }

/* Dead marker */
.member-dead-marker {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: var(--font-lg);
    color: var(--accent-red);
    font-weight: 700;
}

/* ============================================
   COMBAT METERS
   ============================================ */

.meters-panel {
    position: fixed;
    top: calc(var(--header-height) + 200px);
    right: var(--spacing-lg);
    width: 260px;
    background: var(--bg-panel);
    border: 1px solid var(--border-dark);
    border-radius: var(--radius-lg);
    overflow: hidden;
    z-index: var(--z-panels);
}

.meters-title {
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--font-sm);
    font-weight: 600;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 1px;
    border-bottom: 1px solid var(--border-dark);
}

.meters-tabs {
    display: flex;
    border-bottom: 1px solid var(--border-dark);
}

.meter-tab {
    flex: 1;
    padding: var(--spacing-sm);
    font-size: var(--font-xs);
    font-weight: 600;
    color: var(--text-muted);
    text-align: center;
    cursor: pointer;
    border: none;
    background: none;
    transition: all var(--transition-fast);
}

.meter-tab:hover {
    color: var(--text-primary);
    background: var(--bg-tertiary);
}

.meter-tab.active {
    color: var(--text-primary);
    background: var(--bg-tertiary);
}

.meter-tab.active.damage { border-bottom: 2px solid var(--accent-red); }
.meter-tab.active.healing { border-bottom: 2px solid var(--accent-green); }
.meter-tab.active.taken { border-bottom: 2px solid var(--accent-orange); }

.meter-entries {
    max-height: 280px;
    overflow-y: auto;
    padding: var(--spacing-sm);
}

.meter-entry {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-xs) 0;
    position: relative;
}

.meter-rank {
    width: 20px;
    font-size: var(--font-xs);
    color: var(--text-muted);
    text-align: right;
}

.meter-bar-container {
    flex: 1;
    height: 22px;
    background: var(--bg-primary);
    border-radius: var(--radius-sm);
    overflow: hidden;
    position: relative;
}

.meter-bar-fill {
    height: 100%;
    border-radius: var(--radius-sm);
    opacity: 0.7;
    transition: width var(--transition-fast);
}

.meter-bar-fill.damage { background: var(--accent-red); }
.meter-bar-fill.healing { background: var(--accent-green); }
.meter-bar-fill.taken { background: var(--accent-orange); }

.meter-name {
    position: absolute;
    left: var(--spacing-sm);
    top: 50%;
    transform: translateY(-50%);
    font-size: var(--font-sm);
    color: #fff;
    text-shadow: 1px 1px 2px rgba(0,0,0,0.9), -1px -1px 2px rgba(0,0,0,0.9);
    font-weight: 600;
}

.meter-value {
    position: absolute;
    right: var(--spacing-sm);
    top: 50%;
    transform: translateY(-50%);
    font-size: var(--font-sm);
    font-weight: 700;
    color: #fff;
    text-shadow: 1px 1px 2px rgba(0,0,0,0.9), -1px -1px 2px rgba(0,0,0,0.9);
}

/* ============================================
   COMBAT LOG
   ============================================ */

.combat-log {
    position: fixed;
    bottom: calc(var(--spacing-lg) + 28px); /* Above XP bar */
    right: var(--spacing-lg);
    width: 320px;
    height: 180px;
    background: var(--bg-panel);
    border: 1px solid var(--border-dark);
    border-radius: var(--radius-lg);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    z-index: var(--z-panels);
}

/* Raid view combat log positioned differently */
#view-raid .combat-log {
    bottom: calc(100px + 28px); /* Above action bar + XP bar */
    right: var(--spacing-lg);
    left: auto;
}

.combat-log-header {
    display: flex;
    flex-direction: column;
    flex-shrink: 0;
}

.combat-log-title {
    padding: var(--spacing-xs) var(--spacing-md);
    font-size: var(--font-xs);
    font-weight: 600;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 1px;
    border-bottom: 1px solid var(--border-dark);
}

.combat-log-tabs {
    display: flex;
    border-bottom: 1px solid var(--border-dark);
}

.combat-log-tab {
    flex: 1;
    padding: var(--spacing-xs) var(--spacing-sm);
    font-size: 9px;
    font-weight: 600;
    color: var(--text-muted);
    text-align: center;
    cursor: pointer;
    border: none;
    background: none;
    transition: all var(--transition-fast);
}

.combat-log-tab:hover {
    color: var(--text-primary);
    background: var(--bg-tertiary);
}

.combat-log-tab.active {
    color: var(--text-primary);
    background: var(--bg-tertiary);
    border-bottom: 2px solid var(--accent-blue);
}

.combat-log-entries {
    flex: 1;
    overflow-y: auto;
    padding: var(--spacing-xs) var(--spacing-sm);
    font-family: 'Consolas', 'Monaco', monospace;
    font-size: 11px;
    line-height: 1.4;
}

.log-entry {
    padding: 2px 0;
}

.log-entry .timestamp {
    color: var(--text-muted);
    margin-right: var(--spacing-xs);
}

.log-entry.damage .source { color: var(--accent-red); }
.log-entry.damage .amount { color: var(--accent-red); font-weight: 600; }
.log-entry.damage .target { color: var(--text-secondary); }
.log-entry.damage .ability { color: var(--accent-orange); }

.log-entry.healing .source { color: var(--accent-green); }
.log-entry.healing .amount { color: var(--accent-green); font-weight: 600; }
.log-entry.healing .target { color: var(--text-secondary); }

.log-entry.system {
    color: var(--accent-gold);
    font-style: italic;
}

.log-entry.boss-attack .source { color: var(--accent-red); font-weight: 600; }
.log-entry.boss-attack .ability { color: var(--accent-orange); }

/* ============================================
   TOP MENU BUTTONS
   ============================================ */

.top-menu {
    position: fixed;
    top: calc(var(--header-height) + var(--spacing-lg));
    right: var(--spacing-lg);
    display: flex;
    gap: var(--spacing-sm);
    z-index: var(--z-panels);
}

.menu-btn {
    width: 40px;
    height: 40px;
    background: var(--bg-panel);
    border: 1px solid var(--border-dark);
    border-radius: var(--radius-md);
    color: var(--text-secondary);
    font-size: var(--font-md);
    cursor: pointer;
    transition: all var(--transition-fast);
    display: flex;
    align-items: center;
    justify-content: center;
}

.menu-btn:hover {
    background: var(--bg-tertiary);
    border-color: var(--border-light);
    color: var(--text-primary);
}

.menu-btn.active {
    border-color: var(--accent-orange);
    color: var(--accent-orange);
}

/* Auto-play button in action bar */
.ability-button.auto-play-btn {
    background: var(--bg-tertiary);
    border-color: var(--accent-blue);
}

.ability-button.auto-play-btn .auto-icon {
    color: var(--accent-blue);
    font-size: 1.5rem;
}

.ability-button.auto-play-btn:hover {
    border-color: var(--accent-green);
    box-shadow: 0 0 10px rgba(0, 255, 100, 0.3);
}

/* Auto-play button active state (both versions) */
.menu-btn.auto-play-btn.active,
.ability-button.auto-play-btn.active {
    background: linear-gradient(135deg, #00aa55 0%, #00ff88 100%);
    border-color: var(--accent-green);
    box-shadow: 0 0 15px rgba(0, 255, 100, 0.6);
    animation: auto-play-pulse 1.5s ease-in-out infinite;
}

.ability-button.auto-play-btn.active .auto-icon {
    color: #fff;
    text-shadow: 0 0 8px rgba(255, 255, 255, 0.8);
}

@keyframes auto-play-pulse {
    0%, 100% { box-shadow: 0 0 10px rgba(0, 255, 100, 0.5); }
    50% { box-shadow: 0 0 20px rgba(0, 255, 100, 0.8); }
}

.menu-btn.muted i::before {
    content: '\f6a9'; /* fa-volume-mute */
}

.menu-btn.effects-off {
    opacity: 0.5;
}

/* Mobile Toggle Buttons */
.mobile-toggles {
    display: none;
    position: fixed;
    top: calc(var(--header-height) + var(--spacing-lg));
    left: var(--spacing-lg);
    gap: var(--spacing-sm);
    z-index: var(--z-panels);
}

.toggle-btn {
    width: 36px;
    height: 36px;
    background: var(--bg-panel);
    border: 1px solid var(--border-dark);
    border-radius: var(--radius-md);
    color: var(--text-secondary);
    font-size: var(--font-sm);
    cursor: pointer;
    transition: all var(--transition-fast);
    display: flex;
    align-items: center;
    justify-content: center;
}

.toggle-btn.active {
    border-color: var(--accent-orange);
    color: var(--accent-orange);
}

/* ============================================
   TOOLTIPS
   ============================================ */

.tooltip,
.game-tooltip {
    position: fixed;
    z-index: 9999;
    padding: var(--spacing-md);
    background: var(--bg-panel);
    border: 1px solid var(--border-light);
    border-radius: var(--radius-md);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.5);
    max-width: 280px;
    pointer-events: none;
}

.tooltip.hidden,
.game-tooltip.hidden {
    display: none;
}

/* Tooltip Content Structure */
.tooltip-content {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.tooltip-header {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.tooltip-icon {
    font-size: var(--font-lg);
}

.tooltip-name {
    font-size: var(--font-md);
    font-weight: 600;
    color: var(--text-primary);
}

.tooltip-meta {
    display: flex;
    gap: var(--spacing-sm);
    font-size: var(--font-xs);
    color: var(--text-muted);
}

.tooltip-description {
    font-size: var(--font-sm);
    color: var(--text-secondary);
    line-height: 1.4;
}

.tooltip-stats .stat-row {
    display: flex;
    justify-content: space-between;
    gap: var(--spacing-md);
    font-size: var(--font-xs);
}

.tooltip-stats .stat-label {
    color: var(--text-muted);
}

.tooltip-stats .stat-value {
    color: var(--text-primary);
    font-weight: 600;
}

.tooltip-stats .stat-value.damage {
    color: var(--accent-red);
}

.tooltip-stats .stat-value.healing {
    color: var(--accent-green);
}

.tooltip-keybind {
    font-size: var(--font-xs);
    color: var(--accent-yellow);
    text-align: center;
    padding-top: var(--spacing-xs);
    border-top: 1px solid var(--border-dark);
}

/* Ability Tooltip Specific */
.ability-tooltip .ability-type {
    color: var(--accent-cyan);
}

.ability-tooltip .ability-cost {
    color: var(--accent-blue);
}

.tooltip-title {
    font-size: var(--font-md);
    font-weight: 600;
    color: var(--accent-blue);
    margin-bottom: var(--spacing-xs);
}

.tooltip-desc {
    font-size: var(--font-sm);
    color: var(--text-secondary);
    line-height: 1.4;
}

.tooltip-cooldown {
    margin-top: var(--spacing-sm);
    font-size: var(--font-xs);
    color: var(--accent-orange);
}

.tooltip-stats {
    margin-top: var(--spacing-sm);
    font-size: var(--font-xs);
    color: var(--text-muted);
}

/* ============================================
   GAME MODALS / OVERLAYS
   ============================================ */

.game-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.85);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: var(--z-modal);
}

.game-overlay.hidden {
    display: none;
}

.result-modal {
    background: var(--bg-panel);
    border: 2px solid var(--border-light);
    border-radius: var(--radius-lg);
    padding: var(--spacing-xxl);
    text-align: center;
    max-width: 500px;
    width: 90%;
}

.result-title {
    font-size: 48px;
    font-weight: 700;
    margin-bottom: var(--spacing-md);
}

.result-title.victory { color: var(--accent-gold); }
.result-title.defeat { color: var(--accent-red); }

.result-subtitle {
    font-size: var(--font-lg);
    color: var(--text-secondary);
    margin-bottom: var(--spacing-xl);
}

.modal-body {
    margin-bottom: var(--spacing-xl);
}

.modal-buttons {
    display: flex;
    gap: var(--spacing-md);
    justify-content: center;
}

/* Loot Display */
.loot-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    margin: var(--spacing-lg) 0;
}

.loot-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--bg-secondary);
    border-radius: var(--radius-md);
}

.loot-icon {
    font-size: var(--font-xl);
}

.loot-name {
    flex: 1;
    text-align: left;
}

.loot-name.common { color: var(--rarity-common); }
.loot-name.uncommon { color: var(--rarity-uncommon); }
.loot-name.rare { color: var(--rarity-rare); }
.loot-name.epic { color: var(--rarity-epic); }
.loot-name.legendary { color: var(--rarity-legendary); }

/* Rewards Display */
.rewards-display {
    display: flex;
    justify-content: center;
    gap: var(--spacing-xl);
    margin-bottom: var(--spacing-lg);
}

.reward-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-xs);
}

.reward-icon {
    font-size: 2rem;
}

.reward-value {
    font-size: var(--font-lg);
    font-weight: 600;
}

.reward-value.xp { color: var(--accent-blue); }
.reward-value.gold { color: var(--accent-gold); }

/* ============================================
   BLOCK TIMER (Casper Network Mechanic)
   ============================================ */

.block-timer-panel {
    position: fixed;
    top: calc(var(--header-height) + 140px);
    left: var(--spacing-lg);
    width: 120px;
    padding: var(--spacing-md);
    background: var(--bg-panel);
    border: 1px solid var(--border-dark);
    border-radius: var(--radius-lg);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.4);
    z-index: var(--z-panels);
    text-align: center;
}

.block-timer-title {
    font-size: var(--font-sm);
    font-weight: 600;
    color: #ff0040;
    margin-bottom: var(--spacing-xs);
}

.block-timer-number {
    font-size: var(--font-md);
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: var(--spacing-sm);
}

.block-timer-circle {
    position: relative;
    width: 80px;
    height: 80px;
    margin: 0 auto var(--spacing-sm);
}

.block-timer-svg {
    width: 100%;
    height: 100%;
    transform: rotate(-90deg);
}

.block-timer-bg {
    fill: none;
    stroke: var(--bg-tertiary);
    stroke-width: 8;
}

.block-timer-progress {
    fill: none;
    stroke: #ff0040;
    stroke-width: 8;
    stroke-linecap: round;
    stroke-dasharray: 251.2;
    stroke-dashoffset: 0;
    transition: stroke-dashoffset 0.1s linear;
}

.block-timer-text {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: var(--font-xl);
    font-weight: 700;
    color: #ff0040;
}

.block-timer-proc {
    font-size: var(--font-xs);
    color: var(--text-muted);
    margin-bottom: var(--spacing-xs);
}

.block-timer-result {
    font-size: var(--font-sm);
    font-weight: 600;
    min-height: 20px;
}

.block-timer-result.miss { color: var(--accent-green); }
.block-timer-result.proc { color: #ff0040; font-weight: 700; }
.block-timer-result.heal { color: #00ff44; }
.block-timer-result.damage { color: #ff0000; }
.block-timer-result.defense { color: #4499ff; }

/* Inline Block Timer (inside boss frame) */
.block-timer-inline {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    margin-top: var(--spacing-md);
    padding: var(--spacing-sm) var(--spacing-md);
    background: rgba(255, 0, 64, 0.1);
    border: 1px solid rgba(255, 0, 64, 0.3);
    border-radius: var(--radius-md);
}

.block-timer-inline .block-timer-circle {
    width: 50px;
    height: 50px;
    margin: 0;
    flex-shrink: 0;
}

.block-timer-inline .block-timer-text {
    font-size: var(--font-md);
}

.block-timer-inline .block-timer-info {
    flex: 1;
    min-width: 0;
}

.block-timer-inline .block-timer-title {
    font-size: var(--font-sm);
    font-weight: 600;
    color: #ff0040;
    margin-bottom: 2px;
}

.block-timer-inline .block-timer-title span {
    color: var(--text-primary);
    font-weight: 700;
}

.block-timer-inline .block-timer-proc {
    font-size: var(--font-xs);
    color: var(--text-muted);
    margin: 0;
}

.block-timer-inline .block-timer-result {
    font-size: var(--font-sm);
    font-weight: 600;
    text-align: right;
    min-width: 80px;
}

/* Combat Log Panel (unified) */
.combat-log-panel {
    position: fixed;
    bottom: calc(var(--spacing-lg) + 28px); /* Above XP bar */
    left: var(--spacing-lg);
    width: 320px;
    height: 200px;
    background: var(--bg-panel);
    border: 1px solid var(--border-dark);
    border-radius: var(--radius-lg);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.4);
    z-index: var(--z-panels);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

/* Hide combat log on mobile (< 768px) */
@media screen and (max-width: 768px) {
    .combat-log-panel,
    .combat-log,
    .sp-combat-log,
    #combat-log-panel {
        display: none !important;
        visibility: hidden !important;
        width: 0 !important;
        height: 0 !important;
        opacity: 0 !important;
    }
}

/* ============================================
   SINGLE PLAYER COMBAT LOG
   ============================================ */

.sp-combat-log {
    position: fixed;
    bottom: 120px;
    right: var(--spacing-lg);
    width: 320px;
    height: 280px;
    background: var(--bg-panel);
    border: 1px solid var(--border-dark);
    border-radius: var(--radius-lg);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.4);
    z-index: var(--z-panels);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.combat-log-header {
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--bg-tertiary);
    border-bottom: 1px solid var(--border-dark);
}

.combat-log-title {
    font-size: var(--font-sm);
    font-weight: 600;
    color: var(--accent-blue);
}

.combat-log-entries {
    flex: 1;
    overflow-y: auto;
    padding: var(--spacing-sm);
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.combat-log-entry {
    font-size: var(--font-xs);
    padding: 3px 6px;
    border-radius: var(--radius-sm);
    line-height: 1.3;
    animation: log-entry-fade-in 0.2s ease-out;
}

@keyframes log-entry-fade-in {
    from { opacity: 0; transform: translateX(-10px); }
    to { opacity: 1; transform: translateX(0); }
}

.combat-log-entry.damage { color: #ff6b6b; }
.combat-log-entry.heal { color: #4bff4b; }
.combat-log-entry.boss { color: #ff8b4b; }
.combat-log-entry.system { color: #b8b8c8; }
.combat-log-entry.victory { color: #ffd700; }
.combat-log-entry.defeat { color: #ff4444; }
.combat-log-entry.ability { color: #4b9fff; }

.combat-log-entry .log-time {
    color: var(--text-muted);
    font-size: 0.9em;
    margin-right: 4px;
}

/* ============================================
   BOSS ABILITIES DISPLAY
   ============================================ */

/* In bottom frame - no border/margin needed */
.boss-frame-bottom .boss-abilities {
    display: flex;
    justify-content: center;
    gap: var(--spacing-md);
    margin: 0;
    padding: 0;
    border: none;
}

.boss-abilities {
    display: flex;
    justify-content: center;
    gap: var(--spacing-sm);
    margin-top: var(--spacing-sm);
    padding-top: var(--spacing-sm);
    border-top: 1px solid var(--border-dark);
}

/* Boss Timers Container */
.boss-timers {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-md);
    margin-top: var(--spacing-sm);
}

/* Boss Health Bar specific styles */
.boss-health-bar {
    margin: var(--spacing-xs) 0;
}

.boss-ability {
    position: relative;
    width: 40px;
    height: 40px;
    background: var(--bg-tertiary);
    border: 2px solid var(--accent-red);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    cursor: help;
    transition: all var(--transition-fast);
}

.boss-ability:hover {
    transform: scale(1.1);
    box-shadow: 0 0 10px rgba(255, 75, 75, 0.5);
}

.boss-ability.on-cooldown {
    opacity: 0.5;
    border-color: var(--border-dark);
}

.boss-ability-cooldown {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.7);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--font-sm);
    font-weight: 700;
    color: #fff;
    border-radius: var(--radius-md);
}

/* Boss Ability Tooltip */
.boss-ability-tooltip {
    position: fixed;
    z-index: 10000;
    background: linear-gradient(135deg, rgba(20, 20, 28, 0.98), rgba(30, 30, 40, 0.98));
    border: 2px solid var(--accent-red);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md);
    min-width: 200px;
    max-width: 280px;
    transform: translateX(-50%);
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.15s ease, visibility 0.15s ease;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.6), 0 0 20px rgba(255, 75, 75, 0.2);
    pointer-events: none;
}

.boss-ability-tooltip.visible {
    opacity: 1;
    visibility: visible;
}

.boss-ability-tooltip .tooltip-header {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: var(--font-md);
    font-weight: 700;
    margin-bottom: var(--spacing-sm);
    padding-bottom: var(--spacing-sm);
    border-bottom: 1px solid var(--border-dark);
}

.boss-ability-tooltip .tooltip-icon {
    font-size: 1.4em;
}

.boss-ability-tooltip .tooltip-name {
    flex: 1;
}

.boss-ability-tooltip .tooltip-desc {
    font-size: var(--font-sm);
    color: var(--text-secondary);
    line-height: 1.4;
    margin-bottom: var(--spacing-sm);
}

.boss-ability-tooltip .tooltip-stats {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-sm);
    font-size: var(--font-xs);
}

.boss-ability-tooltip .tooltip-stat {
    background: rgba(255, 255, 255, 0.05);
    padding: 3px 8px;
    border-radius: var(--radius-sm);
    color: var(--text-muted);
}

/* ============================================
   FLOATING DAMAGE NUMBERS
   ============================================ */

.damage-numbers-container {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    pointer-events: none;
    z-index: 1000;
    overflow: hidden;
}

.damage-number {
    position: absolute;
    font-weight: 700;
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.8);
    pointer-events: none;
    animation: damage-float 1.2s ease-out forwards;
}

.damage-number.player-damage {
    color: #ff6b6b;
    font-size: 28px;
}

.damage-number.player-damage.crit {
    color: #ffff00;
    font-size: 36px;
}

.damage-number.boss-damage {
    color: #ff8888;
    font-size: 24px;
}

.damage-number.boss-damage.special {
    color: #ff4444;
    font-size: 30px;
}

.damage-number.heal {
    color: #4bff4b;
    font-size: 26px;
}

/* Fallback damage class */
.damage-number.damage {
    color: #ff6b6b;
    font-size: 28px;
}

/* Standalone crit class (when crit is the type) */
.damage-number.crit {
    color: #ffff00;
    font-size: 36px;
    text-shadow: 0 0 10px #ffcc00, 2px 2px 4px rgba(0, 0, 0, 0.8);
}

@keyframes damage-float {
    0% {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
    20% {
        transform: translateY(-20px) scale(1.1);
    }
    100% {
        opacity: 0;
        transform: translateY(-60px) scale(0.8);
    }
}

/* Enrage timer styling */
.enrage-timer {
    font-size: var(--font-sm);
    color: var(--accent-orange);
    text-align: center;
    margin-top: var(--spacing-sm);
    padding: var(--spacing-xs) var(--spacing-sm);
    background: rgba(255, 100, 50, 0.1);
    border-radius: var(--radius-sm);
}

.enrage-timer.warning {
    color: #ff4444;
    background: rgba(255, 50, 50, 0.2);
    animation: enrage-pulse 0.5s ease-in-out infinite alternate;
}

@keyframes enrage-pulse {
    from { opacity: 0.7; }
    to { opacity: 1; }
}

/* ============================================
   ITEM TOOLTIP
   ============================================ */

.item-tooltip {
    position: fixed;
    z-index: 10000;
    min-width: 220px;
    max-width: 300px;
    background: linear-gradient(135deg, rgba(20, 20, 28, 0.98), rgba(30, 30, 40, 0.98));
    border: 2px solid var(--border-light);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.6);
    opacity: 0;
    transform: scale(0.95);
    transition: opacity 0.15s ease, transform 0.15s ease;
    pointer-events: auto;
}

.item-tooltip.visible {
    opacity: 1;
    transform: scale(1);
}

.item-header {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-sm);
    padding-bottom: var(--spacing-sm);
    border-bottom: 1px solid var(--border-dark);
}

.item-icon-large {
    font-size: 2rem;
    line-height: 1;
}

.item-title {
    flex: 1;
}

.item-name {
    font-size: var(--font-md);
    font-weight: 600;
}

.item-type {
    font-size: var(--font-xs);
    opacity: 0.7;
}

.item-level {
    font-size: var(--font-xs);
    color: var(--accent-orange);
    margin-bottom: var(--spacing-xs);
}

.item-level.level-not-met {
    color: #ef4444;
    font-weight: 600;
    padding: 4px 8px;
    background: rgba(239, 68, 68, 0.15);
    border: 1px solid rgba(239, 68, 68, 0.3);
    border-radius: var(--radius-sm);
}

.item-desc {
    font-size: var(--font-xs);
    color: var(--text-muted);
    font-style: italic;
    margin-bottom: var(--spacing-sm);
}

.item-props {
    margin-bottom: var(--spacing-sm);
    padding: var(--spacing-sm);
    background: rgba(0, 0, 0, 0.3);
    border-radius: var(--radius-sm);
}

.item-prop {
    font-size: var(--font-sm);
    color: #4bff4b;
    padding: 2px 0;
}

.item-prop .stat-better {
    color: #00ff00;
    font-weight: 600;
}

.item-prop .stat-worse {
    color: #ff4444;
    font-weight: 600;
}

.item-prop.stat-worse {
    color: #ff4444;
}

/* Roll Quality Display - Shows how good the roll is vs max possible */
.item-prop-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 3px 0;
    gap: 8px;
}

.item-prop-main {
    display: flex;
    align-items: center;
    gap: 4px;
    flex: 1;
    min-width: 0;
}

.prop-value {
    color: #4bff4b;
    font-weight: 600;
    font-size: var(--font-sm);
}

.prop-name {
    color: #cccccc;
    font-size: var(--font-sm);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.prop-roll {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 10px;
    font-family: monospace;
    opacity: 0.9;
    flex-shrink: 0;
}

.roll-bar {
    letter-spacing: -1px;
    font-size: 9px;
}

.roll-max {
    color: #888888;
    font-size: 9px;
}

/* Roll quality colors - visual feedback on roll quality */
.roll-poor .roll-bar {
    color: #ff4444;
}
.roll-poor .roll-max {
    color: #ff4444;
    opacity: 0.7;
}

.roll-avg .roll-bar {
    color: #ffaa00;
}
.roll-avg .roll-max {
    color: #ffaa00;
    opacity: 0.7;
}

.roll-good .roll-bar {
    color: #44ff44;
}
.roll-good .roll-max {
    color: #44ff44;
    opacity: 0.7;
}

.roll-perfect .roll-bar {
    color: #ffd700;
    text-shadow: 0 0 4px #ffd700;
}
.roll-perfect .roll-max {
    color: #ffd700;
    opacity: 0.9;
}

/* Roll Quality Progress Bar (Visual Upgrade) */
.prop-roll-indicator {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-shrink: 0;
}

.roll-track {
    width: 48px;
    height: 6px;
    background: rgba(0, 0, 0, 0.4);
    border-radius: 3px;
    overflow: hidden;
    position: relative;
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.roll-fill {
    height: 100%;
    border-radius: 2px;
    transition: width 0.3s ease;
    position: relative;
}

.roll-percent {
    font-size: 0.65rem;
    font-weight: 600;
    min-width: 28px;
    text-align: right;
    font-family: monospace;
}

/* Roll quality colors - Poor (0-24%) */
.roll-poor .roll-fill {
    background: linear-gradient(90deg, #dc2626, #ef4444);
    box-shadow: 0 0 4px rgba(239, 68, 68, 0.5);
}
.roll-poor .roll-percent {
    color: #ef4444;
}

/* Roll quality colors - Average (25-49%) */
.roll-avg .roll-fill {
    background: linear-gradient(90deg, #d97706, #f59e0b);
    box-shadow: 0 0 4px rgba(245, 158, 11, 0.5);
}
.roll-avg .roll-percent {
    color: #f59e0b;
}

/* Roll quality colors - Good (50-74%) */
.roll-good .roll-fill {
    background: linear-gradient(90deg, #059669, #10b981);
    box-shadow: 0 0 4px rgba(16, 185, 129, 0.5);
}
.roll-good .roll-percent {
    color: #10b981;
}

/* Roll quality colors - Perfect (75-100%) */
.roll-perfect .roll-fill {
    background: linear-gradient(90deg, #eab308, #fbbf24, #fde047);
    box-shadow: 0 0 6px rgba(251, 191, 36, 0.7);
    animation: perfectRollGlow 1.5s ease-in-out infinite alternate;
}
.roll-perfect .roll-percent {
    color: #fbbf24;
    text-shadow: 0 0 4px rgba(251, 191, 36, 0.5);
}

@keyframes perfectRollGlow {
    from {
        box-shadow: 0 0 4px rgba(251, 191, 36, 0.5);
    }
    to {
        box-shadow: 0 0 8px rgba(251, 191, 36, 0.8);
    }
}

.item-comparison-header {
    font-size: var(--font-xs);
    color: var(--accent-cyan);
    text-align: center;
    padding: var(--spacing-xs) 0;
    margin-bottom: var(--spacing-xs);
    border-bottom: 1px dashed var(--border-dark);
    font-style: italic;
}

.item-quality {
    font-size: var(--font-xs);
    color: var(--text-muted);
    margin-bottom: var(--spacing-xs);
}

.item-sell {
    font-size: var(--font-xs);
    color: #ffd700;
    margin-bottom: var(--spacing-sm);
}

.item-actions {
    display: flex;
    gap: var(--spacing-sm);
    padding-top: var(--spacing-sm);
    border-top: 1px solid var(--border-dark);
}

.item-actions .btn {
    flex: 1;
    padding: var(--spacing-xs) var(--spacing-sm);
    font-size: var(--font-xs);
}

.item-actions .btn-sm {
    font-size: 0.75rem;
    padding: 4px 8px;
}

.item-actions .btn-danger {
    background: linear-gradient(135deg, #8b0000, #ff4444);
    border-color: #ff4444;
}

.item-actions .btn-warning {
    background: linear-gradient(135deg, #b8860b, #ffa500);
    border-color: #ffa500;
    color: #000;
}

.item-swap-info {
    font-size: var(--font-xs);
    color: var(--accent-orange);
    padding: var(--spacing-xs) 0;
    font-style: italic;
}

/* Empty inventory message */
.empty-inventory {
    grid-column: 1 / -1;
    text-align: center;
    color: var(--text-muted);
    font-size: var(--font-sm);
    padding: var(--spacing-lg);
}

/* ============================================
   MODAL SYSTEM
   Victory, Defeat, Loot, Confirmation modals
   ============================================ */

.modal-overlay,
#modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100vw;
    height: 100vh;
    background: rgba(0, 0, 0, 0.85);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9999;
    opacity: 0;
    transition: opacity 0.3s ease;
    backdrop-filter: blur(4px);
}

.modal-overlay.hidden,
#modal-overlay.hidden {
    display: none !important;
}

.modal-overlay.visible,
#modal-overlay.visible {
    display: flex !important;
    opacity: 1;
}

.modal-container,
#modal-container {
    position: relative;
    background: var(--bg-panel);
    border-radius: var(--radius-lg);
    border: 2px solid var(--border-dark);
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.6);
    max-width: 90vw;
    max-height: 90vh;
    overflow: auto;
    transform: scale(0.9);
    transition: transform 0.3s ease;
    margin: auto;
}

.modal-overlay.visible .modal-container,
#modal-overlay.visible #modal-container,
#modal-overlay.visible .modal-container {
    transform: scale(1);
}

.modal-content {
    padding: var(--spacing-xl);
    min-width: 300px;
}

.modal-header {
    text-align: center;
    margin-bottom: var(--spacing-lg);
}

.modal-title {
    font-size: var(--font-xl);
    font-weight: 700;
    margin: var(--spacing-sm) 0;
}

.modal-body {
    margin-bottom: var(--spacing-lg);
}

.modal-footer {
    display: flex;
    justify-content: center;
    gap: var(--spacing-md);
}

/* Victory Modal */
.victory-modal .modal-container {
    border-color: var(--accent-green);
    box-shadow: 0 0 40px rgba(75, 255, 75, 0.3);
}

.victory-icon {
    width: 80px;
    height: 80px;
    margin: 0 auto var(--spacing-md);
    background: linear-gradient(135deg, #ffd700, #ffaa00);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 48px;
    font-weight: bold;
    color: #000;
    box-shadow: 0 0 30px rgba(255, 215, 0, 0.5);
    animation: victory-pulse 1.5s ease-in-out infinite;
}

@keyframes victory-pulse {
    0%, 100% { transform: scale(1); box-shadow: 0 0 30px rgba(255, 215, 0, 0.5); }
    50% { transform: scale(1.1); box-shadow: 0 0 50px rgba(255, 215, 0, 0.8); }
}

.victory-content .modal-title {
    color: var(--accent-green);
    font-size: 2rem;
    text-shadow: 0 0 10px rgba(75, 255, 75, 0.5);
}

.victory-message {
    font-size: var(--font-lg);
    color: var(--text-primary);
    margin-bottom: var(--spacing-lg);
}

.rewards-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
    align-items: center;
    margin: var(--spacing-lg) 0;
}

.reward-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-sm) var(--spacing-lg);
    background: rgba(255, 255, 255, 0.05);
    border-radius: var(--radius-md);
    min-width: 200px;
    justify-content: center;
}

.reward-icon {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: bold;
    font-size: var(--font-sm);
}

.reward-icon.xp {
    background: linear-gradient(135deg, #9b59b6, #8e44ad);
    color: white;
}

.reward-icon.gold {
    background: linear-gradient(135deg, #ffd700, #ffaa00);
    color: #000;
}

.reward-value {
    font-size: var(--font-xl);
    font-weight: 700;
    color: var(--text-primary);
}

.item-drop {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-md);
    background: rgba(75, 159, 255, 0.1);
    border: 1px solid rgba(75, 159, 255, 0.3);
    border-radius: var(--radius-md);
    margin-top: var(--spacing-md);
}

.item-drop-icon {
    font-size: 2rem;
}

.item-drop-name {
    font-weight: 600;
    color: var(--accent-blue);
}

.level-up-notice {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-xs);
    padding: var(--spacing-md);
    background: linear-gradient(135deg, rgba(75, 255, 75, 0.2), rgba(75, 255, 75, 0.05));
    border: 2px solid var(--accent-green);
    border-radius: var(--radius-md);
    margin-top: var(--spacing-lg);
    animation: levelup-glow 1s ease-in-out infinite alternate;
}

@keyframes levelup-glow {
    from { box-shadow: 0 0 10px rgba(75, 255, 75, 0.3); }
    to { box-shadow: 0 0 25px rgba(75, 255, 75, 0.6); }
}

.level-up-text {
    font-size: var(--font-lg);
    font-weight: 700;
    color: var(--accent-green);
    text-transform: uppercase;
    letter-spacing: 2px;
}

.new-level {
    font-size: var(--font-xl);
    font-weight: 700;
    color: var(--text-primary);
}

/* Item Drop Card */
.item-drop-section {
    margin-top: var(--spacing-lg);
    padding-top: var(--spacing-lg);
    border-top: 1px solid var(--border-light);
}

.item-drop-header {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-md);
}

.item-drop-icon {
    font-size: 1.5rem;
}

.item-drop-label {
    font-size: var(--font-lg);
    font-weight: 600;
    color: var(--accent-gold);
}

.item-drop-card {
    background: rgba(0, 0, 0, 0.3);
    border-radius: var(--radius-md);
    padding: var(--spacing-md);
    border: 2px solid var(--border-dark);
}

/* Item rarity colors */
.item-drop-card.rarity-common { border-color: #9d9d9d; }
.item-drop-card.rarity-uncommon { border-color: #1eff00; }
.item-drop-card.rarity-rare { border-color: #0070dd; }
.item-drop-card.rarity-epic { border-color: #a335ee; }
.item-drop-card.rarity-legendary {
    border-color: #ff8000;
    box-shadow: 0 0 15px rgba(255, 128, 0, 0.4);
}

.item-name {
    font-size: var(--font-lg);
    font-weight: 700;
    margin-bottom: var(--spacing-xs);
}

.item-name.rarity-common { color: #9d9d9d; }
.item-name.rarity-uncommon { color: #1eff00; }
.item-name.rarity-rare { color: #0070dd; }
.item-name.rarity-epic { color: #a335ee; }
.item-name.rarity-legendary { color: #ff8000; }

.item-meta {
    display: flex;
    gap: var(--spacing-md);
    font-size: var(--font-sm);
    color: var(--text-muted);
    margin-bottom: var(--spacing-sm);
}

.item-rarity {
    font-weight: 600;
}

.item-rarity.rarity-common { color: #9d9d9d; }
.item-rarity.rarity-uncommon { color: #1eff00; }
.item-rarity.rarity-rare { color: #0070dd; }
.item-rarity.rarity-epic { color: #a335ee; }
.item-rarity.rarity-legendary { color: #ff8000; }

.item-slot {
    color: var(--text-secondary);
}

.item-level {
    color: var(--accent-gold);
}

.item-properties {
    margin: var(--spacing-sm) 0;
    padding: var(--spacing-sm);
    background: rgba(0, 0, 0, 0.2);
    border-radius: var(--radius-sm);
}

.item-property {
    display: flex;
    justify-content: space-between;
    padding: 2px 0;
    font-size: var(--font-sm);
}

.prop-name {
    color: var(--text-secondary);
}

.prop-value {
    color: var(--accent-green);
    font-weight: 600;
}

.no-props {
    color: var(--text-muted);
    font-style: italic;
    text-align: center;
}

.item-actions {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: var(--spacing-md);
    padding-top: var(--spacing-sm);
    border-top: 1px solid var(--border-dark);
}

.item-slot-indicator {
    font-size: var(--font-sm);
    color: var(--text-muted);
}

.item-slot-indicator.equipped {
    color: var(--accent-green);
    font-weight: 600;
}

.item-equip-btn {
    background: var(--accent-green);
    color: #000;
    font-weight: 600;
    padding: var(--spacing-xs) var(--spacing-md);
    border: none;
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: all 0.2s ease;
}

.item-equip-btn:hover {
    background: #5fff5f;
    transform: translateY(-1px);
}

.item-equip-btn:disabled {
    background: var(--bg-tertiary);
    color: var(--text-muted);
    cursor: not-allowed;
    transform: none;
}

.item-equip-btn.equipped {
    background: var(--accent-green);
    cursor: default;
}

/* CSPR Drop Section */
.cspr-drop-section {
    margin-top: var(--spacing-lg);
    padding: var(--spacing-md);
    background: linear-gradient(135deg, rgba(139, 92, 246, 0.2), rgba(59, 130, 246, 0.2));
    border: 2px solid #8b5cf6;
    border-radius: var(--radius-md);
    text-align: center;
    animation: cspr-glow 2s ease-in-out infinite;
}

@keyframes cspr-glow {
    0%, 100% { box-shadow: 0 0 10px rgba(139, 92, 246, 0.3); }
    50% { box-shadow: 0 0 25px rgba(139, 92, 246, 0.6); }
}

.cspr-drop-header {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-sm);
}

.cspr-drop-icon {
    font-size: 1.8rem;
    animation: cspr-spin 3s linear infinite;
}

@keyframes cspr-spin {
    0% { transform: rotate(0deg) scale(1); }
    50% { transform: rotate(180deg) scale(1.2); }
    100% { transform: rotate(360deg) scale(1); }
}

.cspr-drop-label {
    font-size: var(--font-lg);
    font-weight: 700;
    color: #8b5cf6;
    text-shadow: 0 0 10px rgba(139, 92, 246, 0.5);
}

.cspr-drop-amount {
    font-size: 1.5rem;
    font-weight: 800;
    color: #fff;
    text-shadow: 0 0 15px rgba(139, 92, 246, 0.8);
    margin: var(--spacing-sm) 0;
}

.cspr-pending-balance {
    display: flex;
    justify-content: center;
    gap: var(--spacing-sm);
    font-size: var(--font-sm);
    color: var(--text-secondary);
    margin-bottom: var(--spacing-sm);
}

.cspr-balance-value {
    color: #8b5cf6;
    font-weight: 600;
}

.cspr-claim-notice {
    font-size: var(--font-sm);
    color: var(--accent-green);
    font-weight: 600;
}

.cspr-claim-notice.cspr-claim-pending {
    color: var(--text-muted);
    font-weight: 400;
}

/* Defeat Modal */
.defeat-modal .modal-container {
    border-color: var(--accent-red);
    box-shadow: 0 0 40px rgba(255, 68, 68, 0.3);
}

.defeat-icon {
    width: 80px;
    height: 80px;
    margin: 0 auto var(--spacing-md);
    background: linear-gradient(135deg, #ff4444, #cc0000);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 48px;
    font-weight: bold;
    color: white;
    box-shadow: 0 0 30px rgba(255, 68, 68, 0.5);
}

.defeat-content .modal-title {
    color: var(--accent-red);
    font-size: 2rem;
    text-shadow: 0 0 10px rgba(255, 68, 68, 0.5);
}

.defeat-message {
    font-size: var(--font-lg);
    color: var(--text-secondary);
    margin-bottom: var(--spacing-sm);
}

.defeat-boss {
    font-size: var(--font-md);
    color: var(--text-muted);
    font-style: italic;
}

/* Loot Modal */
.loot-modal .modal-container {
    border-color: var(--accent-gold);
}

.loot-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    max-height: 300px;
    overflow-y: auto;
}

.loot-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-sm) var(--spacing-md);
    background: rgba(255, 255, 255, 0.05);
    border-radius: var(--radius-sm);
    border-left: 3px solid var(--text-muted);
}

.loot-item.rarity-common { border-left-color: #9d9d9d; }
.loot-item.rarity-uncommon { border-left-color: #1eff00; }
.loot-item.rarity-rare { border-left-color: #0070dd; }
.loot-item.rarity-epic { border-left-color: #a335ee; }
.loot-item.rarity-legendary { border-left-color: #ff8000; }

.loot-item-icon {
    font-size: 1.5rem;
}

.loot-item-name {
    font-weight: 600;
}

.loot-item-type {
    font-size: var(--font-xs);
    color: var(--text-muted);
}

.no-loot {
    text-align: center;
    color: var(--text-muted);
    padding: var(--spacing-lg);
}

/* Level Up Modal */
.levelup-modal .modal-container {
    border-color: var(--accent-gold);
    box-shadow: 0 0 50px rgba(255, 215, 0, 0.4);
    overflow: visible;
}

.levelup-glow {
    position: absolute;
    top: -50px;
    left: 50%;
    transform: translateX(-50%);
    width: 100px;
    height: 100px;
    background: radial-gradient(circle, rgba(255, 215, 0, 0.6) 0%, transparent 70%);
    animation: levelup-burst 1s ease-out;
}

@keyframes levelup-burst {
    from { transform: translateX(-50%) scale(0); opacity: 1; }
    to { transform: translateX(-50%) scale(3); opacity: 0; }
}

.new-level-display {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-xs);
    margin: var(--spacing-lg) 0;
}

.level-label {
    font-size: var(--font-sm);
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 2px;
}

.level-number {
    font-size: 4rem;
    font-weight: 700;
    color: var(--accent-gold);
    text-shadow: 0 0 20px rgba(255, 215, 0, 0.5);
}

.stats-gained {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
    margin-top: var(--spacing-md);
}

.stat-gain {
    display: flex;
    justify-content: space-between;
    padding: var(--spacing-xs) var(--spacing-md);
    background: rgba(75, 255, 75, 0.1);
    border-radius: var(--radius-sm);
}

.stat-gain .stat-name {
    color: var(--text-secondary);
}

.stat-gain .stat-value {
    color: var(--accent-green);
    font-weight: 600;
}

/* Confirm Modal */
.confirm-content .modal-title {
    color: var(--text-primary);
}

.confirm-message {
    font-size: var(--font-md);
    color: var(--text-secondary);
    text-align: center;
}

/* Auto-close countdown */
.modal-countdown {
    position: absolute;
    bottom: var(--spacing-sm);
    right: var(--spacing-sm);
    font-size: var(--font-xs);
    color: var(--text-muted);
}

/* Mobile responsive */
@media (max-width: 480px) {
    .modal-content {
        padding: var(--spacing-md);
        min-width: 250px;
    }

    .victory-icon,
    .defeat-icon {
        width: 60px;
        height: 60px;
        font-size: 32px;
    }

    .modal-title {
        font-size: var(--font-lg);
    }

    .reward-item {
        min-width: 160px;
    }

    .reward-value {
        font-size: var(--font-lg);
    }

    .level-number {
        font-size: 3rem;
    }
}

/* ============================================
   EXPERIENCE BAR (Full-width bottom bar)
   ============================================ */

.xp-bar-container {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    height: 28px;
    background: linear-gradient(180deg, rgba(20, 20, 28, 0.98) 0%, rgba(10, 10, 15, 0.98) 100%);
    border-top: 1px solid var(--border-dark);
    z-index: var(--z-panels);
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 0 var(--spacing-md);
}

.xp-bar-track {
    position: relative;
    height: 8px;
    background: var(--bg-primary);
    border-radius: 4px;
    overflow: hidden;
    box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.5);
}

.xp-bar-fill {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 0%;
    background: linear-gradient(90deg,
        #6b4bff 0%,
        #9b6bff 50%,
        #bb8bff 100%
    );
    border-radius: 4px;
    transition: width 0.5s ease-out;
    box-shadow: 0 0 8px rgba(155, 107, 255, 0.5);
}

.xp-bar-glow {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 0%;
    background: linear-gradient(90deg,
        transparent 0%,
        rgba(255, 255, 255, 0.3) 50%,
        transparent 100%
    );
    border-radius: 4px;
    animation: xp-shimmer 2s ease-in-out infinite;
    pointer-events: none;
}

@keyframes xp-shimmer {
    0% { transform: translateX(-100%); }
    100% { transform: translateX(200%); }
}

.xp-bar-info {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 2px;
    font-size: 10px;
    color: var(--text-muted);
}

.xp-level {
    font-weight: 700;
    color: var(--accent-gold);
    min-width: 80px;
}

.xp-text {
    flex: 1;
    text-align: center;
    color: #bb8bff;
    font-weight: 600;
}

.xp-percent {
    min-width: 50px;
    text-align: right;
    color: var(--text-muted);
}

/* XP bar gain animation */
.xp-bar-fill.gaining {
    animation: xp-pulse 0.5s ease-out;
}

@keyframes xp-pulse {
    0% { box-shadow: 0 0 8px rgba(155, 107, 255, 0.5); }
    50% { box-shadow: 0 0 20px rgba(155, 107, 255, 1), 0 0 30px rgba(255, 215, 0, 0.5); }
    100% { box-shadow: 0 0 8px rgba(155, 107, 255, 0.5); }
}

/* Level up flash effect */
.xp-bar-container.level-up {
    animation: xp-levelup 1s ease-out;
}

@keyframes xp-levelup {
    0% { background: linear-gradient(180deg, rgba(20, 20, 28, 0.98) 0%, rgba(10, 10, 15, 0.98) 100%); }
    25% { background: linear-gradient(180deg, rgba(107, 75, 255, 0.4) 0%, rgba(155, 107, 255, 0.3) 100%); }
    50% { background: linear-gradient(180deg, rgba(255, 215, 0, 0.3) 0%, rgba(255, 170, 0, 0.2) 100%); }
    100% { background: linear-gradient(180deg, rgba(20, 20, 28, 0.98) 0%, rgba(10, 10, 15, 0.98) 100%); }
}

/* Adjust action bar position to account for XP bar */
#view-singleplayer .action-bar,
#view-raid .action-bar {
    bottom: calc(var(--spacing-lg) + 28px);
}

/* Adjust player HUD for raid view */
#view-raid .player-hud {
    bottom: calc(100px + 28px); /* Above action bar + XP bar */
}

/* Adjust player status position */
#view-singleplayer .sp-player-status {
    bottom: calc(110px + 28px);
}

/* Mobile responsive */
@media (max-width: 768px) {
    .xp-bar-container {
        height: 24px;
        padding: 0 var(--spacing-sm);
    }

    .xp-bar-track {
        height: 6px;
    }

    .xp-bar-info {
        font-size: 9px;
    }

    .xp-level {
        min-width: 60px;
    }

    .xp-percent {
        min-width: 40px;
    }

    #view-singleplayer .action-bar {
        bottom: calc(var(--spacing-md) + 24px);
    }

    #view-singleplayer .sp-player-status {
        bottom: calc(100px + 24px);
    }
}

/* ============================================
   DEV TOOLS (Development Mode Only)
   ============================================ */

.dev-tools {
    position: fixed;
    bottom: var(--spacing-lg);
    right: var(--spacing-lg);
    background: linear-gradient(135deg, rgba(40, 20, 60, 0.95), rgba(60, 30, 80, 0.95));
    border: 2px solid #9b59b6;
    border-radius: var(--radius-lg);
    padding: var(--spacing-sm);
    z-index: var(--z-panels);
    min-width: 160px;
    box-shadow: 0 4px 20px rgba(155, 89, 182, 0.4);
}

.dev-tools.hidden {
    display: none;
}

.dev-tools-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-bottom: var(--spacing-sm);
    border-bottom: 1px solid rgba(155, 89, 182, 0.5);
    margin-bottom: var(--spacing-sm);
}

.dev-tools-title {
    font-size: var(--font-xs);
    font-weight: 700;
    color: #9b59b6;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.dev-tools-toggle {
    background: none;
    border: none;
    color: #9b59b6;
    cursor: pointer;
    font-size: var(--font-sm);
    padding: 2px 6px;
    transition: transform 0.2s ease;
}

.dev-tools-toggle.collapsed {
    transform: rotate(-90deg);
}

.dev-tools-content {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.dev-tools-content.collapsed {
    display: none;
}

.dev-btn {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-md);
    background: rgba(155, 89, 182, 0.2);
    border: 1px solid rgba(155, 89, 182, 0.5);
    border-radius: var(--radius-md);
    color: #e8daef;
    font-size: var(--font-xs);
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
}

.dev-btn:hover {
    background: rgba(155, 89, 182, 0.4);
    border-color: #9b59b6;
    transform: translateY(-1px);
}

.dev-btn:active {
    transform: translateY(0);
}

.dev-btn i {
    font-size: var(--font-md);
}

.add-ai-btn {
    background: rgba(46, 204, 113, 0.2);
    border-color: rgba(46, 204, 113, 0.5);
}

.add-ai-btn:hover {
    background: rgba(46, 204, 113, 0.4);
    border-color: #2ecc71;
}

.fill-party-btn {
    background: rgba(52, 152, 219, 0.2);
    border-color: rgba(52, 152, 219, 0.5);
}

.fill-party-btn:hover {
    background: rgba(52, 152, 219, 0.4);
    border-color: #3498db;
}

.reset-raid-btn {
    background: rgba(231, 76, 60, 0.2);
    border-color: rgba(231, 76, 60, 0.5);
}

.reset-raid-btn:hover {
    background: rgba(231, 76, 60, 0.4);
    border-color: #e74c3c;
}

/* (Transition overlay removed - using boss frame timer instead) */

/* ============================================
   GAME MODAL OVERLAY (Respec/Enhance)
   ============================================ */

.game-modal-overlay {
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: rgba(0, 0, 0, 0.85);
    backdrop-filter: blur(4px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-lg);
}

.game-modal {
    background: var(--bg-panel);
    border: 2px solid var(--border-light);
    border-radius: var(--radius-lg);
    max-width: 400px;
    width: 100%;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.6);
    animation: modal-appear 0.2s ease-out;
}

@keyframes modal-appear {
    from {
        opacity: 0;
        transform: scale(0.95);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

.game-modal .modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-md) var(--spacing-lg);
    border-bottom: 1px solid var(--border-dark);
}

.game-modal .modal-header h3 {
    font-size: var(--font-lg);
    font-weight: 600;
    color: var(--text-primary);
    margin: 0;
}

.game-modal .modal-close {
    background: none;
    border: none;
    color: var(--text-muted);
    font-size: 1.5rem;
    cursor: pointer;
    padding: 0;
    line-height: 1;
    transition: color 0.2s ease;
}

.game-modal .modal-close:hover {
    color: var(--accent-red);
}

.game-modal .modal-body {
    padding: var(--spacing-lg);
}

/* Respec Modal */
.respec-modal .modal-header {
    background: linear-gradient(135deg, rgba(251, 191, 36, 0.1), rgba(217, 119, 6, 0.05));
    border-bottom: 1px solid rgba(251, 191, 36, 0.3);
}

.respec-modal .modal-header h3 {
    color: var(--accent-gold);
}

.respec-stat-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-sm) 0;
    border-bottom: 1px solid var(--border-dark);
}

.respec-stat-row:last-of-type {
    border-bottom: none;
}

.respec-stat-row .stat-label {
    font-size: var(--font-md);
    color: var(--text-primary);
    font-weight: 500;
}

.respec-controls {
    display: flex;
    gap: var(--spacing-sm);
}

.respec-divider {
    height: 1px;
    background: var(--border-dark);
    margin: var(--spacing-md) 0;
}

.respec-info {
    margin-top: var(--spacing-md);
    padding: var(--spacing-sm);
    background: rgba(0, 0, 0, 0.2);
    border-radius: var(--radius-sm);
    font-size: var(--font-sm);
    color: var(--text-muted);
}

.respec-info p {
    margin: var(--spacing-xs) 0;
}

/* ============================================
   INVENTORY HEADER & GOLD DISPLAY
   ============================================ */

.inventory-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-sm) var(--spacing-md);
    margin-bottom: var(--spacing-md);
    background: rgba(0, 0, 0, 0.3);
    border-radius: var(--radius-md);
    border: 1px solid var(--border-dark);
}

.inventory-title {
    font-size: var(--font-md);
    font-weight: 600;
    color: var(--text-primary);
    margin: 0;
}

.gold-display {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: var(--font-sm);
    font-weight: 600;
    color: #fbbf24;
    padding: 4px 12px;
    background: rgba(251, 191, 36, 0.1);
    border: 1px solid rgba(251, 191, 36, 0.3);
    border-radius: 20px;
}

.gold-display i {
    font-size: var(--font-md);
}

/* ============================================
   CONFIRMATION MODAL STYLES
   ============================================ */

.confirm-modal .modal-footer {
    display: flex;
    justify-content: flex-end;
    gap: var(--spacing-sm);
    padding: var(--spacing-md) var(--spacing-lg);
    border-top: 1px solid var(--border-dark);
    background: rgba(0, 0, 0, 0.2);
}

.confirm-danger .modal-header {
    background: linear-gradient(135deg, rgba(239, 68, 68, 0.1), rgba(185, 28, 28, 0.05));
    border-bottom: 1px solid rgba(239, 68, 68, 0.3);
}

.confirm-danger .modal-header h3 {
    color: #ef4444;
}

.confirm-warning .modal-header {
    background: linear-gradient(135deg, rgba(251, 191, 36, 0.1), rgba(217, 119, 6, 0.05));
    border-bottom: 1px solid rgba(251, 191, 36, 0.3);
}

.confirm-warning .modal-header h3 {
    color: #fbbf24;
}

.confirm-info .modal-header {
    background: linear-gradient(135deg, rgba(59, 130, 246, 0.1), rgba(37, 99, 235, 0.05));
    border-bottom: 1px solid rgba(59, 130, 246, 0.3);
}

.confirm-info .modal-header h3 {
    color: #3b82f6;
}

/* Results Modal */
.results-modal .modal-header {
    background: linear-gradient(135deg, rgba(16, 185, 129, 0.1), rgba(5, 150, 105, 0.05));
    border-bottom: 1px solid rgba(16, 185, 129, 0.3);
}

.results-modal .modal-header h3 {
    color: #10b981;
}

.results-modal .modal-footer {
    display: flex;
    justify-content: center;
    padding: var(--spacing-md) var(--spacing-lg);
    border-top: 1px solid var(--border-dark);
    background: rgba(0, 0, 0, 0.2);
}

/* Sell Confirm Content */
.sell-confirm-content p {
    margin: var(--spacing-sm) 0;
    font-size: var(--font-sm);
    color: var(--text-secondary);
}

.sell-confirm-content .sell-value {
    margin-top: var(--spacing-md);
    padding: var(--spacing-sm);
    background: rgba(0, 0, 0, 0.3);
    border-radius: var(--radius-sm);
}

.sell-confirm-content .gold-amount {
    color: #fbbf24;
    font-weight: 600;
}

/* Enhance Confirm Content */
.enhance-confirm-content p {
    margin: var(--spacing-sm) 0;
    font-size: var(--font-sm);
    color: var(--text-secondary);
}

.enhance-confirm-content .gold-cost {
    color: #fbbf24;
    font-weight: 600;
}

.enhance-confirm-content .enhance-warning {
    margin-top: var(--spacing-md);
    padding: var(--spacing-sm);
    background: rgba(251, 191, 36, 0.1);
    border: 1px solid rgba(251, 191, 36, 0.2);
    border-radius: var(--radius-sm);
    font-size: var(--font-xs);
    color: #f59e0b;
}

/* Enhance Results */
.enhance-results .enhance-cost {
    text-align: center;
    color: #fbbf24;
    font-weight: 600;
    margin-bottom: var(--spacing-md);
    padding-bottom: var(--spacing-sm);
    border-bottom: 1px solid var(--border-dark);
}

.enhance-results .enhance-changes {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.enhance-result-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 4px 8px;
    background: rgba(0, 0, 0, 0.2);
    border-radius: var(--radius-sm);
}

.enhance-result-row .prop-name {
    color: var(--text-secondary);
    font-size: var(--font-sm);
}

.enhance-result-row .stat-better {
    color: #10b981;
    font-weight: 600;
}

.enhance-result-row .stat-worse {
    color: #ef4444;
    font-weight: 600;
}

/* Respec Confirm Content */
.respec-confirm-content p {
    margin: var(--spacing-sm) 0;
    font-size: var(--font-sm);
    color: var(--text-secondary);
}

.respec-confirm-content .respec-cost {
    margin-top: var(--spacing-md);
    padding: var(--spacing-sm);
    background: rgba(0, 0, 0, 0.3);
    border-radius: var(--radius-sm);
    text-align: center;
}

.respec-confirm-content .gold-cost {
    color: #fbbf24;
    font-weight: 600;
}

/* ============================================
   NFT TAB STYLES
   ============================================ */

.nft-tab-container {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
    padding: var(--spacing-sm);
}

/* Wallet Panel */
.nft-wallet-panel {
    background: rgba(0, 0, 0, 0.3);
    border: 1px solid var(--border-dark);
    border-radius: var(--radius-md);
    padding: var(--spacing-md);
}

.nft-wallet-panel.connected {
    border-color: rgba(16, 185, 129, 0.3);
    background: rgba(16, 185, 129, 0.05);
}

.wallet-status {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

.wallet-icon {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.1);
    border-radius: var(--radius-md);
    font-size: 1.25rem;
    color: var(--text-muted);
}

.nft-wallet-panel.connected .wallet-icon {
    background: rgba(16, 185, 129, 0.2);
    color: #10b981;
}

.wallet-info {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.wallet-label {
    font-size: var(--font-xs);
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.wallet-address {
    font-size: var(--font-sm);
    font-weight: 600;
    color: var(--text-primary);
    font-family: monospace;
}

/* NFT Grid Container */
.nft-grid-container {
    flex: 1;
    display: flex;
    flex-direction: column;
}

.nft-grid-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--spacing-sm);
}

.nft-grid-title {
    font-size: var(--font-md);
    font-weight: 600;
    color: var(--text-primary);
    margin: 0;
}

/* NFT Grid */
.nft-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: var(--spacing-sm);
    min-height: 200px;
}

/* NFT Card */
.nft-card {
    background: rgba(0, 0, 0, 0.3);
    border-radius: var(--radius-md);
    overflow: hidden;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.nft-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

.nft-card-inner {
    position: relative;
    display: flex;
    flex-direction: column;
    border: 2px solid var(--border-dark);
    border-radius: var(--radius-md);
    overflow: hidden;
    padding: var(--spacing-sm);
    gap: var(--spacing-xs);
}

/* Rarity borders */
.nft-card-inner.common { border-color: #9d9d9d; }
.nft-card-inner.uncommon { border-color: #1eff00; }
.nft-card-inner.rare { border-color: #0070dd; }
.nft-card-inner.epic { border-color: #a335ee; }
.nft-card-inner.legendary { border-color: #ff8000; }

/* NFT Badge */
.nft-badge {
    position: absolute;
    top: 4px;
    right: 4px;
    background: linear-gradient(135deg, #7c3aed, #a855f7);
    color: #fff;
    font-size: 9px;
    font-weight: 700;
    padding: 2px 6px;
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* NFT Header */
.nft-header {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-sm);
}

.nft-icon {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(124, 58, 237, 0.2);
    border-radius: var(--radius-sm);
    color: #a855f7;
    font-size: var(--font-md);
}

.nft-title {
    flex: 1;
    min-width: 0;
}

.nft-name {
    font-size: var(--font-sm);
    font-weight: 600;
    color: var(--text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.nft-meta {
    font-size: 10px;
    color: var(--text-muted);
    display: flex;
    gap: 4px;
}

/* NFT Properties */
.nft-properties {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: var(--spacing-xs);
    background: rgba(0, 0, 0, 0.3);
    border-radius: var(--radius-sm);
}

.nft-property {
    font-size: 10px;
    color: #4bff4b;
}

/* NFT Details */
.nft-details {
    display: flex;
    flex-wrap: wrap;
    gap: 4px 8px;
    font-size: 10px;
    color: var(--text-muted);
}

.nft-detail {
    display: flex;
    align-items: center;
    gap: 2px;
}

.nft-rarity {
    font-size: 10px;
    font-weight: 600;
}

.nft-rarity.common { color: #9d9d9d; }
.nft-rarity.uncommon { color: #1eff00; }
.nft-rarity.rare { color: #0070dd; }
.nft-rarity.epic { color: #a335ee; }
.nft-rarity.legendary { color: #ff8000; }

.nft-token-id {
    font-size: 10px;
    color: var(--text-muted);
    font-family: monospace;
}

/* NFT Actions */
.nft-actions {
    display: flex;
    gap: var(--spacing-xs);
    margin-top: var(--spacing-xs);
}

.nft-actions .btn {
    flex: 1;
    font-size: 0.7rem;
    padding: 4px 8px;
}

.nft-actions .btn-secondary {
    flex: 0;
    padding: 4px 8px;
}

/* NFT Loading & Empty States */
.nft-loading,
.nft-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-xl);
    color: var(--text-muted);
    text-align: center;
    gap: var(--spacing-sm);
}

.nft-loading .loading-spinner {
    width: 32px;
    height: 32px;
    border: 3px solid rgba(255, 255, 255, 0.1);
    border-top-color: var(--accent-cyan);
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

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

.nft-empty .empty-icon {
    font-size: 3rem;
    opacity: 0.3;
}

.nft-empty .empty-hint {
    font-size: var(--font-xs);
    opacity: 0.7;
}

/* Purple Button for Mint NFT */
.btn-purple {
    background: linear-gradient(135deg, #7c3aed, #a855f7);
    border-color: #a855f7;
    color: #fff;
}

.btn-purple:hover {
    background: linear-gradient(135deg, #6d28d9, #9333ea);
    border-color: #9333ea;
}

/* Mint/Burn Confirm Content */
.mint-confirm-content p,
.burn-confirm-content p {
    margin: var(--spacing-sm) 0;
    font-size: var(--font-sm);
    color: var(--text-secondary);
}

.mint-confirm-content .mint-fee {
    margin-top: var(--spacing-md);
    padding: var(--spacing-sm);
    background: rgba(0, 0, 0, 0.3);
    border-radius: var(--radius-sm);
    text-align: center;
}

.mint-confirm-content .cspr-amount {
    color: #22d3ee;
    font-weight: 600;
}

.mint-confirm-content .mint-warning,
.burn-confirm-content .burn-warning {
    margin-top: var(--spacing-md);
    padding: var(--spacing-sm);
    background: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.2);
    border-radius: var(--radius-sm);
    font-size: var(--font-xs);
    color: #f87171;
}

/* ============================================
   MOBILE RESPONSIVE STYLES
   All mobile/tablet responsive styles are in game-responsive.css
   DO NOT add responsive styles here - they will conflict!
   ============================================ */
