/* ============================================================
   VÝDEJNÍ MÍSTA — CSS
   Styl: minimalistický, černo-bílý
   ============================================================ */

/* ---- Variables ---- */
:root {
    --sidebar-w: 260px;
    --color-black: #000000;
    --color-white: #ffffff;
    --color-bg: #f4f4f4;
    --color-border: #e0e0e0;
    --color-border-dark: #b0b0b0;
    --color-muted: #777777;
    --color-hover-bg: #f0f0f0;
    --color-section-bg: #ffffff;
    --font: -apple-system, BlinkMacSystemFont, 'Segoe UI', Helvetica, Arial, sans-serif;
}

/* ---- Reset & Base ---- */
*, *::before, *::after { box-sizing: border-box; }

body {
    font-family: var(--font);
    background-color: var(--color-bg);
    color: var(--color-black);
    font-size: 14px;
    line-height: 1.5;
}

a { color: inherit; }

code {
    font-size: .85em;
    color: #222;
    background: #f0f0f0;
    padding: .1em .35em;
    border-radius: 2px;
}


/* ============================================================
   PŘIHLAŠOVACÍ STRÁNKA
   ============================================================ */
#login-page {
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: var(--color-bg);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}

.login-box {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    width: 100%;
    max-width: 400px;
    padding: 2.5rem 2rem 1.75rem;
}

.login-logo {
    font-size: 2.2rem;
    color: var(--color-black);
    margin-bottom: .75rem;
    line-height: 1;
}

.login-title {
    font-size: 1.5rem;
    font-weight: 800;
    letter-spacing: -.03em;
    margin-bottom: .15rem;
    color: var(--color-black);
}

.login-subtitle {
    font-size: .8rem;
    color: var(--color-muted);
    text-transform: uppercase;
    letter-spacing: .07em;
    font-weight: 600;
    margin-bottom: 2rem;
}

.login-label {
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: #555;
    margin-bottom: .35rem;
    display: block;
}

.login-input {
    border-color: var(--color-border);
    font-size: .9rem;
    padding: .55rem .75rem;
}

.login-input:focus {
    border-color: var(--color-black);
    box-shadow: none;
}

.login-input.is-invalid {
    border-color: var(--color-black);
    border-width: 2px;
    /* Zakáže Bootstrap's vykřičník uvnitř pole — chyby zobrazujeme textem pod polem */
    background-image: none;
    padding-right: .75rem;
}

.login-password-wrap {
    position: relative;
}

/* Password input — vždy dát místo pro eye button vpravo */
.login-password-wrap .login-input {
    padding-right: 2.5rem;
}

.login-eye {
    position: absolute;
    right: .65rem;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    cursor: pointer;
    color: #aaa;
    padding: .2rem;
    line-height: 1;
    z-index: 5;
}

.login-eye:hover { color: var(--color-black); }

.login-error {
    font-size: .75rem;
    color: var(--color-black);
    font-weight: 600;
    margin-top: .3rem;
    min-height: 1rem;
}

.login-error--general {
    background: #f5f5f5;
    border: 1.5px solid var(--color-black);
    padding: .5rem .75rem;
    display: none;
}

.login-error--general.visible { display: block; }

.login-btn {
    font-size: .9rem;
    font-weight: 700;
    padding: .65rem;
    letter-spacing: .02em;
}

.login-footer {
    margin-top: 1.75rem;
    padding-top: 1.25rem;
    border-top: 1px solid var(--color-border);
    font-size: .73rem;
    color: #bbb;
    text-align: center;
}

/* Skrytí aplikace dokud není přihlášeno */
body:not(.logged-in) .mobile-header,
body:not(.logged-in) #sidebar,
body:not(.logged-in) .main-content {
    display: none !important;
}


/* ============================================================
   MOBILE HEADER
   ============================================================ */
.mobile-header {
    position: sticky;
    top: 0;
    z-index: 200;
    min-height: 50px;
    background: var(--color-white);
    border-bottom: 1px solid var(--color-border);
}


/* ============================================================
   SIDEBAR
   ============================================================ */

/* Desktop: sidebar vždy viditelný a fixní */
@media (min-width: 992px) {
    #sidebar {
        width: var(--sidebar-w) !important;
        position: fixed;
        top: 0;
        left: 0;
        bottom: 0;
        z-index: 100;
        transform: none !important;
        visibility: visible !important;
        border-right: 1px solid var(--color-border);
    }

    .main-content {
        margin-left: var(--sidebar-w);
    }
}

/* Sidebar body */
#sidebar .offcanvas-body,
#sidebar {
    background: var(--color-white);
}

/* Brand */
.sidebar-brand {
    min-height: 56px;
    border-bottom: 1px solid var(--color-border);
}

.sidebar-brand-text {
    font-size: .75rem;
    letter-spacing: .1em;
}

/* Operator info */
.sidebar-user {
    background: #f8f8f8;
    border-bottom: 1px solid var(--color-border);
}

/* Nav links — shared base */
.nav-main-link,
.nav-group-toggle,
.nav-sub-link {
    display: flex;
    align-items: center;
    width: 100%;
    padding: .55rem 1.25rem;
    font-size: .84rem;
    font-weight: 500;
    color: #333;
    text-decoration: none;
    border: none;
    background: none;
    cursor: pointer;
    transition: background .12s, color .12s;
}

.nav-main-link:hover,
.nav-group-toggle:hover,
.nav-sub-link:hover {
    background: var(--color-hover-bg);
    color: var(--color-black);
}

.nav-main-link.active {
    background: var(--color-black);
    color: var(--color-white);
}

/* Group header */
.nav-group-toggle {
    font-size: .7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--color-muted);
    padding-top: .9rem;
    padding-bottom: .4rem;
}

.nav-group-toggle:hover {
    background: transparent;
    color: #444;
}

/* Arrow rotation */
.nav-arrow { transition: transform .2s; }
.nav-group-toggle[aria-expanded="false"] .nav-arrow { transform: rotate(-90deg); }

/* Sub links */
.nav-sub-link {
    padding-left: 2.75rem;
    font-weight: 400;
    color: #444;
}

.nav-sub-link.active {
    font-weight: 600;
    color: var(--color-black);
}

/* Footer */
.sidebar-footer { background: var(--color-white); }

.nav-main-link--logout { color: #555; }
.nav-main-link--logout:hover { background: #fff0f0; color: #c00; }


/* ============================================================
   MAIN CONTENT
   ============================================================ */
.main-content {
    padding: 1.75rem;
    min-height: 100vh;
}

@media (max-width: 575px) {
    .main-content { padding: 1rem; }
}


/* ============================================================
   SECTION
   ============================================================ */
.content-section {
    background: var(--color-section-bg);
    border: 1px solid var(--color-border);
    padding: 1.75rem;
}

@media (max-width: 575px) {
    .content-section { padding: 1.1rem; }
}

.section-header { margin-bottom: 1.5rem; }

.section-title {
    font-size: 1.35rem;
    font-weight: 800;
    letter-spacing: -.03em;
    margin-bottom: .2rem;
}

.section-subtitle {
    font-size: .8rem;
    color: var(--color-muted);
    margin: 0;
}

/* Section divider */
.sec-divider {
    position: relative;
    text-align: center;
    margin: 1.75rem 0;
    height: 1px;
    background: var(--color-border);
    border: none;
}

.sec-divider span {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: var(--color-bg);
    padding: 0 .9rem;
    font-size: .68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .1em;
    color: #999;
}


/* ============================================================
   DASHBOARD — STAT CARDS
   ============================================================ */
.stat-card {
    position: relative;
    overflow: hidden;
    background: var(--color-white);
    border: 1px solid var(--color-border);
    padding: 1.1rem 1.1rem 1rem;
}

.stat-value {
    position: relative;
    z-index: 1;
    font-size: 2rem;
    font-weight: 800;
    letter-spacing: -.05em;
    line-height: 1;
    color: var(--color-black);
    margin-bottom: .3rem;
}

.stat-label {
    position: relative;
    z-index: 1;
    font-size: .72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--color-muted);
}

.stat-bg-icon {
    position: absolute;
    right: .9rem;
    top: 50%;
    transform: translateY(-50%);
    font-size: 2.8rem;
    color: #ebebeb;
    pointer-events: none;
    z-index: 0;
}

/* Alert variant — ohraničení */
.stat-card--alert {
    border: 2px solid var(--color-black);
}

/* Invertovaná karta */
.stat-card--inverted {
    background: var(--color-black);
    border-color: var(--color-black);
}

.stat-card--inverted .stat-value,
.stat-card--inverted .stat-label {
    color: var(--color-white);
}

.stat-card--inverted .stat-bg-icon {
    color: #2a2a2a;
}


/* ============================================================
   DASHBOARD — INNER CARDS
   ============================================================ */
.inner-card {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    display: flex;
    flex-direction: column;
}

.inner-card-header {
    padding: .7rem 1rem;
    font-size: .78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--color-muted);
    border-bottom: 1px solid var(--color-border);
    background: #fafafa;
}

.inner-card-body {
    padding: 1rem;
    flex: 1;
}

/* Activity list */
.activity-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.activity-item {
    display: flex;
    align-items: baseline;
    gap: .75rem;
    padding: .6rem 1rem;
    border-bottom: 1px solid var(--color-border);
    font-size: .82rem;
}

.activity-item:last-child { border-bottom: none; }

.activity-time {
    flex-shrink: 0;
    font-size: .75rem;
    color: var(--color-muted);
    font-variant-numeric: tabular-nums;
    min-width: 2.5rem;
}

.activity-text { color: #333; }


/* ============================================================
   SEZNAM ZÁSILEK
   ============================================================ */

/* Search */
.search-wrap {
    position: relative;
}

.search-icon {
    position: absolute;
    left: .75rem;
    top: 50%;
    transform: translateY(-50%);
    color: #aaa;
    pointer-events: none;
    z-index: 5;
}

.search-input {
    padding-left: 2.2rem;
    border-radius: 0;
    border-color: var(--color-border);
    font-size: .85rem;
}

.search-input:focus {
    border-color: var(--color-black);
    box-shadow: none;
}

/* Filter buttons */
.filter-btn {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .3rem .7rem;
    font-size: .78rem;
    font-weight: 600;
    border: 1px solid var(--color-border-dark);
    background: var(--color-white);
    color: #444;
    cursor: pointer;
    transition: background .12s, color .12s, border-color .12s;
}

.filter-btn:hover {
    background: var(--color-black);
    color: var(--color-white);
    border-color: var(--color-black);
}

.filter-btn--active,
.filter-btn.active {
    background: var(--color-black);
    color: var(--color-white);
    border-color: var(--color-black);
}

.filter-btn--alert {
    border-color: var(--color-black);
    font-style: italic;
}

.filter-count {
    display: inline-block;
    background: rgba(255,255,255,.25);
    padding: .05rem .35rem;
    font-size: .7rem;
    font-weight: 700;
}

.filter-btn:not(.filter-btn--active):not(.active) .filter-count {
    background: #eee;
    color: #555;
}

/* Table */
.table thead th {
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    background: var(--color-black);
    color: var(--color-white);
    border: none;
    padding: .65rem .75rem;
}

.table tbody td {
    vertical-align: middle;
    padding: .6rem .75rem;
    border-color: var(--color-border);
    font-size: .84rem;
}

.table tbody tr:hover td {
    background: #fafafa;
}

/* Overdue row */
.row-overdue td {
    background: #f9f9f9;
}

.row-overdue td:first-child {
    border-left: 3px solid var(--color-black);
}

/* Order code */
.order-code {
    font-size: .8rem;
    font-weight: 600;
    background: #f0f0f0;
    color: #111;
    padding: .15em .4em;
}

/* Package badge */
.pkg-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.5rem;
    height: 1.5rem;
    background: var(--color-black);
    color: var(--color-white);
    font-size: .72rem;
    font-weight: 700;
    border-radius: 50%;
}

/* Pagination */
.page-link {
    color: var(--color-black);
    border-color: var(--color-border);
    font-size: .8rem;
}

.page-item.active .page-link {
    background: var(--color-black);
    border-color: var(--color-black);
}

.page-link:hover {
    background: var(--color-hover-bg);
    color: var(--color-black);
}


/* ============================================================
   STATUS BADGES
   ============================================================ */
.status-badge {
    display: inline-block;
    padding: .25rem .6rem;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .03em;
    text-transform: uppercase;
    white-space: nowrap;
}

/* Odesláno na VM */
.s-sent {
    background: #f0f0f0;
    color: #555;
    border: 1px solid #ccc;
}

/* Přijato na VM */
.s-received {
    background: #e4e4e4;
    color: #111;
    border: 1px solid #aaa;
}

/* Vydáno zákazníkovi */
.s-issued {
    background: var(--color-black);
    color: var(--color-white);
}

/* Dobírka uhrazena */
.s-cod {
    background: var(--color-black);
    color: var(--color-white);
    outline: 2px solid var(--color-black);
    outline-offset: 1px;
}

/* Nevyzvednuto */
.s-overdue {
    background: var(--color-white);
    color: var(--color-black);
    border: 2px solid var(--color-black);
    font-style: italic;
}

/* Vrací se */
.s-returning {
    background: #555;
    color: var(--color-white);
}


/* ============================================================
   DETAIL ZÁSILKY
   ============================================================ */
.detail-block {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    padding: 1.25rem;
}

.detail-block-title {
    font-size: .7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--color-muted);
    padding-bottom: .65rem;
    margin-bottom: .9rem;
    border-bottom: 1px solid var(--color-border);
}

.detail-field-label {
    font-size: .68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: #aaa;
    margin-bottom: .15rem;
}

.detail-field-value {
    font-size: .88rem;
    font-weight: 500;
    color: var(--color-black);
}

/* Počet balíků — highlight */
.pkg-highlight {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: .5rem;
    background: var(--color-black);
    color: var(--color-white);
    padding: .7rem 1rem;
    font-size: .9rem;
    font-weight: 600;
}

.pkg-highlight-note {
    font-size: .75rem;
    font-weight: 400;
    color: #aaa;
}

/* Dobírka */
.detail-block--cod {
    border: 1px solid var(--color-border-dark);
}

.detail-block--cod-active {
    border: 2px solid var(--color-black);
}

.cod-amount {
    font-size: 2.2rem;
    font-weight: 800;
    letter-spacing: -.04em;
    color: #ccc;
    margin-bottom: .2rem;
    line-height: 1;
}

.cod-amount--active {
    color: var(--color-black);
}

/* Historie */
.history-line {
    position: relative;
    padding-left: 1.5rem;
}

.history-line::before {
    content: '';
    position: absolute;
    left: 5px;
    top: 6px;
    bottom: 6px;
    width: 1px;
    background: var(--color-border);
}

.history-entry {
    position: relative;
    display: flex;
    align-items: flex-start;
    gap: .9rem;
    margin-bottom: 1.1rem;
}

.history-entry:last-child { margin-bottom: 0; }

.history-dot {
    position: absolute;
    left: -1.5rem;
    top: 5px;
    width: 11px;
    height: 11px;
    border-radius: 50%;
    background: #d0d0d0;
    border: 2px solid var(--color-white);
    box-shadow: 0 0 0 1px #bbb;
    flex-shrink: 0;
}

.history-dot--filled {
    background: var(--color-black);
    box-shadow: 0 0 0 1px var(--color-black);
}


/* ============================================================
   ŽIVOTNÍ CYKLUS
   ============================================================ */

/* Hlavní track */
.lc-track {
    display: flex;
    align-items: center;
    overflow-x: auto;
    padding: 1.25rem 0 1.5rem;
    gap: 0;
}

.lc-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    min-width: 90px;
    flex-shrink: 0;
}

.lc-icon {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.3rem;
    background: #eee;
    color: #bbb;
    border: 2px solid #ddd;
    margin-bottom: .55rem;
    transition: background .2s, color .2s;
}

.lc-step--done .lc-icon {
    background: #e0e0e0;
    color: #444;
    border-color: #999;
}

.lc-step--active .lc-icon {
    background: var(--color-black);
    color: var(--color-white);
    border-color: var(--color-black);
    box-shadow: 0 0 0 3px rgba(0,0,0,.15);
}

.lc-label {
    font-size: .75rem;
    font-weight: 700;
    color: var(--color-black);
    line-height: 1.3;
    margin-bottom: .2rem;
}

.lc-sub {
    font-size: .65rem;
    color: var(--color-muted);
}

.lc-line {
    flex: 1;
    height: 2px;
    background: #e0e0e0;
    min-width: 28px;
    margin-bottom: 1.5rem;
    flex-shrink: 0;
}

.lc-line--done {
    background: #888;
}

/* Alt cards */
.lc-alt-card {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    padding: 1rem;
}

/* Action panel */
.lc-action-panel {
    background: #f8f8f8;
    border: 1px solid var(--color-border);
    padding: 1.1rem 1.25rem;
}

.lc-action-panel-title {
    font-size: .78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--color-muted);
    margin-bottom: .85rem;
}

/* COD confirm */
.cod-confirm-box {
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    gap: .75rem;
    background: var(--color-white);
    border: 2px solid var(--color-black);
    padding: .45rem .9rem;
}


/* ============================================================
   BOOTSTRAP OVERRIDES
   ============================================================ */

/* Buttons */
.btn-dark {
    background: var(--color-black);
    border-color: var(--color-black);
    font-size: .84rem;
    font-weight: 600;
}

.btn-dark:hover {
    background: #222;
    border-color: #222;
}

.btn-outline-dark {
    border-color: var(--color-black);
    color: var(--color-black);
    font-size: .84rem;
    font-weight: 600;
}

.btn-outline-dark:hover {
    background: var(--color-black);
    color: var(--color-white);
}

.btn-outline-secondary {
    font-size: .84rem;
}

/* Table reset */
.table > :not(caption) > * > * {
    box-shadow: none;
}

/* Form control */
.form-control:focus {
    box-shadow: none;
    border-color: var(--color-black);
}


/* ============================================================
   SKENOVÁNÍ ZÁSILEK
   ============================================================ */
.scan-area {
    background: #f8f8f8;
    border: 2px solid var(--color-black);
    padding: 1.5rem;
    margin-bottom: 1.5rem;
}

.scan-input-wrap {
    display: flex;
    align-items: center;
    gap: 0;
    position: relative;
}

.scan-input-icon {
    position: absolute;
    left: 1rem;
    font-size: 1.4rem;
    color: #aaa;
    pointer-events: none;
    z-index: 5;
}

/* Větší tlačítko potvrzení vydání (bez dobírky) na desktopu */
@media (min-width: 768px) {
    .issue-confirm-btn--primary {
        padding-top: 1rem;
        padding-bottom: 1rem;
        font-size: 1.1rem;
    }
}

.scan-input {
    flex: 1;
    border: 2px solid var(--color-black);
    border-right: none;
    border-radius: 0;
    padding: .85rem 1rem .85rem 3rem;
    font-size: 1.1rem;
    font-weight: 500;
    outline: none;
    background: var(--color-white);
    color: var(--color-black);
    letter-spacing: .02em;
    min-width: 0;
    transition: background .12s;
}

.scan-input:focus {
    background: var(--color-white);
    border-color: var(--color-black);
    box-shadow: none;
}

.scan-input::placeholder { color: #bbb; font-weight: 400; }

.scan-submit-btn {
    flex-shrink: 0;
    background: var(--color-black);
    color: var(--color-white);
    border: 2px solid var(--color-black);
    padding: .85rem 1.25rem;
    font-size: .85rem;
    font-weight: 700;
    cursor: pointer;
    white-space: nowrap;
    transition: background .12s;
}

.scan-submit-btn:hover { background: #222; border-color: #222; }

.scan-hint {
    margin-top: .6rem;
    font-size: .75rem;
    color: var(--color-muted);
}

/* Výsledkový panel */
.scan-result {
    border: 2px solid var(--color-black);
    background: var(--color-white);
    margin-bottom: 0;
}

.scan-result-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: .75rem;
    padding: .85rem 1.1rem;
    border-bottom: 1px solid var(--color-border);
    background: #f8f8f8;
}

.scan-result-title {
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--color-muted);
}

.scan-result-body {
    padding: 1.1rem;
}

/* Chybový stav */
.scan-result--error {
    border-color: var(--color-black);
    background: #fafafa;
}

.scan-result--error .scan-result-header {
    background: var(--color-black);
}

.scan-result--error .scan-result-title {
    color: var(--color-white);
}

/* Zvýraznění počtu balíků ve výsledku */
.scan-pkg-count {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    background: var(--color-black);
    color: var(--color-white);
    padding: .35rem .8rem;
    font-weight: 700;
    font-size: .95rem;
}

/* Log tabulka — animate-in pro nové řádky */
@keyframes rowIn {
    from { background: #e8e8e8; }
    to   { background: transparent; }
}

.scan-log-new {
    animation: rowIn 1.5s ease-out forwards;
}

/* Scan result badges */
.scan-ok   { color: #1a1a1a; font-weight: 700; }
.scan-err  { color: #555;    font-weight: 600; font-style: italic; }


/* ============================================================
   CONTROLLING DOBÍREK — platební badges + stavy
   ============================================================ */

/* Způsob platby */
.pay-badge {
    display: inline-block;
    padding: .2rem .55rem;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .03em;
    text-transform: uppercase;
}

.pay-cash {
    background: var(--color-black);
    color: var(--color-white);
}

.pay-card {
    background: var(--color-white);
    color: var(--color-black);
    border: 1.5px solid var(--color-black);
}

/* COD status */
.cod-status {
    display: inline-block;
    padding: .2rem .55rem;
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: .02em;
}

.cod-status--pending {
    background: #fff8e1;
    color: #555;
    border: 1px solid #d0c070;
    font-style: italic;
}

/* Čeká na převod — B&W varianta */
.cod-status--pending {
    background: #f5f5f5;
    color: #333;
    border: 1.5px solid var(--color-black);
    font-style: italic;
}

.cod-status--done {
    background: #f0f0f0;
    color: #666;
    border: 1px solid #ccc;
}


/* ============================================================
   FINANCE A VYÚČTOVÁNÍ
   ============================================================ */

/* Filtr období */
.period-filter {
    background: #f8f8f8;
    border: 1px solid var(--color-border);
    padding: .9rem 1.1rem;
}

.period-filter-label {
    font-size: .68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--color-muted);
    margin-bottom: .5rem;
}

.preset-btn {
    font-size: .75rem;
}

/* Bilanční panel */
.balance-panel {
    border: 2px solid var(--color-black);
    background: var(--color-white);
}

.balance-panel-title {
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--color-muted);
    padding: .7rem 1.1rem;
    background: #f8f8f8;
    border-bottom: 1px solid var(--color-border);
}

.balance-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: .5rem;
    padding: .8rem 1.1rem;
    border-bottom: 1px solid var(--color-border);
}

.balance-row:last-child { border-bottom: none; }

.balance-row-label {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: .5rem;
    font-size: .88rem;
}

.bal-indicator {
    font-size: .62rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--color-muted);
    flex-shrink: 0;
    min-width: 4.2rem;
}

.balance-row--result .bal-indicator {
    color: rgba(255,255,255,.55);
}

.balance-row-note {
    font-size: .75rem;
    color: var(--color-muted);
}

.balance-row-value {
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-black);
    white-space: nowrap;
}

.balance-row--plus .balance-row-value { color: #1a1a1a; }
.balance-row--minus .balance-row-value { color: #666; }

.balance-divider {
    height: 2px;
    background: var(--color-black);
    margin: 0;
}

/* Výsledný řádek */
.balance-row--result {
    background: var(--color-black);
    color: var(--color-white);
    border-bottom: none;
}

.balance-row--result .balance-row-label { color: var(--color-white); }
.balance-row--result .balance-row-note { color: #aaa; }

.balance-row-value--result {
    font-size: 1.4rem;
    font-weight: 800;
    letter-spacing: -.03em;
    color: var(--color-white);
}

/* Finance — loading stav */
.finance-is-loading {
    opacity: 0.35;
    pointer-events: none;
    transition: opacity .15s;
}

/* Směr převodu badge */
.balance-direction-badge {
    display: inline-flex;
    align-items: center;
    background: rgba(255,255,255,.15);
    border: 1px solid rgba(255,255,255,.3);
    color: #ddd;
    font-size: .72rem;
    font-weight: 600;
    padding: .15rem .55rem;
    letter-spacing: .04em;
}

/* Transaction type badges */
.tx-badge {
    display: inline-block;
    padding: .15rem .5rem;
    font-size: .7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .03em;
}

.tx-cod {
    background: var(--color-black);
    color: var(--color-white);
}

.tx-commission {
    background: var(--color-white);
    color: #666;
    border: 1px solid #ccc;
}

/* Pokyn k převodu */
.transfer-notice {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    background: #f8f8f8;
    border: 1px solid var(--color-border);
    border-left: 4px solid var(--color-black);
    padding: 1rem 1.1rem;
}

.transfer-notice-icon {
    font-size: 1.5rem;
    color: #555;
    flex-shrink: 0;
    padding-top: .1rem;
}


/* ============================================================
   MOBILNÍ RESPONZIVITA — 400px a méně
   ============================================================ */

/* ---- Karta místo tabulky na xs ---- */
@media (max-width: 575px) {

    /* Hlavička tabulky se skryje */
    .table-mobile-cards thead { display: none; }

    /* Každý tbody řádek = karta */
    .table-mobile-cards tbody tr {
        display: block;
        border: 1px solid var(--color-border);
        margin-bottom: .6rem;
        background: var(--color-white);
    }

    .table-mobile-cards tbody tr:last-child { margin-bottom: 0; }

    /* Každá buňka = flex řádek label | hodnota */
    .table-mobile-cards tbody td {
        display: flex !important;   /* přepisuje Bootstrap d-none */
        align-items: flex-start;
        gap: .4rem;
        padding: .42rem .7rem;
        border-bottom: 1px solid #f0f0f0;
        border-top: none !important;
        border-left: none !important;
        font-size: .84rem;
        text-align: left !important;
    }

    .table-mobile-cards tbody td:last-child { border-bottom: none; }

    /* Štítek z data-label */
    .table-mobile-cards td::before {
        content: attr(data-label);
        min-width: 5.5rem;
        flex-shrink: 0;
        font-size: .65rem;
        font-weight: 700;
        text-transform: uppercase;
        letter-spacing: .05em;
        color: #aaa;
        padding-top: .18rem;
        line-height: 1.4;
    }

    .table-mobile-cards td[data-label=""]::before { display: none; }

    /* Overdue karta — horní červený border */
    .table-mobile-cards tbody tr.row-overdue {
        border-top: 3px solid var(--color-black);
    }

    /* tfoot — zůstane jako řádek přes celou šířku */
    .table-mobile-cards tfoot tr {
        display: flex;
        justify-content: space-between;
        padding: .5rem .7rem;
        background: var(--color-black);
    }

    .table-mobile-cards tfoot td {
        display: block !important;
        border: none !important;
        padding: 0 !important;
        font-size: .82rem;
        color: var(--color-white) !important;
        background: transparent !important;
    }

    /* Prázdné tfoot buňky (colspan zbytky) skryj */
    .table-mobile-cards tfoot td:empty { display: none !important; }

    /* Bez horizontálního scrollu, tabulka má plnou šířku */
    .table-responsive {
        overflow-x: visible;
    }

    .table-mobile-cards {
        min-width: 0;
        width: 100%;
    }
}


/* ---- Životní cyklus — vertikální layout na mobilu ---- */
@media (max-width: 575px) {

    .lc-track {
        flex-direction: column;
        align-items: flex-start;
        padding: .5rem 0;
        overflow-x: visible;
    }

    .lc-step {
        flex-direction: row;
        text-align: left;
        min-width: unset;
        width: 100%;
        align-items: center;
        gap: .85rem;
    }

    .lc-icon {
        margin-bottom: 0;
        flex-shrink: 0;
        width: 42px;
        height: 42px;
        font-size: 1.1rem;
    }

    .lc-label { font-size: .82rem; }
    .lc-sub   { font-size: .7rem; }

    .lc-line {
        width: 2px;
        height: 20px;
        min-width: unset;
        margin-bottom: 0;
        margin-left: 20px; /* zarovnání se středem .lc-icon */
        flex-shrink: 0;
    }

    /* Alt karty pod sebou */
    .lc-alt-card { margin-bottom: .5rem; }

    /* Action panel — tlačítka pod sebou */
    .lc-action-panel .d-flex.flex-wrap { gap: .5rem; }
    .lc-action-panel .btn { width: 100%; }
}


/* ---- Filtr období — na mobilu pod sebou ---- */
@media (max-width: 575px) {

    .period-filter > .d-flex {
        flex-direction: column;
        align-items: stretch !important;
        gap: .5rem !important;
    }

    .period-filter input[type="date"] {
        width: 100%;
    }

    /* Preset tlačítka jako grid */
    .period-filter .d-flex.gap-1 {
        display: grid !important;
        grid-template-columns: 1fr 1fr 1fr;
        gap: .3rem !important;
        margin-left: 0 !important;
    }
}


/* ---- Scan area — mobilní úpravy ---- */
@media (max-width: 575px) {

    .scan-area { padding: 1rem; }

    .scan-input-wrap { flex-direction: column; gap: 0; }

    .scan-input {
        border-right: 2px solid var(--color-black);
        border-bottom: none;
        padding: .75rem 1rem .75rem 2.75rem;
        font-size: 1rem;
        width: 100%;
    }

    .scan-submit-btn {
        width: 100%;
        text-align: center;
        border-top: none;
        padding: .65rem;
    }

    .scan-input-icon { top: 1rem; transform: none; }

    /* inner-card-header s tlačítkem */
    .inner-card-header {
        display: flex;
        align-items: center;
    }
}


/* ---- Hlavní layout — sekce plnou šířkou ---- */
@media (max-width: 575px) {

    .main-content { padding: .75rem; }

    .content-section { padding: 1rem .9rem; }

    /* Bilanční panel — hodnota pod labelem */
    .balance-row {
        flex-direction: column;
        align-items: flex-start;
        gap: .35rem;
    }

    .balance-row--result .balance-row-value--result {
        font-size: 1.25rem;
    }

    /* Detail bloky */
    .detail-block { padding: 1rem .9rem; }

    /* Přehled stavů — wrap */
    .d-flex.flex-wrap.gap-2 { gap: .35rem !important; }

    /* Tlačítka exportu v sekci finance */
    .section-header .d-flex.gap-2 {
        flex-direction: column;
        width: 100%;
    }

    .section-header .d-flex.gap-2 .btn {
        width: 100%;
    }
}


/* ---- Stat karty — menší hodnoty na mobilu ---- */
@media (max-width: 575px) {

    .stat-value {
        font-size: 1.35rem;
        letter-spacing: -.03em;
    }

    .stat-bg-icon {
        font-size: 2rem;
        right: .6rem;
        color: #f0f0f0;
    }

    .stat-card--inverted .stat-bg-icon {
        color: #222;
    }
}
