/* Ogólne */
body {
    overflow-x: hidden;
}



/* Sidebar – flex, pełna wysokość pod navbar */
#sidebar {
    width: 360px;
    position: fixed;
    top: 56px;
    left: 0;
    height: calc(100vh - 56px);          /* zastępuje min-height */
    background: #212529;
    color: #fff;
    display: flex;
    flex-direction: column;
}

/* Nagłówek „Procesy” – niekurczliwy */
#dashboardToggle {
    flex-shrink: 0;
}

/* Kontener listy – przewijany i drobna czcionka */
#processList {
    flex: 1;
    overflow-y: auto;
    display: none;                     /* domyślnie ukryta, slideToggle zmieni na block */
}

/* Linki w sidebarze – ogólne */
#sidebar a {
    color: #ccc;
    display: block;
    padding: 10px 15px;
    text-decoration: none;
}
#sidebar a:hover {
    background: #343a40;
}

/* Elementy listy procesów – mniejsza czcionka i odstępy */
#processList a {
    font-size: 0.80rem;               /* mniejsza czcionka */
    padding: 6px 15px;                /* węższe w pionie */
}

#processList .process-link {
    font-size: 1rem;           /* tyle samo co domyślna czcionka sidebaru */
    padding: 10px 15px;        /* identycznie jak w #sidebar a */
}

/* Styl dla daty procesu – mała, żółta, z odstępem od nazwy */
.process-date {
    font-size: 10px;
    color: #ffc107;            /* żółty (warning) */
    margin-top: 4px;
    line-height: 1.2;
}

/* Opcjonalnie: pasek przewijania ciemny */
#processList::-webkit-scrollbar {
    width: 6px;
}
#processList::-webkit-scrollbar-thumb {
    background: #555;
    border-radius: 3px;
}

/* Główna zawartość */
#content {
    margin-left: 360px;
    margin-top: 56px;
    padding: 20px;
}

/* Stopka */
footer {
    margin-left: 360px;
    padding: 10px;
    text-align: center;
    font-size: 12px;
    background: #f8f9fa;
}

/* Status zapisu */
.save-status {
    opacity: 0;
    transition: opacity 0.2s;
}

/* Okrągłe przyciski (+) */
.btn-circle {
    width: 38px;
    height: 38px;
    padding: 0;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
}

/* Zielony przycisk plusa – mniejszy i z odpowiednim odstępem */
.btn-sm {
    margin-left: 0; /* opcjonalnie: przykleja do prawej – w zależności od potrzeb */
}

.modal-content {
    border: none !important;
    border-radius: 12px !important;
    overflow: hidden;
}

/* Obrazek w splashu – pełna szerokość, bez marginesów */
.splash-wrapper img {
    display: block;
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
}

#processForm .input-group .btn {
    border-radius: 0.25rem;
    margin-left: 5px;
}
#processForm .input-group .btn:first-child {
    margin-left: 0;
}

#processForm .input-group > .form-control {
    border-radius: 0.25rem;
    margin-right: 5px;  /* odstęp od pierwszego przycisku, jeśli chcemy */
}

.wizard-dropdown {
	position: fixed !important; /* zamiast absolute – nie będzie przycinane */
    background: #fff;
    border: 1px solid rgba(0,0,0,.15);
    border-radius: 0.25rem;
    padding: 0.5rem 0;
    min-width: 200px;
    max-height: 200px;
    overflow-y: auto;
    box-shadow: 0 0.5rem 1rem rgba(0,0,0,.15);
}
.dropdown-item {
    padding: 0.25rem 1rem;
    cursor: pointer;
}
.dropdown-item:hover {
    background-color: #f8f9fa;
}	



/* Obce procesy – biała czcionka */
.process-item-other {
    color: #ffffff;
}

/* Moje procesy – żółta czcionka */
.process-item-own {
    color: #fff3cd;
}

.process-main .process-link {
    font-weight: bold;
}

.process-item:not(.process-main) .process-link {
    padding-left: 5px;
}

/* Link procesu – dziedziczy kolor z rodzica, bez podkreślenia */
.process-link {
    color: inherit !important;
    text-decoration: none;
}

/* Przycisk z trzema kropkami – przezroczyste tło, dziedziczony kolor */
.process-menu-btn {
    background: transparent !important;
    border: none !important;
    color: inherit !important;
    box-shadow: none !important;
}

.process-menu-btn:hover,
.process-menu-btn:focus,
.process-menu-btn:active {
    background: transparent !important;
    color: inherit !important;
    box-shadow: none !important;
}

/* Hover – jednolite szare tło dla całego wiersza */
.process-item:hover {
    background-color: #343a40 !important;
}


.process-item.dragging {
    opacity: 0.5;
}
.process-item.drag-over {
    outline: 2px dashed #007bff;
    background-color: #e9f0ff;
}


/* ---------- Splash screen w modalu ---------- */
.splash-wrapper {
    background-color: #212529;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 30px 25px;
    gap: 25px;
}

.splash-logo-img {
    height: 48px;          /* dostosuj do rozmiaru logo */
    width: 48px;
}

.splash-title {
    font-family: 'Lato', sans-serif;
    font-weight: 700;
    font-size: 2.2rem;
    color: #ffffff;
    line-height: 1.2;
    letter-spacing: 0.5px;
}

.splash-subtitle {
    font-family: 'Lato', sans-serif;
    font-weight: 400;
    font-size: 1rem;
    color: #adb5bd;
    margin-top: 4px;
    letter-spacing: 0.3px;
}


.btn-purple {
    background-color: #b19cd9;   /* jasny fiolet */
    border-color: #b19cd9;
    color: #212529;             /* ciemny tekst dla kontrastu (jeśli jasny fiolet) */
}
.btn-purple:hover {
    background-color: #9a7ec5;   /* nieco ciemniejszy przy najechaniu */
    border-color: #9a7ec5;
    color: #212529;
}
.btn-purple:active,
.btn-purple:focus {
    background-color: #8b6db3;
    border-color: #8b6db3;
    box-shadow: 0 0 0 0.2rem rgba(177, 156, 217, 0.5); /* subtelna poświata */
}


.risk-menu {
    border-top: 1px solid #ddd;
    padding-top: 10px;
}
.risk-items {
    padding-left: 1rem;
    display: flex;
    flex-direction: column;
}
.risk-item {
    padding: 4px 8px;
    text-decoration: none;
    color: #333;
    border-radius: 4px;
}
.risk-item:hover {
    background-color: #f0f0f0;
}


.settings-items {
    padding-left: 1rem;
    display: flex;
    flex-direction: column;
}
.settings-item {
    padding: 4px 8px;
    text-decoration: none;
    color: #333;
    border-radius: 4px;
}
.settings-item:hover {
    background-color: #f0f0f0;
}


/* ---------- Lista scenariuszy ryzyka ---------- */
.risk-scenario-item {
    color: #ccc;                     /* jasnoszary tekst, widoczny na ciemnym tle */
}

.risk-scenario-link {
    color: inherit !important;       /* dziedziczy kolor z rodzica */
    text-decoration: none;           /* już ustawiane przez klasę, ale dla pewności */
}

/* Przycisk z trzema kropkami – przezroczysty, dziedziczy kolor */
.risk-menu-btn {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    color: inherit !important;       /* ikona nabiera koloru tekstu wiersza */
}

/* Hover na całym wierszu – tło jak w procesach */
.risk-scenario-item:hover {
    background-color: #343a40 !important;
}

/* Podświetlenie ikony przy hoverze wiersza */
.risk-scenario-item:hover .risk-menu-btn {
    color: #ffffff;                  /* jaśniejszy kolor, bardziej widoczny */
}


/* Przewijanie listy ryzyk – analogicznie do #processList */
#riskScenarioList {
    max-height: 900px;          /* dopasuj według potrzeb */
    overflow-y: auto;           /* pionowy pasek przewijania */
}

/* Styl scrollbara – ciemny, jak w procesach */
#riskScenarioList::-webkit-scrollbar {
    width: 6px;
}
#riskScenarioList::-webkit-scrollbar-thumb {
    background: #555;
    border-radius: 3px;
}


.btn-context {
    color: inherit;
    background: transparent;
    border: none;
    opacity: 0.5;
    transition: opacity 0.2s, background-color 0.2s;
    padding: 2px 6px;
    line-height: 1;
}
.btn-context:hover {
    opacity: 1;
    background-color: rgba(255, 255, 255, 0.15);
    color: inherit;
}

.transition {
    transition: background-color 0.2s ease-in-out;
}


/* Płynne przejście dla podświetleń */
.transition {
    transition: background-color 0.2s ease-in-out;
}

/* Opcjonalne: poprawa wyglądu pól błędów */
.is-invalid {
    border-color: #dc3545;
}


.process-risk-card {
    background-color: #f0f2f5;        /* delikatny szary */
    border: 1px solid #d5d9df;
    border-radius: 6px;
    padding: 8px;
    margin-bottom: 12px;
}

/* === WIERSZ ZAGROŻENIA (białe tło wewnątrz szarej karty) === */
.process-risk-card .threat-row {
    background-color: #ffffff;
    border: 1px solid #e0e0e0;
    border-radius: 6px;
    margin-bottom: 10px;              /* odstęp między zagrożeniami */
    box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}

/* === OPCJONALNIE: etykiety nad suwakami (już masz w HTML, ale możesz wzmocnić) === */
.process-risk-card .small.text-dark.fw-bold {
    font-size: 8pt !important;
    color: #333 !important;
    letter-spacing: 0.02em;
}

/* === PRZYCISK KONTEKSTOWY (trzy kropki) – dostosuj, jeśli nie jest widoczny === */
.btn-context {
    color: inherit;
    background: transparent;
    border: none;
    opacity: 0.5;
    transition: opacity 0.2s, background-color 0.2s;
    padding: 2px 6px;
    line-height: 1;
}
.btn-context:hover {
    opacity: 1;
    background-color: rgba(255, 255, 255, 0.15);
    color: inherit;
}


#dashboardToggle,
#riskToggle,
#settingsToggle {
    background-color: #24284A;   /* szaro-niebieski, delikatnie ciemniejszy od tła */
    padding: 8px 12px;           /* wygodne odstępy */
    border-radius: 4px;          /* lekko zaokrąglone rogi */
    margin-bottom: 2px;          /* odstęp między sekcjami */
    transition: background-color 0.2s;
}

/* Opcjonalnie: delikatna zmiana przy najechaniu */
#dashboardToggle:hover,
#riskToggle:hover,
#settingsToggle:hover {
    background-color: #24284A;
}

#xmlDropZone {
  border: 2px dashed #aaa !important;
  background: #f9f9f9;
  user-select: none;
}


#processForm .mt-3:has(> .d-flex) {
    background-color: #f0f0f0; /* jasnoszary */
    border-radius: 12px; /* or some rounding */
    padding: 12px; /* add some inner spacing */
    margin-bottom: 10px; /* separator effect */
}


/* ---------- Ujednolicenie małych przycisków w nagłówku sekcji ---------- */
.section-actions .btn-sm {
    width: 32px;               /* stała szerokość – wszystkie równe */
    height: 32px;              /* stała wysokość */
    padding: 0;                /* bez wewnętrznych odstępów, ikona idealnie w centrum */
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.875rem;
    border-radius: 0.25rem;    /* lekko zaokrąglone, spójne z Bootstrap */
}

/* Zielony przycisk plusa – szerszy, wyrównany do prawej */
.add-item {
    width: 69px;                  /* szerokość pasująca do dwóch małych przycisków */
    height: 32px;                /* taka sama wysokość jak Wizard i Usuń */
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 0.25rem;      /* delikatnie zaokrąglone, jak pozostałe */
}

/* Ewentualnie, jeśli chcesz mieć identyczne zaokrąglenie jak niżej: */
.input-group .btn-sm {
    width: 32px;
    height: 32px;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.875rem;
    border-radius: 0.25rem;
    margin-left: 5px;
}
.input-group .btn-sm:first-child {
    margin-left: 0;
}

.input-group .form-control {
    height: 32px;
    padding-top: 0;
    padding-bottom: 0;
    font-size: 0.875rem;      /* opcjonalnie – dopasowanie do przycisków */
    line-height: 1.2;         /* wyśrodkowanie tekstu w pionie */
}


/* ---------- DASHBOARD ---------- */
/* ---------- DASHBOARD ---------- */
.heatmap-table {
    border-collapse: collapse;
    width: auto;                /* dopasuje się do komórek */
    max-width: 420px;           /* mały zapas – 5 × 75px = 375px + padding */
    margin: 0 auto;
}

.heatmap-header {
    text-align: center;
    font-weight: bold;
    font-size: 0.8rem;
    padding: 4px;
    background: #f8f9fa;
}

.heatmap-cell {
    text-align: center;
    vertical-align: middle;
    width: 75px;                /* szerokość */
    height: 50px;               /* wysokość – proporcja 3:2 */
    font-weight: bold;
    font-size: 1rem;
    border: 1px solid #dee2e6;
    transition: all 0.2s;
}

.heatmap-axis-label {
    text-align: center;
    font-weight: bold;
    font-size: 0.8rem;
    padding: 4px;
    color: #495057;
}

.bg-heatmap-low {
    background-color: #28a745;
    color: #fff;
}
.bg-heatmap-medium {
    background-color: #ffc107;
    color: #212529;
}
.bg-heatmap-high {
    background-color: #fd7e14;
    color: #fff;
}
.bg-heatmap-extreme {
    background-color: #dc3545;
    color: #fff;
}



.card {
    border-radius: 10px;
}

/* Opcjonalnie: zaokrąglenia kart */
.card {
    border-radius: 10px;
}


/* Responsywność – na wąskich ekranach kolumna */
@media (max-width: 480px) {
    .splash-wrapper {
        flex-direction: column;
        text-align: center;
        gap: 20px;
        padding: 25px 20px;
    }
	.splash-logo-img {
		height: auto;        /* oryginalna wysokość */
		width: auto;         /* oryginalna szerokość */
		max-width: 100%;     /* nie wychodzi poza kontener */
		display: block;
	}
    .splash-title {
        font-size: 1.8rem;
    }
}