body {
    font-family: Arial, sans-serif;
    margin: 0;
    padding: 5px;
    background-color: #f4f4f4;
    color: #333;
    height: 100vh;
    box-sizing: border-box;
}

.container {
    background-color: #fff;
    padding: 20px;
    border-radius: 8px;
    box-shadow: 0 0 10px rgba(0,0,0,0.1);
    display: flex;
    flex-direction: row; /* ZMIANA: Główny kierunek na poziomy */
    height: calc(100vh - 40px); /* Cała wysokość minus padding body (5px*2) i padding kontenera (20px*2) -> 100vh - 50px? Lub zostawiamy jak było */
    max-height: 95vh;
    gap: 20px; /* Odstęp między lewą a prawą kolumną */
}

/* NOWY DIV DLA LEWEJ KOLUMNY */
.left-panel {
    display: flex;
    flex-direction: column;
    flex: 1; /* Lewa kolumna zajmuje 1 część przestrzeni */
    min-width: 300px; /* Minimalna szerokość lewej kolumny */
    gap: 15px; /* Odstęp między tytułem/ścieżką a listą plików */
    overflow: hidden; /* Zapobiega problemom z przepełnieniem */
}

.stitle {
    flex-shrink: 0; /* Zapobiega kurczeniu się sekcji tytułu */
    /* h1 i #current-path-display dziedziczą style */
}

h1 {
    color: #333;
    border-bottom: 1px solid #eee;
    padding-bottom: 10px;
    margin-top: 0;
    margin-bottom: 0; /* Usunięto domyślny margines dolny, odstęp załatwi #current-path-display lub gap w .left-panel */
}

#current-path-display {
    margin-top: 10px; /* Dodano margines górny dla odstępu od h1 */
    margin-bottom: 0; /* Usunięto margines dolny, odstęp załatwi gap w .left-panel */
    font-style: italic;
    color: #555;
    padding: 5px;
    background-color: #e9e9e9;
    border-radius: 4px;
}

/* Usunięto .explorer-wrapper, jego rolę przejął .container i .left-panel */

.file-list-column {
    flex-grow: 1; /* Kolumna listy plików wypełnia dostępną przestrzeń w .left-panel */
    min-width: unset; /* Już niepotrzebne, .left-panel kontroluje szerokość */
    background-color: #fdfdfd;
    border: 1px solid #eee;
    border-radius: 4px;
    padding: 10px;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    min-height: 0; /* Pomaga w prawidłowym działaniu flex i overflow */
}

.preview-column {
    flex: 2; /* Kolumna podglądu zajmuje 2 części przestrzeni (szersza) */
    min-width: 300px;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

#file-list {
    list-style-type: none;
    padding: 0;
    margin: 0;
    flex-grow: 1;
}

#file-list li {
    padding: 8px 12px;
    border-bottom: 1px solid #eee;
    cursor: pointer;
    display: flex;
    align-items: center;
}

#file-list li:hover {
    background-color: #e9e9e9;
}

#file-list li:last-child {
    border-bottom: none;
}

#file-list li .icon {
    margin-right: 10px;
    width: 20px;
    text-align: center;
}

#file-list li .folder {
    color: #007bff;
}

#file-list li .file {
    color: #28a745;
}

#file-preview-container {
    background-color: #fdfdfd;
    border: 1px solid #eee;
    border-radius: 4px;
    padding: 10px; /* Zmieniono padding z 0px na 10px dla spójności */
    display: flex;
    flex-direction: column;
    flex-grow: 1;
    overflow: hidden;
}

#file-preview-container h2 {
    color: #333;
    border-bottom: 1px solid #eee;
    padding-bottom: 10px;
    margin-top: 0;
    margin-bottom: 10px; /* Zwiększono odstęp pod nagłówkiem podglądu */
    flex-shrink: 0;
}

#file-preview {
    background-color: #f9f9f9;
    border-radius: 4px;
    overflow: auto; /* ZMIANA: Lepsze przewijanie dla różnej zawartości */
    font-family: 'Courier New', Courier, monospace;
    white-space: pre-wrap;
    word-wrap: break-word;
    flex-grow: 1;
    padding: 10px; /* Dodano wewnętrzny padding dla treści podglądu */
    min-height: 0; /* Pomaga w prawidłowym działaniu flex i overflow */
}

#file-preview img,
#file-preview iframe {
    max-width: 100%;
    max-height: 100%;
    height: auto; /* Dla obrazów, aby zachować proporcje */
    display: block;
    margin: 0 auto; /* Wyśrodkowanie obrazu, jeśli jest mniejszy niż kontener */
}

#file-preview iframe {
    width: 100%;
    height: 100%; /* Iframe powinien zajmować całą dostępną wysokość w #file-preview */
    border: none;
}