body {
    background: #344874;
}

/* Topbar */
.topbar {
    background: #212529;
    color: #fff;
    padding: 5px 20px;
    font-size: 0.9rem;
}

.topbar .contact-info {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 15px;
    color: #576ea0;
}

/* Logo dopasowane do wymiarów 377x167 */
.navbar-brand img {
    width: auto;
    height: 80px;
}

/* Slider - pełna szerokość */
.carousel-item img {
    height: 500px;
    object-fit: cover;
}

.logo img {
    box-shadow: 0 0 40px 20px rgba(255,255,255,0.7), /* jasna poświata wokół */
                0 0 80px 40px rgba(52,72,116,0.4);    /* niebieska poświata wokół */
    border-radius: 10px;
    margin: 0 5px; /* równy odstęp między logami */
}

.logo {
    padding: 10px 0 30px 0; /* większy odstęp góra/dół dla loga */
}

        .max-container {
            max-width: 1200px;
            margin: 0 auto;
        }
        .logo-shadow {
            box-shadow: 0 8px 16px rgba(47, 65, 170, 0.3);
        }
        .navbar-nav .nav-link {
            position: relative;
            transition: color 0.3s ease;
        }
        .navbar-nav .nav-link::after {
            content: "";
            position: absolute;
            width: 0;
            height: 2px;
            bottom: 0;
            left: 0;
            background-color: #ff0000;
            transition: width 0.3s ease;
        }
        .navbar-nav .nav-link:hover::after {
            width: 100%;
        }
        .navbar-nav .nav-link:hover {
            color: #0d6efd;
        }

/* -------------------
   Wersja mobilna
------------------- */
@media (max-width: 768px) {
    /* Topbar: kontakt na środku i w kolumnie */
    .topbar .contact-info {
        flex-direction: column;
        align-items: flex-start;
        gap: 5px;
        font-size: 0.85rem;
        color: #576ea0;
    }

    /* Logo ma być na środku */
    .navbar-brand {
        display: block;
        margin: 0 auto;
        text-align: center;
    }

    .navbar-brand img {
        height: 70px;
    }

    /* Hamburger menu po prawej */
    .navbar-toggler {
        position: absolute;
        right: 10px;
        top: 25px;
    }

}

/* Galeria - hover efekt */
.container img {
    transition: transform 0.3s ease;
        box-shadow: 0 5px 15px rgba(255,255,255,0.6);
    border-radius: 10px;
    
}

.container img:hover {
    transform: scale(1.05);
        box-shadow: 0 8px 25px rgba(255,255,255,0.8);
}

/* Cień i gładki wygląd modala */
.modal-content {
    border: none;
    box-shadow: 0 10px 30px rgba(0,0,0,0.7);
}

/* Przyciski nawigacyjne - efekt hover */
#prevBtn:hover, #nextBtn:hover {
    background-color: rgba(255,255,255,0.2);
}

/* Obraz z lekkim cieniem */
#popupImage {
    box-shadow: 0 8px 25px rgba(0,0,0,0.6);
}

/* Strzałki w popupie (pełna poprawka mobilna) */
.btn-nav {
    display: flex !important;
    align-items: center;
    justify-content: center;
    width: 3rem;
    height: 3rem;
    border-radius: 50% !important;     /* Wymuszamy pełne zaokrąglenie */
    background: rgba(255,255,255,0.15);
    border: 2px solid rgba(255,255,255,0.6);
    font-size: 1.8rem;
    color: #fff;
    cursor: pointer;
    transition: all 0.2s ease-in-out;

    /* Resetujemy styl buttona na mobile */
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
}

.btn-nav:hover {
    background: rgba(255,255,255,0.3);
    border-color: #fff;
}

.btn-nav:focus {
    outline: none;
    box-shadow: none;
}

/* Slider – zaokrąglone zdjęcia z cieniem */
.carousel-inner img {
    border-radius: 15px;           /* zaokrąglone rogi */
    box-shadow: 0 8px 20px rgba(0,0,0,0.4); /* cień */
    max-height: 500px;             /* żeby nie były za wysokie na dużych ekranach */
    object-fit: cover;              /* proporcje zdjęć */
}

/* Fade efekt slidera – przyspieszona animacja */
.carousel-item {
    transition: opacity 1s ease-in-out;
}

/* Animacje caption w sliderze */
.animate-caption * {
    opacity: 0;
    transform: translateY(20px);
    transition: all 0.8s ease;
}

.carousel-item.active .animate-caption * {
    opacity: 1;
    transform: translateY(0);
}

/* Indywidualne efekty */
.animate-fade {
    transition-delay: 0.2s;
}

.animate-slide {
    transition-delay: 0.4s;
    transform: translateY(30px);
}

.animate-zoom {
    transition-delay: 0.6s;
    transform: scale(0.8);
}

.carousel-item.active .animate-slide {
    transform: translateY(0);
}

.carousel-item.active .animate-zoom {
    transform: scale(1);
}

/* Responsywne napisy w sliderze */
@media (max-width: 768px) {
    .carousel-caption h2 {
        font-size: 1.3rem;   /* mniejszy nagłówek */
    }
    .carousel-caption p {
        font-size: 0.9rem;   /* mniejszy tekst */
    }
    .carousel-caption .btn-cta {
        font-size: 0.8rem;   /* mniejszy przycisk */
        padding: 6px 14px;
    }
    .carousel-caption {
        padding: 10px;       /* mniej miejsca w tle */
        border-radius: 8px;
    }
}

@media (max-width: 480px) {
    .carousel-caption h2 {
        font-size: 1rem;     /* jeszcze mniejszy nagłówek na bardzo małych ekranach */
    }
    .carousel-caption p {
        display: none;       /* ukrywamy opis, zostaje tylko nagłówek i przycisk */
    }
    .carousel-caption .btn-cta {
        width: 100%;         /* przycisk na całą szerokość */
    }
}

/* Cień dla logo - bardzo delikatna, symetryczna poświata w kolorze #344874 */
.logo img, .navbar-brand img {
    box-shadow:
        0 0 15px 3px #344874;
    border-radius: 10px;
    transition: box-shadow 0.3s ease, transform 0.3s ease;
}

.logo img:hover, .navbar-brand img:hover {
    box-shadow:
        0 0 15px 3px #344874;
    transform: scale(1.07);
}

/* --- Style przeniesione z header.php --- */
.max-container {
    max-width: 1200px;
    margin: 0 auto;
}
.logo-shadow {
    box-shadow: 0 0 15px rgba(207, 187, 187, 0.1);
}
.navbar-nav .nav-link {
    position: relative;
    transition: color 0.3s ease;
}
.navbar-nav .nav-link::after {
    content: "";
    position: absolute;
    width: 0;
    height: 2px;
    bottom: 0;
    left: 0;
    background-color: #ff0000;
    transition: width 0.3s ease;
}
.navbar-nav .nav-link:hover::after {
    width: 100%;
}
.navbar-nav .nav-link:hover {
    color: #0d6efd;
}
/* --- Koniec stylów z header.php --- */