@import url('https://fonts.googleapis.com/css2?family=Source+Serif+4:ital,opsz,wght@0,8..60,400..600;1,8..60,400&family=Libre+Franklin:wght@400;500;600;700&display=swap');

/* ============================================
   SEBEGO LEGAL CASE MANAGEMENT SYSTEM
   Professional Law-Firm Admin Theme
   Navy #16273b · Burgundy #7a2931 · Gold #b8923f
   Display: Source Serif 4 · UI: Libre Franklin
   ============================================ */

:root {
    /* ===== Brand Colors ===== */
    --sebego-primary: #7a2931;
    --sebego-primary-dark: #5a1f25;
    --sebego-primary-light: #9a3941;
    --sebego-primary-rgb: 122, 41, 49;

    /* ===== Bootstrap Overrides ===== */
    --bs-primary: #7a2931;
    --bs-primary-rgb: 122, 41, 49;
    --bs-secondary: #6c757d;
    --bs-secondary-rgb: 108, 117, 125;
    --bs-success: #47ad77;
    --bs-success-rgb: 71, 173, 119;
    --bs-info: #16a7e9;
    --bs-info-rgb: 22, 167, 233;
    --bs-warning: #ffc35a;
    --bs-warning-rgb: 255, 195, 90;
    --bs-danger: #f15776;
    --bs-danger-rgb: 241, 87, 118;

    /* ===== Neutral Colors ===== */
    --bs-white: #ffffff;
    --bs-black: #000000;
    --bs-gray-100: #f8f9fa;
    --bs-gray-200: #e9ecef;
    --bs-gray-300: #dee2e6;
    --bs-gray-400: #ced4da;
    --bs-gray-500: #adb5bd;
    --bs-gray-600: #6c757d;
    --bs-gray-700: #495057;
    --bs-gray-800: #343a40;
    --bs-gray-900: #212529;

    /* ===== Layout ===== */
    --bs-body-bg: #f5f6fa;
    --bs-body-color: #495057;
    --bs-body-font-size: 0.875rem;
    --body-max-width: 100%;

    /* ===== Sidebar ===== */
    --sidebar-bg: #ffffff;
    --sidebar-width: 250px;
    --sidebar-menu-color: #495057;
    --sidebar-menu-hover-bg: rgba(122, 41, 49, 0.08);
    --sidebar-menu-active-bg: #7a2931;
    --sidebar-menu-active-color: #ffffff;
    --sidebar-menu-icon-color: #7a2931;
    --sidebar-header-color: #212529;
    --sidebar-border-color: #e9ecef;

    /* ===== Cards ===== */
    --card-bg: #ffffff;
    --card-border-color: #e9ecef;
    --card-border-radius: 0.5rem;
    --card-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
    --card-shadow-hover: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
    --card-spacer-x: 1.5rem;
    --card-spacer-y: 1.5rem;
    --card-cap-padding-x: 1.5rem;
    --card-cap-padding-y: 1rem;

    /* ===== Buttons ===== */
    --btn-border-radius: 0.375rem;
    --btn-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
    --btn-shadow-hover: 0 4px 6px rgba(0, 0, 0, 0.1);

    /* ===== Forms ===== */
    --input-border-color: #ced4da;
    --input-border-radius: 0.375rem;
    --input-focus-border-color: #7a2931;
    --input-focus-shadow: 0 0 0 0.2rem rgba(122, 41, 49, 0.25);

    /* ===== Tables ===== */
    --table-border-color: #e9ecef;
    --table-hover-bg: rgba(122, 41, 49, 0.04);
    --table-striped-bg: rgba(0, 0, 0, 0.02);

    /* ===== Borders ===== */
    --border-width: 1px;
    --border-color: #e9ecef;
    --border-radius: 0.375rem;
    --border-radius-sm: 0.25rem;
    --border-radius-lg: 0.5rem;

    /* ===== Shadows ===== */
    --shadow-sm: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
    --shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
    --shadow-lg: 0 1rem 3rem rgba(0, 0, 0, 0.175);

    /* ===== Typography ===== */
    --font-family-sans-serif: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    --font-size-base: 0.875rem;
    --font-size-sm: 0.8125rem;
    --font-size-lg: 1rem;
    --line-height-base: 1.5;
    --headings-color: #212529;

    /* ===== Transitions ===== */
    --transition-base: all 0.2s ease-in-out;
    --transition-fast: all 0.15s ease-in-out;
    --transition-slow: all 0.3s ease-in-out;
}

/* ============================================
   GLOBAL STYLES
   ============================================ */

body {
    font-family: var(--font-family-sans-serif);
    font-size: var(--font-size-base);
    line-height: var(--line-height-base);
    color: var(--bs-body-color);
    background-color: var(--bs-body-bg);
}

/* ============================================
   CARDS
   ============================================ */

.card {
    background-color: var(--card-bg);
    border: 1px solid var(--card-border-color);
    border-radius: var(--card-border-radius);
    box-shadow: var(--card-shadow);
    margin-bottom: 1.5rem;
    transition: var(--transition-base);
}

.card:hover {
    box-shadow: var(--card-shadow-hover);
}

.card-header {
    padding: var(--card-cap-padding-y) var(--card-cap-padding-x);
    margin-bottom: 0;
    background-color: transparent;
    border-bottom: 1px solid var(--card-border-color);
    font-weight: 600;
    color: var(--headings-color);
}

.card-header:first-child {
    border-radius: calc(var(--card-border-radius) - 1px) calc(var(--card-border-radius) - 1px) 0 0;
}

.card-body {
    flex: 1 1 auto;
    padding: var(--card-spacer-y) var(--card-spacer-x);
}

.card-footer {
    padding: var(--card-cap-padding-y) var(--card-cap-padding-x);
    background-color: var(--bs-gray-100);
    border-top: 1px solid var(--card-border-color);
}

/* Card Variations */
.card.shadow-sm {
    box-shadow: var(--shadow-sm) !important;
}

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

.card.shadow-lg {
    box-shadow: var(--shadow-lg) !important;
}

.card.border-0 {
    border: none !important;
}

/* ============================================
   BACKGROUND COLORS
   ============================================ */

.bg-primary {
    background-color: var(--sebego-primary) !important;
}

.bg-success {
    background-color: var(--bs-success) !important;
}

.bg-info {
    background-color: var(--bs-info) !important;
}

.bg-warning {
    background-color: var(--bs-warning) !important;
}

.bg-danger {
    background-color: var(--bs-danger) !important;
}

.bg-secondary {
    background-color: var(--bs-secondary) !important;
}

.bg-light {
    background-color: var(--bs-gray-100) !important;
}

.bg-white {
    background-color: var(--bs-white) !important;
}

/* ============================================
   TEXT COLORS
   ============================================ */

.text-primary {
    color: var(--sebego-primary) !important;
}

.text-success {
    color: var(--bs-success) !important;
}

.text-info {
    color: var(--bs-info) !important;
}

.text-warning {
    color: var(--bs-warning) !important;
}

.text-danger {
    color: var(--bs-danger) !important;
}

.text-muted {
    color: var(--bs-gray-600) !important;
}

/* ============================================
   BUTTONS
   ============================================ */

.btn {
    border-radius: var(--btn-border-radius);
    font-weight: 500;
    transition: var(--transition-base);
    box-shadow: var(--btn-shadow);
}

.btn:hover {
    box-shadow: var(--btn-shadow-hover);
    transform: translateY(-1px);
}

.btn:active {
    transform: translateY(0);
}

.btn-primary {
    background-color: var(--sebego-primary) !important;
    border-color: var(--sebego-primary) !important;
    color: var(--bs-white) !important;
}

.btn-primary:hover,
.btn-primary:focus {
    background-color: var(--sebego-primary-dark) !important;
    border-color: var(--sebego-primary-dark) !important;
}

.btn-sm {
    padding: 0.375rem 0.75rem;
    font-size: var(--font-size-sm);
}

/* ============================================
   BADGES
   ============================================ */

.badge {
    font-weight: 500;
    padding: 0.375em 0.65em;
    border-radius: 0.25rem;
}

.badge.bg-primary {
    background-color: var(--sebego-primary) !important;
}

.badge.bg-success {
    background-color: var(--bs-success) !important;
}

.badge.bg-warning {
    background-color: var(--bs-warning) !important;
    color: var(--bs-gray-900) !important;
}

.badge.bg-danger {
    background-color: var(--bs-danger) !important;
}

.badge.bg-secondary {
    background-color: var(--bs-secondary) !important;
}

/* ============================================
   TABLES
   ============================================ */

.table {
    border-color: var(--table-border-color);
}

.table thead th {
    border-bottom: 2px solid var(--table-border-color);
    font-weight: 600;
    color: var(--headings-color);
    background-color: var(--bs-gray-100);
}

.table-hover tbody tr:hover {
    background-color: var(--table-hover-bg);
}

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

/* ============================================
   FORMS
   ============================================ */

.form-control,
.form-select {
    border-color: var(--input-border-color);
    border-radius: var(--input-border-radius);
    font-size: var(--font-size-base);
}

.form-control:focus,
.form-select:focus {
    border-color: var(--input-focus-border-color);
    box-shadow: var(--input-focus-shadow);
}

.form-label {
    font-weight: 500;
    color: var(--headings-color);
    margin-bottom: 0.5rem;
}

/* ============================================
   SIDEBAR (EasyAdmin)
   ============================================ */

.sidebar {
    background-color: var(--sidebar-bg);
    border-right: 1px solid var(--sidebar-border-color);
    box-shadow: 2px 0 4px rgba(0, 0, 0, 0.05);
}

.sidebar .menu-item {
    color: var(--sidebar-menu-color);
    transition: var(--transition-fast);
    border-radius: 0.375rem;
    margin: 0.25rem 0.5rem;
}

.sidebar .menu-item:hover {
    background-color: var(--sidebar-menu-hover-bg);
    color: var(--sebego-primary);
}

.sidebar .menu-item.active,
.sidebar .menu-item.active:hover {
    background-color: var(--sidebar-menu-active-bg);
    color: var(--sidebar-menu-active-color);
}

.sidebar .menu-item i {
    color: var(--sidebar-menu-icon-color);
}

.sidebar .menu-item.active i {
    color: var(--bs-white);
}

.sidebar .menu-header {
    color: var(--sidebar-header-color);
    font-weight: 600;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 1rem 1rem 0.5rem;
}

/* ============================================
   LIST GROUPS
   ============================================ */

.list-group-item {
    border-color: var(--border-color);
    transition: var(--transition-fast);
}

.list-group-item:hover {
    background-color: var(--table-hover-bg);
}

.list-group-item-action:hover {
    color: var(--sebego-primary);
}

/* ============================================
   ALERTS
   ============================================ */

.alert {
    border-radius: var(--border-radius);
    border-left: 4px solid;
}

.alert-info {
    border-left-color: var(--bs-info);
}

.alert-success {
    border-left-color: var(--bs-success);
}

.alert-warning {
    border-left-color: var(--bs-warning);
}

.alert-danger {
    border-left-color: var(--bs-danger);
}

/* ============================================
   PAGINATION
   ============================================ */

.pagination .page-link {
    color: var(--sebego-primary);
    border-color: var(--border-color);
}

.pagination .page-link:hover {
    background-color: var(--sidebar-menu-hover-bg);
    border-color: var(--sebego-primary);
}

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

/* ============================================
   UTILITY CLASSES
   ============================================ */

.opacity-50 {
    opacity: 0.5;
}

.opacity-75 {
    opacity: 0.75;
}

.rounded {
    border-radius: var(--border-radius) !important;
}

.rounded-lg {
    border-radius: var(--border-radius-lg) !important;
}

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

.shadow {
    box-shadow: var(--shadow) !important;
}

.shadow-lg {
    box-shadow: var(--shadow-lg) !important;
}

/* ============================================
   DASHBOARD SPECIFIC
   ============================================ */

.dashboard-stat-card {
    border-radius: var(--card-border-radius);
    padding: 1.5rem;
    transition: var(--transition-base);
    min-height: 140px;
}

.dashboard-stat-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow);
}

.dashboard-stat-card h2 {
    font-size: 2.5rem;
    font-weight: 700;
    margin-bottom: 0.5rem;
}

.dashboard-stat-card h6 {
    font-size: 0.875rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    opacity: 0.9;
}

/* ============================================
   RESPONSIVE ADJUSTMENTS
   ============================================ */

@media (max-width: 768px) {
    :root {
        --card-spacer-x: 1rem;
        --card-spacer-y: 1rem;
        --font-size-base: 0.8125rem;
    }

    .dashboard-stat-card h2 {
        font-size: 2rem;
    }
}

/* ============================================
   PRINT STYLES
   ============================================ */

@media print {
    .sidebar,
    .btn,
    .pagination {
        display: none !important;
    }

    .card {
        border: 1px solid var(--bs-gray-300);
        box-shadow: none;
        page-break-inside: avoid;
    }
}

/* ============================================================
   ╔══════════════════════════════════════════════════════════╗
   ║  PROFESSIONAL LAW-FIRM LAYER                               ║
   ║  Navy structure · Burgundy actions · Gold hairlines       ║
   ║  Loaded last so it refines the base theme above.          ║
   ╚══════════════════════════════════════════════════════════╝
   ============================================================ */

:root {
    /* Professional palette */
    --navy:        #16273b;
    --navy-deep:   #0e1b2a;
    --navy-soft:   #21384f;
    --gold:        #b8923f;
    --gold-soft:   #cdab63;
    --burgundy:    #7a2931;
    --burgundy-dk: #5f1f26;
    --pro-ink:     #1a232e;
    --pro-slate:   #51606f;
    --pro-cloud:   #eef1f5;
    --pro-line:    #dce3ea;
    --pro-line-2:  #e7ecf1;

    /* Re-tone the working surfaces */
    --bs-body-bg: #eef1f5;
    --bs-body-color: #2f3a46;
    --card-bg: #ffffff;
    --card-border-color: #dce3ea;
    --card-border-radius: 0.4rem;
    --card-shadow: 0 1px 2px rgba(22, 39, 59, 0.05), 0 10px 26px -20px rgba(22, 39, 59, 0.4);
    --card-shadow-hover: 0 16px 40px -24px rgba(22, 39, 59, 0.42);
    --headings-color: #16273b;
    --sidebar-bg: #ffffff;
    --sidebar-border-color: #dce3ea;
    --table-border-color: #e3e9ef;
    --table-hover-bg: rgba(22, 39, 59, 0.035);
    --table-striped-bg: rgba(22, 39, 59, 0.018);
    --font-family-sans-serif: 'Libre Franklin', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --font-serif: 'Source Serif 4', Georgia, 'Times New Roman', serif;
}

/* ===== Typography ===== */
body, .wrapper, input, button, select, textarea, .form-control, .form-select {
    font-family: var(--font-family-sans-serif);
}
body {
    background-color: var(--pro-cloud);
    background-image:
        radial-gradient(60% 50% at 100% 0%, rgba(22, 39, 59, 0.035), transparent 60%),
        radial-gradient(45% 45% at 0% 100%, rgba(122, 41, 49, 0.03), transparent 60%);
    background-attachment: fixed;
}
h1, h2, h3, h4,
.content-header-title .title,
.content-header h1,
.page-title,
.dash-head__title,
.panel__title,
.kpi__value,
.casebar__count {
    font-family: var(--font-serif);
    font-optical-sizing: auto;
    letter-spacing: -0.01em;
}
.content-header-title .title,
.content-header h1 {
    font-weight: 600 !important;
    color: var(--headings-color);
}

/* ===== Sidebar ===== */
.sidebar, #main-menu {
    background-color: var(--sidebar-bg);
    border-right: 1px solid var(--sidebar-border-color);
}
.sidebar .menu-item a, #main-menu .menu-item a {
    border-radius: 0.35rem;
    font-weight: 500;
}
.sidebar .menu-item i, #main-menu .menu-item i { color: var(--navy); opacity: 0.7; }
.sidebar .menu-item:hover { background-color: rgba(22, 39, 59, 0.05); color: var(--navy); }
.sidebar .menu-item:hover i { color: var(--burgundy); opacity: 1; }
.sidebar .menu-item.active,
.sidebar .menu-item.active:hover,
#main-menu .menu-item.active > a {
    background: linear-gradient(135deg, var(--navy), var(--navy-deep)) !important;
    color: #fff !important;
    box-shadow: 0 8px 20px -12px rgba(22, 39, 59, 0.8);
}
.sidebar .menu-item.active i, #main-menu .menu-item.active i { color: var(--gold-soft) !important; opacity: 1; }
.sidebar .menu-header, #main-menu .menu-header {
    color: var(--navy);
    font-weight: 700;
    font-size: 0.66rem;
    letter-spacing: 0.16em;
    opacity: 0.85;
}
.sidebar .menu-header::after {
    content: "";
    display: block;
    height: 2px;
    width: 26px;
    margin-top: 0.4rem;
    background: var(--gold);
}

/* ===== Cards ===== */
.card { border-radius: var(--card-border-radius); background: var(--card-bg); border: 1px solid var(--card-border-color); box-shadow: var(--card-shadow); }
.card:hover { box-shadow: var(--card-shadow-hover); }
.card-header {
    background: transparent;
    border-bottom: 1px solid var(--pro-line);
    font-family: var(--font-serif);
    font-weight: 600;
    color: var(--navy);
    letter-spacing: -0.01em;
}

/* ===== Buttons ===== */
.btn { letter-spacing: 0.01em; border-radius: 0.35rem; font-weight: 500; }
.btn-primary {
    background: var(--burgundy) !important;
    border: 1px solid var(--burgundy) !important;
    color: #fff !important;
}
.btn-primary:hover, .btn-primary:focus {
    background: var(--burgundy-dk) !important;
    border-color: var(--burgundy-dk) !important;
    box-shadow: 0 12px 26px -14px rgba(122, 41, 49, 0.8);
}
.btn-outline-secondary { border-color: var(--pro-line); color: var(--pro-ink); }

/* ===== Tables ===== */
.table thead th {
    background: var(--navy);
    color: #fff;
    text-transform: uppercase;
    font-size: 0.68rem;
    letter-spacing: 0.08em;
    font-weight: 600;
    border-bottom: none;
}
.table thead th a { color: #fff !important; }
.table td { vertical-align: middle; }
.table a { color: var(--burgundy); }
.table a:hover { color: var(--burgundy-dk); }

/* ===== Badges ===== */
.badge { font-weight: 600; letter-spacing: 0.02em; padding: 0.42em 0.7em; border-radius: 0.28rem; }

/* ============================================================
   DASHBOARD — professional composition
   ============================================================ */

.dash-head {
    display: flex; align-items: flex-end; justify-content: space-between;
    gap: 1.5rem; flex-wrap: wrap;
    padding-bottom: 1.4rem; margin-bottom: 2rem;
    border-bottom: 1px solid var(--pro-line);
    position: relative;
}
.dash-head::after { content: ""; position: absolute; left: 0; bottom: -1px; width: 84px; height: 2px; background: var(--gold); }
.dash-head__eyebrow {
    font-size: 0.7rem; letter-spacing: 0.22em; text-transform: uppercase;
    color: var(--burgundy); display: flex; align-items: center; gap: 0.6rem; margin-bottom: 0.55rem; font-weight: 600;
}
.dash-head__eyebrow i { color: var(--gold); }
.dash-head__title { font-size: clamp(1.6rem, 3vw, 2.3rem); font-weight: 600; line-height: 1.05; color: var(--navy); margin: 0; }
.dash-head__meta { font-size: 0.8rem; color: var(--pro-slate); text-align: right; line-height: 1.5; }
.dash-head__meta strong { color: var(--navy); font-weight: 600; }

/* ===== KPI cards ===== */
.kpi-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.1rem; margin-bottom: 1.1rem; }
.kpi-grid--2 { grid-template-columns: repeat(2, 1fr); }
.kpi {
    --accent: var(--navy);
    position: relative;
    background:
        linear-gradient(180deg, #ffffff, color-mix(in srgb, var(--accent) 4%, #ffffff));
    border: 1px solid var(--card-border-color);
    border-radius: 0.65rem;
    padding: 1.5rem 1.55rem 1.4rem;
    overflow: hidden;
    box-shadow: 0 1px 2px rgba(22, 39, 59, 0.05), 0 12px 30px -24px rgba(22, 39, 59, 0.5);
    transition: transform 0.4s cubic-bezier(.2,.7,.2,1), box-shadow 0.4s ease, border-color 0.4s ease;
}
/* top accent hairline */
.kpi::before {
    content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px;
    background: linear-gradient(90deg, var(--accent), color-mix(in srgb, var(--accent) 28%, transparent) 70%, transparent);
}
/* soft corner glow */
.kpi::after {
    content: ""; position: absolute; right: -36px; top: -36px; width: 132px; height: 132px; border-radius: 50%;
    background: radial-gradient(circle, color-mix(in srgb, var(--accent) 17%, transparent), transparent 68%);
    pointer-events: none; opacity: 0.75;
    transition: transform 0.45s cubic-bezier(.2,.7,.2,1), opacity 0.4s ease;
}
.kpi:hover {
    transform: translateY(-5px);
    border-color: color-mix(in srgb, var(--accent) 30%, var(--card-border-color));
    box-shadow: 0 24px 50px -26px color-mix(in srgb, var(--accent) 55%, rgba(22, 39, 59, 0.55));
}
.kpi:hover::after { transform: scale(1.18); opacity: 1; }
.kpi:hover .kpi__bg { transform: rotate(-7deg) scale(1.07); opacity: 0.10; }
.kpi:hover .kpi__icon { transform: translateY(-2px); }

/* faint watermark icon */
.kpi__bg {
    position: absolute; right: -0.5rem; bottom: -1.5rem; font-size: 6.4rem; line-height: 1;
    color: var(--accent); opacity: 0.07; pointer-events: none;
    transition: transform 0.5s cubic-bezier(.2,.7,.2,1), opacity 0.4s ease;
}

.kpi__top { position: relative; z-index: 1; display: flex; align-items: center; justify-content: space-between; }
.kpi__label { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--pro-slate); font-weight: 600; }
.kpi__icon {
    width: 2.7rem; height: 2.7rem; display: grid; place-items: center; border-radius: 50%;
    font-size: 1.02rem; color: var(--accent);
    background: color-mix(in srgb, var(--accent) 12%, #ffffff);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 20%, transparent) inset,
                0 6px 14px -8px color-mix(in srgb, var(--accent) 65%, transparent);
    transition: transform 0.4s cubic-bezier(.2,.7,.2,1);
}
.kpi__value {
    position: relative; z-index: 1;
    font-size: 3.1rem; font-weight: 600; line-height: 1; margin-top: 1rem;
    color: var(--navy); font-variant-numeric: lining-nums tabular-nums; letter-spacing: -0.02em;
}
.kpi__sub { position: relative; z-index: 1; margin-top: 0.5rem; font-size: 0.76rem; color: var(--pro-slate); }
.kpi__caption {
    position: relative; z-index: 1; margin-top: 0.75rem; padding-top: 0.7rem;
    border-top: 1px solid color-mix(in srgb, var(--accent) 12%, var(--pro-line-2));
    font-size: 0.74rem; color: var(--pro-slate);
    display: flex; align-items: center; gap: 0.45rem;
}
.kpi__caption i { color: var(--accent); font-size: 0.74rem; }
.kpi__caption--alert { color: var(--accent); font-weight: 600; }
.kpi--primary { --accent: #7a2931; }
.kpi--success { --accent: #2f7d5b; }
.kpi--warning { --accent: #b07d2a; }
.kpi--danger  { --accent: #b23a4a; }
.kpi--info    { --accent: #2c5c86; }
.kpi--neutral { --accent: #5b6776; }

/* ===== Panels ===== */
.panel { background: #fff; border: 1px solid var(--card-border-color); border-radius: 0.45rem; overflow: hidden; height: 100%; box-shadow: var(--card-shadow); }
.panel__head { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 1.1rem 1.4rem; border-bottom: 1px solid var(--pro-line); }
.panel__title { font-size: 1.1rem; font-weight: 600; margin: 0; color: var(--navy); display: flex; align-items: center; gap: 0.6rem; }
.panel__title i { color: var(--gold); font-size: 0.9rem; }
.panel__link { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--burgundy); text-decoration: none; white-space: nowrap; font-weight: 600; }
.panel__link:hover { color: var(--burgundy-dk); }
.panel__body { padding: 0; }

.dash-list { list-style: none; margin: 0; padding: 0; }
.dash-list__item { display: block; padding: 1rem 1.4rem; border-bottom: 1px solid var(--pro-line-2); text-decoration: none; color: inherit; transition: background 0.25s ease; position: relative; }
.dash-list__item:last-child { border-bottom: none; }
.dash-list__item::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 0; background: var(--burgundy); transition: width 0.3s ease; }
.dash-list__item:hover { background: var(--table-hover-bg); }
.dash-list__item:hover::before { width: 3px; }
.dash-list__row { display: flex; align-items: flex-start; justify-content: space-between; gap: 0.8rem; }
.dash-list__primary { font-weight: 600; color: var(--navy); display: flex; align-items: center; gap: 0.5rem; flex-wrap: wrap; }
.dash-list__desc { margin: 0.3rem 0 0; font-size: 0.84rem; color: var(--pro-slate); }
.dash-list__metaline { margin-top: 0.4rem; font-size: 0.76rem; color: var(--pro-slate); opacity: 0.85; }
.dash-list__metaline i { color: var(--gold); }
.dash-list__date { font-size: 0.74rem; color: var(--pro-slate); white-space: nowrap; }

/* Empty states */
.dash-empty { text-align: center; padding: 3rem 1.5rem; color: var(--pro-slate); }
.dash-empty i { font-size: 2rem; color: var(--navy); opacity: 0.3; margin-bottom: 0.9rem; }
.dash-empty p { margin: 0; font-size: 0.9rem; }

/* ===== Case-type distribution bars ===== */
.casebars { display: flex; flex-direction: column; gap: 1rem; padding: 1.4rem; }
.casebar__row { display: grid; grid-template-columns: 1fr; gap: 0.4rem; }
.casebar__meta { display: flex; align-items: baseline; justify-content: space-between; }
.casebar__name { font-size: 0.86rem; font-weight: 600; color: var(--navy); }
.casebar__count { font-size: 1.05rem; color: var(--burgundy); font-weight: 600; }
.casebar__track { height: 7px; background: rgba(22, 39, 59, 0.08); border-radius: 99px; overflow: hidden; }
.casebar__fill { height: 100%; border-radius: 99px; background: linear-gradient(90deg, var(--gold), var(--burgundy)); transform-origin: left; animation: barGrow 1s cubic-bezier(.2,.7,.2,1) both; }
@keyframes barGrow { from { transform: scaleX(0); } to { transform: scaleX(1); } }

/* Entrance for dashboard blocks */
.dash-rise { opacity: 0; transform: translateY(16px); animation: dashRise 0.7s cubic-bezier(.2,.7,.2,1) forwards; }
@keyframes dashRise { to { opacity: 1; transform: none; } }
.dash-rise.delay-1 { animation-delay: 0.06s; }
.dash-rise.delay-2 { animation-delay: 0.12s; }
.dash-rise.delay-3 { animation-delay: 0.18s; }
.dash-rise.delay-4 { animation-delay: 0.24s; }

@media (prefers-reduced-motion: reduce) {
    .dash-rise, .casebar__fill { animation: none; opacity: 1; transform: none; }
}
@media (max-width: 992px) {
    .kpi-grid { grid-template-columns: repeat(2, 1fr); }
    .kpi__value { font-size: 2.5rem; }
}
@media (max-width: 540px) {
    .kpi-grid, .kpi-grid--2 { grid-template-columns: 1fr; }
}

/* ============================================================
   ╔══════════════════════════════════════════════════════════╗
   ║  DARK MODE                                                 ║
   ║  EasyAdmin toggles body.ea-dark-scheme (also for "auto").  ║
   ║  Re-tone the custom professional layer for dark surfaces.  ║
   ╚══════════════════════════════════════════════════════════╝
   ============================================================ */

body.ea-dark-scheme {
    --surface-d:    #16212e;   /* cards / panels / sidebar */
    --surface-d2:   #1b2836;   /* raised / table head     */
    --bg-d:         #0e1722;   /* page background         */
    --heading-d:    #eaf0f6;   /* primary text / headings */
    --text-d:       #c8d3df;
    --muted-d:      #93a3b5;   /* secondary text          */
    --line-d:       rgba(255, 255, 255, 0.10);
    --line-d-2:     rgba(255, 255, 255, 0.06);

    /* keep Bootstrap-ish vars consistent for any EA-shared bits */
    --card-bg: #16212e;
    --card-border-color: rgba(255, 255, 255, 0.10);
    --table-hover-bg: rgba(255, 255, 255, 0.04);

    /* override EasyAdmin's own near-black dark surfaces with our navy
       (otherwise the content/datagrid panel renders #171717 / #0a0a0a) */
    --body-bg: #0e1722;
    --content-bg: #111c29;
}

/* ----- Page surface ----- */
body.ea-dark-scheme {
    background-color: var(--bg-d);
    background-image:
        radial-gradient(60% 50% at 100% 0%, rgba(122, 41, 49, 0.16), transparent 60%),
        radial-gradient(45% 45% at 0% 100%, rgba(184, 146, 63, 0.07), transparent 60%);
}

/* ----- Text that was navy in light mode ----- */
body.ea-dark-scheme h1,
body.ea-dark-scheme h2,
body.ea-dark-scheme h3,
body.ea-dark-scheme h4,
body.ea-dark-scheme .content-header-title .title,
body.ea-dark-scheme .content-header h1,
body.ea-dark-scheme .dash-head__title,
body.ea-dark-scheme .panel__title,
body.ea-dark-scheme .kpi__value,
body.ea-dark-scheme .dash-list__primary,
body.ea-dark-scheme .casebar__name {
    color: var(--heading-d);
}
body.ea-dark-scheme .dash-head__meta,
body.ea-dark-scheme .dash-head__meta strong { color: var(--muted-d); }
body.ea-dark-scheme .dash-head { border-bottom-color: var(--line-d); }

/* ----- Sidebar ----- */
body.ea-dark-scheme .sidebar,
body.ea-dark-scheme #main-menu {
    background-color: var(--surface-d);
    border-right-color: var(--line-d);
}
body.ea-dark-scheme .sidebar .menu-item i,
body.ea-dark-scheme #main-menu .menu-item i { color: #b9c6d6; opacity: 0.85; }
body.ea-dark-scheme .sidebar .menu-item:hover { background-color: rgba(255, 255, 255, 0.05); color: #fff; }
body.ea-dark-scheme .sidebar .menu-item:hover i { color: var(--gold-soft); opacity: 1; }
body.ea-dark-scheme .sidebar .menu-header,
body.ea-dark-scheme #main-menu .menu-header { color: #cdd8e4; }

/* ----- Cards ----- */
body.ea-dark-scheme .card { background: var(--surface-d); border-color: var(--line-d); }
body.ea-dark-scheme .card-header { color: var(--heading-d); border-bottom-color: var(--line-d); }

/* ----- KPI cards ----- */
body.ea-dark-scheme .kpi {
    background: linear-gradient(180deg, var(--surface-d), color-mix(in srgb, var(--accent) 12%, var(--surface-d)));
    border-color: var(--line-d);
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.3), 0 14px 32px -24px rgba(0, 0, 0, 0.8);
}
body.ea-dark-scheme .kpi:hover {
    border-color: color-mix(in srgb, var(--accent) 45%, var(--line-d));
    box-shadow: 0 24px 50px -26px color-mix(in srgb, var(--accent) 70%, #000);
}
body.ea-dark-scheme .kpi__value { color: var(--heading-d); }
body.ea-dark-scheme .kpi__label,
body.ea-dark-scheme .kpi__sub,
body.ea-dark-scheme .kpi__caption { color: var(--muted-d); }
body.ea-dark-scheme .kpi__icon {
    background: color-mix(in srgb, var(--accent) 26%, var(--surface-d));
    color: color-mix(in srgb, var(--accent) 55%, #ffffff);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 35%, transparent) inset,
                0 6px 14px -8px color-mix(in srgb, var(--accent) 80%, transparent);
}
body.ea-dark-scheme .kpi__caption { border-top-color: color-mix(in srgb, var(--accent) 30%, var(--line-d)); }
body.ea-dark-scheme .kpi__caption i,
body.ea-dark-scheme .kpi__caption--alert { color: color-mix(in srgb, var(--accent) 55%, #ffffff); }
body.ea-dark-scheme .kpi__bg { opacity: 0.10; }

/* ----- Panels & lists ----- */
body.ea-dark-scheme .panel { background: var(--surface-d); border-color: var(--line-d); }
body.ea-dark-scheme .panel__head { border-bottom-color: var(--line-d); }
body.ea-dark-scheme .dash-list__item { border-bottom-color: var(--line-d-2); color: var(--text-d); }
body.ea-dark-scheme .dash-list__item:hover { background: rgba(255, 255, 255, 0.04); }
body.ea-dark-scheme .dash-list__desc,
body.ea-dark-scheme .dash-list__metaline,
body.ea-dark-scheme .dash-list__date { color: var(--muted-d); }
body.ea-dark-scheme .dash-empty { color: var(--muted-d); }
body.ea-dark-scheme .dash-empty i { color: #ffffff; opacity: 0.22; }

/* ----- Tables ----- */
body.ea-dark-scheme .table { color: var(--text-d); }
body.ea-dark-scheme .table thead th { background: #101c29; color: #eaf0f6; }
body.ea-dark-scheme .table td { border-color: var(--line-d-2); }
body.ea-dark-scheme .table a { color: color-mix(in srgb, var(--burgundy) 45%, #ffffff); }

/* ----- Case-type bars ----- */
body.ea-dark-scheme .casebar__track { background: rgba(255, 255, 255, 0.08); }
body.ea-dark-scheme .casebar__count { color: color-mix(in srgb, var(--burgundy) 50%, #ffffff); }

/* ----- Buttons / misc ----- */
body.ea-dark-scheme .btn-outline-secondary { border-color: var(--line-d); color: var(--text-d); }

/* ============================================================
   CONTENT WRAPPER — rounded content surface
   ============================================================ */
.content-wrapper {
    /* recessed surface so the white/raised inner cards float above it */
    background: #f4f7fa;
    border: 1px solid var(--card-border-color);
    border-radius: 16px;
    padding: 16px;
    box-shadow: var(--card-shadow);
}
body.ea-dark-scheme .content-wrapper {
    background: #111c29;   /* darker than cards (#16212e), above the page (#0e1722) */
    border-color: var(--line-d);
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.3), 0 18px 40px -28px rgba(0, 0, 0, 0.85);
}

/* ============================================================
   PAGE HEADER (custom EA layout: .ea-page-header)
   Generic title bar shown on every CRUD page; themed both modes.
   ============================================================ */
.ea-page-header {
    display: flex;
    flex-direction: row-reverse;   /* title (last child) left, actions right */
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.6rem 1.5rem;
    padding: 0 0 1.1rem;
    margin: 0 0 1.6rem;
    border-bottom: 1px solid var(--pro-line);
    position: relative;
}
.ea-page-header::after {
    content: ""; position: absolute; left: 0; bottom: -1px;
    width: 72px; height: 2px; background: var(--gold);
}
.ea-page-header .content-header-title { margin: 0 !important; flex: 1 1 auto; min-width: 0; }
.ea-page-header .content-header-title h1 {
    font-family: var(--font-serif);
    font-weight: 600;
    font-size: 1.5rem !important;
    line-height: 1.12;
    letter-spacing: -0.01em;
    color: var(--navy);
    margin: 0;
}
.ea-page-header .content-header-title h1 small { color: var(--pro-slate); font-weight: 400; }
.ea-page-header .page-actions { display: flex; align-items: center; flex-wrap: wrap; gap: 0.5rem; margin: 0; }

body.ea-dark-scheme .ea-page-header { border-bottom-color: var(--line-d); }
body.ea-dark-scheme .ea-page-header .content-header-title h1 { color: var(--heading-d); }
body.ea-dark-scheme .ea-page-header .content-header-title h1 small { color: var(--muted-d); }

/* ----- Brighter accents so they read on dark ----- */
body.ea-dark-scheme { --burgundy-d: #c45f6b; }
body.ea-dark-scheme .kpi--primary { --accent: #b8505b; }
body.ea-dark-scheme .kpi--success { --accent: #46b486; }
body.ea-dark-scheme .kpi--warning { --accent: #d8a649; }
body.ea-dark-scheme .kpi--danger  { --accent: #d96275; }
body.ea-dark-scheme .kpi--info    { --accent: #5e9dd2; }
body.ea-dark-scheme .kpi--neutral { --accent: #93a4b8; }
body.ea-dark-scheme .kpi__icon { color: var(--accent); }
body.ea-dark-scheme .kpi__caption i,
body.ea-dark-scheme .kpi__caption--alert { color: var(--accent); }
body.ea-dark-scheme .dash-head__eyebrow { color: var(--burgundy-d); }
body.ea-dark-scheme .panel__link { color: var(--burgundy-d); }
body.ea-dark-scheme .panel__link:hover { color: #db818b; }
body.ea-dark-scheme .casebar__count,
body.ea-dark-scheme .table a { color: var(--burgundy-d); }
body.ea-dark-scheme .dash-list__item:hover::before,
body.ea-dark-scheme .dash-list__item::before { background: var(--burgundy-d); }

/* ----- Sidebar brand logo ----- */
.main-header #header-logo img,
.sidebar #header-logo img {
    display: block;
    max-width: 100%;
    height: auto;
    border-radius: 6px;
}
/* the logo artwork has a light background; frame it cleanly on the dark sidebar */
body.ea-dark-scheme .main-header #header-logo img,
body.ea-dark-scheme .sidebar #header-logo img {
    box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.10);
}
