/* HIGH-END DASHBOARD CSS - PREMIUM DESIGN */

/* Prevent horizontal scrolling on mobile */
html, body {
    max-width: 100vw !important;
    box-sizing: border-box !important;
}

/* Only hide horizontal overflow on mobile - Allow vertical overflow for dropdowns */
@media (max-width: 768px) {
    html, body {
        overflow-x: hidden !important;
        overflow-y: visible !important;
    }
}

*, *::before, *::after {
    box-sizing: border-box !important;
}

/* Dashboard Body */
.dashboard-body {
    background: linear-gradient(135deg, #0a0b0d 0%, #151618 50%, #1a1b1e 100%) !important;
    min-height: 100vh;
    color: var(--text-primary);
    max-width: 100vw !important;
    width: 100% !important;
}

/* Only hide horizontal overflow on mobile for dashboard body - Allow vertical overflow */
@media (max-width: 768px) {
    .dashboard-body {
        overflow-x: hidden !important;
        overflow-y: visible !important;
    }
}

/* Premium Header */
.dashboard-header {
    background: rgba(22, 23, 25, 0.95) !important;
    backdrop-filter: blur(20px) !important;
    border-bottom: 1px solid rgba(164, 28, 50, 0.2) !important;
    padding: 1rem 0 !important;
    position: sticky !important;
    top: 0 !important;
    z-index: 1000 !important;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3) !important;
    overflow: visible !important;
}

.dashboard-header .header-content {
    display: grid !important;
    grid-template-columns: auto 1fr auto auto !important;
    gap: 2rem !important;
    align-items: center !important;
    overflow: visible !important;
    position: relative !important;
}

.dashboard-header .logo {
    display: flex !important;
    align-items: center !important;
    gap: 1rem !important;
}

.logo-text h1 {
    font-size: 1.5rem !important;
    font-weight: 800 !important;
    background: var(--gradient-primary) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
    margin: 0 !important;
}

.season-badge {
    background: rgba(164, 28, 50, 0.2) !important;
    color: #a41c32 !important;
    padding: 0.25rem 0.75rem !important;
    border-radius: 12px !important;
    font-size: 0.75rem !important;
    font-weight: 600 !important;
    border: 1px solid rgba(164, 28, 50, 0.3) !important;
}

/* Header Stats */
.header-stats {
    display: flex !important;
    gap: 2rem !important;
    align-items: center !important;
}

.stat-item {
    text-align: center !important;
    padding: 0.75rem 1rem !important;
    background: rgba(255, 255, 255, 0.05) !important;
    border-radius: 12px !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    min-width: 80px !important;
    transition: all 0.3s ease !important;
}

.stat-item:hover {
    background: rgba(255, 255, 255, 0.1) !important;
    border-color: var(--primary-red) !important;
    transform: translateY(-2px) !important;
}

.stat-item.streak {
    background: rgba(255, 165, 0, 0.1) !important;
    border-color: rgba(255, 165, 0, 0.3) !important;
}

.stat-value {
    display: block !important;
    font-size: 1.5rem !important;
    font-weight: 800 !important;
    font-family: 'JetBrains Mono', monospace !important;
    color: var(--text-primary) !important;
}

.stat-label {
    display: block !important;
    font-size: 0.75rem !important;
    color: var(--text-secondary) !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
}

/* Dashboard Navigation */
.dashboard-nav {
    display: flex !important;
    gap: 0.4rem !important;
    background: rgba(255, 255, 255, 0.05) !important;
    padding: 0.5rem !important;
    border-radius: 16px !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
}

.nav-item {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    padding: 0.75rem 0.8rem !important;
    border-radius: 12px !important;
    text-decoration: none !important;
    color: var(--text-secondary) !important;
    transition: all 0.3s ease !important;
    min-width: 65px !important;
    flex: 1 !important;
}

.nav-item:hover {
    background: rgba(255, 255, 255, 0.1) !important;
    color: var(--text-primary) !important;
    transform: translateY(-2px) !important;
}

.nav-item.active {
    background: var(--gradient-primary) !important;
    color: var(--text-primary) !important;
    box-shadow: 0 4px 12px rgba(164, 28, 50, 0.3) !important;
}

.nav-item.logout:hover {
    background: rgba(239, 68, 68, 0.2) !important;
    border-color: #ef4444 !important;
}

.nav-icon {
    font-size: 1.2rem !important;
    margin-bottom: 0.25rem !important;
}

.nav-text {
    font-size: 0.75rem !important;
    font-weight: 600 !important;
}

/* User Profile */
.user-profile {
    display: flex !important;
    align-items: center !important;
    gap: 1rem !important;
    padding: 0.75rem 1rem !important;
    background: rgba(255, 255, 255, 0.05) !important;
    border-radius: 16px !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    position: relative !important;
    z-index: 1100 !important;
    overflow: visible !important;
}

.user-profile:hover {
    background: rgba(255, 255, 255, 0.1) !important;
    transform: translateY(-2px) !important;
}

.user-avatar {
    width: 40px !important;
    height: 40px !important;
    border-radius: 50% !important;
    background: var(--gradient-primary) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-weight: 800 !important;
    font-size: 0.9rem !important;
    color: white !important;
    box-shadow: 0 4px 12px rgba(164, 28, 50, 0.3) !important;
}

.user-info {
    display: flex !important;
    flex-direction: column !important;
}

.user-name {
    font-weight: 700 !important;
    color: var(--text-primary) !important;
}

.user-status {
    font-size: 0.75rem !important;
    color: #10b981 !important;
    font-weight: 600 !important;
}

/* Main Dashboard */
.dashboard-main {
    padding: 2rem 0 !important;
}

/* Welcome Section */
.welcome-section {
    margin-bottom: 3rem !important;
}

.welcome-card {
    background: rgba(255, 255, 255, 0.05) !important;
    backdrop-filter: blur(20px) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 24px !important;
    padding: 2.5rem !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    position: relative !important;
    overflow: hidden !important;
}

.welcome-card::before {
    content: '' !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: var(--gradient-glass) !important;
    opacity: 0.3 !important;
    pointer-events: none !important;
}

.welcome-content h2 {
    font-size: 2rem !important;
    font-weight: 800 !important;
    margin-bottom: 0.75rem !important;
    background: var(--gradient-primary) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
}

.welcome-content p {
    color: var(--text-secondary) !important;
    font-size: 1.1rem !important;
}

.welcome-stats {
    display: flex !important;
    gap: 2rem !important;
    position: relative !important;
    z-index: 2 !important;
}

.quick-stat {
    text-align: center !important;
    padding: 1rem 1.5rem !important;
    background: rgba(255, 255, 255, 0.1) !important;
    border-radius: 16px !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
}

.stat-number {
    display: block !important;
    font-size: 2rem !important;
    font-weight: 800 !important;
    font-family: 'JetBrains Mono', monospace !important;
    color: var(--text-primary) !important;
}

.stat-text {
    display: block !important;
    font-size: 0.85rem !important;
    color: var(--text-secondary) !important;
    font-weight: 600 !important;
    margin-top: 0.25rem !important;
}

/* Dashboard Grid */
.dashboard-grid {
    display: grid !important;
    grid-template-columns: 1.5fr 1fr !important;
    gap: 4rem !important;
    align-items: start !important;
}

/* Section Headers */
.section-header {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin-bottom: 2rem !important;
}

.section-header h3 {
    font-size: 1.4rem !important;
    font-weight: 700 !important;
    color: var(--text-primary) !important;
}

.section-actions {
    display: flex !important;
    gap: 1rem !important;
}

.action-btn {
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    padding: 0.75rem 1rem !important;
    background: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 12px !important;
    color: var(--text-secondary) !important;
    text-decoration: none !important;
    font-size: 0.9rem !important;
    font-weight: 600 !important;
    transition: all 0.3s ease !important;
    cursor: pointer !important;
}

.action-btn:hover {
    background: rgba(255, 255, 255, 0.1) !important;
    border-color: var(--primary-red) !important;
    color: var(--text-primary) !important;
    transform: translateY(-2px) !important;
}

.view-all-link {
    color: var(--primary-red) !important;
    text-decoration: none !important;
    font-weight: 600 !important;
    font-size: 0.9rem !important;
    transition: all 0.3s ease !important;
}

.view-all-link:hover {
    color: var(--primary-red-light) !important;
    text-decoration: underline !important;
}

/* Premium Game Cards */
.games-grid.premium {
    display: grid !important;
    gap: 1.5rem !important;
}

.premium-game-card {
    background: rgba(255, 255, 255, 0.05) !important;
    backdrop-filter: blur(20px) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 20px !important;
    padding: 2rem !important;
    position: relative !important;
    overflow: hidden !important;
    transition: all 0.4s ease !important;
}

.premium-game-card::before {
    content: '' !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: var(--gradient-glass) !important;
    opacity: 0 !important;
    transition: opacity 0.3s ease !important;
    pointer-events: none !important;
}

.premium-game-card:hover {
    transform: translateY(-8px) !important;
    border-color: var(--primary-red) !important;
    box-shadow: 0 20px 40px rgba(164, 28, 50, 0.2) !important;
}

.premium-game-card:hover::before {
    opacity: 1 !important;
}

.game-status {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin-bottom: 1.5rem !important;
}

.matchday-badge {
    background: var(--gradient-primary) !important;
    color: white !important;
    padding: 0.5rem 1rem !important;
    border-radius: 20px !important;
    font-size: 0.8rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
}

.game-time {
    color: var(--text-secondary) !important;
    font-weight: 600 !important;
    font-family: 'JetBrains Mono', monospace !important;
}

.game-matchup {
    display: grid !important;
    grid-template-columns: 1fr auto 1fr !important;
    gap: 2rem !important;
    align-items: center !important;
    margin-bottom: 2rem !important;
}

.team {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 1rem !important;
    padding: 1rem !important;
    background: rgba(255, 255, 255, 0.05) !important;
    border-radius: 16px !important;
    transition: all 0.3s ease !important;
}

.team:hover {
    background: rgba(255, 255, 255, 0.1) !important;
    transform: scale(1.05) !important;
}

.team-logo {
    width: 60px !important;
    height: 60px !important;
    border-radius: 50% !important;
    border: 2px solid rgba(255, 255, 255, 0.2) !important;
    padding: 4px !important;
    background: rgba(255, 255, 255, 0.1) !important;
    transition: all 0.3s ease !important;
}

.team:hover .team-logo {
    border-color: var(--primary-red) !important;
    box-shadow: 0 0 20px rgba(164, 28, 50, 0.3) !important;
}

.team-name {
    font-weight: 700 !important;
    font-size: 0.9rem !important;
    text-align: center !important;
    color: var(--text-primary) !important;
}

.vs-section {
    text-align: center !important;
}

.vs-text {
    font-size: 1.5rem !important;
    font-weight: 800 !important;
    color: var(--text-muted) !important;
    font-family: 'JetBrains Mono', monospace !important;
}

.countdown {
    display: block !important;
    margin-top: 0.5rem !important;
    font-size: 0.8rem !important;
    color: var(--primary-red) !important;
    font-weight: 600 !important;
    font-family: 'JetBrains Mono', monospace !important;
    background: rgba(164, 28, 50, 0.1) !important;
    padding: 0.25rem 0.5rem !important;
    border-radius: 8px !important;
    text-align: center !important;
    letter-spacing: 0.02em !important;
    transition: none !important;
}

/* Premium Tip Forms */
.tip-section {
    position: relative !important;
    z-index: 2 !important;
}

.premium-tip-form {
    background: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 16px !important;
    padding: 1.5rem !important;
    transition: all 0.3s ease !important;
}

.premium-tip-form.loading {
    opacity: 0.7 !important;
    pointer-events: none !important;
}

.premium-tip-form.success {
    border-color: #10b981 !important;
    background: rgba(16, 185, 129, 0.1) !important;
}

.premium-tip-form.error {
    border-color: #ef4444 !important;
    background: rgba(239, 68, 68, 0.1) !important;
}

.tip-inputs {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 1rem !important;
    margin-bottom: 1.5rem !important;
}

.score-input {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 0.5rem !important;
}

.score-input input {
    width: 60px !important;
    height: 60px !important;
    background: rgba(255, 255, 255, 0.1) !important;
    border: 2px solid rgba(255, 255, 255, 0.2) !important;
    border-radius: 16px !important;
    text-align: center !important;
    font-size: 1.5rem !important;
    font-weight: 800 !important;
    color: var(--text-primary) !important;
    font-family: 'JetBrains Mono', monospace !important;
    transition: all 0.3s ease !important;
}

.score-input input:focus {
    outline: none !important;
    border-color: var(--primary-red) !important;
    background: rgba(164, 28, 50, 0.1) !important;
    box-shadow: 0 0 0 3px rgba(164, 28, 50, 0.2) !important;
    transform: scale(1.1) !important;
}

.score-input label {
    font-size: 0.8rem !important;
    color: var(--text-muted) !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
}

.score-separator {
    font-size: 2rem !important;
    font-weight: 800 !important;
    color: var(--primary-red) !important;
    font-family: 'JetBrains Mono', monospace !important;
    text-shadow: 0 0 10px rgba(164, 28, 50, 0.3) !important;
}

.tip-submit-btn {
    width: 100% !important;
    background: var(--gradient-primary) !important;
    border: none !important;
    color: white !important;
    padding: 1rem 2rem !important;
    border-radius: 12px !important;
    font-weight: 700 !important;
    font-size: 1rem !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0.5rem !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
}

.tip-submit-btn:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 24px rgba(164, 28, 50, 0.4) !important;
}

.tip-submit-btn:disabled {
    opacity: 0.7 !important;
    cursor: not-allowed !important;
    transform: none !important;
}

/* Tip Display */
.tip-display {
    background: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 16px !important;
    padding: 1.5rem !important;
    text-align: center !important;
}

.tip-result {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 0.5rem !important;
}

.tip-label {
    color: var(--text-secondary) !important;
    font-weight: 600 !important;
    font-size: 0.9rem !important;
}

.tip-score {
    font-size: 1.5rem !important;
    font-weight: 800 !important;
    font-family: 'JetBrains Mono', monospace !important;
    color: var(--text-primary) !important;
}

.tip-points {
    padding: 0.5rem 1rem !important;
    border-radius: 20px !important;
    font-weight: 700 !important;
    font-size: 0.9rem !important;
    font-family: 'JetBrains Mono', monospace !important;
}

.tip-points.positive {
    background: rgba(16, 185, 129, 0.2) !important;
    color: #10b981 !important;
}

.tip-points.zero {
    background: rgba(239, 68, 68, 0.2) !important;
    color: #ef4444 !important;
}

/* No Games */
.no-games-card {
    text-align: center !important;
    padding: 4rem 2rem !important;
    background: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 20px !important;
}

.no-games-icon {
    font-size: 4rem !important;
    margin-bottom: 1rem !important;
    opacity: 0.5 !important;
}

.no-games-card h4 {
    font-size: 1.2rem !important;
    font-weight: 700 !important;
    color: var(--text-primary) !important;
    margin-bottom: 0.5rem !important;
}

.no-games-card p {
    color: var(--text-secondary) !important;
    margin-bottom: 2rem !important;
}

/* Top Tippers */
.top-tippers-list {
    display: flex !important;
    flex-direction: column !important;
    gap: 1rem !important;
}

.tipper-item {
    display: flex !important;
    align-items: center !important;
    gap: 1rem !important;
    padding: 1rem 1.25rem !important;
    background: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 16px !important;
    transition: all 0.3s ease !important;
}

.tipper-item:hover {
    background: rgba(255, 255, 255, 0.1) !important;
    transform: translateX(8px) !important;
}

.tipper-item.current-user {
    background: rgba(164, 28, 50, 0.1) !important;
    border-color: var(--primary-red) !important;
    box-shadow: 0 0 20px rgba(164, 28, 50, 0.2) !important;
}

.tipper-rank {
    min-width: 40px !important;
    text-align: center !important;
}

.medal {
    font-size: 1.5rem !important;
}

.rank-number {
    font-size: 1.2rem !important;
    font-weight: 800 !important;
    font-family: 'JetBrains Mono', monospace !important;
    color: var(--text-primary) !important;
}

.tipper-info {
    flex: 1 !important;
}

.tipper-name {
    font-weight: 700 !important;
    color: var(--text-primary) !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
}

.you-indicator {
    background: var(--gradient-primary) !important;
    color: white !important;
    padding: 0.25rem 0.5rem !important;
    border-radius: 8px !important;
    font-size: 0.7rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
}

.tipper-stats {
    display: flex !important;
    gap: 1rem !important;
    margin-top: 0.25rem !important;
}

.points {
    color: var(--text-secondary) !important;
    font-size: 0.9rem !important;
    font-weight: 600 !important;
    font-family: 'JetBrains Mono', monospace !important;
}

.streak {
    color: #ffa500 !important;
    font-size: 0.8rem !important;
    font-weight: 700 !important;
}

/* Quick Actions */
.quick-actions-grid {
    display: grid !important;
    gap: 1rem !important;
}

.quick-action-card {
    display: flex !important;
    align-items: center !important;
    gap: 1rem !important;
    padding: 1.25rem !important;
    background: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 16px !important;
    text-decoration: none !important;
    color: var(--text-primary) !important;
    transition: all 0.3s ease !important;
}

.quick-action-card:hover {
    background: rgba(255, 255, 255, 0.1) !important;
    border-color: var(--primary-red) !important;
    transform: translateY(-4px) !important;
    box-shadow: 0 8px 24px rgba(164, 28, 50, 0.2) !important;
}

.action-icon {
    font-size: 1.5rem !important;
    flex-shrink: 0 !important;
}

.action-title {
    font-weight: 700 !important;
    color: var(--text-primary) !important;
    margin-bottom: 0.25rem !important;
    display: block !important;
}

.action-desc {
    color: var(--text-secondary) !important;
    font-size: 0.85rem !important;
    display: block !important;
}

/* No Tip */
.no-tip {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0.5rem !important;
    padding: 1.5rem !important;
    background: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 16px !important;
    color: var(--text-muted) !important;
}

.no-tip-icon {
    font-size: 1.2rem !important;
}

.no-tip-text {
    font-weight: 600 !important;
    font-size: 0.9rem !important;
}

/* Mobile Responsive */
@media (max-width: 1024px) {
    .dashboard-grid {
        grid-template-columns: 1fr !important;
        gap: 2rem !important;
    }

    .sidebar-content {
        order: -1 !important;
    }

    .welcome-card {
        flex-direction: column !important;
        gap: 2rem !important;
        text-align: center !important;
    }

    .welcome-stats {
        flex-direction: row !important;
        justify-content: center !important;
    }
}

/* GLOBAL MOBILE OVERFLOW PREVENTION */
@media (max-width: 768px) {
    /* Prevent horizontal overflow on all main containers - BUT NOT VERTICAL */
    .container,
    .dashboard-container,
    .main-container,
    .content-wrapper {
        width: 100% !important;
        max-width: 100vw !important;
        overflow-x: hidden !important;
        overflow-y: visible !important;  /* Allow dropdowns to extend vertically */
        box-sizing: border-box !important;
        padding-left: 1rem !important;
        padding-right: 1rem !important;
    }

    /* Ensure all cards and components fit within viewport */
    .premium-game-card,
    .welcome-card,
    .stat-card,
    .filter-nav,
    .bet-card,
    .rules-card-compact,
    .profile-card-premium,
    .friends-card,
    .setting-card {
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
        overflow-x: hidden !important;
    }

    /* SPECIFIC OVERFLOW CONTROL - Only for content that causes horizontal scroll */
    .game-content,
    .tip-section,
    .matchup-content,
    .stats-content,
    .card-body:not(:has(.dropdown)):not(:has([class*="dropdown"])) {
        overflow-x: hidden !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
    }

/* KOMPLETTES MOBILE LAYOUT - NEUGESTALTUNG */
    /* KOMPAKTE MOBILE HEADER */
    .dashboard-header {
        padding: 0.5rem 0 !important;
        position: relative !important;
        width: 100% !important;
        max-width: 100vw !important;
        box-sizing: border-box !important;
        /* No overflow-x: hidden here to allow dropdowns */
    }

    .dashboard-header .header-content {
        display: flex !important;
        flex-direction: column !important;
        gap: 0.75rem !important;
        text-align: center !important;
        position: relative !important;
        width: 100% !important;
        max-width: 100vw !important;
        box-sizing: border-box !important;
        padding: 0 1rem !important;
        min-height: 120px !important;
        /* No overflow-x: hidden here to allow dropdowns */
    }

    /* FORCE USER PROFILE OUT OF FLEXBOX FLOW */
    .dashboard-header .header-content .user-profile {
        position: absolute !important;
        top: 0.25rem !important;
        right: 0.25rem !important;
        order: unset !important;
        margin: 0 !important;
        z-index: 1200 !important;
    }

  /* LOGO ZENTRAL OBEN - leicht nach links verschoben */
.dashboard-header .logo {
    justify-content: center !important;
    gap: 0.8rem !important;
    order: 1 !important;
    padding: 0 2rem 0 1rem !important; /* reduziert um Overflow zu vermeiden */
    width: 100% !important;
    max-width: calc(100vw - 2rem) !important;
    box-sizing: border-box !important;
    overflow-x: hidden !important;
}

.lhl-logo {
    height: 30px !important;
}

.logo-text {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 0.2rem !important;
}

.logo-text h1 {
    font-size: 1.1rem !important;
    margin: 0 !important;
}

.season-badge {
    padding: 0.15rem 0.4rem !important;
    font-size: 0.6rem !important;
}


    /* USER PROFILE - GANZ OBEN RECHTS ECKE - MOBILE OVERRIDE */
    .user-profile {
    position: fixed !important;        /* Fixed statt absolute */
    top: 0.75rem !important;           /* Relativ zum Viewport */
    right: 0.5rem !important;          /* Relativ zum Viewport */
    padding: 0.4rem 0.6rem !important;
    margin: 0 !important;
    gap: 0.4rem !important;
    max-width: none !important;
    order: unset !important;           /* Aus Flexbox raus */
    border-radius: 10px !important;
    background: rgba(255, 255, 255, 0.06) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    z-index: 1200 !important;          /* Höher als Header */
    overflow: visible !important;
    box-sizing: border-box !important;
    display: flex !important;
    align-items: center !important;
    min-height: auto !important;
}


    .user-avatar {
        width: 24px !important;
        height: 24px !important;
        font-size: 0.65rem !important;
        flex-shrink: 0 !important;
    }

    .user-info {
        display: flex !important;
        flex-direction: column !important;
        gap: 0.1rem !important;
        min-width: 0 !important;
    }

    .user-name {
        font-size: 0.7rem !important;
        font-weight: 700 !important;
        line-height: 1 !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    .user-status {
        font-size: 0.6rem !important;
        line-height: 1 !important;
        white-space: nowrap !important;
    }

    /* STATS - GLEICHMÄSSIG UND MITTIG ZUR NAVIGATION */
    .header-stats {
        display: flex !important;
        justify-content: center !important;
        gap: 0.3rem !important;
        width: 100% !important;
        max-width: calc(100vw - 2rem) !important;
        margin: 0 auto !important;
        order: 2 !important;
        overflow-x: hidden !important;
        box-sizing: border-box !important;
    }

    .stat-item {
        padding: 0.3rem 0.4rem !important;
        min-width: 70px !important;
        border-radius: 10px !important;
        flex: 1 !important;
        background: rgba(255, 255, 255, 0.06) !important;
        border: 1px solid rgba(255, 255, 255, 0.1) !important;
    }

    .stat-value {
        font-size: 0.9rem !important;
        font-weight: 800 !important;
    }

    .stat-label {
        font-size: 0.6rem !important;
        font-weight: 600 !important;
    }

    /* NAVIGATION - BREITER UND MITTIG ZU STATS */
    .dashboard-nav {
        display: flex !important;
        justify-content: center !important;
        gap: 0.1rem !important;
        padding: 0.5rem 1rem !important;
        width: 100% !important;
        max-width: calc(100vw - 2rem) !important;
        margin: 0 auto !important;
        border-radius: 30px !important;
        background: rgba(255, 255, 255, 0.08) !important;
        border: 1px solid rgba(255, 255, 255, 0.15) !important;
        order: 3 !important;
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2) !important;
        overflow-x: hidden !important;
        box-sizing: border-box !important;
    }

    .nav-item {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        gap: 0.1rem !important;
        padding: 0.3rem 0.2rem !important;
        min-width: auto !important;
        font-size: 0.65rem !important;
        border-radius: 12px !important;
        flex: 1 !important;
    }

    .nav-icon {
        font-size: 0.85rem !important;
        margin-bottom: 0 !important;
    }

    .nav-text {
        font-size: 0.55rem !important;
        font-weight: 600 !important;
        line-height: 1 !important;
    }

    /* MOBILE MAIN DASHBOARD */
    .dashboard-main {
        padding: 1.5rem 0 !important;
        width: 100% !important;
        max-width: 100vw !important;
        box-sizing: border-box !important;
        /* Only hide horizontal overflow for specific content, not the main container */
    }

    .dashboard-main .container {
        width: 100% !important;
        max-width: 100vw !important;
        padding: 0 1rem !important;
        margin: 0 auto !important;
        box-sizing: border-box !important;
        /* Allow overflow for dropdowns in main container */
    }

    /* ULTRA KOMPAKTE WELCOME SECTION */
    .welcome-card {
        padding: 1rem !important;
        flex-direction: row !important;
        gap: 1rem !important;
        text-align: left !important;
        align-items: center !important;
    }

    .welcome-content {
        flex: 1 !important;
    }

    .welcome-content h2 {
        font-size: 1.2rem !important;
        margin-bottom: 0.25rem !important;
        line-height: 1.2 !important;
    }

    .welcome-content p {
        font-size: 0.8rem !important;
        margin: 0 !important;
        line-height: 1.3 !important;
    }

    .welcome-stats {
        display: flex !important;
        flex-direction: column !important;
        gap: 0.5rem !important;
        flex-shrink: 0 !important;
    }

    .quick-stat {
        padding: 0.5rem 0.75rem !important;
        text-align: center !important;
        min-width: 80px !important;
        border-radius: 8px !important;
        background: rgba(255, 255, 255, 0.05) !important;
        border: 1px solid rgba(255, 255, 255, 0.1) !important;
    }

    .stat-number {
        font-size: 1.1rem !important;
        font-weight: 800 !important;
    }

    .stat-text {
        font-size: 0.65rem !important;
        font-weight: 600 !important;
    }

    /* MOBILE DASHBOARD GRID */
    .dashboard-grid {
        grid-template-columns: 1fr !important;
        gap: 1.5rem !important;
    }

    /* ULTRA REDUZIERTE ABSTÄNDE ZWISCHEN ELEMENTEN */
    .games-grid.premium {
        gap: 0.5rem !important;
        margin-bottom: 0.5rem !important;
        margin-top: 0 !important;
    }

    .section-header {
        margin-bottom: 0.25rem !important;
    }

    .games-section {
        padding-bottom: 0 !important;
    }

    /* MINIMALER ABSTAND ZWISCHEN GAMES UND BUTTON */
    .games-section [style*="margin-top: 0.75rem"] {
        margin-top: 0.5rem !important;
    }

    .sidebar-content {
        order: -1 !important;
    }

    /* MOBILE SECTION HEADERS - LINKS RECHTS LAYOUT */
    .section-header {
        flex-direction: row !important;
        justify-content: space-between !important;
        align-items: center !important;
        text-align: left !important;
        margin-bottom: 0.25rem !important;
        gap: 0.5rem !important;
    }

    .section-header h3 {
        font-size: 1.1rem !important;
        margin: 0 !important;
        flex: 1 !important;
    }

    .section-actions {
        display: flex !important;
        justify-content: flex-end !important;
        flex-shrink: 0 !important;
    }

    /* ACTION BUTTONS AUF MOBILE AUSBLENDEN AUSSER REFRESH */
    .section-actions .action-btn:not(.refresh-btn) {
        display: none !important;
    }

    .refresh-btn {
        padding: 0.4rem 0.6rem !important;
        font-size: 0.75rem !important;
        border-radius: 8px !important;
    }

    .refresh-btn .btn-text {
        display: none !important;
    }

    .refresh-btn .btn-icon {
        font-size: 0.9rem !important;
    }

    .action-btn {
        padding: 0.5rem 0.75rem !important;
        font-size: 0.8rem !important;
    }

    /* ULTRA KOMPAKTE MOBILE GAME CARDS */
    .premium-game-card {
        padding: 0.75rem !important;
        margin-bottom: 0.5rem !important;
        border-radius: 16px !important;
        background: rgba(255, 255, 255, 0.04) !important;
        border: 1px solid rgba(255, 255, 255, 0.08) !important;
    }

    .game-status {
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        margin-bottom: 0.75rem !important;
        padding-bottom: 0.5rem !important;
        border-bottom: 1px solid rgba(255, 255, 255, 0.06) !important;
    }

    .matchday-badge {
        padding: 0.25rem 0.5rem !important;
        font-size: 0.65rem !important;
        border-radius: 12px !important;
        font-weight: 700 !important;
    }

    .game-time {
        font-size: 0.7rem !important;
        color: var(--text-muted) !important;
        font-weight: 600 !important;
    }

    /* KOMPAKTE MOBILE GAME MATCHUP */
    .game-matchup {
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        gap: 0.5rem !important;
        margin-bottom: 0.75rem !important;
    }

    .team {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        gap: 0.4rem !important;
        padding: 0.5rem 0.25rem !important;
        background: transparent !important;
        flex: 1 !important;
    }

    .team-logo {
        width: 32px !important;
        height: 32px !important;
        border-radius: 50% !important;
        border: 1.5px solid rgba(255, 255, 255, 0.15) !important;
        padding: 2px !important;
    }

    .team-name {
        font-size: 0.7rem !important;
        text-align: center !important;
        font-weight: 600 !important;
        line-height: 1.2 !important;
        color: var(--text-secondary) !important;
    }

    .vs-section {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        gap: 0.2rem !important;
        margin: 0 !important;
        flex: 0 0 auto !important;
    }

    .vs-text {
        font-size: 0.8rem !important;
        font-weight: 800 !important;
        color: var(--primary-red) !important;
        font-family: 'JetBrains Mono', monospace !important;
    }

    .countdown {
        font-size: 0.6rem !important;
        margin: 0 !important;
        color: var(--primary-red) !important;
        font-weight: 600 !important;
        background: rgba(164, 28, 50, 0.1) !important;
        padding: 0.15rem 0.3rem !important;
        border-radius: 8px !important;
        text-align: center !important;
        line-height: 1.2 !important;
        font-family: 'JetBrains Mono', monospace !important;
        letter-spacing: 0.02em !important;
        transition: none !important;
    }

    /* KOMPAKTE MOBILE TIP FORMS */
    .premium-tip-form {
        padding: 0.5rem !important;
        background: rgba(255, 255, 255, 0.03) !important;
        border: 1px solid rgba(255, 255, 255, 0.06) !important;
        border-radius: 12px !important;
    }

    .tip-inputs {
        margin-bottom: 0.5rem !important;
        gap: 0.5rem !important;
        justify-content: center !important;
    }

    .score-input {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        gap: 0.25rem !important;
    }

    .score-input input {
        width: 50px !important;
        height: 40px !important;
        font-size: 1rem !important;
        border-radius: 10px !important;
        background: rgba(255, 255, 255, 0.08) !important;
        border: 1.5px solid rgba(255, 255, 255, 0.15) !important;
        text-align: center !important;
        color: var(--text-primary) !important;
        font-weight: 800 !important;
        font-family: 'JetBrains Mono', monospace !important;
    }

    .score-input input:focus {
        border-color: var(--primary-red) !important;
        background: rgba(164, 28, 50, 0.1) !important;
        transform: scale(1.05) !important;
    }

    .score-input label {
        font-size: 0.65rem !important;
        color: var(--text-muted) !important;
        font-weight: 600 !important;
        text-transform: uppercase !important;
    }

    .score-separator {
        font-size: 1.2rem !important;
        color: var(--primary-red) !important;
        font-weight: 800 !important;
        align-self: center !important;
        margin-top: 0.5rem !important;
    }

    .tip-submit-btn {
        padding: 0.5rem 1rem !important;
        font-size: 0.8rem !important;
        border-radius: 10px !important;
        font-weight: 700 !important;
    }

    /* KOMPAKTE MOBILE TIP DISPLAY */
    .tip-display {
        padding: 0.5rem !important;
        background: rgba(255, 255, 255, 0.03) !important;
        border-radius: 12px !important;
    }

    .tip-result {
        gap: 0.3rem !important;
    }

    .tip-label {
        font-size: 0.65rem !important;
        font-weight: 600 !important;
    }

    .tip-score {
        font-size: 1rem !important;
        font-weight: 800 !important;
    }

    .tip-points {
        padding: 0.25rem 0.5rem !important;
        font-size: 0.65rem !important;
        border-radius: 8px !important;
        font-weight: 700 !important;
    }

    /* KOMPAKTE NO TIP */
    .no-tip {
        padding: 0.5rem !important;
        gap: 0.3rem !important;
        background: rgba(255, 255, 255, 0.03) !important;
        border-radius: 12px !important;
    }

    .no-tip-icon {
        font-size: 1rem !important;
    }

    .no-tip-text {
        font-size: 0.7rem !important;
        font-weight: 600 !important;
    }

    /* MOBILE NO GAMES */
    .no-games-card {
        padding: 2rem 1rem !important;
    }

    .no-games-icon {
        font-size: 3rem !important;
    }

    .no-games-card h4 {
        font-size: 1.1rem !important;
    }

    /* TOP TIPPERS & QUICK ACTIONS - AUSGEBLENDET AUF MOBILE */
    .top-tippers-section {
        display: none !important;
    }

    .quick-actions-section {
        display: none !important;
    }

    /* MOBILE NO TIP */
    .no-tip {
        padding: 1rem !important;
        gap: 0.4rem !important;
        flex-direction: column !important;
    }

    .no-tip-icon {
        font-size: 1.5rem !important;
    }

    .no-tip-text {
        font-size: 0.85rem !important;
    }
}

/* EXTRA SMALL MOBILE OPTIMIERUNG */
@media (max-width: 480px) {
    .dashboard-main {
        padding: 1rem 0 !important;
    }

    .welcome-card {
        padding: 1rem !important;
    }

    .welcome-content h2 {
        font-size: 1.3rem !important;
    }

    .welcome-stats {
        grid-template-columns: 1fr !important;
        gap: 0.75rem !important;
    }

    .header-stats {
        grid-template-columns: 1fr 1fr !important;
        gap: 0.5rem !important;
    }

    .header-stats .stat-item:nth-child(3) {
        grid-column: 1 / -1 !important;
        max-width: 120px !important;
        margin: 0 auto !important;
    }

    .dashboard-nav {
        display: flex !important;
        justify-content: center !important;
        gap: 0.1rem !important;
        padding: 0.4rem 0.5rem !important;
        width: 100% !important;
        max-width: calc(100vw - 2rem) !important;
        margin: 0 auto !important;
        border-radius: 25px !important;
        background: rgba(255, 255, 255, 0.08) !important;
        border: 1px solid rgba(255, 255, 255, 0.15) !important;
        order: 3 !important;
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2) !important;
        overflow-x: hidden !important;
        flex-wrap: nowrap !important;
        box-sizing: border-box !important;
    }

    .nav-item {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        gap: 0.1rem !important;
        padding: 0.25rem 0.2rem !important;
        min-width: auto !important;
        font-size: 0.65rem !important;
        border-radius: 8px !important;
        flex: 1 !important;
        flex-shrink: 0 !important;
    }

    .nav-icon {
        font-size: 0.8rem !important;
        margin-bottom: 0 !important;
    }

    .nav-text {
        font-size: 0.5rem !important;
        font-weight: 600 !important;
        line-height: 1 !important;
        text-align: center !important;
        white-space: nowrap !important;
    }

    .premium-game-card {
        padding: 1rem !important;
    }

    .team {
        padding: 0.5rem 0.75rem !important;
    }

    .team-logo {
        width: 40px !important;
        height: 40px !important;
    }

    .team-name {
        font-size: 0.8rem !important;
    }

    .score-input input {
        width: 55px !important;
        height: 45px !important;
        font-size: 1.1rem !important;
    }

    .tipper-item {
        padding: 0.75rem 0.875rem !important;
    }
}

/* LANDSCAPE MOBILE OPTIMIZATION */
@media (max-width: 768px) and (orientation: landscape) {
    .dashboard-header .header-content {
        flex-direction: row !important;
        flex-wrap: wrap !important;
        justify-content: space-between !important;
    }

    .dashboard-header .logo {
        order: 1 !important;
    }

    .header-stats {
        order: 2 !important;
        max-width: 250px !important;
    }

    .dashboard-nav {
        order: 3 !important;
        max-width: 300px !important;
    }

    .user-profile {
        order: 4 !important;
        max-width: 200px !important;
    }

    .welcome-stats {
        grid-template-columns: repeat(3, 1fr) !important;
    }

    .game-matchup {
        flex-direction: row !important;
        justify-content: space-around !important;
        align-items: center !important;
    }

    .vs-section {
        order: unset !important;
    }
}

/* PROFILE PAGE STYLES */

/* Profile Grid */
.profile-grid {
    display: grid !important;
    grid-template-columns: 2fr 1fr !important;
    gap: 3rem !important;
    align-items: start !important;
}

/* Profile Header Section */
.profile-header-section {
    margin-bottom: 3rem !important;
}

.profile-card-premium {
    background: rgba(255, 255, 255, 0.05) !important;
    backdrop-filter: blur(20px) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 24px !important;
    padding: 2.5rem !important;
    position: relative !important;
    overflow: hidden !important;
}

.profile-card-premium::before {
    content: '' !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: var(--gradient-glass) !important;
    opacity: 0.3 !important;
    pointer-events: none !important;
}

.profile-avatar-section {
    display: flex !important;
    align-items: center !important;
    gap: 2rem !important;
    position: relative !important;
    z-index: 2 !important;
}

.profile-avatar-large {
    position: relative !important;
    width: 120px !important;
    height: 120px !important;
    border-radius: 50% !important;
    background: var(--gradient-primary) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    overflow: hidden !important;
    box-shadow: 0 8px 32px rgba(164, 28, 50, 0.3) !important;
}

.profile-avatar-large:hover {
    transform: scale(1.05) !important;
    box-shadow: 0 12px 48px rgba(164, 28, 50, 0.4) !important;
}

.profile-avatar-large img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    border-radius: 50% !important;
}

.avatar-initials {
    font-size: 2.5rem !important;
    font-weight: 800 !important;
    color: white !important;
}

.avatar-upload-overlay {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: rgba(0, 0, 0, 0.7) !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    opacity: 0 !important;
    transition: opacity 0.3s ease !important;
    border-radius: 50% !important;
    gap: 0.5rem !important;
}

.profile-avatar-large:hover .avatar-upload-overlay {
    opacity: 1 !important;
}

.upload-icon {
    font-size: 1.5rem !important;
}

.upload-text {
    font-size: 0.8rem !important;
    font-weight: 600 !important;
    color: white !important;
}

.profile-info-premium h2 {
    font-size: 2rem !important;
    font-weight: 800 !important;
    margin-bottom: 0.5rem !important;
    background: var(--gradient-primary) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
}

.profile-rank {
    font-size: 1.1rem !important;
    color: var(--text-secondary) !important;
    font-weight: 600 !important;
    margin-bottom: 0.5rem !important;
}

.profile-member-since {
    color: var(--text-muted) !important;
    font-size: 0.9rem !important;
    margin-bottom: 1rem !important;
}

.profile-status {
    display: flex !important;
    gap: 1rem !important;
}

.status-badge {
    padding: 0.5rem 1rem !important;
    border-radius: 20px !important;
    font-size: 0.8rem !important;
    font-weight: 600 !important;
}

.status-badge.active {
    background: rgba(16, 185, 129, 0.2) !important;
    color: #10b981 !important;
}

.status-badge.verified {
    background: rgba(59, 130, 246, 0.2) !important;
    color: #3b82f6 !important;
}

/* Statistics Grid */
.profile-stats-section {
    margin-bottom: 3rem !important;
}

.stats-grid-premium {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 1.5rem !important;
}

.stat-card-premium {
    background: rgba(255, 255, 255, 0.05) !important;
    backdrop-filter: blur(20px) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 20px !important;
    padding: 2rem !important;
    display: flex !important;
    align-items: center !important;
    gap: 1.5rem !important;
    transition: all 0.3s ease !important;
}

.stat-card-premium:hover {
    transform: translateY(-4px) !important;
    border-color: var(--primary-red) !important;
    box-shadow: 0 12px 32px rgba(164, 28, 50, 0.2) !important;
}

.stat-icon {
    font-size: 2.5rem !important;
    flex-shrink: 0 !important;
}

.stat-content {
    flex: 1 !important;
}

.stat-content .stat-number {
    display: block !important;
    font-size: 2rem !important;
    font-weight: 800 !important;
    font-family: 'JetBrains Mono', monospace !important;
    color: var(--text-primary) !important;
    margin-bottom: 0.25rem !important;
}

.stat-content .stat-label {
    color: var(--text-secondary) !important;
    font-weight: 600 !important;
    font-size: 0.9rem !important;
}

/* Account Settings */
.account-settings-section {
    margin-bottom: 3rem !important;
}

.settings-grid {
    display: flex !important;
    flex-direction: column !important;
    gap: 1rem !important;
}

.setting-card {
    background: rgba(255, 255, 255, 0.05) !important;
    backdrop-filter: blur(20px) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 16px !important;
    padding: 1.5rem !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    transition: all 0.3s ease !important;
}

.setting-card:hover {
    border-color: var(--primary-red) !important;
    background: rgba(255, 255, 255, 0.08) !important;
}

.setting-header {
    display: flex !important;
    align-items: center !important;
    gap: 1rem !important;
}

.setting-icon {
    font-size: 1.5rem !important;
    width: 40px !important;
    height: 40px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: rgba(255, 255, 255, 0.1) !important;
    border-radius: 12px !important;
}

.setting-info h4 {
    color: var(--text-primary) !important;
    font-weight: 700 !important;
    margin-bottom: 0.25rem !important;
}

.setting-info p {
    color: var(--text-secondary) !important;
    font-size: 0.9rem !important;
    margin: 0 !important;
}

.setting-action-btn {
    background: var(--gradient-primary) !important;
    border: none !important;
    color: white !important;
    padding: 0.75rem 1.5rem !important;
    border-radius: 12px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
}

.setting-action-btn:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 24px rgba(164, 28, 50, 0.4) !important;
}

.setting-action-btn.disabled {
    background: rgba(255, 255, 255, 0.1) !important;
    color: var(--text-muted) !important;
    cursor: not-allowed !important;
}

.setting-action-btn.disabled:hover {
    transform: none !important;
    box-shadow: none !important;
}

/* Friends Section */
.friends-section {
    margin-bottom: 2rem !important;
}

.friends-card {
    background: rgba(255, 255, 255, 0.05) !important;
    backdrop-filter: blur(20px) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 20px !important;
    padding: 2rem !important;
}

.friend-code-section {
    margin-bottom: 2rem !important;
    padding-bottom: 2rem !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
}

.friend-code-section h4 {
    color: var(--text-primary) !important;
    font-weight: 700 !important;
    margin-bottom: 1rem !important;
}

.friend-code-display {
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    margin-bottom: 0.5rem !important;
}

.friend-code {
    background: rgba(164, 28, 50, 0.2) !important;
    color: var(--primary-red) !important;
    padding: 0.75rem 1rem !important;
    border-radius: 12px !important;
    font-family: 'JetBrains Mono', monospace !important;
    font-weight: 700 !important;
    font-size: 1.1rem !important;
    letter-spacing: 0.1em !important;
    flex: 1 !important;
    text-align: center !important;
}

.copy-code-btn {
    background: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    color: var(--text-secondary) !important;
    padding: 0.75rem !important;
    border-radius: 12px !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
}

.copy-code-btn:hover {
    background: rgba(255, 255, 255, 0.2) !important;
    color: var(--text-primary) !important;
}

.friend-code-info {
    color: var(--text-muted) !important;
    font-size: 0.8rem !important;
    margin: 0 !important;
}

.add-friend-section {
    margin-bottom: 2rem !important;
    padding-bottom: 2rem !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
}

.add-friend-section h4 {
    color: var(--text-primary) !important;
    font-weight: 700 !important;
    margin-bottom: 1rem !important;
}

.add-friend-form {
    display: flex !important;
    gap: 0.5rem !important;
}

.friend-code-input {
    flex: 1 !important;
    background: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    border-radius: 12px !important;
    padding: 0.75rem 1rem !important;
    color: var(--text-primary) !important;
    font-family: 'JetBrains Mono', monospace !important;
    text-transform: uppercase !important;
}

.friend-code-input:focus {
    outline: none !important;
    border-color: var(--primary-red) !important;
    background: rgba(164, 28, 50, 0.1) !important;
}

.add-friend-btn {
    background: var(--gradient-secondary) !important;
    border: none !important;
    color: white !important;
    padding: 0.75rem 1.5rem !important;
    border-radius: 12px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
}

.add-friend-btn:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 24px rgba(44, 180, 206, 0.4) !important;
}

.friends-list h4 {
    color: var(--text-primary) !important;
    font-weight: 700 !important;
    margin-bottom: 1rem !important;
}

.friends-empty {
    text-align: center !important;
    padding: 2rem !important;
    color: var(--text-muted) !important;
}

.empty-icon {
    font-size: 3rem !important;
    display: block !important;
    margin-bottom: 1rem !important;
    opacity: 0.5 !important;
}

.friends-empty p {
    font-weight: 600 !important;
    margin-bottom: 0.5rem !important;
}

.friends-empty small {
    font-size: 0.8rem !important;
    opacity: 0.7 !important;
}

/* Profile Quick Actions */
.profile-quick-actions .quick-actions-grid {
    display: grid !important;
    gap: 1rem !important;
}

.profile-quick-actions .quick-action-card {
    background: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 16px !important;
    padding: 1.5rem !important;
    text-decoration: none !important;
    color: var(--text-primary) !important;
    display: flex !important;
    align-items: center !important;
    gap: 1rem !important;
    transition: all 0.3s ease !important;
}

.profile-quick-actions .quick-action-card:hover {
    background: rgba(255, 255, 255, 0.1) !important;
    border-color: var(--primary-red) !important;
    transform: translateY(-4px) !important;
    box-shadow: 0 8px 24px rgba(164, 28, 50, 0.2) !important;
}

.profile-quick-actions .action-icon {
    font-size: 1.5rem !important;
}

.profile-quick-actions .action-title {
    font-weight: 700 !important;
}

/* Hide mobile friends section on desktop */
.mobile-friends-section {
    display: none !important;
}

/* HOMEPAGE SPECIFIC STYLES */

/* Auth Actions in Header */
.auth-actions {
    display: flex !important;
    gap: 0.5rem !important;
    align-items: center !important;
}

/* Hero Section */
.hero-section {
    margin-bottom: 3rem !important;
}

.hero-card-premium {
    background: rgba(255, 255, 255, 0.05) !important;
    backdrop-filter: blur(20px) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 24px !important;
    padding: 3rem !important;
    position: relative !important;
    overflow: hidden !important;
    text-align: center !important;
}

.hero-card-premium::before {
    content: '' !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: var(--gradient-glass) !important;
    opacity: 0.3 !important;
    pointer-events: none !important;
}

.hero-content {
    position: relative !important;
    z-index: 2 !important;
}

.hero-content h2 {
    font-size: 2.5rem !important;
    font-weight: 800 !important;
    margin-bottom: 1rem !important;
    background: var(--gradient-primary) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
}

.hero-subtitle {
    font-size: 1.2rem !important;
    color: var(--text-secondary) !important;
    margin-bottom: 2.5rem !important;
    line-height: 1.6 !important;
}

.hero-features {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 2rem !important;
    margin-bottom: 2.5rem !important;
}

.hero-feature {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 1rem !important;
    padding: 1.5rem !important;
    background: rgba(255, 255, 255, 0.05) !important;
    border-radius: 16px !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    transition: all 0.3s ease !important;
}

.hero-feature:hover {
    transform: translateY(-4px) !important;
    border-color: var(--primary-red) !important;
    background: rgba(255, 255, 255, 0.1) !important;
}

.feature-icon {
    font-size: 2.5rem !important;
    display: block !important;
}

.hero-feature h4 {
    font-size: 1.1rem !important;
    font-weight: 700 !important;
    color: var(--text-primary) !important;
    margin: 0 !important;
}

.hero-feature p {
    font-size: 0.9rem !important;
    color: var(--text-secondary) !important;
    margin: 0 !important;
    text-align: center !important;
}

.hero-actions {
    display: flex !important;
    gap: 1rem !important;
    justify-content: center !important;
}

/* Homepage Grid */
.homepage-grid {
    display: grid !important;
    grid-template-columns: 2fr 1fr !important;
    gap: 3rem !important;
    align-items: start !important;
}

/* Preview Section */
.preview-section {
    margin-bottom: 3rem !important;
}

/* Prizes Section */
.prizes-section {
    margin-bottom: 2rem !important;
}

.prizes-grid {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 1.5rem !important;
    margin-bottom: 2rem !important;
}

.prize-card {
    background: rgba(255, 255, 255, 0.05) !important;
    backdrop-filter: blur(20px) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 20px !important;
    padding: 2rem !important;
    text-align: center !important;
    position: relative !important;
    overflow: hidden !important;
    transition: all 0.4s ease !important;
}

.prize-card::before {
    content: '' !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: var(--gradient-glass) !important;
    opacity: 0 !important;
    transition: opacity 0.3s ease !important;
    pointer-events: none !important;
}

.prize-card:hover {
    transform: translateY(-8px) !important;
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.3) !important;
}

.prize-card:hover::before {
    opacity: 1 !important;
}

.prize-card.gold {
    border-color: rgba(255, 215, 0, 0.3) !important;
}

.prize-card.gold:hover {
    border-color: #ffd700 !important;
    box-shadow: 0 20px 40px rgba(255, 215, 0, 0.2) !important;
}

.prize-card.silver {
    border-color: rgba(192, 192, 192, 0.3) !important;
}

.prize-card.silver:hover {
    border-color: #c0c0c0 !important;
    box-shadow: 0 20px 40px rgba(192, 192, 192, 0.2) !important;
}

.prize-card.bronze {
    border-color: rgba(205, 127, 50, 0.3) !important;
}

.prize-card.bronze:hover {
    border-color: #cd7f32 !important;
    box-shadow: 0 20px 40px rgba(205, 127, 50, 0.2) !important;
}

.prize-rank {
    font-size: 3rem !important;
    margin-bottom: 1rem !important;
    display: block !important;
}

.prize-content {
    position: relative !important;
    z-index: 2 !important;
}

.prize-content h4 {
    font-size: 1.1rem !important;
    font-weight: 700 !important;
    color: var(--text-primary) !important;
    margin-bottom: 0.5rem !important;
}

.prize-content h5 {
    font-size: 1rem !important;
    font-weight: 600 !important;
    color: var(--text-primary) !important;
    margin-bottom: 0.75rem !important;
}

.prize-content p {
    font-size: 0.85rem !important;
    color: var(--text-secondary) !important;
    line-height: 1.5 !important;
    margin: 0 !important;
}

.prizes-cta {
    text-align: center !important;
}

/* Social Section */
.social-section {
    margin-bottom: 2rem !important;
}

.social-links {
    display: flex !important;
    flex-direction: column !important;
    gap: 1rem !important;
}

.social-link {
    display: flex !important;
    align-items: center !important;
    gap: 1rem !important;
    padding: 1rem 1.25rem !important;
    background: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 16px !important;
    text-decoration: none !important;
    color: var(--text-primary) !important;
    transition: all 0.3s ease !important;
}

.social-link:hover {
    background: rgba(255, 255, 255, 0.1) !important;
    border-color: var(--primary-red) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 24px rgba(164, 28, 50, 0.2) !important;
}

.social-icon {
    font-size: 1.5rem !important;
    flex-shrink: 0 !important;
}

.social-info h4 {
    font-weight: 700 !important;
    color: var(--text-primary) !important;
    margin-bottom: 0.25rem !important;
    font-size: 0.95rem !important;
}

.social-info p {
    color: var(--text-secondary) !important;
    font-size: 0.85rem !important;
    margin: 0 !important;
}

/* Game Action */
.game-action {
    padding: 1rem 0 0 0 !important;
    border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
    position: relative !important;
    z-index: 2 !important;
}

/* Mobile Homepage Responsive */
@media (max-width: 1024px) {
    .homepage-grid {
        grid-template-columns: 1fr !important;
        gap: 2rem !important;
    }

    .sidebar-content {
        order: -1 !important;
    }

    .hero-features {
        grid-template-columns: 1fr !important;
        gap: 1rem !important;
    }

    .prizes-grid {
        grid-template-columns: 1fr !important;
        gap: 1rem !important;
    }
}

@media (max-width: 768px) {
    /* Mobile Header Adjustments */
    .auth-actions {
        display: none !important;
    }

    /* Mobile Hero */
    .hero-card-premium {
        padding: 2rem !important;
    }

    .hero-content h2 {
        font-size: 1.8rem !important;
    }

    .hero-subtitle {
        font-size: 1rem !important;
        margin-bottom: 2rem !important;
    }

    .hero-feature {
        padding: 1rem !important;
    }

    .feature-icon {
        font-size: 2rem !important;
    }

    .hero-feature h4 {
        font-size: 1rem !important;
    }

    .hero-feature p {
        font-size: 0.8rem !important;
    }

    .hero-actions {
        flex-direction: column !important;
        gap: 0.75rem !important;
    }

    /* Mobile Prizes */
    .prize-card {
        padding: 1.5rem !important;
    }

    .prize-rank {
        font-size: 2.5rem !important;
        margin-bottom: 0.75rem !important;
    }

    .prize-content h4 {
        font-size: 1rem !important;
    }

    .prize-content h5 {
        font-size: 0.9rem !important;
    }

    .prize-content p {
        font-size: 0.8rem !important;
    }

    /* Mobile Social */
    .social-link {
        padding: 0.875rem 1rem !important;
    }

    .social-icon {
        font-size: 1.25rem !important;
    }

    .social-info h4 {
        font-size: 0.9rem !important;
    }

    .social-info p {
        font-size: 0.8rem !important;
    }
}

/* MY-BETS SPECIFIC STYLES */

/* Page Header for My-Bets */
.my-bets-header {
    text-align: center !important;
    margin-bottom: 2rem !important;
}

.my-bets-header h2 {
    font-size: 1.8rem !important;
    font-weight: 800 !important;
    margin-bottom: 0.5rem !important;
    color: var(--text-primary) !important;
}

.my-bets-header h2 .text-part {
    background: var(--gradient-primary) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
}

.my-bets-header p {
    color: var(--text-secondary) !important;
    font-size: 1rem !important;
    margin: 0 !important;
}

/* Stats Grid for My-Bets */
.stats-grid {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 1.5rem !important;
    margin-bottom: 3rem !important;
}

.stat-card {
    background: rgba(255, 255, 255, 0.05) !important;
    backdrop-filter: blur(20px) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 20px !important;
    padding: 2rem !important;
    display: flex !important;
    align-items: center !important;
    gap: 1.5rem !important;
    transition: all 0.3s ease !important;
}

.stat-card:hover {
    transform: translateY(-4px) !important;
    border-color: var(--primary-red) !important;
    box-shadow: 0 12px 32px rgba(164, 28, 50, 0.2) !important;
}

.stat-card .stat-icon {
    font-size: 2.5rem !important;
    flex-shrink: 0 !important;
}

.stat-card .stat-content {
    flex: 1 !important;
}

.stat-card .stat-number {
    display: block !important;
    font-size: 2rem !important;
    font-weight: 800 !important;
    font-family: 'JetBrains Mono', monospace !important;
    color: var(--text-primary) !important;
    margin-bottom: 0.25rem !important;
}

.stat-card .stat-text {
    color: var(--text-secondary) !important;
    font-weight: 600 !important;
    font-size: 0.9rem !important;
    margin: 0 !important;
}

/* Filter Navigation for My-Bets */
.filter-nav {
    display: flex !important;
    gap: 1rem !important;
    margin-bottom: 3rem !important;
    background: rgba(255, 255, 255, 0.05) !important;
    padding: 1rem !important;
    border-radius: 20px !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
}

.filter-btn {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 0.5rem !important;
    padding: 1rem 1.5rem !important;
    background: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 16px !important;
    text-decoration: none !important;
    color: var(--text-secondary) !important;
    transition: all 0.3s ease !important;
    flex: 1 !important;
    text-align: center !important;
}

.filter-btn:hover {
    background: rgba(255, 255, 255, 0.1) !important;
    color: var(--text-primary) !important;
    transform: translateY(-2px) !important;
}

.filter-btn.active {
    background: var(--gradient-primary) !important;
    color: var(--text-primary) !important;
    box-shadow: 0 4px 12px rgba(164, 28, 50, 0.3) !important;
}

.filter-btn .filter-icon {
    font-size: 1.5rem !important;
}

.filter-btn .filter-text {
    font-size: 0.9rem !important;
    font-weight: 600 !important;
}

.filter-btn .filter-count {
    background: rgba(255, 255, 255, 0.2) !important;
    color: var(--text-primary) !important;
    padding: 0.25rem 0.5rem !important;
    border-radius: 12px !important;
    font-size: 0.8rem !important;
    font-weight: 700 !important;
    font-family: 'JetBrains Mono', monospace !important;
}

.filter-btn.active .filter-count {
    background: rgba(255, 255, 255, 0.3) !important;
}

/* Bets Grid for My-Bets */
.bets-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(500px, 1fr)) !important;
    gap: 2rem !important;
    margin-bottom: 3rem !important;
}

.bet-card {
    background: rgba(255, 255, 255, 0.05) !important;
    backdrop-filter: blur(20px) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 20px !important;
    padding: 2rem !important;
    transition: all 0.3s ease !important;
}

.bet-card:hover {
    transform: translateY(-4px) !important;
    border-color: var(--primary-red) !important;
    box-shadow: 0 12px 32px rgba(164, 28, 50, 0.2) !important;
}

.bet-header {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin-bottom: 1.5rem !important;
    padding-bottom: 1rem !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
}

.bet-matchday {
    background: var(--gradient-primary) !important;
    color: white !important;
    padding: 0.5rem 1rem !important;
    border-radius: 16px !important;
    font-size: 0.8rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
}

.bet-date {
    color: var(--text-secondary) !important;
    font-weight: 600 !important;
    font-family: 'JetBrains Mono', monospace !important;
    font-size: 0.9rem !important;
}

.bet-status .status-badge {
    padding: 0.5rem 1rem !important;
    border-radius: 16px !important;
    font-size: 0.8rem !important;
    font-weight: 700 !important;
}

.status-badge.success {
    background: rgba(16, 185, 129, 0.2) !important;
    color: #10b981 !important;
}

.status-badge.failed {
    background: rgba(239, 68, 68, 0.2) !important;
    color: #ef4444 !important;
}

.status-badge.running {
    background: rgba(255, 165, 0, 0.2) !important;
    color: #ffa500 !important;
}

.status-badge.pending {
    background: rgba(59, 130, 246, 0.2) !important;
    color: #3b82f6 !important;
}

.bet-matchup {
    display: grid !important;
    grid-template-columns: 1fr auto 1fr !important;
    gap: 2rem !important;
    align-items: center !important;
    margin-bottom: 1.5rem !important;
}

.bet-team {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 1rem !important;
    padding: 1rem !important;
    background: rgba(255, 255, 255, 0.05) !important;
    border-radius: 16px !important;
}

.bet-team .team-logo {
    width: 50px !important;
    height: 50px !important;
    border-radius: 50% !important;
    border: 2px solid rgba(255, 255, 255, 0.2) !important;
}

.bet-team .team-name {
    font-weight: 700 !important;
    font-size: 0.9rem !important;
    text-align: center !important;
    color: var(--text-primary) !important;
}

.bet-scores {
    text-align: center !important;
}

.tip-score,
.actual-score {
    margin-bottom: 0.75rem !important;
}

.score-label {
    display: block !important;
    color: var(--text-secondary) !important;
    font-size: 0.8rem !important;
    font-weight: 600 !important;
    margin-bottom: 0.25rem !important;
}

.score-value {
    display: block !important;
    font-size: 1.5rem !important;
    font-weight: 800 !important;
    font-family: 'JetBrains Mono', monospace !important;
    color: var(--text-primary) !important;
}

.score-value.actual {
    color: var(--primary-red) !important;
}

.bet-footer {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding-top: 1rem !important;
    border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
}

.bet-info {
    display: flex !important;
    flex-direction: column !important;
    gap: 0.25rem !important;
}

.bet-time,
.bet-locked {
    color: var(--text-secondary) !important;
    font-size: 0.8rem !important;
    font-weight: 600 !important;
}

.bet-points .points-earned {
    background: rgba(16, 185, 129, 0.2) !important;
    color: #10b981 !important;
    padding: 0.5rem 1rem !important;
    border-radius: 16px !important;
    font-size: 0.9rem !important;
    font-weight: 700 !important;
    font-family: 'JetBrains Mono', monospace !important;
}

/* No Bets Card */
.no-bets-card {
    text-align: center !important;
    padding: 4rem 2rem !important;
    background: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 20px !important;
    grid-column: 1 / -1 !important;
}

.no-bets-icon {
    font-size: 4rem !important;
    margin-bottom: 1rem !important;
    opacity: 0.5 !important;
}

.no-bets-card h4 {
    font-size: 1.2rem !important;
    font-weight: 700 !important;
    color: var(--text-primary) !important;
    margin-bottom: 0.5rem !important;
}

.no-bets-card p {
    color: var(--text-secondary) !important;
    margin-bottom: 2rem !important;
}

/* Page Actions */
.page-actions {
    display: flex !important;
    gap: 1rem !important;
    justify-content: center !important;
    margin-top: 2rem !important;
}

/* MOBILE RESPONSIVE FOR MY-BETS */
@media (max-width: 768px) {
    /* Mobile Page Header */
    .my-bets-header {
        margin-bottom: 1.25rem !important;
    }

    .my-bets-header h2 {
        font-size: 1.4rem !important;
    }

    .my-bets-header p {
        font-size: 0.85rem !important;
    }

    /* Mobile Stats Grid - AUSGEBLENDET */
    .stats-grid {
        display: none !important;
    }

    /* Mobile Filter Navigation - GRÖßER UND BESSER LESBAR */
    .filter-nav {
        display: grid !important;
        grid-template-columns: repeat(4, 1fr) !important;
        gap: 0.5rem !important;
        margin-bottom: 2rem !important;
        padding: 0.75rem !important;
        background: rgba(255, 255, 255, 0.05) !important;
        border-radius: 20px !important;
        width: 100% !important;
        box-sizing: border-box !important;
        border: 1px solid rgba(255, 255, 255, 0.1) !important;
    }

    .filter-nav .filter-btn {
        width: 100% !important;
        max-width: none !important;
        min-width: 0 !important;
        padding: 0.75rem 0.25rem !important;
        gap: 0.4rem !important;
        border-radius: 12px !important;
        background: rgba(255, 255, 255, 0.08) !important;
        border: 1px solid rgba(255, 255, 255, 0.15) !important;
        box-sizing: border-box !important;
        flex-direction: column !important;
        align-items: center !important;
        text-align: center !important;
        transition: all 0.3s ease !important;
    }

    .filter-nav .filter-btn:hover {
        background: rgba(255, 255, 255, 0.15) !important;
        transform: translateY(-2px) !important;
    }

    .filter-nav .filter-btn.active {
        background: var(--gradient-primary) !important;
        border-color: var(--primary-red) !important;
        box-shadow: 0 4px 12px rgba(164, 28, 50, 0.3) !important;
    }

    .filter-nav .filter-btn .filter-icon {
        font-size: 1.2rem !important;
        margin: 0 !important;
    }

    .filter-nav .filter-btn .filter-text {
        font-size: 0.7rem !important;
        line-height: 1.1 !important;
        margin: 0 !important;
        word-wrap: break-word !important;
        hyphens: auto !important;
        text-align: center !important;
        font-weight: 600 !important;
    }

    .filter-nav .filter-btn .filter-count {
        padding: 0.2rem 0.4rem !important;
        font-size: 0.8rem !important;
        border-radius: 8px !important;
        margin: 0 !important;
        min-width: auto !important;
        line-height: 1 !important;
        font-weight: 800 !important;
        background: rgba(255, 255, 255, 0.2) !important;
    }

    .filter-nav .filter-btn.active .filter-count {
        background: rgba(255, 255, 255, 0.3) !important;
    }

    /* Mobile Bets Grid */
    .bets-grid {
        grid-template-columns: 1fr !important;
        gap: 1rem !important;
        margin-bottom: 2rem !important;
    }

    .bet-card {
        padding: 1rem !important;
        border-radius: 16px !important;
    }

    .bet-header {
        flex-wrap: wrap !important;
        gap: 0.5rem !important;
        margin-bottom: 1rem !important;
        padding-bottom: 0.75rem !important;
    }

    .bet-matchday {
        padding: 0.25rem 0.75rem !important;
        font-size: 0.7rem !important;
        border-radius: 12px !important;
    }

    .bet-date {
        font-size: 0.75rem !important;
    }

    .bet-status .status-badge {
        padding: 0.25rem 0.75rem !important;
        font-size: 0.7rem !important;
        border-radius: 12px !important;
    }

    /* Mobile Bet Matchup */
    .bet-matchup {
        grid-template-columns: 1fr auto 1fr !important;
        gap: 0.75rem !important;
        margin-bottom: 1rem !important;
    }

    .bet-team {
        padding: 0.5rem !important;
        gap: 0.5rem !important;
        border-radius: 12px !important;
    }

    .bet-team .team-logo {
        width: 32px !important;
        height: 32px !important;
    }

    .bet-team .team-name {
        font-size: 0.7rem !important;
        line-height: 1.2 !important;
    }

    .bet-scores {
        padding: 0.5rem !important;
    }

    .tip-score,
    .actual-score {
        margin-bottom: 0.5rem !important;
    }

    .score-label {
        font-size: 0.65rem !important;
        margin-bottom: 0.15rem !important;
    }

    .score-value {
        font-size: 1rem !important;
    }

    /* Mobile Bet Footer */
    .bet-footer {
        flex-direction: column !important;
        gap: 0.75rem !important;
        padding-top: 0.75rem !important;
        text-align: center !important;
    }

    .bet-info {
        align-items: center !important;
        text-align: center !important;
    }

    .bet-time,
    .bet-locked {
        font-size: 0.7rem !important;
    }

    .bet-points .points-earned {
        padding: 0.25rem 0.75rem !important;
        font-size: 0.75rem !important;
        border-radius: 12px !important;
    }

    /* Mobile No Bets Card */
    .no-bets-card {
        padding: 2rem 1rem !important;
    }

    .no-bets-icon {
        font-size: 3rem !important;
    }

    .no-bets-card h4 {
        font-size: 1rem !important;
    }

    .no-bets-card p {
        font-size: 0.85rem !important;
    }

    /* Mobile Page Actions - AUSGEBLENDET */
    .page-actions {
        display: none !important;
    }
}

/* EXTRA SMALL MOBILE */
@media (max-width: 480px) {
    /* Stats Grid bleibt ausgeblendet */
    .stats-grid {
        display: none !important;
    }

    /* Filter Navigation - leicht kleiner aber gut lesbar */
    .filter-nav {
        padding: 0.6rem !important;
        gap: 0.4rem !important;
    }

    .filter-nav .filter-btn {
        padding: 0.6rem 0.2rem !important;
        gap: 0.3rem !important;
    }

    .filter-nav .filter-btn .filter-icon {
        font-size: 1rem !important;
    }

    .filter-nav .filter-btn .filter-text {
        font-size: 0.65rem !important;
    }

    .filter-nav .filter-btn .filter-count {
        font-size: 0.7rem !important;
        padding: 0.15rem 0.3rem !important;
        font-weight: 800 !important;
    }

    .bet-team .team-logo {
        width: 28px !important;
        height: 28px !important;
    }

    .bet-team .team-name {
        font-size: 0.65rem !important;
    }
}

/* ULTRA SMALL MOBILE - ZUSÄTZLICHE OPTIMIERUNG */
@media (max-width: 360px) {
    /* Stats Grid bleibt ausgeblendet */
    .stats-grid {
        display: none !important;
    }

    /* Filter Navigation - minimal aber lesbar */
    .filter-nav {
        gap: 0.3rem !important;
        padding: 0.5rem !important;
    }

    .filter-nav .filter-btn {
        padding: 0.5rem 0.15rem !important;
        gap: 0.25rem !important;
    }

    .filter-nav .filter-btn .filter-icon {
        font-size: 0.9rem !important;
    }

    .filter-nav .filter-btn .filter-text {
        font-size: 0.6rem !important;
    }

    .filter-nav .filter-btn .filter-count {
        font-size: 0.65rem !important;
        font-weight: 800 !important;
        padding: 0.1rem 0.25rem !important;
    }
}

/* PREMIUM FOOTER */
.premium-footer {
    background: rgba(15, 16, 18, 0.95) !important;
    backdrop-filter: blur(20px) !important;
    border-top: 1px solid rgba(164, 28, 50, 0.2) !important;
    margin-top: 4rem !important;
    padding: 3rem 0 1.5rem 0 !important;
    position: relative !important;
}

.premium-footer::before {
    content: '' !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: var(--gradient-glass) !important;
    opacity: 0.1 !important;
    pointer-events: none !important;
}

.footer-content {
    display: grid !important;
    grid-template-columns: 2fr 1fr 1fr 1fr !important;
    gap: 3rem !important;
    margin-bottom: 2rem !important;
    position: relative !important;
    z-index: 2 !important;
}

.footer-brand {
    display: flex !important;
    flex-direction: column !important;
    gap: 1.5rem !important;
}

.footer-logo {
    display: flex !important;
    align-items: center !important;
    gap: 1rem !important;
}

.footer-logo .lhl-logo {
    height: 40px !important;
}

.footer-logo-text h4 {
    font-size: 1.3rem !important;
    font-weight: 800 !important;
    margin: 0 !important;
    background: var(--gradient-primary) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
}

.footer-season {
    background: rgba(164, 28, 50, 0.2) !important;
    color: #a41c32 !important;
    padding: 0.2rem 0.5rem !important;
    border-radius: 8px !important;
    font-size: 0.7rem !important;
    font-weight: 600 !important;
    border: 1px solid rgba(164, 28, 50, 0.3) !important;
    margin-top: 0.25rem !important;
    display: inline-block !important;
}

.footer-description {
    color: var(--text-secondary) !important;
    line-height: 1.6 !important;
    font-size: 0.9rem !important;
    margin: 0 !important;
}

.footer-section h5 {
    color: var(--text-primary) !important;
    font-weight: 700 !important;
    font-size: 1rem !important;
    margin-bottom: 1rem !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
}

.contact-info {
    display: flex !important;
    flex-direction: column !important;
    gap: 0.75rem !important;
}

.contact-item {
    display: flex !important;
    flex-direction: column !important;
    gap: 0.25rem !important;
}

.contact-label {
    color: var(--text-secondary) !important;
    font-size: 0.8rem !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
}

.contact-value {
    color: var(--text-primary) !important;
    font-size: 0.9rem !important;
    font-weight: 500 !important;
}

.contact-email {
    color: var(--primary-red) !important;
    text-decoration: none !important;
    font-size: 0.9rem !important;
    font-weight: 500 !important;
    transition: all 0.3s ease !important;
}

.contact-email:hover {
    color: var(--primary-red-light) !important;
    text-decoration: underline !important;
}

.footer-links {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 0.75rem !important;
}

.footer-links li a {
    color: var(--text-secondary) !important;
    text-decoration: none !important;
    font-size: 0.9rem !important;
    font-weight: 500 !important;
    transition: all 0.3s ease !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
}

.footer-links li a:hover {
    color: var(--primary-red) !important;
    transform: translateX(4px) !important;
}

.footer-bottom {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding-top: 1.5rem !important;
    border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
    position: relative !important;
    z-index: 2 !important;
}

.footer-legal {
    display: flex !important;
    align-items: center !important;
    gap: 0.75rem !important;
}

.footer-legal a {
    color: var(--text-secondary) !important;
    text-decoration: none !important;
    font-size: 0.85rem !important;
    font-weight: 500 !important;
    transition: all 0.3s ease !important;
}

.footer-legal a:hover {
    color: var(--primary-red) !important;
}

.footer-copyright {
    display: flex !important;
    align-items: center !important;
    gap: 0.75rem !important;
    color: var(--text-muted) !important;
    font-size: 0.85rem !important;
}

.footer-divider {
    color: var(--text-muted) !important;
    opacity: 0.5 !important;
}

.developer-credit {
    color: var(--text-secondary) !important;
}

.developer-credit strong {
    background: var(--gradient-primary) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
    font-weight: 800 !important;
}

/* Footer Mobile Responsive */
@media (max-width: 1024px) {
    .footer-content {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 2rem !important;
    }

    .footer-brand {
        grid-column: 1 / -1 !important;
        margin-bottom: 1rem !important;
    }
}

@media (max-width: 768px) {
    .premium-footer {
        padding: 2rem 0 1rem 0 !important;
        margin-top: 2rem !important;
    }

    .footer-content {
        grid-template-columns: 1fr !important;
        gap: 1.5rem !important;
        margin-bottom: 1.5rem !important;
    }

    .footer-brand {
        grid-column: 1 !important;
        margin-bottom: 0 !important;
    }

    .footer-logo {
        justify-content: center !important;
        text-align: center !important;
    }

    .footer-description {
        text-align: center !important;
        font-size: 0.85rem !important;
    }

    .footer-section {
        text-align: center !important;
    }

    .contact-info {
        align-items: center !important;
    }

    .contact-item {
        align-items: center !important;
        text-align: center !important;
    }

    .footer-links {
        align-items: center !important;
    }

    .footer-bottom {
        flex-direction: column !important;
        gap: 1rem !important;
        text-align: center !important;
    }

    .footer-legal,
    .footer-copyright {
        flex-wrap: wrap !important;
        justify-content: center !important;
        gap: 0.5rem !important;
    }
}

/* ADDITIONAL MOBILE OVERFLOW PREVENTION - CRITICAL */
@media (max-width: 768px) {
    /* Force all grid layouts to stay within viewport */
    .dashboard-grid,
    .stats-grid,
    .games-grid,
    .bets-grid,
    .profile-grid,
    .footer-content,
    .homepage-grid {
        width: 100% !important;
        max-width: 100vw !important;
        overflow-x: hidden !important;
        box-sizing: border-box !important;
    }

    /* Prevent any element from extending beyond viewport - BUT EXCLUDE DROPDOWNS */
    div:not(.dropdown):not(.dropdown-menu):not(.notification-dropdown):not([class*="dropdown"]):not([class*="popover"]):not([class*="tooltip"]),
    section:not(.dropdown):not(.dropdown-menu):not(.notification-dropdown),
    article:not(.dropdown):not(.dropdown-menu):not(.notification-dropdown),
    main:not(.dropdown):not(.dropdown-menu):not(.notification-dropdown) {
        max-width: 100vw !important;
        box-sizing: border-box !important;
    }

    /* Header and navigation areas should NOT have overflow hidden to allow dropdowns */
    .dashboard-header,
    .header-content,
    .dashboard-nav,
    .user-profile {
        overflow: visible !important;
        overflow-x: visible !important;
        overflow-y: visible !important;
    }

    /* ENSURE DROPDOWN PARENT CONTAINERS ALLOW OVERFLOW */
    .dashboard-header,
    .header-content {
        overflow: visible !important;
    }

    /* Only user-profile needs special positioning for dropdowns */
    .user-profile {
        overflow: visible !important;
    }

    /* FORCE HIGHER Z-INDEX FOR ALL DROPDOWN ELEMENTS */
    .user-profile,
    .user-profile:hover,
    .user-profile:focus,
    .user-profile.active {
        z-index: 1100 !important;
        position: relative !important;
    }

    /* Specific fixes for potentially problematic elements */
    .game-matchup,
    .bet-matchup,
    .tip-inputs,
    .welcome-stats,
    .hero-features {
        width: 100% !important;
        max-width: 100% !important;
        overflow-x: hidden !important;
        box-sizing: border-box !important;
    }

    /* Ensure tables and wide content scales properly */
    .leaderboard-premium,
    .leaderboard-header,
    .leaderboard-row {
        width: 100% !important;
        max-width: 100% !important;
        overflow-x: auto !important;
        box-sizing: border-box !important;
    }

    /* DROPDOWN SUPPORT - Ensure dropdowns can extend outside containers */
    .dropdown,
    .dropdown-menu,
    .notification-dropdown,
    [class*="dropdown"],
    [class*="popover"],
    [class*="tooltip"],
    .menu-dropdown,
    .user-dropdown,
    .settings-dropdown {
        position: absolute !important;
        z-index: 99999 !important;
        overflow: visible !important;
    }

    /* SPECIFIC NOTIFICATION DROPDOWN FIXES */
    .notification-dropdown,
    .notification-menu,
    .notifications-panel,
    [class*="notification"][class*="dropdown"] {
        position: absolute !important;
        z-index: 100000 !important;
        overflow: visible !important;
        top: 100% !important;
        right: 0 !important;
        min-width: 300px !important;
        max-height: 400px !important;
        background: rgba(22, 23, 25, 0.98) !important;
        backdrop-filter: blur(20px) !important;
        border: 1px solid rgba(255, 255, 255, 0.1) !important;
        border-radius: 16px !important;
        box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5) !important;
    }
}

/* Mobile Profile Responsive */
@media (max-width: 1024px) {
    .profile-grid {
        grid-template-columns: 1fr !important;
        gap: 2rem !important;
    }

    .profile-sidebar {
        order: -1 !important;
    }

    .profile-avatar-section {
        flex-direction: column !important;
        text-align: center !important;
        gap: 1.5rem !important;
    }

    .stats-grid-premium {
        grid-template-columns: 1fr !important;
        gap: 1rem !important;
    }
}

@media (max-width: 768px) {
    /* Mobile Profile Grid - Single Column with proper spacing */
    .profile-grid {
        display: block !important;
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 auto !important;
        padding: 0 !important;
    }

    .profile-main {
        order: 1 !important;
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 auto !important;
    }

    .profile-sidebar {
        order: 2 !important;
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 auto !important;
    }

    /* Mobile content ordering with proper spacing */
    .profile-main {
        display: flex !important;
        flex-direction: column !important;
        gap: 1.5rem !important;
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 auto !important;
        padding: 0 !important;
    }

    .profile-header-section {
        order: 1 !important;
        margin-bottom: 0 !important;
        width: 100% !important;
    }

    .mobile-friends-section {
        order: 2 !important;
        display: block !important;
        width: 100% !important;
        margin: 0 !important;
    }

    .profile-stats-section {
        order: 3 !important;
        margin-bottom: 0 !important;
        width: 100% !important;
    }

    .account-settings-section {
        order: 4 !important;
        margin-bottom: 0 !important;
        width: 100% !important;
    }

    /* Hide original sidebar on mobile */
    .profile-sidebar {
        display: none !important;
    }

    /* Ensure all cards are properly centered and spaced */
    .profile-card-premium,
    .mobile-friends-section .friends-card,
    .account-settings-section .settings-grid .setting-card {
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 auto !important;
        box-sizing: border-box !important;
    }

    /* Hide Quick Actions on Mobile */
    .profile-quick-actions {
        display: none !important;
    }

    /* Mobile Profile Card */
    .profile-card-premium {
        padding: 1.5rem !important;
        margin: 0 auto !important;
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
    }

    .profile-avatar-large {
        width: 100px !important;
        height: 100px !important;
    }

    .avatar-initials {
        font-size: 2rem !important;
    }

    .profile-info-premium h2 {
        font-size: 1.5rem !important;
    }

    /* Mobile Stats Integration into Profile Card */
    .profile-header-section {
        margin-bottom: 0 !important;
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 auto !important;
    }

    .profile-stats-section {
        display: none !important; /* Hide original stats section on mobile */
        order: 3 !important;
        margin-bottom: 0 !important;
        width: 100% !important;
    }

    /* Add mobile stats directly to profile card */
    .profile-card-premium::after {
        content: '' !important;
        display: block !important;
        width: 100% !important;
        height: 1px !important;
        background: rgba(255, 255, 255, 0.1) !important;
        margin: 1.5rem 0 !important;
    }

    /* Mobile Friends Card - Same styling and width as profile card */
    .mobile-friends-section {
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 auto !important;
        padding: 0 !important;
    }

    .mobile-friends-section .friends-card {
        padding: 1.5rem !important;
        width: 100% !important;
        max-width: 100% !important;
        background: rgba(255, 255, 255, 0.05) !important;
        backdrop-filter: blur(20px) !important;
        border: 1px solid rgba(255, 255, 255, 0.1) !important;
        border-radius: 24px !important;
        margin: 0 auto !important;
        box-sizing: border-box !important;
        position: relative !important;
        overflow: hidden !important;
    }

    .mobile-friends-section .friends-card::before {
        content: '' !important;
        position: absolute !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        background: var(--gradient-glass) !important;
        opacity: 0.3 !important;
        pointer-events: none !important;
    }

    .friends-section {
        margin-bottom: 0 !important;
    }

    .friend-code-section {
        margin-bottom: 1rem !important;
        padding-bottom: 1rem !important;
    }

    .friend-code-section h4 {
        font-size: 1rem !important;
        margin-bottom: 0.5rem !important;
    }

    .friend-code-display {
        margin-bottom: 0.25rem !important;
    }

    .friend-code {
        padding: 0.5rem 0.75rem !important;
        font-size: 0.9rem !important;
    }

    .friend-code-info {
        font-size: 0.7rem !important;
        margin: 0 !important;
    }

    .add-friend-section {
        margin-bottom: 1rem !important;
        padding-bottom: 0 !important;
        border-bottom: none !important;
    }

    .add-friend-section h4 {
        font-size: 1rem !important;
        margin-bottom: 0.5rem !important;
    }

    .add-friend-form {
        flex-direction: column !important;
        margin-bottom: 0 !important;
        gap: 0.5rem !important;
    }

    .friend-code-input {
        padding: 0.5rem 0.75rem !important;
        font-size: 0.9rem !important;
    }

    .add-friend-btn {
        padding: 0.5rem 1rem !important;
        font-size: 0.9rem !important;
    }

    .friends-list {
        display: none !important; /* Hide friends list on mobile, will be popup */
    }

    /* Mobile Friends List Button */
    .mobile-friends-button {
        background: var(--gradient-primary) !important;
        border: none !important;
        color: white !important;
        padding: 0.75rem 1.5rem !important;
        border-radius: 12px !important;
        font-weight: 600 !important;
        cursor: pointer !important;
        transition: all 0.3s ease !important;
        width: 100% !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 0.5rem !important;
    }

    .mobile-friends-button:hover {
        transform: translateY(-2px) !important;
        box-shadow: 0 8px 24px rgba(164, 28, 50, 0.4) !important;
    }

    /* Mobile Friends Popup */
    .friends-popup {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        background: rgba(0, 0, 0, 0.8) !important;
        backdrop-filter: blur(10px) !important;
        z-index: 9999 !important;
        display: none !important;
        align-items: center !important;
        justify-content: center !important;
        padding: 1rem !important;
    }

    .friends-popup.show {
        display: flex !important;
    }

    .friends-popup-content {
        background: rgba(22, 23, 25, 0.95) !important;
        border: 1px solid rgba(255, 255, 255, 0.1) !important;
        border-radius: 20px !important;
        padding: 2rem !important;
        max-width: 90% !important;
        width: 100% !important;
        max-height: 80vh !important;
        overflow-y: auto !important;
        position: relative !important;
    }

    .friends-popup-header {
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        margin-bottom: 1.5rem !important;
        padding-bottom: 1rem !important;
        border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
    }

    .friends-popup-header h4 {
        color: var(--text-primary) !important;
        font-weight: 700 !important;
        margin: 0 !important;
    }

    .friends-popup-close {
        background: rgba(255, 255, 255, 0.1) !important;
        border: none !important;
        color: var(--text-secondary) !important;
        padding: 0.5rem !important;
        border-radius: 8px !important;
        cursor: pointer !important;
        font-size: 1.2rem !important;
        transition: all 0.3s ease !important;
    }

    .friends-popup-close:hover {
        background: rgba(255, 255, 255, 0.2) !important;
        color: var(--text-primary) !important;
    }

    /* Mobile stats - even smaller */
    .mobile-stats-integration .stat-card-premium {
        padding: 0.75rem !important;
        flex-direction: row !important;
        text-align: left !important;
        gap: 0.75rem !important;
        background: rgba(255, 255, 255, 0.03) !important;
        border: 1px solid rgba(255, 255, 255, 0.05) !important;
        border-radius: 12px !important;
    }

    .mobile-stats-integration .stat-icon {
        font-size: 1.2rem !important;
        width: 32px !important;
        height: 32px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        background: rgba(255, 255, 255, 0.05) !important;
        border-radius: 8px !important;
        flex-shrink: 0 !important;
    }

    .mobile-stats-integration .stat-content .stat-number {
        font-size: 1rem !important;
        font-weight: 700 !important;
    }

    .mobile-stats-integration .stat-content .stat-label {
        font-size: 0.75rem !important;
        margin-top: 0.1rem !important;
    }

    .mobile-stats-integration .stats-grid-premium {
        grid-template-columns: 1fr 1fr !important;
        gap: 0.75rem !important;
        margin-top: 1rem !important;
    }

    .setting-card {
        flex-direction: column !important;
        gap: 1rem !important;
        text-align: center !important;
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 auto !important;
        box-sizing: border-box !important;
    }

    .account-settings-section {
        margin-bottom: 0 !important;
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 auto !important;
    }

    .account-settings-section .settings-grid {
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 auto !important;
        gap: 1rem !important;
    }
}

/* LOGIN PAGE PREMIUM STYLES */

.login-section {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    min-height: 80vh !important;
    padding: 3rem 0 !important;
}

.login-card-premium {
    background: rgba(255, 255, 255, 0.05) !important;
    backdrop-filter: blur(20px) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 24px !important;
    padding: 3rem !important;
    position: relative !important;
    overflow: hidden !important;
    max-width: 500px !important;
    width: 100% !important;
}

.login-card-premium::before {
    content: '' !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: var(--gradient-glass) !important;
    opacity: 0.3 !important;
    pointer-events: none !important;
}

.login-content {
    position: relative !important;
    z-index: 2 !important;
}

.login-header {
    text-align: center !important;
    margin-bottom: 2.5rem !important;
}

.login-header h2 {
    font-size: 2rem !important;
    font-weight: 800 !important;
    margin-bottom: 0.75rem !important;
    background: var(--gradient-primary) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
}

.login-subtitle {
    color: var(--text-secondary) !important;
    font-size: 1rem !important;
    margin: 0 !important;
    line-height: 1.5 !important;
}

/* Premium Alert */
.alert {
    display: flex !important;
    align-items: center !important;
    gap: 0.75rem !important;
    padding: 1rem 1.25rem !important;
    border-radius: 12px !important;
    margin-bottom: 2rem !important;
    font-weight: 600 !important;
}

.alert-error {
    background: rgba(239, 68, 68, 0.1) !important;
    border: 1px solid rgba(239, 68, 68, 0.3) !important;
    color: #ef4444 !important;
}

.alert-icon {
    font-size: 1.2rem !important;
    flex-shrink: 0 !important;
}

.alert-text {
    flex: 1 !important;
}

/* Premium Form */
.login-form {
    display: flex !important;
    flex-direction: column !important;
    gap: 1.5rem !important;
    margin-bottom: 2rem !important;
}

.form-group {
    position: relative !important;
}

.form-label {
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    margin-bottom: 0.75rem !important;
    font-weight: 600 !important;
    color: var(--text-primary) !important;
}

.label-icon {
    font-size: 1rem !important;
}

.label-text {
    font-size: 0.9rem !important;
}

.premium-input {
    width: 100% !important;
    padding: 1rem 1.25rem !important;
    background: rgba(255, 255, 255, 0.08) !important;
    border: 2px solid rgba(255, 255, 255, 0.15) !important;
    border-radius: 12px !important;
    color: var(--text-primary) !important;
    font-size: 1rem !important;
    font-weight: 500 !important;
    transition: all 0.3s ease !important;
    box-sizing: border-box !important;
}

.premium-input:focus {
    outline: none !important;
    border-color: var(--primary-red) !important;
    background: rgba(164, 28, 50, 0.1) !important;
    box-shadow: 0 0 0 3px rgba(164, 28, 50, 0.2) !important;
    transform: translateY(-2px) !important;
}

.premium-input::placeholder {
    color: var(--text-muted) !important;
    opacity: 0.7 !important;
}

/* Password Input Wrapper */
.password-input-wrapper {
    position: relative !important;
}

.password-toggle {
    position: absolute !important;
    right: 1rem !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    background: none !important;
    border: none !important;
    color: var(--text-secondary) !important;
    cursor: pointer !important;
    font-size: 1.2rem !important;
    padding: 0.25rem !important;
    border-radius: 6px !important;
    transition: all 0.3s ease !important;
}

.password-toggle:hover {
    color: var(--text-primary) !important;
    background: rgba(255, 255, 255, 0.1) !important;
}

/* Premium Submit Button */
.premium-submit-btn {
    width: 100% !important;
    background: var(--gradient-primary) !important;
    border: none !important;
    color: white !important;
    padding: 1.25rem 2rem !important;
    border-radius: 12px !important;
    font-weight: 700 !important;
    font-size: 1rem !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0.75rem !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    margin-top: 0.5rem !important;
}

.premium-submit-btn:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 12px 32px rgba(164, 28, 50, 0.4) !important;
}

.premium-submit-btn.loading {
    opacity: 0.8 !important;
    cursor: not-allowed !important;
    transform: none !important;
}

/* Login Footer */
.login-footer {
    margin-top: 2rem !important;
}

.divider {
    display: flex !important;
    align-items: center !important;
    margin: 1.5rem 0 !important;
}

.divider::before,
.divider::after {
    content: '' !important;
    flex: 1 !important;
    height: 1px !important;
    background: rgba(255, 255, 255, 0.1) !important;
}

.divider-text {
    margin: 0 1rem !important;
    color: var(--text-muted) !important;
    font-size: 0.85rem !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
}

/* Auth Links */
.auth-links {
    text-align: center !important;
    margin-bottom: 2rem !important;
}

.auth-link-text {
    color: var(--text-secondary) !important;
    margin: 0 !important;
    font-size: 0.95rem !important;
}

.auth-link {
    display: inline-flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    color: var(--primary-red) !important;
    text-decoration: none !important;
    font-weight: 600 !important;
    transition: all 0.3s ease !important;
}

.auth-link:hover {
    color: var(--primary-red-light) !important;
    text-decoration: underline !important;
}

.link-icon {
    font-size: 0.9rem !important;
}

/* Login Features */
.login-features {
    display: flex !important;
    justify-content: space-around !important;
    gap: 1rem !important;
    margin-top: 1.5rem !important;
    padding-top: 1.5rem !important;
    border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
}

.feature-item {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 0.5rem !important;
    text-align: center !important;
}

.feature-icon {
    font-size: 1.5rem !important;
    display: block !important;
}

.feature-text {
    color: var(--text-secondary) !important;
    font-size: 0.8rem !important;
    font-weight: 600 !important;
}

/* Mobile Login Responsive */
@media (max-width: 768px) {
    .login-section {
        padding: 2rem 0 !important;
        min-height: auto !important;
    }

    .login-card-premium {
        padding: 2rem !important;
        margin: 0 1rem !important;
        border-radius: 20px !important;
    }

    .login-header h2 {
        font-size: 1.6rem !important;
    }

    .login-subtitle {
        font-size: 0.9rem !important;
    }

    .premium-input {
        padding: 0.875rem 1rem !important;
        font-size: 0.95rem !important;
    }

    .premium-submit-btn {
        padding: 1rem 1.5rem !important;
        font-size: 0.95rem !important;
    }

    .login-features {
        flex-direction: column !important;
        gap: 0.75rem !important;
    }

    .feature-item {
        flex-direction: row !important;
        justify-content: center !important;
        gap: 0.75rem !important;
    }

    .feature-icon {
        font-size: 1.2rem !important;
    }

    .feature-text {
        font-size: 0.85rem !important;
    }
}

/* LEADERBOARD PREMIUM STYLES */

/* Stats Highlights Grid */
.stats-highlights-grid {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 1.5rem !important;
    margin-bottom: 3rem !important;
}

.highlight-card {
    background: rgba(255, 255, 255, 0.05) !important;
    backdrop-filter: blur(20px) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 20px !important;
    padding: 2rem !important;
    position: relative !important;
    overflow: hidden !important;
    transition: all 0.4s ease !important;
    text-align: center !important;
}

.highlight-card::before {
    content: '' !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: var(--gradient-glass) !important;
    opacity: 0 !important;
    transition: opacity 0.3s ease !important;
    pointer-events: none !important;
}

.highlight-card:hover {
    transform: translateY(-8px) !important;
    border-color: var(--primary-red) !important;
    box-shadow: 0 20px 40px rgba(164, 28, 50, 0.2) !important;
}

.highlight-card:hover::before {
    opacity: 1 !important;
}

.highlight-card.game-streak {
    border-color: rgba(255, 165, 0, 0.3) !important;
}

.highlight-card.game-streak:hover {
    border-color: #ffa500 !important;
    box-shadow: 0 20px 40px rgba(255, 165, 0, 0.2) !important;
}

.highlight-card.matchday-streak {
    border-color: rgba(255, 215, 0, 0.3) !important;
}

.highlight-card.matchday-streak:hover {
    border-color: #ffd700 !important;
    box-shadow: 0 20px 40px rgba(255, 215, 0, 0.2) !important;
}

.highlight-card.total-players {
    border-color: rgba(59, 130, 246, 0.3) !important;
}

.highlight-card.total-players:hover {
    border-color: #3b82f6 !important;
    box-shadow: 0 20px 40px rgba(59, 130, 246, 0.2) !important;
}

.highlight-header {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0.75rem !important;
    margin-bottom: 1.5rem !important;
    position: relative !important;
    z-index: 2 !important;
}

.highlight-icon {
    font-size: 2rem !important;
}

.highlight-header h4 {
    font-size: 1.1rem !important;
    font-weight: 700 !important;
    color: var(--text-primary) !important;
    margin: 0 !important;
}

.highlight-content {
    position: relative !important;
    z-index: 2 !important;
}

.highlight-value {
    font-size: 2.5rem !important;
    font-weight: 800 !important;
    font-family: 'JetBrains Mono', monospace !important;
    color: var(--text-primary) !important;
    display: block !important;
    margin-bottom: 0.5rem !important;
}

.highlight-label {
    font-size: 0.9rem !important;
    color: var(--text-secondary) !important;
    font-weight: 600 !important;
    display: block !important;
    margin-bottom: 0.75rem !important;
}

.highlight-user {
    font-size: 1rem !important;
    color: var(--primary-red) !important;
    font-weight: 700 !important;
    display: block !important;
}

/* Premium Leaderboard */
.leaderboard-premium {
    background: rgba(255, 255, 255, 0.05) !important;
    backdrop-filter: blur(20px) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 20px !important;
    overflow: hidden !important;
}

.leaderboard-header {
    display: grid !important;
    grid-template-columns: 80px 1fr 100px 80px 100px 120px !important;
    gap: 1rem !important;
    padding: 1.5rem 2rem !important;
    background: rgba(255, 255, 255, 0.1) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
}

.header-cell {
    font-weight: 700 !important;
    color: var(--text-primary) !important;
    font-size: 0.9rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    text-align: center !important;
}

.header-cell.name {
    text-align: left !important;
}

.leaderboard-body {
    position: relative !important;
}

.leaderboard-row {
    display: grid !important;
    grid-template-columns: 80px 1fr 100px 80px 100px 120px !important;
    gap: 1rem !important;
    padding: 1.5rem 2rem !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
    transition: all 0.3s ease !important;
    position: relative !important;
}

.leaderboard-row:hover {
    background: rgba(255, 255, 255, 0.05) !important;
    transform: translateX(4px) !important;
}

.leaderboard-row.current-user {
    background: rgba(164, 28, 50, 0.1) !important;
    border-color: var(--primary-red) !important;
    box-shadow: 0 0 20px rgba(164, 28, 50, 0.2) !important;
}

.leaderboard-row.current-user::before {
    content: '' !important;
    position: absolute !important;
    left: 0 !important;
    top: 0 !important;
    bottom: 0 !important;
    width: 4px !important;
    background: var(--gradient-primary) !important;
}

.leaderboard-row:last-child {
    border-bottom: none !important;
}

.row-cell {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: var(--text-primary) !important;
}

.row-cell.name {
    justify-content: flex-start !important;
}

/* Rank */
.medal {
    font-size: 1.5rem !important;
}

.rank-number {
    font-size: 1.2rem !important;
    font-weight: 800 !important;
    font-family: 'JetBrains Mono', monospace !important;
    color: var(--text-primary) !important;
}

/* Player Info */
.player-info {
    display: flex !important;
    align-items: center !important;
    gap: 1rem !important;
}

.player-avatar {
    width: 40px !important;
    height: 40px !important;
    border-radius: 50% !important;
    background: var(--gradient-primary) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-weight: 800 !important;
    font-size: 0.9rem !important;
    color: white !important;
    box-shadow: 0 4px 12px rgba(164, 28, 50, 0.3) !important;
    flex-shrink: 0 !important;
}

.player-avatar img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    border-radius: 50% !important;
}

.player-name {
    font-weight: 700 !important;
    color: var(--text-primary) !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
}

.you-indicator {
    background: var(--gradient-primary) !important;
    color: white !important;
    padding: 0.25rem 0.5rem !important;
    border-radius: 8px !important;
    font-size: 0.7rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
}

/* Points and Stats */
.points-value,
.tips-value {
    font-family: 'JetBrains Mono', monospace !important;
    font-weight: 700 !important;
    font-size: 1.1rem !important;
}

.streak-badge {
    background: rgba(255, 165, 0, 0.2) !important;
    color: #ffa500 !important;
    padding: 0.5rem 0.75rem !important;
    border-radius: 20px !important;
    font-size: 0.8rem !important;
    font-weight: 700 !important;
    font-family: 'JetBrains Mono', monospace !important;
    border: 1px solid rgba(255, 165, 0, 0.3) !important;
}

.streak-badge.matchday {
    background: rgba(255, 215, 0, 0.2) !important;
    color: #ffd700 !important;
    border-color: rgba(255, 215, 0, 0.3) !important;
}

.streak-empty {
    color: var(--text-muted) !important;
    font-size: 1.2rem !important;
    font-weight: 600 !important;
}

/* Mobile Compact Stats */
.mobile-stats-compact {
    display: none !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 0.5rem !important;
    margin-bottom: 1rem !important;
    padding: 0.75rem !important;
    background: rgba(255, 255, 255, 0.05) !important;
    border-radius: 16px !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
}

.compact-stat-item {
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    padding: 0.5rem !important;
    background: rgba(255, 255, 255, 0.05) !important;
    border-radius: 12px !important;
    transition: all 0.3s ease !important;
}

.compact-stat-item:hover {
    background: rgba(255, 255, 255, 0.1) !important;
    transform: translateY(-2px) !important;
}

.compact-stat-icon {
    font-size: 1.2rem !important;
    flex-shrink: 0 !important;
}

.compact-stat-content {
    flex: 1 !important;
    text-align: center !important;
}

.compact-stat-value {
    display: block !important;
    font-size: 1rem !important;
    font-weight: 800 !important;
    font-family: 'JetBrains Mono', monospace !important;
    color: var(--text-primary) !important;
    line-height: 1 !important;
}

.compact-stat-label {
    display: block !important;
    font-size: 0.6rem !important;
    color: var(--text-secondary) !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.02em !important;
    line-height: 1 !important;
    margin-top: 0.1rem !important;
}

/* Player Search */
.player-search-wrapper {
    position: relative !important;
    display: flex !important;
    align-items: center !important;
}

.player-search-input {
    background: rgba(255, 255, 255, 0.08) !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    border-radius: 12px !important;
    padding: 0.75rem 2.5rem 0.75rem 1rem !important;
    color: var(--text-primary) !important;
    font-size: 0.9rem !important;
    font-weight: 500 !important;
    width: 200px !important;
    transition: all 0.3s ease !important;
}

.player-search-input:focus {
    outline: none !important;
    border-color: var(--primary-red) !important;
    background: rgba(164, 28, 50, 0.1) !important;
    box-shadow: 0 0 0 3px rgba(164, 28, 50, 0.2) !important;
}

.player-search-input::placeholder {
    color: var(--text-muted) !important;
}

.search-icon {
    position: absolute !important;
    right: 0.75rem !important;
    font-size: 0.9rem !important;
    color: var(--text-secondary) !important;
    pointer-events: none !important;
}

/* Rules and Streaks Combined Section */
.rules-streaks-section {
    margin-bottom: 2rem !important;
    width: 100% !important;
}

.rules-streaks-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 3rem !important;
    width: 100% !important;
}

/* Rules and Streaks Cards */
.rules-card,
.streaks-card {
    background: rgba(255, 255, 255, 0.05) !important;
    backdrop-filter: blur(20px) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 20px !important;
    padding: 2.5rem !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 2rem !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

/* Mobile Rules Section */
.mobile-rules-section {
    display: none !important;
    margin-bottom: 1rem !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

.mobile-rules-header {
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    margin-bottom: 0.75rem !important;
    padding: 0 0.25rem !important;
}

.mobile-rules-icon {
    font-size: 1.2rem !important;
}

.mobile-rules-header h4 {
    color: var(--text-primary) !important;
    font-weight: 700 !important;
    font-size: 1rem !important;
    margin: 0 !important;
}

/* Compact Rules Card for Mobile */
.rules-card-compact {
    background: rgba(255, 255, 255, 0.05) !important;
    backdrop-filter: blur(20px) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 16px !important;
    padding: 1rem !important;
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 0.5rem !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

.rule-item-compact {
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    padding: 0.75rem !important;
    background: rgba(255, 255, 255, 0.05) !important;
    border-radius: 12px !important;
    transition: all 0.3s ease !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    min-height: auto !important;
}

.rule-item-compact:hover {
    background: rgba(255, 255, 255, 0.1) !important;
    transform: translateY(-2px) !important;
    border-color: var(--primary-red) !important;
}

.rule-item-compact.bonus {
    background: rgba(164, 28, 50, 0.1) !important;
    border: 1px solid rgba(164, 28, 50, 0.3) !important;
    grid-column: 1 / -1 !important;
}

.rule-icon-compact {
    font-size: 1.2rem !important;
    flex-shrink: 0 !important;
    width: 24px !important;
    text-align: center !important;
}

.rule-content-compact {
    flex: 1 !important;
    text-align: left !important;
}

.rule-content-compact h4 {
    font-weight: 700 !important;
    color: var(--text-primary) !important;
    margin: 0 0 0.1rem 0 !important;
    font-size: 0.8rem !important;
    line-height: 1 !important;
}

.rule-content-compact p {
    color: var(--text-secondary) !important;
    font-size: 0.65rem !important;
    margin: 0 !important;
    line-height: 1.2 !important;
}

.rule-item,
.streak-explanation {
    display: flex !important;
    align-items: center !important;
    gap: 1.5rem !important;
    padding: 1.5rem !important;
    background: rgba(255, 255, 255, 0.05) !important;
    border-radius: 16px !important;
    transition: all 0.3s ease !important;
    min-height: 60px !important;
}

.rule-item:hover,
.streak-explanation:hover {
    background: rgba(255, 255, 255, 0.1) !important;
    transform: translateX(4px) !important;
}

.rule-item.bonus {
    background: rgba(164, 28, 50, 0.1) !important;
    border: 1px solid rgba(164, 28, 50, 0.3) !important;
}

.rule-icon,
.streak-icon {
    font-size: 2rem !important;
    flex-shrink: 0 !important;
    width: 60px !important;
    text-align: center !important;
}

.rule-content,
.streak-content {
    flex: 1 !important;
}

.rule-content h4,
.streak-content h4 {
    font-weight: 700 !important;
    color: var(--text-primary) !important;
    margin-bottom: 0.5rem !important;
    font-size: 1.1rem !important;
}

.rule-content p,
.streak-content p {
    color: var(--text-secondary) !important;
    font-size: 0.95rem !important;
    margin: 0 !important;
    line-height: 1.4 !important;
}

/* Mobile Responsive for Leaderboard */
@media (max-width: 1024px) {
    .stats-highlights-grid {
        display: none !important;
    }

    .leaderboard-header {
        grid-template-columns: 60px 1fr 80px 80px !important;
        padding: 1rem 1.5rem !important;
    }

    .leaderboard-row {
        grid-template-columns: 60px 1fr 80px 80px !important;
        padding: 1rem 1.5rem !important;
    }

    .header-cell.tips,
    .header-cell.matchday,
    .row-cell.tips,
    .row-cell.matchday {
        display: none !important;
    }

    /* Tablet: Keep rules and streaks side by side but smaller */
    .rules-streaks-grid {
        gap: 2rem !important;
    }

    .rules-card,
    .streaks-card {
        padding: 2rem !important;
    }

    .rule-item,
    .streak-explanation {
        padding: 1.25rem !important;
        gap: 1.25rem !important;
    }
}

@media (max-width: 768px) {
    /* Hide both desktop stats and highlights on mobile */
    .leaderboard-stats-section {
        display: none !important;
    }

    .stats-highlights-grid {
        display: none !important;
    }

    .mobile-stats-compact {
        display: none !important;
    }

    /* Hide desktop rules and streaks grid */
    .rules-streaks-section {
        display: none !important;
    }

    /* Show compact rules card */
    .mobile-rules-section {
        display: block !important;
    }

    /* Player search adjustments */
    .player-search-input {
        width: 150px !important;
        padding: 0.5rem 2rem 0.5rem 0.75rem !important;
        font-size: 0.8rem !important;
    }

    .search-icon {
        right: 0.5rem !important;
        font-size: 0.8rem !important;
    }

    .section-actions {
        flex-direction: column !important;
        gap: 0.5rem !important;
        align-items: stretch !important;
    }

    .action-btn:not(.refresh-btn) {
        display: none !important;
    }

    .highlight-card {
        padding: 1.5rem !important;
    }

    .highlight-value {
        font-size: 2rem !important;
    }

    .highlight-header h4 {
        font-size: 1rem !important;
    }

    .leaderboard-header {
        grid-template-columns: 50px 1fr 70px !important;
        padding: 1rem !important;
    }

    .leaderboard-row {
        grid-template-columns: 50px 1fr 70px !important;
        padding: 1rem !important;
    }

    .header-cell.streak,
    .row-cell.streak {
        display: none !important;
    }

    .player-avatar {
        width: 32px !important;
        height: 32px !important;
        font-size: 0.8rem !important;
    }

    .player-name {
        font-size: 0.9rem !important;
    }

    .you-indicator {
        font-size: 0.6rem !important;
        padding: 0.2rem 0.4rem !important;
    }
}

/* Extra small mobile adjustments */
@media (max-width: 480px) {
    .mobile-stats-compact {
        grid-template-columns: 1fr !important;
        gap: 0.4rem !important;
        padding: 0.5rem !important;
    }

    .compact-stat-item {
        padding: 0.4rem !important;
        gap: 0.4rem !important;
    }

    .compact-stat-icon {
        font-size: 1rem !important;
    }

    .compact-stat-value {
        font-size: 0.9rem !important;
    }

    .compact-stat-label {
        font-size: 0.55rem !important;
    }

    .mobile-rules-header {
        margin-bottom: 0.5rem !important;
    }

    .mobile-rules-header h4 {
        font-size: 0.9rem !important;
    }

    .rules-card-compact {
        grid-template-columns: 1fr 1fr !important;
        gap: 0.4rem !important;
        padding: 0.75rem !important;
    }

    .rule-item-compact {
        padding: 0.5rem !important;
        gap: 0.4rem !important;
    }

    .rule-item-compact.bonus {
        grid-column: 1 / -1 !important;
    }

    .rule-content-compact h4 {
        font-size: 0.75rem !important;
    }

    .rule-content-compact p {
        font-size: 0.6rem !important;
    }

    .player-search-input {
        width: 120px !important;
        padding: 0.4rem 1.8rem 0.4rem 0.6rem !important;
        font-size: 0.75rem !important;
    }

    .search-icon {
        right: 0.4rem !important;
        font-size: 0.7rem !important;
    }

    .section-header h3 {
        font-size: 1rem !important;
    }
}

/* GLOBAL DROPDOWN Z-INDEX OVERRIDE - HIGHEST PRIORITY */
.dropdown,
.dropdown-menu,
.notification-dropdown,
.notifications-dropdown,
.user-dropdown,
.profile-dropdown,
[data-dropdown],
[class*="dropdown"],
[class*="popover"],
[class*="tooltip"] {
    z-index: 999999 !important;
    position: absolute !important;
    overflow: visible !important;
}

/* NOTIFICATION DROPDOWN SPECIFIC OVERRIDE */
.notification-dropdown,
.notifications-dropdown,
.notification-menu,
.notifications-panel,
[class*="notification"][class*="dropdown"],
[class*="notification"][class*="menu"] {
    z-index: 1000000 !important;
    position: absolute !important;
    overflow: visible !important;
    top: calc(100% + 0.5rem) !important;
    right: 0 !important;
}
