/* --- DEFINICJA MOTYWU --- */
:root {
    /* --- KOLORY BAZOWE (Paleta) --- */
    --theme-beige: #EAD4B7;
    --theme-beige-dark: #bc9e82;

    /* --- KOLORY DODATKOWE - sprawdź czy nadal potrzebne --- */
    --theme-light: #fcfaf8;
    --theme-dark: #495057;
    --theme-white: #ffffff;
    --theme-shadow: rgba(0, 0, 0, 0.06);

    /* --- ZMIENNE LOGICZNE (Light Mode) --- */
    --bg-main: #fcfaf8;                     /* Tło całej strony */
    --bg-secondary: #f8f9fa;                /* Tło hoverów, inputów */
    --bg-glass: rgba(255, 255, 255, 0.95);  /* Półprzezroczyste tło (navbary) */
    --text-main: #495057;                   /* Główny tekst */
    --card-bg: #ffffff;                     /* Tło kart i elementów */
    --border-color: #f1f3f5;                /* Kolor ramek i linii */
    --shadow-color: rgba(0, 0, 0, 0.06);    /* Kolor cieni */
    --navbar-bg: var(--theme-beige);
    --primary-action: #212529;              /* Przyciski główne */
    --inverse-text: #ffffff;                /* Tekst na przyciskach */

    /* MODALE I OFFCANVAS (Light) */
    --panel-bg: #ffffff;
    --panel-border: #dee2e6;
    --item-hover-bg: #f8f9fa;
    --input-addon-bg: #f8f9fa;

    /* --- STAŁE --- */
    --border-radius-lg: 20px;
    --border-radius-sm: 12px;

    --primary-beige: var(--theme-beige-dark);
    --light-beige: var(--theme-beige);

    --soft-bg: #fdfaf5;
    --header-collapsed-height: 97px; /* Wysokość po zwinięciu */

    --theme-success: #198754; /* Wyraźna zieleń sukcesu */
    --theme-success-light: rgba(25, 135, 84, 0.4);
}

[data-bs-theme="dark"] {
    /* --- ZMIENNE LOGICZNE (Dark Mode) --- */
    --bg-main: #121212;
    --text-main: #e0e0e0;
    --card-bg: #1e1e1e;
    --bg-secondary: #2c3034;        /* Ciemniejszy szary dla tła elementów */
    --bg-glass: rgba(30, 30, 30, 0.95); /* Ciemne szkło */
    --border-color: #373b3e;        /* Ciemne ramki */
    --shadow-color: rgba(0, 0, 0, 0.4);

    --theme-beige: #b89c7e;         /* Przygaszony beż dla ciemnego trybu */
    --theme-beige-dark: #d6bda0;    /* Jaśniejszy akcent tekstu w ciemnym */

    --primary-action: #EAD4B7;      /* W ciemnym trybie akcentem jest beż */
    --inverse-text: #212529;        /* Ciemny tekst na beżowym przycisku */

    /* MODALE I OFFCANVAS (Dark) */
    --panel-bg: #1e1e1e;          /* Ciemne tło panelu */
    --panel-border: #373b3e;      /* Ciemna linia oddzielająca */
    --item-hover-bg: #2c3034;     /* Podświetlenie elementu listy */
    --input-addon-bg: #25282b;    /* Tło ikony lupy w wyszukiwarce */

    --soft-bg: #2c3034;

}




/* --- OGÓLNE --- */
body {
    background-color: var(--bg-main);
    color: var(--text-main);
    font-family: 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
    padding-bottom: 100px; /* Miejsce na navbar-bottom */
    -webkit-font-smoothing: antialiased;
    transition: background-color 0.3s ease, color 0.3s ease;
}
/* Domyślnie, zanim załadują się zmienne, ustawiamy neutralne tło lub ciemne,
   jeśli wiesz, że większość userów używa ciemnego */
html {
    background-color: var(--bg-main); /* Twój --bg-main light */
}



html, body {
    /* Wyłącza natywne odświeżanie przeglądarki, aby nasz skrypt mógł działać */
    overscroll-behavior-y: contain;
}

#ptr-loader {
    position: fixed;
    top: -60px;
    left: 0;
    width: 100%;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 99999;
    pointer-events: none;
    transition: transform 0.1s linear;
}

/* Dodaj/nadpisz w style.css */

#ptr-loader .spinner-border {
    width: 1.8rem;
    height: 1.8rem;
    color: var(--theme-beige-dark);
    transition: all 0.2s cubic-bezier(0.175, 0.885, 0.32, 1.275); /* Efekt sprężynowania */
    opacity: 0.6;
}

/* Stan GOTOWOŚCI (zamiast wibracji) */
#ptr-loader.ptr-ready .spinner-border {
    color: #198754 !important; /* Wyraźna zieleń sukcesu */
    transform: scale(1.4) rotate(10deg); /* Powiększenie i lekki przechył */
    opacity: 1;
    filter: drop-shadow(0 0 8px rgba(25, 135, 84, 0.4)); /* Delikatna poświata */
}

/* Animacja kręcenia przyspiesza gdy jesteśmy blisko progu */
@keyframes ptr-spin {
    to { transform: rotate(360deg); }
}

#ptr-loader.ptr-loading .spinner-border {
    animation: ptr-spin 0.6s linear infinite;
}

/* --- NAGŁÓWEK (NAVBAR) --- */
.navbar-theme {
    background-color: var(--theme-beige) !important;
    border-bottom: 1px solid rgba(0,0,0,0.05);
    padding-top: 12px;
    padding-bottom: 12px;
}

.navbar-theme h3, .navbar-theme h5, .navbar-theme h6 {
    color: var(--theme-dark) !important;
    font-weight: 800 !important;
    margin: 0;
}

/* --- KARTY (CARDS) --- */
.card-custom {
    background: var(--card-bg);
    border: none !important;
    border-radius: var(--border-radius-lg) !important;
    box-shadow: 0 4px 15px var(--shadow-color); /* Zamiast --theme-shadow */
    margin-bottom: 1rem;
    padding: 1.25rem;
}

.nav-pills-custom {
    background: var(--bg-secondary);
    border-radius: 50px;
    overflow-x: auto;
    flex-wrap: nowrap
}

.nav-pills-custom.active {
    background: var(--theme-beige);
}

/* Sekcje wewnątrz kart (np. w planie) */
.section-header {
    font-weight: 800;
    font-size: 0.7rem;
    text-transform: uppercase;
    color: var(--theme-beige-dark);
    letter-spacing: 1.2px;
    margin: 1.5rem 0 0.5rem 0.5rem;
}

/* --- FORMULARZE I POLA TEKSTOWE --- */
.form-label-caps {
    font-weight: 800;
    font-size: 0.7rem;
    text-transform: uppercase;
    color: var(--theme-beige-dark);
    margin-bottom: 0.5rem;
    display: block;
    padding-left: 5px;
}

.input-pill {
    border-radius: var(--border-radius-sm) !important;
    background-color: var(--card-bg);
    color: var(--text-main);
    border: 2px solid var(--border-color) !important;
    padding: 0.75rem 1rem !important;
    font-weight: 500;
    transition: all 0.2s ease;
}

.input-pill:focus {
    border-color: var(--theme-beige) !important;
    box-shadow: 0 0 0 0.25rem rgba(234, 212, 183, 0.25) !important;
    outline: none;
}

/* --- PRZYCISKI WYBORU (PILLS) --- */
.btn-outline-pill {
    border-radius: 30px !important;
    border: 2px solid var(--border-color) !important; /* Zamiast #f1f3f5 */
    color: var(--text-main) !important; /* Zamiast var(--theme-dark) */
    margin: 4px;
    padding: 7px 16px !important;
    font-weight: 600 !important;
    background-color: var(--card-bg); /* Zamiast var(--theme-white) */
    box-shadow: 0 4px 10px rgba(0,0,0,0.08);

}

.btn-check:checked + .btn-outline-pill {
    background-color: var(--theme-beige) !important;
    border-color: var(--theme-beige) !important;
    color: var(--theme-dark) !important;
    box-shadow: 0 4px 10px rgba(0,0,0,0.08);
}

/* --- PRZYCISKI GŁÓWNE --- */
.btn-primary-theme {
    background-color: var(--primary-action) !important;
    border: none !important;
    border-radius: 50px !important;
    padding: 12px 24px !important;
    font-weight: 700 !important;
    color: var(--inverse-text) !important; /* Zamiast white */
    text-transform: uppercase;
    letter-spacing: 0.5px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

.btn-primary-theme:active {
    transform: scale(0.96);
}

/* --- BADGES (ROLE W ZESPOLE) --- */
.badge-role {
    background-color: var(--soft-bg); /* Zamiast #fdfaf5 */
    color: var(--theme-beige-dark);
    border: 1px solid var(--theme-beige);
    font-weight: 600;
    font-size: 0.7rem;
    border-radius: 8px;
    padding: 4px 10px;
    text-transform: uppercase;
}

.badge-role-no-caps {
    background-color: var(--soft-bg); /* Zamiast #fdfaf5 */
    color: var(--theme-beige-dark);
    border: 1px solid var(--theme-beige);
    font-weight: 600;
    font-size: 0.7rem;
    border-radius: 8px;
    padding: 4px 10px;
}
.badge-role-large {
    background-color: var(--soft-bg); /* Zamiast #fdfaf5 */
    color: var(--theme-beige-dark);
    border: 1px solid var(--theme-beige);
    border-radius: 50px !important;
    padding: 4px 10px;
}

/* --- ELEMENTY PLANU (LISTA) --- */
.plan-item {
    border-bottom: 1px solid var(--border-color); /* Zamiast #f1f3f5 */
    padding: 12px 5px;
}

.plan-item:last-child {
    border-bottom: none;
}

/* Responsywność na większych ekranach */
@media (min-width: 768px) {
    /* Ukrywamy nawigację zakładkami na dużych ekranach */
    .nav-underline { display: none !important; }

    /* Dodatkowe dopasowanie kart */
    .card-custom {
        transition: transform 0.2s;
        border: 1px solid #eee;
    }
    .card-custom:hover {
        transform: translateY(-2px);
    }
}

/* --- Nowoczesny Minimalizm --- */

/* Nagłówki sekcji (Teams) - Czyste, bez tła, tylko bold i ikona */
.section-title {
    background: transparent;
    color: var(--text-main); /* Zamiast #212529 */
    padding: 0;
    margin-top: 30px;
    margin-bottom: 20px;
    font-weight: 700;
    font-size: 1.1rem;
    display: flex;
    align-items: center;
    border: none;
}

.section-title i {
    color: #0d6efd; /* Subtelny akcent kolorystyczny na ikonie */
    margin-right: 10px;
}

/* Etykiety piosenek (Labels) - Małe, szare, niekrzykliwe */
.label-header {
    /*color: #bc9e82;*/
    font-size: 0.75rem;
    font-weight: 800;
    text-transform: uppercase;
    border-left: 4px solid #EAD4B7;
    padding: 2px 10px;
    margin-bottom: 0.75rem;
    letter-spacing: 1px;
    display: flex;
    align-items: center;
}

/* Linia pomocnicza po tekście etykiety */
.label-header::after {
    content: "";
    flex: 1;
    height: 1px;
    background: var(--border-color);
    margin-left: 15px;
}

.label-header-large {
    font-size: 1rem;
    font-weight: 800;
    text-transform: uppercase;
    color: var(--theme-beige-dark);
    letter-spacing: 1.2px;
    border-left: 5px solid var(--theme-beige);
    padding-left: 12px;
}

/* Role w zespole - Jako proste tagi z lekkim obramowaniem */
.badge-role-pill {
    background: transparent;
    color: var(--text-main); /* Zamiast #6c757d */
    border: 1px solid var(--border-color); /* Zamiast #dee2e6 */
    font-weight: 400;
    font-size: 0.65rem;
    padding: 2px 8px;
    border-radius: 4px;
}

/* Ikony w planie */
.bi-music-note {
    font-size: 1.1rem;
    color: var(--border-color) !important; /* Zamiast #dee2e6 */
}

/* Kafelek informacji (Tempo, Tonacja itp.) */
.info-tile {
    background: var(--soft-bg);
    border-radius: 15px;
    padding: 15px;
    text-align: center;
    border: 1px solid var(--light-beige);
}

.info-tile .label {
    font-size: 0.7rem;
    text-transform: uppercase;
    color: var(--primary-beige);
    font-weight: 800;
    display: block;
}

.info-tile .value {
    font-size: 1.2rem;
    font-weight: 700;
    color: #444;
}

/* Styl dla przycisku wyzwalającego */
.collapse-trigger {
    border: none;
    background: transparent;
    transition: transform 0.3s ease;
}

/* Ikona wewnątrz przycisku */
.collapse-trigger i {
    display: inline-block;
    transition: transform 0.3s ease;
}

/* Gdy sekcja jest ZWINIĘTA (Bootstrap dodaje klasę .collapsed) */
.collapse-trigger.collapsed i {
    transform: rotate(180deg);
}

/* Opcjonalne dopasowanie section-title, jeśli flex-box go rozciąga */
.section-title.m-0 {
    flex-grow: 1;
}




/* --- COLLAPSING HEADER STYLES --- */

/* Główny kontener nagłówka */
#service-sticky-header {
    background-color: var(--bg-glass); /* Zamiast rgba(255,255,255,0.98) */
    z-index: 1020;
    top: 0; /* Przyklej do samej góry */
    border-bottom: 1px solid var(--border-color);
    overflow: hidden; /* Ważne, żeby zawartość nie wystawała podczas animacji */
    transition: height 0.3s ease, padding 0.3s ease, box-shadow 0.3s ease;
}
/* Stan "ZWINIĘTY" (gdy klasa jest aktywna) */
#service-sticky-header.is-scrolled {
    padding-top: 0.5rem !important;
    padding-bottom: 0 !important;
    box-shadow: 0 4px 20px rgba(0,0,0,0.08); /* Cień oddzielający od treści */
}
/* Tytuł nabożeństwa */
#service-sticky-header h2 {
    transition: font-size 0.3s ease;
}
#service-sticky-header.is-scrolled h2 {
    font-size: 1.1rem; /* Zmniejsz czcionkę */
    margin-bottom: 0 !important;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 250px; /* Utnij zbyt długi tytuł na mobile */
}

#content-wrapper {
    margin-top: 10px; /* Minimalny odstęp od nagłówka */
}

/* Data i detale pod tytułem */
.header-details {
    transition: all 0.3s ease;
    opacity: 1;
    overflow: hidden;
}

/* Ukrywamy datę przy przewijaniu */
#service-sticky-header.is-scrolled .header-details {
    max-height: 0;
    opacity: 0;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    pointer-events: none; /* Żeby nie dało się kliknąć w niewidoczne przyciski */
}

/* Zakładki (Tabs) */
#service-sticky-header .nav-tabs {
    border-bottom: none; /* Usuń linię, bo kontener ma border */
}

/* Korekta dla przycisków w nagłówku, żeby się ładnie skalowały */
#service-sticky-header .header-actions {
    transition: transform 0.3s ease;
}
#service-sticky-header.is-scrolled .header-actions {
    transform: scale(0.9); /* Lekko zmniejsz przyciski akcji */
}

/* Styl dla przycisków nawigacji w nagłówku */
.header-nav-btn {
    font-size: 0.75rem !important;
    border-color: #dee2e6 !important;
    color: var(--text-main) !important;
    background: transparent;
}

.header-nav-btn:hover {
    background-color: var(--theme-beige) !important;
    color: var(--theme-dark) !important;
}

/* Styl dla elementów listy dodawania piosenek */
.song-item:hover {
    background-color: #f8f9fa !important;
}
/*Aktualizacja do stylu ciemnego, użycie w modalach i offcanvas service*/
.song-item-2{
    background-color: var(--card-bg);
    border: 1px solid var(--border-color) !important;
    color: var(--text-main);
}
.song-item-2:hover{
    background-color: var(--bg-secondary);
    border-color: var(--theme-beige) !important;
}
.song-db-item{
    background-color: var(--card-bg);
    border: 1px solid var(--border-color) !important;
    color: var(--text-main);
}
.song-db-item:hover{
    background-color: var(--bg-secondary);
    border-color: var(--theme-beige) !important;
}
/* Gwarantuje, że karta z otwartym dropdownem będzie nad innymi kartami */
.song-db-item:has(.dropdown-toggle.show) {
    z-index: 1070 !important;
    position: relative;
}
.user-item-2{
    background-color: var(--card-bg);
    border: 1px solid var(--border-color) !important;
    color: var(--text-main);
}
.user-item-2:hover{
    background-color: var(--bg-secondary);
    border-color: var(--theme-beige) !important;
}
.cursor-pointer {
    cursor: pointer;
}

/* Animacje dla kart piosenek */
.song-card-item {
    transition: all 0.2s ease;
    cursor: pointer;
    background-color: var(--card-bg); /* Zamiast #fff */
    border-radius: 12px !important;
}

.song-card-item:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 15px var(--theme-shadow) !important;
}

.song-card-item:active {
    transform: scale(0.98);
}

/* Placeholder dla pustej sekcji */
.empty-placeholder {
    border: 2px dashed;
    background: var(--bg-secondary); /* Zamiast #fafafa */
    border-color: var(--border-color); /* Zamiast #eee */
}

/* Styl dla elementu w trakcie przeciągania (SortableJS) */
.sortable-ghost {
    opacity: 0.3;
    background-color: var(--theme-beige) !important;
}

/* Wymuszamy, aby główny navbar był zawsze nad nagłówkiem nabożeństwa */
#navbar-top {
    z-index: 1030 !important; /* Wartość wyższa niż 1020 ustawione w service-sticky-header */
}

/* Kolorwa ikona */
.icon-theme {
    color: var(--theme-beige);
}
.icon-theme-dark {
    color: var(--theme-beige-dark);
}

/* Applowski widok dla instrukcji PWA */
#pwa-install-prompt {
    border-top-left-radius: 20px;
    border-top-right-radius: 20px;
    background-color: var(--bg-glass) !important;
    backdrop-filter: blur(10px);
    color: var(--text-main) !important;
    border-top: 1px solid var(--border-color);
    padding-bottom: env(safe-area-inset-bottom); /* Obsługa "notcha" na dole */
}

#pwa-install-prompt .btn-close {
    filter: none; /* Ciemny krzyżyk na jasnym tle */
}

/* Profile page*/
 .profile-header {
     padding-bottom: 4rem;
     margin-bottom: -1rem;
     border-radius: 0 0 30px 30px;
 }
.profile-card {
    border-radius: 20px;
    border: none;
    overflow: visible;
}
.avatar-container {
    position: relative;
    width: 140px;
    height: 140px;
    margin: 0 auto;
    margin-top: -55px;
    margin-bottom: 15px;
}
.profile-avatar {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
    background-color: var(--card-bg);
    border: 5px solid var(--card-bg);
    box-shadow: 0 5px 15px rgba(0,0,0,0.15);
}
.profile-avatar-small {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background-color: var(--card-bg);
    border: 2px solid var(--card-bg);
    box-shadow: 0 5px 5px rgba(0,0,0,0.15);
}
.profile-avatar-medium {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    background-color: var(--card-bg);
    border: 2px solid var(--card-bg);
    box-shadow: 0 5px 5px rgba(0,0,0,0.15);
}

.avatar-edit-btn {
    position: absolute;
    bottom: 5px;
    right: 0;
    background: var(--theme-beige);
    color: white;
    border: 3px solid var(--card-bg); /* Zamiast white */
    border-radius: 50%;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: transform 0.2s;
    box-shadow: 0 2px 5px rgba(0,0,0,0.2);
    z-index: 10;
}
.avatar-edit-btn:hover { transform: scale(1.1); background-color: var(--theme-beige-dark); }
#avatarInput { display: none; }
.avatar-spinner {
    position: absolute; top: 50%; left: 50%;
    transform: translate(-50%, -50%); z-index: 5;
    display: none; background: rgba(255,255,255,0.8);
    border-radius: 50%; padding: 10px;
}

.theme-toast {
    position: fixed;
    bottom: 120px; /* Nad dolnym navbarem */
    left: 50%;
    transform: translateX(-50%) translateY(50px); /* Start niżej */
    background: #333; /* Ciemne tło dla kontrastu */
    color: #fff;
    padding: 12px 24px;
    border-radius: 50px;
    box-shadow: 0 4px 15px rgba(0,0,0,0.2);
    display: flex;
    align-items: center;
    font-weight: 500;
    z-index: 10001;
    gap: 10px;
    opacity: 0;
    pointer-events: none;
    transition: all 0.4s cubic-bezier(0.68, -0.55, 0.265, 1.55);
    white-space: nowrap;
    -webkit-backdrop-filter: blur(4px); /* Opcjonalnie: fajny efekt iOS */
    -webkit-transform: translateZ(0);   /* Wymuszenie warstwy GPU */
}
.theme-toast.show {
    opacity: 1;
    transform: translate(-50%, 0);
}
.theme-toast i {
    color: var(--theme-beige); /* Twoja zmienna beżu dla akcentu */
}


/* --- TOAST NOTIFICATIONS v2 --- */
.toast-container {
    z-index: 1060; /* Powyżej navbara */
    padding-bottom: 80px; /* Żeby nie zasłaniał dolnego menu */
}

.theme-toast .toast-header {
    background-color: var(--theme-beige);
    color: var(--theme-dark);
    border-bottom: 1px solid rgba(0,0,0,0.05);
    font-weight: bold;
}

.theme-toast .toast-body {
    padding: 1rem;
    font-size: 0.9rem;
}

/* --- KLASY POMOCNICZE (UTILITIES) --- */

/* Tekst dostosowujący się do tła */
.text-adaptive {
    color: var(--text-main) !important;
}

/* Tło karty (białe w dzień, ciemne w nocy) */
.bg-adaptive-card {
    background-color: var(--card-bg) !important;
    color: var(--text-main) !important;
}

/* Tło drugoplanowe (jasnoszare w dzień, ciemnoszare w nocy) */
.bg-adaptive-secondary {
    background-color: var(--bg-secondary) !important;
    color: var(--text-main) !important;
    border-color: var(--border-color) !important;
}

/* Specjalna klasa dla nagłówków tabel */
.thead-adaptive {
    background-color: var(--bg-secondary) !important;
    color: var(--text-main) !important;
    border-bottom: 2px solid var(--border-color) !important;
}

/* Naprawa przycisków akordeonu */
.accordion-button.bg-adaptive-card::after {
    /* Opcjonalnie: filtr odwracający kolory strzałki w trybie ciemnym */
    filter: invert(var(--arrow-invert, 0));
}
[data-bs-theme="dark"] { --arrow-invert: 1; }



/* --- ACTIVITY LOG & FILTRY --- */

/* Przyciski filtrów (np. ALL, INSERT, UPDATE) */
.btn-filter {
    background-color: var(--card-bg); /* Zamiast white */
    border: 1px solid var(--border-color); /* Delikatniejsza ramka */
    color: var(--text-main); /* Adaptacyjny kolor tekstu */
    border-radius: 20px;
    padding: 6px 16px;
    font-size: 0.8rem;
    font-weight: 600;
    white-space: nowrap;
    transition: all 0.2s ease;
    text-decoration: none;
}

.btn-filter:hover {
    background-color: var(--bg-secondary); /* Zamiast --theme-light */
    border-color: var(--theme-beige);
    color: var(--text-main);
}

.btn-filter.active {
    background-color: var(--theme-beige);
    color: #212529; /* Ciemny tekst na beżu dla czytelności */
    border-color: var(--theme-beige);
    box-shadow: 0 4px 10px var(--shadow-color);
}

/* Inputy i Selecty w filtrach */
.form-select, .form-control {
    background-color: var(--card-bg);
    color: var(--text-main);
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius-sm);
}

.form-select:focus, .form-control:focus {
    background-color: var(--card-bg);
    color: var(--text-main);
    border-color: var(--theme-beige);
    box-shadow: 0 0 0 0.25rem rgba(234, 212, 183, 0.25);
}

/* Styl dla podglądu SQL w logach */
pre {
    background-color: var(--bg-secondary) !important;
    color: var(--text-main) !important;
    padding: 1rem;
    border-radius: 10px;
    border: 1px solid var(--border-color);
    font-size: 0.85rem;
    overflow-x: auto;
}

/* Wiersze tabeli w logach */
.table {
    --bs-table-bg: transparent;
    --bs-table-color: var(--text-main);
    border-color: var(--border-color);
}

/* Jeśli masz efekt "rozwijania" wiersza w logach (Collapse) */
.collapse-details {
    background-color: var(--bg-secondary);
    border-radius: 0 0 15px 15px;
}

/* Badge typu akcji (INSERT/UPDATE/DELETE) */
.badge {
    border: 1px solid rgba(0,0,0,0.05);
}
[data-bs-theme="dark"] .badge {
    border: 1px solid rgba(255,255,255,0.1);
}

/* Styl dla Modali i Offcanvas */
.modal-content,
.offcanvas {
    background-color: var(--panel-bg) !important;
    color: var(--text-main) !important;
    border-color: var(--panel-border) !important;
}

.modal-header,
.offcanvas-header,
.modal-footer {
    border-color: var(--panel-border) !important;
}

/* Przyciski zamykania (X) */
[data-bs-theme="dark"] .btn-close {
    filter: invert(1) grayscale(100%) brightness(200%);
}



.list-group-item-action:hover {
    background-color: var(--item-hover-bg) !important;
    color: var(--text-main) !important;
}

/* Wyszukiwarka w Offcanvas */
.input-group-text {
    border-color: var(--panel-border) !important;
    color: var(--text-main) !important;
}

#suggestionSearchInput {
    background-color: var(--panel-bg) !important;
    border-color: var(--panel-border) !important;
    color: var(--text-main) !important;
}

/* Naprawa paska przewijania w trybie ciemnym (opcjonalne) */
[data-bs-theme="dark"] ::-webkit-scrollbar-thumb {
    background: #3f4448;
}

.song-header {
    background-color: var(--bg-glass); /* Zamiast rgba(255,255,255,0.98) */
    z-index: 1020;
    top: 0; /* Przyklej do samej góry */
    border-bottom: 1px solid var(--border-color);
    overflow: hidden; /* Ważne, żeby zawartość nie wystawała podczas animacji */
    transition: height 0.3s ease, padding 0.3s ease, box-shadow 0.3s ease;
}


/* ----------------------------- */
/* Custom Audio Player Styling */
/* ----------------------------- */
 .custom-audio-card {
     border-radius: var(--border-radius-lg) !important;
     background-color: var(--bg-secondary) !important;
 }

.custom-progress-bar {
    background-color: var(--bg-main); /* Tło paska */
    border-radius: var(--border-radius-sm);
    overflow: hidden;
}

.custom-progress-bar .progress-bar {
    background-color: var(--theme-beige) !important; /* Twoja ciemna beża */
}

#audio-play-btn {
    background-color: var(--theme-beige);
    border: none;
    transition: transform 0.2s ease, background-color 0.2s ease;
}

#audio-play-btn:active {
    transform: scale(0.9);
}

#audio-play-btn:hover {
    background-color: var(--primary-action);
}

.custom-audio-card .text-success:hover {
    color: #157347 !important;
}



/*CALENDAR*/
.calendar-table {
    table-layout: fixed;
    width: 100%;
    border-collapse: separate;
    border-spacing: 2px;
}
.calendar-table th {
    text-align: center;
    font-size: 0.65rem;
    color: var(--theme-beige-dark);
    text-transform: uppercase;
    padding: 10px 0;
}
.calendar-day {
    min-height: 90px;
    vertical-align: top;
    padding: 4px !important;
    background: var(--bg-main);
    border-radius: 12px;
    border: 1px solid var(--soft-bg) !important;
    transition: background-color 0.2s ease, transform 0.1s ease;
}
.calendar-day:hover {
    background-color: var(--bg-secondary) !important;
}
.calendar-day:active {
    transform: scale(0.98);
}
.day-number {
    font-weight: 800;
    font-size: 0.85rem;
    color: var(--text-main);
    display: block;
    margin-bottom: 0px;
    padding: 4px;
}
.has-service {
    background-color: var(--soft-bg);
    border-color: var(--theme-beige) !important;
    box-shadow: 0 0 10px var(--theme-beige);
}
.has-service .day-number {
    color: var(--text-main);
}
.service-link {
    display: block;
    background: var(--soft-bg);
    color: var(--text-main);
    font-size: 0.65rem;
    padding: 6px;
    border-radius: 8px;
    text-decoration: none;
    font-weight: 600;
    line-height: 1.2;
    border: 1px solid var(--theme-beige);
    box-shadow: 0 0 10px var(--theme-beige);
}
.assigned-badge {
    background: var(--theme-beige-dark) !important;
    color: var(--inverse-text) !important;
    border: none;
}
.today {
    border: 2px solid var(--theme-success) !important;
    box-shadow: 0 0 10px var(--theme-success-light);
}
.bg-empty {
    background: transparent;
    border: none !important;
}

/* Nadpisujemy główny kontener paska */
.navbar-bottom.navbar {
    background-color: var(--bg-glass) !important;
    position: fixed !important;
    bottom: 15px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    backdrop-filter: blur(3px);

    width: auto !important;
    min-width: 320px; /* Minimalna szerokość */
    max-width: 90%;   /* Maksymalna szerokość na małych ekranach */

    border-radius: 50px !important; /* Mocne zaokrąglenie */
    border: 1px solid rgba(255, 255, 255, 0.3);
    padding: 6px 8px !important;

    /* Delikatny, miękki cień jak w iOS */
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1) !important;
    z-index: 1040;

    overflow: hidden; /* Ważne, by ukryć resztę ikon przy zwijaniu */
}
[data-bs-theme="dark"] .navbar-bottom {
    background: none !important;
}

/* Stylizacja linków (ikon) */
.navbar-bottom .nav-link {
    color: #adb5bd;
    padding: 0 !important;
    margin: 0 5px;

    /* Tworzymy koło dla aktywnego stanu */
    width: 48px;
    height: 48px;
    border-radius: 50% !important;

    display: flex;
    align-items: center;
    text-align: center;
    justify-content: center;
    transition: all 0.2s ease-in-out;
}

/* Rozmiar ikon */
.navbar-bottom .nav-link i {
    font-size: 1.6rem !important;
    line-height: 1;
    display: block;
    margin-top: 2px;
}
/* Tekst (label) */
.navbar-bottom .nav-label {
    font-size: 0.9rem;
    font-weight: 600;
    white-space: nowrap; /* Zapobiega łamaniu tekstu */
}
.navbar-bottom .nav-link.active {
    background-color: var(--bg-glass) !important;
    color: var(--theme-beige-dark) !important;
    box-shadow: 0 4px 15px var(--shadow-color) !important;
}

/* --- MEDIA QUERY: DESKTOP / TABLET (>768px) --- */
@media (min-width: 768px) {
    .navbar-bottom .nav-link {
        width: auto !important;
        height: 48px; /* Wysokość bez zmian */
        padding: 0 20px !important; /* Padding wewnątrz pastylki */
        border-radius: 30px !important; /* Zmieniamy koło w pastylkę */
        margin: 0 8px;

    }

    .navbar-bottom .nav-link i {
        margin-top: 0; /* Reset korekty optycznej */
    }
}

/* Klasa nadawana przez JS przy scrollowaniu */
.navbar-bottom.navbar-collapsed {
    min-width: 60px !important;
    width: 60px !important;
    padding: 6px !important;
    left: 30px !important; /* Przesunięcie do lewej krawędzi */
    transform: translateX(0) !important; /* Wyłączamy centrowanie */
    cursor: pointer;
    transition: all 0.2s ease-in-out;
}

/* Ukrywamy wszystkie linki poza pierwszym w trybie zwiniętym */
.navbar-collapsed .nav-link:not(.active) {
    opacity: 0;
    pointer-events: none;
    width: 0;
    margin: 0;
}

/* Pierwsza ikona (np. Home lub Aktywna) zawsze widoczna */
.navbar-collapsed .nav-link.active {
    margin: 0 auto;
    box-shadow: none !important;
    background: none !important;
}

/* Ukrywamy tekst całkowicie w trybie zwiniętym */
.navbar-collapsed .nav-label {
    display: none !important;
}

/* Zakładki Wszystkie/Niedzielne/Młodzieżowe */
.segment-control {
    background-color: var(--bg-secondary); /* Tło całego paska */
    border-radius: 10px;
    border: 1px solid var(--border-color);

    padding: 3px;
    display: flex;
    width: 100%;
    margin-bottom: 20px;
}
.segment-item {
    flex: 1;
    text-align: center;
    padding: 6px 0;
    border-radius: 8px;
    font-size: 0.85rem;
    font-weight: 600;
    color: #8E8E93;
    text-decoration: none;
    transition: all 0.2s ease;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.segment-item:hover {
    color: var(--text-main);
}
/* Aktywna zakładka - Biała kartka z cieniem */
.segment-item.active {
    background-color: var(--card-bg);
    color: var(--text-main);
    box-shadow: 0 2px 4px var(--shadow-color);
}