/* Sticky footer – układ strony */
html, body { height: 100%;
			 background-color: #fff; 
}

html, body, main {
  background-color: #fff !important;
}

/* Resetowanie marginesów i odstępów */
body, h1, h2, p, nav, section, footer {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

/* Styl ogólny strony */
body {
    font-family: Arial, sans-serif;
    font-size: 16px;
    color: #333;
    background-color: #fff;
	min-height: 100dvh;          /* pełna wysokość widoku */
    display: flex;
    flex-direction: column;
}

/* Pasek nawigacyjny */
nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 20px;
    background-color: white;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
}

nav .logo {
    font-size: 1.5rem;
    font-weight: bold;
}

nav a {
    text-decoration: none;
    color: white;
    margin-left: 15px;
    font-weight: bold;
    transition: color 0.3s;
}

.logo h1 {
    font-family: 'Arial Black', Arial, sans-serif;
    font-size: 1.8rem; /* Rozmiar tekstu */
    font-weight: Light;
    color: #0073e6;
    margin: 0;
    text-align: center;
}

nav a:hover {
    color: #fffcf5;
}

/* Logo */
.logo {
    width: 25%; /* 25% szerokości na logo */
    display: flex;
    justify-content: center; /* Wyśrodkowanie tekstu w poziomie */
    align-items: center; /* Wyśrodkowanie tekstu w pionie */
    text-align: center; /* Dodatkowe wyrównanie tekstu */
}

/* Sekcja z nagłówkami */
.header-section {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 70%; /* Cała przestrzeń dla klawiszy */
}

.header-links {
    display: flex;
    justify-content: center; /* Wycentrowanie linków w pozostałej przestrzeni */
    gap: 15px; /* Odstęp między klawiszami */
    flex: 1; /* Elastyczna przestrzeń */
}

/* Klawisze */
.header-box {
    flex: 0 0 120px; /* Szerokość klawiszy */
    max-width: 120px;
    text-align: center;
    padding: 8px 12px;
    border: 2px solid #0073e6;
    border-radius: 10px;
    color: #11ADFE;;
    font-size: 1rem;
    font-weight: bold;
    background-color: #f9f9f9;
    text-decoration: none;
    transition: transform 0.3s, box-shadow 0.3s;
}

.header-box:hover {
    transform: translateY(-3px);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
    background-color: #e6f2ff;
}

/* Klawisz logowania */
.login-btn {
    background-color: #0073e6;
    color: white;
}

.login-btn:hover {
    background-color: #005bb5;
    color: #e6f2ff;
}

/* Styl dla main */
main{
  width: 10 0%;
  margin: 0;
  padding: 0;

  /* 2 warstwy: 1) welon (rozjaśnienie), 2) logo */
  background-image:
    linear-gradient(rgba(255,255,255,.7), rgba(255,255,255,.7)),
    url("/images/logo.svg");
  background-repeat: no-repeat, no-repeat;

  /* rozmiary odpowiadają kolejności warstw */
  background-size: cover, 50% auto;

  /* pozycje odpowiadają kolejności warstw */
  background-position: center, center calc(50% + 80px);
}

/* WARIANT: bez obrazka w tle (zostaje sam „welon”) */
.main-no-image{
  background-image: linear-gradient(rgba(255,255,255,.7), rgba(255,255,255,.7)) !important;
  background-repeat: no-repeat !important;
  background-size: cover !important;
  background-position: center !important;
}

/* główna zawartość rozpycha stronę */
#main-content {
  flex: 1 0 auto;
}

.navbar .nav-link .bi-facebook {
  color: #1877f2; /* firmowy fb niebieski */
  transition: opacity .2s ease-in-out;
}

.navbar .nav-link:hover .bi-facebook,
.navbar .nav-link:focus .bi-facebook {
  opacity: .75;
}

/* Sekcja powitalna */
.hero{
	display:flex;
	flex-direction:column;
	align-items:center;
	justify-content:flex-start;
	min-height:20vh;   /* możesz zwiększyć np. do 50–60vh */
	padding:20px;
	text-align:center;
}
.hero h1 { position: relative; z-index: 1; }

/* Dla dużych ekranów - tekst na 3/4 wysokości */
.hero h1 {
    margin-top: 0vh; /* Przesunięcie w dół */
    transform: translateY(10%); /* Dostosowanie ostatecznego położenia */
    font-family: 'Arial Black', Arial, sans-serif;
    font-weight: 300;
    font-size: 2.5rem;
    line-height: 1.3;
}

.hero p {
    font-size: 1.2rem; /* Rozmiar tekstu dla opisu */
    text-align: center;
}

/* Dynamiczny kolor tekstu */
.dynamic-color {
    font-family: 'Arial Black', Arial, sans-serif;
    font-weight: 300;
    margin-bottom: 15px;
    font-size: 2.5rem;
    line-height: 1.3;
    text-shadow: 2px 2px 4px rgba(255, 255, 255, 0.7); /* Dodatkowy cień dla kontrastu */
}

/* Karty sekcji */
.cards-container {
    display: grid;
    grid-template-columns: 1fr; /* Domyślnie jedna kolumna */
	margin-top: 120px;
    gap: 50px;
    padding: 40px;
    margin: 0 auto;
    max-width: 1200px;
	background-color: transparent !important;
}

#cards.container, #cards .row {
  background-color: transparent !important;
}

.navbar .dropdown-menu {
  border: 0;
  box-shadow: 0 12px 28px rgba(0,0,0,.12);
  border-radius: 12px;
  padding: .5rem;
}
.navbar .dropdown-menu { min-width: 19rem; } /* np. 14–18rem */
#cards {
    padding: 20px 0; /* Odstęp wewnętrzny dla lepszej prezentacji */
}

.navbar .dropdown-toggle:focus,
.navbar .dropdown-item:focus {
  outline: 2px solid rgba(13,110,253,.35);
  outline-offset: 2px;
}

.card {
    border: 1px solid #ddd;
    border-radius: 10px;
    transition: transform 0.3s ease-in-out, box-shadow 0.3s ease-in-out;
}

.card:hover {
    transform: translateY(-5px); /* Efekt podniesienia przy najechaniu */
    box-shadow: 0 10px 15px rgba(0, 0, 0, 0.2); /* Cień przy najechaniu */
}

.card a {
    display: block;
    text-decoration: none;
    color: inherit;
    padding: 20px;
}

.card h3 {
    margin-bottom: 10px;
    color: #000000;
}

.card p {
    font-size: 1rem;
}

/* Karty zajmujące 80% szerokości */
.custom-card {
    width: 80%; /* Szerokość karty */
    margin-left: auto;
    margin-right: auto;
    background-color: #11ADFE;
	border: 1px solid rgba(0,0,0,.08);
    max-width: 700px; /* Ograniczenie maksymalnej szerokości */
}

/* Kolor tła dla stopki */
.bg-footer-color {
    background-color: #E0F2FE;
}

/* Tekst stopki */
footer {
	margin-top: auto;            /* klucz do sticky footer */
    font-size: 0.9rem; /* Pomniejszona czcionka */
    line-height: 1.4; /* Optymalny odstęp między liniami */
}

/* Linki w stopce */
footer a {
    color: #f8d210; /* Kontrastowy kolor linków */
    font-weight: 500;
}

footer a:hover {
    color: #ffdd57; /* Jaśniejszy żółty przy najechaniu */
    text-decoration: underline;
}

/* Styl dla trybu dostępności */
body.accessibility-mode {
    font-size: 20px; /* Powiększony tekst */
    color: #000; /* Czarny tekst */
    background-color: #ffffe0; /* Jasne tło dla kontrastu */
    line-height: 1.6; /* Większy odstęp między liniami */
}

body.accessibility-mode a {
    color: #005bb5; /* Wyraźniejszy kolor linków */
    font-weight: bold;
    text-decoration: underline;
}

body.accessibility-mode a:hover {
    color: #00274d; /* Ciemniejszy kolor przy najechaniu */
}

body.accessibility-mode .header-box {
    border: 2px solid #000; /* Wyraźniejsza ramka */
    background-color: #ffffe0;
    color: #000;
}

/* Styl przycisku */
#toggle-accessibility {
    padding: 10px 15px;
    margin-left: 20px;
    background-color: #0073e6;
    color: #fff;
    border: none;
    border-radius: 5px;
    cursor: pointer;
    font-size: 1rem;
}

#toggle-accessibility:hover {
    background-color: #005bb5;
}


/* Dostosowanie czcionki dla małych urządzeń */
@media (max-width: 768px) {
    .hero h1 {
        font-size: 1.8rem; /* Pomniejszony nagłówek */
        line-height: 1.2;
    }

    .hero p {
        font-size: 1rem; /* Pomniejszony opis */
    }
	.hero{ background-size: 50% auto, cover; }

    .custom-card {
        width: 100%; /* Pełna szerokość w ramach kolumny */
    }
}

@media (max-width: 480px) {
    .hero h1 {
        font-size: 1.5rem; /* Jeszcze mniejszy nagłówek dla bardzo małych urządzeń */
        line-height: 1.1;
    }
		
    .hero p {
        font-size: 0.9rem; /* Dostosowanie opisu */
	
    }
	.hero{ background-size: 50% auto, cover; }
}

.text-color-accent-DIM {
  color: #003366; 
}


.highlight-box {
  border: 1px solid #11ADFE;;       /* kolor ramki */
  border-radius: 4px;              /* zaokrąglenie rogów */
  padding: 0 4px;                  /* odstęp od tekstu */
  background-color: #EAF4FF;       /* opcjonalnie lekki kolor tła */
  box-decoration-break: clone;     /* utrzymuje wygląd przy zawijaniu */
}
section#cards,
section#cards.container,
section#cards.cards-container {
  background: transparent !important; /* zeruje color+image */
}

/* karty zostają pełne */
#cards .card { background-color: #fff; }          
#cards .custom-card { background-color: #11ADFE80; } 


