/* ============================================================
   Rozliczenia Wspólnicy — Design System v2
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
    --font: system-ui, -apple-system, 'Segoe UI', sans-serif;

    /* Kolory */
    --bg:         #F5F4F0;
    --bg-card:    #FFFFFF;
    --bg-muted:   #F0EEE9;
    --border:     #E2DDD6;
    --border-md:  #CCC8C0;

    --text:       #18181A;
    --text-2:     #6B6860;
    --text-3:     #9E9B94;

    --blue:       #185FA5;
    --blue-bg:    #EAF2FB;
    --blue-dark:  #0C447C;

    --green:      #0F6E56;
    --green-bg:   #E2F4EE;

    --red:        #A32D2D;
    --red-bg:     #FCEAEA;

    --amber:      #7A4A08;
    --amber-bg:   #FDF0DC;

    --purple:     #3C3489;
    --purple-bg:  #EEEDFE;

    --radius-sm:  6px;
    --radius:     10px;
    --radius-lg:  14px;

    --sidebar-w:  210px;
    --topnav-h:   52px;
    --shadow:     0 1px 3px rgba(0,0,0,.06);
}

/* ── Base ─────────────────────────────────────────────────── */
body {
    font-family: var(--font);
    font-size: 14px;
    line-height: 1.5;
    color: var(--text);
    background: var(--bg);
}
a { color: var(--blue); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ── Topnav ───────────────────────────────────────────────── */
.topnav {
    position: sticky; top: 0; z-index: 100;
    height: calc(var(--topnav-h) + env(safe-area-inset-top));
    background: var(--bg-card);
    border-bottom: 1px solid var(--border);
    display: flex; align-items: center; justify-content: space-between;
    padding: env(safe-area-inset-top) 20px 0;
    gap: 12px;
}
.topnav-brand {
    display: flex; align-items: center; gap: 10px;
    font-size: 15px; font-weight: 600; color: var(--text);
    text-decoration: none;
}
.topnav-brand:hover { text-decoration: none; }
.brand-icon {
    width: 30px; height: 30px; border-radius: 8px;
    background: var(--blue); color: #fff;
    display: flex; align-items: center; justify-content: center;
    font-size: 11px; font-weight: 700; flex-shrink: 0;
}
.topnav-right {
    display: flex; align-items: center; gap: 8px;
}
.topnav-user {
    font-size: 13px; color: var(--text-2); padding: 0 6px;
}
.topnav-btn {
    font-size: 12px; font-weight: 500; padding: 5px 12px;
    border-radius: var(--radius-sm); cursor: pointer;
    border: 1px solid var(--border-md);
    background: var(--bg-card); color: var(--text-2);
    text-decoration: none; transition: background .1s;
}
.topnav-btn:hover { background: var(--bg-muted); text-decoration: none; color: var(--text); }
.topnav-btn-danger { color: var(--red); border-color: #F0BABA; }
.topnav-btn-danger:hover { background: var(--red-bg); color: var(--red); }
.topnav-btn-primary { background: var(--blue); color: #fff; border-color: var(--blue); }
.topnav-btn-primary:hover { background: var(--blue-dark); color: #fff; }

/* ── Layout ───────────────────────────────────────────────── */
.app-layout {
    display: flex;
    min-height: calc(100vh - var(--topnav-h));
}
.sidebar {
    width: var(--sidebar-w);
    flex-shrink: 0;
    background: var(--bg-card);
    border-right: 1px solid var(--border);
    padding: 16px 10px;
    position: sticky;
    top: calc(var(--topnav-h) + env(safe-area-inset-top));
    height: calc(100vh - var(--topnav-h) - env(safe-area-inset-top));
    overflow-y: auto;
}
.sidebar-label {
    font-size: 10px; font-weight: 600; color: var(--text-3);
    text-transform: uppercase; letter-spacing: .08em;
    padding: 0 8px; margin: 12px 0 4px;
}
.sidebar-label:first-child { margin-top: 0; }
.sidebar-link {
    display: flex; align-items: center; gap: 8px;
    padding: 7px 10px; border-radius: var(--radius-sm);
    font-size: 13px; color: var(--text-2);
    text-decoration: none; margin-bottom: 1px;
    transition: background .1s, color .1s;
}
.sidebar-link:hover { background: var(--bg-muted); color: var(--text); text-decoration: none; }
.sidebar-link.active { background: var(--blue-bg); color: var(--blue); font-weight: 500; }
.sidebar-link.active:hover { background: var(--blue-bg); }
.sidebar-sep { height: 1px; background: var(--border); margin: 8px 4px; }
.dot {
    width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
}
.dot-blue  { background: #378ADD; }
.dot-coral { background: #D85A30; }

.main {
    flex: 1; min-width: 0;
    padding: 24px 28px;
}

/* ── Page header ──────────────────────────────────────────── */
.page-hd {
    display: flex; align-items: flex-start; justify-content: space-between;
    margin-bottom: 20px; gap: 12px;
}
.page-hd h1 {
    font-size: 20px; font-weight: 600; color: var(--text);
    display: flex; align-items: center; gap: 8px;
}
.page-subtitle { font-size: 13px; color: var(--text-2); margin-top: 3px; }

/* ── Cards ────────────────────────────────────────────────── */
.card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    margin-bottom: 16px;
    overflow: hidden;
}
.card-hd {
    display: flex; align-items: center; justify-content: space-between;
    padding: 11px 16px;
    background: var(--bg-muted);
    border-bottom: 1px solid var(--border);
    font-size: 13px; font-weight: 500; color: var(--text);
}
.card-body { padding: 20px; }

/* ── Stat cards ───────────────────────────────────────────── */
.stats-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 12px;
    margin-bottom: 20px;
}
.stat {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 14px 16px;
}
.stat-label { font-size: 11px; color: var(--text-2); margin-bottom: 6px; }
.stat-value { font-size: 22px; font-weight: 600; color: var(--text); }
.stat-hint  { font-size: 11px; color: var(--text-3); margin-top: 4px; }
.stat-green { border-color: #8FD4BE; background: var(--green-bg); }
.stat-green .stat-value { color: var(--green); }
.stat-amber { border-color: #F0C87A; background: var(--amber-bg); }
.stat-amber .stat-value { color: var(--amber); }
.stat-red   { border-color: #F0BABA; background: var(--red-bg); }
.stat-red   .stat-value { color: var(--red); }
.stat-red   .stat-hint  { color: var(--red); }

/* ── Buttons ──────────────────────────────────────────────── */
.btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 8px 16px; border-radius: var(--radius-sm);
    font-size: 13px; font-weight: 500; cursor: pointer;
    border: 1px solid var(--border-md); text-decoration: none;
    transition: background .1s; white-space: nowrap;
    background: var(--bg-card); color: var(--text);
}
.btn:hover { background: var(--bg-muted); text-decoration: none; color: var(--text); }
.btn-primary { background: var(--blue); color: #fff; border-color: var(--blue); }
.btn-primary:hover { background: var(--blue-dark); color: #fff; }
.btn-secondary { background: var(--bg-muted); color: var(--text-2); }
.btn-danger { background: var(--red-bg); color: var(--red); border-color: #F0BABA; }
.btn-danger:hover { background: #F7D0D0; color: var(--red); }
.btn-sm { padding: 5px 11px; font-size: 12px; }
.btn-full { width: 100%; justify-content: center; }

/* ── Forms ────────────────────────────────────────────────── */
.form-row { display: flex; gap: 12px; margin-bottom: 14px; flex-wrap: wrap; }
.form-group { display: flex; flex-direction: column; gap: 5px; flex: 1; min-width: 120px; }
.form-group.w2 { flex: 2; }
.form-group label { font-size: 12px; font-weight: 500; color: var(--text-2); }
.form-group input,
.form-group select,
.form-group textarea {
    width: 100%; padding: 8px 11px;
    border: 1px solid var(--border-md); border-radius: var(--radius-sm);
    font-size: 13px; font-family: var(--font); color: var(--text);
    background: var(--bg-card); transition: border-color .15s;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
    outline: none; border-color: var(--blue);
    box-shadow: 0 0 0 3px rgba(24,95,165,.1);
}
.form-hint { font-size: 11px; color: var(--text-3); }
.form-sep { border-top: 1px solid var(--border); margin: 16px 0; }
.form-actions {
    display: flex; justify-content: flex-end; gap: 8px;
    padding-top: 16px; border-top: 1px solid var(--border); margin-top: 4px;
}
.required { color: var(--red); }
.computed-box {
    padding: 8px 11px; border-radius: var(--radius-sm);
    font-size: 15px; font-weight: 600; color: var(--green);
    background: var(--green-bg); border: 1px solid #8FD4BE;
    min-height: 36px;
}
.computed-box-red {
    color: var(--red); background: var(--red-bg); border-color: #F0BABA;
}

/* ── Typ switcher (wydatek / spłata) ──────────────────────── */
.typ-switcher {
    display: flex; margin-bottom: 18px;
    border: 1px solid var(--border-md);
    border-radius: var(--radius-sm); overflow: hidden; width: fit-content;
}
.typ-btn {
    padding: 8px 20px; font-size: 13px; font-weight: 500; cursor: pointer;
    border: none; background: var(--bg-muted); color: var(--text-2); transition: all .15s;
}
.typ-btn + .typ-btn { border-left: 1px solid var(--border-md); }
.typ-btn:hover { background: var(--bg); color: var(--text); }
.typ-btn.active { background: var(--blue); color: #fff; }
.splata-info {
    background: var(--amber-bg); border: 1px solid #F0C87A;
    border-radius: var(--radius-sm); padding: 10px 14px;
    font-size: 13px; color: var(--amber); margin-bottom: 14px;
}

/* ── Table ────────────────────────────────────────────────── */
.table-wrap { overflow-x: auto; }
.tbl {
    width: 100%; border-collapse: collapse; font-size: 13px;
}
.tbl thead th {
    padding: 10px 12px; text-align: left;
    font-size: 11px; font-weight: 600; color: var(--text-2);
    text-transform: uppercase; letter-spacing: .05em;
    background: var(--bg-muted); border-bottom: 1px solid var(--border);
    white-space: nowrap;
}
.tbl tbody td {
    padding: 9px 12px; border-bottom: 1px solid var(--border);
    vertical-align: middle;
}
.tbl tbody tr:last-child td { border-bottom: none; }
.tbl tbody tr:hover td { background: #FAFAF7; }
.tbl tfoot td {
    padding: 10px 12px; font-weight: 600;
    border-top: 2px solid var(--border-md);
    background: var(--bg-muted);
}
.tbl td.td-opis { min-width: 150px; }
.tbl .r { text-align: right; }
.tbl .c { text-align: center; }
.tbl .muted { color: var(--text-2); }
.tbl .num { font-variant-numeric: tabular-nums; }
.row-neg td { color: var(--red) !important; }

/* Szerokości kolumn */
.col-lp    { width: 38px; }
.col-av    { width: 44px; }
.col-nr    { width: 110px; }
.col-data  { width: 96px; white-space: nowrap; }
.col-plat  { width: 78px; }
.col-brutto{ width: 90px; }
.col-vat   { width: 54px; }
.col-netto { width: 90px; }
.col-doodd { width: 96px; }
.col-act   { width: 34px; }

/* ── Badges ───────────────────────────────────────────────── */
.badge {
    display: inline-flex; align-items: center;
    padding: 2px 8px; border-radius: 20px;
    font-size: 11px; font-weight: 500; white-space: nowrap;
}
.badge-blue   { background: var(--blue-bg);   color: var(--blue-dark); }
.badge-green  { background: var(--green-bg);  color: var(--green); }
.badge-red    { background: var(--red-bg);    color: var(--red); }
.badge-amber  { background: var(--amber-bg);  color: var(--amber); }
.badge-purple { background: var(--purple-bg); color: var(--purple); }
.badge-gray   { background: var(--bg-muted);  color: var(--text-2); }
.vat-text { font-size: 11px; color: var(--text-3); }

/* ── Avatar ───────────────────────────────────────────────── */
.av {
    width: 26px; height: 26px; border-radius: 50%;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 9px; font-weight: 700; flex-shrink: 0;
}
.av-blue  { background: var(--blue-bg);  color: var(--blue); }
.av-coral { background: #FAECE7; color: #712B13; }

/* ── Text utilities ───────────────────────────────────────── */
.text-green  { color: var(--green) !important; }
.text-red    { color: var(--red) !important; }
.text-amber  { color: var(--amber) !important; }
.text-muted  { color: var(--text-2); }
.text-xs     { font-size: 11px; }
.text-sm     { font-size: 12px; }
.fw-6        { font-weight: 600; }
.nowrap      { white-space: nowrap; }

/* ── Alerts ───────────────────────────────────────────────── */
.alert {
    border-radius: var(--radius-sm); padding: 12px 16px;
    margin-bottom: 16px; font-size: 13px;
}
.alert-ok  { background: var(--green-bg); color: var(--green); border: 1px solid #8FD4BE; }
.alert-err { background: var(--red-bg);   color: var(--red);   border: 1px solid #F0BABA; }

/* ── Login page ───────────────────────────────────────────── */
.login-wrap {
    min-height: 100vh; display: flex;
    align-items: center; justify-content: center; padding: 1rem;
}
.login-box {
    background: var(--bg-card); border: 1px solid var(--border);
    border-radius: var(--radius-lg); padding: 36px 32px;
    width: 100%; max-width: 380px;
}
.login-logo { text-align: center; margin-bottom: 24px; }
.login-logo .brand-icon { width: 48px; height: 48px; font-size: 14px; margin: 0 auto 12px; }
.login-logo h1 { font-size: 20px; font-weight: 600; }
.login-logo p  { font-size: 13px; color: var(--text-2); margin-top: 4px; }

/* ── Print ────────────────────────────────────────────────── */
@media print {
    .topnav, .sidebar, .no-print { display: none !important; }
    .app-layout { display: block; }
    body { background: #fff; font-size: 11px; }
    .card { border: 1px solid #ccc; break-inside: avoid; }
    .tbl { font-size: 11px; }
}

/* ── Zestawienie (print view) ─────────────────────────────── */
.zes-wrap { max-width: 1100px; margin: 0 auto; padding: 24px 28px 48px; }
.zes-title { text-align: center; margin-bottom: 24px; }
.zes-title h1 { font-size: 20px; font-weight: 600; }
.zes-title p  { font-size: 13px; color: var(--text-2); margin-top: 4px; }
.zes-person-hd {
    display: flex; justify-content: space-between; align-items: baseline;
    padding: 12px 16px;
    background: var(--bg-muted); border-bottom: 1px solid var(--border);
    font-size: 13px;
}
.zes-person-hd strong { font-size: 15px; font-weight: 600; }

/* ============================================================
   Dark mode
   ============================================================ */
[data-theme="dark"] {
    --bg:         #141416;
    --bg-card:    #1E1E22;
    --bg-muted:   #26262C;
    --border:     #2E2E36;
    --border-md:  #3E3E48;

    --text:       #F0EFEb;
    --text-2:     #A8A5A0;
    --text-3:     #6A6760;

    --blue:       #5B9FE0;
    --blue-bg:    #1A2A3E;
    --blue-dark:  #7DB8F0;

    --green:      #3DBD96;
    --green-bg:   #0D2920;

    --red:        #E06060;
    --red-bg:     #2E1414;

    --amber:      #D4A44A;
    --amber-bg:   #2A1E08;

    --purple:     #9A90F0;
    --purple-bg:  #1E1A38;

    --shadow:     0 1px 4px rgba(0,0,0,.4);
}

[data-theme="dark"] .tbl tbody tr:hover td { background: #26262C; }
[data-theme="dark"] .tbl tbody tr.row-neg td { color: var(--red); }
[data-theme="dark"] body { background: var(--bg); }
[data-theme="dark"] .stat-green { background: var(--green-bg); border-color: #1A4A38; }
[data-theme="dark"] .stat-amber { background: var(--amber-bg); border-color: #4A3010; }
[data-theme="dark"] .login-box  { background: var(--bg-card); }
[data-theme="dark"] input, [data-theme="dark"] select, [data-theme="dark"] textarea {
    background: #26262C; color: var(--text); border-color: var(--border-md);
}
[data-theme="dark"] input:focus, [data-theme="dark"] select:focus, [data-theme="dark"] textarea:focus {
    border-color: var(--blue); box-shadow: 0 0 0 3px rgba(91,159,224,.15);
}

/* Theme toggle button */
.theme-toggle {
    background: none; border: 1px solid var(--border-md);
    border-radius: var(--radius-sm); cursor: pointer;
    padding: 5px 9px; font-size: 15px; line-height: 1;
    color: var(--text-2); transition: background .15s;
}
.theme-toggle:hover { background: var(--bg-muted); }

/* ============================================================
   Responsive — Mobile
   ============================================================ */

/* Hamburger button */
.hamburger {
    display: none;
    background: none; border: none; cursor: pointer;
    padding: 6px; color: var(--text); flex-shrink: 0;
}
.hamburger svg { display: block; }

/* Overlay za sidebarem */
.sidebar-overlay {
    display: none;
    position: fixed; inset: 0;
    background: rgba(0,0,0,.4);
    z-index: 199;
}
.sidebar-overlay.open { display: block; }

@media (max-width: 768px) {

    /* Topnav */
    .topnav {
        padding: env(safe-area-inset-top) 10px 0;
        gap: 6px;
        height: calc(52px + env(safe-area-inset-top));
        flex-wrap: nowrap;
    }
    .topnav-brand span { display: none; }
    .topnav-user { display: none; }
    .hamburger { display: flex; order: -1; }
    .topnav-right { gap: 5px; }
    .topnav-btn { padding: 5px 8px; font-size: 11px; }
    .theme-toggle { padding: 5px 7px; }

    /* Sidebar — wysuwa się z lewej */
    .sidebar {
        position: fixed;
        top: 0; left: 0;
        height: 100vh;
        width: 260px;
        z-index: 200;
        transform: translateX(-100%);
        transition: transform .25s ease;
        padding-top: calc(var(--topnav-h) + env(safe-area-inset-top) + 8px);
        padding-left: max(10px, env(safe-area-inset-left));
        padding-bottom: env(safe-area-inset-bottom);
        box-shadow: 4px 0 20px rgba(0,0,0,.15);
    }
    .sidebar.open { transform: translateX(0); }

    /* Główna treść — pełna szerokość */
    .app-layout { display: block; }
    .main { padding: 16px 14px; padding-bottom: calc(16px + env(safe-area-inset-bottom)); }

    /* Karty statystyk — jedna kolumna */
    .stats-row { grid-template-columns: 1fr !important; gap: 8px; }
    .stat { padding: 12px 14px; }
    .stat-value { font-size: 18px !important; }

    /* Tabele — scroll poziomy */
    .table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
    .tbl { font-size: 12px; }
    .tbl thead th { padding: 8px 10px; }
    .tbl tbody td { padding: 7px 10px; }

    /* Page header */
    .page-hd { flex-direction: column; gap: 10px; align-items: flex-start; }
    .page-hd h1 { font-size: 17px; }

    /* Formularze */
    .form-row { flex-direction: column; }
    .form-group { min-width: unset; }
    .form-actions { flex-wrap: wrap; }

    /* Card */
    .card-hd { flex-direction: column; align-items: flex-start; gap: 4px; font-size: 12px; }
    .card-body { padding: 14px; }

    /* Typ switcher */
    .typ-switcher { width: 100%; }
    .typ-btn { flex: 1; text-align: center; }

    /* Login */
    .login-wrap { padding: .5rem; }
    .login-box { padding: 24px 20px; }

    /* Ukryj kolumny mniej ważne na mobile */
    .tbl .col-nr   { display: none; }
    .tbl th.col-nr { display: none; }
}

@media (max-width: 480px) {
    .tbl .col-vat  { display: none; }
    .tbl th.col-vat { display: none; }
    .tbl .col-netto  { display: none; }
    .tbl th.col-netto { display: none; }
}

[data-theme="dark"] .stat-red { background: #2E1414; border-color: #4A2020; }

/* ── Analityka wydatków ───────────────────────────────────── */
.anal-card { margin-bottom: 16px; }
.anal-body { padding: 14px 16px; }

.anal-controls {
    display: flex; flex-direction: column; gap: 10px; margin-bottom: 14px;
}
.anal-ctrl-group { display: flex; flex-direction: column; gap: 5px; }
.anal-ctrl-label { font-size: 11px; color: var(--text-2); }
.anal-switcher   { margin-bottom: 0 !important; width: fit-content; }

.anal-wlasny {
    display: flex; flex-wrap: wrap; gap: 8px; align-items: flex-end;
}
.anal-date-input {
    padding: 7px 10px; font-size: 13px;
    border: 1px solid var(--border-md); border-radius: var(--radius-sm);
    background: var(--bg-card); color: var(--text);
}
.anal-apply-btn { align-self: flex-end; }

/* KPI grid — desktop: 4 karty w rzędzie */
.anal-kpi-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 8px; margin-bottom: 14px;
}
.anal-kpi {
    background: var(--bg-muted);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 10px 12px;
}
.anal-kpi-label    { font-size: 10px; color: var(--text-2); margin-bottom: 3px; line-height: 1.3; }
.anal-kpi-sublabel { font-size: 10px; color: var(--text-3); }
.anal-kpi-val      { font-size: 18px; font-weight: 700; line-height: 1.2; }
.anal-kpi-hint     { font-size: 10px; color: var(--text-3); margin-top: 2px; }

/* Chart grid — responsywny */
.chart-grid { display: grid; grid-template-columns: 1fr 2fr; gap: 16px; }
@media (max-width: 768px) {
    .chart-grid { grid-template-columns: 1fr !important; }
    .chart-grid > .card { margin: 0 !important; }
}

.computed-box-green { background: var(--green-bg); color: var(--green); }

/* ============================================================
   Panel komentarzy
   ============================================================ */

/* Przycisk komentarza w tabeli */
.btn-koment {
    background: none; border: none; cursor: pointer;
    color: var(--text-3); font-size: 15px; padding: 2px 4px;
    position: relative; line-height: 1;
    transition: color .15s;
}
.btn-koment:hover { color: var(--blue); }
.btn-koment.has-new { color: var(--blue); }
.koment-badge {
    position: absolute; top: -4px; right: -4px;
    background: var(--blue); color: #fff;
    font-size: 9px; font-weight: 700; line-height: 14px;
    width: 14px; height: 14px; border-radius: 50%;
    text-align: center; display: block;
}

/* Overlay */
.koment-overlay {
    display: none; position: fixed; inset: 0;
    background: rgba(0,0,0,.35); z-index: 299;
}
.koment-overlay.open { display: block; }

/* Panel */
.koment-panel {
    position: fixed; top: 0; right: 0;
    width: 380px; max-width: 100vw;
    height: 100vh;
    background: var(--bg-card);
    border-left: 1px solid var(--border);
    box-shadow: -4px 0 24px rgba(0,0,0,.12);
    z-index: 300;
    display: flex; flex-direction: column;
    transform: translateX(110%);
    transition: transform .25s ease;
    overflow: hidden;
}
.koment-panel.open { transform: translateX(0) !important; }

.koment-panel-hd {
    display: flex; align-items: center; justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid var(--border);
    flex-shrink: 0;
}
.koment-panel-hd h3 { font-size: 14px; font-weight: 600; margin: 0; }
.koment-close {
    background: none; border: none; cursor: pointer;
    font-size: 20px; color: var(--text-2); padding: 0 4px; line-height: 1;
}
.koment-close:hover { color: var(--text); }

.koment-opis {
    padding: 10px 20px;
    font-size: 12px; color: var(--text-2);
    border-bottom: 1px solid var(--border);
    flex-shrink: 0;
    background: var(--bg-muted);
}

.koment-lista {
    flex: 1; overflow-y: auto;
    padding: 12px 20px;
    display: flex; flex-direction: column; gap: 10px;
}

.koment-empty {
    text-align: center; color: var(--text-3);
    font-size: 13px; padding: 2rem 0;
}

.koment-item {
    background: var(--bg-muted);
    border-radius: var(--radius-sm);
    padding: 10px 12px;
}
.koment-item.moj {
    background: var(--blue-bg);
    margin-left: 20px;
}
.koment-item-hd {
    display: flex; align-items: center; gap: 6px;
    margin-bottom: 5px;
}
.koment-autor { font-size: 11px; font-weight: 600; color: var(--text); }
.koment-czas  { font-size: 10px; color: var(--text-3); margin-left: auto; }
.koment-tresc { font-size: 13px; color: var(--text); line-height: 1.5; white-space: pre-wrap; }

.koment-form {
    padding: 12px 20px;
    border-top: 1px solid var(--border);
    flex-shrink: 0;
}
.koment-form textarea {
    width: 100%; resize: none;
    border: 1px solid var(--border-md);
    border-radius: var(--radius-sm);
    padding: 8px 10px;
    font-size: 13px; font-family: var(--font);
    background: var(--bg-card); color: var(--text);
    line-height: 1.5;
}
.koment-form textarea:focus {
    outline: none; border-color: var(--blue);
    box-shadow: 0 0 0 3px rgba(24,95,165,.12);
}
.koment-form-actions {
    display: flex; align-items: center;
    justify-content: space-between;
    margin-top: 8px;
}
.koment-hint { font-size: 11px; color: var(--text-3); }

/* Mobile — panel wysuwa się od dołu */
@media (max-width: 768px) {
    .koment-panel {
        top: auto; bottom: 0; left: 0; right: 0;
        width: 100%; height: 75vh;
        border-left: none;
        border-top: 1px solid var(--border);
        border-radius: 16px 16px 0 0;
        transform: translateY(100%);
        transition: transform .25s ease;
    }
    .koment-panel.open { transform: translateY(0); }
    .koment-panel-hd { padding-top: 20px; }
    .koment-panel-hd::before {
        content: '';
        position: absolute;
        top: 8px; left: 50%;
        transform: translateX(-50%);
        width: 36px; height: 4px;
        background: var(--border-md);
        border-radius: 2px;
    }
}

/* ── Analityka KPI — mobile override (musi być na końcu) ── */
@media (max-width: 768px) {
    .anal-switcher { width: 100% !important; }

    /* 4 kompaktowe kafelki w rzędzie */
    .anal-kpi-grid { gap: 5px; }
    .anal-kpi      { padding: 7px 8px; }
    .anal-kpi-label { font-size: 9px; margin-bottom: 2px; }
    .anal-kpi-val   { font-size: 13px; }
    .anal-kpi-hint  { font-size: 9px; }
    .anal-kpi-sublabel { display: none; }
}
