/* Naprawy dla sekcji Aktualności i tabeli ligowej */

/* Kontenery główne */
.content-grid {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 40px;
    align-items: start;
}

/* Box ze sliderem aktualności */
.news-slider-box {
    background-color: #fff;
    border-radius: 12px;
    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.07);
    overflow: hidden;
    height: auto;
    display: flex;
    flex-direction: column;
}

.news-slider {
    position: relative;
    display: flex;
    flex-direction: column;
}

/* Główny slider */
.news-slider-main {
    position: relative;
    overflow: hidden;
    height: 450px;
}

.news-slide {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.5s ease, visibility 0.5s ease;
    display: flex;
    flex-direction: column;
}

.news-slide.active {
    opacity: 1;
    visibility: visible;
    position: relative;
}

.news-slide-image {
    height: 220px;
    overflow: hidden;
}

.news-slide-content {
    padding: 20px 30px;
    display: flex;
    flex-direction: column;
    flex: 1;
    overflow: hidden;
}

.news-slide-content p {
    font-size: 1rem;
    color: #555;
    margin-bottom: 15px;
    line-height: 1.6;
    overflow-y: auto;
    max-height: 120px;
}

.read-more {
    margin-top: auto;
    align-self: flex-start;
}

/* Miniatury newsów */
.news-slider-thumbs {
    display: flex;
    padding: 15px 30px;
    gap: 20px;
    border-top: 1px solid #f0f0f0;
}

.news-thumb {
    flex: 1;
    position: relative;
    border-radius: 8px;
    overflow: hidden;
    cursor: pointer;
    opacity: 0.7;
    transition: all 0.3s ease;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    height: 70px;
}

/* Kontrolki slidera */
.slider-controls {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 15px 30px;
    gap: 20px;
    border-top: 1px solid #f0f0f0;
}

/* Box z tabelą ligową */
.league-table-box {
    background-color: #fff;
    border-radius: 12px;
    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.07);
    overflow: hidden;
    height: 100%;
    display: flex;
    flex-direction: column;
}

.table-container {
    padding: 0 15px 20px;
    flex: 1;
    display: flex;
    flex-direction: column;
    overflow: auto;
    max-height: none;
    scrollbar-width: thin;
    scrollbar-color: rgba(0, 0, 0, 0.2) transparent;
}

.league-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.85rem;
    margin-bottom: 15px;
    table-layout: fixed;
}

.league-table th, 
.league-table td {
    padding: 8px 5px;
    text-align: center;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.league-table th:nth-child(1),
.league-table td:nth-child(1) {
    width: 15%;
}

.league-table th:nth-child(2),
.league-table td:nth-child(2) {
    width: 70%;
    text-align: left;
}

.league-table th:nth-child(3),
.league-table td:nth-child(3) {
    width: 15%;
}

.league-table th {
    background-color: #f7f7f7;
    font-weight: 600;
}

.league-table tr:nth-child(even) {
    background-color: #f9f9f9;
}

.league-table tr:hover {
    background-color: #f0f0f0;
}

/* Legenda tabeli */
.table-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: auto;
    padding: 15px 25px;
    border-top: 1px solid #eee;
    flex-wrap: wrap;
    gap: 10px;
}

.legend-item {
    font-size: 0.8rem;
    display: flex;
    align-items: center;
    position: relative;
    padding-left: 20px;
    margin-right: 15px;
}

/* Dodatkowe poprawki dla systemu powiadomień */
#notification-system {
    z-index: 1100; /* Wyższy niż większość elementów, ale niższy niż menu (1000) */
    pointer-events: none; /* Domyślnie wyłączamy przechwytywanie zdarzeń dla całego kontenera */
}

/* Tylko samo powiadomienie może przechwytywać zdarzenia, nie cały kontener */
#notification-system .notification {
    pointer-events: auto;
}

/* Na urządzeniach mobilnych, gdy jest aktywne menu hamburgerowe, ukrywamy powiadomienia */
@media (max-width: 768px) {
    #notification-system {
        left: 15px;
        right: 15px;
        bottom: 80px; /* Odsunięcie od dołu ekranu, żeby nie nakładać się na przyciski */
        max-width: calc(100% - 30px);
    }
    
    /* Gdy menu jest aktywne, usuwamy powiadomienia całkowicie z flow */
    .menu.active ~ #notification-system,
    body:has(.menu.active) #notification-system {
        display: none !important;
    }
    
    /* Poprawka dla z-index, aby powiadomienia nie nakładały się na menu */
    #notification-system {
        z-index: 999; /* Niższy niż menu (1000) */
    }
    
    /* Ustawiamy transparentne tło dla całego contenera powiadomień */
    #notification-system::before {
        content: "";
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background: transparent; /* Przezroczyste tło */
        z-index: -1;
        pointer-events: none;
    }
}

/* Naprawa problemu z "ghost powiadomieniami" */
#notification-system .notification[style*="display: none"] {
    pointer-events: none !important; /* Wyłączamy przechwytywanie zdarzeń dla ukrytych powiadomień */
    opacity: 0 !important;
    visibility: hidden !important;
    position: absolute !important;
    top: -9999px !important;
    left: -9999px !important;
}

/* Poprawki dla responsywności */
@media (max-width: 992px) {
    .content-grid {
        grid-template-columns: 1fr;
        gap: 30px;
    }
    
    .news-slider-main {
        height: 400px;
    }
    
    .table-container {
        max-height: 500px;
        overflow-y: auto;
    }
}

@media (max-width: 768px) {
    .news-slider-main {
        height: 380px;
    }
    
    .news-slide-image {
        height: 200px;
    }
    
    .news-slide-content p {
        max-height: 100px;
    }
    
    .news-slider-thumbs {
        flex-wrap: wrap;
    }
    
    .news-thumb {
        flex: 0 0 calc(50% - 10px);
    }
    
    .table-container {
        max-height: 450px;
        overflow-y: auto;
    }
}

@media (max-width: 576px) {
    .news-slider-main {
        height: 350px;
    }
    
    .news-slide-image {
        height: 180px;
    }
    
    .news-slide-content p {
        max-height: 80px;
    }
    
    .news-thumb {
        flex: 0 0 100%;
    }
    
    .table-container {
        max-height: 450px;
        overflow-y: auto;
    }
    
    .league-table {
        font-size: 0.75rem;
    }
    
    .league-table th, 
    .league-table td {
        padding: 8px 3px;
    }
    
    .our-team {
        font-weight: 700 !important;
    }
}

/* Poprawki dla przycisków na urządzeniach mobilnych */
.touch-friendly {
    /* Zwiększamy obszar dotyku dla przycisków na urządzeniach mobilnych */
    min-height: 44px;
    min-width: 44px;
    padding: 12px;
    position: relative;
    /* Eliminujemy opóźnienie dotykowe */
    touch-action: manipulation;
}

/* Zwiększamy odstępy między przyciskami na urządzeniach mobilnych */
@media (max-width: 768px) {
    .btn, button, .filter-btn, .read-more {
        margin: 5px;
        padding: 12px 20px;
        /* Eliminujemy opóźnienie dotykowe */
        touch-action: manipulation;
    }
    
    /* Zapobiegamy nakładaniu się przycisków */
    .filter-options {
        gap: 10px;
    }
    
    /* Poprawiamy przyciski w menu */
    .menu-toggle {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 44px;
        height: 44px;
        /* Zwiększamy obszar dotyku */
        padding: 12px;
    }
    
    /* Poprawiamy przyciski w sekcji nagłówkowej */
    .hero-buttons {
        display: flex;
        flex-wrap: wrap;
        gap: 10px;
        margin-top: 20px;
    }
    
    .hero-buttons .btn {
        margin: 0;
    }
    
    /* Poprawiamy przyciski w sliderze */
    .slider-controls {
        padding: 15px 25px 20px;
    }
    
    .slider-prev, .slider-next {
        width: 44px;
        height: 44px;
    }
    
    /* Zmniejszamy problem "ghostclicking" (podwójnego kliknięcia) */
    a, button, .btn, .read-more, .filter-btn, .menu-toggle, .slider-prev, .slider-next {
        /* Wyłączamy highlight przy kliknięciu */
        -webkit-tap-highlight-color: transparent;
    }
    
    /* Zwiększamy obszar dotykowy dla kropek nawigacyjnych */
    .dot, .slider-dot {
        width: 16px;
        height: 16px;
        margin: 0 8px;
    }
}

/* Naprawa innych błędów CSS związanych z przyciskami */
button, .btn {
    cursor: pointer;
    user-select: none; /* Zapobiega zaznaczaniu tekstu */
}

/* Dodajemy wyraźny stan :active dla lepszego feedbacku na urządzeniach dotykowych */
button:active, .btn:active, .read-more:active, .filter-btn:active, .menu-toggle:active {
    opacity: 0.8;
    transform: scale(0.98);
}

/* Zapewniamy, że przyciski w sekcji sponsorów działają poprawnie */
.sponsors-slider-container {
    touch-action: pan-y; /* Pozwalamy na przewijanie pionowe, ale blokujemy gestów przeglądarki poziomo */
}

/* Usuwamy konfliktujące style dla przycisków w karuzeli */
.slider-prev, .slider-next {
    touch-action: manipulation;
}

/* Stylizacja przewijania dla WebKit (Chrome, Safari, Edge) */
.table-container::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}

.table-container::-webkit-scrollbar-track {
    background: transparent;
}

.table-container::-webkit-scrollbar-thumb {
    background-color: rgba(0, 0, 0, 0.2);
    border-radius: 20px;
}

/* Styl dla wskazówki przewijania */
.scroll-hint {
    display: none; /* Domyślnie ukryte */
    padding: 8px 15px;
    margin: 0 15px 10px;
    background-color: rgba(30, 58, 138, 0.05);
    border-radius: 6px;
    font-size: 0.85rem;
    color: #666;
    text-align: center;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

.scroll-icon {
    color: var(--primary-color);
    animation: bounce 1.5s infinite;
    display: inline-block;
}

@keyframes bounce {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(3px); }
}

/* Pokazuj wskazówkę tylko na urządzeniach mobilnych */
@media (max-width: 768px) {
    .scroll-hint {
        display: flex;
    }
}

/* Ukryj wskazówkę po przewinięciu */
.table-container:focus + .scroll-hint,
.table-container:hover + .scroll-hint {
    opacity: 0;
    transition: opacity 0.5s ease;
}

/* Poprawka dla kart meczów w terminarzu */
.schedule-section .match-teams {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 10px;
    flex-wrap: nowrap; /* Zapobiega zawijaniu elementów */
}

.schedule-section .team {
    flex: 1; /* Każda drużyna zajmuje równą przestrzeń */
    text-align: center; /* Centrowanie tekstu */
}

.schedule-section .team.home {
    text-align: right; /* Wyrównanie do prawej dla drużyny gospodarzy */
    padding-right: 10px; /* Dodatkowy odstęp od prawej strony */
}

.schedule-section .team.away {
    text-align: left; /* Wyrównanie do lewej dla drużyny gości */
    padding-left: 10px; /* Dodatkowy odstęp od lewej strony */
}

.schedule-section .match-score {
    padding: 0 10px;
    flex: 0 0 auto; /* Utrzymanie szerokości elementu wyniku/vs */
    width: auto; /* Automatyczna szerokość */
    min-width: 50px; /* Minimalna szerokość dla wyniku */
    text-align: center; /* Centrowanie tekstu */
}

.schedule-section .team-name {
    font-weight: 600;
    font-size: 16px;
    white-space: nowrap; /* Zapobiega zawijaniu tekstu do nowej linii */
    display: inline-block; /* Upewnia się, że tekst zachowuje się jako blok */
    max-width: 100%; /* Ograniczenie szerokości do szerokości kontenera */
    overflow: hidden; /* Ukrywa tekst, który nie mieści się w kontenerze */
    text-overflow: ellipsis; /* Dodaje kropki na końcu, jeśli tekst jest za długi */
}

/* Dodatkowe poprawki dla terminarz.html */
.schedule-section .match-details {
    flex: 1;
    padding: 15px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

/* Wyraźne nadpisanie stylów, które mogą powodować problemy */
.schedule-section .match-teams {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
    margin-bottom: 10px !important;
    width: 100% !important;
}

/* Naprawienie responsywności na małych ekranach */
@media (max-width: 768px) {
    .schedule-section .match-teams {
        flex-direction: row !important; /* Zapewnienie, że zawsze będzie wyświetlane w rzędzie */
    }
    
    .schedule-section .team-name {
        font-size: 14px; /* Mniejsza czcionka na mniejszych ekranach */
    }
    
    .schedule-section .match-score {
        min-width: 40px; /* Mniejsza szerokość na mniejszych ekranach */
    }
}

/* Karty meczowe – layout oparty na flexbox (naprawa wyrównania pionowego i mobile) */
.match-card {
    display: flex;
    align-items: stretch;
    background-color: #fff;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 3px 10px rgba(0, 0, 0, 0.1);
    margin-bottom: 20px;
    transition: all 0.3s ease;
}

.match-date {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background-color: var(--primary-color);
    color: white;
    padding: 15px;
    min-width: 100px;
    text-align: center;
}

.match-details {
    flex: 1;
    padding: 15px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-width: 0;
}

/* Układ drużyn – flexbox zapewnia spójne wyrównanie pionowe */
.match-teams {
    display: flex !important;
    align-items: center !important;
    flex-wrap: nowrap !important; /* Zapobiega zawijaniu (terminarz.html: flex-wrap: wrap) */
    width: 100% !important;
    margin-bottom: 10px !important;
}

.team.home,
.team.away {
    display: flex !important;
    align-items: center !important;
    flex: 1 1 0 !important;
    min-width: 0 !important;
}

.team.home {
    justify-content: flex-end !important;
}

.team.away {
    justify-content: flex-start !important;
}

/* Wrapper wewnętrzny – min-width i overflow dla ellipsis długich nazw */
.team.home > div,
.team.away > div {
    align-self: center !important; /* Wymusza pionowe wycentrowanie względem .team.home/.team.away */
    min-width: 0 !important;
    overflow: hidden !important;
}
/* Kolejność [NAZWA][HERB] dla home obsługuje terminarz.html: .team.home .team-name { order: -1 } */

.team-logo {
    flex-shrink: 0 !important; /* Logo zawsze pełny rozmiar */
    align-self: center !important; /* Wymusza pionowe wycentrowanie w wewnętrznym inline-flex */
    vertical-align: middle !important; /* Fallback dla edge cases baseline alignment */
}

.team-name {
    display: block !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    font-weight: 600 !important;
    font-size: 16px !important;
    min-width: 0 !important;
}

.match-score {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex: 0 0 auto !important;
    order: 0 !important; /* Zapobiega order: -1 z terminarz.html (768px media query) */
}

/* Responsywność – tablet */
@media (max-width: 768px) {
    .match-date {
        min-width: 80px;
        padding: 10px;
    }

    .match-details {
        padding: 12px;
    }

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

    .team-name {
        font-size: 12px !important;
    }

    .match-score {
        min-width: 40px !important;
    }
}

/* Responsywność – małe telefony */
@media (max-width: 480px) {
    .match-date {
        min-width: 68px;
        padding: 8px;
    }

    .match-details {
        padding: 8px;
    }

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

    .team-name {
        font-size: 10px !important;
    }

    .match-score {
        min-width: 32px !important;
    }
}

/* ═══════════════════════════════════════════════════════════════════════════
   KOLORY WYNIKÓW MECZÓW (Aktualności meczowe)
   Box zmienia kolor tła w zależności od wyniku, tekst zawsze biały
   ═══════════════════════════════════════════════════════════════════════════ */

/* Wygrana - zielone tło */
.match-result-label.win {
    background-color: #28a745 !important;
    color: white !important;
}

/* Porażka - czerwone tło */
.match-result-label.loss {
    background-color: #dc3545 !important;
    color: white !important;
}

/* Remis - szare tło */
.match-result-label.draw {
    background-color: #6c757d !important;
    color: white !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   TIMER ODLICZAJĄCY DO MECZU (Aktualności meczowe - karta Najbliższy mecz)
   ═══════════════════════════════════════════════════════════════════════════ */

.match-countdown {
    display: flex;
    align-items: center;
    gap: 4px;
}

/* Równomierne rozłożenie elementów w nagłówku karty meczu */
.match-upcoming .match-header {
    justify-content: space-between;
    flex-wrap: nowrap;
}

.match-upcoming .match-header > span,
.match-upcoming .match-header > .match-countdown {
    flex: 1;
    text-align: center;
    white-space: nowrap;
}

.match-upcoming .match-header > span:first-child {
    text-align: left;
}

.match-upcoming .match-header > .match-countdown {
    justify-content: flex-end;
}

/* Tło dla daty - spójne z boxami timera */
.match-item .match-header .match-date {
    background: rgba(255, 255, 255, 0.2);
    border-radius: 4px;
    padding: 4px 10px;
}

.countdown-box {
    display: flex;
    flex-direction: column;
    align-items: center;
    background: rgba(255, 255, 255, 0.2);
    border-radius: 4px;
    padding: 3px 6px;
    min-width: 32px;
}

.countdown-value {
    font-size: 0.95rem;
    font-weight: 700;
    color: #ffffff;
    line-height: 1.1;
}

.countdown-label {
    font-size: 0.55rem;
    color: rgba(255, 255, 255, 0.8);
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

/* Animacja dla "MECZ TRWA!" */
.countdown-live {
    background: linear-gradient(135deg, #28a745, #20c997);
    color: white;
    padding: 4px 12px;
    border-radius: 12px;
    font-weight: 700;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    animation: pulse-live 1.5s ease-in-out infinite;
}

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

/* Responsywność timera */
@media (max-width: 768px) {
    .match-countdown {
        gap: 4px; /* Większy odstęp na mobile */
    }

    .countdown-box {
        padding: 4px 6px; /* Większy padding na mobile */
        min-width: 35px; /* Szersze boxy na mobile */
    }

    .countdown-value {
        font-size: 0.9rem; /* Większa czcionka na mobile */
    }

    .countdown-label {
        font-size: 0.55rem; /* Większa czcionka na mobile */
    }
}

/* Mobile - lepsza kontrola wrappingu w headerze */
@media (max-width: 600px) {
    .match-upcoming .match-header {
        flex-wrap: wrap !important; /* Pozwól na zawijanie */
        justify-content: center !important; /* Wycentruj gdy elementy spadają */
        gap: 8px !important;
    }

    /* Data - może się zawijać wewnętrznie (dzień poniżej) */
    .match-upcoming .match-header .match-date {
        white-space: normal !important;
        flex: 0 1 auto !important; /* Może się kurczyć */
        text-align: center !important; /* Wycentruj tekst gdy się zawija */
        font-size: 0.85rem; /* Trochę mniejsza czcionka na mobile */
    }

    /* Godzina - zawsze w jednej linii */
    .match-upcoming .match-header .match-time {
        white-space: nowrap !important;
        flex: 0 0 auto !important; /* Stały rozmiar */
        font-size: 0.85rem;
    }

    /* Timer i Round - zawsze w jednej linii */
    .match-upcoming .match-header .match-countdown,
    .match-upcoming .match-header .match-round {
        white-space: nowrap !important;
        flex: 0 0 auto !important; /* Stały rozmiar */
        font-size: 0.85rem;
    }
}

/* Jeszcze mniejsze ekrany - timer na środku gdy spada */
@media (max-width: 480px) {
    .match-upcoming .match-header .match-countdown {
        width: 100%; /* Pełna szerokość gdy spada */
        justify-content: center; /* Wycentruj wewnętrzne elementy */
    }
}

@media (max-width: 380px) {
    .match-countdown {
        display: none; /* Ukryj timer tylko na BARDZO małych ekranach */
    }
}
