/* Vaporwave Beach Volleyball Tournament - Mobile Optimized */
@import url('https://fonts.googleapis.com/css2?family=Orbitron:wght@400;500;600;700;800;900&family=Rajdhani:wght@300;400;500;600;700&display=swap');

:root {
    /* Darker Vaporwave Color Palette for Night Theme */
    --primary-cyan: #40e0d0;
    --primary-magenta: #da70d6;
    --primary-purple: #9370db;
    --sunset-pink: #ff91a4;
    --sunset-orange: #ff8a65;
    --ocean-blue: #4fc3f7;
    --deep-purple: #2d1b69;
    --dark-navy: #0f0f23;
    --darker-navy: #0a0a15;
    --neon-green: #7fffd4;
    --electric-blue: #87ceeb;
    
    /* Darker Gradients for Night Theme */
    --gradient-sunset: linear-gradient(135deg, #0a0a15 0%, #2d1b69 30%, #4a0e4e 60%, #1a1a2e 100%);
    --gradient-ocean: linear-gradient(180deg, #0f0f23 0%, #16213e 50%, #0e3460 100%);
    --gradient-neon: linear-gradient(45deg, #da70d6 0%, #40e0d0 50%, #7fffd4 100%);
    --gradient-card: linear-gradient(135deg, rgba(64,224,208,0.08) 0%, rgba(218,112,214,0.08) 100%);
    --gradient-button: linear-gradient(45deg, #da70d6, #40e0d0);
    
    /* Enhanced Glass morphism for dark theme */
    --glass-bg: rgba(15, 15, 35, 0.4);
    --glass-border: rgba(64, 224, 208, 0.2);
    --glass-shadow: 0 8px 32px 0 rgba(0, 0, 0, 0.6);
    
    /* Text colors for better readability */
    --text-primary: #ffffff;
    --text-secondary: #b0b0b0;
    --text-accent: #40e0d0;
    
    /* Mobile-first spacing */
    --spacing-xs: 0.25rem;
    --spacing-sm: 0.5rem;
    --spacing-md: 1rem;
    --spacing-lg: 1.5rem;
    --spacing-xl: 2rem;
    --spacing-xxl: 3rem;
    
    /* Mobile typography */
    --font-xs: 0.75rem;
    --font-sm: 0.875rem;
    --font-base: 1rem;
    --font-lg: 1.125rem;
    --font-xl: 1.25rem;
    --font-2xl: 1.5rem;
    --font-3xl: 1.875rem;
    --font-4xl: 2.25rem;
    /* Fluid heading for mobile scaling */
    --fluid-heading: clamp(1.1rem, 2.5vw, 1.6rem);
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: 'Rajdhani', sans-serif;
    background: var(--gradient-sunset);
    background-attachment: fixed;
    min-height: 100vh;
    color: var(--text-primary);
    line-height: 1.6;
    overflow-x: hidden;
    position: relative;
    
    /* iOS-specific fixes */
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
}

/* iOS PWA viewport fixes */
@supports (-webkit-touch-callout: none) {
    html {
        /* Fix iOS viewport units */
        height: -webkit-fill-available;
        /* Completely disable iOS color scheme to prevent gray backgrounds */
        color-scheme: normal !important;
        /* Force our gradient background */
        background: linear-gradient(135deg, #0a0a15 0%, #2d1b69 30%, #4a0e4e 60%, #1a1a2e 100%) !important;
        background-attachment: fixed !important;
    }
    
    body {
        /* Fix iOS viewport height issues */
        min-height: 100vh;
        min-height: -webkit-fill-available;
        
        /* Force our gradient background on iOS */
        background: linear-gradient(135deg, #0a0a15 0%, #2d1b69 30%, #4a0e4e 60%, #1a1a2e 100%) !important;
        background-attachment: fixed !important;
        
        /* Disable iOS automatic color adjustments */
        -webkit-print-color-adjust: exact !important;
        print-color-adjust: exact !important;
        
        /* Fix iOS scrolling and color rendering */
        -webkit-overflow-scrolling: touch;
        overscroll-behavior: none;
    }
    
    /* Force card backgrounds to be visible on iOS */
    .card,
    .player-setup-card, 
    .tournament-section {
        background: rgba(15, 15, 35, 0.8) !important;
        border: 1px solid rgba(64, 224, 208, 0.3) !important;
        -webkit-backdrop-filter: blur(15px) !important;
        backdrop-filter: blur(15px) !important;
    }
    
    /* Force header background on iOS */
    .header {
        background: rgba(15, 15, 35, 0.8) !important;
        border: 1px solid rgba(64, 224, 208, 0.3) !important;
        -webkit-backdrop-filter: blur(20px) !important;
        backdrop-filter: blur(20px) !important;
    }
}

/* Subtle animated background for nighttime */
body::before {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: 
        radial-gradient(circle at 15% 85%, rgba(64,224,208,0.15) 0%, transparent 40%),
        radial-gradient(circle at 85% 15%, rgba(218,112,214,0.15) 0%, transparent 40%),
        radial-gradient(circle at 50% 50%, rgba(127,255,212,0.08) 0%, transparent 30%);
    animation: floating 25s ease-in-out infinite;
    pointer-events: none;
    z-index: -1;
}

@keyframes floating {
    0%, 100% { transform: translateY(0px) rotate(0deg); }
    50% { transform: translateY(-20px) rotate(5deg); }
}

/* Neon glow animation */
@keyframes neonGlow {
    0%, 100% { 
        text-shadow: 
            0 0 5px rgba(64, 224, 208, 0.4),
            0 0 10px rgba(64, 224, 208, 0.3),
            0 0 15px rgba(64, 224, 208, 0.2);
    }
    50% { 
        text-shadow: 
            0 0 3px rgba(64, 224, 208, 0.3),
            0 0 6px rgba(64, 224, 208, 0.2),
            0 0 10px rgba(64, 224, 208, 0.1);
    }
}

.container {
    max-width: 100%;
    margin: 0 auto;
    padding: var(--spacing-md);
    position: relative;
    z-index: 1;
}

/* Mobile-first responsive breakpoints */
@media (min-width: 768px) {
    .container {
        max-width: 768px;
        padding: var(--spacing-lg);
    }
}

@media (min-width: 1024px) {
    .container {
        max-width: 1024px;
        padding: var(--spacing-xl);
    }
}

/* Header Styling */
.header {
    text-align: center;
    margin-bottom: var(--spacing-lg);
    padding: var(--spacing-md) var(--spacing-md);
    background: var(--glass-bg);
    backdrop-filter: blur(20px);
    border: 1px solid var(--glass-border);
    border-radius: 20px;
    box-shadow: var(--glass-shadow);
}

.header-content {
    background: none;
    padding: 0;
    border-radius: 0;
    box-shadow: none;
    backdrop-filter: none;
}

.header h1,
.title {
    font-family: 'Orbitron', monospace;
    font-size: var(--font-xl);
    font-weight: 700;
    color: var(--text-primary);
    text-shadow: 
        0 0 5px rgba(64, 224, 208, 0.4),
        0 0 10px rgba(64, 224, 208, 0.3),
        0 0 15px rgba(64, 224, 208, 0.2);
    margin-bottom: var(--spacing-sm);
    animation: neonGlow 4s ease-in-out infinite;
    text-transform: uppercase;
    letter-spacing: 1px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

.header h1 i,
.title i {
    font-size: 0.9em;
}

@media (min-width: 768px) {
    .header h1,
    .title {
        font-size: var(--font-2xl);
        letter-spacing: 2px;
        gap: 12px;
    }
    
    .header h1 i,
    .title i {
        font-size: 1em;
    }
}

@media (max-width: 480px) {
    .header {
        margin-bottom: var(--spacing-md);
        padding: var(--spacing-sm) var(--spacing-sm);
    }
    
    .header h1,
    .title {
        font-size: var(--font-lg);
        gap: 6px;
        letter-spacing: 0.5px;
    }
    
    .header h1 i,
    .title i {
        font-size: 0.8em;
    }
}

.header p,
.subtitle {
    font-size: var(--font-sm);
    color: var(--text-accent);
    font-weight: 500;
    text-shadow: 0 0 8px rgba(64, 224, 208, 0.6);
}

@media (min-width: 768px) {
    .header p,
    .subtitle {
        font-size: var(--font-base);
    }
}

@media (max-width: 480px) {
    .header p,
    .subtitle {
        font-size: var(--font-xs);
    }
}

/* Glass Card Components */
.card,
.player-setup-card,
.tournament-section {
    background: var(--glass-bg);
    backdrop-filter: blur(15px);
    border: 1px solid var(--glass-border);
    border-radius: 15px;
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
    box-shadow: var(--glass-shadow);
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
}

.card::before,
.player-setup-card::before,
.tournament-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.1), transparent);
    transition: left 0.6s ease;
}

.card:hover::before,
.player-setup-card:hover::before,
.tournament-section:hover::before {
    left: 100%;
}

.card:hover,
.player-setup-card:hover,
.tournament-section:hover {
    transform: translateY(-5px);
    box-shadow: 0 15px 40px 0 rgba(31, 38, 135, 0.5);
    border-color: var(--primary-cyan);
}

/* Section Headers */
.section-header,
.card-title {
    font-family: 'Orbitron', monospace;
    font-size: var(--font-xl);
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: var(--spacing-md);
    text-align: center;
    text-transform: uppercase;
    letter-spacing: 1px;
    text-shadow: 0 0 8px var(--text-accent);
}

@media (min-width: 768px) {
    .section-header,
    .card-title {
        font-size: var(--font-2xl);
    }
}

/* Button Styling */
.btn {
    background: var(--gradient-button);
    color: white;
    border: none;
    padding: var(--spacing-sm) var(--spacing-lg);
    border-radius: 25px;
    font-family: 'Orbitron', monospace;
    font-size: var(--font-sm);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: 0 4px 15px rgba(255, 0, 255, 0.3);
    position: relative;
    overflow: hidden;
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-xs);
    min-height: 44px; /* Mobile touch target */
    text-decoration: none;
}

.btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
    transition: left 0.4s ease;
}

.btn:hover::before {
    left: 100%;
}

.btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(255, 0, 255, 0.5);
    filter: brightness(1.1);
}

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

.btn-primary {
    background: linear-gradient(45deg, var(--primary-magenta), var(--electric-blue));
}

.btn-success {
    background: linear-gradient(45deg, var(--neon-green), var(--primary-cyan));
}

.btn-secondary {
    background: linear-gradient(45deg, var(--sunset-pink), var(--sunset-orange));
}

.btn-danger {
    background: linear-gradient(45deg, #ff1744, #ff6b35);
}

/* Mobile button sizing */
@media (max-width: 767px) {
    .btn {
        width: 100%;
        justify-content: center;
        margin-bottom: var(--spacing-sm);
        padding: var(--spacing-md) var(--spacing-lg);
    }
    
    /* Make input fields same width as buttons on mobile */
    .player-input,
    input[type="text"],
    input[type="number"],
    select {
        width: 100% !important;
    }
    
    .player-input-group .player-input {
        width: 100% !important;
    }
}

/* Restart Tournament Section */
.restart-section {
    margin-top: var(--spacing-xxl);
    padding: var(--spacing-xl);
    text-align: center;
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: 15px;
    backdrop-filter: blur(15px);
    box-shadow: var(--glass-shadow);
}

.restart-section .btn {
    font-size: var(--font-lg);
    padding: var(--spacing-lg) var(--spacing-xl);
    min-width: 200px;
    box-shadow: 0 6px 20px rgba(255, 23, 68, 0.4);
    /* Prevent accidental text selection when tapping/clicking the button */
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    /* Improve touch behavior on mobile */
    touch-action: manipulation;
    -webkit-tap-highlight-color: rgba(0,0,0,0);
}

.restart-section .btn:hover {
    box-shadow: 0 10px 30px rgba(255, 23, 68, 0.6);
}

@media (max-width: 767px) {
    .restart-section {
        margin-top: var(--spacing-lg);
        padding: var(--spacing-lg);
    }
    
    .restart-section .btn {
        width: 100%;
        min-width: unset;
    }
}

/* Player Setup Section */
.player-setup {
    display: grid;
    gap: var(--spacing-md);
}

/* Setup Section Layout Spacing */
.setup-section .card {
    padding: var(--spacing-xl);
}

.player-input-section {
    margin-bottom: var(--spacing-xl);
}

/* Championship result styling (high contrast, readable) */
.championship-result {
    background: linear-gradient(135deg,#ffd700 0%,#ffecb3 100%);
    padding: 28px;
    border-radius: 10px;
    text-align: center;
    margin-top: 20px;
    border: 2px solid #b8860b;
    color: #fff;
    box-shadow: 0 12px 40px rgba(0,0,0,0.6), inset 0 0 40px rgba(255,215,0,0.06);
}

.championship-result h3 {
    color: #fff;
    margin-bottom: 12px;
    font-size: 1.6em;
    font-weight: 800;
    text-shadow: 0 6px 18px rgba(0,0,0,0.85);
    letter-spacing: 1px;
}

.championship-winner {
    font-size: 1.6em;
    font-weight: 900;
    color: #fff;
    text-shadow: 0 6px 18px rgba(0,0,0,0.85);
    margin-bottom: 6px;
}

.championship-sets {
    margin-top: 10px;
    font-size: 1.05em;
    color: #fff;
    text-shadow: 0 2px 8px rgba(0,0,0,0.6);
}

/* Match card helper classes */
.match-card {
    border: 2px solid #007bff;
    margin-bottom: 15px;
}
.match-card .match-header {
    background: #007bff;
    color: white;
    padding: 8px 12px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.match-card .match-teams {
    background: #e8f5e8;
    padding: 15px;
    border-radius: 6px;
    margin: 10px 0;
}
.team-name-centered {
    font-weight: 700;
    font-size: 1.1em;
    text-align: center;
}


.input-group {
    margin-bottom: var(--spacing-lg);
}

.input-with-button {
    display: flex;
    gap: var(--spacing-md);
    align-items: flex-end;
}

.tournament-settings {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: var(--spacing-lg);
    margin-top: var(--spacing-lg);
    padding: var(--spacing-lg);
    background: rgba(15, 15, 35, 0.3);
    border: 1px solid var(--glass-border);
    border-radius: 12px;
    backdrop-filter: blur(10px);
}

.setting-group {
    margin-bottom: var(--spacing-md);
}

.setting-group label {
    display: block;
    margin-bottom: var(--spacing-sm);
    font-weight: 600;
    color: var(--primary-cyan);
    font-size: var(--font-sm);
}

.repeat-team-selection {
    display: flex;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-sm);
}

.repeat-team-selection select {
    flex: 1;
}

.repeat-team-note {
    font-size: var(--font-xs);
    color: var(--sunset-orange);
    font-style: italic;
    margin: 0;
    padding: var(--spacing-sm);
    background: rgba(255, 138, 101, 0.1);
    border-radius: 8px;
    border-left: 3px solid var(--sunset-orange);
}

@media (max-width: 767px) {
    .repeat-team-selection {
        flex-direction: column;
        gap: var(--spacing-sm);
    }
}

.players-list-section {
    margin-top: var(--spacing-xl);
}

.players-list-section h3 {
    margin-bottom: var(--spacing-lg);
}

.action-buttons {
    margin-top: var(--spacing-xl);
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-md);
    justify-content: center;
}

@media (max-width: 767px) {
    .input-with-button {
        flex-direction: column;
        gap: var(--spacing-sm);
    }
    
    .tournament-settings {
        grid-template-columns: 1fr;
        gap: var(--spacing-md);
        padding: var(--spacing-md);
    }
    
    .action-buttons {
        flex-direction: column;
    }
}

.player-input-group {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    width: 100%;
}

.player-input-group .player-input {
    width: 100%;
    flex: 1;
}

@media (min-width: 768px) {
    .player-input-group {
        flex-direction: column;
    }
    
    .player-input-group .player-input {
        width: 100%;
    }
}

.player-input,
input[type="text"],
input[type="number"],
select {
    background: rgba(15, 15, 35, 0.6);
    border: 2px solid var(--glass-border);
    border-radius: 10px;
    padding: var(--spacing-sm) var(--spacing-md);
    color: var(--text-primary);
    font-size: var(--font-base);
    font-family: 'Rajdhani', sans-serif;
    backdrop-filter: blur(10px);
    transition: all 0.3s ease;
    min-height: 44px; /* Mobile touch target */
}

.player-input:focus,
input[type="text"]:focus,
input[type="number"]:focus,
select:focus {
    outline: none;
    border-color: var(--primary-cyan);
    box-shadow: 0 0 15px rgba(64, 224, 208, 0.4);
    transform: scale(1.02);
    background: rgba(15, 15, 35, 0.8);
}

.player-input::placeholder,
input::placeholder {
    color: var(--text-secondary);
}

/* Player List */
.players-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: var(--spacing-sm);
    margin-top: var(--spacing-md);
}

@media (min-width: 480px) {
    .players-list {
        grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    }
}

@media (min-width: 768px) {
    .players-list {
        grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    }
}

.player-item {
    background: var(--gradient-card);
    border: 1px solid var(--glass-border);
    border-radius: 10px;
    padding: var(--spacing-sm) var(--spacing-md);
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: all 0.3s ease;
    min-height: 48px;
    position: relative;
}

.player-item:hover {
    background: rgba(64, 224, 208, 0.1);
    border-color: var(--primary-cyan);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(64, 224, 208, 0.2);
}

.player-name {
    color: var(--text-primary);
    font-weight: 600;
    text-shadow: 0 0 5px rgba(64, 224, 208, 0.3);
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    margin-right: var(--spacing-xs);
}

.remove-player {
    background: none;
    border: none;
    color: var(--sunset-pink);
    cursor: pointer;
    font-size: var(--font-lg);
    padding: var(--spacing-xs);
    border-radius: 50%;
    transition: all 0.3s ease;
    min-width: 28px;
    min-height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.remove-player:hover {
    background: rgba(255, 105, 180, 0.2);
    transform: scale(1.1);
}

/* Mobile Player Items Styling */
@media (max-width: 767px) {
    .player-item {
        padding: var(--spacing-md) var(--spacing-lg);
        min-height: 56px; /* Larger touch target */
    }
    
    .player-name {
        font-size: var(--font-lg);
        font-weight: 700;
    }
    
    .remove-player {
        font-size: var(--font-xl);
        min-width: 36px;
        min-height: 36px;
        padding: var(--spacing-sm);
    }
}

@media (max-width: 480px) {
    .player-item {
        padding: var(--spacing-lg);
        min-height: 60px;
    }
    
    .player-name {
        font-size: var(--font-xl);
        font-weight: 800;
    }
    
    .remove-player {
        font-size: var(--font-2xl);
        min-width: 40px;
        min-height: 40px;
    }
}

/* Tournament Components */
.tournament-grid {
    display: grid;
    gap: var(--spacing-lg);
    grid-template-columns: 1fr;
}

@media (min-width: 1024px) {
    .tournament-grid {
        grid-template-columns: 2fr 1fr;
    }
}

/* Match Styling */
.match {
    background: var(--glass-bg);
    border: 2px solid var(--glass-border);
    border-radius: 15px;
    margin-bottom: var(--spacing-md);
    overflow: hidden;
    transition: all 0.3s ease;
    position: relative;
}

.match:hover {
    border-color: var(--primary-cyan);
    box-shadow: 0 0 20px rgba(0, 255, 255, 0.2);
}

.match.completed {
    border-color: var(--neon-green);
}

.match.pending {
    border-color: var(--sunset-orange);
}

.match-header {
    background: var(--gradient-neon);
    color: white;
    padding: var(--spacing-sm) var(--spacing-md);
    font-family: 'Orbitron', monospace;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.match-content {
    padding: var(--spacing-md);
}

.match-teams {
    background: rgba(0, 255, 255, 0.1);
    padding: var(--spacing-md);
    border-radius: 10px;
    margin-bottom: var(--spacing-md);
    display: grid;
    gap: var(--spacing-md);
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    text-align: center;
}

.team {
    font-weight: 600;
    color: var(--text-primary);
    text-shadow: 0 0 5px rgba(64, 224, 208, 0.3);
}

.vs {
    font-family: 'Orbitron', monospace;
    font-weight: 700;
    color: var(--sunset-pink);
    font-size: var(--font-lg);
}

/* Scoring Interface */
.score-input {
    display: grid;
    grid-template-columns: 1fr auto 1fr auto;
    gap: var(--spacing-sm);
    align-items: center;
    margin-bottom: var(--spacing-md);
}

.score-input input {
    text-align: center;
    font-weight: bold;
    font-size: var(--font-lg);
}

/* Tables and Standings */
.standings-table,
table {
    width: 100%;
    border-collapse: collapse;
    background: rgba(15, 15, 35, 0.9);
    border-radius: 10px;
    overflow: hidden;
    backdrop-filter: blur(15px);
    border: 1px solid var(--glass-border);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.4);
}

.standings-table th,
.standings-table td,
th, td {
    padding: var(--spacing-md) var(--spacing-lg);
    text-align: left;
    border-bottom: 1px solid rgba(64, 224, 208, 0.2);
    color: var(--text-primary);
    font-size: var(--font-base);
    line-height: 1.4;
}

.standings-table th,
th {
    background: linear-gradient(135deg, var(--deep-purple), rgba(64, 224, 208, 0.3));
    font-family: 'Orbitron', monospace;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    font-size: var(--font-sm);
    text-shadow: 0 0 8px rgba(0, 0, 0, 0.9);
    color: white;
    border-bottom: 2px solid var(--primary-cyan);
}

.standings-table tr:hover,
tr:hover {
    background: rgba(64, 224, 208, 0.15);
}

.standings-table tbody tr {
    background: rgba(15, 15, 35, 0.7);
}

.standings-table tbody tr:nth-child(even) {
    background: rgba(45, 27, 105, 0.3);
}

.standings-table tbody tr:nth-child(odd) {
    background: rgba(15, 15, 35, 0.5);
}

/* Playoff-specific styling */
.playoffs-section .standings-table {
    background: rgba(5, 5, 25, 0.98);
    margin-bottom: var(--spacing-lg);
    border: 2px solid var(--primary-cyan);
    box-shadow: 0 8px 32px rgba(0, 255, 255, 0.15);
}

.playoffs-section .standings-table th {
    background: linear-gradient(135deg, var(--primary-cyan), var(--electric-blue));
    color: var(--dark-navy);
    font-weight: 800;
    text-shadow: none;
    border-bottom: 3px solid var(--primary-cyan);
    font-size: var(--font-base);
    padding: var(--spacing-md) var(--spacing-lg);
}

.playoffs-section .standings-table td {
    font-weight: 600;
    font-size: var(--font-base);
    color: white;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.8);
    background: rgba(15, 15, 35, 0.9);
}

.playoffs-section .standings-table tbody tr:nth-child(even) td {
    background: rgba(25, 25, 45, 0.9);
}

.playoffs-section .standings-table tbody tr:nth-child(odd) td {
    background: rgba(15, 15, 35, 0.9);
}

.playoffs-section .standings-table tbody tr:hover td {
    background: rgba(64, 224, 208, 0.25);
    color: white;
}

/* Status indicators in tables */
.playoffs-section .standings-table .status {
    font-weight: 600;
    padding: var(--spacing-xs) var(--spacing-sm);
    border-radius: 15px;
    font-size: var(--font-xs);
    text-transform: uppercase;
    letter-spacing: 1px;
}

.playoffs-section .standings-table .status.playoffs {
    background: linear-gradient(45deg, var(--neon-green), var(--primary-cyan));
    color: var(--dark-navy);
    text-shadow: none;
}

/* Mobile Optimized Standings Table */
.mobile-standings-table {
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: 15px;
    overflow: hidden;
    backdrop-filter: blur(15px);
    box-shadow: var(--glass-shadow);
}

.mobile-standings-table table {
    width: 100%;
    border-collapse: collapse;
    background: transparent;
    border: none;
    box-shadow: none;
}

.mobile-standings-table th {
    background: linear-gradient(135deg, var(--deep-purple), rgba(64, 224, 208, 0.3));
    color: white;
    font-family: 'Orbitron', monospace;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    font-size: var(--font-sm);
    padding: var(--spacing-md) var(--spacing-sm);
    text-align: center;
    border-bottom: 2px solid var(--primary-cyan);
}

.mobile-standings-table td {
    padding: var(--spacing-md) var(--spacing-sm);
    text-align: center;
    color: var(--text-primary);
    font-size: var(--font-sm);
    border-bottom: 1px solid rgba(64, 224, 208, 0.2);
}

.mobile-standings-table .seed-cell {
    font-weight: bold;
    font-size: var(--font-lg);
    width: 15%;
}

.mobile-standings-table .player-cell {
    text-align: left;
    font-weight: 600;
    width: 40%;
    position: relative;
}

.mobile-standings-table .record-cell,
.mobile-standings-table .points-cell {
    font-family: 'Orbitron', monospace;
    font-weight: 600;
    width: 22.5%;
}

.mobile-standings-table .playoff-qualified {
    background: rgba(64, 224, 208, 0.1);
}

.mobile-standings-table .playoff-qualified .seed-cell {
    color: var(--primary-cyan);
}

.mobile-standings-table .eliminated {
    background: rgba(255, 255, 255, 0.05);
}

.mobile-standings-table .eliminated .seed-cell {
    color: var(--text-secondary);
}

.mobile-standings-table .tiebreaker {
    border-left: 3px solid var(--sunset-orange);
}

.mobile-standings-table .playoff-badge {
    font-size: 0.8em;
    margin-left: var(--spacing-xs);
}

.expand-standings-btn {
    font-size: var(--font-sm);
    padding: var(--spacing-sm) var(--spacing-md);
}

@media (max-width: 767px) {
    .mobile-standings-table th,
    .mobile-standings-table td {
        padding: var(--spacing-sm) var(--spacing-xs);
        font-size: var(--font-xs);
    }
    
    .mobile-standings-table .seed-cell {
        font-size: var(--font-base);
    }
    
    .mobile-standings-table .player-cell {
        font-size: var(--font-sm);
    }
}

/* Full Standings Modal */
.fullscreen-modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: var(--gradient-ocean);
    z-index: 9999;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.modal-header {
    background: var(--glass-bg);
    border-bottom: 2px solid var(--primary-cyan);
    padding: var(--spacing-lg);
    display: flex;
    justify-content: space-between;
    align-items: center;
    backdrop-filter: blur(15px);
    position: sticky;
    top: 0;
    z-index: 100;
}

.modal-header h3 {
    color: var(--primary-cyan);
    font-family: 'Orbitron', monospace;
    font-size: var(--font-xl);
    font-weight: 700;
    margin: 0;
    text-shadow: 0 0 10px rgba(64, 224, 208, 0.5);
}

.modal-close-btn {
    background: var(--gradient-button);
    color: white;
    border: none;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    font-size: var(--font-lg);
    cursor: pointer;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 15px rgba(255, 0, 255, 0.3);
}

.modal-close-btn:hover {
    transform: scale(1.1);
    box-shadow: 0 6px 20px rgba(255, 0, 255, 0.5);
}

.modal-content {
    flex: 1;
    overflow-y: auto;
    padding: var(--spacing-lg);
}

.full-standings-table {
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: 15px;
    overflow-x: auto;
    overflow-y: hidden;
    backdrop-filter: blur(15px);
    box-shadow: var(--glass-shadow);
    -webkit-overflow-scrolling: touch; /* Smooth scrolling on iOS */
}

.full-standings-table table {
    width: 100%;
    min-width: 700px; /* Ensures horizontal scroll on narrow screens */
    border-collapse: collapse;
    background: transparent;
    border: none;
    box-shadow: none;
}

.full-standings-table th {
    background: linear-gradient(135deg, var(--deep-purple), rgba(64, 224, 208, 0.3));
    color: white;
    font-family: 'Orbitron', monospace;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    font-size: var(--font-sm);
    padding: var(--spacing-md);
    text-align: center;
    border-bottom: 2px solid var(--primary-cyan);
}

.full-standings-table td {
    padding: var(--spacing-md);
    text-align: center;
    color: var(--text-primary);
    font-size: var(--font-sm);
    border-bottom: 1px solid rgba(64, 224, 208, 0.2);
    vertical-align: top;
}

.full-standings-table .player-name {
    text-align: left;
    font-weight: 600;
}

.full-standings-table .seed-number {
    font-weight: bold;
    font-size: var(--font-lg);
}

.full-standings-table .point-diff.positive {
    color: var(--neon-green);
    font-weight: bold;
}

.full-standings-table .point-diff.negative {
    color: var(--sunset-pink);
    font-weight: bold;
}

.full-standings-table .status-playoff {
    background: linear-gradient(45deg, var(--neon-green), var(--primary-cyan));
    color: var(--dark-navy);
    padding: var(--spacing-xs) var(--spacing-sm);
    border-radius: 15px;
    font-weight: bold;
    font-size: var(--font-xs);
    text-transform: uppercase;
    letter-spacing: 1px;
}

.full-standings-table .status-eliminated {
    background: linear-gradient(45deg, var(--sunset-pink), var(--sunset-orange));
    color: white;
    padding: var(--spacing-xs) var(--spacing-sm);
    border-radius: 15px;
    font-weight: bold;
    font-size: var(--font-xs);
    text-transform: uppercase;
    letter-spacing: 1px;
}

.full-standings-table .tiebreaker-info {
    font-style: italic;
    color: var(--sunset-orange);
    font-size: var(--font-xs);
    margin-top: var(--spacing-xs);
}

.full-standings-table .partners-list {
    font-size: var(--font-xs);
    color: var(--text-secondary);
    line-height: 1.3;
}

/* Custom scrollbar for better UX */
.full-standings-table::-webkit-scrollbar {
    height: 8px;
}

.full-standings-table::-webkit-scrollbar-track {
    background: rgba(15, 15, 35, 0.5);
    border-radius: 4px;
}

.full-standings-table::-webkit-scrollbar-thumb {
    background: var(--gradient-button);
    border-radius: 4px;
    box-shadow: 0 2px 8px rgba(64, 224, 208, 0.3);
}

.full-standings-table::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(45deg, var(--primary-cyan), var(--primary-magenta));
}

@media (max-width: 767px) {
    .modal-header {
        padding: var(--spacing-md);
    }
    
    .modal-header h3 {
        font-size: var(--font-lg);
    }
    
    .modal-content {
        padding: var(--spacing-md);
    }
    
    .full-standings-table {
        /* Add subtle gradient to indicate scrollability */
        position: relative;
    }
    
    .full-standings-table::after {
        content: '';
        position: absolute;
        top: 0;
        right: 0;
        width: 20px;
        height: 100%;
        background: linear-gradient(to left, rgba(64, 224, 208, 0.1), transparent);
        pointer-events: none;
        border-radius: 0 15px 15px 0;
    }
    
    .full-standings-table th,
    .full-standings-table td {
        padding: var(--spacing-sm);
        font-size: var(--font-xs);
        white-space: nowrap; /* Prevent text wrapping */
    }
    
    .full-standings-table .seed-number {
        font-size: var(--font-base);
    }
    
    .full-standings-table .partners-list {
        max-width: 120px;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }
}

/* All Teams Modal */
.teams-list {
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: 15px;
    backdrop-filter: blur(15px);
    overflow: hidden;
}

.team-list-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-md);
    border-bottom: 1px solid rgba(64, 224, 208, 0.2);
    color: var(--text-primary);
    transition: background 0.3s ease;
}

.team-list-item:last-child {
    border-bottom: none;
}

.team-list-item:hover {
    background: rgba(64, 224, 208, 0.1);
}

.team-name {
    font-weight: 600;
    font-size: var(--font-base);
    flex: 1;
    text-align: left;
}

.team-record {
    font-family: 'Orbitron', monospace;
    font-weight: 700;
    font-size: var(--font-base);
    color: var(--primary-cyan);
}

.team-status {
    padding: var(--spacing-xs) var(--spacing-sm);
    border-radius: 12px;
    font-size: var(--font-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
    min-width: 80px;
    text-align: center;
}

.team-status.playing {
    background: linear-gradient(45deg, var(--neon-green), var(--primary-cyan));
    color: var(--dark-navy);
}

.team-status.sitting-out {
    background: linear-gradient(45deg, var(--sunset-pink), var(--sunset-orange));
    color: white;
}

.teams-stats-summary {
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: 15px;
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
    backdrop-filter: blur(15px);
}

.teams-stats-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-md);
    text-align: center;
}

.teams-stat-item {
    color: var(--text-primary);
}

.teams-stat-number {
    font-size: var(--font-2xl);
    font-weight: 800;
    font-family: 'Orbitron', monospace;
    color: var(--primary-cyan);
    display: block;
    text-shadow: 0 0 8px rgba(64, 224, 208, 0.5);
}

.teams-stat-label {
    font-size: var(--font-sm);
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-top: var(--spacing-xs);
}

@media (max-width: 767px) {
    .team-list-item {
        padding: var(--spacing-sm);
    }
    
    .team-name {
        font-size: var(--font-sm);
    }
    
    .team-record {
        font-size: var(--font-sm);
    }
    
    .teams-stats-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--spacing-sm);
    }
    
    .teams-stat-number {
        font-size: var(--font-xl);
    }
}

/* Playoff Section */
.playoffs-section {
    background: linear-gradient(135deg, rgba(15, 15, 35, 0.8), rgba(45, 27, 105, 0.6));
    border: 2px solid var(--primary-cyan);
    border-radius: 20px;
    padding: var(--spacing-lg);
    margin-top: var(--spacing-xl);
    backdrop-filter: blur(15px);
}

.playoffs-section p,
.playoffs-section div {
    color: var(--text-primary);
    line-height: 1.5;
    font-size: var(--font-base);
}

.playoffs-section .description {
    background: rgba(15, 15, 35, 0.7);
    padding: var(--spacing-md);
    border-radius: 10px;
    border-left: 4px solid var(--primary-cyan);
    margin: var(--spacing-md) 0;
}

.playoffs-header h2 {
    font-family: 'Orbitron', monospace;
    font-size: var(--font-3xl);
    color: var(--text-primary);
    text-transform: uppercase;
    letter-spacing: 2px;
    text-shadow: 0 0 15px var(--primary-cyan);
    margin-bottom: var(--spacing-md);
    text-align: center;
}

/* Championship Section */
.championship-section {
    background: linear-gradient(135deg, rgba(255, 215, 0, 0.2), rgba(255, 105, 180, 0.2)) !important;
    border: 3px solid #ffd700 !important;
    border-radius: 20px !important;
    padding: var(--spacing-xl) !important;
    margin-top: var(--spacing-xl) !important;
    position: relative;
    overflow: hidden;
    backdrop-filter: blur(15px);
    box-shadow: 0 0 50px rgba(255, 215, 0, 0.3);
}

/* Championship Header Styling */
.championship-header h2 {
    font-family: 'Orbitron', monospace !important;
    color: #ffd700 !important;
    text-align: center !important;
    font-size: var(--font-3xl) !important;
    text-shadow: 0 0 20px rgba(255, 215, 0, 0.8) !important;
    margin-bottom: var(--spacing-lg) !important;
    text-transform: uppercase;
    letter-spacing: 3px;
}

.championship-header p {
    font-size: var(--font-xl) !important;
    color: white !important;
    font-weight: 700 !important;
    text-shadow: 0 2px 8px rgba(0, 0, 0, 0.8) !important;
    margin-bottom: var(--spacing-lg) !important;
}

/* Championship Player Stats Cards */
.championship-header > div[style*="grid-template-columns"] > div {
    background: rgba(15, 15, 35, 0.9) !important;
    padding: var(--spacing-lg) !important;
    border-radius: 15px !important;
    border: 2px solid rgba(255, 215, 0, 0.5) !important;
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.4) !important;
}

.championship-header > div[style*="grid-template-columns"] > div strong {
    color: #ffd700 !important;
    font-size: var(--font-lg) !important;
    text-shadow: 0 0 10px rgba(255, 215, 0, 0.6) !important;
}

.championship-header > div[style*="grid-template-columns"] > div br + text {
    color: white !important;
    font-weight: 600 !important;
}

/* Partner Selection Styling */
.partner-selection h4 {
    color: #ffd700 !important;
    font-family: 'Orbitron', monospace !important;
    font-size: var(--font-xl) !important;
    text-shadow: 0 0 15px rgba(255, 215, 0, 0.6) !important;
    margin-bottom: var(--spacing-lg) !important;
}

.partner-selection > div[style*="grid-template-columns"] > div {
    background: rgba(15, 15, 35, 0.9) !important;
    padding: var(--spacing-lg) !important;
    border-radius: 15px !important;
    border: 2px solid var(--primary-cyan) !important;
    box-shadow: 0 8px 25px rgba(0, 255, 255, 0.2) !important;
}

.partner-selection label {
    color: white !important;
    font-weight: 700 !important;
    font-size: var(--font-base) !important;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.8) !important;
    margin-bottom: var(--spacing-sm) !important;
}

.partner-selection select {
    background: rgba(25, 25, 45, 0.9) !important;
    border: 2px solid var(--glass-border) !important;
    border-radius: 10px !important;
    padding: var(--spacing-md) !important;
    color: white !important;
    font-size: var(--font-base) !important;
    font-weight: 600;
    width: 100% !important;
}

.partner-selection select:focus {
    border-color: var(--primary-cyan) !important;
    box-shadow: 0 0 15px rgba(64, 224, 208, 0.4) !important;
}

/* Championship Teams Display */
.championship-teams > div[style*="grid-template-columns"] > div {
    background: rgba(15, 15, 35, 0.9) !important;
    padding: var(--spacing-lg) !important;
    border-radius: 15px !important;
    border: 2px solid var(--primary-cyan) !important;
    box-shadow: 0 8px 25px rgba(0, 255, 255, 0.2) !important;
}

.championship-teams h4 {
    color: white !important;
    font-family: 'Orbitron', monospace !important;
    font-size: var(--font-lg) !important;
    text-shadow: 0 0 10px var(--primary-cyan) !important;
    margin-bottom: var(--spacing-sm) !important;
}

.championship-teams > div[style*="grid-template-columns"] > div > div:last-child {
    color: white !important;
    font-size: var(--font-lg) !important;
    font-weight: 700 !important;
    text-shadow: 0 2px 6px rgba(0, 0, 0, 0.8) !important;
}

/* Championship Sets Styling */
.championship-scoring h4 {
    color: #ffd700 !important;
    font-family: 'Orbitron', monospace !important;
    font-size: var(--font-xl) !important;
    text-shadow: 0 0 15px rgba(255, 215, 0, 0.6) !important;
    margin-bottom: var(--spacing-lg) !important;
}

.championship-set {
    background: rgba(15, 15, 35, 0.9) !important;
    padding: var(--spacing-lg) !important;
    border-radius: 15px !important;
    border: 2px solid rgba(255, 215, 0, 0.3) !important;
    margin-bottom: var(--spacing-md) !important;
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.3) !important;
}

.championship-set .set-header {
    color: #ffd700 !important;
    font-family: 'Orbitron', monospace !important;
    font-size: var(--font-lg) !important;
    font-weight: 700 !important;
    text-shadow: 0 0 10px rgba(255, 215, 0, 0.6) !important;
    margin-bottom: var(--spacing-md) !important;
}

/* Championship Set Scoring */
.set-scoring label {
    color: white !important;
    font-weight: 600 !important;
    font-size: var(--font-sm) !important;
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.8) !important;
    margin-bottom: var(--spacing-xs) !important;
}

.set-scoring input[type="number"] {
    background: rgba(25, 25, 45, 0.9) !important;
    border: 2px solid var(--glass-border) !important;
    border-radius: 8px !important;
    padding: var(--spacing-sm) !important;
    color: white !important;
    font-size: var(--font-lg) !important;
    font-weight: 700 !important;
    text-align: center !important;
    width: 80px !important;
}

.set-scoring input[type="number"]:focus {
    border-color: var(--primary-cyan) !important;
    box-shadow: 0 0 10px rgba(64, 224, 208, 0.4) !important;
}

.set-scoring > div[style*="font-size: 1.2em"] {
    color: var(--sunset-pink) !important;
    font-family: 'Orbitron', monospace !important;
    text-shadow: 0 0 8px rgba(255, 105, 180, 0.6) !important;
}

/* Adjust VS placement and spacing for championship sets */
.set-vs {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 var(--spacing-lg);
    /* add vertical breathing room */
    padding-block: calc(var(--spacing-xs) + 2px);
    margin: 0 var(--spacing-sm);
    font-family: 'Orbitron', monospace;
    font-weight: 800;
    color: var(--sunset-pink);
    font-size: calc(var(--font-lg) + 2px);
    line-height: 1.6;
}

/* Give Update Set buttons breathing room above inputs */
.update-set-btn {
    margin-top: var(--spacing-md) !important;
}

/* Championship Buttons - Override inline styles */
.championship-section .btn,
.championship-section button {
    background: linear-gradient(135deg, var(--primary-cyan), var(--electric-blue)) !important;
    color: var(--dark-navy) !important;
    border: 2px solid var(--primary-cyan) !important;
    border-radius: 10px !important;
    padding: var(--spacing-md) var(--spacing-lg) !important;
    font-size: var(--font-base) !important;
    font-weight: 700 !important;
    font-family: 'Rajdhani', sans-serif !important;
    text-shadow: none !important;
    box-shadow: 0 4px 15px rgba(64, 224, 208, 0.3) !important;
    transition: all 0.3s ease !important;
    cursor: pointer !important;
    min-height: 44px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
}

.championship-section .btn:hover,
.championship-section button:hover {
    background: linear-gradient(135deg, var(--electric-blue), var(--primary-cyan)) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px rgba(64, 224, 208, 0.4) !important;
}

.championship-section .btn-success {
    background: linear-gradient(135deg, var(--neon-green), #32cd32) !important;
    border-color: var(--neon-green) !important;
    color: var(--dark-navy) !important;
}

.championship-section .btn-success:hover {
    background: linear-gradient(135deg, #32cd32, var(--neon-green)) !important;
}

.championship-section .btn-primary {
    background: linear-gradient(135deg, var(--primary-cyan), var(--electric-blue)) !important;
    border-color: var(--primary-cyan) !important;
    color: var(--dark-navy) !important;
}

/* Helper classes for championship set markup */
.set-team {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-xs);
}

.set-score-input {
    width: 80px;
    padding: 6px;
    border-radius: 8px;
    text-align: center;
    font-weight: 700;
}

.set-vs {
    font-family: 'Orbitron', monospace;
    font-weight: 800;
    color: var(--sunset-pink);
    font-size: var(--font-lg);
    padding: 0 var(--spacing-md);
}

.update-set-btn {
    margin-left: 10px;
    min-width: 140px;
}

.set-result {
    text-align: center;
    font-size: var(--font-base);
    color: white;
}

.set-winner {
    margin-top: 6px;
    color: var(--text-secondary);
}

/* Fix inline styled elements with readability issues */
div[style*="background: #e8f5e8"] {
    background: rgba(15, 15, 35, 0.9) !important;
    color: white !important;
}

div[style*="background: #f8f9fa"] {
    background: rgba(15, 15, 35, 0.9) !important;
    color: white !important;
}

div[style*="background: linear-gradient(135deg, #fff9e6, #fffbf0)"] {
    background: linear-gradient(135deg, rgba(15, 15, 35, 0.9), rgba(45, 27, 105, 0.8)) !important;
}

/* Fix playoff preview section */
.playoff-preview {
    background: rgba(15, 15, 35, 0.9) !important;
    border-left: 4px solid var(--neon-green) !important;
    padding: var(--spacing-lg) !important;
    border-radius: 15px !important;
    color: white !important;
}

/* Fix championship team displays */
.championship-teams div[style*="background: #e8f5e8"] {
    background: rgba(15, 15, 35, 0.9) !important;
}

.championship-teams div[style*="background: #f8e8e8"] {
    background: rgba(15, 15, 35, 0.9) !important;
}

/* Fix championship partner selection backgrounds */
.partner-selection div[style*="background: #f8f9fa"] {
    background: rgba(15, 15, 35, 0.9) !important;
}

/* Fix any remaining white text issues */
div[style*="color: white"] {
    color: white !important;
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.8) !important;
}

/* Fix playoff standings and table text */
table[style*="background: #fff"] th,
table[style*="background: #fff"] td {
    background: rgba(15, 15, 35, 0.9) !important;
    color: white !important;
    border: 1px solid rgba(64, 224, 208, 0.3) !important;
}

table[style*="background: #fff"] th {
    background: linear-gradient(135deg, var(--primary-cyan), var(--electric-blue)) !important;
    color: var(--dark-navy) !important;
    font-weight: 700 !important;
}

/* Fix green colored text to be more readable */
div[style*="color: #28a745"],
td[style*="color: #28a745"],
span[style*="color: #28a745"] {
    color: var(--neon-green) !important;
    text-shadow: 0 0 8px rgba(64, 255, 64, 0.6) !important;
    font-weight: 700 !important;
}

/* Fix gray colored text to be more readable */
div[style*="color: #6c757d"],
td[style*="color: #6c757d"],
span[style*="color: #6c757d"] {
    color: var(--text-secondary) !important;
    font-weight: 600 !important;
}

/* Override any white backgrounds in tables */
table {
    background: rgba(15, 15, 35, 0.95) !important;
}

/* Fix match team backgrounds in playoffs */
.playoff-round-robin .match-teams[style*="background: #e8f5e8"] {
    background: rgba(25, 25, 45, 0.9) !important;
}

/* Fix championship section white backgrounds */
.championship-section div[style*="background: #fff"] {
    background: rgba(15, 15, 35, 0.9) !important;
    color: white !important;
}

/* Fix specific inline style combinations that cause readability issues */
div[style*="background: #fff"]:not(.championship-result),
div[style*="background: white"]:not(.championship-result),
div[style*="background: #ffffff"]:not(.championship-result) {
    background: rgba(15, 15, 35, 0.9) !important;
    color: white !important;
}

/* Fix light colored backgrounds */
div[style*="background: #f8f9fa"],
div[style*="background: #e8f5e8"],
div[style*="background: #fff9e6"],
div[style*="background: #fffbf0"] {
    background: rgba(15, 15, 35, 0.9) !important;
    color: white !important;
}

/* Ensure all text in playoff sections is readable */
.playoffs-section * {
    color: inherit;
}

.playoffs-section div,
.playoffs-section span,
.playoffs-section p {
    color: white !important;
}

/* Fix any remaining problematic color combinations */
[style*="color: white"][style*="background: #fff"],
[style*="color: white"][style*="background: white"],
[style*="color: white"][style*="background: #ffffff"] {
    background: rgba(15, 15, 35, 0.9) !important;
}

/* Tournament section text improvements */
.tournament-section div[style*="background: #f"],
.tournament-section div[style*="background: white"] {
    background: rgba(15, 15, 35, 0.9) !important;
    color: white !important;
}

/* Final catch-all for readability */
.match-teams[style*="background: #e8f5e8"] * {
    color: white !important;
}

/* Individual Player Standings Table Styling */
.standings-header {
    margin-bottom: var(--spacing-lg);
}

.standings-header h4 {
    color: var(--text-primary);
    font-family: 'Orbitron', monospace;
    font-size: var(--font-xl);
    text-transform: uppercase;
    letter-spacing: 1px;
    text-shadow: 0 0 10px var(--primary-cyan);
    margin-bottom: var(--spacing-sm);
}

.standings-header p {
    color: var(--text-secondary) !important;
    font-size: var(--font-sm) !important;
    line-height: 1.4;
    margin: var(--spacing-sm) 0 !important;
}

/* Player Standings Table Container */
.tournament-display table[style*="width: 100%"],
.tournament-display table,
.standings-table table,
table[style*="border-collapse: collapse"] {
    width: 100% !important;
    border-collapse: collapse !important;
    background: rgba(5, 5, 15, 0.98) !important;
    border-radius: 15px !important;
    overflow: hidden !important;
    backdrop-filter: blur(20px) !important;
    border: 2px solid var(--primary-cyan) !important;
    box-shadow: 0 8px 32px rgba(0, 255, 255, 0.2) !important;
    margin: var(--spacing-lg) 0 !important;
    font-size: var(--font-sm) !important;
}

/* Table Headers */
.tournament-display table[style*="width: 100%"] thead tr,
.tournament-display table thead tr,
.standings-table table thead tr,
table[style*="border-collapse: collapse"] thead tr,
tr[style*="background: #f8f9fa"] {
    background: linear-gradient(135deg, var(--deep-purple), var(--primary-cyan)) !important;
}

.tournament-display table[style*="width: 100%"] th,
.tournament-display table th,
.standings-table table th,
table[style*="border-collapse: collapse"] th,
tr[style*="background: #f8f9fa"] th {
    padding: var(--spacing-md) var(--spacing-sm) !important;
    text-align: center !important;
    border: 1px solid rgba(64, 224, 208, 0.4) !important;
    color: white !important;
    font-family: 'Orbitron', monospace !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    font-size: var(--font-sm) !important;
    text-shadow: 0 0 10px rgba(0, 0, 0, 0.8) !important;
    background: linear-gradient(135deg, rgba(45, 27, 105, 0.9), rgba(64, 224, 208, 0.3)) !important;
}

/* Table Body Rows */
.tournament-display table[style*="width: 100%"] tbody tr,
.tournament-display table tbody tr,
.standings-table table tbody tr,
table[style*="border-collapse: collapse"] tbody tr,
tr[style*="background: white"],
tr[style*="background: #d4edda"] {
    background: rgba(10, 10, 25, 0.95) !important;
    transition: all 0.3s ease;
}

.tournament-display table[style*="width: 100%"] tbody tr:nth-child(even),
.tournament-display table tbody tr:nth-child(even),
.standings-table table tbody tr:nth-child(even),
table[style*="border-collapse: collapse"] tbody tr:nth-child(even) {
    background: rgba(15, 15, 30, 0.95) !important;
}

.tournament-display table[style*="width: 100%"] tbody tr:hover,
.tournament-display table tbody tr:hover,
.standings-table table tbody tr:hover,
table[style*="border-collapse: collapse"] tbody tr:hover {
    background: rgba(64, 224, 208, 0.1) !important;
    transform: scale(1.01);
}

/* Playoff Qualifier Rows - Much Darker */
.tournament-display table[style*="width: 100%"] tr[style*="background: #d4edda"],
.tournament-display table tr[style*="background: #d4edda"],
.standings-table table tr[style*="background: #d4edda"],
table[style*="border-collapse: collapse"] tr[style*="background: #d4edda"] {
    background: rgba(45, 27, 105, 0.4) !important;
    border-left: 4px solid var(--neon-green) !important;
    box-shadow: inset 0 0 20px rgba(64, 255, 64, 0.1) !important;
}

.tournament-display table[style*="width: 100%"] tr[style*="background: #d4edda"]:hover,
.tournament-display table tr[style*="background: #d4edda"]:hover,
.standings-table table tr[style*="background: #d4edda"]:hover,
table[style*="border-collapse: collapse"] tr[style*="background: #d4edda"]:hover {
    background: rgba(45, 27, 105, 0.6) !important;
}

.tournament-display table[style*="width: 100%"] tr[style*="background: #d4edda"]:nth-child(even),
.tournament-display table tr[style*="background: #d4edda"]:nth-child(even),
.standings-table table tr[style*="background: #d4edda"]:nth-child(even),
table[style*="border-collapse: collapse"] tr[style*="background: #d4edda"]:nth-child(even) {
    background: rgba(45, 27, 105, 0.5) !important;
}

/* Table Cells */
.tournament-display table[style*="width: 100%"] td,
.tournament-display table td,
.standings-table table td,
table[style*="border-collapse: collapse"] td {
    padding: var(--spacing-md) var(--spacing-sm) !important;
    border: 1px solid rgba(64, 224, 208, 0.15) !important;
    color: white !important;
    font-weight: 600 !important;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.9) !important;
    vertical-align: middle !important;
    background: transparent !important;
}

/* Seed Column Styling */
.tournament-display table[style*="width: 100%"] td:first-child,
.tournament-display table td:first-child,
.standings-table table td:first-child,
table[style*="border-collapse: collapse"] td:first-child {
    text-align: center !important;
    font-family: 'Orbitron', monospace !important;
    font-size: var(--font-lg) !important;
    font-weight: 800 !important;
    color: var(--primary-cyan) !important;
    text-shadow: 0 0 10px rgba(64, 224, 208, 0.6) !important;
}

/* Player Name Styling */
.tournament-display table[style*="width: 100%"] td:nth-child(2),
.tournament-display table td:nth-child(1):not(:only-child),
.standings-table table td:nth-child(1),
table[style*="border-collapse: collapse"] td:nth-child(1) {
    font-weight: 700 !important;
    color: white !important;
    font-size: var(--font-base) !important;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.9) !important;
}

/* Stats Columns */
.tournament-display table[style*="width: 100%"] td:nth-child(3),
.tournament-display table[style*="width: 100%"] td:nth-child(4),
.tournament-display table[style*="width: 100%"] td:nth-child(5),
.tournament-display table td:not(:first-child):not(:last-child),
.standings-table table td:not(:first-child),
table[style*="border-collapse: collapse"] td:not(:first-child) {
    text-align: center !important;
    font-family: 'Rajdhani', sans-serif !important;
    font-weight: 700 !important;
    font-size: var(--font-base) !important;
}

/* Point Differential Styling */
.tournament-display table[style*="width: 100%"] td[style*="color: #27ae60"],
.tournament-display table td[style*="color: #27ae60"],
.standings-table table td[style*="color: #27ae60"],
table[style*="border-collapse: collapse"] td[style*="color: #27ae60"] {
    color: var(--neon-green) !important;
    text-shadow: 0 0 10px rgba(64, 255, 64, 0.8) !important;
    font-weight: 800 !important;
}

.tournament-display table[style*="width: 100%"] td[style*="color: #e74c3c"],
.tournament-display table td[style*="color: #e74c3c"],
.standings-table table td[style*="color: #e74c3c"],
table[style*="border-collapse: collapse"] td[style*="color: #e74c3c"] {
    color: var(--sunset-pink) !important;
    text-shadow: 0 0 10px rgba(255, 105, 180, 0.8) !important;
    font-weight: 800 !important;
}

/* Status Column */
.tournament-display table[style*="width: 100%"] td:last-child,
.tournament-display table td:last-child,
.standings-table table td:last-child,
table[style*="border-collapse: collapse"] td:last-child {
    text-align: left !important;
    font-size: var(--font-sm) !important;
    padding-left: var(--spacing-md) !important;
}

.tournament-display table[style*="width: 100%"] td:last-child div,
.tournament-display table td:last-child div,
.standings-table table td:last-child div,
table[style*="border-collapse: collapse"] td:last-child div {
    color: white !important;
    margin-bottom: var(--spacing-xs);
    font-weight: 600 !important;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.9) !important;
}

/* Playoff Status Text Override */
.tournament-display table[style*="width: 100%"] td div[style*="color: #28a745"],
.tournament-display table td div[style*="color: #28a745"],
.standings-table table td div[style*="color: #28a745"],
table[style*="border-collapse: collapse"] td div[style*="color: #28a745"] {
    color: var(--neon-green) !important;
    text-shadow: 0 0 10px rgba(64, 255, 64, 0.6) !important;
    font-weight: 700 !important;
}

.tournament-display table[style*="width: 100%"] td div[style*="color: #6c757d"],
.tournament-display table td div[style*="color: #6c757d"],
.standings-table table td div[style*="color: #6c757d"],
table[style*="border-collapse: collapse"] td div[style*="color: #6c757d"] {
    color: var(--text-secondary) !important;
    font-weight: 600 !important;
}

/* Tiebreaker Text */
.tournament-display table[style*="width: 100%"] td div[style*="color: #856404"],
.tournament-display table td div[style*="color: #856404"],
.standings-table table td div[style*="color: #856404"],
table[style*="border-collapse: collapse"] td div[style*="color: #856404"] {
    color: var(--sunset-orange) !important;
    text-shadow: 0 0 8px rgba(255, 165, 0, 0.6) !important;
    font-style: italic !important;
    font-size: var(--font-xs) !important;
}

/* Mobile Responsive Styling */
@media (max-width: 767px) {
    /* Make tables horizontally scrollable on mobile */
    .tournament-display table[style*="width: 100%"],
    .tournament-display table,
    .standings-table table,
    table[style*="border-collapse: collapse"] {
        font-size: var(--font-xs) !important;
        display: block !important;
        overflow-x: auto !important;
        white-space: nowrap !important;
        border-radius: 10px !important;
        margin: var(--spacing-md) 0 !important;
        box-shadow: 0 4px 20px rgba(0, 255, 255, 0.15) !important;
        -webkit-overflow-scrolling: touch !important;
        /* Ensure table has proper width for all content */
        width: auto !important;
        min-width: 600px !important; /* Force minimum width to show all columns */
    }
    
    /* Mobile table headers and cells - simplified */
    .tournament-display table[style*="width: 100%"] th,
    .tournament-display table th,
    .standings-table table th,
    table[style*="border-collapse: collapse"] th {
        padding: var(--spacing-sm) var(--spacing-xs) !important;
        font-size: var(--font-xs) !important;
        line-height: 1.2 !important;
        white-space: nowrap !important;
    }
    
    .tournament-display table[style*="width: 100%"] td,
    .tournament-display table td,
    .standings-table table td,
    table[style*="border-collapse: collapse"] td {
        padding: var(--spacing-sm) var(--spacing-xs) !important;
        font-size: var(--font-xs) !important;
        line-height: 1.3 !important;
        white-space: nowrap !important;
    }
    
    /* Specific column widths for better mobile layout */
    .tournament-display table[style*="width: 100%"] th:first-child,
    .tournament-display table[style*="width: 100%"] td:first-child {
        width: 50px !important;
        min-width: 50px !important;
    }
    
    /* Player name column */
    .tournament-display table[style*="width: 100%"] th:nth-child(2),
    .tournament-display table[style*="width: 100%"] td:nth-child(2) {
        width: 100px !important;
        min-width: 100px !important;
    }
    
    /* Stats columns */
    .tournament-display table[style*="width: 100%"] th:nth-child(3),
    .tournament-display table[style*="width: 100%"] th:nth-child(4),
    .tournament-display table[style*="width: 100%"] th:nth-child(5),
    .tournament-display table[style*="width: 100%"] td:nth-child(3),
    .tournament-display table[style*="width: 100%"] td:nth-child(4),
    .tournament-display table[style*="width: 100%"] td:nth-child(5) {
        width: 70px !important;
        min-width: 70px !important;
    }
    
    /* Partners column */
    .tournament-display table[style*="width: 100%"] th:nth-child(6),
    .tournament-display table[style*="width: 100%"] td:nth-child(6) {
        width: 120px !important;
        min-width: 120px !important;
    }
    
    /* Status column - ensure it has enough space and doesn't get cut off */
    .tournament-display table[style*="width: 100%"] th:last-child,
    .tournament-display table[style*="width: 100%"] td:last-child {
        width: 150px !important;
        min-width: 150px !important;
        padding-right: var(--spacing-lg) !important;
    }
    
    /* Mobile row hover effects */
    .tournament-display table[style*="width: 100%"] tbody tr:hover,
    .tournament-display table tbody tr:hover,
    .standings-table table tbody tr:hover,
    table[style*="border-collapse: collapse"] tbody tr:hover {
        transform: none !important;
        background: rgba(64, 224, 208, 0.08) !important;
    }
}

/* Enhanced scrollbar for mobile tables */
@media (max-width: 767px) {
    .tournament-display table[style*="width: 100%"]::-webkit-scrollbar,
    .tournament-display table::-webkit-scrollbar,
    .standings-table table::-webkit-scrollbar,
    table[style*="border-collapse: collapse"]::-webkit-scrollbar {
        height: 8px !important;
        background: rgba(0, 0, 0, 0.2) !important;
        border-radius: 10px !important;
    }

    .tournament-display table[style*="width: 100%"]::-webkit-scrollbar-track,
    .tournament-display table::-webkit-scrollbar-track,
    .standings-table table::-webkit-scrollbar-track,
    table[style*="border-collapse: collapse"]::-webkit-scrollbar-track {
        background: rgba(255, 255, 255, 0.1) !important;
        border-radius: 10px !important;
        margin: 0 10px !important;
    }

    .tournament-display table[style*="width: 100%"]::-webkit-scrollbar-thumb,
    .tournament-display table::-webkit-scrollbar-thumb,
    .standings-table table::-webkit-scrollbar-thumb,
    table[style*="border-collapse: collapse"]::-webkit-scrollbar-thumb {
        background: linear-gradient(90deg, var(--primary-cyan), var(--electric-blue)) !important;
        border-radius: 10px !important;
        border: 1px solid rgba(255, 255, 255, 0.2) !important;
        box-shadow: 0 0 10px rgba(64, 224, 208, 0.4) !important;
    }

    .tournament-display table[style*="width: 100%"]::-webkit-scrollbar-thumb:hover,
    .tournament-display table::-webkit-scrollbar-thumb:hover,
    .standings-table table::-webkit-scrollbar-thumb:hover,
    table[style*="border-collapse: collapse"]::-webkit-scrollbar-thumb:hover {
        background: linear-gradient(90deg, var(--electric-blue), var(--primary-cyan)) !important;
        box-shadow: 0 0 15px rgba(64, 224, 208, 0.6) !important;
    }
}

/* Mobile table wrapper - simplified */
@media (max-width: 767px) {
    .standings-header {
        margin-bottom: var(--spacing-md) !important;
    }
    
    .standings-header h4 {
        font-size: var(--font-lg) !important;
        margin-bottom: var(--spacing-xs) !important;
    }
    
    .standings-header p {
        font-size: calc(var(--font-xs) * 0.9) !important;
        line-height: 1.3 !important;
    }
    
    /* Add scroll hint for mobile users */
    .tournament-display::before {
        content: "← Swipe table to see more columns →";
        display: block;
        text-align: center;
        color: var(--text-secondary);
        font-size: var(--font-xs);
        font-style: italic;
        margin-bottom: var(--spacing-sm);
        padding: var(--spacing-xs);
        background: rgba(64, 224, 208, 0.1);
        border-radius: 20px;
        border: 1px solid rgba(64, 224, 208, 0.2);
    }
}

/* Championship Result */
.championship-result {
    background: linear-gradient(135deg, rgba(255, 215, 0, 0.9), rgba(255, 165, 0, 0.7)) !important;
    padding: var(--spacing-xl) !important;
    border-radius: 20px !important;
    text-align: center !important;
    margin-top: var(--spacing-xl) !important;
    border: 3px solid #ffd700 !important;
    box-shadow: 0 0 40px rgba(255, 215, 0, 0.5) !important;
}

.championship-result h3 {
    color: var(--dark-navy) !important;
    font-family: 'Orbitron', monospace !important;
    font-size: var(--font-2xl) !important;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3) !important;
    margin-bottom: var(--spacing-md) !important;
}

.championship-result > div {
    color: var(--dark-navy) !important;
    font-size: var(--font-xl) !important;
    font-weight: 800 !important;
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.2) !important;
}

/* Additional Championship Text Overrides */
.championship-section * {
    color: inherit;
}

.championship-section div:not(.championship-result div):not(.set-scoring div):not(.championship-teams div):not(.partner-selection div) {
    color: white !important;
}

.championship-section .set-result {
    color: white !important;
    font-weight: 700 !important;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.8) !important;
}

.championship-section .set-result strong {
    color: #ffd700 !important;
    font-size: var(--font-xl) !important;
    text-shadow: 0 0 10px rgba(255, 215, 0, 0.6) !important;
}

.championship-section .set-result div[style*="color: #666"] {
    color: var(--text-secondary) !important;
    font-weight: 600 !important;
}

/* Playoff Qualifiers Styling */
.players-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-md);
    margin: var(--spacing-lg) 0;
}

@media (max-width: 768px) {
    .players-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--spacing-sm);
    }
}

@media (max-width: 480px) {
    .players-grid {
        grid-template-columns: 1fr;
    }
}

.playoff-player-card {
    background: linear-gradient(135deg, var(--neon-green), var(--primary-cyan)) !important;
    color: var(--dark-navy) !important;
    padding: var(--spacing-lg) !important;
    border-radius: 15px !important;
    text-align: center !important;
    box-shadow: 0 8px 25px rgba(0, 255, 255, 0.3);
    border: 2px solid rgba(255, 255, 255, 0.2);
    transition: all 0.3s ease;
    margin-bottom: var(--spacing-md);
}

.playoff-player-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 12px 35px rgba(0, 255, 255, 0.4);
}

.playoff-player-card div:first-child {
    font-size: var(--font-xl) !important;
    font-weight: 800 !important;
    font-family: 'Orbitron', monospace !important;
    color: var(--dark-navy) !important;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
    margin-bottom: var(--spacing-xs);
}

.playoff-player-card div:last-child {
    font-size: var(--font-base) !important;
    opacity: 0.85 !important;
    color: var(--dark-navy) !important;
    font-weight: 600;
}

/* Playoff Matches Container */
.matches-container {
    display: grid;
    gap: var(--spacing-lg);
    margin-top: var(--spacing-lg);
}

/* Enhanced Match Card Styling for Playoffs */
.playoff-round-robin .match {
    background: rgba(15, 15, 35, 0.95) !important;
    border: 2px solid var(--neon-green) !important;
    border-radius: 15px;
    box-shadow: 0 8px 25px rgba(64, 255, 64, 0.2);
    margin-bottom: var(--spacing-lg) !important;
}

.playoff-round-robin .match-header {
    background: linear-gradient(135deg, var(--neon-green), var(--primary-cyan)) !important;
    color: var(--dark-navy) !important;
    font-weight: 700;
    padding: var(--spacing-md) var(--spacing-lg);
}

.playoff-round-robin .match-teams {
    background: rgba(25, 25, 45, 0.9) !important;
    padding: var(--spacing-lg) !important;
    border-radius: 10px !important;
    margin: var(--spacing-md) 0 !important;
}

.playoff-round-robin .team-name {
    color: white !important;
    font-weight: 700 !important;
    font-size: var(--font-lg) !important;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.8);
    padding: var(--spacing-sm) 0;
}

.playoff-round-robin .match-teams .team-name[style*="bold"] {
    color: var(--neon-green) !important;
    text-shadow: 0 0 10px rgba(64, 255, 64, 0.6);
}

.playoff-round-robin .match-teams div[style*="vs"] {
    color: var(--sunset-pink) !important;
    font-weight: 700 !important;
    font-family: 'Orbitron', monospace !important;
}

.championship-section::before {
    content: '🏆';
    position: absolute;
    top: -10px;
    right: -10px;
    font-size: 3rem;
    opacity: 0.1;
    animation: floating 6s ease-in-out infinite;
}

.championship-header h2 {
    font-family: 'Orbitron', monospace;
    color: #ffd700;
    text-align: center;
    font-size: var(--font-2xl);
    text-shadow: 0 0 20px rgba(255, 215, 0, 0.5);
    margin-bottom: var(--spacing-md);
}

/* Status Badges */
.status-badge {
    padding: var(--spacing-xs) var(--spacing-sm);
    border-radius: 20px;
    font-size: var(--font-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.status-badge.completed {
    background: linear-gradient(45deg, var(--neon-green), #32cd32);
    color: white;
}

.status-badge.pending {
    background: linear-gradient(45deg, var(--sunset-orange), #ffa500);
    color: white;
}

/* Notification System */
.notification {
    position: fixed;
    top: 20px;
    right: 20px;
    padding: var(--spacing-md) var(--spacing-lg);
    border-radius: 10px;
    color: white;
    font-weight: 600;
    z-index: 1000;
    animation: slideIn 0.3s ease;
    backdrop-filter: blur(20px);
    border: 1px solid var(--glass-border);
}

@keyframes slideIn {
    from { transform: translateX(100%); opacity: 0; }
    to { transform: translateX(0); opacity: 1; }
}

.notification.success {
    background: linear-gradient(45deg, var(--neon-green), rgba(57, 255, 20, 0.8));
}

.notification.error {
    background: linear-gradient(45deg, #ff1744, rgba(255, 23, 68, 0.8));
}

.notification.info {
    background: linear-gradient(45deg, var(--electric-blue), rgba(0, 127, 255, 0.8));
}

/* Mobile Responsive Adjustments */
@media (max-width: 767px) {
    .match-teams {
        grid-template-columns: 1fr;
        gap: var(--spacing-sm);
        text-align: center;
    }
    
    .vs {
        order: 2;
    }
    
    .score-input {
        grid-template-columns: 1fr 1fr;
        gap: var(--spacing-md);
    }
    
    .standings-table,
    table {
        font-size: var(--font-sm);
    }
    
    .standings-table th,
    .standings-table td,
    th, td {
        padding: var(--spacing-xs) var(--spacing-sm);
    }
    
    .championship-header h2 {
        font-size: var(--font-xl);
    }

    /* Use a fluid heading variable for finals/important names on mobile */
    .champion-name, .runner-up-name, .championship-header p {
        font-size: var(--fluid-heading) !important;
    }

    /* Compact championship layout for small screens */
    .championship-section {
        padding: calc(var(--spacing-md)) !important;
        margin: var(--spacing-md) 0 !important;
        border-radius: 12px !important;
    }

    .championship-section .championship-teams,
    .championship-section .partner-selection {
        display: block !important;
    }

    .championship-section .match-teams {
        display: flex !important;
        flex-direction: column !important;
        gap: var(--spacing-sm) !important;
        padding: var(--spacing-sm) !important;
    }

    .championship-section .sets-container {
        display: flex !important;
        flex-direction: column !important;
        gap: var(--spacing-sm) !important;
    }

    .championship-set {
        padding: var(--spacing-sm) !important;
        margin-bottom: var(--spacing-sm) !important;
    }

    .set-scoring input[type="number"], .set-score-input {
        width: 60px !important;
        font-size: 0.95rem !important;
    }

    .update-set-btn {
        width: 100% !important;
        margin-left: 0 !important;
        margin-top: 8px !important;
        padding: 10px !important;
        font-size: 0.95rem !important;
    }

    .championship-result {
        padding: var(--spacing-md) !important;
        margin-top: var(--spacing-sm) !important;
    }

    /* Ensure finals container occupies available width and is centered */
    #finals-container, .finals-display {
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
    }
    
    .playoffs-header h2 {
        font-size: var(--font-2xl);
    }
}

/* Scrollbar Styling */
::-webkit-scrollbar {
    width: 8px;
}

::-webkit-scrollbar-track {
    background: rgba(255, 255, 255, 0.1);
    border-radius: 10px;
}

::-webkit-scrollbar-thumb {
    background: var(--gradient-neon);
    border-radius: 10px;
}

::-webkit-scrollbar-thumb:hover {
    background: var(--gradient-button);
}

/* Loading States */
.loading {
    position: relative;
    color: transparent;
}

.loading::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(90deg, transparent, var(--primary-cyan), transparent);
    animation: shimmer 1.5s infinite;
}

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

/* Accessibility Improvements */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* Focus States for Accessibility */
.btn:focus,
.player-input:focus,
input:focus,
select:focus {
    outline: 3px solid var(--primary-cyan);
    outline-offset: 2px;
}

/* High Contrast Mode Support */
@media (prefers-contrast: high) {
    :root {
        --glass-bg: rgba(0, 0, 0, 0.8);
        --glass-border: rgba(255, 255, 255, 0.8);
    }
}

/* PWA Status Bar Theming */
/* Ensure dark status bar for PWA on mobile devices */
@media (display-mode: standalone) {
    html {
        /* Force dark color scheme for PWA */
        color-scheme: dark;
        /* Fix iOS background color bleed */
        background-color: var(--darker-navy);
    }
    
    /* Ensure proper status bar styling on iOS and Android */
    body {
        /* Add safe area support for devices with notches */
        padding-top: env(safe-area-inset-top);
        padding-left: env(safe-area-inset-left);
        padding-right: env(safe-area-inset-right);
        padding-bottom: env(safe-area-inset-bottom);
        
        /* Fix iOS background color issues */
        background: var(--gradient-sunset);
        background-attachment: fixed;
        min-height: 100vh;
        min-height: 100dvh; /* Dynamic viewport height for iOS */
    }
}

/* iOS-specific PWA fixes */
@supports (-webkit-touch-callout: none) {
    /* This targets iOS Safari specifically */
    @media (display-mode: standalone) {
        html {
            /* Completely override iOS PWA background */
            color-scheme: normal !important;
            background: linear-gradient(135deg, #0a0a15 0%, #2d1b69 30%, #4a0e4e 60%, #1a1a2e 100%) !important;
            background-attachment: fixed !important;
            /* Fix iOS color space issues */
            -webkit-print-color-adjust: exact !important;
            print-color-adjust: exact !important;
        }
        
        body {
            /* Override iOS default body styling in PWA mode */
            background: linear-gradient(135deg, #0a0a15 0%, #2d1b69 30%, #4a0e4e 60%, #1a1a2e 100%) !important;
            background-attachment: fixed !important;
            color: #ffffff !important;
            /* Fix iOS viewport issues */
            min-height: 100vh;
            min-height: -webkit-fill-available;
            
            /* Fix iOS rubber band scrolling background */
            overscroll-behavior: none;
            -webkit-overflow-scrolling: touch;
        }
        
        /* Fix iOS color inconsistencies in glassmorphism */
        .card,
        .player-setup-card,
        .tournament-section {
            background: rgba(15, 15, 35, 0.85) !important;
            border: 1px solid rgba(64, 224, 208, 0.4) !important;
            backdrop-filter: blur(15px) !important;
            -webkit-backdrop-filter: blur(15px) !important;
            /* Force iOS to render colors correctly */
            -webkit-transform: translateZ(0);
            transform: translateZ(0);
        }
        
        /* Force proper gradient rendering on iOS */
        .header {
            background: rgba(15, 15, 35, 0.85) !important;
            border: 1px solid rgba(64, 224, 208, 0.4) !important;
            backdrop-filter: blur(20px) !important;
            -webkit-backdrop-filter: blur(20px) !important;
            -webkit-transform: translateZ(0);
            transform: translateZ(0);
        }
        
        /* Fix iOS button gradient rendering */
        .btn-primary {
            background: linear-gradient(45deg, #da70d6, #40e0d0) !important;
            border: none !important;
            color: #0a0a15 !important;
            font-weight: 600 !important;
            -webkit-transform: translateZ(0);
            transform: translateZ(0);
        }
        
        /* Ensure neon effects render properly on iOS */
        .title {
            text-shadow: 0 0 5px rgba(64, 224, 208, 0.6), 0 0 10px rgba(64, 224, 208, 0.4), 0 0 15px rgba(64, 224, 208, 0.3);
            -webkit-font-smoothing: antialiased;
            -moz-osx-font-smoothing: grayscale;
            color: #ffffff !important;
        }
        
        /* Fix iOS animation and glow rendering */
        @keyframes neonGlow {
            0%, 100% {
                text-shadow: 
                    0 0 5px rgba(64, 224, 208, 0.6),
                    0 0 10px rgba(64, 224, 208, 0.4),
                    0 0 15px rgba(64, 224, 208, 0.3);
            }
            50% {
                text-shadow: 
                    0 0 8px rgba(64, 224, 208, 0.8),
                    0 0 15px rgba(64, 224, 208, 0.6),
                    0 0 20px rgba(64, 224, 208, 0.4);
            }
        }
    }
}

/* Additional iOS color fixes for all modes */
@supports (-webkit-touch-callout: none) {
    /* Force consistent rendering on all iOS devices */
    * {
        -webkit-tap-highlight-color: rgba(64, 224, 208, 0.2) !important;
        -webkit-touch-callout: none;
    }
    
    /* Override iOS system colors completely using background image */
    html {
        background: #0a0a15 !important;
        background-image: 
            radial-gradient(circle at 20% 80%, rgba(45, 27, 105, 0.8) 0%, transparent 50%),
            radial-gradient(circle at 80% 20%, rgba(74, 14, 78, 0.8) 0%, transparent 50%),
            radial-gradient(circle at 40% 40%, rgba(26, 26, 46, 0.8) 0%, transparent 50%) !important;
        background-attachment: fixed !important;
        min-height: 100vh !important;
        color-scheme: normal !important;
        -webkit-appearance: none !important;
    }
    
    body {
        background: transparent !important;
        color: #ffffff !important;
        -webkit-appearance: none !important;
    }
    
    /* Force main container backgrounds */
    .container {
        background: rgba(10, 10, 21, 0.9) !important;
        min-height: 100vh !important;
    }
    
    /* Fix iOS gradient rendering issues */
    .gradient-button,
    .btn-primary {
        background: #da70d6 !important;
        background-image: linear-gradient(45deg, #da70d6 0%, #40e0d0 100%) !important;
        color: #0a0a15 !important;
        -webkit-background-clip: padding-box !important;
        background-clip: padding-box !important;
        -webkit-appearance: none !important;
        border: none !important;
    }
    
    /* Force card backgrounds on iOS using solid colors with opacity */
    .card,
    .player-setup-card,
    .tournament-section {
        background: #0f0f23 !important;
        background-image: 
            linear-gradient(rgba(15, 15, 35, 0.95), rgba(15, 15, 35, 0.95)),
            radial-gradient(circle at center, rgba(64, 224, 208, 0.1) 0%, transparent 70%) !important;
        border: 1px solid rgba(64, 224, 208, 0.4) !important;
        -webkit-backdrop-filter: none !important;
        backdrop-filter: none !important;
        -webkit-appearance: none !important;
    }
    
    /* Header specific styling */
    .header {
        background: #0f0f23 !important;
        background-image: linear-gradient(rgba(15, 15, 35, 0.95), rgba(15, 15, 35, 0.95)) !important;
        -webkit-appearance: none !important;
    }
    
    /* Ensure all text is white on iOS */
    h1, h2, h3, h4, h5, h6, p, span, div, label {
        color: #ffffff !important;
        text-shadow: none !important;
    }
    
    /* Force input styling on iOS */
    input, select, textarea {
        background: #0f0f23 !important;
        color: #ffffff !important;
        border: 1px solid rgba(64, 224, 208, 0.4) !important;
        -webkit-appearance: none !important;
        -webkit-border-radius: 8px !important;
    }
    
    /* Remove any iOS specific styling that might interfere */
    input[type="text"], input[type="email"], input[type="number"], select, textarea {
        -webkit-appearance: none !important;
        -webkit-border-radius: 8px !important;
    }
}

/* Android PWA theming support */
@media (display-mode: standalone) and (max-width: 767px) {
    /* Ensure the app uses dark theming on Android */
    :root {
        --status-bar-theme: dark;
    }
}

/* Finals wrapper adjustments to allow the finals content to expand */
.finals-section {
    width: 100%;
    padding: 0; /* rely on inner finals content for spacing */
    margin: 0 0 var(--spacing-md) 0;
}

.finals-wrapper {
    width: 100%;
    display: block;
    padding: var(--spacing-md);
    box-sizing: border-box;
    background: transparent; /* remove redundant card background */
    border: none !important;
}

@media (max-width: 767px) {
    .finals-wrapper {
        padding: calc(var(--spacing-sm));
    }
}

/* PWA Install Banner Styles */
.pwa-install-banner {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;
    background: linear-gradient(135deg, var(--deep-purple) 0%, var(--primary-magenta) 100%);
    border-bottom: 2px solid var(--primary-cyan);
    box-shadow: 0 4px 20px rgba(64, 224, 208, 0.3);
    animation: slideDown 0.5s ease-out;
}

.pwa-banner-content {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-sm) var(--spacing-md);
    max-width: 1200px;
    margin: 0 auto;
}

.pwa-banner-text {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    color: var(--text-primary);
    font-size: var(--font-sm);
    font-weight: 500;
}

.pwa-banner-text i {
    color: var(--primary-cyan);
    font-size: var(--font-base);
}

.pwa-banner-buttons {
    display: flex;
    gap: var(--spacing-sm);
    align-items: center;
}

.pwa-install-banner .btn {
    font-size: var(--font-xs);
    padding: var(--spacing-xs) var(--spacing-sm);
    border-radius: 6px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.pwa-install-banner .btn-primary {
    background: linear-gradient(45deg, var(--primary-cyan), var(--neon-green));
    color: var(--dark-navy);
    border: none;
}

.pwa-install-banner .btn-secondary {
    background: transparent;
    color: var(--text-secondary);
    border: 1px solid rgba(255, 255, 255, 0.2);
}

.pwa-install-banner .btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(64, 224, 208, 0.4);
}

/* Animation for banner */
@keyframes slideDown {
    from {
        transform: translateY(-100%);
        opacity: 0;
    }
    to {
        transform: translateY(0);
        opacity: 1;
    }
}

/* Adjust body padding when banner is shown */
body.pwa-banner-shown {
    padding-top: 60px;
}

/* Mobile responsive adjustments for PWA banner */
@media (max-width: 767px) {
    .pwa-banner-content {
        flex-direction: column;
        gap: var(--spacing-sm);
        padding: var(--spacing-sm);
        text-align: center;
    }
    
    .pwa-banner-text {
        font-size: var(--font-xs);
        justify-content: center;
    }
    
    .pwa-banner-buttons {
        justify-content: center;
        width: 100%;
    }
    
    .pwa-install-banner .btn {
        flex: 1;
        max-width: 120px;
    }
    
    body.pwa-banner-shown {
        padding-top: 80px;
    }
}
