/* ═══════════════════════════════════════════════════════════════════
   PLAY SCREEN - Mode Selection & Queue
   ═══════════════════════════════════════════════════════════════════ */

.play-screen {
    padding: var(--spacing-md);
}

/* Active Match Banner (Background Gaming) */
.active-match-banner {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    background: linear-gradient(135deg, rgba(255, 193, 7, 0.2) 0%, rgba(255, 152, 0, 0.15) 100%);
    border: 2px solid var(--color-warning);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
    animation: pulse-glow 2s ease-in-out infinite;
}

@keyframes pulse-glow {
    0%, 100% { box-shadow: 0 0 5px rgba(255, 193, 7, 0.3); }
    50% { box-shadow: 0 0 15px rgba(255, 193, 7, 0.6); }
}

.active-match-icon {
    font-size: 2rem;
    flex-shrink: 0;
}

.active-match-info {
    flex: 1;
}

.active-match-title {
    font-size: 0.9rem;
    font-weight: bold;
    color: var(--color-warning);
}

.active-match-subtitle {
    font-size: 0.75rem;
    color: var(--color-text-muted);
}

.active-match-rejoin {
    flex-shrink: 0;
    padding: var(--spacing-sm) var(--spacing-md);
}

/* Practice Mode Section */
.play-practice {
    background: linear-gradient(135deg, rgba(0, 200, 100, 0.1) 0%, rgba(68, 255, 68, 0.05) 100%);
    border: 1px solid rgba(0, 200, 100, 0.3);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
}

.play-mode-title {
    font-size: 0.9rem;
    font-weight: bold;
    color: var(--color-success);
    margin-bottom: var(--spacing-sm);
}

.play-mode-subtitle {
    font-size: 0.7rem;
    color: var(--color-text-muted);
    margin-bottom: var(--spacing-md);
}

/* Difficulty Selection */
.difficulty-selector {
    display: flex;
    gap: var(--spacing-xs);
    margin-bottom: var(--spacing-md);
}

.difficulty-btn {
    flex: 1;
    padding: var(--spacing-sm);
    border-radius: var(--radius-sm);
    cursor: pointer;
    border: 2px solid;
    background: rgba(255, 255, 255, 0.05);
    font-size: 0.7rem;
    font-weight: bold;
    transition: all var(--transition-fast);
    min-height: var(--min-touch-target);
}

.difficulty-btn:hover {
    opacity: 0.8;
}

.difficulty-btn.easy {
    border-color: var(--color-success);
    color: var(--color-success);
}

.difficulty-btn.easy.selected {
    background: rgba(68, 255, 68, 0.2);
}

.difficulty-btn.normal {
    border-color: var(--color-gold);
    color: var(--color-gold);
}

.difficulty-btn.normal.selected {
    background: rgba(255, 215, 0, 0.2);
}

.difficulty-btn.hard {
    border-color: var(--color-danger);
    color: var(--color-danger);
}

.difficulty-btn.hard.selected {
    background: rgba(255, 68, 68, 0.2);
}

/* Ranked Mode Section */
.play-ranked {
    background: linear-gradient(135deg, rgba(147, 112, 219, 0.1) 0%, rgba(138, 43, 226, 0.05) 100%);
    border: 1px solid rgba(147, 112, 219, 0.3);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
}

.play-ranked.locked {
    opacity: 0.7;
}

.ranked-title {
    color: var(--color-purple) !important;
}

/* Weekly Bonus Pool */
.weekly-bonus-pool {
    background: linear-gradient(135deg, rgba(0, 200, 255, 0.1) 0%, rgba(100, 150, 255, 0.05) 100%);
    border: 1px solid rgba(0, 200, 255, 0.3);
    border-radius: var(--radius-md);
    padding: var(--spacing-sm) var(--spacing-md);
    margin-bottom: var(--spacing-md);
}

.bonus-pool-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 2px 0;
}

.bonus-pool-label {
    font-size: 0.7rem;
    font-weight: bold;
    color: rgba(0, 200, 255, 0.9);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.bonus-pool-value {
    font-size: 1rem;
    font-weight: bold;
    color: rgba(0, 200, 255, 1);
    text-shadow: 0 0 8px rgba(0, 200, 255, 0.4);
}

.bonus-pool-detail {
    font-size: 0.65rem;
    color: var(--color-text-muted);
}

.bonus-pool-detail-value {
    font-size: 0.7rem;
    font-weight: bold;
    color: var(--color-text-secondary);
}

/* Free Token Indicator */
.free-token-indicator {
    background: linear-gradient(135deg, rgba(147, 112, 219, 0.2) 0%, rgba(138, 43, 226, 0.1) 100%);
    border: 1px solid rgba(147, 112, 219, 0.5);
    border-radius: var(--radius-md);
    padding: var(--spacing-sm) var(--spacing-md);
    margin-bottom: var(--spacing-md);
}

.free-token-badge {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-sm);
}

.free-token-icon {
    font-size: 1.2rem;
}

.free-token-count {
    font-size: 1.1rem;
    font-weight: bold;
    color: var(--color-purple);
}

.free-token-label {
    font-size: 0.75rem;
    color: var(--color-text-muted);
}

.use-free-token-toggle {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: 0.75rem;
    color: var(--color-purple);
    cursor: pointer;
}

.use-free-token-toggle input {
    width: auto;
    min-height: auto;
    accent-color: var(--color-purple);
}

/* Ranked Locked Notice */
.ranked-locked-notice {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-md);
    background: rgba(255, 140, 0, 0.15);
    border: 1px solid rgba(255, 140, 0, 0.4);
    border-radius: var(--radius-md);
    margin-bottom: var(--spacing-md);
    font-size: 0.75rem;
    color: var(--color-gold);
}

.ranked-locked-icon {
    font-size: 1.2rem;
}

/* Ranked Streak Display */
.ranked-streak-display {
    background: linear-gradient(135deg, rgba(255, 140, 0, 0.2) 0%, rgba(255, 80, 0, 0.1) 100%);
    border: 1px solid rgba(255, 140, 0, 0.5);
    border-radius: var(--radius-md);
    padding: var(--spacing-sm) var(--spacing-md);
    margin-bottom: var(--spacing-md);
}

.streak-info {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    margin-bottom: var(--spacing-xs);
}

.streak-icon {
    font-size: 1.2rem;
    animation: flame 0.5s infinite alternate;
}

@keyframes flame {
    from { transform: scale(1); }
    to { transform: scale(1.1); }
}

.streak-label {
    font-size: 0.7rem;
    font-weight: bold;
    color: var(--color-gold);
    letter-spacing: 0.5px;
}

.streak-count {
    font-size: 1.3rem;
    font-weight: bold;
    color: var(--color-gold);
    text-shadow: 0 0 10px rgba(255, 140, 0, 0.5);
}

.streak-wins {
    font-size: 0.75rem;
    color: var(--color-text-muted);
}

.streak-next {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    font-size: 0.7rem;
    color: var(--color-text-muted);
    padding-top: var(--spacing-xs);
    border-top: 1px solid rgba(255, 140, 0, 0.2);
}

.streak-next-label {
    color: var(--color-text-muted);
}

.streak-next-value {
    font-weight: bold;
    color: var(--color-gold);
}

.streak-next-wins {
    color: var(--color-text-muted);
}

.streak-next-reward {
    font-weight: bold;
    color: var(--color-success);
    margin-left: auto;
}

.streak-max {
    color: var(--color-gold);
    font-weight: bold;
}

.tier-btn.disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.btn-disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.play-section-label {
    font-size: 0.7rem;
    color: var(--color-text-muted);
    margin-bottom: var(--spacing-sm);
}

/* Tier Selection (legacy, kept for custom match compatibility) */
.tier-selector {
    display: flex;
    gap: var(--spacing-xs);
    margin-bottom: var(--spacing-md);
}

.tier-btn {
    flex: 1;
    padding: var(--spacing-sm);
    border-radius: var(--radius-md);
    cursor: pointer;
    border: 2px solid;
    background: rgba(255, 255, 255, 0.05);
    font-weight: bold;
    font-size: 0.85rem;
    transition: all var(--transition-fast);
    text-align: center;
    min-height: var(--min-touch-target);
}

.tier-btn.active {
    box-shadow: 0 0 10px currentColor;
}

/* Queue Status */
.queue-status {
    text-align: center;
    font-size: 0.85rem;
    margin-top: var(--spacing-sm);
    padding: var(--spacing-md);
    background: var(--color-bg-dark);
    border-radius: var(--radius-md);
}

.queue-status-searching {
    color: var(--color-gold);
    animation: pulse 1.5s infinite;
}

.queue-status-found {
    color: var(--color-success);
}

/* Custom Match Expandable */
.custom-match-section {
    margin-top: var(--spacing-md);
}

.custom-match-toggle {
    cursor: pointer;
    font-size: 0.7rem;
    color: var(--color-text-muted);
    padding: var(--spacing-sm);
    background: var(--color-bg-dark);
    border-radius: var(--radius-md);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.custom-match-toggle:hover {
    color: var(--color-text-secondary);
}

.custom-match-content {
    padding: var(--spacing-md);
    background: var(--color-bg-dark);
    border-radius: 0 0 var(--radius-md) var(--radius-md);
    margin-top: -1px;
}

.custom-match-buttons {
    display: flex;
    gap: var(--spacing-xs);
    margin-top: var(--spacing-sm);
}

.custom-match-buttons .btn {
    flex: 1;
    font-size: 0.7rem;
    padding: var(--spacing-xs) var(--spacing-sm);
}

/* Auto Battle Toggle */
.auto-battle-toggle {
    margin-top: var(--spacing-md);
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: 0.7rem;
}

.auto-battle-toggle input {
    width: auto;
    min-height: auto;
}

/* Connection Required Message */
.connection-required {
    text-align: center;
    padding: var(--spacing-xl);
    background: var(--color-bg-dark);
    border-radius: var(--radius-lg);
    margin-bottom: var(--spacing-lg);
}

.connection-required-icon {
    font-size: 2rem;
    margin-bottom: var(--spacing-sm);
}

.connection-required-text {
    color: var(--color-text-muted);
    margin-bottom: var(--spacing-md);
}

/* Server Status */
.server-status {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-lg);
    padding: var(--spacing-sm);
    background: var(--color-bg-dark);
    border-radius: var(--radius-md);
}

.server-status-text {
    font-size: 0.8rem;
}

.server-status.connected .server-status-text {
    color: var(--color-success);
}

.server-status.disconnected .server-status-text {
    color: var(--color-danger);
}

/* ═══════════════════════════════════════════════════════════════════
   MULTI-GAME SELECTOR
   ═══════════════════════════════════════════════════════════════════ */

.multi-game-selector {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    margin-top: var(--spacing-xs);
}

.multi-game-label {
    font-size: 0.75rem;
    color: var(--color-text-dim);
    white-space: nowrap;
}

.multi-game-btn {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    color: var(--color-text-dim);
    padding: 4px 10px;
    border-radius: var(--radius-sm);
    cursor: pointer;
    font-size: 0.8rem;
    transition: all 0.15s;
}

.multi-game-btn:hover {
    border-color: var(--color-purple);
    color: var(--color-text-primary);
}

.multi-game-btn.active {
    background: rgba(128, 0, 255, 0.2);
    border-color: var(--color-purple);
    color: var(--color-text-primary);
    font-weight: bold;
}

.multi-game-summary {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    background: rgba(128, 0, 255, 0.1);
    border: 1px solid rgba(128, 0, 255, 0.3);
    border-radius: var(--radius-md);
    padding: var(--spacing-sm) var(--spacing-md);
    margin-bottom: var(--spacing-sm);
    flex-wrap: wrap;
}

.multi-game-summary-title {
    font-size: 0.75rem;
    color: var(--color-text-dim);
    flex: 1;
}

.multi-game-summary-stats {
    display: flex;
    gap: 4px;
    align-items: center;
    font-weight: bold;
    font-size: 1rem;
}

.mgs-win { color: #44ffaa; }
.mgs-loss { color: #ff6666; }
.mgs-draw { color: #ffd700; }
.mgs-sep { color: var(--color-text-dim); }
