/* ============================================================================
 * lib/css/app.css — GATT design system v2 (Linear/Stripe hybrid)
 *
 * Această versiune REPLACE-uiește app.css din slice 1. Schimbări majore:
 *   - Sistem de variabile CSS (paletă, spacing, radius, shadow)
 *   - Paletă status semantică pentru cele 10 stări R2 (mapate la 4 categorii)
 *   - Cards cu shadow soft, border subtil 0.5px
 *   - Tabele cu noul stil (rânduri cu separator orizontal, fără borduri verticale)
 *   - Butoane cu ierarhie (primary = negru, outline-secondary)
 *   - Container 80% default (override per pagină prin --gatt-container-max)
 *   - DataTables override pentru aspect modern
 *   - Backward-compat: păstrăm clasele vechi `.s-editabil`, `.s-descarcare`, etc.
 *   - Tabler Icons + Chart.js prezente în /lib/vendor/
 * ========================================================================= */

/* ============================================================================
 * 1. CSS Variables (single source of truth pentru tot designul)
 * ========================================================================= */
:root {
    /* --- Layout --- */
    --gatt-container-max: 80%;
    --gatt-container-pad: 1.25rem;

    /* --- Tipografie --- */
    --gatt-font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    --gatt-font-mono: ui-monospace, SFMono-Regular, "SF Mono", Consolas, "Liberation Mono", Menlo, monospace;
    --gatt-fs-xs: 11px;
    --gatt-fs-sm: 12px;
    --gatt-fs-base: 14px;
    --gatt-fs-lg: 16px;
    --gatt-fs-xl: 22px;
    --gatt-fs-h1: 22px;
    --gatt-fs-h2: 18px;
    --gatt-fs-h3: 16px;

    /* --- Spațiere --- */
    --gatt-radius-sm: 4px;
    --gatt-radius-md: 8px;
    --gatt-radius-lg: 12px;
    --gatt-radius-xl: 16px;

    /* --- Culori bază (light mode) — paletă cu tentă albastră (mai puțin obositor decât alb pur) --- */
    --gatt-bg-page: #D5DBE3;       /* body: gri-albastru deschis (contrast clar cu cards-uri albe) */
    --gatt-bg-card: #FFFFFF;       /* cards: alb pur (contrast cu body) */
    --gatt-bg-secondary: #F1F5FA;  /* table thead, hover: albastru foarte pal */
    --gatt-bg-tertiary: #DDE7F1;   /* surface mai închis pentru contraste */
    --gatt-text-primary: #000000;
    --gatt-text-secondary: #1a1a1a;
    --gatt-text-tertiary: #5F5E5A;
    --gatt-border-subtle: rgba(24, 95, 165, 0.10);   /* border albastru subtil */
    --gatt-border-default: rgba(24, 95, 165, 0.16);
    --gatt-border-strong: rgba(24, 95, 165, 0.25);

    /* --- Accent (acțiuni primare) — albastru în loc de negru --- */
    --gatt-accent-primary: #185fa5;        /* btn-primary: albastru mediu */
    --gatt-accent-primary-hover: #0c447c;  /* hover: albastru închis */
    --gatt-accent-info: #378add;           /* informative: albastru mediu-deschis */
    --gatt-accent-info-bg: #e6f1fb;        /* bg pastel pentru info */

    /* --- Shadow --- */
    --gatt-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.04), 0 1px 3px rgba(0, 0, 0, 0.06);
    --gatt-shadow-md: 0 2px 4px rgba(0, 0, 0, 0.05), 0 4px 8px rgba(0, 0, 0, 0.04);

    /* --- Status palette (mapată la cele 10 stări R2) --- */
    --gatt-status-amber-bg: #faeeda;
    --gatt-status-amber-fg: #854f0b;
    --gatt-status-amber-strong-bg: #fac775;
    --gatt-status-amber-strong-fg: #633806;

    --gatt-status-blue-bg: #e6f1fb;
    --gatt-status-blue-fg: #0c447c;
    --gatt-status-blue-strong-bg: #b5d4f4;
    --gatt-status-blue-strong-fg: #042c53;

    --gatt-status-purple-bg: #eeedfe;
    --gatt-status-purple-fg: #3c3489;
    --gatt-status-purple-strong-bg: #cecbf6;
    --gatt-status-purple-strong-fg: #26215c;

    --gatt-status-teal-bg: #e1f5ee;
    --gatt-status-teal-fg: #085041;

    --gatt-status-green-bg: #c0dd97;
    --gatt-status-green-fg: #173404;

    --gatt-status-gray-bg: #ecebe6;
    --gatt-status-gray-fg: #444441;
}

/* ============================================================================
 * 2. Reset minimal + body
 * ========================================================================= */
html, body {
    background: var(--gatt-bg-page);
    color: var(--gatt-text-primary);
    font-family: var(--gatt-font-sans);
    font-size: var(--gatt-fs-base);
    line-height: 1.5;
}

main {
    /* Override Bootstrap container-fluid → container 80% (sau override per pagină) */
    max-width: var(--gatt-container-max) !important;
    margin: 0 auto;
    padding: 1.5rem var(--gatt-container-pad);
}

h1 { font-size: var(--gatt-fs-h1); font-weight: 500; }
h2 { font-size: var(--gatt-fs-h2); font-weight: 500; }
h3 { font-size: var(--gatt-fs-h3); font-weight: 500; }

a { color: var(--gatt-accent-info); text-decoration: none; }
a:hover { text-decoration: underline; }

.text-mono, .gatt-mono { font-family: var(--gatt-font-mono); }
.text-secondary, .gatt-text-secondary { color: var(--gatt-text-secondary) !important; }
.text-tertiary, .gatt-text-tertiary { color: var(--gatt-text-tertiary) !important; }

/* Eyebrow label (folosit deasupra titlurilor în carduri) */
.gatt-eyebrow {
    font-size: var(--gatt-fs-xs);
    color: var(--gatt-text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-weight: 500;
    margin-bottom: 0.25rem;
}

/* ============================================================================
 * 3. Navbar — albă curată cu border subtil
 * ========================================================================= */
nav.navbar.bg-primary,
nav.navbar.navbar-dark {
    background: var(--gatt-bg-card) !important;
    border-bottom: 1px solid var(--gatt-border-subtle);
    box-shadow: 0 1px 0 var(--gatt-border-subtle);
    padding: 0.5rem 1rem;
}

nav.navbar .navbar-brand {
    color: var(--gatt-text-primary) !important;
    font-weight: 500;
    letter-spacing: 0.02em;
}

nav.navbar .nav-link,
nav.navbar .navbar-text {
    color: var(--gatt-text-secondary) !important;
    font-size: var(--gatt-fs-base);
}
nav.navbar .nav-link:hover,
nav.navbar .nav-link.active {
    color: var(--gatt-text-primary) !important;
}
nav.navbar .nav-link.active {
    font-weight: 500;
}

nav.navbar .navbar-text small.text-white-50 {
    color: var(--gatt-text-tertiary) !important;
}

nav.navbar .btn-outline-light {
    color: var(--gatt-text-secondary);
    border-color: var(--gatt-border-default);
}
nav.navbar .btn-outline-light:hover {
    color: var(--gatt-text-primary);
    background: var(--gatt-bg-secondary);
    border-color: var(--gatt-border-strong);
}

nav.navbar .navbar-toggler {
    border-color: var(--gatt-border-default);
}

nav.navbar .dropdown-menu {
    border: 1px solid var(--gatt-border-subtle);
    box-shadow: var(--gatt-shadow-md);
    border-radius: var(--gatt-radius-md);
    padding: 0.4rem 0;
    margin-top: 0.25rem;
}
nav.navbar .dropdown-menu .dropdown-item {
    font-size: var(--gatt-fs-base);
    padding: 0.45rem 1rem;
}
nav.navbar .dropdown-menu .dropdown-header {
    font-size: var(--gatt-fs-xs);
    color: var(--gatt-text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-weight: 500;
    padding: 0.5rem 1rem 0.25rem;
}
nav.navbar .dropdown-divider {
    border-top: 1px solid var(--gatt-border-subtle);
    margin: 0.3rem 0;
}

/* ============================================================================
 * 4. Card / Box generic
 * ========================================================================= */
.card,
.gatt-card {
    background: var(--gatt-bg-card);
    border: 1px solid var(--gatt-border-subtle);
    border-radius: var(--gatt-radius-lg);
    box-shadow: var(--gatt-shadow-sm);
    margin-bottom: 1rem;
}

.card.shadow-sm,
.card.shadow {
    box-shadow: var(--gatt-shadow-sm) !important;
}

.card-body {
    padding: 1.25rem;
}

.card-title {
    font-size: var(--gatt-fs-h2);
    font-weight: 500;
    margin-bottom: 0.5rem;
}

/* Container box mai mare pentru pagini care au nevoie (index.php = 90%) */
main.gatt-wide {
    --gatt-container-max: 90%;
}

/* ============================================================================
 * 5. Tabel — stil modern (zebra subtilă, fără borduri verticale)
 * ========================================================================= */
table.table,
table.dataTable {
    background: transparent;
    border-collapse: collapse;
    margin-bottom: 0;
}

table.table thead th,
table.dataTable thead th {
    background: var(--gatt-bg-secondary) !important;
    color: var(--gatt-text-tertiary) !important;
    font-size: var(--gatt-fs-xs);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    padding: 0.5rem 0.6rem !important;
    border-bottom: 1px solid var(--gatt-border-default) !important;
    border-top: none !important;
    white-space: nowrap;
    text-align: left;
    vertical-align: middle;
}

table.table tbody tr,
table.dataTable tbody tr {
    border-bottom: 1px solid var(--gatt-border-subtle);
}

table.table tbody td,
table.dataTable tbody td {
    padding: 0.55rem 0.6rem !important;
    font-size: var(--gatt-fs-base);
    border: none !important;
    vertical-align: middle;
}

table.table tbody tr:hover,
table.dataTable tbody tr:hover {
    background: var(--gatt-bg-secondary);
}

table.table-striped tbody tr:nth-of-type(odd) {
    background: transparent;
}

/* Tabel compact (folosit în liste lungi) */
.table-compact th,
.table-compact td {
    padding: 0.35rem 0.5rem !important;
    font-size: var(--gatt-fs-sm);
}

/* Filter row în thead (al doilea row cu input-uri) */
table.table thead tr.gatt-filters th,
table.dataTable thead tr.gatt-filters th {
    background: var(--gatt-bg-card) !important;
    padding: 0.3rem 0.4rem !important;
    text-transform: none;
    letter-spacing: 0;
}
table.table thead tr.gatt-filters input,
table.table thead tr.gatt-filters select,
table.dataTable thead tr.gatt-filters input,
table.dataTable thead tr.gatt-filters select {
    width: 100%;
    height: 28px;
    font-size: var(--gatt-fs-xs);
    padding: 2px 6px;
    border: 1px solid var(--gatt-border-default);
    border-radius: var(--gatt-radius-sm);
    background: #fff;
}

/* Sticky thead pentru tabele cu scroll */
.gatt-scroll-table {
    max-height: 60vh;
    overflow-y: auto;
    border: 1px solid var(--gatt-border-subtle);
    border-radius: var(--gatt-radius-md);
}
.gatt-scroll-table thead {
    position: sticky;
    top: 0;
    z-index: 5;
}

/* Coloane mono pentru ID-uri (R2, container, AWB, etc.) */
.col-mono {
    font-family: var(--gatt-font-mono);
    font-size: var(--gatt-fs-sm);
}

/* Rânduri clickabile */
tr.row-link { cursor: pointer; }

/* ============================================================================
 * 6. DataTables — overrides pentru noul stil
 * ========================================================================= */
.dataTables_wrapper {
    font-size: var(--gatt-fs-base);
}
.dataTables_wrapper .dataTables_filter input {
    height: 32px;
    font-size: var(--gatt-fs-base);
    padding: 4px 10px;
    border: 1px solid var(--gatt-border-default);
    border-radius: var(--gatt-radius-sm);
    margin-left: 0.5rem;
}
.dataTables_wrapper .dataTables_length select {
    height: 32px;
    font-size: var(--gatt-fs-base);
    padding: 4px 8px;
    border: 1px solid var(--gatt-border-default);
    border-radius: var(--gatt-radius-sm);
}
.dataTables_wrapper .dataTables_info,
.dataTables_wrapper .dataTables_paginate {
    color: var(--gatt-text-secondary);
    font-size: var(--gatt-fs-sm);
    padding-top: 0.75rem;
}
.dataTables_wrapper .dataTables_paginate .paginate_button {
    border-radius: var(--gatt-radius-sm) !important;
    border: 1px solid var(--gatt-border-subtle) !important;
}
.dataTables_wrapper .dataTables_paginate .paginate_button.current {
    background: var(--gatt-accent-primary) !important;
    color: #fff !important;
    border-color: var(--gatt-accent-primary) !important;
}

/* ============================================================================
 * 7. Butoane — ierarhie (primary = negru, outline = transparent)
 * ========================================================================= */
.btn {
    border-radius: var(--gatt-radius-md);
    font-size: var(--gatt-fs-base);
    font-weight: 500;
    padding: 0.4rem 0.9rem;
    border: 1px solid transparent;
    transition: all 0.15s ease;
    line-height: 1.4;
}
.btn:focus, .btn:focus-visible {
    box-shadow: 0 0 0 3px rgba(24, 95, 165, 0.2);
}

.btn-primary {
    background: var(--gatt-accent-primary);
    color: #fff;
    border-color: var(--gatt-accent-primary);
}
.btn-primary:hover {
    background: var(--gatt-accent-primary-hover);
    color: #fff;
    border-color: var(--gatt-accent-primary-hover);
}

.btn-outline-primary {
    color: var(--gatt-text-primary);
    background: transparent;
    border-color: var(--gatt-border-default);
}
.btn-outline-primary:hover {
    color: var(--gatt-text-primary);
    background: var(--gatt-bg-secondary);
    border-color: var(--gatt-border-strong);
}

.btn-outline-secondary {
    color: var(--gatt-text-secondary);
    background: transparent;
    border-color: var(--gatt-border-default);
}
.btn-outline-secondary:hover {
    color: var(--gatt-text-primary);
    background: var(--gatt-bg-secondary);
    border-color: var(--gatt-border-strong);
}

.btn-outline-danger {
    color: #a32d2d;
    background: transparent;
    border-color: var(--gatt-border-default);
}
.btn-outline-danger:hover {
    color: #fff;
    background: #a32d2d;
    border-color: #a32d2d;
}

.btn-success {
    background: #3b6d11;
    color: #fff;
    border-color: #3b6d11;
}
.btn-success:hover {
    background: #27500a;
    color: #fff;
    border-color: #27500a;
}

.btn-warning {
    background: var(--gatt-status-amber-strong-bg);
    color: var(--gatt-status-amber-strong-fg);
    border-color: var(--gatt-status-amber-strong-bg);
}
.btn-warning:hover {
    background: #ef9f27;
    color: var(--gatt-status-amber-strong-fg);
    border-color: #ef9f27;
}

.btn-sm { font-size: var(--gatt-fs-sm); padding: 0.3rem 0.7rem; }
.btn-xs { font-size: var(--gatt-fs-xs); padding: 0.2rem 0.55rem; }

/* ============================================================================
 * 8. Form-uri — input, select, textarea
 * ========================================================================= */
.form-control,
.form-select {
    border: 1px solid var(--gatt-border-default);
    border-radius: var(--gatt-radius-sm);
    font-size: var(--gatt-fs-base);
    padding: 0.4rem 0.65rem;
    background: var(--gatt-bg-card);
    color: var(--gatt-text-primary);
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.form-control:focus,
.form-select:focus {
    border-color: var(--gatt-accent-info);
    box-shadow: 0 0 0 3px rgba(24, 95, 165, 0.15);
    outline: none;
}

.form-label {
    font-size: var(--gatt-fs-sm);
    font-weight: 500;
    color: var(--gatt-text-secondary);
    margin-bottom: 0.25rem;
}

.form-text {
    font-size: var(--gatt-fs-xs);
    color: var(--gatt-text-tertiary);
}

.form-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 0.75rem 1rem;
}

/* Form-uri cu spațiere consistentă */
.form-section {
    background: var(--gatt-bg-secondary);
    border-radius: var(--gatt-radius-md);
    padding: 1rem 1.25rem;
    margin-bottom: 1rem;
}

/* ============================================================================
 * 9. Status badges — paletă semantică pentru cele 10 stări R2
 *
 * Mapare:
 *   .s-editabil                       → amber (în lucru la firmă)
 *   .s-solicitare-r2                  → blue (la vamă)
 *   .s-atribuire-r2                   → blue strong (pas următor)
 *   .s-asteapta-liber-de-vama         → blue (așteaptă vamă)
 *   .s-asteapta-liber-de-vama-pe-roti → blue (variantă pe roți)
 *   .s-incepe-descarcarea             → purple (start descărcare)
 *   .s-descarcare                     → purple strong (descărcare activă)
 *   .s-descarcare-incheiata           → teal (success intermediar)
 *   .s-marfa-vamuita-partial          → amber strong (atenție, parțial)
 *   .s-marfa-in-libera-circulatie     → green (final, totul ok)
 * ========================================================================= */
.status-badge {
    display: inline-block;
    padding: 3px 8px;
    font-size: var(--gatt-fs-xs);
    font-weight: 500;
    line-height: 1.4;
    white-space: nowrap;
    border-radius: var(--gatt-radius-md);
    text-align: center;
    min-width: 0;
    border: none;
}

/* În lucru la firmă (galben pal) */
.status-badge.s-editabil {
    background: var(--gatt-status-amber-bg);
    color: var(--gatt-status-amber-fg);
}

/* La vamă - așteaptă (albastru) */
.status-badge.s-solicitare-r2,
.status-badge.s-solicitare-ds,
.status-badge.s-confirmare-depozit,
.status-badge.s-asteapta-liber-de-vama,
.status-badge.s-liber-de-vama,
.status-badge.s-asteapta-liber-de-vama-pe-roti,
.status-badge.s-liber-de-vama-pe-roti {
    background: var(--gatt-status-blue-bg);
    color: var(--gatt-status-blue-fg);
}

/* Atribuire R2 (albastru pronunțat) */
.status-badge.s-atribuire-r2,
.status-badge.s-atribuire-ds,
.status-badge.s-r2-in-curs-validare {
    background: var(--gatt-status-blue-strong-bg);
    color: var(--gatt-status-blue-strong-fg);
}

/* Operațional descărcare (violet) */
.status-badge.s-incepe-descarcarea,
.status-badge.s-modificare-date {
    background: var(--gatt-status-purple-bg);
    color: var(--gatt-status-purple-fg);
}

.status-badge.s-descarcare {
    background: var(--gatt-status-purple-strong-bg);
    color: var(--gatt-status-purple-strong-fg);
}

/* Descărcare încheiată (teal) */
.status-badge.s-descarcare-incheiata,
.status-badge.s-validare-vama {
    background: var(--gatt-status-teal-bg);
    color: var(--gatt-status-teal-fg);
}

/* Final cu atenție (amber strong) */
.status-badge.s-marfa-vamuita-partial,
.status-badge.s-vamuita-partial {
    background: var(--gatt-status-amber-strong-bg);
    color: var(--gatt-status-amber-strong-fg);
}

/* Final OK (verde) */
.status-badge.s-marfa-in-libera-circulatie,
.status-badge.s-libera-circulatie,
.status-badge.s-livrare {
    background: var(--gatt-status-green-bg);
    color: var(--gatt-status-green-fg);
}

/* Roșu — cazuri speciale legacy */
.status-badge.s-solicitare-r2-pe-roti,
.status-badge.s-inchis {
    background: var(--gatt-status-blue-strong-bg);
    color: var(--gatt-status-blue-strong-fg);
}

/* Default pentru stări necunoscute */
.status-badge.s-default {
    background: var(--gatt-status-gray-bg);
    color: var(--gatt-status-gray-fg);
}

/* ============================================================================
 * 10. KPI cards (pentru Box 3 din index.php — sumar luna)
 * ========================================================================= */
.gatt-kpi {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}
.gatt-kpi-label {
    font-size: var(--gatt-fs-xs);
    color: var(--gatt-text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-weight: 500;
}
.gatt-kpi-value {
    font-size: 24px;
    font-weight: 500;
    color: var(--gatt-text-primary);
    line-height: 1.2;
}
.gatt-kpi-sub {
    font-size: var(--gatt-fs-xs);
    color: var(--gatt-text-secondary);
    font-weight: 400;
    margin-left: 0.4rem;
}

/* Container chart */
.gatt-chart-wrap {
    position: relative;
    height: 120px;
    margin-top: 0.5rem;
}

/* Grid pentru cele 3 chart-uri în Box 3 */
.gatt-chart-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
}
@media (max-width: 768px) {
    .gatt-chart-grid {
        grid-template-columns: 1fr;
        gap: 1rem;
    }
}

/* ============================================================================
 * 11. Alertele — folosite și de header.php pentru flash messages
 * ========================================================================= */
.alert {
    border-radius: var(--gatt-radius-md);
    border: 1px solid transparent;
    padding: 0.7rem 1rem;
    font-size: var(--gatt-fs-base);
    margin-bottom: 1rem;
}
.alert-success {
    background: var(--gatt-status-green-bg);
    color: var(--gatt-status-green-fg);
    border-color: rgba(99, 153, 34, 0.3);
}
.alert-warning {
    background: var(--gatt-status-amber-bg);
    color: var(--gatt-status-amber-fg);
    border-color: rgba(186, 117, 23, 0.3);
}
.alert-danger {
    background: #fcebeb;
    color: #791f1f;
    border-color: rgba(163, 45, 45, 0.3);
}
.alert-info {
    background: var(--gatt-status-blue-bg);
    color: var(--gatt-status-blue-fg);
    border-color: rgba(24, 95, 165, 0.3);
}
.alert .btn-close {
    filter: opacity(0.5);
}

/* ============================================================================
 * 12. Login page
 * ========================================================================= */
body.page-login {
    background: var(--gatt-bg-page);
}
.login-card {
    max-width: 420px;
    margin: 4rem auto;
    border-radius: var(--gatt-radius-lg);
    box-shadow: var(--gatt-shadow-md);
}
.login-card .card-body {
    padding: 2rem;
}

/* ============================================================================
 * 13. Module cards (home.php)
 * ========================================================================= */
.module-card {
    transition: transform 0.12s ease, box-shadow 0.12s ease, border-color 0.12s ease;
    border: 1px solid var(--gatt-border-subtle);
    border-radius: var(--gatt-radius-lg);
}
.module-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--gatt-shadow-md);
    border-color: var(--gatt-border-default);
}
.module-card .card-body {
    padding: 1.25rem;
}
.module-card-icon {
    width: 44px;
    height: 44px;
    border-radius: var(--gatt-radius-md);
    background: var(--gatt-status-blue-bg);
    color: var(--gatt-status-blue-fg);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    margin-bottom: 0.75rem;
}

/* ============================================================================
 * 14. Polling indicator (păstrat din slice 1)
 * ========================================================================= */
.poll-indicator {
    display: inline-block;
    padding: 3px 10px;
    font-size: var(--gatt-fs-xs);
    border-radius: 999px;
    background: var(--gatt-status-gray-bg);
    color: var(--gatt-status-gray-fg);
    vertical-align: middle;
    transition: background 0.3s, color 0.3s;
}
.poll-indicator.poll-loading {
    background: var(--gatt-status-blue-bg);
    color: var(--gatt-status-blue-fg);
}
.poll-indicator.poll-loading::before {
    content: "";
    display: inline-block;
    width: 0.6em;
    height: 0.6em;
    margin-right: 0.4em;
    border: 1.5px solid currentColor;
    border-top-color: transparent;
    border-radius: 50%;
    vertical-align: -0.05em;
    animation: poll-spin 0.7s linear infinite;
}
.poll-indicator.poll-ok {
    background: var(--gatt-status-teal-bg);
    color: var(--gatt-status-teal-fg);
}
.poll-indicator.poll-error {
    background: #fcebeb;
    color: #791f1f;
}
@keyframes poll-spin { to { transform: rotate(360deg); } }

/* Row flash — evidențiere rânduri schimbate în polling */
@keyframes row-flash {
    0%   { background-color: var(--gatt-status-amber-bg); }
    100% { background-color: transparent; }
}
tr.row-changed > td { animation: row-flash 3s ease-out 1; }
tr.row-new > td {
    animation: row-flash 3s ease-out 1;
    font-weight: 500;
}

/* ============================================================================
 * 15. Iconuri (Tabler) — utility
 * ========================================================================= */
.ti {
    vertical-align: -2px;
    line-height: 1;
}
.btn .ti { margin-right: 4px; font-size: 1.1em; }
.btn .ti:only-child { margin-right: 0; }

/* ============================================================================
 * 16. Print
 * ========================================================================= */
@media print {
    nav.navbar,
    footer,
    .no-print,
    .btn,
    form.d-inline { display: none !important; }
    body { background: #fff; }
    main { padding: 0 !important; max-width: 100% !important; }
    .card { box-shadow: none !important; border: 1px solid #ccc; }
}

/* ============================================================================
 * 17. Utility classes
 * ========================================================================= */
.gatt-truncate {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    display: block;
}
.gatt-divider {
    border: none;
    border-top: 1px solid var(--gatt-border-subtle);
    margin: 1rem 0;
}
.gatt-empty-state {
    text-align: center;
    padding: 1.5rem;
    color: var(--gatt-text-secondary);
    font-size: var(--gatt-fs-sm);
}
.gatt-empty-state .ti {
    display: block;
    margin: 0 auto 0.4rem;
    font-size: 28px;
    color: var(--gatt-text-tertiary);
}

/* ============================================================================
 * BLUE PATCH — paletă cu nuanțe diverse de albastru pe nav, butoane, tabel
 * Adăugat în iterația 2 după feedback „totul e prea alb și obositor".
 * ========================================================================= */

/* --- Navbar Bootstrap (.navbar.bg-primary) cu albastru bogat (gradient subtil) --- */
.navbar.bg-primary {
    background: linear-gradient(180deg, #185FA5 0%, #0C447C 100%) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 2px 4px rgba(12, 68, 124, 0.12);
}
.navbar.bg-primary .navbar-brand {
    color: #ffffff;
    font-weight: 600;
    letter-spacing: 0.02em;
}
.navbar.bg-primary .nav-link {
    color: rgba(255, 255, 255, 0.85) !important;
    transition: background 0.15s, color 0.15s;
    border-radius: 6px;
    padding: 6px 12px !important;
    margin: 0 2px;
}
.navbar.bg-primary .nav-link:hover {
    background: rgba(255, 255, 255, 0.10);
    color: #ffffff !important;
}
.navbar.bg-primary .nav-link.active,
.navbar.bg-primary .nav-link.show {
    background: rgba(255, 255, 255, 0.16);
    color: #ffffff !important;
    font-weight: 500;
}
.navbar.bg-primary .navbar-toggler {
    border-color: rgba(255, 255, 255, 0.25);
}

/* --- Dropdown menu — colorat și clar --- */
.navbar .dropdown-menu {
    background: #FFFFFF;
    border: 1px solid #B5D4F4;
    border-radius: 8px;
    box-shadow: 0 6px 16px rgba(12, 68, 124, 0.12), 0 2px 4px rgba(12, 68, 124, 0.06);
    padding: 6px;
    margin-top: 4px;
}
.navbar .dropdown-header {
    color: #0C447C;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    padding: 8px 12px 4px;
}
.navbar .dropdown-item {
    border-radius: 6px;
    padding: 7px 12px;
    color: #1a1a1a;
    font-size: 13px;
    transition: background 0.1s, color 0.1s;
}
.navbar .dropdown-item:hover,
.navbar .dropdown-item:focus {
    background: #E6F1FB;
    color: #0C447C;
}
.navbar .dropdown-item.active,
.navbar .dropdown-item:active {
    background: #185FA5;
    color: #FFFFFF;
}
.navbar .dropdown-divider {
    margin: 4px 6px;
    border-color: rgba(24, 95, 165, 0.12);
}

/* --- Butoane: nuanțe diverse de albastru --- */

/* btn-primary — albastru solid (înlocuiește negrul) */
.btn-primary {
    background: #185FA5 !important;
    border-color: #185FA5 !important;
    color: #FFFFFF !important;
    box-shadow: 0 1px 2px rgba(12, 68, 124, 0.16);
}
.btn-primary:hover,
.btn-primary:focus {
    background: #0C447C !important;
    border-color: #0C447C !important;
    color: #FFFFFF !important;
    box-shadow: 0 2px 4px rgba(12, 68, 124, 0.24);
}
.btn-primary:active,
.btn-primary.active {
    background: #042C53 !important;
    border-color: #042C53 !important;
}

/* btn-secondary / btn-outline-secondary — outline albastru deschis cu hover */
.btn-secondary,
.btn-outline-secondary {
    background: #FFFFFF !important;
    color: #185FA5 !important;
    border: 1px solid #B5D4F4 !important;
}
.btn-secondary:hover,
.btn-outline-secondary:hover {
    background: #E6F1FB !important;
    color: #0C447C !important;
    border-color: #378ADD !important;
}

/* btn-outline-primary — accent albastru */
.btn-outline-primary {
    background: transparent !important;
    color: #185FA5 !important;
    border: 1px solid #185FA5 !important;
}
.btn-outline-primary:hover {
    background: #185FA5 !important;
    color: #FFFFFF !important;
}

/* btn-info — albastru mediu-deschis (acțiuni informative) */
.btn-info {
    background: #378ADD !important;
    color: #FFFFFF !important;
    border-color: #378ADD !important;
}
.btn-info:hover {
    background: #185FA5 !important;
    color: #FFFFFF !important;
    border-color: #185FA5 !important;
}

/* btn-light / .btn-default — albastru foarte pal (acțiuni neutre) */
.btn-light {
    background: #E6F1FB !important;
    color: #0C447C !important;
    border-color: #B5D4F4 !important;
}
.btn-light:hover {
    background: #B5D4F4 !important;
    color: #042C53 !important;
}

/* btn-success rămâne verde (semantica) */
/* btn-danger rămâne roșu (semantica) */

/* --- Cards — border subtil albastru (în loc de gri/negru) --- */
.card,
.gatt-card {
    border: 1px solid rgba(24, 95, 165, 0.10) !important;
    background: #FFFFFF;
}
.card:hover,
.gatt-card:hover {
    border-color: rgba(24, 95, 165, 0.18) !important;
}

/* --- Tabel: thead colorat, hover albastru --- */
table.dataTable thead tr,
.gatt-table-wrap thead tr,
table.gatt-table thead tr,
.table thead tr {
    background: #E6F1FB !important;
}
table.dataTable thead th,
.gatt-table-wrap thead th,
table.gatt-table thead th,
.table thead th {
    color: #0C447C !important;
    font-weight: 600;
    background: transparent !important;
    border-bottom: 1px solid rgba(24, 95, 165, 0.18) !important;
}
table.dataTable tbody tr:hover,
.gatt-table-wrap tbody tr:hover,
table.gatt-table tbody tr:hover,
.table tbody tr:hover {
    background: #F1F5FA !important;
}

/* Filter row în thead (al doilea rând cu inputs/selects) */
.gatt-table-wrap thead tr.filter-row,
.gatt-table-wrap thead tr.gatt-filters,
table.dataTable thead tr.gatt-filters {
    background: #FAFCFE !important;
}
.gatt-table-wrap thead tr.gatt-filters input,
.gatt-table-wrap thead tr.gatt-filters select,
table thead tr.gatt-filters input,
table thead tr.gatt-filters select {
    border: 1px solid rgba(24, 95, 165, 0.18);
    background: #FFFFFF;
    transition: border-color 0.15s, box-shadow 0.15s;
}
.gatt-table-wrap thead tr.gatt-filters input:focus,
.gatt-table-wrap thead tr.gatt-filters select:focus,
table thead tr.gatt-filters input:focus,
table thead tr.gatt-filters select:focus {
    border-color: #378ADD;
    outline: none;
    box-shadow: 0 0 0 2px rgba(55, 138, 221, 0.18);
}

/* --- Form controls — focus cu accent albastru --- */
.form-control:focus,
.form-select:focus,
input.form-control:focus,
select.form-select:focus,
textarea.form-control:focus {
    border-color: #378ADD !important;
    box-shadow: 0 0 0 3px rgba(55, 138, 221, 0.15) !important;
    outline: none;
}

/* --- Link-uri — albastru cu hover mai pronunțat --- */
a:not(.btn):not(.dropdown-item):not(.nav-link):not(.navbar-brand):not(.action-icon) {
    color: #185FA5;
}
a:not(.btn):not(.dropdown-item):not(.nav-link):not(.navbar-brand):not(.action-icon):hover {
    color: #0C447C;
}

/* --- Page title — separator albastru sub h1 --- */
.gatt-page-title h1,
main h1:first-child {
    border-bottom: 1px solid rgba(24, 95, 165, 0.10);
    padding-bottom: 8px;
}

/* --- Polling indicator (rămâne verde dar pe fundal albastru pal) --- */
.poll-indicator {
    background: #E6F1FB;
    color: #0C447C;
    border: 1px solid rgba(24, 95, 165, 0.12);
}

/* --- Footer pagină --- */
footer.text-center {
    color: #1a1a1a !important;
}

/* --- Ștergem ultimul rest de fundal alb pur pe elemente esențiale --- */
main.container-fluid {
    background: transparent;  /* să se vadă bg-page colorat în jurul cards */
}

/* === END BLUE PATCH === */

/* ============================================================================
 * NAVBAR FIX — selectori largi (pentru cazul când nav-ul nu are class .bg-primary)
 * Adăugat în iterația 3 după feedback „meniul e scris cu alb și nu se vede".
 * ========================================================================= */

/* Forțăm orice navbar de la nivel top să fie albastru cu text alb */
body > nav,
body > header,
nav.navbar,
header.gatt-header {
    background: linear-gradient(180deg, #185FA5 0%, #0C447C 100%) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
    box-shadow: 0 2px 4px rgba(12, 68, 124, 0.12) !important;
    padding: 10px 20px !important;
}

/* Brand (text „GATT") — alb */
body > nav .navbar-brand,
body > header .navbar-brand,
nav.navbar .navbar-brand,
header.gatt-header .navbar-brand,
header.gatt-header h1,
header.gatt-header .brand,
header.gatt-header > strong,
header.gatt-header > b {
    color: #FFFFFF !important;
    font-weight: 600 !important;
    text-decoration: none !important;
}

/* Nav links generale */
body > nav a:not(.dropdown-item):not(.btn),
body > header a:not(.dropdown-item):not(.btn),
nav.navbar a:not(.dropdown-item):not(.btn),
header.gatt-header a:not(.dropdown-item):not(.btn) {
    color: rgba(255, 255, 255, 0.88) !important;
    text-decoration: none !important;
    padding: 6px 12px !important;
    border-radius: 6px !important;
    transition: background 0.15s, color 0.15s !important;
}
body > nav a:not(.dropdown-item):not(.btn):hover,
body > header a:not(.dropdown-item):not(.btn):hover,
nav.navbar a:not(.dropdown-item):not(.btn):hover,
header.gatt-header a:not(.dropdown-item):not(.btn):hover {
    background: rgba(255, 255, 255, 0.12) !important;
    color: #FFFFFF !important;
}

/* Active state */
body > nav .nav-link.active,
nav.navbar .nav-link.active,
nav.navbar .nav-link.show,
header.gatt-header a.active {
    background: rgba(255, 255, 255, 0.18) !important;
    color: #FFFFFF !important;
    font-weight: 500 !important;
}

/* Text user (Gicu SRL etc.) în navbar */
body > nav .navbar-text,
nav.navbar .navbar-text,
header.gatt-header .user-info,
header.gatt-header span:not(.dropdown-item) {
    color: rgba(255, 255, 255, 0.92) !important;
    font-size: 13px !important;
}
body > nav .navbar-text small,
nav.navbar .navbar-text small,
header.gatt-header small {
    color: rgba(255, 255, 255, 0.65) !important;
}

/* Buton Logout (dacă e în navbar) */
body > nav button,
body > nav .btn,
nav.navbar button,
nav.navbar .btn,
header.gatt-header button,
header.gatt-header .btn {
    background: rgba(255, 255, 255, 0.12) !important;
    border: 1px solid rgba(255, 255, 255, 0.25) !important;
    color: #FFFFFF !important;
    padding: 5px 12px !important;
    border-radius: 6px !important;
    font-size: 13px !important;
}
body > nav button:hover,
nav.navbar button:hover,
header.gatt-header button:hover {
    background: rgba(255, 255, 255, 0.20) !important;
    border-color: rgba(255, 255, 255, 0.35) !important;
}

/* Toggler hamburger (mobil) */
body > nav .navbar-toggler,
nav.navbar .navbar-toggler {
    border-color: rgba(255, 255, 255, 0.25) !important;
}

/* === END NAVBAR FIX === */

/* ============================================================================
 * THEME SYSTEM — toate culorile vin din var(--theme-*) generate de
 * lib/php/theme.php pe baza rolului user-ului. Suprascrie regulile anterioare.
 *
 * Pentru a schimba o culoare în toată aplicația: editează lib/themes/{rol}.php
 * NU edita acest bloc — e o oglindă a sistemului central.
 * ========================================================================= */

/* --- Body & surface --- */
body {
    background: var(--theme-page-bg) !important;
    color: var(--theme-text-primary);
    font-family: var(--theme-font-sans);
    font-size: var(--theme-font-size-base);
}

.card,
.gatt-card {
    background: var(--theme-card-bg) !important;
    border-color: var(--theme-card-border) !important;
}

/* --- Navbar (orice variant: <nav class="navbar">, <header>, etc.) --- */
body > nav,
body > header,
nav.navbar,
header.gatt-header {
    background: var(--theme-navbar-bg) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.10) !important;
}

body > nav .navbar-brand,
body > header .navbar-brand,
nav.navbar .navbar-brand,
header.gatt-header h1,
header.gatt-header > strong,
header.gatt-header > b,
header.gatt-header .brand {
    color: var(--theme-navbar-brand-color) !important;
    font-weight: 600 !important;
    text-decoration: none !important;
}

body > nav a:not(.dropdown-item):not(.btn),
body > header a:not(.dropdown-item):not(.btn),
nav.navbar a:not(.dropdown-item):not(.btn),
header.gatt-header a:not(.dropdown-item):not(.btn) {
    color: var(--theme-navbar-text) !important;
    text-decoration: none !important;
    border-radius: 6px !important;
    transition: background 0.15s, color 0.15s !important;
}
body > nav a:not(.dropdown-item):not(.btn):hover,
body > header a:not(.dropdown-item):not(.btn):hover,
nav.navbar a:not(.dropdown-item):not(.btn):hover,
header.gatt-header a:not(.dropdown-item):not(.btn):hover {
    background: var(--theme-navbar-active-bg) !important;
    color: var(--theme-navbar-text-hover) !important;
}
body > nav .nav-link.active,
body > nav .nav-link.show,
nav.navbar .nav-link.active,
nav.navbar .nav-link.show {
    background: var(--theme-navbar-active-bg) !important;
    color: var(--theme-navbar-text-hover) !important;
    font-weight: 500 !important;
}

body > nav .navbar-text,
nav.navbar .navbar-text,
header.gatt-header .user-info,
header.gatt-header span:not(.dropdown-item):not(.badge):not(.status-badge) {
    color: var(--theme-navbar-text) !important;
}

/* Dropdown menu */
.navbar .dropdown-menu {
    background: var(--theme-navbar-dropdown-bg) !important;
    border-color: var(--theme-card-border) !important;
}
.navbar .dropdown-item {
    color: var(--theme-text-primary) !important;
}
.navbar .dropdown-item:hover,
.navbar .dropdown-item:focus {
    background: var(--theme-navbar-dropdown-hover-bg) !important;
    color: var(--theme-navbar-dropdown-hover-text) !important;
}

/* --- Butoane --- */
.btn-primary {
    background: var(--theme-btn-primary-bg) !important;
    color: var(--theme-btn-primary-text) !important;
    border-color: var(--theme-btn-primary-bg) !important;
}
.btn-primary:hover,
.btn-primary:focus {
    background: var(--theme-btn-primary-hover-bg) !important;
    border-color: var(--theme-btn-primary-hover-bg) !important;
    color: var(--theme-btn-primary-text) !important;
}

.btn-secondary,
.btn-outline-secondary {
    background: var(--theme-btn-secondary-bg) !important;
    color: var(--theme-btn-secondary-text) !important;
    border-color: var(--theme-btn-secondary-border) !important;
}
.btn-secondary:hover,
.btn-outline-secondary:hover {
    background: var(--theme-btn-secondary-hover-bg) !important;
    border-color: var(--theme-btn-secondary-text) !important;
    color: var(--theme-btn-secondary-text) !important;
}

.btn-danger {
    background: var(--theme-btn-danger-bg) !important;
    color: var(--theme-btn-danger-text) !important;
    border-color: var(--theme-btn-danger-bg) !important;
}
.btn-danger:hover {
    background: var(--theme-btn-danger-hover-bg) !important;
    border-color: var(--theme-btn-danger-hover-bg) !important;
}

.btn-success {
    background: var(--theme-btn-success-bg) !important;
    color: var(--theme-btn-success-text) !important;
    border-color: var(--theme-btn-success-bg) !important;
}
.btn-success:hover {
    background: var(--theme-btn-success-hover-bg) !important;
    border-color: var(--theme-btn-success-hover-bg) !important;
}

/* --- Tabele --- */
table.dataTable thead tr,
.gatt-table-wrap thead tr,
table.gatt-table thead tr,
.table thead tr {
    background: var(--theme-table-header-bg) !important;
}
table.dataTable thead th,
.gatt-table-wrap thead th,
table.gatt-table thead th,
.table thead th {
    color: var(--theme-table-header-text) !important;
    background: transparent !important;
    border-bottom-color: var(--theme-table-border) !important;
    font-weight: 600 !important;
}
table.dataTable tbody tr:hover,
.gatt-table-wrap tbody tr:hover,
table.gatt-table tbody tr:hover,
.table tbody tr:hover {
    background: var(--theme-table-row-hover) !important;
}

.gatt-table-wrap thead tr.filter-row,
.gatt-table-wrap thead tr.gatt-filters,
table thead tr.filter-row,
table thead tr.gatt-filters {
    background: var(--theme-table-filter-bg) !important;
}

/* --- Status badges --- */
.status-badge.s-editabil,
.status-badge.s-modificare-date {
    background: var(--theme-status-amber-bg) !important;
    color: var(--theme-status-amber-text) !important;
}
.status-badge.s-marfa-vamuita-partial,
.status-badge.s-vamuita-partial {
    background: var(--theme-status-amber-strong-bg) !important;
    color: var(--theme-status-amber-strong-text) !important;
}
.status-badge.s-solicitare-r2,
.status-badge.s-solicitare-r2---pe-roti,
.status-badge.s-solicitare-r2-pe-roti,
.status-badge.s-solicitare-ds,
.status-badge.s-asteapta-liber-de-vama,
.status-badge.s-asteapta-vama,
.status-badge.s-liber-de-vama,
.status-badge.s-asteapta-liber-de-vama-pe-roti,
.status-badge.s-liber-de-vama---pe-roti,
.status-badge.s-liber-de-vama-pe-roti,
.status-badge.s-vama-pe-roti {
    background: var(--theme-status-blue-bg) !important;
    color: var(--theme-status-blue-text) !important;
}
.status-badge.s-atribuire-r2,
.status-badge.s-atribuire-ds,
.status-badge.s-r2-in-curs-validare {
    background: var(--theme-status-blue-strong-bg) !important;
    color: var(--theme-status-blue-strong-text) !important;
}
.status-badge.s-incepe-descarcarea {
    background: var(--theme-status-purple-bg) !important;
    color: var(--theme-status-purple-text) !important;
}
.status-badge.s-descarcare {
    background: var(--theme-status-purple-strong-bg) !important;
    color: var(--theme-status-purple-strong-text) !important;
}
.status-badge.s-descarcare-incheiata,
.status-badge.s-validare-vama {
    background: var(--theme-status-teal-bg) !important;
    color: var(--theme-status-teal-text) !important;
}
.status-badge.s-marfa-in-libera-circulatie,
.status-badge.s-libera-circulatie,
.status-badge.s-livrare {
    background: var(--theme-status-green-bg) !important;
    color: var(--theme-status-green-text) !important;
}

/* --- Alerte --- */
.alert-info {
    background: var(--theme-alert-info-bg) !important;
    color: var(--theme-alert-info-text) !important;
    border-color: var(--theme-alert-info-border) !important;
}
.alert-success {
    background: var(--theme-alert-success-bg) !important;
    color: var(--theme-alert-success-text) !important;
    border-color: var(--theme-alert-success-border) !important;
}
.alert-warning {
    background: var(--theme-alert-warning-bg) !important;
    color: var(--theme-alert-warning-text) !important;
    border-color: var(--theme-alert-warning-border) !important;
}
.alert-danger {
    background: var(--theme-alert-danger-bg) !important;
    color: var(--theme-alert-danger-text) !important;
    border-color: var(--theme-alert-danger-border) !important;
}

/* --- Text utilitar --- */
.text-secondary,
.gatt-text-secondary {
    color: var(--theme-text-secondary) !important;
}
.text-tertiary,
.gatt-text-tertiary {
    color: var(--theme-text-tertiary) !important;
}

/* --- Link-uri --- */
a:not(.btn):not(.dropdown-item):not(.nav-link):not(.navbar-brand):not(.action-icon) {
    color: var(--theme-text-link) !important;
}
a:not(.btn):not(.dropdown-item):not(.nav-link):not(.navbar-brand):not(.action-icon):hover {
    color: var(--theme-text-link-hover) !important;
}

/* --- Form controls (focus ring) --- */
.form-control:focus,
.form-select:focus,
input.form-control:focus,
select.form-select:focus,
textarea.form-control:focus {
    border-color: var(--theme-form-focus-border) !important;
    box-shadow: 0 0 0 3px var(--theme-form-focus-ring) !important;
    outline: none !important;
}

/* === END THEME SYSTEM === */


/* ============================================================================
   ADMIN LAYOUT — sidebar stânga (rapoarte + setări)
   ----------------------------------------------------------------------------
   Folosit din /admin/rapoarte/* și /admin/setari/* (vezi
   lib/php/layout/admin_sidebar.php).
   ============================================================================ */

.admin-layout-with-sidebar {
    display: flex !important;
    align-items: flex-start;
    gap: 16px;
    width: 100%;
}

.admin-sidebar {
    flex: 0 0 260px;
    width: 260px;
    max-width: 260px;
    position: sticky;
    top: 12px;
    max-height: calc(100vh - 24px);
    overflow-y: auto;
    background: #ffffff;
    border: 1px solid var(--theme-card-border, rgba(24, 95, 165, 0.10));
    border-radius: 10px;
    box-shadow: 0 1px 4px rgba(12, 68, 124, 0.06);
}

.admin-sidebar .sb-root .list-group-item {
    border: 0;
    border-bottom: 1px solid rgba(0, 0, 0, 0.04);
    border-radius: 0 !important;
    font-size: 13px;
    padding: 10px 14px;
    color: var(--theme-text-primary, #1a1a1a);
    background: transparent;
}

.admin-sidebar .sb-root .list-group-item:hover {
    background: var(--theme-status-blue-bg, #E6F1FB);
    color: var(--theme-status-blue-text, #0C447C);
}

.admin-sidebar .sb-root .list-group-item.active {
    background: var(--theme-status-blue-strong-bg, #B5D4F4);
    color: var(--theme-status-blue-strong-text, #042C53);
    font-weight: 500;
    border-left: 3px solid var(--theme-status-blue-strong-text, #042C53);
    padding-left: 11px;
}

.admin-sidebar button.list-group-item {
    text-align: left;
    cursor: pointer;
}

.admin-sidebar button.list-group-item .sb-caret {
    transition: transform 0.18s ease;
    font-size: 14px;
    opacity: 0.55;
}

.admin-sidebar button.list-group-item.collapsed .sb-caret {
    transform: rotate(-90deg);
}

.admin-sidebar .sb-sub {
    background: rgba(24, 95, 165, 0.03);
}

.admin-sidebar .sb-sub-item {
    font-size: 12.5px !important;
    padding: 7px 14px 7px 38px !important;
    color: var(--theme-text-secondary, #5F5E5A) !important;
}

.admin-sidebar .sb-sub-item:hover {
    background: var(--theme-status-blue-bg, #E6F1FB) !important;
    color: var(--theme-status-blue-text, #0C447C) !important;
}

.admin-sidebar .sb-sub-item.active {
    background: var(--theme-status-blue-strong-bg, #B5D4F4) !important;
    color: var(--theme-status-blue-strong-text, #042C53) !important;
    font-weight: 500;
}

.admin-sidebar hr.sb-sep {
    margin: 4px 0;
    border-color: rgba(0, 0, 0, 0.06);
}

.admin-main {
    flex: 1 1 0;
    min-width: 0; /* previne overflow pe charts/tabele largi */
}

/* Mobile: sidebar full-width sub conținut (fără offcanvas pentru simplitate) */
@media (max-width: 992px) {
    .admin-layout-with-sidebar {
        flex-direction: column;
    }
    .admin-sidebar {
        flex: none;
        width: 100%;
        max-width: 100%;
        position: static;
        max-height: none;
    }
}

