﻿/* =====================================================
   Orionis Identity – Theme system (CSP safe)
   ===================================================== */

/* ---------- Light (default) ---------- */
:root {
    --bg-main: #f8fafc;
    --bg-card: #ffffff;
    --bg-navbar: #ffffff;
    --text-main: #111827;
    --text-muted: #6b7280;
    --border: #e5e7eb;
    --input-bg: #ffffff;
    --input-text: #111827;
    --input-border: #d1d5db;
}

/* ---------- Dark ---------- */
html[data-theme="dark"] {
    --bg-main: #0b1220;
    --bg-card: #0f172a;
    --bg-navbar: #0f172a;
    --text-main: #e5e7eb;
    --text-muted: #9ca3af;
    --border: rgba(255,255,255,0.10);
    --input-bg: #0b1220;
    --input-text: #e5e7eb;
    --input-border: rgba(255,255,255,0.16);
}

/* ---------- Global ---------- */
/*body {
    background-color: var(--bg-main);
    color: var(--text-main);
}*/
/*body {
    background: radial-gradient(1000px 600px at 50% -10%, rgba(13,110,253,0.08), transparent 60%), radial-gradient(900px 500px at 10% 20%, rgba(20,184,166,0.06), transparent 55%), linear-gradient(180deg, var(--bg-main) 0%, #eef2f7 100%);
    color: var(--text-main);
}
html[data-theme="dark"] body {
    background: radial-gradient(1200px 600px at 50% -10%, rgba(96,165,250,0.10), transparent 60%), linear-gradient(180deg, var(--bg-main) 0%, #070b14 100%);
}*/

html {
    background:
        radial-gradient(1000px 600px at 50% -10%, rgba(13,110,253,0.08), transparent 60%),
        radial-gradient(900px 500px at 10% 20%, rgba(20,184,166,0.06), transparent 55%),
        linear-gradient(180deg, var(--bg-main) 0%, #eef2f7 100%);
}

body {
    background: transparent;
    color: var(--text-main);
}

html[data-theme="dark"] {
    background: radial-gradient(1200px 600px at 50% -10%, rgba(96,165,250,0.10), transparent 60%), linear-gradient(180deg, var(--bg-main) 0%, #070b14 100%);
}


/* Navbar */
.navbar {
    background-color: var(--bg-navbar) !important;
    border-color: var(--border);
}

/* Cards */
.card {
    background-color: var(--bg-card);
    border-color: var(--border);
    color: var(--text-main);
    box-shadow: 0 10px 26px rgba(15, 23, 42, 0.06);
    border-radius: 12px;
}
    /* lekki hover na kartach (nie agresywny) */
    .card:hover {
        box-shadow: 0 14px 34px rgba(15, 23, 42, 0.09);
        transform: translateY(-1px);
        transition: box-shadow 160ms ease, transform 160ms ease;
    }

/* Light navbar  */
.navbar {
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}

html[data-theme="dark"] .card {
    box-shadow: 0 18px 45px rgba(0,0,0,0.45);
}

/* Inputs */
.form-control,
.form-select,
textarea {
    background-color: var(--input-bg);
    color: var(--input-text);
    border-color: var(--input-border);
}

    .form-control::placeholder,
    textarea::placeholder {
        color: var(--text-muted);
    }

/* Muted text */
.text-muted,
.form-text,
small {
    color: var(--text-muted) !important;
}

/* === Navbar text/link colors in dark mode === */
html[data-theme="dark"] .navbar .navbar-brand,
html[data-theme="dark"] .navbar .navbar-brand:visited {
    color: var(--text-main) !important;
}

html[data-theme="dark"] .navbar .nav-link,
html[data-theme="dark"] .navbar .nav-link:visited {
    color: rgba(229,231,235,0.90) !important; /* jasny tekst */
}

    html[data-theme="dark"] .navbar .nav-link:hover,
    html[data-theme="dark"] .navbar .nav-link:focus {
        color: #ffffff !important;
    }

    /* jeśli masz tam span z nazwą usera */
    html[data-theme="dark"] .navbar .navbar-text,
    html[data-theme="dark"] .navbar .nav-link.text-muted {
        color: rgba(156,163,175,0.95) !important;
    }

html[data-theme="dark"] .btn-outline-secondary {
    color: rgba(229,231,235,0.90);
    border-color: rgba(255,255,255,0.20);
}

    html[data-theme="dark"] .btn-outline-secondary:hover {
        background-color: rgba(255,255,255,0.08);
        border-color: rgba(255,255,255,0.30);
    }

    /* ===== Page wrapper ===== */
.orionis-page{
    max-width: 1100px;
    margin: 0 auto;
    padding: 8px 0 24px;
}

.orionis-page-header{
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 16px;
}

/* ===== Sessions ===== */
.sessions-list{
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.session-card{
    background: rgba(255,255,255,0.04);
    border: 1px solid var(--border);
    border-radius: 14px;
    padding: 14px;
    box-shadow: 0 18px 45px rgba(0,0,0,0.25);
}

html[data-theme="dark"] .session-card{
    background: rgba(255,255,255,0.03);
}

.session-title{
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
    margin-bottom: 8px;
}

.session-actions{
    margin-top: -34px;
    display: flex;
    justify-content: flex-end;
}

@media (max-width: 768px){
    .session-actions{ margin-top: 10px; justify-content: flex-start; }
}

.session-meta{
    display: grid;
    grid-template-columns: 1fr;
    gap: 6px;
    font-size: 14px;
}

.session-meta .ua{
    overflow-wrap: anywhere;
}

.badge-soft{
    padding: 2px 10px;
    border-radius: 999px;
    font-size: 12px;
    border: 1px solid var(--border);
    background: rgba(255,255,255,0.06);
    color: var(--text-main);
    opacity: .92;
}

.badge-ok{
    background: rgba(34,197,94,0.15);
    border-color: rgba(34,197,94,0.35);
}

/* ===== Devices table (Security/Devices) ===== */
.devices-table {
    --bs-table-bg: transparent;
    --bs-table-color: var(--text-main);
    --bs-table-border-color: var(--border);
    --bs-table-hover-bg: rgba(255,255,255,0.04);
    --bs-table-striped-bg: rgba(255,255,255,0.02);
}

    .devices-table > :not(caption) > * > * {
        background-color: transparent !important;
        color: var(--text-main) !important;
    }

    .devices-table thead th {
        background: rgba(15, 23, 42, 0.40);
        backdrop-filter: blur(8px);
        border-bottom: 1px solid var(--border) !important;
        color: var(--text-main) !important;
    }

/* Light theme: header jaśniejszy */
html:not([data-theme="dark"]) .devices-table thead th {
    background: rgba(248,250,252,0.92);
}

/* Łagodniejsze podświetlenia wierszy niż Bootstrap */
html[data-theme="dark"] .devices-table tbody tr.table-primary {
    background-color: rgba(59,130,246,0.14) !important;
}

html[data-theme="dark"] .devices-table tbody tr.table-danger {
    background-color: rgba(239,68,68,0.12) !important;
}

/* W light też niech to będzie subtelne */
html:not([data-theme="dark"]) .devices-table tbody tr.table-primary {
    background-color: rgba(59,130,246,0.08) !important;
}

html:not([data-theme="dark"]) .devices-table tbody tr.table-danger {
    background-color: rgba(239,68,68,0.08) !important;
}
