/**
 * Project: Forum 2026 - Latest Posts / FBK V3 Cards
 * Description: Optimized layout with Grid, Fluid Typography and Mobile UI.
 */

:root {
}

.latest-posts-section-bg {
    padding-top: var(--post-cards-padding-top);
    padding-bottom: var(--post-cards-padding-bottom);
}

.read-more-section {
    background-color: var(--site-bg-color);
}

/* HEADING - Fluid Typography zastosowane bezpośrednio */
.latest-posts-section-heading {
    color: var(--h1-text-color); 
    font-family: var(--font-primary);
    font-size: var(--h1-font-size);
    font-weight: var(--h1-font-weight);
    letter-spacing: var(--h1-letter-spacing);
    text-transform: var(--h1-text-transform);
    line-height: 60px;
    /* Skalowanie dolnego odstępu, aby uniknąć gigantycznej dziury na mobile */
    padding-bottom: var(--post-cards-heading-to-content-gap) ; 
}

/* CONTAINER (Grid) */
.fbk-v3-container {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 25px;
    width: 100%;
    padding-bottom: 20px;
    box-sizing: border-box;
}

/* BASE CARD STYLES */
.fbk-v3-card {
    text-decoration: none;
    border-radius: var(--post-cards-sub-card-radius);
    padding: var(--post-cards-card-padding);
    display: flex;
    flex-direction: column;
    transition: all 0.3s ease;
    box-sizing: border-box;
    overflow: hidden;
    height: 100%; 
    position: relative; /* Dodane dla pewności poprawnego działania overlay'a */
}

.fbk-v3-card h3 {
    margin: 0 0 15px 0;
    font-size: var( --post-cards-article-title-font-size);
    font-weight: var(--post-cards-article-title-font-weight);
    letter-spacing: var(--h3-letter-spacing);
    font-family: var(--font-primary);
}

.fbk-v3-card p {
    color: var(--p-text-color);
    font-size: var(--post-cards-article-desc-font-size);
    font-family: var(--font-primary);
    font-weight: var(--post-cards-article-desc-font-weight);
    line-height: var(--p-line-heght);
    margin: 0;
    opacity: 0.85;
}
/*Button colors inversion*/
.latest-posts-section-bg .wp-element-button{
    background-color: var(--button-inverted-bg-color) !important;
    outline: var(--button-hover-outline) !important;
}

.latest-posts-section-bg .wp-element-button:hover{
    background-color: var(--button-inverted-hover-color) !important;
    outline: none !important;
}

/* LEWA KARTA (MAIN) */
.fbk-v3-main {
    background-color: var(--site-light-bg-action);
    color: var(--p-text-color);
    border: var(--button-hover-outline);
    border-radius: var(--post-cards-main-card-radius);
    min-height: var(--post-cards-main-card-min-height);
}

.fbk-v3-img-wrapper {
    width: 100%;
    height: var(--post-cards-img-container-height);
    margin-bottom: 25px;
    border-radius: 20px;
    overflow: hidden;
    background: rgba(0,0,0,0.1);
}

.fbk-v3-img-wrapper img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.fbk-v3-img-wrapper.placeholder {
    background-color: var(--img-placeholder-bg);
}

/* PRAWA KOLUMNA (SIDEBAR) */
.fbk-v3-sidebar {
    display: flex;
    flex-direction: column;
    gap: 25px;
}

.fbk-v3-secondary, 
.fbk-v3-tertiary {
    min-height: var(--post-cards-sidebar-card-min-height);
}

.fbk-v3-secondary {
    background-color: var(--post-cards-second-card-bg);
    color: var(--post-cards-second-card-text);
    flex: 1;
}

.fbk-v3-tertiary {
    background-color: var(--post-cards-thrid-card-bg);
    color: var(--post-cards-third-card-text);
    border: var(--element-general-border);
    flex: 1;
}

/* OVERLAY LINK Z-INDEX FIX */
.fbk-v3-card-link-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 999 !important; 
    text-decoration: none;
    cursor: pointer;
}

.fbk-v3-card h3, 
.fbk-v3-card .fbk-v3-excerpt, 
.fbk-v3-card .fbk-v3-img-wrapper {
    pointer-events: none;
    position: relative;
    z-index: 1;
}
.fbk-v3-tertiary .fbk-v3-excerpt{
    color: var(--post-cards-third-card-text);

}
.fbk-v3-excerpt {
    /* Aktywacja mechanizmu line-clamp */
    display: -webkit-box;
    -webkit-line-clamp: 4; /* Tutaj ustalasz DOKŁADNĄ liczbę linii */
    -webkit-box-orient: vertical;  
    overflow: hidden;

    /* Opcjonalne: Ustalenie stałej wysokości, aby karty były idealnie równe */
    /* Obliczane jako: liczba linii * line-height */
    height: calc(var(--p-line-height, 1.5) * 1em * 4); 
    
    color: var(--p-text-color);
    font-size: var(--post-cards-article-desc-font-size);
    line-height: var(--p-line-height, 1.5);
    margin: 0;
    opacity: 0.85;
}

/* ==========================================================================
   Mobile UI & Responsive Adjustments (1191px and below)
   ========================================================================== */
@media screen and (max-width: 1191px) {
    
    :root {
        /* Reset wymuszonych wysokości dla naturalnego ułożenia na mobile */
        --post-cards-mobile-main-card-min-height: auto; 
        --post-cards-mobile-sidebar-card-min-height: auto;
        
        /* Zmniejszamy paddingi i zaokrąglenia, aby odzyskać przestrzeń na treść */
        --post-cards-mobile-card-padding: 24px;
        --post-cards-main-card-radius: 30px;
        --post-cards-sub-card-radius: 24px;
    }
    .fbk-v3-img-wrapper{
        display: none !important;
    }

    /* Zmiana rozmiarów fontów zgodnie ze zmiennymi pod Mobile */
    .latest-posts-section-heading {
        font-size: var(--mobile-h1-font-size);
        line-height: var(--p-line-heght);
    }

    .fbk-v3-card p {
        font-size: var(--post-cards-mobile-article-desc-font-size);
    }

    .fbk-v3-card h3 {
        font-size: var(--post-cards-mobile-article-title-font-size);
        display: -webkit-box;
        -webkit-line-clamp: 5; /* Twardy limit liczby wyświetlanych linii */
        -webkit-box-orient: vertical;
        overflow: hidden;
        text-overflow: ellipsis; /* Wygenerowanie wielokropka na końcu uciętego tekstu */
        
        /* Opcjonalne zabezpieczenie: zapobiega rozbiciu słów w nienaturalnych miejscach, 
           jeśli tytuł zawiera bardzo długie wyrazy bez spacji */
        word-break: break-word;
    }

    /* Nadpisanie klas nowymi zmiennymi mobilnymi oraz poprawa bezpieczeństwa UI */
    .fbk-v3-card {
        padding: var(--post-cards-mobile-card-padding);
        /* FIX (Wydajność i Stabilność UI): min-width: 0 zapobiega "Grid Blowout". 
           Wymusza na elementach dziecięcych respektowanie granic kolumny 1fr. */
        min-width: 0; 
        overflow-wrap: break-word; /* Ochrona przed rozpychaniem grida przez długie linki/słowa */
    }

    .fbk-v3-main {
        min-height: var(--post-cards-mobile-main-card-min-height);
    }

    .fbk-v3-secondary, 
    .fbk-v3-tertiary {
        min-height: var(--post-cards-mobile-sidebar-card-min-height);
    }

    .latest-posts-section-bg {
        padding-top: 40px;
        padding-bottom: 40px;
        /* FIX: Ukrycie poziomego scrollbara generowanego przez błędne obliczenia WordPressa */
        overflow-x: hidden; 
    }

    .fbk-v3-container {
        /* Zamiana na układ jednokolumnowy */
        grid-template-columns: 1fr;
        gap: 20px;
        
        /* FIX: Symetria marginesów. Wymuszamy, by grid container nie przekraczał ekranu
           i miał twardy, symetryczny padding. Zabezpieczamy to właściwością box-sizing. */
        width: 100%;
        max-width: 100vw;
        padding-left: 20px;
        padding-right: 20px;
        box-sizing: border-box;
    }

    .fbk-v3-img-wrapper {
        /* Zmniejszenie wysokości kontenera na zdjęcia */
        height: 200px;
        margin-bottom: 20px;
    }
    /* Resetujemy parametry wymuszające wypychanie prawego marginesu poza ekran */
    .fbk-v3-container {
        /* minmax(0, 1fr) zamiast 1fr to twardy reset dla silnika Grid, zapobiegający overflow */
        grid-template-columns: minmax(0, 1fr);
        gap: 20px;
        
        /* KRYTYCZNE: width: auto zamiast 100% pozwala elementowi dopasować się 
           do globalnego paddingu WordPressa, zamiast z nim walczyć */
        width: auto;
        max-width: 100%;
        
        /* Upewniamy się, że kontener sam z siebie nie generuje przesunięć */
        margin-left: 0;
        margin-right: 0;
        padding-left: 0;
        padding-right: 0;
    }

    .fbk-v3-sidebar,
    .fbk-v3-card {
        /* Wymuszamy na zagnieżdżonych elementach respektowanie nowej siatki */
        width: 100%;
        min-width: 0; 
        box-sizing: border-box;
    }
    .latest-posts-section-heading {
    font-size: var(--mobile-scaled-h1-font-size) !important;
}
}