/*
 * ada-theme.css — Tema eGestiune portata pentru platforma Ada (eGestiuneSuportAI)
 * Port din: eGestiune.API/wwwroot/css/custom.css + vanzari.css (read-only)
 *
 * UTILIZARE (include in <head> DUPA Bootstrap 5):
 *   <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.3/dist/css/bootstrap.min.css">
 *   <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.6.0/css/all.min.css">
 *   <link rel="stylesheet" href="/css/ada-theme.css?v=1.0.0">
 *   <!-- Cache-busting: Ada e static (fara Razor) — include cu ?v=<versiune> sau ?v=<hash> la fiecare deploy -->
 *
 * Dependente: Bootstrap 5.x (clase .btn, .card, .table, .badge, .nav-pills, .nav-tabs, .toast, .modal)
 *             Font Awesome 6.x Free (iconite in navbar si butoane)
 *             Select2 4.x (optional — stiluri prezente dar neobligatorii)
 *
 * Dark mode: adauga html.dark-mode pe <html> pentru tema intunecata.
 *            Toggle-ul e gestionat de ada-shared.js (persista in localStorage).
 *
 * Auto-generated: 2026-06-09
 */

/* ===========================================================
   TOKENI BRAND
   =========================================================== */
:root {
    --ada-primary: #11998e;
    --ada-primary-dark: #0f8075;
    --ada-primary-darker: #0c6b62;
    --ada-primary-light: #13b3a6;
    --ada-primary-lighter: #2ec5b8;
    --ada-primary-gradient: linear-gradient(135deg, #11998e 0%, #0f8075 100%);
    --ada-primary-gradient-sat: linear-gradient(135deg, #11998e 0%, #2ed573 100%);

    --ada-success: #10b981;
    --ada-danger: #dc2626;
    --ada-warning: #f59e0b;
    --ada-info: #3b82f6;

    /* Slate palette pentru dark mode */
    --ada-slate-900: #0f172a;
    --ada-slate-800: #1e293b;
    --ada-slate-750: #1a2332;
    --ada-slate-700: #242b3d;
    --ada-slate-650: #1e2535;
    --ada-slate-600: #2d3548;
    --ada-slate-500: #334155;
    --ada-slate-400: #475569;
    --ada-slate-300: #64748b;
    --ada-slate-200: #94a3b8;
    --ada-slate-100: #cbd5e1;
    --ada-slate-50: #e2e8f0;
    --ada-text-dark: #f0f2f5;
    --ada-text-muted-dark: #94a3b8;
}

/* ===========================================================
   RESET GLOBAL
   =========================================================== */
*, *::before, *::after {
    box-sizing: border-box;
}

body {
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    background-color: #f5f7fa;
    color: #1e293b;
}

html.dark-mode body {
    background-color: #0f172a;
    color: #e2e8f0;
}

a {
    color: var(--ada-primary);
    text-decoration: none;
}

a:hover {
    color: var(--ada-primary-dark);
}

html.dark-mode a {
    color: var(--ada-primary-light);
}

html.dark-mode a:hover {
    color: var(--ada-primary-lighter);
}

/* ===========================================================
   SIDEBAR + TOPBAR APLICATIE (inject via ada-shared.js)
   Sidebar fix la stanga (mereu vizibil pe desktop) + bara subtire sus.
   Continutul paginii e deplasat via body.ada-has-sidebar (fara a edita fiecare pagina).
   =========================================================== */
:root {
    --ada-sidebar-w: 250px;
    --ada-topbar-h: 56px;
}

body.ada-has-sidebar {
    padding-left: var(--ada-sidebar-w);
    padding-top: var(--ada-topbar-h);
}

/* ---- Sidebar ---- */
.ada-sidebar {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    width: var(--ada-sidebar-w);
    display: flex;
    flex-direction: column;
    background: #ffffff;
    border-right: 1px solid #e2e8f0;
    box-shadow: 2px 0 8px rgba(0, 0, 0, 0.04);
    z-index: 1045;
    transition: transform 0.25s ease;
}

.ada-sidebar-brand {
    display: flex;
    align-items: center;
    gap: 10px;
    height: var(--ada-topbar-h);
    padding: 0 20px;
    font-size: 18px;
    font-weight: 700;
    color: #fff;
    background: var(--ada-primary-gradient);
    text-decoration: none;
    flex-shrink: 0;
}

.ada-sidebar-brand:hover { color: #fff; opacity: 0.95; }
.ada-sidebar-brand i { font-size: 20px; }

.ada-sidebar-nav {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 12px 10px;
    overflow-y: auto;
    flex: 1 1 auto;
}

.ada-sidebar-nav a {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 14px;
    border-radius: 8px;
    color: #334155;
    font-size: 14px;
    font-weight: 500;
    text-decoration: none;
    transition: background 0.15s, color 0.15s;
}

.ada-sidebar-nav a i {
    width: 18px;
    text-align: center;
    font-size: 15px;
    color: #64748b;
    transition: color 0.15s;
}

.ada-sidebar-nav a:hover { background: rgba(17, 153, 142, 0.08); color: var(--ada-primary); }
.ada-sidebar-nav a:hover i { color: var(--ada-primary); }

.ada-sidebar-nav a.ada-sidebar-active {
    background: var(--ada-primary-gradient);
    color: #fff;
    font-weight: 600;
    box-shadow: 0 2px 6px rgba(17, 153, 142, 0.3);
}

.ada-sidebar-nav a.ada-sidebar-active i { color: #fff; }

.ada-sidebar-footer {
    border-top: 1px solid #e2e8f0;
    padding: 12px;
    flex-shrink: 0;
}

.ada-sidebar-user {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: #475569;
    padding: 4px 6px 10px;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}

.ada-sidebar-user i { font-size: 18px; color: var(--ada-primary); }

.ada-sidebar-footer-actions { display: flex; gap: 8px; }

.ada-sidebar-footer-actions .ada-dark-toggle {
    background: #f1f5f9;
    border: 1px solid #e2e8f0;
    color: #475569;
    width: 38px;
    border-radius: 8px;
    cursor: pointer;
    font-size: 15px;
}

.ada-sidebar-footer-actions .ada-dark-toggle:hover { background: #e2e8f0; color: var(--ada-primary); }

.ada-sidebar-footer-actions .ada-logout-btn {
    flex: 1;
    background: #fef2f2;
    border: 1px solid #fecaca;
    color: #dc2626;
    border-radius: 8px;
    padding: 8px 12px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    transition: background 0.15s;
}

.ada-sidebar-footer-actions .ada-logout-btn:hover { background: #fee2e2; }

/* ---- Topbar ---- */
.ada-topbar {
    position: fixed;
    top: 0;
    left: var(--ada-sidebar-w);
    right: 0;
    height: var(--ada-topbar-h);
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 0 20px;
    background: #ffffff;
    border-bottom: 1px solid #e2e8f0;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.04);
    z-index: 1040;
}

.ada-hamburger {
    display: none;
    background: transparent;
    border: none;
    color: #334155;
    font-size: 20px;
    cursor: pointer;
    padding: 4px 8px;
}

.ada-topbar-title {
    font-size: 17px;
    font-weight: 600;
    color: #1e293b;
    margin: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.ada-topbar-actions { margin-left: auto; display: flex; align-items: center; gap: 8px; }

.ada-topbar-bell {
    background: transparent;
    border: none;
    color: #94a3b8;
    font-size: 17px;
    width: 38px;
    height: 38px;
    border-radius: 8px;
    cursor: not-allowed;
}

/* ---- Overlay (mobil) ---- */
.ada-sidebar-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, 0.45);
    z-index: 1044;
}

/* ---- Dark mode ---- */
html.dark-mode .ada-sidebar {
    background: var(--ada-slate-800);
    border-right-color: var(--ada-slate-600);
    box-shadow: 2px 0 8px rgba(0, 0, 0, 0.25);
}

html.dark-mode .ada-sidebar-nav a { color: var(--ada-slate-100); }
html.dark-mode .ada-sidebar-nav a i { color: var(--ada-slate-300); }
html.dark-mode .ada-sidebar-nav a:hover { background: rgba(46, 197, 184, 0.12); color: var(--ada-primary-lighter); }
html.dark-mode .ada-sidebar-nav a:hover i { color: var(--ada-primary-lighter); }
html.dark-mode .ada-sidebar-nav a.ada-sidebar-active i { color: #fff; }
html.dark-mode .ada-sidebar-footer { border-top-color: var(--ada-slate-600); }
html.dark-mode .ada-sidebar-user { color: var(--ada-slate-100); }

html.dark-mode .ada-sidebar-footer-actions .ada-dark-toggle {
    background: var(--ada-slate-700);
    border-color: var(--ada-slate-600);
    color: var(--ada-slate-100);
}

html.dark-mode .ada-sidebar-footer-actions .ada-dark-toggle:hover { background: var(--ada-slate-600); color: var(--ada-primary-lighter); }

html.dark-mode .ada-sidebar-footer-actions .ada-logout-btn {
    background: rgba(220, 38, 38, 0.12);
    border-color: rgba(220, 38, 38, 0.4);
    color: #f87171;
}

html.dark-mode .ada-sidebar-footer-actions .ada-logout-btn:hover { background: rgba(220, 38, 38, 0.2); }

html.dark-mode .ada-topbar {
    background: var(--ada-slate-800);
    border-bottom-color: var(--ada-slate-600);
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.25);
}

html.dark-mode .ada-topbar-title { color: var(--ada-text-dark); }
html.dark-mode .ada-hamburger { color: var(--ada-slate-100); }

/* ---- Responsive: off-canvas sub 992px ---- */
@media (max-width: 992px) {
    body.ada-has-sidebar { padding-left: 0; }
    .ada-sidebar { transform: translateX(-100%); }
    .ada-topbar { left: 0; }
    .ada-hamburger { display: inline-flex; align-items: center; }
    body.ada-sidebar-open .ada-sidebar { transform: translateX(0); }
    body.ada-sidebar-open .ada-sidebar-overlay { display: block; }
}

/* ===========================================================
   HEADER MODUL (gradient palid, stil eGestiune)
   Pattern: .ada-module-header ca inlocuitor de .vanzari-header
   =========================================================== */
.ada-module-header {
    /* Light: gradient teal palid => alb, ca sa contrasteze cu butonul primar */
    background: linear-gradient(135deg, #d4f4ee 0%, #f0faf8 55%, #ffffff 100%);
    color: #1e293b;
    padding: 1.75rem 0;
    margin-bottom: 2rem;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
    border-bottom: 4px solid #11998e;
    border-radius: 0 0 16px 16px;
}

.ada-module-header h1,
.ada-module-header h2 {
    color: #1e293b;
    font-weight: 700;
    font-size: 1.8rem;
}

.ada-module-header h1 i,
.ada-module-header h2 i {
    color: #11998e;
}

/* Subtitlul din header — NU folosi text-muted Bootstrap (devine invizibil pe gradient) */
.ada-module-header small,
.ada-module-header .ada-subtitle {
    color: #4b5563;
    font-size: 0.95rem;
}

/* Containerul actiunilor din header */
.ada-header-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 8px;
    align-items: center;
}

/* Dark mode header modul */
html.dark-mode .ada-module-header {
    background: linear-gradient(135deg, #0f3d3a 0%, #1a3a3f 55%, #1e293b 100%);
    color: #f0f2f5;
    border-bottom-color: #13b3a6;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}

html.dark-mode .ada-module-header h1,
html.dark-mode .ada-module-header h2 {
    color: #f0f2f5;
}

html.dark-mode .ada-module-header h1 i,
html.dark-mode .ada-module-header h2 i {
    color: #2ec5b8;
}

html.dark-mode .ada-module-header small,
html.dark-mode .ada-module-header .ada-subtitle {
    color: #b8c1cc;
}

/* ===========================================================
   BUTOANE STANDARD (paleta brand teal — stil login-btn)
   ----------------------------------------------------------
   .btn-header-primar — gradient teal solid, UN SINGUR pe ecran.
   .btn-header-secundar — outline teal, oricat de multi.
   =========================================================== */

/* PRIMAR — gradient teal + hover shine */
.btn-header-primar {
    background: linear-gradient(135deg, #11998e 0%, #0f8075 100%);
    border: none;
    color: #ffffff !important;
    font-weight: 600;
    box-shadow: 0 2px 6px rgba(17, 153, 142, 0.25);
    transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
    position: relative;
    overflow: hidden;
    cursor: pointer;
}

/* Efect "shine" — banda alba care trece peste buton la hover */
.btn-header-primar::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
    transition: left 0.5s ease;
    pointer-events: none;
}

.btn-header-primar:hover,
.btn-header-primar:focus {
    color: #ffffff !important;
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(17, 153, 142, 0.4);
    background: linear-gradient(135deg, #11998e 0%, #0f8075 100%);
    text-decoration: none;
}

.btn-header-primar:hover::before {
    left: 100%;
}

.btn-header-primar:active {
    transform: translateY(0);
    box-shadow: 0 2px 4px rgba(17, 153, 142, 0.3);
}

.btn-header-primar:disabled,
.btn-header-primar.disabled {
    background: #b8b8b8;
    color: #ffffff !important;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
    opacity: 0.7;
}

/* SECUNDAR — outline teal */
.btn-header-secundar {
    background-color: transparent;
    border: 1.5px solid #11998e;
    color: #11998e !important;
    font-weight: 500;
    transition: background-color 0.2s, color 0.2s, box-shadow 0.2s, transform 0.2s;
    cursor: pointer;
}

.btn-header-secundar:hover,
.btn-header-secundar:focus {
    background-color: rgba(17, 153, 142, 0.1);
    border-color: #0f8075;
    color: #0d7d6f !important;
    box-shadow: 0 2px 8px rgba(17, 153, 142, 0.2);
    transform: translateY(-1px);
    text-decoration: none;
}

.btn-header-secundar:active {
    background-color: rgba(17, 153, 142, 0.18);
    transform: translateY(0);
    box-shadow: 0 1px 3px rgba(17, 153, 142, 0.2);
}

.btn-header-secundar:disabled,
.btn-header-secundar.disabled {
    color: #9ca3af !important;
    border-color: #d1d5db;
    background-color: transparent;
    opacity: 0.7;
    transform: none;
    box-shadow: none;
}

/* Dark mode butoane */
html.dark-mode .btn-header-primar {
    background: linear-gradient(135deg, #13b3a6 0%, #0f8075 50%, #0d6b62 100%);
    box-shadow: 0 4px 15px rgba(19, 179, 166, 0.3);
}

html.dark-mode .btn-header-primar:hover,
html.dark-mode .btn-header-primar:focus {
    background: linear-gradient(135deg, #0f8075 0%, #0d6b62 50%, #0a5550 100%);
    box-shadow: 0 6px 20px rgba(19, 179, 166, 0.4);
}

html.dark-mode .btn-header-primar::before {
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.15), transparent);
}

html.dark-mode .btn-header-secundar {
    border-color: #13b3a6;
    color: #13b3a6 !important;
}

html.dark-mode .btn-header-secundar:hover,
html.dark-mode .btn-header-secundar:focus {
    background-color: rgba(19, 179, 166, 0.15);
    border-color: #2ec5b8;
    color: #2ec5b8 !important;
}

html.dark-mode .btn-header-secundar:disabled,
html.dark-mode .btn-header-secundar.disabled {
    color: #6b7280 !important;
    border-color: #3a4556;
}

/* ===========================================================
   BTN-PRIMARY BOOTSTRAP — override la paleta teal (nu albastru)
   =========================================================== */
.btn-primary {
    background: linear-gradient(135deg, #11998e 0%, #2ed573 100%);
    border: none;
    color: #ffffff;
    font-weight: 600;
}

.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active {
    background: linear-gradient(135deg, #0f8075 0%, #11998e 100%);
    color: #ffffff;
    box-shadow: 0 4px 12px rgba(17, 153, 142, 0.3);
    transform: translateY(-1px);
}

.btn-primary:disabled,
.btn-primary.disabled {
    background: #b8b8b8;
    color: #ffffff;
    transform: none;
    box-shadow: none;
    opacity: 0.7;
}

html.dark-mode .btn-primary {
    background: linear-gradient(135deg, #13b3a6 0%, #0f8075 100%);
    color: #ffffff;
}

html.dark-mode .btn-primary:hover,
html.dark-mode .btn-primary:focus,
html.dark-mode .btn-primary:active {
    background: linear-gradient(135deg, #0f8075 0%, #0d6b62 100%);
    box-shadow: 0 4px 12px rgba(19, 179, 166, 0.4);
}

/* Butoane outline in dark */
html.dark-mode .btn-outline-secondary {
    border-color: #475569;
    color: #cbd5e1;
}

html.dark-mode .btn-outline-secondary:hover,
html.dark-mode .btn-outline-secondary:focus {
    background-color: #475569;
    border-color: #64748b;
    color: #f0f2f5;
}

html.dark-mode .btn-outline-dark {
    border-color: #cbd5e1;
    color: #cbd5e1;
}

html.dark-mode .btn-outline-dark:hover,
html.dark-mode .btn-outline-dark:focus {
    background-color: #cbd5e1;
    color: #0f172a;
}

html.dark-mode .btn-light {
    background-color: #334155;
    border-color: #475569;
    color: #f0f2f5;
}

html.dark-mode .btn-light:hover,
html.dark-mode .btn-light:focus {
    background-color: #475569;
    border-color: #64748b;
    color: #ffffff;
}

/* ===========================================================
   STAT-CARD — carduri KPI cu variante de culoare
   Structura HTML:
   <div class="stat-card stat-card-primary">
       <div class="stat-icon"><i class="fas fa-ticket-alt"></i></div>
       <div class="stat-content">
           <div class="stat-label">Tichete active</div>
           <div class="stat-value">42</div>
       </div>
   </div>
   =========================================================== */
.stat-card {
    background: white;
    border-radius: 12px;
    padding: 1rem 1.25rem;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    transition: transform 0.2s, box-shadow 0.2s;
    display: flex;
    align-items: center;
    gap: 0.85rem;
    height: 100%;
    min-width: 0;
}

.stat-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
}

.stat-icon {
    width: 48px;
    height: 48px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.4rem;
    flex-shrink: 0;
}

.stat-content {
    flex: 1;
    min-width: 0;
}

.stat-label {
    font-size: 0.75rem;
    color: #6c757d;
    margin-bottom: 0.15rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.stat-value {
    font-size: 1.35rem;
    font-weight: 700;
    line-height: 1.2;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Varianta primary (teal) */
.stat-card-primary .stat-icon {
    background: linear-gradient(135deg, #11998e 0%, #2ed573 100%);
    color: white;
}

.stat-card-primary .stat-value {
    color: #11998e;
}

/* Varianta success (tot teal, alias pentru compatibilitate) */
.stat-card-success .stat-icon {
    background: linear-gradient(135deg, #11998e 0%, #2ed573 100%);
    color: white;
}

.stat-card-success .stat-value {
    color: #11998e;
}

/* Varianta info (albastru) */
.stat-card-info .stat-icon {
    background: linear-gradient(135deg, #3498db 0%, #2980b9 100%);
    color: white;
}

.stat-card-info .stat-value {
    color: #3498db;
}

/* Varianta warning (portocaliu) */
.stat-card-warning .stat-icon {
    background: linear-gradient(135deg, #f39c12 0%, #e67e22 100%);
    color: white;
}

.stat-card-warning .stat-value {
    color: #f39c12;
}

/* Varianta danger (rosu) */
.stat-card-danger .stat-icon {
    background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
    color: white;
}

.stat-card-danger .stat-value {
    color: #ef4444;
}

/* Dark mode stat-card */
html.dark-mode .stat-card {
    background: linear-gradient(135deg, #1e293b 0%, #242b3d 100%);
    border: 1px solid #2d3548;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

html.dark-mode .stat-card:hover {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.4);
    border-color: #13b3a6;
}

html.dark-mode .stat-label {
    color: #8b92a7;
}

html.dark-mode .stat-value {
    color: #f0f2f5;
}

html.dark-mode .stat-card-primary .stat-icon,
html.dark-mode .stat-card-success .stat-icon {
    background: linear-gradient(135deg, #13b3a6 0%, #0f8075 100%);
}

html.dark-mode .stat-card-primary .stat-value,
html.dark-mode .stat-card-success .stat-value {
    color: #13b3a6;
}

html.dark-mode .stat-card-info .stat-icon {
    background: linear-gradient(135deg, #13b3a6 0%, #0f8075 100%);
    color: white;
}

html.dark-mode .stat-card-info .stat-value {
    color: #13b3a6;
}

html.dark-mode .stat-card-warning .stat-icon {
    background: linear-gradient(135deg, rgba(255, 193, 7, 0.2) 0%, rgba(255, 193, 7, 0.1) 100%);
    color: #ffc107;
}

html.dark-mode .stat-card-warning .stat-value {
    color: #ffc107;
}

html.dark-mode .stat-card-danger .stat-icon {
    background: linear-gradient(135deg, rgba(239, 68, 68, 0.2) 0%, rgba(220, 38, 38, 0.1) 100%);
    color: #f87171;
}

html.dark-mode .stat-card-danger .stat-value {
    color: #f87171;
}

/* ===========================================================
   CARDURI BOOTSTRAP — DARK MODE GLOBAL
   =========================================================== */
html.dark-mode .card {
    background: linear-gradient(135deg, #1e293b 0%, #242b3d 100%);
    border-color: #2d3548;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
    color: #e2e8f0;
}

html.dark-mode .card-header {
    background: linear-gradient(135deg, #242b3d 0%, #1e2535 100%);
    color: #f0f2f5;
    border-bottom-color: #2d3548;
}

html.dark-mode .card-header.bg-light,
html.dark-mode .card-header.bg-white {
    background: linear-gradient(135deg, #242b3d 0%, #1e2535 100%) !important;
    color: #f0f2f5 !important;
}

html.dark-mode .card-header h5,
html.dark-mode .card-header h4,
html.dark-mode .card-header h3 {
    color: #f0f2f5;
}

html.dark-mode .card-header i {
    color: #13b3a6;
}

html.dark-mode .card-header i.text-primary,
html.dark-mode i.text-primary {
    color: #13b3a6 !important;
}

html.dark-mode .card-body {
    color: #e2e8f0;
}

html.dark-mode .card-footer {
    background-color: #1a2332;
    color: #cbd5e1;
    border-top-color: #2d3548;
}

/* ===========================================================
   MODAL — DARK MODE GLOBAL
   =========================================================== */
html.dark-mode .modal-content {
    background-color: #1e293b;
    color: #e2e8f0;
    border: 1px solid #2d3548;
}

html.dark-mode .modal-header {
    background: linear-gradient(135deg, #242b3d 0%, #1e2535 100%);
    border-bottom-color: #2d3548;
    color: #f0f2f5;
}

html.dark-mode .modal-header.bg-light,
html.dark-mode .modal-header.bg-white {
    background: linear-gradient(135deg, #242b3d 0%, #1e2535 100%) !important;
    color: #f0f2f5 !important;
}

html.dark-mode .modal-title {
    color: #f0f2f5;
}

html.dark-mode .modal-footer {
    border-top-color: #2d3548;
    background-color: #1e293b;
}

html.dark-mode .modal-header .btn-close {
    filter: invert(1) grayscale(1) brightness(1.3);
}

/* ===========================================================
   TEXT-MUTED — mai vizibil in dark
   =========================================================== */
html.dark-mode .text-muted,
html.dark-mode small.text-muted,
html.dark-mode p.text-muted,
html.dark-mode span.text-muted {
    color: #94a3b8 !important;
}

html.dark-mode i.text-muted {
    color: #94a3b8 !important;
}

/* ===========================================================
   TABELE BOOTSTRAP — DARK MODE GLOBAL
   =========================================================== */
html.dark-mode .table {
    color: #e2e8f0;
    --bs-table-bg: transparent;
    --bs-table-color: #e2e8f0;
    --bs-table-border-color: #2d3548;
    --bs-table-striped-bg: rgba(255, 255, 255, 0.015);
    --bs-table-striped-color: #e2e8f0;
    --bs-table-hover-bg: rgba(19, 179, 166, 0.08);
    --bs-table-hover-color: #f0f2f5;
}

html.dark-mode .table thead th {
    background: linear-gradient(135deg, #242b3d 0%, #1e2535 100%);
    color: #f0f2f5;
    border-bottom-color: #2d3548;
}

html.dark-mode .table tbody tr {
    border-color: #2d3548;
}

html.dark-mode .table tbody tr:hover,
html.dark-mode .table-hover > tbody > tr:hover > * {
    background-color: rgba(19, 179, 166, 0.08);
    color: #f0f2f5;
}

html.dark-mode .table-responsive {
    border-color: #2d3548;
}

/* ===========================================================
   BADGE
   =========================================================== */
html.dark-mode .badge.bg-secondary {
    background-color: #475569 !important;
    color: #e2e8f0;
}

/* Badge-uri pentru status tichete */
.ada-badge-new {
    background: #e0f2fe;
    color: #0369a1;
    display: inline-block;
    padding: 2px 10px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
}

.ada-badge-open {
    background: #fef3c7;
    color: #92400e;
    display: inline-block;
    padding: 2px 10px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
}

.ada-badge-pending {
    background: #f3e8ff;
    color: #6b21a8;
    display: inline-block;
    padding: 2px 10px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
}

.ada-badge-resolved {
    background: #d1fae5;
    color: #065f46;
    display: inline-block;
    padding: 2px 10px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
}

.ada-badge-closed {
    background: #f1f5f9;
    color: #475569;
    display: inline-block;
    padding: 2px 10px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
}

html.dark-mode .ada-badge-new { background: #0c2a4a; color: #7dd3fc; }
html.dark-mode .ada-badge-open { background: #3b2b00; color: #fde68a; }
html.dark-mode .ada-badge-pending { background: #2a1a4a; color: #d8b4fe; }
html.dark-mode .ada-badge-resolved { background: #0a2a1e; color: #6ee7b7; }
html.dark-mode .ada-badge-closed { background: #1e293b; color: #94a3b8; border: 1px solid #2d3548; }

/* Badge canal (WhatsApp / Web / Email) */
.ada-badge-channel {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 8px;
    border-radius: 12px;
    font-size: 11px;
    font-weight: 600;
}

.ada-badge-channel-whatsapp {
    background: #e7fbe9;
    color: #1a6e26;
}

.ada-badge-channel-web {
    background: #e0f2fe;
    color: #0369a1;
}

.ada-badge-channel-email {
    background: #fef3c7;
    color: #854d0e;
}

html.dark-mode .ada-badge-channel-whatsapp { background: #0a2f10; color: #4ade80; }
html.dark-mode .ada-badge-channel-web { background: #0c2a4a; color: #7dd3fc; }
html.dark-mode .ada-badge-channel-email { background: #2a1a00; color: #fcd34d; }

/* Badge categorie tichet — culoare dinamica (inline style din categoryBadge()) */
.ada-badge-category {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 10px;
    border-radius: 12px;
    font-size: 12px;
    font-weight: 600;
    white-space: nowrap;
}

/* Preview badge categorie in formularul de editare */
.ada-category-preview {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 12px;
    border-radius: 12px;
    font-size: 13px;
    font-weight: 600;
    border: 2px solid rgba(0,0,0,0.08);
}

/* Color swatch in tabelul de categorii */
.ada-color-swatch {
    display: inline-block;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    vertical-align: middle;
    border: 1px solid rgba(0,0,0,0.12);
    flex-shrink: 0;
}

/* ===========================================================
   FORM CONTROLS — DARK MODE
   =========================================================== */
html.dark-mode .form-control,
html.dark-mode .form-select {
    background-color: #0f172a;
    border-color: #2d3548;
    color: #e2e8f0;
}

html.dark-mode .form-control:focus,
html.dark-mode .form-select:focus {
    background-color: #0f172a;
    border-color: #13b3a6;
    color: #e2e8f0;
    box-shadow: 0 0 0 0.2rem rgba(19, 179, 166, 0.2);
}

html.dark-mode .form-control::placeholder {
    color: #64748b;
}

html.dark-mode .form-label {
    color: #cbd5e1;
}

html.dark-mode .form-control:disabled,
html.dark-mode .form-control[readonly],
html.dark-mode .form-select:disabled,
html.dark-mode .form-select[disabled] {
    background-color: #0f172a;
    color: #94a3b8;
    border-color: #2d3548;
    opacity: 0.7;
}

html.dark-mode .form-control:disabled::placeholder,
html.dark-mode .form-control[readonly]::placeholder {
    color: #64748b;
}

html.dark-mode textarea {
    background-color: #0f172a;
    border-color: #2d3548;
    color: #e2e8f0;
}

html.dark-mode textarea:focus {
    background-color: #0f172a;
    border-color: #13b3a6;
    color: #e2e8f0;
    box-shadow: 0 0 0 0.2rem rgba(19, 179, 166, 0.2);
}

/* ===========================================================
   NAV-PILLS — paleta teal canonic
   =========================================================== */
.nav-pills .nav-link {
    color: #475569 !important;
    font-weight: 500;
}

.nav-pills .nav-link:hover:not(.active):not(.disabled),
.nav-pills .nav-link:focus:not(.active):not(.disabled) {
    color: #0f8075 !important;
    background-color: rgba(17, 153, 142, 0.08);
}

.nav-pills .nav-link.active,
.nav-pills .show > .nav-link {
    background: linear-gradient(135deg, #11998e 0%, #0f8075 100%);
    color: #ffffff !important;
}

.nav-pills .nav-link.active:hover,
.nav-pills .nav-link.active:focus,
.nav-pills .show > .nav-link:hover,
.nav-pills .show > .nav-link:focus {
    background: linear-gradient(135deg, #0f8075 0%, #0c6b62 100%);
    color: #ffffff !important;
    box-shadow: 0 2px 6px rgba(17, 153, 142, 0.25);
}

html.dark-mode .nav-pills .nav-link {
    color: #cbd5e1 !important;
}

html.dark-mode .nav-pills .nav-link:hover:not(.active):not(.disabled),
html.dark-mode .nav-pills .nav-link:focus:not(.active):not(.disabled) {
    color: #13b3a6 !important;
    background-color: rgba(46, 197, 184, 0.10);
}

html.dark-mode .nav-pills .nav-link.active,
html.dark-mode .nav-pills .show > .nav-link {
    background: linear-gradient(135deg, #13b3a6 0%, #0f8075 100%);
    color: #ffffff !important;
}

html.dark-mode .nav-pills .nav-link.active:hover,
html.dark-mode .nav-pills .nav-link.active:focus,
html.dark-mode .nav-pills .show > .nav-link:hover,
html.dark-mode .nav-pills .show > .nav-link:focus {
    background: linear-gradient(135deg, #0f8075 0%, #0c6b62 100%);
    color: #ffffff !important;
    box-shadow: 0 2px 6px rgba(46, 197, 184, 0.30);
}

/* ===========================================================
   NAV-TABS — paleta teal canonic
   =========================================================== */
.nav-tabs .nav-link {
    color: #475569 !important;
    font-weight: 500;
}

.nav-tabs .nav-link:hover:not(.active):not(.disabled),
.nav-tabs .nav-link:focus:not(.active):not(.disabled) {
    color: #0f8075 !important;
    border-color: transparent transparent #11998e;
    background-color: rgba(17, 153, 142, 0.04);
}

.nav-tabs .nav-link.active {
    color: #11998e !important;
    border-color: #dee2e6 #dee2e6 #fff;
    font-weight: 600;
}

.nav-tabs .nav-link.active:hover,
.nav-tabs .nav-link.active:focus {
    color: #0f8075 !important;
    border-color: #dee2e6 #dee2e6 #fff;
}

html.dark-mode .nav-tabs {
    border-bottom-color: #2d3548;
}

html.dark-mode .nav-tabs .nav-link {
    color: #cbd5e1 !important;
    border: 1px solid transparent;
}

html.dark-mode .nav-tabs .nav-link:hover:not(.active):not(.disabled),
html.dark-mode .nav-tabs .nav-link:focus:not(.active):not(.disabled) {
    color: #13b3a6 !important;
    border-color: #2d3548 #2d3548 transparent;
    background-color: rgba(46, 197, 184, 0.08);
}

html.dark-mode .nav-tabs .nav-link.active {
    background-color: #1e293b;
    color: #13b3a6 !important;
    border-color: #2d3548 #2d3548 #1e293b;
}

html.dark-mode .nav-tabs .nav-link.active:hover,
html.dark-mode .nav-tabs .nav-link.active:focus {
    color: #2ec5b8 !important;
    border-color: #2d3548 #2d3548 #1e293b;
}

/* ===========================================================
   TOAST — DARK MODE GLOBAL
   Structura Bootstrap standard: .toast > .toast-header + .toast-body
   showToast() din ada-shared.js creeaza aceste toast-uri.
   =========================================================== */
html.dark-mode .toast {
    background-color: #1e293b;
    color: #e2e8f0;
    border: 1px solid #2d3548;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.5);
}

html.dark-mode .toast-header {
    background-color: #0f172a;
    color: #f0f2f5;
    border-bottom-color: #2d3548;
}

html.dark-mode .toast-header strong {
    color: #f0f2f5;
}

html.dark-mode .toast-body {
    color: #e2e8f0;
}

html.dark-mode .toast-header .btn-close {
    filter: invert(1) grayscale(1) brightness(1.3);
}

html.dark-mode .toast-header .text-success {
    color: #34d399 !important;
}

html.dark-mode .toast-header .text-danger {
    color: #f87171 !important;
}

html.dark-mode .toast-header .text-warning {
    color: #fbbf24 !important;
}

html.dark-mode .toast-header .text-info {
    color: #60a5fa !important;
}

/* ===========================================================
   SELECT2 — HEIGHT ALINIAT CU FORM-CONTROL (38px)
   Asigura ca select2-urile stau la acelasi nivel cu input-urile Bootstrap.
   =========================================================== */
.select2-container--default .select2-selection--single {
    height: calc(1.5em + 0.75rem + 2px);
    padding: 0 0.75rem;
    line-height: calc(1.5em + 0.75rem);
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
    line-height: calc(1.5em + 0.75rem);
    padding-left: 0;
    padding-right: 1.25rem;
}

.select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 100%;
    top: 0;
    right: 0.5rem;
}

.select2-container--default .select2-selection--multiple {
    min-height: calc(1.5em + 0.75rem + 2px);
    padding: 2px 0.5rem;
}

.select2-container--bootstrap-5 .select2-selection {
    min-height: calc(1.5em + 0.75rem + 2px);
}

/* SELECT2 — DARK MODE */
html.dark-mode .select2-container--default .select2-selection--single,
html.dark-mode .select2-container--default .select2-selection--multiple,
html.dark-mode .select2-container--bootstrap-5 .select2-selection {
    background-color: #0f172a;
    border-color: rgba(19, 179, 166, 0.3);
    color: #e2e8f0;
}

html.dark-mode .select2-container--default .select2-selection__rendered,
html.dark-mode .select2-container--bootstrap-5 .select2-selection__rendered {
    color: #e2e8f0 !important;
}

html.dark-mode .select2-container--default .select2-selection__placeholder,
html.dark-mode .select2-container--bootstrap-5 .select2-selection__placeholder {
    color: #94a3b8;
}

html.dark-mode .select2-container--default .select2-selection__arrow b {
    border-color: #cbd5e1 transparent transparent transparent;
}

html.dark-mode .select2-container--default.select2-container--open .select2-selection__arrow b {
    border-color: transparent transparent #cbd5e1 transparent;
}

html.dark-mode .select2-container--default.select2-container--focus .select2-selection--single,
html.dark-mode .select2-container--default.select2-container--focus .select2-selection--multiple,
html.dark-mode .select2-container--default.select2-container--open .select2-selection--single,
html.dark-mode .select2-container--default.select2-container--open .select2-selection--multiple,
html.dark-mode .select2-container--bootstrap-5.select2-container--focus .select2-selection,
html.dark-mode .select2-container--bootstrap-5.select2-container--open .select2-selection {
    border-color: #13b3a6;
    box-shadow: 0 0 0 0.2rem rgba(19, 179, 166, 0.25);
}

html.dark-mode .select2-container--default .select2-selection__clear {
    color: #cbd5e1;
}

html.dark-mode .select2-container--default .select2-dropdown,
html.dark-mode .select2-container--bootstrap-5 .select2-dropdown {
    background-color: #1e293b;
    border-color: #2d3548;
    color: #e2e8f0;
}

html.dark-mode .select2-container--default .select2-search--dropdown .select2-search__field,
html.dark-mode .select2-container--bootstrap-5 .select2-search__field {
    background-color: #0f172a;
    border-color: rgba(19, 179, 166, 0.3);
    color: #e2e8f0;
}

html.dark-mode .select2-container--default .select2-search__field::placeholder,
html.dark-mode .select2-container--bootstrap-5 .select2-search__field::placeholder {
    color: #64748b;
}

html.dark-mode .select2-container--default .select2-results__option,
html.dark-mode .select2-container--bootstrap-5 .select2-results__option {
    color: #e2e8f0;
}

html.dark-mode .select2-container--default .select2-results__option--highlighted,
html.dark-mode .select2-container--default .select2-results__option--highlighted[aria-selected],
html.dark-mode .select2-container--bootstrap-5 .select2-results__option--highlighted {
    background-color: rgba(19, 179, 166, 0.2);
    color: #13b3a6;
}

html.dark-mode .select2-container--default .select2-results__option[aria-selected="true"],
html.dark-mode .select2-container--bootstrap-5 .select2-results__option--selected {
    background-color: rgba(19, 179, 166, 0.15);
    color: #e2e8f0;
}

html.dark-mode .select2-container--default .select2-results__option.select2-results__message,
html.dark-mode .select2-container--bootstrap-5 .select2-results__message {
    color: #cbd5e1;
    background-color: transparent;
}

html.dark-mode .select2-container--default .select2-selection__choice {
    background-color: #1e293b;
    border-color: #2d3548;
    color: #e2e8f0;
}

html.dark-mode .select2-container--default .select2-selection__choice__remove {
    color: #94a3b8;
}

html.dark-mode .select2-container--default .select2-selection__choice__remove:hover {
    color: #f87171;
    background-color: transparent;
}

/* ===========================================================
   PAGINARE — dark mode
   =========================================================== */
html.dark-mode .pagination .page-link {
    background-color: #1e293b;
    border-color: #2d3548;
    color: #cbd5e1;
}

html.dark-mode .pagination .page-link:hover {
    background-color: #242b3d;
    border-color: #13b3a6;
    color: #13b3a6;
}

html.dark-mode .pagination .page-item.active .page-link {
    background: linear-gradient(135deg, #13b3a6 0%, #0f8075 100%);
    border-color: #13b3a6;
    color: white;
}

html.dark-mode .pagination .page-item.disabled .page-link {
    background-color: #1a2332;
    border-color: #2d3548;
    color: #475569;
}

/* ===========================================================
   SPINNER (indicator de incarcare)
   =========================================================== */
.ada-spinner {
    display: inline-block;
    width: 14px;
    height: 14px;
    border: 2px solid rgba(255, 255, 255, 0.4);
    border-top-color: white;
    border-radius: 50%;
    animation: ada-spin 0.7s linear infinite;
    margin-right: 6px;
    vertical-align: middle;
}

@keyframes ada-spin {
    to { transform: rotate(360deg); }
}

.ada-spinner-teal {
    border-color: rgba(17, 153, 142, 0.2);
    border-top-color: #11998e;
}

/* ===========================================================
   SECTIUNEA LISTEI DE MESAJE (thread conversatie)
   =========================================================== */
.ada-messages-thread {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-bottom: 20px;
}

.ada-message-bubble {
    padding: 12px 16px;
    border-radius: 12px;
    max-width: 80%;
    font-size: 14px;
    line-height: 1.5;
}

.ada-message-bubble.operator {
    background: #eff6ff;
    border: 1px solid #bfdbfe;
}

.ada-message-bubble.customer {
    background: #fefce8;
    border: 1px solid #fde68a;
    align-self: flex-start;
}

.ada-message-bubble.ai {
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
}

/* Mesajele proprii ale clientului (Portal Client) — teal, aliniat dreapta */
.ada-message-bubble.client-user {
    background: #f0fdf4;
    border: 1px solid #6ee7b7;
    align-self: flex-end;
}

.ada-message-bubble.system {
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    font-style: italic;
    color: #64748b;
    align-self: center;
    max-width: 100%;
    text-align: center;
}

.ada-message-meta {
    font-size: 11px;
    color: #94a3b8;
    margin-top: 4px;
}

html.dark-mode .ada-message-bubble.operator {
    background: #1e2a3a;
    border-color: #1e3a5f;
    color: #e2e8f0;
}

html.dark-mode .ada-message-bubble.customer {
    background: #2a2310;
    border-color: #4a3800;
    color: #e2e8f0;
}

html.dark-mode .ada-message-bubble.ai {
    background: #0a2a1e;
    border-color: #155534;
    color: #e2e8f0;
}

html.dark-mode .ada-message-bubble.client-user {
    background: #0a2a1e;
    border-color: #1a6e44;
    color: #e2e8f0;
}

html.dark-mode .ada-message-bubble.system {
    background: #1e293b;
    border-color: #2d3548;
    color: #94a3b8;
}

/* ===========================================================
   PAGINA DE LOGIN (standalone, fara navbar)
   =========================================================== */
.ada-login-page {
    min-height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
    background: linear-gradient(135deg, #11998e 0%, #0f8075 100%);
    padding: 20px;
}

.ada-login-card {
    background: white;
    padding: 40px;
    border-radius: 20px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
    max-width: 460px;
    width: 100%;
}

html.dark-mode .ada-login-card {
    background: #1e293b;
    color: #e2e8f0;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.6);
}

/* Butonul de submit pe pagina de login */
.ada-login-btn {
    background: linear-gradient(135deg, #11998e 0%, #0f8075 100%);
    color: white;
    border: none;
    padding: 12px 30px;
    border-radius: 8px;
    cursor: pointer;
    font-size: 16px;
    font-weight: 600;
    width: 100%;
    transition: transform 0.2s, box-shadow 0.2s;
    box-shadow: 0 2px 8px rgba(17, 153, 142, 0.25);
}

.ada-login-btn:hover:not(:disabled) {
    transform: translateY(-2px);
    box-shadow: 0 6px 18px rgba(17, 153, 142, 0.4);
}

.ada-login-btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    transform: none;
}

/* ===========================================================
   RESPONSIVENESS
   =========================================================== */
@media (max-width: 768px) {
    .ada-module-header {
        padding: 1.25rem 0;
        margin-bottom: 1.5rem;
    }

    .ada-module-header h1,
    .ada-module-header h2 {
        font-size: 1.4rem;
    }

    .ada-header-actions {
        justify-content: flex-start;
        margin-top: 8px;
    }
}

@media (max-width: 576px) {
    .stat-card {
        padding: 0.75rem 1rem;
    }

    .stat-value {
        font-size: 1.1rem;
    }
}

/* ===========================================================
   BADGE SLA (generat de window.slaBadge() din ada-shared.js)
   Verde = in termen; Amber = aproape de termen (<30 min);
   Rosu = breach; Gri/italic = pauzat (Pending).
   =========================================================== */
.ada-sla-badge {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    padding: 2px 8px;
    border-radius: 12px;
    font-size: 11px;
    font-weight: 600;
    white-space: nowrap;
    vertical-align: middle;
    letter-spacing: 0.2px;
}

/* Verde: in termen */
.ada-sla-badge.ada-sla-ok {
    background: #dcfce7;
    color: #166534;
    border: 1px solid #86efac;
}

html.dark-mode .ada-sla-badge.ada-sla-ok {
    background: #14532d;
    color: #86efac;
    border-color: #166534;
}

/* Amber: aproape de termen */
.ada-sla-badge.ada-sla-warn {
    background: #fef9c3;
    color: #854d0e;
    border: 1px solid #fde047;
}

html.dark-mode .ada-sla-badge.ada-sla-warn {
    background: #422006;
    color: #fde68a;
    border-color: #854d0e;
}

/* Rosu: breach */
.ada-sla-badge.ada-sla-breach {
    background: #fee2e2;
    color: #991b1b;
    border: 1px solid #fca5a5;
}

html.dark-mode .ada-sla-badge.ada-sla-breach {
    background: #450a0a;
    color: #fca5a5;
    border-color: #991b1b;
}

/* Gri: pauzat */
.ada-sla-badge.ada-sla-paused {
    background: #f1f5f9;
    color: #64748b;
    border: 1px solid #cbd5e1;
    font-style: italic;
}

html.dark-mode .ada-sla-badge.ada-sla-paused {
    background: #1e293b;
    color: #94a3b8;
    border-color: #334155;
}
