/* ========================================
   GLOBALNE USTAWIENIA I ZMIENNE (v2 - Modern)
========================================= */
:root {
    /* Tryb Jasny - Czysty i jasny */
    --bg-color-light: #F8F9FA;        /* Lekko szare tło */
    --primary-color-light: #FFFFFF;   /* Czysta biel dla kontenerów */
    --text-color-light: #212529;      /* Ciemny szary dla tekstu */
    --secondary-text-light: #6C757D;  /* Jaśniejszy szary dla etykiet, statusów */
    --border-color-light: #DEE2E6;    /* Delikatny border */
    --accent-color: #DC3545;          /* Czerwony akcent (trochę jaśniejszy) */
    --accent-hover: #C82333;          /* Ciemniejszy czerwony przy najechaniu */

    /* Tryb Ciemny - Stonowany i kontrastowy */
    --bg-color-dark: #121212;         /* Głęboka czerń */
    --primary-color-dark: #1E1E1E;    /* Ciemny szary dla kontenerów */
    --text-color-dark: #E9ECEF;       /* Jasny szary dla tekstu */
    --secondary-text-dark: #ADB5BD;   /* Ciemniejszy szary dla etykiet, statusów */
    --border-color-dark: #343A40;     /* Ciemny border */
    /* Akcent pozostaje ten sam */
}

/* --- Globalny Reset i Ustawienia --- */
*, *::before, *::after {
    box-sizing: border-box;
}

body {
    font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
    margin: 0;
    height: 100dvh; /* ZMIANA: z vh na dvh dla lepszej obsługi mobilnej */
    width: 100vw;
    font-size: 16px; /* Bazowy rozmiar fontu */
    line-height: 1.5;
    transition: background-color 0.2s, color 0.2s;
    overflow: hidden; /* Zapobiega przewijaniu całej strony */
}

body.light-mode {
    background-color: var(--bg-color-light);
    color: var(--text-color-light);
    --chat-background: var(--primary-color-light); /* Domyślne tło czatu */
}
body.dark-mode {
    background-color: var(--bg-color-dark);
    color: var(--text-color-dark);
    --chat-background: var(--primary-color-dark); /* Domyślne tło czatu */
}

.hidden { display: none !important; }

h1, h2, h3, h4, h5, h6 {
    margin-top: 0;
    margin-bottom: 0.75rem; /* Odstęp pod nagłówkami */
    font-weight: 600; /* Lekko pogrubione */
}

.logo {
    margin: 0;
    font-size: 2rem;
    color: var(--accent-color);
    text-align: center;
    margin-bottom: 2rem; /* Większy odstęp */
    font-weight: 700;
}

/* --- Style Pomocnicze --- */
.error-message {
    color: var(--accent-color);
    font-size: 0.875rem; /* Nieco mniejszy */
    text-align: center;
    min-height: 1.2em;
    margin-bottom: 1rem;
}

/* ========================================
   EKRAN LOGOWANIA / REJESTRACJI (v2)
========================================= */
#auth-container {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100dvh; /* ZMIANA: z vh na dvh */
    padding: 1rem; /* Dodany padding dla mniejszych ekranów */
}
body.light-mode #auth-container { background-color: var(--bg-color-light); }
body.dark-mode #auth-container { background-color: var(--bg-color-dark); }

.auth-box {
    width: 100%; /* Dopasuj do paddingu rodzica */
    max-width: 400px;
    padding: 2.5rem; /* Więcej przestrzeni w środku */
    border-radius: 16px; /* Bardziej zaokrąglone */
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.05); /* Subtelny cień */
}
body.light-mode .auth-box { background-color: var(--primary-color-light); border: 1px solid var(--border-color-light); }
body.dark-mode .auth-box { background-color: var(--primary-color-dark); border: 1px solid var(--border-color-dark); }


.auth-tabs {
    display: flex;
    margin-bottom: 2rem; /* Większy odstęp */
    border-bottom: 1px solid;
}
body.light-mode .auth-tabs { border-color: var(--border-color-light); }
body.dark-mode .auth-tabs { border-color: var(--border-color-dark); }

.auth-tab {
    flex: 1;
    padding: 0.75rem;
    border: none;
    background: none;
    font-size: 1rem;
    font-weight: 500; /* Normalna grubość */
    cursor: pointer;
    border-bottom: 3px solid transparent;
    margin-bottom: -1px; /* Aby border dolny nachodził na border taba */
    color: var(--secondary-text-light); /* Domyślnie szary */
    transition: color 0.2s, border-color 0.2s;
}
body.dark-mode .auth-tab { color: var(--secondary-text-dark); }

.auth-tab:hover {
    color: var(--text-color-light);
}
body.dark-mode .auth-tab:hover {
    color: var(--text-color-dark);
}

.auth-tab.active {
    color: var(--accent-color);
    border-bottom-color: var(--accent-color);
    font-weight: 600; /* Aktywny jest pogrubiony */
}

.auth-form {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

input[type="text"],
input[type="password"],
input[type="date"],
select {
    width: 100%;
    padding: 0.75rem 1rem; /* Zwiększony padding */
    border-radius: 8px; /* Mniejsze zaokrąglenie dla inputów */
    border: 1px solid;
    box-sizing: border-box;
    font-size: 1rem;
    transition: border-color 0.2s, box-shadow 0.2s;
}

body.light-mode input, body.light-mode select {
    border-color: var(--border-color-light);
    background-color: var(--bg-color-light); /* Jaśniejsze tło */
    color: var(--text-color-light);
}
body.dark-mode input, body.dark-mode select {
    border-color: var(--border-color-dark);
    background-color: var(--bg-color-dark); /* Ciemniejsze tło */
    color: var(--text-color-dark);
}
input:focus, select:focus {
    outline: none;
    border-color: var(--accent-color);
    box-shadow: 0 0 0 3px rgba(220, 53, 69, 0.25); /* Lekka poświata przy focusie */
}

/* Poprawka dla strzałki w select */
select {
    appearance: none; /* Usuń domyślny wygląd */
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='none' stroke='%23343a40' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 1rem center;
    background-size: 1em;
    padding-right: 2.5rem; /* Miejsce na strzałkę */
}
body.dark-mode select {
     background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='none' stroke='%23adb5bd' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3E%3C/svg%3E");
}


.divider-or {
    text-align: center;
    margin: 1.5rem 0;
    color: var(--secondary-text-light);
}
body.dark-mode .divider-or { color: var(--secondary-text-dark); }


/* ========================================
   GŁÓWNY UKŁAD APLIKACJI (v2)
========================================= */
#app-container {
    display: flex;
    height: 100dvh; /* ZMIANA: z vh na dvh */
    position: relative; /* Potrzebne dla mobilnego menu */
    overflow: hidden; /* Zapobiega dziwnym paskom przewijania */
}

/* --- Panel Boczny (Sidebar v2) --- */
#sidebar {
    width: 280px;
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    border-right: 1px solid;
    transition: width 0.3s ease; /* Płynna zmiana szerokości */
}
body.light-mode #sidebar {
    background-color: var(--primary-color-light); /* Biel */
    border-color: var(--border-color-light);
}
body.dark-mode #sidebar {
    background-color: var(--primary-color-dark); /* Ciemny szary */
    border-color: var(--border-color-dark);
}

.sidebar-header {
    padding: 1rem 1.25rem; /* Zwiększony padding */
    border-bottom: 1px solid;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-shrink: 0; /* Zapobiega kurczeniu się */
}
body.light-mode .sidebar-header { border-color: var(--border-color-light); }
body.dark-mode .sidebar-header { border-color: var(--border-color-dark); }

.sidebar-header h3 {
    margin: 0;
    font-size: 1rem;
    font-weight: 600;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

#friend-requests-container, #friends-list-container {
    padding: 0.5rem 1.25rem; /* Zwiększony padding */
    overflow-y: auto;
}
#friend-requests-container {
    border-bottom: 1px solid;
    max-height: 25vh; /* Ograniczona wysokość dla zaproszeń */
    flex-shrink: 0;
}
#friends-list-container {
    flex-grow: 1; /* Wypełnia resztę miejsca */
}
body.light-mode #friend-requests-container { border-color: var(--border-color-light); }
body.dark-mode #friend-requests-container { border-color: var(--border-color-dark); }


#friend-requests-container h4, #friends-list-container h4 {
    margin: 0.75rem 0; /* Zwiększony margines */
    font-size: 0.875rem; /* Mniejszy nagłówek sekcji */
    font-weight: 600;
    text-transform: uppercase; /* Wielkie litery */
    color: var(--secondary-text-light);
}
body.dark-mode #friend-requests-container h4,
body.dark-mode #friends-list-container h4 {
    color: var(--secondary-text-dark);
}


#friend-requests-list, #friends-list {
    list-style: none; padding: 0; margin: 0;
}
.no-requests, .no-friends {
    color: var(--secondary-text-light);
    font-style: italic; font-size: 0.9rem; padding: 0.5rem 0;
}
body.dark-mode .no-requests, body.dark-mode .no-friends { color: var(--secondary-text-dark); }

.friend-request-item, .friend-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.6rem 0; /* Zwiększony padding */
    font-size: 0.95rem; /* Nieco większy font */
    border-bottom: 1px solid;
}
.friend-item { cursor: pointer; } /* Tylko znajomych można kliknąć */

body.light-mode .friend-request-item, body.light-mode .friend-item { border-color: var(--border-color-light); }
body.dark-mode .friend-request-item, body.dark-mode .friend-item { border-color: var(--border-color-dark); }

.friend-request-item:last-child, .friend-item:last-child {
    border-bottom: none; /* Usuń border ostatniego elementu */
}

.friend-item:hover {
     background-color: rgba(128, 128, 128, 0.05); /* Bardzo subtelne podświetlenie */
}
body.dark-mode .friend-item:hover {
     background-color: rgba(255, 255, 255, 0.03);
}

.friend-item.active {
    font-weight: 600;
}
body.light-mode .friend-item.active { background-color: rgba(220, 53, 69, 0.1); } /* Lekko czerwone tło */
body.dark-mode .friend-item.active { background-color: rgba(220, 53, 69, 0.2); }


.request-buttons { display: flex; gap: 0.25rem; }
.request-buttons button {
    padding: 0.25rem 0.5rem; font-size: 0.8rem; border-radius: 6px; font-weight: 500;
}
.accept-btn { background-color: #28a745; } /* Zielony */
.accept-btn:hover { background-color: #218838; }
.decline-btn { /* Style jak secondary, tylko mniejszy */
    background-color: transparent; border: 1px solid; padding: calc(0.25rem - 1px) calc(0.5rem - 1px);
}
body.light-mode .decline-btn { color: var(--secondary-text-light); border-color: var(--border-color-light); }
body.dark-mode .decline-btn { color: var(--secondary-text-dark); border-color: var(--border-color-dark); }
body.light-mode .decline-btn:hover { background-color: #80808015; }
body.dark-mode .decline-btn:hover { background-color: #ffffff10; }

.friend-status { font-size: 0.75rem; margin-left: 0.5rem; } /* Mniejsza kropka */
.friend-status.online { color: #28a745; } /* Zielony */
.friend-status.offline { color: var(--secondary-text-light); }
body.dark-mode .friend-status.offline { color: var(--secondary-text-dark); }


.sidebar-footer {
    padding: 0.75rem 1.25rem; /* Dopasowany padding */
    border-top: 1px solid;
    flex-shrink: 0;
}
body.light-mode .sidebar-footer { border-color: var(--border-color-light); }
body.dark-mode .sidebar-footer { border-color: var(--border-color-dark); }

/* Poprawka dla przycisków motywu */
#theme-toggle { /* Domyślnie widoczny (desktop) */ }
#theme-toggle-mobile { display: none; } /* Domyślnie ukryty */


/* --- Główny Obszar Czatu (v2) --- */
#main-chat-area {
    flex-grow: 1; display: flex; flex-direction: column; height: 100dvh; /* ZMIANA: z vh na dvh */
}
body.light-mode #main-chat-area { background-color: var(--bg-color-light); }
body.dark-mode #main-chat-area { background-color: var(--bg-color-dark); }

/* W trybie gościa, ukryj sidebar i rozciągnij czat */
#main-chat-area.guest-mode {
    width: 100%;
}
/* W trybie gościa, ukryj też przycisk menu */
#main-chat-area.guest-mode #menu-toggle-btn {
    display: none;
}


.navbar {
    display: flex; justify-content: space-between; align-items: center;
    padding: 0.75rem 1.5rem; border-bottom: 1px solid; flex-shrink: 0;
}
body.light-mode .navbar { background-color: var(--primary-color-light); border-color: var(--border-color-light); }
body.dark-mode .navbar { background-color: var(--primary-color-dark); border-color: var(--border-color-dark); }
.navbar .logo { margin: 0; font-size: 1.75rem; } /* Logo w navbarze */

#chat-partner-info { font-weight: 500; color: var(--secondary-text-light); }
body.dark-mode #chat-partner-info { color: var(--secondary-text-dark); }

/* Wrapper dla ikon w navbarze */
.navbar-icons {
    display: flex;
    align-items: center;
    gap: 0.25rem; /* Mały odstęp między ikonami */
}

/* NOWY: Przycisk menu mobilnego */
#menu-toggle-btn {
    display: none; /* Ukryty na desktopie */
    font-size: 1.75rem;
    color: inherit; /* Dziedziczy kolor tekstu */
    padding: 0.5rem; /* Mniejszy padding niż inne icon-btn */
}

/* NOWA: Nakładka menu mobilnego */
#mobile-menu-overlay {
    position: fixed;
    top: 0; left: 0;
    width: 100%; height: 100%;
    background: rgba(0,0,0,0.4);
    z-index: 199; /* Poniżej sidebar (200) */
    opacity: 0;
    transition: opacity 0.3s ease;
    pointer-events: none; /* Domyślnie nieklikalne */
}
#mobile-menu-overlay:not(.hidden) {
    opacity: 1;
    pointer-events: auto; /* Klikalne gdy widoczne */
}


.chat-container {
    flex-grow: 1; display: flex; flex-direction: column;
    padding: 1rem 1.5rem; /* Większy padding boczny */
    overflow-y: hidden;
}

#status-bar {
    padding: 0.5rem; text-align: center; font-style: italic; border-radius: 8px; /* Zaokrąglony */
    margin-bottom: 1rem; flex-shrink: 0; font-size: 0.9rem;
    color: var(--secondary-text-light);
}
body.light-mode #status-bar { background-color: transparent; } /* Bez tła */
body.dark-mode #status-bar { background-color: transparent; color: var(--secondary-text-dark); }


#chat-messages {
    flex-grow: 1;
    overflow-y: auto;
    padding: 1rem;
    border-radius: 8px;
    background: var(--chat-background, transparent); /* Użyj zmiennej lub przezroczystości */
    transition: background 0.3s ease-in-out;
}


/* --- Kontrolki Czatu (Szukanie v2) --- */
.chat-controls-wrapper {
    display: flex; justify-content: space-between; align-items: center;
    flex-wrap: wrap; gap: 1rem; padding: 1rem 0 0.5rem 0; /* Padding tylko na górze/dole */
    flex-shrink: 0;
}
.preferences { display: flex; flex-wrap: wrap; gap: 1rem; } /* Zwiększony gap */
.preference-group { display: flex; align-items: center; gap: 0.5rem; }
.preferences label { font-size: 0.875rem; font-weight: 500; color: var(--secondary-text-light); }
body.dark-mode .preferences label { color: var(--secondary-text-dark); }
.preferences select {
    padding: 0.5rem 0.75rem; border-radius: 8px; border: 1px solid; font-size: 0.9rem;
    /* Strzałka dla select już jest z globalnych stylów */
}
.preferences select:disabled { background-color: #80808015; color: #808080; }

.chat-controls { display: flex; gap: 0.75rem; margin-left: auto; }


/* --- Wiadomości (Dymki v2) --- */
.message {
    display: flex; flex-direction: column; max-width: 75%; /* Trochę węższe */
    margin-bottom: 1rem; /* Większy odstęp */
}
.message .sender {
    font-weight: 600; font-size: 0.8rem; /* Mniejszy nadawca */
    margin-bottom: 0.25rem; padding: 0 0.2rem;
    color: var(--secondary-text-light);
}
body.dark-mode .message .sender { color: var(--secondary-text-dark); }

.message .message-content {
    padding: 0.6rem 1rem; /* Dopasowany padding */
    border-radius: 18px; /* Bardziej zaokrąglone */
    display: inline-block; max-width: 100%; word-wrap: break-word;
    font-size: 0.95rem; /* Standardowy font wiadomości */
    line-height: 1.4;
    box-shadow: 0 1px 2px rgba(0,0,0,0.05); /* Bardzo subtelny cień */
}

.message-you { align-items: flex-end; margin-left: auto; }
.message-you .sender { text-align: right; } /* Ukrywamy "Ty", ale zostawiamy miejsce */
.message-you .message-content {
    background: linear-gradient(to right, #EF476F, var(--accent-color)); /* Gradient */
    color: white;
    border-radius: 18px 18px 4px 18px; /* Inne zaokrąglenie */
}

.message-stranger { align-items: flex-start; margin-right: auto; }
.message-stranger .sender { text-align: left; }
.message-stranger .message-content { border-radius: 18px 18px 18px 4px; }
body.light-mode .message-stranger .message-content {
    background-color: #E9ECEF; /* Jaśniejszy szary */
    border: none; /* Bez borderu */
    color: var(--text-color-light);
}
body.dark-mode .message-stranger .message-content {
    background-color: var(--primary-color-dark); /* Ciemny szary */
    border: none; /* Bez borderu */
    color: var(--text-color-dark);
}

.message-system {
    align-items: center; width: 100%; max-width: 100%; margin: 0.5rem auto;
}
.message-system .sender { display: none; } /* Ukryj 'System' */
.message-system .message-content {
    display: block; text-align: center; font-style: italic;
    color: var(--secondary-text-light); background: none; border: none; padding: 0.1rem 0;
    font-size: 0.85rem; box-shadow: none;
}
body.dark-mode .message-system .message-content { color: var(--secondary-text-dark); }

.chat-image {
    max-width: 100%; max-height: 300px; /* Trochę mniejsze */
    object-fit: contain; border-radius: 12px; /* Zaokrąglenie pasujące do dymka */
    cursor: pointer; display: block; margin-top: 0.3rem; /* Mały odstęp od tekstu (jeśli był) */
}
/* Obrazki w dymkach nie potrzebują dodatkowego paddingu ani cienia */
.message-content .chat-image { box-shadow: none; padding: 0; }


/* --- Stopka (Input v2) --- */
.message-input-area {
    display: flex; flex-direction: column; align-items: stretch;
    padding: 1rem 1.5rem; /* Dopasowany padding */
    border-top: 1px solid; flex-shrink: 0;
}
body.light-mode .message-input-area { border-color: var(--border-color-light); background-color: var(--primary-color-light); }
body.dark-mode .message-input-area { border-color: var(--border-color-dark); background-color: var(--primary-color-dark); }


.media-preview {
    position: relative; width: 80px; height: 80px; /* Mniejszy podgląd */
    margin-bottom: 0.5rem; border: 1px dashed; border-radius: 8px;
}
body.light-mode .media-preview { border-color: var(--border-color-light); }
body.dark-mode .media-preview { border-color: var(--border-color-dark); }
.media-preview img { width: 100%; height: 100%; object-fit: cover; border-radius: 8px; }
.media-preview-remove {
    position: absolute; top: -8px; right: -8px; width: 20px; height: 20px;
    border-radius: 50%; background-color: var(--accent-color); color: white;
    border: none; font-weight: bold; cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 0.8rem;
}
.media-preview-remove:hover { background-color: var(--accent-hover); }

.input-controls-wrapper { display: flex; align-items: center; width: 100%; gap: 0.5rem; }

#msgInput {
    flex-grow: 1;
    margin: 0; /* Usunięto marginesy */
    padding: 0.75rem 1rem;
    border-radius: 20px; /* Bardziej zaokrąglony input */
    border: 1px solid;
    font-size: 0.95rem;
}
body.light-mode #msgInput { border-color: var(--border-color-light); background-color: var(--bg-color-light); }
body.dark-mode #msgInput { border-color: var(--border-color-dark); background-color: var(--bg-color-dark); }
#msgInput:focus { /* Styl focusa już zdefiniowany globalnie */ }
#msgInput:disabled { background-color: rgba(128, 128, 128, 0.1); }


/* --- Przyciski (v2) --- */
button {
    padding: 0.75rem 1.25rem; border: none; border-radius: 20px; cursor: pointer;
    font-weight: 600; /* Standardowa grubość */
    background-color: var(--accent-color); color: white;
    transition: background-color 0.2s, transform 0.1s;
    white-space: nowrap;
    font-size: 0.95rem; /* Nieco mniejszy font */
}
button:hover { background-color: var(--accent-hover); }
button:active { transform: scale(0.98); } /* Lekkie wciśnięcie */
button:disabled {
    background-color: #6c757d; color: #ced4da; cursor: not-allowed; transform: none;
}
body.dark-mode button:disabled {
     background-color: #495057; color: #adb5bd;
}

.secondary-btn {
    background-color: transparent; border: 1px solid var(--accent-color); color: var(--accent-color);
    transition: background-color 0.2s, color 0.2s;
}
.secondary-btn:hover { background-color: rgba(220, 53, 69, 0.1); }
.secondary-btn:disabled {
    background-color: transparent; border-color: #adb5bd; color: #adb5bd;
}
body.dark-mode .secondary-btn:disabled { border-color: #495057; color: #495057; }

/* Przycisk Gościa */
#guest-mode-btn {
    width: 100%; /* Pełna szerokość */
    margin-top: 1rem;
    border-color: var(--border-color-light);
    color: var(--text-color-light);
}
#guest-mode-btn:hover { background-color: #80808015; }
body.dark-mode #guest-mode-btn { border-color: var(--border-color-dark); color: var(--text-color-dark); }
body.dark-mode #guest-mode-btn:hover { background-color: #ffffff10; }

.icon-btn {
    background-color: transparent; border: none; font-size: 1.5rem; padding: 0.5rem;
    border-radius: 50%; width: 44px; height: 44px; display: inline-flex; align-items: center; justify-content: center;
    cursor: pointer; transition: background-color 0.2s;
    color: var(--secondary-text-light); /* Domyślnie szary dla ikon */
}
.icon-btn:hover { background-color: #80808015; }
body.dark-mode .icon-btn { color: var(--secondary-text-dark); }
body.dark-mode .icon-btn:hover { background-color: #ffffff10; }

.icon-btn:disabled {
    color: #adb5bd; background-color: transparent; cursor: not-allowed;
}
body.dark-mode .icon-btn:disabled { color: #495057; }

/* Wyjątek dla ikony spinacza - czerwony */
#mediaBtn { color: var(--accent-color); }
#mediaBtn:disabled { color: #adb5bd; }
body.dark-mode #mediaBtn:disabled { color: #495057; }

/* Kolor dla ikony motywu */
#theme-toggle, #theme-toggle-mobile { color: inherit; }


/* --- Modal (v2) --- */
.modal-overlay {
    position: fixed; top: 0; left: 0; width: 100%; height: 100%;
    background-color: rgba(0, 0, 0, 0.5); /* Trochę ciemniejsze tło */
    z-index: 100; opacity: 0; transition: opacity 0.2s ease-in-out; pointer-events: none;
}
.modal-overlay:not(.hidden) { opacity: 1; pointer-events: auto; } /* Pokaż z fade-in */

.modal {
    position: fixed; top: 50%; left: 50%; transform: translate(-50%, -50%) scale(0.95);
    z-index: 101; border-radius: 16px; width: 90%; max-width: 450px; /* Nieco szerszy */
    box-shadow: 0 10px 30px rgba(0,0,0,0.1); border: 1px solid;
    opacity: 0; transition: opacity 0.2s ease-in-out, transform 0.2s ease-in-out; pointer-events: none;
}
.modal:not(.hidden) { opacity: 1; transform: translate(-50%, -50%) scale(1); pointer-events: auto; } /* Pokaż z fade-in i lekkim zoomem */

body.light-mode .modal { background-color: var(--primary-color-light); border-color: var(--border-color-light); }
body.dark-mode .modal { background-color: var(--primary-color-dark); border-color: var(--border-color-dark); }

.modal-content { padding: 2rem; border-radius: 16px; }
.modal-content h2 { margin-top: 0; color: var(--accent-color); font-size: 1.5rem; text-align: center; }
.modal-content p { text-align: center; margin-bottom: 1.5rem; color: var(--secondary-text-light); }
body.dark-mode .modal-content p { color: var(--secondary-text-dark); }

.modal-content form { display: flex; flex-direction: column; gap: 1rem; }
.modal-content label { font-weight: 500; font-size: 0.9rem; margin-bottom: -0.5rem; /* Zbliż etykietę do inputu */ }

/* Modal Potwierdzenia */
#confirm-modal .modal-content { text-align: center; padding: 2rem; }
#confirm-message { margin-top: 0; margin-bottom: 1.5rem; font-size: 1.1rem; color: inherit; }
.confirm-buttons { display: flex; justify-content: center; gap: 1rem; }
#confirm-modal button { padding: 0.6rem 1.5rem; font-size: 0.95rem; }

/* Modal Ustawień Tła */
#background-settings-modal .modal-content { text-align: center; }
#background-settings-modal h2 { margin-bottom: 1.5rem; }
.background-options-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(100px, 1fr)); gap: 1rem; margin-bottom: 1.5rem; }
.background-option { height: 80px; border-radius: 8px; cursor: pointer; border: 2px solid transparent; display: flex; align-items: center; justify-content: center; font-size: 0.8rem; font-weight: 500; text-align: center; color: rgba(0,0,0,0.6); transition: border-color 0.2s, transform 0.1s; }
.background-option:hover { transform: scale(1.05); }
.background-option.selected { border-color: var(--accent-color); }
body.dark-mode .background-option { color: rgba(255,255,255,0.6); }
#close-bg-settings-btn { margin-top: 1rem; }


/* ========================================
   RESPONSYWNOŚĆ (Mobile v2)
========================================= */
@media (max-width: 768px) {
    
    /* --- NOWA LOGIKA SIDEBARA (MENU MOBILNE) --- */
    #sidebar {
        /* Zamiast 'display: none', pozycjonujemy go poza ekranem */
        position: fixed;
        left: 0; top: 0;
        height: 100dvh; /* Pełna wysokość ekranu */
        z-index: 200; /* Nad wszystkim innym */
        transform: translateX(-100%); /* Schowany domyślnie */
        transition: transform 0.3s ease-in-out;
        box-shadow: 0 0 20px rgba(0,0,0,0.1);
        /* Szerokość i tło są dziedziczone z bazowych stylów */
    }
    #sidebar.open {
        transform: translateX(0); /* Wysuń menu */
    }

    /* Pokaż przycisk hamburgera */
    #menu-toggle-btn {
        display: inline-flex;
    }
    
    /* W trybie gościa, sidebar jest nadal w pełni ukryty */
    #main-chat-area.guest-mode #sidebar {
        display: none;
    }
    
    /* --- RESZTA STYLÓW MOBILNYCH --- */
    #main-chat-area { 
        width: 100%; /* Rozciągnij na całą szerokość */
    }

    /* Poprawne pokazywanie/ukrywanie przycisków motywu */
    #theme-toggle { display: none; } /* Ukryj wersję desktopową */
    #theme-toggle-mobile { display: inline-flex; } /* Pokaż wersję mobilną */

    .navbar { 
        padding: 0.5rem 0.75rem; /* Zmniejszony padding */
        gap: 0.5rem; /* Odstęp między ikonami */
    }
    .navbar .logo { 
        font-size: 1.5rem; 
        margin-left: 0.5rem; /* Odsuń logo od hamburgera */
        margin-right: auto; /* Wypchnij ikony w prawo */
    }
    #chat-partner-info { display: none; }

    /* ZMIANA: Optymalizacja paddingu dla okna czatu */
    .chat-container { 
        padding: 0.75rem 0; /* Usuń padding boczny z głównego kontenera */
    }
    #chat-messages { 
        padding: 0 0.75rem; /* Dodaj padding boczny tylko do listy wiadomości */
    }

    .chat-controls-wrapper { flex-direction: column; align-items: stretch; gap: 0.75rem; }
    .preferences { justify-content: center; }
    
    /* *** POPRAWKA PRZYCISKÓW *** */
    .chat-controls { 
        margin-left: 0; 
        justify-content: center;
        flex-direction: column;  /* Ułóż przyciski pionowo */
        align-items: stretch;  /* Rozciągnij je na pełną szerokość */
        width: 100%;           /* Upewnij się, że kontener ma pełną szerokość */
    }
    /* *** KONIEC POPRAWKI PRZYCISKÓW *** */

    .message .message-content { font-size: 0.9rem; }
    .message .sender { font-size: 0.75rem; }

    /* ZMIANA: Zmniejsz padding dolnego paska */
    .message-input-area { 
        padding: 0.5rem 0.75rem; 
    }
    #msgInput { padding: 0.6rem 0.9rem; font-size: 0.9rem; }
    .icon-btn { width: 40px; height: 40px; font-size: 1.3rem; }
    #sendBtn { padding: 0.6rem 1rem; font-size: 0.9rem; }

    .modal { max-width: 90%; }
    .modal-content { padding: 1.5rem; }

    /* *** NOWE STYLE DLA WIĘKSZEGO OKNA CZATU *** */
    /* Ukryj elementy interfejsu podczas aktywnego czatu na mobilce, aby zmaksymalizować okno */
    body.chat-active #status-bar,
    body.chat-active .partner-interests {
        display: none;
    }
    /* Zmniejsz padding kontenera czatu jeszcze bardziej, gdy czat jest aktywny */
    body.chat-active .chat-container {
        padding-top: 0.25rem; /* Mniejszy odstęp od góry */
    }

}
/* --- Dodane style dla Licznika Online --- */

.online-counter {
    display: flex;
    align-items: center;
    font-size: 0.9rem;
    color: var(--secondary-text-light);
    /* Wyśrodkowanie w navbarze, jeśli jest miejsce */
    position: absolute; /* Wyjmij z przepływu */
    left: 50%;
    transform: translateX(-50%);
}
body.dark-mode .online-counter {
    color: var(--secondary-text-dark);
}

.online-dot {
    color: #28a745; /* Zielony */
    font-size: 1.2rem;
    margin-right: 0.3rem;
    line-height: 1; /* Zapobiega dodatkowej wysokości */
}

#user-count {
    font-weight: 600;
    margin-left: 0.2rem;
}

/* Na mobilce ukryj licznik, bo brakuje miejsca */
@media (max-width: 768px) {
    .online-counter {
        display: none;
    }
}

/* --- Dodane style dla Ustawień Profilu i Zainteresowań --- */

/* Przycisk ustawień profilu w sidebarze */
#profile-settings-btn {
    margin-left: auto; /* Przesuń w prawo, przed Wyloguj */
    margin-right: 0.5rem;
    color: inherit; /* Użyj koloru tekstu */
}

/* Modal ustawień profilu */
#profile-settings-modal .modal-content {
    text-align: left; /* Wyrównaj do lewej */
}
#profile-settings-modal h2 {
    text-align: center; /* Nagłówek wyśrodkowany */
    margin-bottom: 1.5rem;
}
#profile-settings-modal form {
    gap: 1.2rem; /* Większy odstęp w formularzu */
}
#profile-settings-modal label {
    font-weight: 500;
    font-size: 0.9rem;
    color: var(--secondary-text-light);
    margin-bottom: -0.8rem; /* Zbliż do inputu */
}
body.dark-mode #profile-settings-modal label {
    color: var(--secondary-text-dark);
}

/* Przyciski w modalu profilu */
.profile-modal-buttons {
    display: flex;
    justify-content: flex-end; /* Przyciski po prawej */
    gap: 0.75rem;
    margin-top: 1.5rem; /* Odstęp od ostatniego pola */
}

/* Sekcja zainteresowań partnera */
.partner-interests {
    padding: 0.5rem 0.75rem;
    margin-bottom: 0.75rem;
    border-radius: 8px;
    font-size: 0.85rem;
    color: var(--secondary-text-light);
    border: 1px dashed;
    text-align: center;
}
body.light-mode .partner-interests {
    background-color: #f8f9fa; /* Lekkie tło */
    border-color: var(--border-color-light);
}
body.dark-mode .partner-interests {
    background-color: #2a2a2a; /* Ciemniejsze tło */
    border-color: var(--border-color-dark);
    color: var(--secondary-text-dark);
}
.partner-interests strong {
    margin-right: 0.5em;
}
/* Styl dla tagów zainteresowań (można dodać później) */
#partner-interests-list .interest-tag {
    display: inline-block;
    background-color: rgba(128, 128, 128, 0.15);
    padding: 0.1rem 0.5rem;
    border-radius: 10px;
    margin: 0 0.2rem 0.2rem 0;
    font-size: 0.8rem;
}
body.dark-mode #partner-interests-list .interest-tag {
    background-color: rgba(255, 255, 255, 0.1);
}