@media (max-width: 480px) {
    .title {
        max-width: 220px !important;
    }
    
    .subtitle {
        font-size: 0.8rem !important;
        letter-spacing: 1px !important;
    }
    
    .main-menu {
        grid-template-columns: 1fr !important;
        gap: 20px !important;
    }
    
    .menu-card {
        padding: 25px 20px !important;
    }
    
    .menu-card-icon {
        font-size: 3rem !important;
        margin-bottom: 15px !important;
    }
    
    .menu-card-title {
        font-size: 1.8rem !important;
        margin-bottom: 12px !important;
    }
    
    .menu-card-desc {
        font-size: 0.9rem !important;
    }
    
    .config-area {
        padding: 20px 15px !important;
        margin-top: 15px !important;
    }
    
    .config-title {
        font-size: 1.8rem !important;
    }
    
    .controls-section {
        grid-template-columns: 1fr !important;
        gap: 20px !important;
    }
    
    .control-group {
        padding: 20px 15px !important;
    }
    
    .start-training-btn {
        width: 100% !important;
        font-size: 1.2rem !important;
        padding: 18px 20px !important;
        margin: 20px 0 !important;
    }
    
    .back-btn {
        padding: 12px 16px !important;
        font-size: 0.8rem !important;
    }
    
    .beat-grid {
        grid-template-columns: 1fr !important;
        gap: 12px !important;
    }
    
    .beat-option {
        padding: 12px !important;
        text-align: center;
    }
    
    .category-filter {
        flex-direction: column !important;
        gap: 8px !important;
    }
    
    .category-chip {
        text-align: center;
        padding: 12px 16px !important;
        font-size: 0.8rem !important;
    }
    
    select, input {
        padding: 14px 12px !important;
        font-size: 1rem !important;
    }
    
    .control-btn {
        min-width: 100px !important;
        padding: 14px 16px !important;
        font-size: 0.8rem !important;
        margin: 5px !important;
    }
    
    .beat-controls-buttons {
        flex-direction: column !important;
        align-items: center !important;
        gap: 10px !important;
    }
    
    .beat-controls-buttons .control-btn {
        min-width: 200px !important;
    }
}

@media (min-width: 481px) and (max-width: 768px) {
    .title {
        max-width: 250px !important;
    }
    
    .main-menu {
        grid-template-columns: 1fr !important;
        gap: 25px !important;
    }
    
    .controls-section {
        grid-template-columns: 1fr !important;
    }
    
    .beat-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 15px !important;
    }
    
    .beat-controls-buttons {
        flex-wrap: wrap !important;
        justify-content: center !important;
    }
    
    .control-btn {
        min-width: 140px !important;
    }
}

@media (max-width: 768px) {
    .training-screen {
        padding: 15px 10px !important;
    }
    
    .training-header {
        flex-direction: column !important;
        gap: 15px !important;
        margin-bottom: 20px !important;
    }
    
    .training-info {
        justify-content: center !important;
        flex-wrap: wrap !important;
        gap: 15px !important;
    }
    
    .info-item {
        padding: 8px 12px !important;
        font-size: 0.9rem !important;
    }
    
    .info-label {
        font-size: 0.7rem !important;
    }
    
    .info-value {
        font-size: 0.9rem !important;
    }
    
    .training-center {
        gap: 15px !important;
        margin-bottom: 15px !important;
    }
    
    .timer-display {
        font-size: 3rem !important;
        margin: 5px 0 !important;
    }
    
    .word-container {
        width: 95% !important;
        max-width: none !important;
        height: 180px !important;
        padding: 30px 15px !important;
        margin: 10px auto !important;
    }
    
    .current-word {
        font-size: 1.8rem !important;
        letter-spacing: 2px !important;
        line-height: 1.2 !important;
        text-align: center !important;
        hyphens: auto !important;
        word-break: break-word !important;
    }
    
    .beat-controls {
        margin: 15px 0 !important;
        padding: 12px !important;
    }
    
    .beat-controls-title {
        font-size: 0.9rem !important;
        margin-bottom: 12px !important;
    }
}

@media (max-width: 768px) {
    .battle-screen {
        padding: 15px 10px !important;
    }
    
    .battle-header {
        flex-direction: column !important;
        gap: 15px !important;
        margin-bottom: 20px !important;
    }
    
    .battle-info {
        justify-content: center !important;
        gap: 15px !important;
        flex-wrap: wrap !important;
    }
    
    .battle-layout {
        gap: 15px !important;
        margin-bottom: 15px !important;
    }
    
    .battle-top-row {
        grid-template-columns: 1fr !important;
        grid-template-rows: auto auto auto !important;
        gap: 15px !important;
        text-align: center !important;
    }
    
    .battle-top-row > *:nth-child(1) { grid-row: 1; }
    .battle-top-row > *:nth-child(2) { grid-row: 3; }
    .battle-top-row > *:nth-child(3) { grid-row: 2; }
    
    .battle-mc-container {
        flex-direction: row !important;
        justify-content: center !important;
        min-width: auto !important;
    }
    
    .battle-mc-name {
        font-size: 1.8rem !important;
        max-width: 250px !important;
    }
    
    .battle-mc-score {
        font-size: 1.2rem !important;
    }
    
    .battle-mc-indicator {
        width: 45px !important;
        height: 45px !important;
    }
    
    .timer-display {
        font-size: 3rem !important;
        order: 3 !important;
    }
    
    .word-container {
        width: 95% !important;
        height: 160px !important;
        padding: 25px 15px !important;
    }
}

@media (max-width: 768px) {
    .voting-screen {
        padding: 20px 15px !important;
    }
    
    .voting-title {
        font-size: 2rem !important;
    }
    
    .voting-info {
        padding: 15px !important;
        margin-bottom: 25px !important;
    }
    
    .voting-round-info {
        gap: 20px !important;
        flex-wrap: wrap !important;
        justify-content: center !important;
    }
    
    .current-scores {
        gap: 30px !important;
        font-size: 1rem !important;
        flex-wrap: wrap !important;
        justify-content: center !important;
    }
    
    .voting-question h2 {
        font-size: 1.4rem !important;
        margin-bottom: 20px !important;
    }
    
    .voting-options {
        flex-direction: column !important;
        align-items: center !important;
        gap: 15px !important;
        margin-bottom: 30px !important;
    }
    
    .voting-option {
        min-width: 250px !important;
        max-width: 300px !important;
        width: 100% !important;
        padding: 20px 15px !important;
    }
    
    .voting-mc-name {
        font-size: 1.3rem !important;
    }
}

@media (max-width: 768px) {
    .results-screen {
        padding: 20px 15px !important;
    }
    
    .results-title {
        font-size: 2rem !important;
    }
    
    .winner-announcement {
        font-size: 2.2rem !important;
        line-height: 1.1 !important;
        margin-bottom: 8px !important;
    }
    
    .winner-subtitle {
        font-size: 1.2rem !important;
    }
    
    .results-summary {
        padding: 20px 15px !important;
        margin-bottom: 20px !important;
    }
    
    .final-scores {
        flex-direction: column !important;
        gap: 15px !important;
        margin-bottom: 15px !important;
    }
    
    .final-score {
        font-size: 1.2rem !important;
    }
    
    .score-number {
        font-size: 2.2rem !important;
    }
    
    .vs-separator {
        font-size: 1.5rem !important;
        order: 2 !important;
    }
    
    .results-rounds {
        padding: 15px !important;
        margin-bottom: 20px !important;
    }
    
    .round-result {
        flex-direction: column !important;
        text-align: center !important;
        gap: 5px !important;
        padding: 12px 15px !important;
    }
    
    .results-actions {
        flex-direction: column !important;
        align-items: center !important;
        gap: 15px !important;
    }
    
    .results-actions .control-btn {
        min-width: 200px !important;
        width: 100% !important;
        max-width: 300px !important;
    }
}

@media (max-width: 768px) {
    .tournament-participants-list {
        grid-template-columns: 1fr !important;
    }
    
    .tournament-round-selectors {
        grid-template-columns: 1fr !important;
        gap: 8px !important;
    }
    
    .tournament-results-content {
        grid-template-columns: 1fr !important;
        gap: 20px !important;
    }
    
    .champion-name {
        font-size: 2.2rem !important;
        line-height: 1.1 !important;
    }
    
    .tournament-header {
        flex-direction: column !important;
        text-align: center !important;
        gap: 15px !important;
    }
    
    .tournament-info {
        justify-content: center !important;
        flex-wrap: wrap !important;
    }
    
    .tournament-match-participants {
        flex-direction: column !important;
        gap: 10px !important;
    }
    
    .tournament-vs {
        font-size: 1.5rem !important;
    }
    
    .participant-name {
        font-size: 1.3rem !important;
    }
    
    .tournament-match-item {
        flex-direction: column !important;
        gap: 10px !important;
        text-align: center !important;
        padding: 12px 15px !important;
    }
    
    .match-participants {
        flex-direction: column !important;
        gap: 8px !important;
    }
    
    .match-participants .participant-name {
        font-size: 1.1rem !important;
    }
    
    .tournament-phases-config {
        padding: 15px !important;
    }
    
    .tournament-phase-header h4 {
        font-size: 1.8rem !important;
    }
}

@media (max-width: 768px) and (orientation: landscape) {
    .title {
        max-width: 180px !important;
        margin-bottom: 5px !important;
    }
    
    .subtitle {
        font-size: 0.7rem !important;
        margin-bottom: 10px !important;
    }
    
    .header {
        margin-bottom: 15px !important;
    }
    
    .word-container {
        height: 120px !important;
        padding: 20px 15px !important;
    }
    
    .current-word {
        font-size: 1.5rem !important;
    }
    
    .timer-display {
        font-size: 2.5rem !important;
    }
    
    .training-center {
        gap: 10px !important;
    }
    
    .battle-layout {
        gap: 10px !important;
    }
    
    .battle-top-row {
        gap: 10px !important;
    }
}

@media (min-width: 769px) and (max-width: 1023px) {
    .container {
        padding: 20px;
    }
    
    .title {
        max-width: 320px;
    }
    
    .main-menu {
        grid-template-columns: repeat(2, 1fr);
        gap: 25px;
    }
    
    .controls-section {
        grid-template-columns: repeat(2, 1fr);
        gap: 20px;
    }
    
    .beat-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 15px;
    }
    
    .battle-top-row {
        grid-template-columns: 1fr auto 1fr;
        gap: 20px;
    }
    
    .word-container {
        width: 90%;
        height: 250px;
    }
    
    .current-word {
        font-size: 3.5rem;
    }
    
    .timer-display {
        font-size: 4rem;
    }
}

@media (max-width: 768px) {
    * {
        max-width: 100%;
    }
    
    .beat-blacklist-toggle {
        width: 30px !important;
        height: 30px !important;
        font-size: 1rem !important;
    }
    
    .beat-mass-controls {
        flex-direction: column !important;
        gap: 8px !important;
        width: 100% !important;
    }
    
    .beat-mass-btn {
        width: 100% !important;
        min-width: auto !important;
    }
    
    .beat-grid-controls {
        flex-direction: column !important;
        gap: 15px !important;
    }
    
    .beat-grid-toggle {
        width: 100% !important;
    }
    
    .round-selectors {
        grid-template-columns: 1fr !important;
        gap: 8px !important;
    }
    
    .timer-mode-toggle {
        flex-direction: column !important;
        align-items: center !important;
        gap: 10px !important;
        text-align: center !important;
    }
    
    .timer-mode-button {
        width: 100% !important;
        max-width: 250px !important;
    }
}
