/* --- 1. CZCIONKI --- */
@import url('https://fonts.googleapis.com/css2?family=Lobster&family=Montserrat:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&display=swap');
/* --- 2. RESET I BAZA --- */
* { box-sizing: border-box; margin: 0; padding: 0; }

body {
    display: flex;
    flex-direction: column;
    /* Dodajemy odstęp od góry, żeby treść nie wchodziła pod przyklejony nagłówek.
       Wartość 90px to przybliżona wysokość Twojego nagłówka. */
    padding-top: 0 !important; 
}

html, body {
    height: 100%;
    background: #C2E3FF;
    background: linear-gradient(90deg, rgb(209, 231, 255) 0%, rgb(132, 174, 221) 25%, rgb(132, 174, 221) 75%, rgb(209, 231, 255) 100%);
    font-family: 'Montserrat', sans-serif !important;
    color: #111;
    line-height: 1.6;
}

body {
    display: flex;
    flex-direction: column;
}

/* --- 3. NAGŁÓWEK (HEADER) --- */
header {
    background-color: #ffffff;
    width: 100%;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15); 
    
    /* ZMIANY DLA SMART HEADER: */
    position: fixed; /* Przyklejony do okna przeglądarki */
    top: 0;
    left: 0;
    z-index: 1000; /* Musi być nad treścią, ale pod przyciskami dostępności */
    
    /* Płynna animacja wysuwania/chowania */
    transition: transform 0.3s ease-in-out;
}

/* Klasa, którą JS będzie dodawał, żeby schować nagłówek */
header.header-hidden {
    transform: translateY(-100%); /* Przesuń w górę o całą swoją wysokość */
    box-shadow: none; /* Ukryj cień, żeby nie wisiał "w powietrzu" */
}

/* Układ 3-elementowy: Imię - Logo - Menu */
.header-container {
    max-width: 1140px; 
    margin: 0 auto;    
    padding: 0 20px; /* Padding tylko po bokach, wysokość ustali min-height */
    
    /* TO USTAWIA WSZYSTKO W JEDNEJ LINII Y: */
    display: flex;
    justify-content: space-between;
    align-items: center; /* Centrowanie pionowe (oś Y) */
    
    min-height: 90px; /* Stała wysokość nagłówka */
}

/* LEWA STRONA: Imię i Nazwisko */
.header-left {
    flex: 1;
    display: flex;
    align-items: center; /* Centruj Imię w pionie */
    justify-content: flex-start; /* Dosuń do lewej */
}

.author-name {
    font-size: 1.1rem;
    font-style: italic;
    color: #333;
    font-weight: 400;
    margin: 0;      /* Usuwa przesunięcia */
    line-height: 1; /* Usuwa zbędne odstępy góra/dół */
}

/* ŚRODEK: Logo */
.header-center {
    flex: 1;
    display: flex;
    align-items: center; /* Centruj Logo w pionie */
    justify-content: center; /* Centruj Logo w poziomie */
}

.logo {
    font-family: 'Lobster', display;
    font-size: 2.5rem; 
    color: #73a3d0; 
    text-decoration: none;
    white-space: nowrap; 
    margin: 0;      /* Usuwa przesunięcia */
    line-height: 1; /* Tytuł idealnie na środku */
    padding-bottom: 5px; /* Lobster czasem optycznie wydaje się być za wysoko, to go koryguje. Jeśli jest za nisko - usuń to. */
}

/* PRAWA STRONA: Menu */
.header-right {
    flex: 1;
    display: flex;
    align-items: center; /* Centruj Menu w pionie */
    justify-content: flex-end; /* Dosuń do prawej */
}

.nav-menu {
    display: flex;
    list-style: none;
    gap: 25px;
    margin: 0;
    padding: 0;
    align-items: center; /* Linki w menu też w jednej linii */
}

.nav-link {
    text-decoration: none;
    color: #597d9e; 
    font-size: 1rem;
    font-style: italic;
    font-weight: 500;
    transition: color 0.3s;
    line-height: 1;
    display: block; /* Pomaga w równym ułożeniu */
}

.nav-link:hover { color: #333; }

/* HAMBURGER (Mobile) */
.hamburger {
    display: none; 
    background: none;
    border: none;
    font-size: 26px;
    cursor: pointer;
    color: #333;
    padding: 0;
    margin: 0;
    line-height: 1;
    align-items: center;
}

/* --- 4. GŁÓWNY UKŁAD TREŚCI (Fix rozjeżdżania się) --- */
main {
    flex-grow: 1;
    background-color: #ffffff60;
    flex-grow: 1;
    width: 80%;
    margin-left: 10%;
    margin-right: 10%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    /* RESET */
    margin-top: 0 !important; 
    
    /* ODSTĘP OD GÓRY */
    /* 90px (wysokość headera) + 40px (luzu) = 130px. */
    /* Dzięki temu tekst nie wchodzi pod nagłówek, ale tło maina jest pod nim */
    padding-top: 130px;
}

/* To jest Twój "Kontener" trzymający szerokość 1140px */
.content-sheet {
    width: 100%;
    max-width: 1140px; 
    margin: 0 auto;    
    padding: 40px 20px; 
    
    /* TO SĄ KLUCZOWE ZMIANY DLA KOMPUTERA: */
    display: flex;
    flex-direction: row;   /* Ustawia elementy obok siebie */
    align-items: center;   /* Wyśrodkowuje je w pionie */
    justify-content: center;
    gap: 40px;             /* Odstęp między tekstem a zdjęciem */
}

/* Tytuły na środku */
.section-title, h1 {
    font-family: 'Open Sans', sans-serif;
    font-size: 3rem;
    text-align: center; /* Wyśrodkowanie */
    margin-bottom: 40px;
    font-weight: normal;
    width: 100%;
}

/* --- 5. STRONA GŁÓWNA (INDEX) --- */
.hero-block {
    text-align: left;
    max-width: 50%;
    font-size: 1.4rem;
}

.hero-heading {
    font-size: 2.2rem;
    margin-bottom: 15px;
    font-weight: 400;
    font-family: 'Montserrat', sans-serif !important;;
}

.hero-image {
    margin: auto;
    width: auto;
    height: auto;
    max-width: 300px;
    max-height: 50vh; /* Ograniczenie wysokości zdjęcia */
    box-shadow: 0 10px 20px rgba(0,0,0,0.15); /* Cień pod zdjęciem */
    border-radius: 3%;  
}

/* --- 6. GALERIA (Grid) --- */
/* Styl dla tytułu na zdjęciu (np. "Ptaszek") */
.overlay-title {
    font-weight: 700;       /* Mocne pogrubienie */
    font-size: 1.5rem;      /* Duża czcionka */
    margin-bottom: 10px;    /* Odstęp od opisu pod spodem */
    line-height: 1.2;
    text-shadow: 1px 1px 3px rgba(0,0,0,0.8); /* Lekki cień pod tekstem dla czytelności */
}

/* Styl dla opisu pod tytułem (np. "Spotkany w lesie") */
.gallery-overlay p {
    font-size: 0.9rem;      /* Mniejsza czcionka dla opisu */
    font-weight: 400;       /* Normalna grubość */
    margin: 0;
    line-height: 1.4;
}

.content-sheet.pvpolicy-mode {
    flex-direction: column !important; /* Tytuł NAD zdjęciami, a nie obok */
    align-items: center;
    gap: 30px;
    width: 100%;
}

.content-sheet.gallery-mode {
    flex-direction: column !important; /* Tytuł NAD zdjęciami, a nie obok */
    align-items: center;
    gap: 30px;
    width: 100%;
    max-width: 1200px; /* Galeria może być nieco szersza */
}

.gallery-grid {
    display: grid;
    /* To magiczna linijka: twórz tyle kolumn ile się zmieści, 
       ale niech żadna nie będzie węższa niż 300px */
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); 
    gap: 15px; /* Odstęp między kafelkami */
    width: 100%;
}

.gallery-item {
    position: relative;
    width: 100%;
    
    /* To wymusza idealny kwadrat niezależnie od rozmiaru ekranu: */
    aspect-ratio: 1 / 1; 
    
    overflow: hidden;
    cursor: pointer;
    box-shadow: 0 4px 8px rgba(0,0,0,0.1); /* Lekki cień dla estetyki */
}

.gallery-img {
    width: 100%;
    height: 100%;
    object-fit: cover; /* Zdjęcie wypełnia kwadrat, nie zniekształca się */
    transition: transform 0.5s ease;
    display: block;
}

/* Hover - Ciemna nakładka */
.gallery-overlay {
    position: absolute;
    top: 0; left: 0; width: 100%; height: 100%;
    background: rgba(0, 0, 0, 0.6); 
    color: #fff;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    opacity: 0;
    transition: opacity 0.3s;
    padding: 10px;
}

.gallery-item:hover .gallery-overlay { opacity: 1; }
.gallery-item:hover .gallery-img { transform: scale(1.1); }

/* PAGINACJA */
#pagination-controls {
    margin-top: 30px;
    display: flex;
    justify-content: center;
    gap: 5px;
}
.page-btn {
    border: 1px solid #73a3d0;
    background: transparent;
    padding: 5px 12px;
    cursor: pointer;
    color: #333;
}
.page-btn.active {
    background: #73a3d0;
    color: white;
}
.hidden-photo { display: none !important; }

/* --- 7. STOPKA --- */
footer {
    background-color: #435365; 
    width: 100%;
    text-align: center;
    padding: 20px;
    margin-top: auto;
    font-size: 0.9rem;
    border-top: 5px solid white;
    color: white;
    display: flex;
    flex-direction: row;
}

footer p{
    margin-left: 20px;
    margin-right: 20px;
    align-self: center;
}

.social-links img {
    order: -1;              /* Przesuwa ikonkę na lewo przed tekst */
    width: 30px;            /* Sztywna szerokość */
    height: 30px;           /* Sztywna wysokość */
    display: block;         /* Usuwa zbędne odstępy */
    margin-right: 15px;     /* Odstęp od tekstu */
    
    object-fit: contain;    
}

.social-links {
    display: flex;
    flex-direction: column; /* Linki jeden pod drugim */
    gap: 15px;              /* Odstęp między Facebookiem a Instagramem */
    
    /* CENTROWANIE CAŁEGO BLOKU W STOPCE */
    width: fit-content;     /* Szerokość tylko taka, jakiej potrzebują linki */
    margin: 20px auto;      /* "auto" po bokach centruje blok na środku ekranu */
    align-self: center;
}

.social-links a {
    display: flex;
    
    /* TO JEST KLUCZ DO WYRÓWNANIA GÓRA-DÓŁ: */
    align-items: center;    /* Idealnie centruje ikonę i tekst w pionie */
    
    text-decoration: none;
    color: inherit;
    width: 100%;
}

.social-links label {
    cursor: pointer;
    white-space: nowrap;    
    font-size: 1rem;
    
    /* Resetujemy linię, żeby tekst nie uciekał w górę/dół */
    line-height: 1;         
    margin: 0;
    
    /* Wyrównanie samego tekstu */
    text-align: left;       
}

hr{
    border: none;
    background-color: rgb(201, 201, 201);
    color: rgb(209, 209, 209);
    width: 50%;
    margin-left: 10px;
    margin-right: 10px;
    margin-bottom: auto;
    margin-top: auto;
    height: 1px;
}

/* --- 8. MOBILE (RWD) --- */
@media (max-width: 991px) {
    .header-left, .header-right { flex: 0 0 auto; } /* Na tablecie nie rozciągaj boków */
    .gallery-grid { grid-template-columns: repeat(2, 1fr); }
}

/* --- WIDOK MOBILNY (TELEFONY) - WERSJA POPRAWIONA --- */
@media (max-width: 768px) {
    
    main {
        width: 100% !important;
        margin: 0 !important;
        padding-top: 110px !important; /* Trochę mniej luzu na telefonie */
    }

    /* 1. NAGŁÓWEK (Układ pionowy) */
    .header-container { flex-wrap: wrap; }
    
    .header-left { 
        width: 100%; 
        text-align: center; 
        margin-bottom: 5px;
        order: 1; 
    }
    .header-center { 
        width: auto; 
        order: 2; 
    }
    .header-right { 
        width: auto; 
        order: 3; 
    }
    
    .logo { font-size: 1.8rem; } 
    .author-name { display: none; } 
    
    .hamburger { display: block; margin-left: auto; }
    
    .nav-menu {
        display: none;
        position: absolute;
        top: 100%; 
        left: 0; 
        width: 100%;
        background: white;
        
        /* ZMIANA 1: Ustawiamy w kolumnę (pionowo) */
        flex-direction: column; 
        
        /* ZMIANA 2: Centrujemy elementy flexa */
        align-items: center;    
        justify-content: center;
    
        box-shadow: 0 5px 10px rgba(0,0,0,0.1);
        z-index: 999;
    
        /* ZMIANA 3: Resetujemy padding (ważne przez Twoje globalne !important na dole pliku) */
        padding: 20px 0 !important; 
        margin: 0 !important;
    }

    .nav-menu.active { display: flex; }
    
    /* 2. GŁÓWNY KONTENER (Rozciągnięcie na boki) */
    .content-sheet {
        flex-direction: column !important; /* Układ pionowy */
        
        /* Marginesy: 20px góra/dół, 15px boki. */
        padding: 20px 40px !important; 
        
        width: 100% !important;
        max-width: 100% !important;
        
        /* Ważne: pozwala elementom w środku zająć całą szerokość */
        align-items: stretch !important; 
        gap: 30px;
    }

    /* 3. BLOK TEKSTU (To naprawia "zbicie na środku") */
    .hero-block {
        max-width: 100% !important; /* Usuwa limit 800px z komputera */
        width: 100% !important;     /* Wymusza pełną szerokość */
        
        /* Tekst wyjustowany (elegancki blok) */
        text-align: center !important; 
    }

    /* Tytuł "O mnie" wyśrodkowany (bo justowanie tytułu wyglądałoby źle) */
    .hero-heading {
        text-align: center !important;
        font-size: 2rem !important;
    }

    /* Zmniejszenie czcionki tekstu dla czytelności */
    .hero-block p {
        font-size: 0.95rem !important;
    }

    /* 4. ZDJĘCIE */
    .hero-image {
        width: 100%
    }
}

ul, ol {
    /* 1. Kropka "na zewnątrz" pudełka z tekstem */
    list-style-position: outside !important; 
    
    /* 2. Musimy zrobić miejsce na tę kropkę z lewej strony, 
       inaczej wyjdzie poza ekran. 20px to zazwyczaj idealnie. */
    padding-left: 20px !important; 
    
    /* 3. Reset marginesu, żeby nie przesuwało za mocno */
    margin-left: 0 !important;
}

/* FIX LIGHTBOX (Centrowanie) */
.lightboxOverlay { position: fixed !important; top:0; left:0; width:100%; height:100%; }
#lightbox { position: fixed !important; top: 50% !important; left: 50% !important; transform: translate(-50%, -50%) !important; }

/* --- 9. PRZYCISKI DOSTĘPNOŚCI (WCAG) - WERSJA PC/TABLET FIX --- */

/* 1. USTAWIENIA BAZOWE (Dla komputerów - "Szuflada") */
#access-buttons {
    position: fixed;
    bottom: 20%; 
    right: 0;
    z-index: 10000;
    display: flex;
    flex-direction: column;
    align-items: flex-end; 
    gap: 10px;
    
    /* PŁYNNE UKRYWANIE PRZY STOPCE */
    /* Dodajemy to tutaj, aby cały kontener płynnie zjeżdżał w dół */
    transition: transform 0.5s ease, opacity 0.5s ease;
}

.access-btn {
    display: flex;
    align-items: center;
    justify-content: flex-start; /* Tekst od lewej strony */
    
    background-color: #0000007c;
    color: #ffffff;
    border: none;
    border-right: none;
    border-radius: 8px 0 0 8px; 
    
    padding: 12px 0 12px 15px;
    
    /* PC FIX: Zmniejszyliśmy z 290px na 220px. */
    /* Dzięki temu po wysunięciu przycisk jest zgrabny i nie zasłania pół strony. */
    min-width: 180px; 
    
    cursor: pointer;
    font-weight: bold;
    font-size: 14px;
    font-family: 'Montserrat', sans-serif;
    white-space: nowrap;
    box-shadow: -2px 2px 5px rgba(0,0,0,0.3);
    
    /* PC FIX: Ustawiamy widoczność tekstu. */
    /* 100% - 115px oznacza, że zawsze widzisz 115 pikseli przycisku. */
    /* To wystarczy, by przeczytać "Zwiększ..." */
    transform: translateX(calc(100% - 140px)); 
    
    /* Animacja wysuwania samego przycisku po najechaniu */
    transition: transform 0.3s cubic-bezier(0.25, 0.8, 0.25, 1), background-color 0.3s;
}

/* PC: Po najechaniu myszką - wysuń całkowicie */
.access-btn:hover {
    background-color: #435365;
    transform: translateX(0); 
}

/* 2. WYJĄTEK DLA TELEFONÓW (Poniżej 768px) */
@media (max-width: 768px) {
    #access-buttons {
        bottom: 20px; 
        right: 0;
        gap: 8px;
        align-items: flex-end;
    }

    .access-btn {
        /* Resetujemy animacje szuflady */
        min-width: auto !important; 
        transform: none !important; 
        
        /* Sztywna szerokość dla równych przycisków na telefonie */
        width: 170px !important;    
        justify-content: center !important; 
        
        padding: 10px 5px !important;
        font-size: 13px !important;
        border-radius: 5px 0 0 5px;
    }
    
    .access-btn:hover {
        transform: none !important;
    }
}

/* 3. KLASA UKRYWAJĄCA (Aktywowana przez JS przy stopce) */
#access-buttons.hidden-near-footer {
    transform: translateY(200%) !important; /* Zjazd w dół */
    opacity: 0; /* Zanikanie */
    pointer-events: none; /* Klikanie niemożliwe gdy ukryte */
}

/* --- LOGIKA TRYBU CZYTELNOŚCI - FIX CENTROWANIA TEKSTU --- */

/* 1. BAZA: Globalne powiększenie czcionek */
body.high-readability { 
    font-size: 130% !important; 
}

body.high-readability * { 
    font-weight: 700 !important; 
    line-height: 1.6 !important; 
}

/* 2. WYJĄTKI (Logo zostaje bez zmian) */
body.high-readability .logo { 
    font-weight: 400 !important; 
    font-size: 2.5rem !important; 
    letter-spacing: normal !important; 
}

/* 3. POWIĘKSZONE ELEMENTY INTERFEJSU */
body.high-readability .author-name { font-size: 1.4rem !important; }
body.high-readability .nav-link { font-size: 1.3rem !important; text-decoration: none !important; }

/* 4. KONFIGURACJA PODPISU POD ZDJĘCIEM */
body.high-readability .lb-caption {
    font-size: 1.5rem !important;    
    font-weight: 700 !important;
    line-height: 1.4 !important;
    color: #f1f1f1 !important;
    text-align: center !important; /* Tekst na środku */
    display: block !important;
}

body.high-readability .lb-number {
    font-size: 0.9rem !important;
    opacity: 0.8;
    font-weight: normal !important;
    text-align: center !important;
}

/* 5. FIX GEOMETRII LIGHTBOXA (Fit-content) */
body.high-readability .lightbox,
body.high-readability .lb-outerContainer,
body.high-readability .lb-dataContainer {
    font-weight: normal !important; 
}

/* Pudełko ze zdjęciem dopasowane do zawartości */
body.high-readability .lb-outerContainer {
    width: fit-content !important;
    height: auto !important;
    margin: 0 auto !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
}

/* Pudełko z danymi (tekstem) - pełna szerokość */
body.high-readability .lb-dataContainer {
    width: 100% !important;
    max-width: 100% !important;
}

/* 6. FIX UKŁADU TEKSTU (To naprawia "uciekanie w lewo") */
/* Lightbox domyślnie ustawia tu float:left i width:85%. Musimy to nadpisać! */
body.high-readability .lb-data .lb-details {
    width: 100% !important;      /* Rozciągnij na całą szerokość */
    float: none !important;      /* Wyłącz przyklejenie do lewej */
    text-align: center !important; /* Wyśrodkuj zawartość */
    display: block !important;   /* Upewnij się, że to blok */
}

/* Przycisk zamknięcia (X) też niech nie przeszkadza */
body.high-readability .lb-data .lb-close {
    float: none !important;      /* Wyłącz float dla X */
    display: inline-block !important; /* Pokaż go obok lub pod tekstem */
    margin-top: 10px !important;
    text-align: center !important;
}

/* --- RESPANSYWNOŚĆ (Bez zmian) --- */
@media (min-width: 769px) {
    body.high-readability .lb-image {
        max-height: 80vh !important; 
        width: auto !important;      
        max-width: 100% !important;
        height: auto !important;
        line-height: 0 !important;
        display: block !important;
    }
}

@media (max-width: 768px) {
    body.high-readability .lb-image {
        max-width: 95vw !important;
        height: auto !important;
        width: auto !important;
        line-height: 0 !important;
    }
    body.high-readability .lb-outerContainer {
        max-width: 95vw !important; 
    }
    body.high-readability .lb-caption {
        font-size: 1.2rem !important;
    }
}