


@import "https://fonts.googleapis.com/css?family=Poppins:300,400,500,600,700";
body {
    font-size: 14px; font-family: 'Poppins', sans-serif;

    /* background: #fafafa; */
}

p {

}

a,
a:hover,
a:focus {
    color: inherit;
    text-decoration: none;
    transition: all 0.3s;
}

.navbar {
    padding: 15px 10px;
    background: #000;
    border: none;
    border-radius: 3px;
    margin-bottom: 0px;
    box-shadow: 1px 1px 3px rgba(0, 0, 0, 0.1);
}

.navbar-btn {
    box-shadow: none;
    outline: none !important;
    border: none;
}

.line {
    width: 100%;
    height: 1px;
    border-bottom: 1px dashed #ddd;
    margin: 40px 0;
}

/* ---------------------------------------------------
    SIDEBAR STYLE
----------------------------------------------------- */

.wrapper {
    display: flex;
    width: 100%;
}

#sidebar {
    width: 260px;
   
    top: 0;
    left: 0;
    height: 500vh;
    z-index: 999;
    background: #F8F9FA;
    color: #000;
    transition: all 0.3s;
}

#sidebar.active {
    margin-left: -250px;
}

#sidebar .sidebar-header {
    padding: 5px;
    background: #F8F9FA;
}

#sidebar ul.components {
    padding: 5px 10px;
    border-bottom: 1px solid #47748b;
}

#sidebar ul p {
    color: #000;
    padding: 5px;
}

#sidebar ul li a {
    
    padding: 3px 0px; /* Większy padding dla lepszej czytelności */
    font-size: 1.0em;
    display: block;
}

#sidebar ul li a:hover {
    color: #F8F9FA;
    background: cadetblue;
}

#sidebar ul li a:focus {
    background-color:cadetblue;
    border-color: cadetblue;
    color:#fff;
    outline-color: transparent;
    outline-style:solid;
}

#sidebar ul li a:active
{
    background-color:cadetblue;
    border-color: cadetblue;
    color:#fff;
}


#sidebar ul li.active>a,
a[aria-expanded="true"] {
    color: #000;
    background: color: cadetblue;;
}

a[data-toggle="collapse"] {
    position: relative;
}

/* Domyślny trójkąt w dół */
.dropdown-toggle::after {
    display: block;
    position: absolute;
    top: 50%;
    right: 10px;
    transform: translateY(-50%);
    content: "";
    width: 0;
    height: 0;
    border-top: 6px solid #000;
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
}

/* Zmieniony trójkąt w górę, jeśli menu otwarte */
.dropdown-toggle[aria-expanded="true"]::after {
    border-top: none;
    border-bottom: 6px solid #000;
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
}

ul ul a {
    font-size: 1.0em !important;
    padding-left: 30px !important;
    background: #F8F9FA;
}

ul.CTAs {
    padding: 5px;
}

ul.CTAs a {
    text-align: center;
    font-size: 0.9em !important;
    display: block;
    border-radius: 3px;
    margin-bottom: 5px;
}

a.download {
    background: #000;
    color: #7386D5;
}

a.article,
a.article:hover {
    background: #F8F9FA !important;
    color: #000 !important;
}

/* ---------------------------------------------------
    CONTENT STYLE
----------------------------------------------------- */

#content {
    width: calc(100% - 250px);
    padding: 0px;
    min-height: 100vh;
    transition: all 0.3s;
    position: absolute;
    top: 0;
    right: 0;
}

#content.active {
    width: 100%;
}

.container {
    display: flex;
    flex-direction: column; /* Pionowe ułożenie */
    gap: 15px; /* Odstęp między elementami */
}
#divmenulewe, #divgrupy {
    flex: 1; /* Oba elementy zajmują równą szerokość */
}

/* ---------------------------------------------------
    MEDIAQUERIES
----------------------------------------------------- */

@media (max-width: 768px) {
    #sidebar {
        margin-left: -250px;
    }
    #sidebar.active {
        margin-left: 0;
    }
    #content {
        width: 100%;
    }
    #content.active {
        width: calc(100% - 250px);
    }
    #sidebarCollapse span {
        display: none;
    }
}

    td, th, input, select, textarea {
        border-radius: 3px; /* Zaokrąglone rogi */
    }

    input {
        border: 1px solid black; /* Jaśniejsza, delikatna ramka */
        outline: none; /* Usunięcie domyślnej obwódki */
        transition: border-color 0.3s ease-in-out; /* Płynna animacja */
    }

	.btn-i4c
	{
	  /* background-color: #f5e6e7; */
      background-color: Silver;
	  color:#000;
	  /* border-color: #f5e6e7; */
      border-color: Silver;
	  border-radius: 3px
	}	

    .btn-i4c:hover
	{
        background-color:#000;
        border-color: #000;
        color:#fff;
        transition: 0.7s;
    }

    .btn-i4c:focus {
        background-color:#000;
        border-color: #000;
        color:#fff;
        outline-color: transparent;
        outline-style:solid;
        box-shadow: 0 0 0 2px #000;
    }

    .btn-i4c:active, .btn-i4c.active, .open .dropdown-toggle.btn-i4c 
	{
        background-color:#000;
        border-color: #000;
        color:#fff;
        box-shadow: 0px 0px 2px 2px rgb(0,0,0);
    }

    .btn-info
	{
	  /* background-color: #f5e6e7; */
        background-color: Silver;
	  color:#000;
	  /* border-color: #f5e6e7; */
      border-color: Silver;
	  border-radius: 3px
	}

	.btn-info:hover, .btn-info:focus, .btn-info:active, .btn-info.active, .open .dropdown-toggle.btn-info 
	{
        background-color:#000;
        border-color: #000;
        color:#fff;
    }

    .TloCiemneZazn 
{  	
    background-color:cadetblue;
    border-color: #000;
    color:#fff;
}

.strony-table {
    margin: auto;
    border-collapse: separate; /* Musi być 'separate', aby działało border-radius */
    border-spacing: 0px; /* Dodajemy minimalny odstęp, aby zaokrąglenia były widoczne */
}

/* Komórki tabeli */
.strony-table .strony-cell {
    width: 30px;
    height: 30px;
    border: 1px solid lightgray;
    text-align: center;
    vertical-align: middle;
    cursor: pointer;
    color: cadetblue;
    border-radius: 0; /* Resetowanie domyślnego zaokrąglenia */
}

/* Zaokrąglenie dla pierwszej komórki w każdym wierszu */
.strony-table tr > .strony-cell:first-child {
    border-top-left-radius: 3px;
    border-bottom-left-radius: 3px;
}

/* Zaokrąglenie dla ostatniej komórki w każdym wierszu */
.strony-table tr > .strony-cell:last-child {
    border-top-right-radius: 3px;
    border-bottom-right-radius: 3px;
}

.strony-table .highlight-cell {
    /*color: red; */
    font-weight: 500;
    background-color: #e0e0e0; /* ciemne szare tło */
}


.twr0a-table  {
    width: calc(100% - 10px); /* Szerokość tabeli pomniejszona o marginesy */
    margin: 0px 5px; /* Marginesy po lewej i prawej stronie */
    background-color: #f9f9f9; /* Bardzo jasno szare tło */
    border-radius: 8px;        /* Zaokrąglone rogi */
}

.twr0b-table  {
    width: calc(100% - 10px); /* Szerokość tabeli pomniejszona o marginesy */
    margin: 0px 5px; /* Marginesy po lewej i prawej stronie */
    background-color: #eeeeee; /* Bardzo jasno szare tło */
    border-radius: 8px;        /* Zaokrąglone rogi */
}

.twr0a-table, .twr0b-table td {
    padding: 0px 10px; /* Wewnętrzne odstępy */
}

.twr1-table, .twr2-table {
    width: calc(100% - 10px); /* Szerokość tabeli pomniejszona o marginesy */
    margin: 0px 5px; /* Marginesy po lewej i prawej stronie */
    border-collapse: collapse; /* Usuwa podwójne linie */
    background-color: #f9f9f9; /* Bardzo jasno szare tło */
}

.twr2-table {
    background-color: #eeeeee; /* Ciemniejsze tło */
}

.twr3-table {
    width: calc(100% - 10px); /* Szerokość tabeli pomniejszona o marginesy */
    margin: 0px 5px; /* Marginesy po lewej i prawej stronie */
    border-collapse: collapse; /* Usuwa podwójne linie */
    background-color: #eeeeee; /* Ciemniejsze tło */
}

.twr1-table td, .twr2-table td, .twr3-table td   {
    padding: 5px 10px; /* Wewnętrzne odstępy */
    text-align: left; /* Tekst w nazwach wyrównany do lewej */
}

.twr1-table td.value, .twr2-table td.value {
    text-align: right; /* Wartości wyrównane do prawej */
}

.twr1-table tr, .twr2-table tr:nth-child(2n+2){
    border-bottom: 1px solid #ddd; /* Linia oddzielająca wiersze */
    width: 90%; /* Linie są krótsze niż szerokość komórki */
    margin: 0 auto; /* Linie są wyśrodkowane */
}

.twr1-table tr:last-child,  .twr2-table tr:last-child  {
    border-bottom: none; /* Usuwa linię na końcu tabeli */
}

.Atrybut-Table {
    width: 100%; /* Tabela zajmuje całą szerokość kontenera */
    max-width: 1025px;           /* ← ograniczenie do 1000px */
    border-collapse: collapse; /* Usuwa podwójne linie */
    margin: 20px 0; /* Marginesy górny i dolny */
    text-align: left; /* Wyrównanie tekstu w komórkach */
    table-layout: fixed; /* Równe szerokości kolumn */

    background-color: #f5f5f5; /* Jasno szare tło */
    border-radius: 8px;        /* Zaokrąglone rogi */
    overflow: hidden;          /* Działa tylko, gdy tabela w bloku */
    border: 1px solid #ccc;    /* Delikatna ramka */
}

.Atrybut-Table tbody {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr)); /* 6 równych kolumn */
    gap: 5px; /* Odstęp między komórkami */
    width: 96%;
    margin-left: 30px; 
    margin-right: 20px; 
}

.Atrybut-Table th {
    font-size: 18px; /* Większa czcionka */
    font-weight: 500;
    color: darkred; /* Czerwony kolor czcionki */
    text-align: left; 
    padding: 10px;
}

.Atrybut-Table td.separator-cell {
    grid-column: 1 / -1;
    height: 2px;
    background-color: #ccc;
    padding: 0;
    margin-top: 10px;
    margin-bottom: 10px;
    margin-left: -20px;   /* ← tu dodajesz lewy margines */
    margin-right: 5px;  /* ← i prawy margines */
    border-radius: 2px;  /* opcjonalnie, dla estetyki */
}

.Atrybut-Table tr.separator-row td {
    border-top: 2px solid #ccc;
    padding: 0;
    height: 5px;
    background: #f5f5f5;
}

.Atrybut-Table tr {
    display: contents; /* Zachowuje semantykę HTML */
}

.Atrybut-Table td {
    font-size: 16px;
    padding: 10px;
    vertical-align: top;
    display: flex;
    flex-direction: column; /* Ustawia wartości w kolumnie */
    justify-content: stretch; /* Zapewnia równą wysokość */

    box-sizing: border-box; /* Padding nie powiększa szerokości */
}


/* Styl dla sekcji Name */
.Atrybut-Table .name {
    font-weight: 500;
    word-wrap: break-word;
    overflow-wrap: break-word;
    white-space: normal;
    flex-grow: 1; /* Sprawia, że .name i .value mają równą wysokość */
    display: flex;
    align-items: flex-start; /* Wyrównuje tekst do góry */
}


/* Styl dla sekcji Value */
.Atrybut-Table .value {
    font-weight: normal;
    color: #555;
    word-wrap: break-word;
    overflow-wrap: break-word;
    white-space: normal;
    flex-grow: 1; /* Zapewnia równą wysokość */
    display: flex;
    align-items: flex-end; /* Wyrównuje tekst do góry */
}



.Pliki-Table {
    width: 100%; /* Tabela zajmuje całą szerokość kontenera */
    border-collapse: collapse; /* Usuwa podwójne linie */
    margin: 20px 0; /* Marginesy górny i dolny */
    text-align: left; /* Wyrównanie tekstu w komórkach */
}

.Pliki-Table th {
    font-size: 16px; /* Większa czcionka */
    font-weight: 500;
    color: black; /* Czarny kolor czcionki */
    text-align: left; 
    padding: 10px;
    background-color: #f2f2f2; /* Szare tło dla nagłówków */
}

.Pliki-Table td {
    font-size: 14px;
    padding: 10px;
    vertical-align: middle; /* Wyrównanie do góry */
}

.Pliki-Table .name {
    border: none; /* Usuń pionowe kreski */
    font-weight: 500; /* Wyróżnienie nazw */
    margin-bottom: 5px; /* Odstęp od wartości */
    color: darkred; /* Czerwony kolor czcionki */
}

.Pliki-Table .value {
    font-weight: normal; /* Wartości mniej wyróżnione */
    color: #555; /* Przygaszony kolor */
}

/* Naprzemienne tło dla wierszy tabeli */
.Pliki-Table tr:nth-child(even) {
    background-color: #f9f9f9; /* Jasno szare tło dla parzystych wierszy */
}

.Pliki-Table tr:nth-child(odd) {
    background-color: #ffffff; /* Białe tło dla nieparzystych wierszy */
}

/* Opcjonalne: Dodanie obramowania dla lepszego wyglądu */
.Pliki-Table td, .Pliki-Table th {
    border: 1px solid #ddd; /* Jasno szare obramowanie komórek */
}


.Pliki2-Table {
    width: 100%; /* Tabela zajmuje całą szerokość kontenera */
    border-collapse: collapse; /* Usuwa podwójne linie */
    margin: 20px 0; /* Marginesy górny i dolny */
    text-align: left; /* Wyrównanie tekstu w komórkach */
}

.Pliki2-Table th {
    font-size: 14px; /* Większa czcionka */
    font-weight: 500;
    color: black; /* Czarny kolor czcionki */
    text-align: left; 
    padding: 10px;
    background-color: #f2f2f2; /* Szare tło dla nagłówków */
}

.Pliki2-Table td {
    font-size: 14px;
    padding: 10px;
    vertical-align: middle; /* Wyrównanie do góry */
    border: none; /* Usuń obramowanie komórek */
}

/* Styl dla wierszy .name */
.Pliki2-Table tr.name {
    font-weight: 500; /* Wyróżnienie nazw */
    color: black; /* Czarny kolor tekstu */
    border-bottom: 2px solid #ccc; /* Linia podkreślenia */
    background-color: #ffffff !important; /* Zawsze białe tło */
}

.Pliki2-Table .name td {
    padding-bottom: 10px; /* Odstęp między tekstem a linią */
}

/* Styl dla wierszy .spacer */
.Pliki2-Table tr.spacer {
    height: 10px; /* Wysokość przerwy */
    background-color: #ffffff !important; /* Zawsze białe tło */
    border: none; /* Brak granic */
}

/* Naprzemienne tło dla wierszy .value */
.Pliki2-Table tr.value:nth-child(odd):not(.spacer):not(.name) {
    background-color: #f9f9f9; /* Szare tło */
}

.Pliki2-Table tr.value:nth-child(even):not(.spacer):not(.name) {
    background-color: #ffffff; /* Białe tło */
}

/* Pierwszy wiersz .value po spacer zawsze szary */
.Pliki2-Table tr.spacer + tr.value {
    background-color: #f9f9f9 !important; /* Szare tło */
}

/* Drugi wiersz .value po spacer zawsze biały */
.Pliki2-Table tr.spacer + tr.value + tr.value {
    background-color: #ffffff !important; /* Białe tło */
}

.FaLista-Table {
    width: 100%; /* Tabela zajmuje całą szerokość kontenera */
    border-collapse: collapse; /* Usuwa podwójne linie i odstępy */
    margin: 10px 0; /* Mniejszy margines górny i dolny */
    text-align: left; /* Wyrównanie tekstu w komórkach */
}

.FaLista-Table th {
    font-size: 14px; /* Czcionka nagłówków */
    font-weight: 500;
    color: black; /* Czarny kolor czcionki */
    text-align: left;
    padding: 6px; /* Mniejsze marginesy wewnętrzne */
    background-color: #e0e0e0; /* Nieco ciemniejsze szare tło dla nagłówków */
}

.FaLista-Table td {
    font-size: 14px;
    padding: 6px; /* Mniejszy padding w komórkach */
    vertical-align: middle; /* Wyrównanie do góry */
    border: none; /* Brak obramowania komórek */
}

/* Styl dla wierszy .name */
.FaLista-Table tr.name {
    font-weight: 500; /* Wyróżnienie nazw */
    color: black; /* Czarny kolor tekstu */
    border-bottom: 1px solid #ccc; /* Cieńsza linia podkreślenia */
    background-color: #ffffff !important; /* Zawsze białe tło */
}

/* Naprzemienne tło dla wierszy .value */
.FaLista-Table tr.value:nth-of-type(odd) {
    background-color: #f6f6f6; /* Jasnoszare tło */
}

.FaLista-Table tr.value:nth-of-type(even) {
    background-color: #ffffff; /* Białe tło */
}

/* Zapewnia, że pierwszy wiersz .value po nagłówku ma właściwy kolor */
.FaLista-Table tbody tr:first-of-type.value {
    background-color: #f6f6f6 !important; /* Jasnoszare tło dla pierwszego wiersza wartości */
}

.Filtr-Table {
    width: 100%;
    max-width: 100%; /* Zapobiega wychodzeniu poza kontener */
    border-spacing: 4px; /* Odstępy między komórkami */
    background-color: white; /* Kolor tła między komórkami */
    font-size: 14px;
    table-layout: fixed; /* Zapewnia równomierne dopasowanie szerokości kolumn */
}

.Filtr-Table td {
    background-color: #F8F9FA;/* Jasno-szare tło komórek */
    padding: 8px 12px; /* Większy padding: 8px góra/dół, 12px lewo/prawo */
}

/* Styl dla select w komórkach tabeli */
.Filtr-Table td select {
    width: 100%; /* Dopasowuje szerokość selecta do szerokości komórki */
    max-width: 220px; /* Maksymalna szerokość */
    min-width: 60px; /* Minimalna szerokość */
    padding: 4px; /* Minimalny padding dla lepszej czytelności */
    font-size: 14px;
    box-sizing: border-box; /* Zapobiega powiększaniu przez padding */
}

.Filtr-Table td input[type="text"] {
    width: 100%; /* Dopasowanie do szerokości komórki */
    max-width: 220px; /* Maksymalna szerokość - taka jak dla <select> */
    min-width: 60px; /* Minimalna szerokość */
    padding: 4px; /* Dodanie paddingu dla czytelności */
    font-size: 14px;
    box-sizing: border-box; /* Zapobiega powiększaniu przez padding */
}

/* Styl dla tekstu w komórce Name */
.Filtr-Table .Name {
    color: #000; /* Czarny tekst */
    font-weight: normal;
    font-size: 14px;
}

.FiltrLista-Table {
    width: 100%;
    border-collapse: colapse; /* było separate  - Oddzielne komórki */
    max-width: 100%; /* Zapobiega wychodzeniu poza kontener */
    border-spacing: 0px; /* Odstępy między komórkami */
    background-color: white; /* Kolor tła między komórkami */
    font-size: 14px;
}

.FiltrLista-Table td {
    background-color: #f0f0f0; /* Jasno-szare tło komórek */
    padding: 5px;
    /* border: 1px solid #ccc; */
    text-align: center; 
}

/* Styl dla tekstu w komórce Name */
.FiltrLista-Table .Name {
    color: #000; /* Czarny tekst */
    font-weight: normal;
    font-size: 14px;
}


.checkbox-filtr {
    display: flex;
    flex-direction: column;
    gap: 5px; /* Odstęp między elementami */
}

.checkbox-item {
    display: flex;
    align-items: center; /* Wyrównanie checkboxa i tekstu */
    gap: 8px; /* Odstęp między checkboxem a tekstem */
}

.checkbox-item input[type="checkbox"] {
    width: 16px;
    height: 16px;
    margin: 0; /* Usuwa domyślne marginesy */
    vertical-align: middle;
}

.checkbox-item label {
    font-size: 14px;
    cursor: pointer;
    display: inline-block;
    line-height: 16px; /* Dopasowanie wysokości tekstu do checkboxa */
    margin: 0; 
    padding: 0;
}

.checkbox-header {
    font-size: 14px;
    padding-bottom: 6px; /* Dodaje odstęp między tekstem a linią */
    position: relative; /* Umożliwia precyzyjne pozycjonowanie podkreślenia */
    cursor: pointer;
}

.checkbox-header::after {
    content: ""; /* Tworzy sztuczne podkreślenie */
    display: block;
    position: absolute;
    bottom: 0;
    left: 0px; /* Odsunięcie od lewej */
    right: 0px; /* Odsunięcie od prawej */
    height: 1px;
    background-color: #ccc; /* Kolor podkreślenia */
}

#loadingSpinner {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 9999;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: rgba(255, 255, 255, 0.8); /* Półprzezroczyste tło */
    width: 100%;
    height: 100%;
  }

  .spinner {
    border: 4px solid rgba(0, 0, 0, 0.1);
    border-top: 4px solid #000;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    animation: spin 1s linear infinite;
  }

  @keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
  }
  