/**
 * ESD Unified Design System
 * Единый CSS файл для всех страниц ESD
 * Объединяет: app.css, esd-design-system.css, dashboard-v2.css, esd-modern.css
 * 
 * @version 2.0.0
 * @date 2026-02-07
 */

/* ========================================
   BASE STYLES (from app.css)
   ======================================== */
html, body { height: 100%; }

body {
    background-color: var(--bs-body-bg);
    color: var(--bs-body-color);
}

h1, .page-title { font-weight: 600; margin-bottom: 20px; }

/* Theme-aware table striped background */
:root { --app-table-striped-bg: rgba(0, 0, 0, .04); }
[data-bs-theme="dark"] { --app-table-striped-bg: rgba(255, 255, 255, .06); }

/* Table header colors */
:root {
    --app-thead-bg: #dee2e6;
    --app-thead-color: #212529;
}

/* Thesis contracts scrollable container */
.thesis-table-scroll {
    max-height: 70vh;
    overflow: auto;
}
.thesis-table-scroll thead th {
    position: sticky;
    top: 0;
    z-index: 2;
    background: var(--app-thead-bg);
    color: var(--app-thead-color);
}
[data-bs-theme="dark"] .thesis-table-scroll thead th {
    background: var(--bs-dark);
    color: var(--bs-light);
}
[data-bs-theme="dark"] {
    --app-thead-bg: #2e3237;
    --app-thead-color: #e9ecef;
}

/* Dark theme overrides */
[data-bs-theme="dark"] .table-light {
    background-color: #343a40 !important;
    color: #f8f9fa !important;
}

[data-bs-theme="dark"] .bg-light {
    background-color: #2b3035 !important;
    color: var(--bs-body-color) !important;
    border-color: rgba(255,255,255,.1) !important;
}

[data-bs-theme="dark"] .card,
[data-bs-theme="dark"] .modal-content,
[data-bs-theme="dark"] .dropdown-menu {
    background-color: var(--bs-body-bg);
    border-color: rgba(255,255,255,.1);
}

[data-bs-theme="dark"] hr,
[data-bs-theme="dark"] .border-top,
[data-bs-theme="dark"] .border-bottom,
[data-bs-theme="dark"] .border-start,
[data-bs-theme="dark"] .border-end {
    border-color: rgba(255,255,255,.12) !important;
}

/* Navbar */
.navbar-brand .brand-icon { margin-right: .5rem; }
.navbar .nav-link.active, .navbar .nav-link:focus { font-weight: 600; }
[data-bs-theme="dark"] .navbar-brand img.logo { filter: invert(1) hue-rotate(180deg); }

/* Form controls in dark theme */
[data-bs-theme="dark"] .form-control,
[data-bs-theme="dark"] .form-select {
    background-color: #2b3035;
    color: var(--bs-body-color);
    border-color: rgba(255,255,255,.15);
}
[data-bs-theme="dark"] .form-control:focus,
[data-bs-theme="dark"] .form-select:focus {
    border-color: rgba(255,255,255,.25);
    box-shadow: 0 0 0 .2rem rgba(13,110,253,.15);
}

/* Close button in dark theme */
[data-bs-theme="dark"] .btn-close {
    filter: invert(1) grayscale(100%) brightness(200%);
    opacity: .85;
}
[data-bs-theme="dark"] .btn-close:hover {
    opacity: 1;
}

/* Dropdown in dark theme */
[data-bs-theme="dark"] .dropdown-menu {
    background-color: #2b3035;
    color: var(--bs-body-color);
    border-color: rgba(255,255,255,.12);
}
[data-bs-theme="dark"] .dropdown-item {
    color: var(--bs-body-color);
}
[data-bs-theme="dark"] .dropdown-item:hover,
[data-bs-theme="dark"] .dropdown-item:focus {
    background-color: rgba(255,255,255,.06);
}

/* ITSM v2: Ticket description can contain inline HTML colors that become unreadable in dark theme */
[data-bs-theme="dark"] #ticket-description,
[data-bs-theme="dark"] #ticket-description * {
    color: var(--bs-body-color) !important;
}

/* Badges */
.badge-submitted {
    background-color: #28a745;
    color: #fff;
    padding: 5px 10px;
    border-radius: 0.25rem;
}
.badge-not-submitted {
    background-color: #dc3545;
    color: #fff;
    padding: 5px 10px;
    border-radius: 0.25rem;
}

/* Utilities */
.actions-cell { white-space: nowrap; text-align: right; }
.actions-cell .btn { margin-bottom: 2px; margin-right: 2px; }
.truncate { max-width: 320px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
input[type="file"] { display: none; }

/* Card shadows */
.card-shadow { box-shadow: 0 0.25rem 0.5rem rgba(0,0,0,.05); }
[data-bs-theme="dark"] .card-shadow { box-shadow: 0 0.25rem 0.75rem rgba(0,0,0,.5); }
.card canvas { background: transparent; }
.card.shadow-sm { box-shadow: 0 .125rem .5rem rgba(0,0,0,.08), 0 .25rem 1rem rgba(0,0,0,.06); }

/* Sticky table header */
table thead.sticky-top {
    box-shadow: 0 1px 0 var(--bs-border-color);
}

/* Table hover */
.table-hover tbody tr:hover {
    background-color: var(--bs-tertiary-bg);
}

/* Form elements */
.form-control, .form-select, .btn { border-radius: .5rem; }
.text-body-secondary.small { letter-spacing: .2px; }
.badge.rounded-pill { padding-top: .4em; padding-bottom: .4em; }
.table .form-label.small { margin-bottom: .25rem; }

/* AD Inventory styles */
.ad-user-avatar {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 1.05rem;
    background: var(--bs-primary);
    color: #fff;
}
[data-bs-theme="dark"] .ad-user-avatar {
    background: rgba(var(--bs-primary-rgb), .35);
    color: #fff;
}

/* User Avatar (for users table) */
.user-avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    min-width: 2rem;
    min-height: 2rem;
    border-radius: 50%;
    font-weight: 600;
    font-size: 0.875rem;
    background: var(--bs-primary);
    color: #fff;
    margin-right: 0.75rem;
    flex-shrink: 0;
}

[data-bs-theme="dark"] .user-avatar {
    background: rgba(var(--bs-primary-rgb), .35);
    color: #fff;
}

.ad-password-expired {
    background-color: rgba(var(--bs-danger-rgb), .08);
    border-left: 4px solid var(--bs-danger);
}
[data-bs-theme="dark"] .ad-password-expired {
    background-color: rgba(var(--bs-danger-rgb), .18);
}
.ad-password-warning {
    background-color: rgba(var(--bs-warning-rgb), .1);
    border-left: 4px solid var(--bs-warning);
}
[data-bs-theme="dark"] .ad-password-warning {
    background-color: rgba(var(--bs-warning-rgb), .18);
}
.ad-password-info {
    background-color: rgba(var(--bs-info-rgb), .1);
    border-left: 4px solid var(--bs-info);
}
[data-bs-theme="dark"] .ad-password-info {
    background-color: rgba(var(--bs-info-rgb), .2);
}
.ad-table-empty {
    padding: 2.5rem 1rem;
}

/* ========================================
   CSS Variables
   ======================================== */
:root {
    /* Тени */
    --esd-card-shadow: 0 2px 8px rgba(0,0,0,0.08);
    --esd-card-shadow-hover: 0 12px 32px rgba(0,0,0,0.12);
    --esd-card-shadow-sm: 0 1px 3px rgba(0,0,0,0.08);
    
    /* Градиенты */
    --esd-gradient-success: linear-gradient(135deg, #28a745 0%, #20c997 100%);
    --esd-gradient-warning: linear-gradient(135deg, #ffc107 0%, #fd7e14 100%);
    --esd-gradient-danger: linear-gradient(135deg, #dc3545 0%, #e83e8c 100%);
    --esd-gradient-primary: linear-gradient(135deg, #0d6efd 0%, #6610f2 100%);
    --esd-gradient-info: linear-gradient(135deg, #0dcaf0 0%, #6610f2 100%);
    --esd-gradient-secondary: linear-gradient(135deg, #6c757d 0%, #495057 100%);
    
    /* Радиусы */
    --esd-radius-sm: 0.375rem;
    --esd-radius-md: 0.5rem;
    --esd-radius-lg: 0.875rem;
    --esd-radius-xl: 1rem;
    
    /* Переходы */
    --esd-transition-fast: 0.2s ease;
    --esd-transition-normal: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    --esd-transition-slow: 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ========================================
   Page Header
   ======================================== */
.esd-page-header {
    margin-bottom: 1.5rem;
}

.esd-page-header h1,
.esd-page-header .h3 {
    font-weight: 600;
    margin-bottom: 0.25rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.esd-page-header h1 i,
.esd-page-header .h3 i {
    color: var(--bs-primary);
}

.esd-page-header .text-muted {
    font-size: 0.9rem;
}

/* ========================================
   Cards
   ======================================== */
.esd-card {
    border-radius: var(--esd-radius-xl);
    border: 1px solid var(--bs-border-color);
    background: var(--bs-body-bg);
    transition: all var(--esd-transition-slow);
    box-shadow: var(--esd-card-shadow);
    position: relative;
    overflow: hidden;
}

.esd-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: transparent;
    transition: background var(--esd-transition-normal);
}

.esd-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--esd-card-shadow-hover);
    border-color: transparent;
}

.esd-card:hover::before {
    background: var(--esd-gradient-primary);
}

.esd-card-header {
    padding: 1.25rem 1.25rem 0.75rem;
    border-bottom: 1px solid var(--bs-border-color-translucent);
    background: linear-gradient(180deg, var(--bs-tertiary-bg) 0%, transparent 100%);
}

.esd-card-body {
    padding: 1rem 1.25rem;
}

.esd-card-footer {
    padding: 0.875rem 1.25rem;
    background: var(--bs-tertiary-bg);
    border-top: 1px solid var(--bs-border-color-translucent);
}

/* Card без hover-эффекта */
.esd-card-static {
    border-radius: var(--esd-radius-lg);
    border: none;
    background: var(--bs-body-bg);
    box-shadow: 0 2px 12px rgba(0,0,0,0.08);
}

/* ========================================
   Stats Cards (documents_v1 style)
   ======================================== */
.stats-card {
    border-radius: 1rem;
    padding: 1.5rem;
    text-align: center;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    overflow: hidden;
}

.stats-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, rgba(255,255,255,0.1) 0%, transparent 50%);
    pointer-events: none;
}

.stats-card:hover {
    transform: translateY(-4px) scale(1.02);
    box-shadow: 0 8px 24px rgba(0,0,0,0.1);
}

.stats-number {
    font-size: 2.75rem;
    font-weight: 800;
    line-height: 1;
    text-shadow: 0 2px 4px rgba(0,0,0,0.1);
}

.stats-card .text-muted {
    font-weight: 500;
    margin-top: 0.5rem;
    font-size: 0.875rem;
}

/* ESD Stats Cards (alias) */
.esd-stats-card {
    border-radius: var(--esd-radius-xl);
    padding: 1.5rem;
    text-align: center;
    transition: all var(--esd-transition-normal);
    position: relative;
    overflow: hidden;
    color: white;
}

.esd-stats-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, rgba(255,255,255,0.1) 0%, transparent 50%);
    pointer-events: none;
}

.esd-stats-card:hover {
    transform: translateY(-4px) scale(1.02);
    box-shadow: 0 8px 24px rgba(0,0,0,0.15);
}

.esd-stats-card.bg-primary { background: var(--esd-gradient-primary); }
.esd-stats-card.bg-success { background: var(--esd-gradient-success); }
.esd-stats-card.bg-warning { background: var(--esd-gradient-warning); color: #212529; }
.esd-stats-card.bg-danger { background: var(--esd-gradient-danger); }
.esd-stats-card.bg-info { background: var(--esd-gradient-info); }
.esd-stats-card.bg-secondary { background: var(--esd-gradient-secondary); }

.esd-stats-number {
    font-size: 2.75rem;
    font-weight: 800;
    line-height: 1;
    text-shadow: 0 2px 4px rgba(0,0,0,0.1);
}

.esd-stats-label {
    font-weight: 500;
    margin-top: 0.5rem;
    font-size: 0.875rem;
    opacity: 0.9;
}

.esd-stats-icon {
    font-size: 2.5rem;
    opacity: 0.3;
    position: absolute;
    right: 1rem;
    top: 50%;
    transform: translateY(-50%);
}

/* Компактные stats карточки */
.esd-stats-card-sm {
    padding: 1rem;
}

.esd-stats-card-sm .esd-stats-number {
    font-size: 2rem;
}

/* ========================================
   Tabs (documents_v1 style)
   ======================================== */
.nav-tabs-custom {
    border-bottom: 2px solid var(--bs-border-color);
    gap: 0.25rem;
}

.nav-tabs-custom .nav-link {
    border: none;
    border-bottom: 3px solid transparent;
    color: var(--bs-secondary-color);
    padding: 0.875rem 1.25rem;
    font-weight: 500;
    transition: all 0.25s ease;
    border-radius: 0.5rem 0.5rem 0 0;
    margin-bottom: -2px;
    position: relative;
}

.nav-tabs-custom .nav-link:hover {
    background: var(--bs-tertiary-bg);
    color: var(--bs-body-color);
}

.nav-tabs-custom .nav-link.active {
    color: var(--bs-primary);
    border-bottom-color: var(--bs-primary);
    background: linear-gradient(180deg, var(--bs-tertiary-bg) 0%, transparent 100%);
    font-weight: 600;
}

.nav-tabs-custom .nav-link .badge {
    transition: all 0.25s ease;
    font-weight: 600;
}

.nav-tabs-custom .nav-link:hover .badge {
    transform: scale(1.1);
}

/* Alias for backward compatibility */
.esd-tabs {
    border-bottom: 2px solid var(--bs-border-color);
    gap: 0.25rem;
}

.esd-tabs .nav-link {
    border: none;
    border-bottom: 3px solid transparent;
    color: var(--bs-secondary-color);
    padding: 0.875rem 1.25rem;
    font-weight: 500;
    transition: all 0.25s ease;
    border-radius: var(--esd-radius-md) var(--esd-radius-md) 0 0;
    margin-bottom: -2px;
    position: relative;
}

.esd-tabs .nav-link:hover {
    background: var(--bs-tertiary-bg);
    color: var(--bs-body-color);
}

.esd-tabs .nav-link.active {
    color: var(--bs-primary);
    border-bottom-color: var(--bs-primary);
    background: linear-gradient(180deg, var(--bs-tertiary-bg) 0%, transparent 100%);
    font-weight: 600;
}

.esd-tabs .nav-link .badge {
    transition: all 0.25s ease;
    font-weight: 600;
}

.esd-tabs .nav-link:hover .badge {
    transform: scale(1.1);
}

/* ========================================
   Tables
   ======================================== */
.esd-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    border-radius: var(--esd-radius-lg);
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}

.esd-table thead {
    position: sticky;
    top: 0;
    z-index: 10;
}

.esd-table th {
    background: linear-gradient(180deg, var(--bs-tertiary-bg) 0%, var(--bs-secondary-bg) 100%);
    font-weight: 600;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 1rem;
    border-bottom: 2px solid var(--bs-border-color);
    white-space: nowrap;
    color: var(--bs-secondary-color);
}

.esd-table td {
    padding: 1rem;
    border-bottom: 1px solid var(--bs-border-color-translucent);
    vertical-align: middle;
    background: var(--bs-body-bg);
    transition: background var(--esd-transition-fast);
}

.esd-table tbody tr {
    transition: all var(--esd-transition-fast);
}

.esd-table tbody tr:hover td {
    background: var(--bs-tertiary-bg);
}

.esd-table tbody tr:last-child td {
    border-bottom: none;
}

/* Clickable rows */
.esd-table tbody tr.clickable {
    cursor: pointer;
}

/* Bootstrap table унификация под documents_v1 стиль */
.card .table,
.card-body .table {
    margin-bottom: 0;
}

.card .table thead th,
.card-body .table thead th {
    background: linear-gradient(180deg, var(--bs-tertiary-bg) 0%, var(--bs-secondary-bg) 100%);
    font-weight: 600;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    padding: 0.875rem 1rem;
    border-bottom: 2px solid var(--bs-border-color);
    white-space: nowrap;
    color: var(--bs-secondary-color);
    vertical-align: middle;
}

.card .table tbody td,
.card-body .table tbody td {
    padding: 0.875rem 1rem;
    border-bottom: 1px solid var(--bs-border-color-translucent);
    vertical-align: middle;
    background: var(--bs-body-bg);
    transition: background 0.2s ease;
}

.card .table-hover tbody tr:hover td,
.card-body .table-hover tbody tr:hover td {
    background: var(--bs-tertiary-bg);
}

.card .table tbody tr:last-child td,
.card-body .table tbody tr:last-child td {
    border-bottom: none;
}

/* Sticky header для таблиц */
.table-responsive .table thead {
    position: sticky;
    top: 0;
    z-index: 10;
}

/* Улучшенный table-light для заголовков */
.table thead.table-light th {
    background: linear-gradient(180deg, var(--bs-tertiary-bg) 0%, var(--bs-secondary-bg) 100%);
    border-bottom: 2px solid var(--bs-border-color);
}

/* Тёмная тема для Bootstrap таблиц */
[data-bs-theme="dark"] .card .table tbody td,
[data-bs-theme="dark"] .card-body .table tbody td {
    background: var(--bs-dark);
}

[data-bs-theme="dark"] .card .table-hover tbody tr:hover td,
[data-bs-theme="dark"] .card-body .table-hover tbody tr:hover td {
    background: var(--bs-gray-800);
}

[data-bs-theme="dark"] .card .table thead th,
[data-bs-theme="dark"] .card-body .table thead th,
[data-bs-theme="dark"] .table thead.table-light th {
    background: linear-gradient(180deg, var(--bs-gray-800) 0%, var(--bs-gray-900) 100%);
}

/* ========================================
   Filters Card
   ======================================== */
.esd-filters {
    border-radius: var(--esd-radius-lg);
    border: none;
    box-shadow: 0 2px 12px rgba(0,0,0,0.08);
    margin-bottom: 1.5rem;
}

.esd-filters .form-control,
.esd-filters .form-select {
    border-radius: var(--esd-radius-md);
    transition: all var(--esd-transition-fast);
}

.esd-filters .form-control:focus,
.esd-filters .form-select:focus {
    box-shadow: 0 0 0 3px rgba(13, 110, 253, 0.15);
}

/* ========================================
   Empty State
   ======================================== */
.esd-empty-state {
    text-align: center;
    padding: 5rem 2rem;
    color: var(--bs-secondary-color);
    background: linear-gradient(135deg, var(--bs-tertiary-bg) 0%, transparent 100%);
    border-radius: var(--esd-radius-xl);
    margin: 1rem 0;
}

.esd-empty-state i {
    font-size: 5rem;
    margin-bottom: 1.5rem;
    opacity: 0.4;
    color: var(--bs-primary);
}

.esd-empty-state h5 {
    font-weight: 600;
    margin-bottom: 0.75rem;
    color: var(--bs-body-color);
}

.esd-empty-state p {
    max-width: 400px;
    margin: 0 auto;
}

/* ========================================
   Skeleton Loading
   ======================================== */
.esd-skeleton {
    border-radius: var(--esd-radius-xl);
    border: 1px solid var(--bs-border-color);
    background: var(--bs-body-bg);
    padding: 1.5rem;
    min-height: 200px;
    box-shadow: var(--esd-card-shadow);
}

.esd-skeleton-line {
    height: 1rem;
    background: linear-gradient(90deg, var(--bs-tertiary-bg) 25%, var(--bs-secondary-bg) 50%, var(--bs-tertiary-bg) 75%);
    background-size: 200% 100%;
    animation: esd-skeleton-loading 1.5s ease-in-out infinite;
    border-radius: 6px;
    margin-bottom: 0.75rem;
}

.esd-skeleton-line.short { width: 40%; }
.esd-skeleton-line.medium { width: 70%; }
.esd-skeleton-line.long { width: 90%; }

.esd-skeleton-circle {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: linear-gradient(90deg, var(--bs-tertiary-bg) 25%, var(--bs-secondary-bg) 50%, var(--bs-tertiary-bg) 75%);
    background-size: 200% 100%;
    animation: esd-skeleton-loading 1.5s ease-in-out infinite;
}

@keyframes esd-skeleton-loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* ========================================
   Pagination
   ======================================== */
.esd-pagination .pagination {
    gap: 0.25rem;
}

.esd-pagination .page-link {
    border-radius: var(--esd-radius-md);
    padding: 0.5rem 1rem;
    font-weight: 500;
    transition: all var(--esd-transition-fast);
}

.esd-pagination .page-link:hover {
    background: var(--bs-primary);
    color: white;
    border-color: var(--bs-primary);
}

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

/* ========================================
   Badges
   ======================================== */
.esd-badge {
    font-size: 0.7rem;
    padding: 0.3rem 0.6rem;
    border-radius: var(--esd-radius-sm);
    text-transform: uppercase;
    font-weight: 700;
    letter-spacing: 0.025em;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}

/* ========================================
   Buttons
   ======================================== */
.esd-btn {
    border-radius: var(--esd-radius-md);
    font-weight: 500;
    transition: all var(--esd-transition-fast);
}

.esd-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

/* ========================================
   View Toggle
   ======================================== */
.esd-view-toggle {
    display: flex;
    gap: 0;
    border-radius: var(--esd-radius-md);
    overflow: hidden;
    box-shadow: 0 2px 4px rgba(0,0,0,0.08);
}

.esd-view-toggle .btn {
    padding: 0.5rem 0.875rem;
    border: 1px solid var(--bs-border-color);
    background: var(--bs-body-bg);
    color: var(--bs-secondary-color);
    transition: all 0.25s ease;
    border-radius: 0;
}

.esd-view-toggle .btn:first-child {
    border-radius: var(--esd-radius-md) 0 0 var(--esd-radius-md);
}

.esd-view-toggle .btn:last-child {
    border-radius: 0 var(--esd-radius-md) var(--esd-radius-md) 0;
    border-left: none;
}

.esd-view-toggle .btn:hover:not(.active) {
    background: var(--bs-tertiary-bg);
    color: var(--bs-primary);
}

.esd-view-toggle .btn.active {
    background: var(--bs-primary);
    border-color: var(--bs-primary);
    color: white;
    box-shadow: inset 0 2px 4px rgba(0,0,0,0.1);
}

/* ========================================
   Modals
   ======================================== */
.esd-modal .modal-content {
    border-radius: var(--esd-radius-lg);
    border: none;
    box-shadow: 0 16px 48px rgba(0,0,0,0.2);
}

.esd-modal .modal-header {
    border-bottom: 1px solid var(--bs-border-color-translucent);
    background: linear-gradient(180deg, var(--bs-tertiary-bg) 0%, transparent 100%);
    border-radius: var(--esd-radius-lg) var(--esd-radius-lg) 0 0;
}

.esd-modal .modal-footer {
    border-top: 1px solid var(--bs-border-color-translucent);
    background: var(--bs-tertiary-bg);
    border-radius: 0 0 var(--esd-radius-lg) var(--esd-radius-lg);
}

/* ========================================
   Animations
   ======================================== */
@keyframes esd-fade-in-up {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.esd-animate-in {
    animation: esd-fade-in-up 0.4s ease-out backwards;
}

.esd-animate-in:nth-child(1) { animation-delay: 0.05s; }
.esd-animate-in:nth-child(2) { animation-delay: 0.1s; }
.esd-animate-in:nth-child(3) { animation-delay: 0.15s; }
.esd-animate-in:nth-child(4) { animation-delay: 0.2s; }
.esd-animate-in:nth-child(5) { animation-delay: 0.25s; }
.esd-animate-in:nth-child(6) { animation-delay: 0.3s; }
.esd-animate-in:nth-child(7) { animation-delay: 0.35s; }
.esd-animate-in:nth-child(8) { animation-delay: 0.4s; }

/* ========================================
   Grid Layout
   ======================================== */
.esd-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(380px, 1fr));
    gap: 1.5rem;
    padding: 1rem 0;
}

.esd-grid-3 {
    grid-template-columns: repeat(3, 1fr);
}

.esd-grid-4 {
    grid-template-columns: repeat(4, 1fr);
}

@media (max-width: 1199.98px) {
    .esd-grid-4 {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 991.98px) {
    .esd-grid {
        grid-template-columns: 1fr;
    }
    
    .esd-grid-3,
    .esd-grid-4 {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .esd-stats-number {
        font-size: 2rem;
    }
    
    .esd-tabs .nav-link {
        padding: 0.625rem 0.875rem;
        font-size: 0.875rem;
    }
}

@media (max-width: 575.98px) {
    .esd-grid-3,
    .esd-grid-4 {
        grid-template-columns: 1fr;
    }
}

/* ========================================
   Dark Theme Support
   ======================================== */
[data-bs-theme="dark"] .esd-card {
    background: var(--bs-dark);
    border-color: var(--bs-border-color);
}

[data-bs-theme="dark"] .esd-card-static {
    background: var(--bs-dark);
    border: 1px solid var(--bs-border-color);
}

[data-bs-theme="dark"] .esd-table td {
    background: var(--bs-dark);
}

[data-bs-theme="dark"] .esd-table tbody tr:hover td {
    background: var(--bs-gray-800);
}

[data-bs-theme="dark"] .esd-table th {
    background: linear-gradient(180deg, var(--bs-gray-800) 0%, var(--bs-gray-900) 100%);
}

[data-bs-theme="dark"] .esd-filters {
    background: var(--bs-dark);
    border: 1px solid var(--bs-border-color);
}

[data-bs-theme="dark"] .esd-empty-state {
    background: linear-gradient(135deg, var(--bs-gray-800) 0%, transparent 100%);
}

[data-bs-theme="dark"] .esd-skeleton {
    background: var(--bs-dark);
}

[data-bs-theme="dark"] .esd-modal .modal-content {
    background: var(--bs-dark);
}

[data-bs-theme="dark"] .esd-modal .modal-header {
    background: linear-gradient(180deg, var(--bs-gray-800) 0%, var(--bs-dark) 100%);
}

[data-bs-theme="dark"] .esd-modal .modal-footer {
    background: var(--bs-gray-800);
}

[data-bs-theme="dark"] .bg-primary.bg-opacity-10 {
    background-color: rgba(13, 110, 253, 0.15) !important;
}

[data-bs-theme="dark"] .bg-success.bg-opacity-10 {
    background-color: rgba(25, 135, 84, 0.15) !important;
}

[data-bs-theme="dark"] .bg-warning.bg-opacity-10 {
    background-color: rgba(255, 193, 7, 0.15) !important;
}

[data-bs-theme="dark"] .bg-danger.bg-opacity-10 {
    background-color: rgba(220, 53, 69, 0.15) !important;
}

[data-bs-theme="dark"] .bg-info.bg-opacity-10 {
    background-color: rgba(13, 202, 240, 0.15) !important;
}

/* ========================================
   Loading Overlay
   ======================================== */
.esd-loading-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(255, 255, 255, 0.8);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 100;
    border-radius: inherit;
}

[data-bs-theme="dark"] .esd-loading-overlay {
    background: rgba(33, 37, 41, 0.8);
}

/* ========================================
   Toast Notifications
   ======================================== */
.esd-toast-container {
    position: fixed;
    top: 1rem;
    right: 1rem;
    z-index: 1100;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.esd-toast {
    padding: 1rem 1.25rem;
    border-radius: var(--esd-radius-md);
    box-shadow: 0 8px 24px rgba(0,0,0,0.15);
    display: flex;
    align-items: center;
    gap: 0.75rem;
    min-width: 300px;
    max-width: 450px;
    animation: esd-toast-in 0.3s ease-out;
}

.esd-toast.success {
    background: var(--esd-gradient-success);
    color: white;
}

.esd-toast.error {
    background: var(--esd-gradient-danger);
    color: white;
}

.esd-toast.warning {
    background: var(--esd-gradient-warning);
    color: #212529;
}

.esd-toast.info {
    background: var(--esd-gradient-primary);
    color: white;
}

.esd-toast i {
    font-size: 1.25rem;
}

.esd-toast-close {
    margin-left: auto;
    background: none;
    border: none;
    color: inherit;
    opacity: 0.7;
    cursor: pointer;
    padding: 0;
    font-size: 1.25rem;
    line-height: 1;
}

.esd-toast-close:hover {
    opacity: 1;
}

@keyframes esd-toast-in {
    from {
        opacity: 0;
        transform: translateX(100%);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes esd-toast-out {
    from {
        opacity: 1;
        transform: translateX(0);
    }
    to {
        opacity: 0;
        transform: translateX(100%);
    }
}

/* ========================================
   Avatar
   ======================================== */
.esd-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 1rem;
    font-weight: 600;
    flex-shrink: 0;
    background: var(--esd-gradient-primary);
}

.esd-avatar-sm {
    width: 32px;
    height: 32px;
    font-size: 0.875rem;
}

.esd-avatar-lg {
    width: 56px;
    height: 56px;
    font-size: 1.25rem;
}

/* ========================================
   Status Indicators
   ======================================== */
.esd-status-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    display: inline-block;
    flex-shrink: 0;
}

.esd-status-dot.success { background-color: var(--bs-success); }
.esd-status-dot.warning { background-color: var(--bs-warning); }
.esd-status-dot.danger { background-color: var(--bs-danger); }
.esd-status-dot.info { background-color: var(--bs-info); }
.esd-status-dot.secondary { background-color: var(--bs-secondary); }

/* Пульсирующий индикатор */
.esd-status-dot.pulse {
    animation: esd-pulse 2s ease-in-out infinite;
}

@keyframes esd-pulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50% { opacity: 0.6; transform: scale(1.2); }
}

/* ========================================
   Progress Bar
   ======================================== */
.esd-progress {
    height: 8px;
    border-radius: 4px;
    background: var(--bs-secondary-bg);
    overflow: hidden;
}

.esd-progress-bar {
    height: 100%;
    border-radius: 4px;
    transition: width 0.6s ease;
}

.esd-progress-bar.success { background: var(--esd-gradient-success); }
.esd-progress-bar.warning { background: var(--esd-gradient-warning); }
.esd-progress-bar.danger { background: var(--esd-gradient-danger); }
.esd-progress-bar.primary { background: var(--esd-gradient-primary); }

/* ========================================
   Utility Classes
   ======================================== */
.esd-hover-lift {
    transition: transform var(--esd-transition-normal), box-shadow var(--esd-transition-normal);
}

.esd-hover-lift:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0,0,0,0.12);
}

.esd-text-gradient {
    background: var(--esd-gradient-primary);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.esd-border-gradient {
    border: 2px solid transparent;
    background: linear-gradient(var(--bs-body-bg), var(--bs-body-bg)) padding-box,
                var(--esd-gradient-primary) border-box;
}

/* ========================================
   RESPONSIVE / ADAPTIVE STYLES
   ======================================== */

/* Таблицы: скрываем менее важные колонки на мобильных */
@media (max-width: 768px) {
    /* Заголовки страниц */
    .d-flex.align-items-center.justify-content-between {
        flex-direction: column;
        align-items: flex-start !important;
        gap: 1rem;
    }
    
    .d-flex.align-items-center.justify-content-between .d-flex.gap-2 {
        width: 100%;
        flex-wrap: wrap;
    }
    
    .d-flex.align-items-center.justify-content-between .d-flex.gap-2 .btn {
        flex: 1;
        min-width: 120px;
    }
    
    /* Карточки фильтров */
    .card .row.g-2 > [class*="col-md-"],
    .card .row.g-3 > [class*="col-md-"] {
        flex: 0 0 100%;
        max-width: 100%;
    }
    
    /* Таблицы */
    .table th,
    .table td {
        padding: 0.5rem;
        font-size: 0.85rem;
    }
    
    /* Скрываем широкие колонки действий */
    .table th[style*="width:320px"],
    .table td:last-child {
        min-width: auto !important;
    }
    
    /* Кнопки в таблицах */
    .table .btn {
        padding: 0.25rem 0.5rem;
        font-size: 0.75rem;
    }
    
    .table .btn-group {
        flex-wrap: wrap;
        gap: 0.25rem;
    }
    
    /* Бейджи */
    .badge {
        font-size: 0.7rem;
        padding: 0.2rem 0.4rem;
    }
    
    /* Модальные окна */
    .modal-dialog {
        margin: 0.5rem;
        max-width: calc(100% - 1rem);
    }
    
    /* Навигация вкладок */
    .nav-tabs-custom {
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
    
    .nav-tabs-custom .nav-link {
        white-space: nowrap;
        padding: 0.5rem 0.75rem;
        font-size: 0.85rem;
    }
    
    /* Статистические карточки */
    .stats-card,
    .kpi-card,
    .esd-kpi-card {
        margin-bottom: 0.75rem;
    }
    
    /* Контейнер */
    .container-fluid.py-4 {
        padding-left: 0.75rem;
        padding-right: 0.75rem;
    }
}

/* Планшеты */
@media (min-width: 769px) and (max-width: 1024px) {
    .d-flex.align-items-center.justify-content-between .d-flex.gap-2 .btn {
        padding: 0.375rem 0.75rem;
        font-size: 0.875rem;
    }
    
    .table th,
    .table td {
        padding: 0.625rem;
    }
}

/* Большие экраны */
@media (min-width: 1400px) {
    .container-fluid.py-4 {
        padding-left: 2rem;
        padding-right: 2rem;
    }
}

/* Печать */
@media print {
    .navbar,
    .btn,
    .d-flex.gap-2,
    .card-body form,
    .alert {
        display: none !important;
    }
    
    .container-fluid {
        padding: 0 !important;
    }
    
    .card {
        border: none !important;
        box-shadow: none !important;
    }
    
    .table {
        font-size: 10pt;
    }
    
    .table th,
    .table td {
        padding: 0.25rem;
    }
}

/* ========================================
   STATS CARDS (from reports.css)
   ======================================== */
.stats-card {
    border-radius: 1rem;
    padding: 1.25rem;
    text-align: center;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    overflow: hidden;
    cursor: pointer;
    box-shadow: var(--esd-card-shadow);
}

.stats-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, rgba(255,255,255,0.15) 0%, transparent 50%);
    pointer-events: none;
}

.stats-card:hover {
    transform: translateY(-4px) scale(1.02);
    box-shadow: var(--esd-card-shadow-hover);
}

.stats-icon {
    font-size: 1.5rem;
    opacity: 0.8;
    margin-bottom: 0.5rem;
}

.stats-number {
    font-size: 2rem;
    font-weight: 800;
    line-height: 1.2;
    text-shadow: 0 2px 4px rgba(0,0,0,0.1);
}

.stats-label {
    font-size: 0.8rem;
    font-weight: 500;
    opacity: 0.9;
    margin-top: 0.25rem;
}

/* ========================================
   REPORT CARDS
   ======================================== */
.report-card {
    border-radius: 1rem;
    border: 1px solid var(--bs-border-color);
    background: var(--bs-body-bg);
    transition: all 0.35s cubic-bezier(0.4, 0, 0.2, 1);
    cursor: pointer;
    height: 100%;
    overflow: hidden;
    box-shadow: var(--esd-card-shadow);
    position: relative;
    animation: esd-fade-in-up 0.4s ease-out backwards;
}

.report-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: transparent;
    transition: background 0.3s ease;
}

.report-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--esd-card-shadow-hover);
    border-color: transparent;
}

.report-card:hover::before {
    background: var(--esd-gradient-primary);
}

.report-card-header {
    padding: 1.25rem 1.25rem 0.75rem;
    border-bottom: 1px solid var(--bs-border-color-translucent);
    background: linear-gradient(180deg, var(--bs-tertiary-bg) 0%, transparent 100%);
}

.report-card-body {
    padding: 1rem 1.25rem;
    flex-grow: 1;
}

.report-card-footer {
    padding: 0.875rem 1.25rem;
    background: var(--bs-tertiary-bg);
    border-top: 1px solid var(--bs-border-color-translucent);
}

.report-card-title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--bs-body-color);
    margin-bottom: 0.5rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.report-card-title i {
    color: var(--bs-primary);
}

.report-card:hover .report-card-title {
    color: var(--bs-primary);
}

/* Reports grid */
.reports-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 1.5rem;
    padding: 1rem 0;
}

/* ========================================
   KPI MINI CARDS
   ======================================== */
.kpi-mini {
    background: var(--bs-tertiary-bg);
    border-radius: 0.75rem;
    padding: 1rem;
    text-align: center;
    transition: all 0.2s ease;
}

.kpi-mini:hover {
    background: var(--bs-secondary-bg);
    transform: translateY(-2px);
}

.kpi-mini-value {
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1.2;
}

.kpi-mini-label {
    font-size: 0.75rem;
    color: var(--bs-secondary-color);
    margin-top: 0.25rem;
}

/* ========================================
   SKELETON LOADING
   ======================================== */
.skeleton-card {
    border-radius: 1rem;
    border: 1px solid var(--bs-border-color);
    background: var(--bs-body-bg);
    padding: 1.5rem;
    min-height: 200px;
    box-shadow: var(--esd-card-shadow);
}

.skeleton-line {
    height: 1rem;
    background: linear-gradient(90deg, var(--bs-tertiary-bg) 25%, var(--bs-secondary-bg) 50%, var(--bs-tertiary-bg) 75%);
    background-size: 200% 100%;
    animation: esd-skeleton 1.5s ease-in-out infinite;
    border-radius: 6px;
    margin-bottom: 0.75rem;
}

.skeleton-line.short { width: 40%; }
.skeleton-line.medium { width: 70%; }

@keyframes esd-skeleton {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* ========================================
   EMPTY STATE
   ======================================== */
.empty-state {
    text-align: center;
    padding: 4rem 2rem;
    color: var(--bs-secondary-color);
    background: linear-gradient(135deg, var(--bs-tertiary-bg) 0%, transparent 100%);
    border-radius: 1rem;
    margin: 1rem 0;
}

.empty-state i {
    font-size: 4rem;
    margin-bottom: 1.5rem;
    opacity: 0.4;
    color: var(--bs-primary);
}

.empty-state h5 {
    font-weight: 600;
    margin-bottom: 0.75rem;
}

/* ========================================
   CHART CONTAINERS
   ======================================== */
.chart-container {
    position: relative;
    height: 300px;
    width: 100%;
}

.chart-container canvas {
    width: 100% !important;
    height: 100% !important;
}

/* ========================================
   QUICK PERIOD BUTTONS
   ======================================== */
.quick-period.active {
    background: var(--bs-primary);
    color: white;
    border-color: var(--bs-primary);
}

/* ========================================
   PROGRESS BARS
   ======================================== */
.progress-thin {
    height: 6px;
    border-radius: 3px;
}

/* ========================================
   FLOATING ALERTS
   ======================================== */
.alert-floating {
    position: fixed;
    top: 80px;
    right: 20px;
    z-index: 1050;
    min-width: 300px;
    animation: esd-slide-in-right 0.3s ease;
}

@keyframes esd-slide-in-right {
    from {
        transform: translateX(100%);
        opacity: 0;
    }
    to {
        transform: translateX(0);
        opacity: 1;
    }
}

/* ========================================
   CURSOR UTILITIES
   ======================================== */
.cursor-pointer {
    cursor: pointer;
}

.cursor-pointer:hover {
    background-color: rgba(var(--bs-primary-rgb), 0.08) !important;
}

/* ========================================
   AVATAR SIZES
   ======================================== */
.avatar-lg {
    width: 56px;
    height: 56px;
    min-width: 56px;
}

.avatar-md {
    width: 40px;
    height: 40px;
    min-width: 40px;
}

.avatar-sm {
    width: 32px;
    height: 32px;
    min-width: 32px;
}

/* ========================================
   DARK THEME OVERRIDES FOR NEW COMPONENTS
   ======================================== */
[data-bs-theme="dark"] .stats-card {
    box-shadow: 0 2px 8px rgba(0,0,0,0.3);
}

[data-bs-theme="dark"] .report-card {
    background: var(--bs-dark);
    border-color: var(--bs-border-color);
}

[data-bs-theme="dark"] .skeleton-card {
    background: var(--bs-dark);
}

[data-bs-theme="dark"] .kpi-mini {
    background: var(--bs-gray-800);
}

[data-bs-theme="dark"] .kpi-mini:hover {
    background: var(--bs-gray-700);
}

/* ========================================
   RESPONSIVE FOR NEW COMPONENTS
   ======================================== */
@media (max-width: 991.98px) {
    .reports-grid {
        grid-template-columns: 1fr;
    }
    
    .stats-number {
        font-size: 1.5rem;
    }
    
    .chart-container {
        height: 250px;
    }
}

@media (max-width: 575.98px) {
    .stats-card {
        padding: 1rem;
    }
    
    .stats-number {
        font-size: 1.25rem;
    }
    
    .stats-icon {
        font-size: 1.25rem;
    }
}

/* ========================================
   COMMON INLINE STYLES (from PHP files)
   ======================================== */

/* Monospace text */
.text-mono {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}

/* Truncate text to 2 lines */
.truncate-2 {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Width utilities */
.w-140 { width: 140px; }
.w-120 { width: 120px; }
.w-100px { width: 100px; }
.w-80 { width: 80px; }

/* Key-value grid layout */
.kv {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 0.5rem 1rem;
}

@media (max-width: 768px) {
    .kv {
        grid-template-columns: 1fr;
    }
    .kv dt {
        font-weight: 600;
    }
}

.kv dt {
    color: var(--bs-secondary-color);
}

/* ========================================
   KANBAN BOARD STYLES
   ======================================== */
.kanban-column {
    transition: background-color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
    min-height: 200px;
}

.kanban-column.drag-over {
    background-color: rgba(var(--bs-primary-rgb), 0.1);
    border-color: var(--bs-primary);
    box-shadow: 0 0 0 2px rgba(var(--bs-primary-rgb), 0.25);
}

.kanban-card {
    cursor: grab;
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.kanban-card:active {
    cursor: grabbing;
}

.kanban-card.dragging {
    opacity: 0.5;
    transform: rotate(3deg);
}

.kanban-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

#kanban-board {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1rem;
}

/* ========================================
   HR MODULE STYLES
   ======================================== */
.hr-table td,
.hr-table th {
    vertical-align: middle;
}

/* Timesheet table */
.ts-table thead th {
    position: sticky;
    top: 0;
    z-index: 10;
    background: var(--bs-body-bg);
}

/* Calendar grid */
.calendar-grid {
    display: grid;
    grid-template-columns: 200px repeat(12, 1fr);
    gap: 1px;
    background: var(--bs-border-color);
}

.calendar-grid > div {
    background: var(--bs-body-bg);
    padding: 0.5rem;
}

/* ========================================
   ITSM STYLES
   ======================================== */

/* Sidebar sticky */
#sidebar-column {
    position: sticky;
    top: 1rem;
    max-height: calc(100vh - 2rem);
    overflow-y: auto;
}

/* Type selection modal */
.type-selection-modal .modal-content {
    border-radius: 1rem;
}

/* Hover card effect */
.hover-card {
    transition: transform 0.2s, box-shadow 0.2s;
    cursor: pointer;
}

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

/* Health score circle */
.health-score-circle {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    font-weight: 700;
}

/* Wizard steps */
.wizard-step {
    text-align: center;
    flex: 1;
    position: relative;
}

.wizard-step::after {
    content: '';
    position: absolute;
    top: 15px;
    left: 50%;
    width: 100%;
    height: 2px;
    background: var(--bs-border-color);
    z-index: 0;
}

.wizard-step:last-child::after {
    display: none;
}

.wizard-step .step-number {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--bs-secondary-bg);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: relative;
    z-index: 1;
}

.wizard-step.active .step-number {
    background: var(--bs-primary);
    color: white;
}

.wizard-step.completed .step-number {
    background: var(--bs-success);
    color: white;
}

/* ========================================
   KB (KNOWLEDGE BASE) STYLES
   ======================================== */
.kb-header {
    text-align: center;
    padding: 2rem 0;
}

.kb-search-box {
    max-width: 600px;
    margin: 0 auto;
}

.kb-category-card {
    transition: all 0.3s ease;
    cursor: pointer;
}

.kb-category-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0,0,0,0.12);
}

.kb-article-card {
    border-left: 3px solid var(--bs-primary);
    transition: all 0.2s ease;
}

.kb-article-card:hover {
    background: var(--bs-tertiary-bg);
}

/* ========================================
   INBOX/WORKFLOW CARDS
   ======================================== */
.inbox-card {
    transition: all 0.2s ease;
    cursor: pointer;
}

.inbox-card:hover {
    transform: translateX(4px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}

.dashboard-card {
    border-radius: 1rem;
    transition: all 0.2s ease;
}

.dashboard-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(0,0,0,0.12);
}

/* ========================================
   MODAL FIXES
   ======================================== */
#widgetsModal .modal-body {
    max-height: calc(100vh - 12rem);
    overflow-y: auto;
}

#widgetsModal .modal-footer {
    position: sticky;
    bottom: 0;
    z-index: 2;
    background: var(--bs-body-bg);
}

/* ========================================
   QUILL EDITOR DARK THEME
   ======================================== */
[data-bs-theme="dark"] .ql-editor {
    background: #2b3035;
    color: var(--bs-body-color);
}

[data-bs-theme="dark"] .ql-toolbar {
    background: var(--bs-tertiary-bg);
    border-color: var(--bs-border-color);
}

[data-bs-theme="dark"] .ql-container {
    border-color: var(--bs-border-color);
}

[data-bs-theme="dark"] .ql-stroke {
    stroke: var(--bs-body-color);
}

[data-bs-theme="dark"] .ql-fill {
    fill: var(--bs-body-color);
}

[data-bs-theme="dark"] .ql-picker-label {
    color: var(--bs-body-color);
}

/* ========================================
   TICKET VIEW STYLES
   ======================================== */
.nav-tabs#ticket-main-tabs {
    overflow: visible;
    white-space: normal;
    flex-wrap: wrap;
    gap: 0.25rem;
    margin-bottom: 0;
}

.nav-tabs#ticket-main-tabs .nav-link {
    min-width: auto;
    text-align: center;
    padding-left: 0.85rem;
    padding-right: 0.85rem;
}

.tab-wrapper {
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-top: 0;
    padding: 0.5rem 0.75rem;
}

.tab-content#ticket-tab-content {
    margin-top: 0;
}

@keyframes pulse {
    0%, 100% {
        opacity: 1;
        transform: scale(1);
    }
    50% {
        opacity: 0.7;
        transform: scale(1.1);
    }
}

/* ========================================
   AUTOCOMPLETE DROPDOWN
   ======================================== */
.autocomplete-dropdown {
    background: linear-gradient(135deg, #ffffff 0%, #f8f9fa 100%);
    border: 2px solid #e3f2fd;
    border-radius: 8px;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12), 0 2px 4px rgba(0, 0, 0, 0.08);
    max-height: 350px;
    overflow-y: auto;
    z-index: 1055 !important;
    backdrop-filter: blur(10px);
}

.autocomplete-dropdown::-webkit-scrollbar {
    width: 8px;
}

.autocomplete-dropdown::-webkit-scrollbar-track {
    background: #f1f1f1;
    border-radius: 4px;
}

.autocomplete-dropdown::-webkit-scrollbar-thumb {
    background: linear-gradient(180deg, #64b5f6 0%, #42a5f5 100%);
    border-radius: 4px;
}

.autocomplete-dropdown::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(180deg, #42a5f5 0%, #2196f3 100%);
}

.autocomplete-dropdown .autocomplete-item {
    padding: 14px 16px;
    cursor: pointer;
    border-bottom: 1px solid rgba(227, 242, 253, 0.6);
    transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
    background: transparent;
    position: relative;
    overflow: hidden;
}

.autocomplete-dropdown .autocomplete-item::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    width: 3px;
    height: 100%;
    background: linear-gradient(180deg, #64b5f6 0%, #42a5f5 100%);
    transform: scaleY(0);
    transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

.autocomplete-dropdown .autocomplete-item:hover::before,
.autocomplete-dropdown .autocomplete-item.selected::before {
    transform: scaleY(1);
}

.autocomplete-dropdown .autocomplete-item:hover,
.autocomplete-dropdown .autocomplete-item.selected {
    background: linear-gradient(135deg, #e3f2fd 0%, #bbdefb 100%);
    padding-left: 20px;
}

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

[data-bs-theme="dark"] .autocomplete-dropdown {
    background: linear-gradient(135deg, var(--bs-dark) 0%, var(--bs-gray-800) 100%);
    border-color: var(--bs-border-color);
}

[data-bs-theme="dark"] .autocomplete-dropdown .autocomplete-item {
    border-bottom-color: var(--bs-border-color);
}

[data-bs-theme="dark"] .autocomplete-dropdown .autocomplete-item:hover,
[data-bs-theme="dark"] .autocomplete-dropdown .autocomplete-item.selected {
    background: linear-gradient(135deg, var(--bs-gray-700) 0%, var(--bs-gray-800) 100%);
}

/* ========================================
   METRIC CARDS (compact KPI cards)
   ======================================== */
.metrics-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1rem;
}

.metric-card {
    position: relative;
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1.1rem 1.35rem;
    border-radius: 1rem;
    background: var(--bs-body-bg);
    border: 1px solid rgba(15, 23, 42, 0.08);
    box-shadow: 0 0.6rem 1.5rem rgba(15, 23, 42, 0.08);
    overflow: hidden;
    min-height: 90px;
}

.metric-card::before {
    content: "";
    position: absolute;
    inset: 0;
    opacity: 0.65;
    pointer-events: none;
    border-radius: inherit;
    mix-blend-mode: color;
}

.metric-card.metric-card-muted::before { background: linear-gradient(135deg, rgba(13, 110, 253, 0.08), rgba(13, 202, 240, 0.12)); }
.metric-card.metric-card-income::before { background: linear-gradient(135deg, rgba(25, 135, 84, 0.12), rgba(13, 202, 240, 0.12)); }
.metric-card.metric-card-novat::before { background: linear-gradient(135deg, rgba(111, 66, 193, 0.12), rgba(13, 110, 253, 0.1)); }
.metric-card.metric-card-paid::before { background: linear-gradient(135deg, rgba(255, 193, 7, 0.14), rgba(255, 159, 64, 0.2)); }
.metric-card.metric-card-unpaid::before { background: linear-gradient(135deg, rgba(220, 53, 69, 0.12), rgba(255, 99, 132, 0.2)); }
.metric-card.metric-card-primary::before { background: linear-gradient(135deg, rgba(13, 110, 253, 0.12), rgba(102, 126, 234, 0.15)); }
.metric-card.metric-card-success::before { background: linear-gradient(135deg, rgba(25, 135, 84, 0.12), rgba(32, 201, 151, 0.15)); }
.metric-card.metric-card-warning::before { background: linear-gradient(135deg, rgba(255, 193, 7, 0.12), rgba(253, 126, 20, 0.15)); }
.metric-card.metric-card-danger::before { background: linear-gradient(135deg, rgba(220, 53, 69, 0.12), rgba(232, 62, 140, 0.15)); }
.metric-card.metric-card-info::before { background: linear-gradient(135deg, rgba(13, 202, 240, 0.12), rgba(102, 16, 242, 0.1)); }

.metric-card > * {
    position: relative;
    z-index: 1;
}

.metric-icon {
    flex-shrink: 0;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    background: rgba(255, 255, 255, 0.9);
    color: var(--bs-body-color);
    box-shadow: 0 0.45rem 1.15rem rgba(15, 23, 42, 0.08);
}

.metric-body {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.metric-label {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--bs-secondary-color);
    font-weight: 600;
}

.metric-value {
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1.1;
    color: var(--bs-body-color);
}

@media (max-width: 576px) {
    .metric-card {
        padding: 0.875rem;
        min-height: unset;
    }
    .metric-value {
        font-size: 1.25rem;
    }
    .metric-icon {
        width: 40px;
        height: 40px;
        font-size: 1rem;
    }
}

[data-bs-theme="dark"] .metric-card {
    border-color: var(--bs-border-color);
}

[data-bs-theme="dark"] .metric-icon {
    background: var(--bs-gray-800);
}

/* ========================================
   CHART CARDS
   ======================================== */
.chart-card {
    height: 100%;
}

.chart-card .card-body {
    padding: 1.2rem;
}

/* ========================================
   TOP TABLE (compact tables)
   ======================================== */
.top-table {
    font-size: 0.85rem;
}

.top-table tbody tr td {
    vertical-align: middle;
}

.top-table tbody tr td.num {
    text-align: right;
    font-variant-numeric: tabular-nums;
}

.top-table tbody tr td:first-child {
    width: 60%;
}

/* ========================================
   POINTER UTILITY
   ======================================== */
.pointer {
    cursor: pointer;
}

/* ========================================
   STATS GRID (simple inline stats)
   ======================================== */
.stats-grid {
    display: flex;
    gap: 1.5rem;
    flex-wrap: wrap;
}

.stat-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 0.5rem 1rem;
    background: var(--bs-tertiary-bg);
    border-radius: 0.5rem;
    min-width: 80px;
}

.stat-value {
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1.2;
    color: var(--bs-primary);
}

.stat-label {
    font-size: 0.75rem;
    color: var(--bs-secondary-color);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* ========================================
   SEARCH PANEL
   ======================================== */
.search-panel {
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 0.75rem;
    padding: 1rem;
    margin-bottom: 1rem;
}

.search-input-wrapper {
    position: relative;
    margin-bottom: 0.75rem;
}

.search-input-wrapper i {
    position: absolute;
    left: 1rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--bs-secondary-color);
}

.search-input-wrapper input {
    padding-left: 2.5rem;
}

.filter-badges {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.filter-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.35rem 0.75rem;
    border-radius: 2rem;
    font-size: 0.8rem;
    background: var(--bs-tertiary-bg);
    color: var(--bs-body-color);
    cursor: pointer;
    transition: all 0.2s ease;
    border: 1px solid transparent;
}

.filter-badge:hover {
    background: var(--bs-secondary-bg);
}

.filter-badge.active {
    background: var(--bs-primary);
    color: white;
}

/* ========================================
   SOFTWARE STATS ROW
   ======================================== */
.sw-stats-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.esd-stats-card {
    position: relative;
    padding: 1.25rem;
    border-radius: 1rem;
    color: white;
    overflow: hidden;
    min-height: 100px;
}

.esd-stats-card.bg-primary { background: linear-gradient(135deg, #0d6efd 0%, #6610f2 100%); }
.esd-stats-card.bg-success { background: linear-gradient(135deg, #198754 0%, #20c997 100%); }
.esd-stats-card.bg-warning { background: linear-gradient(135deg, #ffc107 0%, #fd7e14 100%); color: #212529; }
.esd-stats-card.bg-danger { background: linear-gradient(135deg, #dc3545 0%, #e83e8c 100%); }
.esd-stats-card.bg-info { background: linear-gradient(135deg, #0dcaf0 0%, #6610f2 100%); }

.esd-stats-number {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.2;
}

.esd-stats-label {
    font-size: 0.85rem;
    opacity: 0.9;
}

.esd-stats-icon {
    position: absolute;
    right: 1rem;
    bottom: 0.5rem;
    font-size: 3rem;
    opacity: 0.2;
}

/* ========================================
   FILTER ROW (HR module)
   ======================================== */
.filter-row {
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 0.75rem;
    padding: 1rem;
    margin-bottom: 1.5rem;
}

/* ========================================
   ESD PAGE HEADER
   ======================================== */
.esd-page-header {
    margin-bottom: 1.5rem;
}

.esd-page-header h1 {
    font-size: 1.5rem;
    font-weight: 600;
}

/* ========================================
   ESD ANIMATE IN
   ======================================== */
.esd-animate-in {
    animation: esd-fade-in-up 0.4s ease-out;
}

/* ========================================
   ESD BUTTON
   ======================================== */
.esd-btn {
    border-radius: 0.5rem;
    font-weight: 500;
    transition: all 0.2s ease;
}

.esd-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

/* ========================================
   SOFTWARE CONTAINER (two-column layout)
   ======================================== */
.software-container {
    display: grid;
    grid-template-columns: 350px 1fr;
    gap: 1.5rem;
}

@media (max-width: 991.98px) {
    .software-container {
        grid-template-columns: 1fr;
    }
}

/* ========================================
   EMPTY STATE (compact)
   ======================================== */
.empty-state {
    text-align: center;
    padding: 3rem 1.5rem;
    color: var(--bs-secondary-color);
}

.empty-state i {
    font-size: 3rem;
    opacity: 0.4;
    margin-bottom: 1rem;
    display: block;
}

.empty-state p {
    margin: 0;
}

/* ========================================
   KPI CARDS (dashboard)
   ======================================== */
.kpi-card {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    padding: 1.25rem;
    border-radius: 1rem;
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    box-shadow: 0 0.3rem 0.8rem rgba(15, 23, 42, 0.08);
    text-decoration: none;
    color: inherit;
    transition: transform 0.15s ease, box-shadow 0.15s ease;
    min-height: 140px;
}

.kpi-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 0.5rem 1.2rem rgba(15, 23, 42, 0.14);
    text-decoration: none;
    color: inherit;
}

.kpi-icon {
    font-size: 1.5rem;
    opacity: 0.8;
    margin-bottom: 0.25rem;
    flex-shrink: 0;
}

/* Icons inside kpi-card text */
.kpi-card i.bi {
    flex-shrink: 0;
    display: inline-flex;
    width: 1.25em;
}

.kpi-label {
    font-size: 0.75rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--bs-secondary-color);
}

.kpi-value {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.1;
}

.kpi-sub {
    font-size: 0.85rem;
    color: var(--bs-secondary-color);
}

/* KPI card color variants */
.kpi-card.kpi-primary { border-left: 4px solid var(--bs-primary); }
.kpi-card.kpi-success { border-left: 4px solid var(--bs-success); }
.kpi-card.kpi-warning { border-left: 4px solid var(--bs-warning); }
.kpi-card.kpi-danger { border-left: 4px solid var(--bs-danger); }
.kpi-card.kpi-info { border-left: 4px solid var(--bs-info); }

.kpi-card.kpi-primary .kpi-icon { color: var(--bs-primary); }
.kpi-card.kpi-success .kpi-icon { color: var(--bs-success); }
.kpi-card.kpi-warning .kpi-icon { color: var(--bs-warning); }
.kpi-card.kpi-danger .kpi-icon { color: var(--bs-danger); }
.kpi-card.kpi-info .kpi-icon { color: var(--bs-info); }

/* ========================================
   DASHBOARD TILE GRID
   ======================================== */
.dashboard-tile-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
}

.dashboard-tile-grid .dashboard-tile {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    padding: 1rem 1.25rem;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 0.9rem;
    background-color: var(--bs-body-bg);
    box-shadow: 0 0.3rem 0.8rem rgba(15, 23, 42, 0.08);
    cursor: pointer;
    transition: transform 0.12s ease, box-shadow 0.12s ease;
    min-height: 120px;
}

.dashboard-tile-grid .dashboard-tile:hover {
    transform: translateY(-2px);
    box-shadow: 0 0.55rem 1.2rem rgba(15, 23, 42, 0.14);
}

.dashboard-tile-grid .tile-label {
    font-size: 0.74rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--bs-secondary-color);
}

.dashboard-tile-grid .tile-value {
    font-size: 1.75rem;
    font-weight: 700;
    line-height: 1.1;
}

.dashboard-tile-grid .tile-sub {
    font-size: 0.85rem;
    color: var(--bs-secondary-color);
}

/* ========================================
   DASHBOARD WIDGET
   ======================================== */
.dashboard-widget {
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.dashboard-widget:hover {
    transform: translateY(-2px);
    box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15) !important;
}

/* ========================================
   SSL WIDGET
   ======================================== */
.ssl-widget .card-header {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 1rem;
}

.ssl-widget .title {
    font-weight: 600;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.ssl-widget .kpis {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.75rem;
    flex-grow: 1;
    min-width: 12rem;
}

.ssl-chip-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
}

.ssl-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.4rem 0.75rem;
    border-radius: 999px;
    border: 1px solid rgba(var(--bs-primary-rgb), 0.18);
    background: rgba(var(--bs-primary-rgb), 0.12);
    color: var(--bs-body-color);
    font-size: 0.82rem;
    line-height: 1.1;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.ssl-chip:hover {
    transform: translateY(-1px);
    box-shadow: 0 0.45rem 1.2rem rgba(15, 23, 42, 0.18);
}

.ssl-chip.is-success {
    border-color: rgba(var(--bs-success-rgb), 0.32);
    background: rgba(var(--bs-success-rgb), 0.18);
}

.ssl-chip.is-warning {
    border-color: rgba(var(--bs-warning-rgb), 0.4);
    background: rgba(var(--bs-warning-rgb), 0.24);
}

.ssl-chip.is-danger {
    border-color: rgba(var(--bs-danger-rgb), 0.45);
    background: rgba(var(--bs-danger-rgb), 0.24);
}

/* ========================================
   DASHBOARD PROFILE CARD
   ======================================== */
.dashboard-profile-card .profile-photo {
    width: 72px;
    height: 72px;
    object-fit: cover;
}

.dashboard-profile-card .profile-meta {
    font-size: 0.85rem;
    color: var(--bs-secondary-color);
}

/* ========================================
   CLICKABLE ROW
   ======================================== */
.clickable-row {
    transition: background-color 0.15s ease;
    cursor: pointer;
}

.clickable-row:hover {
    background-color: var(--bs-tertiary-bg) !important;
}

/* ========================================
   QUICK LINKS
   ======================================== */
.quick-links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.quick-link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 1rem;
    border-radius: 0.5rem;
    background: var(--bs-tertiary-bg);
    color: var(--bs-body-color);
    text-decoration: none;
    font-size: 0.875rem;
    font-weight: 500;
    transition: all 0.2s ease;
    border: 1px solid var(--bs-border-color);
}

.quick-link:hover {
    background: var(--bs-primary);
    color: white;
    border-color: var(--bs-primary);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(var(--bs-primary-rgb), 0.3);
    text-decoration: none;
}

.quick-link i {
    font-size: 1rem;
    flex-shrink: 0;
}

/* Icons in card headers - ensure proper spacing */
.card-header i.bi {
    margin-right: 0.5rem;
}

.card-header h6 i.bi,
.card-header h5 i.bi {
    margin-right: 0.5rem;
}

/* Section headers icons */
.section-header h2 i.bi {
    margin-right: 0.5rem;
}

[data-bs-theme="dark"] .quick-link {
    background: var(--bs-gray-800);
    border-color: var(--bs-border-color);
}

[data-bs-theme="dark"] .quick-link:hover {
    background: var(--bs-primary);
    border-color: var(--bs-primary);
}

/* ========================================
   RBAC PAGES STYLES
   ======================================== */
.rbac-pages-container {
    max-width: 100%;
}

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

.page-header-section h3 {
    font-size: 1.5rem;
    font-weight: 600;
    margin-bottom: 0.5rem;
}

.controls-panel {
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 0.75rem;
    padding: 1rem;
    margin-bottom: 1.5rem;
}

.search-wrapper {
    position: relative;
    flex: 1;
    min-width: 200px;
    max-width: 400px;
}

.search-wrapper input {
    padding-right: 2.5rem;
}

.search-clear-btn {
    position: absolute;
    right: 0.75rem;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    color: var(--bs-secondary-color);
    cursor: pointer;
    font-size: 0.875rem;
    padding: 0.25rem;
    line-height: 1;
}

.search-clear-btn:hover {
    color: var(--bs-danger);
}

.pages-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 1rem;
}

.loading-spinner {
    width: 40px;
    height: 40px;
    border: 3px solid var(--bs-border-color);
    border-top-color: var(--bs-primary);
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

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

.preview-card {
    overflow-y: auto;
}

.preview-list {
    padding: 0.5rem;
}

.matrix-card {
    border: 1px solid var(--bs-border-color);
}

/* Pages Grid - компактный табличный вид */
.pages-grid {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

/* Page Groups - компактные аккордеоны */
.page-group {
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 0.5rem;
    overflow: hidden;
}

.page-group-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.5rem 1rem;
    background: var(--bs-tertiary-bg);
    cursor: pointer;
    user-select: none;
}

.page-group-header:hover {
    background: var(--bs-secondary-bg);
}

.page-group-title {
    font-weight: 600;
    font-size: 0.9rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.page-group-count {
    background: var(--bs-primary);
    color: white;
    font-size: 0.7rem;
    padding: 0.1rem 0.4rem;
    border-radius: 1rem;
}

.page-group-toggle {
    transition: transform 0.2s ease;
    font-size: 0.75rem;
}

.page-group.collapsed .page-group-toggle {
    transform: rotate(-90deg);
}

.page-group-content {
    display: flex;
    flex-direction: column;
}

.page-group.collapsed .page-group-content {
    display: none;
}

/* Page Card - компактная строка */
.page-card {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 0.5rem 1rem;
    border-bottom: 1px solid var(--bs-border-color);
    transition: background 0.15s ease;
}

.page-card:last-child {
    border-bottom: none;
}

.page-card:hover {
    background: var(--bs-tertiary-bg);
}

.page-card.inactive {
    opacity: 0.6;
}

.page-card-header {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex: 1;
    min-width: 0;
}

.page-card-title {
    font-size: 0.9rem;
    font-weight: 500;
    margin: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.page-card-key {
    font-size: 0.7rem;
    color: var(--bs-secondary-color);
    font-family: monospace;
    white-space: nowrap;
}

.page-card-status {
    flex-shrink: 0;
}

.status-badge {
    display: inline-block;
    padding: 0.15rem 0.4rem;
    border-radius: 0.25rem;
    font-size: 0.65rem;
    font-weight: 600;
}

.status-badge.active {
    background: rgba(25, 135, 84, 0.15);
    color: var(--bs-success);
}

.status-badge.inactive {
    background: rgba(108, 117, 125, 0.15);
    color: var(--bs-secondary);
}

.page-card-body {
    display: none;
}

.page-card-info {
    display: flex;
    align-items: center;
    gap: 1rem;
    font-size: 0.8rem;
    flex-shrink: 0;
}

.info-row {
    display: flex;
    gap: 0.25rem;
    white-space: nowrap;
}

.info-label {
    color: var(--bs-secondary-color);
}

.info-value code {
    font-size: 0.75rem;
    background: var(--bs-tertiary-bg);
    padding: 0.1rem 0.25rem;
    border-radius: 0.2rem;
}

.page-card-roles {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    flex-shrink: 0;
}

.roles-label {
    display: none;
}

.roles-list {
    display: flex;
    flex-wrap: nowrap;
    gap: 0.25rem;
}

.role-badge {
    display: inline-block;
    padding: 0.1rem 0.4rem;
    background: var(--bs-primary);
    color: white;
    font-size: 0.65rem;
    border-radius: 1rem;
    white-space: nowrap;
}

.role-badge.denied {
    background: var(--bs-danger);
}

.page-card-actions {
    display: flex;
    gap: 0.25rem;
    flex-shrink: 0;
}

.page-card-actions .btn {
    padding: 0.2rem 0.5rem;
    font-size: 0.7rem;
}

/* Toast Container */
.toast-container {
    position: fixed;
    top: 1rem;
    right: 1rem;
    z-index: 1100;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

/* Filter Badges */
.filter-badges .count {
    background: rgba(0, 0, 0, 0.1);
    padding: 0.1rem 0.4rem;
    border-radius: 1rem;
    font-size: 0.75rem;
    margin-left: 0.25rem;
}

.filter-badges .filter-badge.active .count {
    background: rgba(255, 255, 255, 0.2);
}

/* ========================================
   SELFSERVICE PORTAL STYLES
   ======================================== */

/* Hero Section */
.selfservice-hero {
    background: linear-gradient(135deg, var(--bs-primary) 0%, #667eea 100%);
    color: white;
    padding: 1.5rem 0;
    margin: -1.5rem -0.75rem 1.5rem;
    border-radius: 0 0 1rem 1rem;
}

.selfservice-hero h1 {
    font-size: 1.5rem;
    font-weight: 600;
    margin-bottom: 0.5rem;
}

.selfservice-hero p {
    font-size: 0.9rem;
    opacity: 0.9;
    margin-bottom: 0;
}

/* Stats Cards */
.stats-card {
    border-radius: 0.75rem;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    border: none;
}

.stats-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.stats-card .card-body {
    padding: 1rem;
    text-align: center;
}

.stats-label {
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.stats-number {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.2;
}

.stats-card-primary { border-left: 4px solid var(--bs-primary); }
.stats-card-warning { border-left: 4px solid var(--bs-warning); }
.stats-card-info { border-left: 4px solid var(--bs-info); }
.stats-card-success { border-left: 4px solid var(--bs-success); }
.stats-card-danger { border-left: 4px solid var(--bs-danger); }

/* Quick Action Cards */
.quick-action-card {
    display: block;
    padding: 1.25rem;
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 0.75rem;
    text-decoration: none;
    color: inherit;
    transition: all 0.2s ease;
    height: 100%;
}

.quick-action-card:hover {
    border-color: var(--bs-primary);
    box-shadow: 0 4px 12px rgba(var(--bs-primary-rgb), 0.15);
    transform: translateY(-2px);
    text-decoration: none;
    color: inherit;
}

.quick-action-icon {
    font-size: 2rem;
    margin-bottom: 0.75rem;
    display: block;
}

.quick-action-title {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: 0.25rem;
}

.quick-action-description {
    font-size: 0.8rem;
    color: var(--bs-secondary-color);
}

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

.search-container .search-icon {
    position: absolute;
    left: 1rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--bs-secondary-color);
    z-index: 1;
}

.search-container .search-input {
    padding-left: 2.5rem;
    border-radius: 2rem;
    border: 2px solid var(--bs-border-color);
}

.search-container .search-input:focus {
    border-color: var(--bs-primary);
    box-shadow: 0 0 0 0.2rem rgba(var(--bs-primary-rgb), 0.15);
}

/* Type Selection Modal */
.type-selection-tile {
    padding: 1.5rem;
    border: 2px solid var(--bs-border-color);
    border-radius: 0.75rem;
    text-align: center;
    cursor: pointer;
    transition: all 0.2s ease;
    height: 100%;
}

.type-selection-tile:hover {
    border-color: var(--bs-primary);
    background: var(--bs-tertiary-bg);
}

.type-selection-tile.type-request:hover {
    border-color: var(--bs-info);
}

.type-selection-tile.type-incident:hover {
    border-color: var(--bs-warning);
}

.type-selection-icon {
    font-size: 2.5rem;
    margin-bottom: 1rem;
    display: block;
}

.type-request .type-selection-icon { color: var(--bs-info); }
.type-incident .type-selection-icon { color: var(--bs-warning); }

.type-selection-title {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: 0.5rem;
}

.type-selection-description {
    font-size: 0.8rem;
    color: var(--bs-secondary-color);
}

/* Empty State */
.empty-state {
    text-align: center;
    padding: 3rem 1rem;
    color: var(--bs-secondary-color);
}

.empty-state i {
    font-size: 3rem;
    opacity: 0.5;
    margin-bottom: 1rem;
}

/* Service Cards (Каталог услуг) */
.service-card {
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 0.75rem;
    cursor: pointer;
    transition: all 0.2s ease;
    height: 100%;
    position: relative;
}

.service-card:hover {
    border-color: var(--bs-primary);
    box-shadow: 0 4px 12px rgba(var(--bs-primary-rgb), 0.15);
    transform: translateY(-2px);
}

.service-card .card-body {
    padding: 1.25rem;
    text-align: center;
}

.service-card-icon {
    font-size: 2.5rem;
    color: var(--bs-primary);
    margin-bottom: 1rem;
    display: block;
}

.service-card-title {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: 0.5rem;
}

.service-card-description {
    font-size: 0.8rem;
    color: var(--bs-secondary-color);
    margin-bottom: 0.75rem;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.category-badge {
    display: inline-block;
    padding: 0.2rem 0.5rem;
    background: var(--bs-tertiary-bg);
    color: var(--bs-secondary-color);
    font-size: 0.7rem;
    border-radius: 1rem;
}

.favorite-star {
    position: absolute;
    top: 0.75rem;
    right: 0.75rem;
    font-size: 1.25rem;
    color: var(--bs-warning);
    cursor: pointer;
    z-index: 1;
}

.favorite-star:hover {
    transform: scale(1.2);
}

.favorite-star .fas {
    color: var(--bs-warning);
}

.favorite-star .far {
    color: var(--bs-secondary-color);
}

/* KB Articles */
.kb-article-item {
    padding: 0.75rem;
    border-bottom: 1px solid var(--bs-border-color);
    transition: background 0.15s ease;
}

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

.kb-article-item:hover {
    background: var(--bs-tertiary-bg);
}

.kb-article-title {
    font-weight: 500;
    color: var(--bs-body-color);
    text-decoration: none;
}

.kb-article-title:hover {
    color: var(--bs-primary);
}

.kb-article-meta {
    font-size: 0.75rem;
    color: var(--bs-secondary-color);
}

/* Gamification Badges */
.gamification-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.75rem;
    background: var(--bs-tertiary-bg);
    border-radius: 0.5rem;
    margin: 0.25rem;
}

.gamification-badge-icon {
    font-size: 1.5rem;
}

.gamification-badge-name {
    font-size: 0.85rem;
    font-weight: 500;
}

/* Breakdown Items */
.breakdown-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.5rem 0;
    border-bottom: 1px solid var(--bs-border-color);
}

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

.breakdown-label {
    color: var(--bs-secondary-color);
}

.breakdown-value {
    font-weight: 600;
}

/* SLA Badge */
.sla-badge {
    display: inline-block;
    padding: 0.2rem 0.5rem;
    border-radius: 0.25rem;
    font-size: 0.7rem;
    font-weight: 600;
}

.sla-badge.sla-ok {
    background: rgba(25, 135, 84, 0.15);
    color: var(--bs-success);
}

.sla-badge.sla-warning {
    background: rgba(255, 193, 7, 0.15);
    color: var(--bs-warning);
}

.sla-badge.sla-breach {
    background: rgba(220, 53, 69, 0.15);
    color: var(--bs-danger);
}

/* ========================================
   PAYMENTS / RECEIPTS STYLES
   ======================================== */

/* Payment Summary Container */
.payment-summary {
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 0.75rem;
    padding: 1.25rem;
}

/* Metrics Row - основные KPI */
.metrics-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
    margin-bottom: 1.25rem;
}

.metric-card {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem;
    background: var(--bs-tertiary-bg);
    border-radius: 0.5rem;
    border-left: 4px solid var(--bs-primary);
}

.metric-card.metric-contracts { border-left-color: var(--bs-primary); }
.metric-card.metric-received { border-left-color: var(--bs-success); }
.metric-card.metric-remaining { border-left-color: var(--bs-warning); }

.metric-icon {
    font-size: 1.75rem;
    opacity: 0.7;
}

.metric-card.metric-contracts .metric-icon { color: var(--bs-primary); }
.metric-card.metric-received .metric-icon { color: var(--bs-success); }
.metric-card.metric-remaining .metric-icon { color: var(--bs-warning); }

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

.metric-label {
    font-size: 0.75rem;
    color: var(--bs-secondary-color);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.metric-value {
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1.2;
}

.metric-sub {
    font-size: 0.8rem;
    color: var(--bs-secondary-color);
}

/* Payment Progress Bar */
.payment-progress-wrap {
    margin-bottom: 1.25rem;
}

.progress-label-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0.5rem;
}

.progress-title {
    font-size: 0.85rem;
    font-weight: 500;
}

.progress-pct {
    font-size: 0.85rem;
    font-weight: 600;
}

.payment-progress {
    display: flex;
    height: 0.75rem;
    border-radius: 0.5rem;
    overflow: hidden;
    background: var(--bs-tertiary-bg);
}

.progress-segment {
    height: 100%;
    transition: width 0.3s ease;
}

.progress-paid {
    background: var(--bs-success);
}

.progress-unpaid {
    background: var(--bs-secondary-bg);
}

/* Status Breakdown */
.status-breakdown {
    margin-bottom: 1.25rem;
}

.status-title {
    font-size: 0.85rem;
    font-weight: 500;
    margin-bottom: 0.75rem;
}

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

.status-card {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 0.75rem 1rem;
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 0.5rem;
    cursor: pointer;
    transition: all 0.2s ease;
    text-align: left;
    width: 100%;
}

.status-card:hover {
    border-color: var(--bs-primary);
    background: var(--bs-tertiary-bg);
}

.status-card.active {
    border-color: var(--bs-primary);
    box-shadow: 0 0 0 2px rgba(var(--bs-primary-rgb), 0.2);
}

.status-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    flex-shrink: 0;
    margin-top: 0.25rem;
}

.status-paid .status-dot { background: var(--bs-success); }
.status-partial .status-dot { background: var(--bs-warning); }
.status-unpaid .status-dot { background: var(--bs-danger); }

.status-info {
    flex: 1;
    min-width: 100px;
}

.status-label {
    display: block;
    font-size: 0.85rem;
    font-weight: 500;
}

.status-count {
    display: block;
    font-size: 0.75rem;
    color: var(--bs-secondary-color);
}

.status-values {
    width: 100%;
    font-size: 0.8rem;
    padding-top: 0.5rem;
    border-top: 1px solid var(--bs-border-color);
    margin-top: 0.25rem;
}

.status-row {
    display: flex;
    justify-content: space-between;
    gap: 0.5rem;
}

.val-label {
    color: var(--bs-secondary-color);
}

/* VAT Details */
.vat-details {
    border-top: 1px solid var(--bs-border-color);
    padding-top: 1rem;
}

.vat-summary {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.85rem;
    font-weight: 500;
    cursor: pointer;
    padding: 0.5rem 0;
}

.vat-summary i {
    transition: transform 0.2s ease;
}

.vat-details[open] .vat-summary i {
    transform: rotate(90deg);
}

.vat-breakdown {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    padding-top: 0.75rem;
}

.vat-item {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.75rem;
    background: var(--bs-tertiary-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 0.5rem;
    font-size: 0.8rem;
    cursor: pointer;
    transition: all 0.2s ease;
}

.vat-item:hover {
    border-color: var(--bs-primary);
    background: var(--bs-body-bg);
}

.vat-label {
    color: var(--bs-secondary-color);
}

.vat-value {
    font-weight: 600;
}

/* Cards Grid (юрлица) */
.cards-grid {
    margin-bottom: 1.5rem;
}

.cards-grid h3 {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: 0.75rem;
}

.cards-grid .cards {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 0.75rem;
}

/* Chart Card */
.chart-card {
    height: 100%;
}

.chart-card .card-header {
    font-size: 0.9rem;
    padding: 0.75rem 1rem;
}

/* Top Table */
.top-table {
    font-size: 0.85rem;
}

.top-table th {
    font-weight: 500;
    white-space: nowrap;
}

.top-table td {
    vertical-align: middle;
}

/* ========================================
   CONSUMABLES STYLES
   ======================================== */

/* Dashboard Grid */
.cons-dashboard-grid {
    margin-bottom: 1rem;
}

/* Dashboard Tile */
.cons-dashboard-tile {
    display: flex;
    flex-direction: column;
    width: 100%;
    padding: 1.25rem;
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 0.75rem;
    cursor: pointer;
    transition: all 0.2s ease;
    text-align: left;
}

.cons-dashboard-tile:hover {
    border-color: var(--bs-primary);
    box-shadow: 0 4px 12px rgba(var(--bs-primary-rgb), 0.15);
    transform: translateY(-2px);
}

.cons-dashboard-tile:focus {
    outline: none;
    border-color: var(--bs-primary);
    box-shadow: 0 0 0 3px rgba(var(--bs-primary-rgb), 0.2);
}

.tile-label {
    font-size: 0.8rem;
    color: var(--bs-secondary-color);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 0.5rem;
}

.tile-value {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.2;
    color: var(--bs-body-color);
}

.tile-subline {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-top: 0.5rem;
    font-size: 0.8rem;
}

.tile-sub {
    color: var(--bs-secondary-color);
}

.tile-subvalue {
    font-weight: 600;
}

/* Consumables Table */
.cons-table {
    font-size: 0.85rem;
}

.cons-table th {
    font-weight: 500;
    white-space: nowrap;
    background: var(--bs-tertiary-bg);
}

.cons-table td {
    vertical-align: middle;
}

/* Stock Badge */
.stock-badge {
    display: inline-block;
    padding: 0.2rem 0.5rem;
    border-radius: 0.25rem;
    font-size: 0.75rem;
    font-weight: 600;
}

.stock-badge.stock-ok {
    background: rgba(25, 135, 84, 0.15);
    color: var(--bs-success);
}

.stock-badge.stock-low {
    background: rgba(255, 193, 7, 0.15);
    color: var(--bs-warning);
}

.stock-badge.stock-out {
    background: rgba(220, 53, 69, 0.15);
    color: var(--bs-danger);
}

/* Consumable Item Card */
.cons-item-card {
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 0.5rem;
    padding: 1rem;
    transition: all 0.2s ease;
}

.cons-item-card:hover {
    border-color: var(--bs-primary);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.cons-item-name {
    font-weight: 600;
    margin-bottom: 0.25rem;
}

.cons-item-sku {
    font-size: 0.75rem;
    color: var(--bs-secondary-color);
    font-family: monospace;
}

.cons-item-stock {
    font-size: 1.25rem;
    font-weight: 700;
}

/* Category Badge */
.cons-category-badge {
    display: inline-block;
    padding: 0.15rem 0.5rem;
    background: var(--bs-tertiary-bg);
    color: var(--bs-secondary-color);
    font-size: 0.7rem;
    border-radius: 1rem;
}

/* ESD Page Header */
.esd-page-header {
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--bs-border-color);
}

/* ESD Button */
.esd-btn {
    transition: all 0.2s ease;
}

.esd-btn:hover {
    transform: translateY(-1px);
}

/* ESD Animate In */
.esd-animate-in {
    animation: esdFadeIn 0.3s ease-out;
}

@keyframes esdFadeIn {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* ========================================
   EQUIPMENT STYLES
   ======================================== */

/* Equipment Card */
.eq-card {
    border: 1px solid var(--bs-border-color);
    border-radius: 0.5rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

.eq-card .card-header {
    background: var(--bs-tertiary-bg);
    border-bottom: 1px solid var(--bs-border-color);
    padding: 0.75rem 1rem;
    font-weight: 500;
}

/* Equipment Table */
.eq-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.85rem;
}

.eq-table thead th {
    background: var(--bs-tertiary-bg);
    border-bottom: 2px solid var(--bs-border-color);
    padding: 0.75rem 0.5rem;
    font-weight: 500;
    white-space: nowrap;
    vertical-align: middle;
}

.eq-table tbody td {
    padding: 0.5rem;
    border-bottom: 1px solid var(--bs-border-color);
    vertical-align: middle;
}

.eq-table tbody tr:hover {
    background: var(--bs-tertiary-bg);
}

.eq-table tbody tr:last-child td {
    border-bottom: none;
}

/* Width helpers for equipment table */
.w-80 { width: 80px; min-width: 80px; }
.w-90 { width: 90px; min-width: 90px; }
.w-110 { width: 110px; min-width: 110px; }
.w-120 { width: 120px; min-width: 120px; }
.w-140 { width: 140px; min-width: 140px; }
.w-200 { width: 200px; min-width: 200px; }

/* Scanner Card */
.scanner-card {
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 0.5rem;
    padding: 1rem;
}

/* Equipment Actions */
.eq-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    justify-content: center;
}

.eq-actions .btn {
    font-size: 0.75rem;
    padding: 0.25rem 0.45rem;
    line-height: 1.2;
    font-weight: 500;
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    border-radius: 0.35rem;
}

/* Text Mono */
.text-mono {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
}

/* Text Truncate 2 lines */
.text-truncate-2 {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* ========================================
   DOCUMENTS STYLES
   ======================================== */

/* Documents Grid */
.documents-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 1rem;
}

/* Document Card */
.doc-card {
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 0.5rem;
    padding: 1rem;
    transition: all 0.2s ease;
    cursor: pointer;
    overflow: hidden;
    min-width: 0;
    word-wrap: break-word;
    overflow-wrap: break-word;
}

.doc-card:hover {
    border-color: var(--bs-primary);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.doc-card-title {
    font-weight: 600;
    margin-bottom: 0.5rem;
}

.doc-card-meta {
    font-size: 0.8rem;
    color: var(--bs-secondary-color);
}

/* Document Card Header */
.doc-card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 0.75rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid var(--bs-border-color);
    flex-wrap: wrap;
    gap: 0.25rem;
}

.doc-card-body {
    margin-bottom: 0.75rem;
}

.doc-card-footer {
    padding-top: 0.75rem;
    border-top: 1px solid var(--bs-border-color);
    min-width: 0;
}

.doc-card-footer .doc-meta {
    flex-wrap: wrap;
    gap: 0.25rem;
}

.doc-card-footer .doc-meta span {
    min-width: 0;
    overflow-wrap: break-word;
    word-break: break-word;
}

.doc-title {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: 0.5rem;
    color: var(--bs-body-color);
    overflow-wrap: break-word;
    word-break: break-word;
}

.doc-description {
    font-size: 0.875rem;
    color: var(--bs-secondary-color);
    line-height: 1.5;
    margin-bottom: 0.5rem;
}

.doc-type-badge {
    font-size: 0.75rem;
    font-weight: 600;
    padding: 0.25rem 0.5rem;
    border-radius: 0.25rem;
}

/* Documents Table Row States (works with Bootstrap .table) */
.table tbody tr.pending {
    --bs-table-bg: rgba(255, 193, 7, 0.08);
    --bs-table-hover-bg: rgba(255, 193, 7, 0.15);
}

.table tbody tr.acknowledged {
    --bs-table-bg: rgba(40, 167, 69, 0.08);
    --bs-table-hover-bg: rgba(40, 167, 69, 0.15);
}

.table tbody tr.mandatory {
    border-left: 3px solid var(--bs-danger);
}

.table tbody tr[onclick] {
    cursor: pointer;
}

/* Dark theme adjustments for document table rows */
[data-bs-theme="dark"] .table tbody tr.pending {
    --bs-table-bg: rgba(255, 193, 7, 0.12);
    --bs-table-hover-bg: rgba(255, 193, 7, 0.2);
}

[data-bs-theme="dark"] .table tbody tr.acknowledged {
    --bs-table-bg: rgba(40, 167, 69, 0.12);
    --bs-table-hover-bg: rgba(40, 167, 69, 0.2);
}

.doc-title-cell {
    max-width: 300px;
}

.doc-title-cell > div:first-child {
    font-weight: 500;
    color: var(--bs-body-color);
    margin-bottom: 0.25rem;
}

.doc-meta {
    font-size: 0.875rem;
    color: var(--bs-secondary-color);
    white-space: nowrap;
}

/* Empty State */
.empty-state {
    text-align: center;
    padding: 3rem 1rem;
    color: var(--bs-secondary-color);
}

.empty-state i {
    font-size: 3rem;
    margin-bottom: 1rem;
    opacity: 0.5;
}

.empty-state h5 {
    color: var(--bs-body-color);
    margin-bottom: 0.5rem;
}

/* Document View Page */
.doc-view-header {
    border-bottom: 2px solid var(--bs-border-color);
    padding-bottom: 1.5rem;
    margin-bottom: 1.5rem;
}

.doc-title-large {
    font-size: 1.75rem;
    font-weight: 600;
    margin-bottom: 0;
    color: var(--bs-body-color);
}

.doc-info-card {
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 0.5rem;
    padding: 1.25rem;
}

.doc-info-card .info-row {
    display: flex;
    justify-content: space-between;
    padding: 0.5rem 0;
    border-bottom: 1px solid var(--bs-border-color);
}

.doc-info-card .info-row:last-child {
    border-bottom: none;
}

.doc-info-card .info-label {
    font-size: 0.875rem;
    color: var(--bs-secondary-color);
}

.doc-info-card .info-value {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--bs-body-color);
    text-align: right;
}

/* Summary Card */
.summary-card {
    background: var(--bs-tertiary-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 0.5rem;
    padding: 1rem;
}

.summary-title {
    font-weight: 600;
    margin-bottom: 0.75rem;
    color: var(--bs-body-color);
    display: flex;
    align-items: center;
}

.summary-content {
    font-size: 0.95rem;
    line-height: 1.6;
    color: var(--bs-body-color);
}

/* File Preview */
.file-preview-container {
    min-height: 400px;
    background: var(--bs-tertiary-bg);
}

.file-preview-container iframe {
    width: 100%;
    height: 700px;
    border: none;
    display: block;
}

.file-preview-container img {
    max-width: 100%;
    height: auto;
    display: block;
}

.file-preview-container .empty-state {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 400px;
}

/* Analytics styles for documents */
.analytics-summary-card {
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color) !important;
}

.analytics-accordion {
    border: 1px solid var(--bs-border-color);
    border-radius: 0.5rem;
    overflow: hidden;
}

.analytics-accordion .accordion-item {
    border-left: none;
    border-right: none;
    border-top: none;
    border-bottom: 1px solid var(--bs-border-color);
}

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

.analytics-accordion .accordion-button {
    padding: 0.75rem 1rem;
    background: var(--bs-body-bg);
}

.analytics-accordion .accordion-button:not(.collapsed) {
    background: var(--bs-tertiary-bg);
    color: var(--bs-body-color);
    box-shadow: none;
}

.analytics-accordion .accordion-body {
    padding: 0;
    background: var(--bs-body-bg);
}

.analytics-users-table {
    margin-bottom: 0;
}

.analytics-users-table thead {
    background: var(--bs-tertiary-bg);
}

.analytics-users-table th {
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
    border-bottom: 1px solid var(--bs-border-color);
    letter-spacing: 0.5px;
    color: var(--bs-secondary-color);
}

.status-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    display: inline-block;
}

.table-warning-subtle {
    background-color: rgba(255, 193, 7, 0.1);
}

[data-bs-theme="dark"] .table-warning-subtle {
    background-color: rgba(255, 193, 7, 0.15);
}

.collapse-row td {
    padding: 0 !important;
}

/* Border Dashed (Bootstrap 5 missing utility) */
.border-dashed {
    border-style: dashed !important;
}

/* Drop Zone for file uploads */
.drop-zone,
#bulk-drop-zone {
    border: 2px dashed var(--bs-border-color);
    border-radius: 0.5rem;
    padding: 2rem;
    text-align: center;
    cursor: pointer;
    transition: all 0.2s ease;
    background: var(--bs-tertiary-bg);
}

.drop-zone:hover,
#bulk-drop-zone:hover,
.drop-zone.drag-over,
#bulk-drop-zone.drag-over {
    border-color: var(--bs-primary);
    background: rgba(var(--bs-primary-rgb), 0.05);
}

.drop-zone.drag-over,
#bulk-drop-zone.drag-over {
    border-color: var(--bs-primary);
    background: rgba(var(--bs-primary-rgb), 0.1);
}

[data-bs-theme="dark"] .drop-zone,
[data-bs-theme="dark"] #bulk-drop-zone {
    background: var(--bs-tertiary-bg);
}

[data-bs-theme="dark"] .drop-zone:hover,
[data-bs-theme="dark"] #bulk-drop-zone:hover {
    background: rgba(var(--bs-primary-rgb), 0.1);
}

/* Custom border colors */
.border-purple {
    border-color: #7030A0 !important;
}

/* List group item hover for notifications */
.list-group-item-action {
    cursor: pointer;
}

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

/* Table light header in dark mode */
[data-bs-theme="dark"] .table-light {
    --bs-table-bg: var(--bs-tertiary-bg);
    --bs-table-color: var(--bs-body-color);
}

/* Progress bar improvements */
.progress {
    background-color: var(--bs-tertiary-bg);
}

/* Card stat colors */
.card.bg-primary,
.card.bg-success,
.card.bg-warning,
.card.bg-danger,
.card.bg-info,
.card.bg-secondary {
    border: none;
}

/* Skeleton Loaders */
.skeleton-card {
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 0.5rem;
    padding: 1rem;
}

.skeleton-line {
    height: 1rem;
    background: linear-gradient(90deg, var(--bs-tertiary-bg) 25%, var(--bs-secondary-bg) 50%, var(--bs-tertiary-bg) 75%);
    background-size: 200% 100%;
    animation: skeleton-loading 1.5s infinite;
    border-radius: 0.25rem;
    margin-bottom: 0.5rem;
}

.skeleton-line.short { width: 40%; }
.skeleton-line.medium { width: 70%; }

@keyframes skeleton-loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* View Toggle */
.view-toggle {
    display: inline-flex;
    background: var(--bs-tertiary-bg);
    border-radius: 0.375rem;
    padding: 0.25rem;
}

.view-toggle .btn {
    padding: 0.375rem 0.75rem;
    border: none;
    background: transparent;
    color: var(--bs-secondary-color);
}

.view-toggle .btn.active {
    background: var(--bs-body-bg);
    color: var(--bs-primary);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

/* Nav Tabs Custom */
.nav-tabs-custom {
    border-bottom: none;
    gap: 0.25rem;
}

.nav-tabs-custom .nav-link {
    border: 1px solid transparent;
    border-radius: 0.375rem;
    padding: 0.5rem 1rem;
    color: var(--bs-secondary-color);
    background: transparent;
}

.nav-tabs-custom .nav-link:hover {
    background: var(--bs-tertiary-bg);
    border-color: transparent;
}

.nav-tabs-custom .nav-link.active {
    background: var(--bs-primary);
    color: white;
    border-color: var(--bs-primary);
}

/* ========================================
   KANBAN STYLES
   ======================================== */

/* Kanban Board */
#kanban-board {
    display: flex;
    gap: 1rem;
    overflow-x: auto;
    padding-bottom: 1rem;
}

.kanban-column-wrapper {
    flex: 0 0 280px;
    min-width: 280px;
}

.kanban-column {
    min-height: 400px;
    max-height: 80vh;
    overflow-y: auto;
}

/* Kanban Card */
.kanban-card {
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 0.375rem;
    padding: 0.75rem;
    margin-bottom: 0.5rem;
    cursor: grab;
    transition: all 0.2s ease;
}

.kanban-card:hover {
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.kanban-card.dragging {
    opacity: 0.5;
    cursor: grabbing;
}

.kanban-card-title {
    font-weight: 500;
    font-size: 0.9rem;
    margin-bottom: 0.5rem;
}

.kanban-card-meta {
    font-size: 0.75rem;
    color: var(--bs-secondary-color);
}

.kanban-card-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.25rem;
    margin-top: 0.5rem;
}

.kanban-tag {
    display: inline-block;
    padding: 0.1rem 0.4rem;
    background: var(--bs-tertiary-bg);
    color: var(--bs-secondary-color);
    font-size: 0.65rem;
    border-radius: 0.25rem;
}

/* ========================================
   WORKFLOW STYLES
   ======================================== */

.workflow-card {
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 0.5rem;
    padding: 1rem;
    margin-bottom: 0.75rem;
}

.workflow-card:hover {
    border-color: var(--bs-primary);
}

.workflow-status {
    display: inline-block;
    padding: 0.2rem 0.5rem;
    border-radius: 0.25rem;
    font-size: 0.75rem;
    font-weight: 500;
}

.workflow-status.pending { background: rgba(255, 193, 7, 0.15); color: var(--bs-warning); }
.workflow-status.approved { background: rgba(25, 135, 84, 0.15); color: var(--bs-success); }
.workflow-status.rejected { background: rgba(220, 53, 69, 0.15); color: var(--bs-danger); }

/* ========================================
   REPORT STYLES
   ======================================== */

.report-card {
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 0.5rem;
    padding: 1rem;
    height: 100%;
}

.report-card-title {
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--bs-secondary-color);
    margin-bottom: 0.5rem;
}

.report-card-value {
    font-size: 1.75rem;
    font-weight: 700;
}

.report-card-change {
    font-size: 0.8rem;
}

.report-card-change.positive { color: var(--bs-success); }
.report-card-change.negative { color: var(--bs-danger); }

/* ========================================
   CLEARANCE STYLES
   ======================================== */

.clearance-step {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 0.75rem;
    border-bottom: 1px solid var(--bs-border-color);
}

.clearance-step:last-child {
    border-bottom: none;
}

.clearance-step-number {
    width: 2rem;
    height: 2rem;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bs-tertiary-bg);
    border-radius: 50%;
    font-weight: 600;
    font-size: 0.85rem;
}

.clearance-step.completed .clearance-step-number {
    background: var(--bs-success);
    color: white;
}

.clearance-step.current .clearance-step-number {
    background: var(--bs-primary);
    color: white;
}

/* ========================================
   TICKET STYLES
   ======================================== */

.ticket-card {
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 0.5rem;
    padding: 1rem;
    transition: all 0.2s ease;
}

.ticket-card:hover {
    border-color: var(--bs-primary);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.ticket-priority {
    width: 4px;
    border-radius: 2px;
}

.ticket-priority.low { background: var(--bs-secondary); }
.ticket-priority.medium { background: var(--bs-primary); }
.ticket-priority.high { background: var(--bs-warning); }
.ticket-priority.critical { background: var(--bs-danger); }

.ticket-status-badge {
    display: inline-block;
    padding: 0.2rem 0.5rem;
    border-radius: 0.25rem;
    font-size: 0.7rem;
    font-weight: 600;
}

/* ========================================
   LOADING SPINNER
   ======================================== */

.loading-spinner {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 3rem;
}

.loading-spinner i {
    font-size: 2rem;
    color: var(--bs-primary);
    animation: spin 1s linear infinite;
}

@keyframes spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

/* ========================================
   TICKET CHAT STYLES
   ======================================== */

/* Chat Variables */
:root {
    --chat-bg-light: #ffffff;
    --chat-bg-dark: #f8f9fa;
    --chat-border: #dee2e6;
    --chat-text-muted: #6c757d;
    --chat-own-bg: #007bff;
    --chat-own-color: #ffffff;
    --chat-other-bg: #ffffff;
    --chat-other-border: #dee2e6;
    --chat-typing-bg: #f0f0f0;
}

[data-bs-theme="dark"] {
    --chat-bg-light: #212529;
    --chat-bg-dark: #1a1d20;
    --chat-border: #495057;
    --chat-text-muted: #adb5bd;
    --chat-own-bg: #0d6efd;
    --chat-own-color: #ffffff;
    --chat-other-bg: #343a40;
    --chat-other-border: #495057;
    --chat-typing-bg: #495057;
}

/* Chat Wrapper */
.ticket-chat-wrapper {
    display: flex;
    flex-direction: column;
    height: 100%;
    background: var(--chat-bg-dark);
    border-radius: 0.5rem;
    overflow: hidden;
}

/* Chat Messages Container */
#chat-messages-container {
    flex: 1;
    overflow-y: auto;
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    background: var(--chat-bg-light);
}

/* Chat Message */
.chat-message {
    display: flex;
    flex-direction: column;
    margin-bottom: 0.5rem;
    animation: slideIn 0.3s ease-out;
}

@keyframes slideIn {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Message from others */
.chat-message-other {
    align-items: flex-start;
}

.chat-message-other .chat-message-body {
    background: var(--chat-other-bg);
    border: 1px solid var(--chat-other-border);
    border-radius: 0.5rem 0.5rem 0.5rem 0;
    padding: 0.5rem 0.7rem;
    max-width: 70%;
    word-wrap: break-word;
    color: inherit;
    font-size: 0.7rem;
}

/* Message from current user */
.chat-message-own {
    align-items: flex-end;
}

.chat-message-own .chat-message-body {
    background: var(--chat-own-bg);
    color: var(--chat-own-color);
    border-radius: 0.5rem 0.5rem 0 0.5rem;
    padding: 0.5rem 0.7rem;
    max-width: 70%;
    word-wrap: break-word;
    font-size: 0.7rem;
}

/* Message header */
.chat-message-header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.25rem;
    font-size: 0.6rem;
    color: var(--chat-text-muted);
}

.chat-message-own .chat-message-header {
    justify-content: flex-end;
}

.chat-message-header small {
    font-size: 0.55rem;
}

/* Message actions */
.chat-message-actions {
    display: none;
    gap: 0.25rem;
    margin-left: 0.5rem;
}

.chat-message:hover .chat-message-actions {
    display: flex;
}

.chat-message-actions .btn {
    padding: 0.125rem 0.25rem;
    font-size: 0.75rem;
}

/* Chat input area */
.ticket-chat-input-area {
    padding: 1rem;
    background: var(--chat-bg-light);
    border-top: 1px solid var(--chat-border);
}

.chat-input-group {
    display: flex;
    gap: 0.5rem;
    align-items: flex-end;
}

#chat-message-input {
    flex: 1;
    resize: vertical;
    min-height: 2.5rem;
    max-height: 6rem;
    border-radius: 0.5rem;
    border: 1px solid var(--chat-border);
    padding: 0.5rem;
    font-family: inherit;
    font-size: 0.95rem;
    background: var(--chat-bg-light);
    color: inherit;
}

#chat-message-input:focus {
    border-color: #007bff;
    box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
    background: var(--chat-bg-light);
    color: inherit;
}

#chat-send-btn {
    padding: 0.5rem 1rem;
    white-space: nowrap;
}

/* Internal checkbox */
.chat-internal-checkbox {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-top: 0.5rem;
    font-size: 0.875rem;
}

#chat-internal-checkbox {
    cursor: pointer;
}

/* Typing indicator */
#chat-typing-indicator {
    padding: 0.75rem 1.5rem;
    background: var(--chat-typing-bg);
    border-top: 1px solid var(--chat-border);
    font-size: 0.875rem;
    color: var(--chat-text-muted);
    display: none;
    animation: fadeIn 0.3s ease-out;
}

@keyframes fadeIn {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

/* Typing dots animation */
.typing-dots {
    display: inline-flex;
    gap: 0.25rem;
}

.typing-dot {
    width: 0.5rem;
    height: 0.5rem;
    border-radius: 50%;
    background: var(--chat-text-muted);
    animation: typing 1.4s infinite;
}

.typing-dot:nth-child(2) {
    animation-delay: 0.2s;
}

.typing-dot:nth-child(3) {
    animation-delay: 0.4s;
}

@keyframes typing {
    0%, 60%, 100% {
        opacity: 0.5;
        transform: translateY(0);
    }
    30% {
        opacity: 1;
        transform: translateY(-10px);
    }
}

/* Chat empty state */
.chat-empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100%;
    color: var(--chat-text-muted);
    text-align: center;
}

.chat-empty-state i {
    font-size: 2rem;
    margin-bottom: 1rem;
    opacity: 0.5;
}

/* Chat scrollbar */
#chat-messages-container::-webkit-scrollbar {
    width: 8px;
}

#chat-messages-container::-webkit-scrollbar-track {
    background: var(--chat-bg-light);
}

#chat-messages-container::-webkit-scrollbar-thumb {
    background: var(--chat-border);
    border-radius: 4px;
}

#chat-messages-container::-webkit-scrollbar-thumb:hover {
    background: var(--chat-text-muted);
}

/* Chat responsive */
@media (max-width: 768px) {
    .chat-message-other .chat-message-body,
    .chat-message-own .chat-message-body {
        max-width: 85%;
    }

    .chat-input-group {
        flex-direction: column;
    }

    #chat-send-btn {
        width: 100%;
    }
}

/* ========================================
   KNOWLEDGE BASE STYLES
   ======================================== */

/* KB Search Card */
.kb-search-card {
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 0.5rem;
    padding: 1rem;
    display: flex;
    align-items: center;
    gap: 1rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

.kb-search-icon {
    color: var(--bs-secondary-color);
    font-size: 1.25rem;
}

.kb-search-input {
    flex: 1;
    border: none;
    outline: none;
    font-size: 1rem;
    color: inherit;
    background: transparent;
}

.kb-search-input::placeholder {
    color: var(--bs-secondary-color);
}

.kb-search-btn {
    padding: 0.5rem 1rem;
    background: var(--bs-primary);
    color: white;
    border: none;
    border-radius: 0.375rem;
    font-size: 0.875rem;
    cursor: pointer;
    transition: background 0.2s ease;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.kb-search-btn:hover {
    background: var(--bs-primary-hover, #0b5ed7);
}

/* KB Filters */
.kb-filters {
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 0.5rem;
    padding: 0.75rem;
}

.kb-filters-buttons {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.kb-filter-btn {
    padding: 0.5rem 1rem;
    background: transparent;
    border: 1px solid var(--bs-border-color);
    border-radius: 0.375rem;
    color: var(--bs-secondary-color);
    cursor: pointer;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.875rem;
}

.kb-filter-btn:hover {
    background: var(--bs-tertiary-bg);
    border-color: var(--bs-primary);
    color: var(--bs-primary);
}

.kb-filter-btn.active {
    background: var(--bs-primary);
    color: white;
    border-color: var(--bs-primary);
}

/* KB Articles Header */
.kb-articles-header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 1rem;
}

.kb-articles-title {
    font-size: 1.25rem;
    font-weight: 600;
    margin: 0;
    color: var(--bs-body-color);
}

.kb-count-badge {
    background: var(--bs-primary);
    color: white;
    padding: 0.25rem 0.5rem;
    border-radius: 0.25rem;
    font-size: 0.75rem;
    font-weight: 600;
}

/* KB Article Card */
.kb-article-card {
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 0.5rem;
    padding: 1rem;
    margin-bottom: 1rem;
    transition: all 0.2s ease;
    cursor: pointer;
}

.kb-article-card:hover {
    border-color: var(--bs-primary);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.kb-article-title {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: 0.5rem;
    color: inherit;
}

.kb-article-excerpt {
    font-size: 0.875rem;
    color: var(--bs-secondary-color);
    margin-bottom: 0.5rem;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.kb-article-meta {
    font-size: 0.75rem;
    color: var(--bs-secondary-color);
    display: flex;
    gap: 1rem;
    align-items: center;
}

.kb-article-category {
    display: inline-block;
    padding: 0.125rem 0.5rem;
    background: var(--bs-tertiary-bg);
    color: var(--bs-secondary-color);
    border-radius: 0.25rem;
    font-size: 0.7rem;
    font-weight: 600;
}

.kb-article-date {
    color: var(--bs-secondary-color);
}

/* KB Article Content */
.kb-article-content {
    font-size: 1rem;
    line-height: 1.7;
    color: var(--bs-body-color);
}

.kb-article-content h1,
.kb-article-content h2,
.kb-article-content h3,
.kb-article-content h4,
.kb-article-content h5,
.kb-article-content h6 {
    font-weight: 600;
    margin-top: 1.5rem;
    margin-bottom: 0.75rem;
}

.kb-article-content h1 { font-size: 1.75rem; }
.kb-article-content h2 { font-size: 1.5rem; }
.kb-article-content h3 { font-size: 1.25rem; }
.kb-article-content h4 { font-size: 1.1rem; }
.kb-article-content h5 { font-size: 1rem; }
.kb-article-content h6 { font-size: 0.875rem; }

.kb-article-content p {
    margin-bottom: 1rem;
}

.kb-article-content ul,
.kb-article-content ol {
    margin-bottom: 1rem;
    padding-left: 2rem;
}

.kb-article-content li {
    margin-bottom: 0.5rem;
}

.kb-article-content code {
    background: var(--bs-tertiary-bg);
    padding: 0.125rem 0.375rem;
    border-radius: 0.25rem;
    font-size: 0.875rem;
    font-family: monospace;
}

.kb-article-content pre {
    background: var(--bs-tertiary-bg);
    padding: 1rem;
    border-radius: 0.375rem;
    overflow-x: auto;
    margin-bottom: 1rem;
}

.kb-article-content pre code {
    background: transparent;
    padding: 0;
}

.kb-article-content blockquote {
    border-left: 4px solid var(--bs-primary);
    padding-left: 1rem;
    margin-bottom: 1rem;
    color: var(--bs-secondary-color);
}

.kb-article-content img {
    max-width: 100%;
    height: auto;
    border-radius: 0.375rem;
    margin: 1rem 0;
}

.kb-article-content table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 1rem;
}

.kb-article-content th,
.kb-article-content td {
    border: 1px solid var(--bs-border-color);
    padding: 0.5rem;
}

.kb-article-content th {
    background: var(--bs-tertiary-bg);
    font-weight: 600;
}

/* KB Table of Contents */
.kb-toc-nav {
    position: sticky;
    top: 1rem;
}

.kb-toc-nav ul {
    list-style: none;
    padding-left: 0;
    margin: 0;
}

.kb-toc-nav li {
    margin-bottom: 0.5rem;
}

.kb-toc-nav a {
    color: var(--bs-secondary-color);
    text-decoration: none;
    font-size: 0.875rem;
    display: block;
    padding: 0.25rem 0.5rem;
    border-radius: 0.25rem;
    transition: all 0.2s ease;
}

.kb-toc-nav a:hover {
    background: var(--bs-tertiary-bg);
    color: var(--bs-primary);
}

.kb-toc-nav .toc-level-2 {
    padding-left: 1rem;
}

.kb-toc-nav .toc-level-3 {
    padding-left: 2rem;
}

/* KB Feedback Section */
.kb-feedback-section {
    padding: 1rem;
    background: var(--bs-tertiary-bg);
    border-radius: 0.5rem;
    margin-top: 1rem;
}

/* ========================================
   CONTRACTOR PROFILES MODULE
   ======================================== */

/* Таблица профилей СЗ/ИП */
#profilesTable {
    table-layout: fixed;
    width: 100%;
}

#profilesTable th:first-child,
#profilesTable td:first-child {
    width: 25%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

#profilesTable th:nth-child(2),
#profilesTable td:nth-child(2) { width: 7%; }

#profilesTable th:nth-child(3),
#profilesTable td:nth-child(3) { width: 12%; }

#profilesTable th:nth-child(4),
#profilesTable td:nth-child(4) { width: 13%; }

#profilesTable th:nth-child(5),
#profilesTable td:nth-child(5) { width: 13%; }

#profilesTable th:nth-child(6),
#profilesTable td:nth-child(6) { width: 14%; }

#profilesTable th:last-child,
#profilesTable td:last-child { width: 16%; }

#profilesTable td {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Таблицы Excel СЗ/ИП */
.excel-table-sz,
.excel-table-ip {
    font-size: 0.75rem;
    table-layout: auto;
    width: 100%;
}

.excel-table-sz th,
.excel-table-sz td,
.excel-table-ip th,
.excel-table-ip td {
    white-space: nowrap;
    padding: 0.35rem 0.5rem;
    vertical-align: middle;
}

.excel-table-sz th:first-child,
.excel-table-sz td:first-child,
.excel-table-ip th:first-child,
.excel-table-ip td:first-child {
    text-align: center;
    width: 35px;
    min-width: 35px;
}

/* ========================================
   DASHBOARD SEMANTIC SEARCH DROPDOWN
   ======================================== */
#dash-search-wrap {
    position: relative;
    max-width: 480px;
}
#dash-search-icon {
    background-color: #fff !important;
    color: #6c757d;
    border-color: #dee2e6;
}
[data-bs-theme="dark"] #dash-search-icon {
    background-color: rgb(33, 37, 41) !important;
    color: #adb5bd;
    border-color: rgba(255, 255, 255, .15);
}
#dash-search-dropdown {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    z-index: 1050;
    background: var(--bs-body-bg, #fff);
    border: 1px solid var(--bs-border-color, #dee2e6);
    border-top: none;
    border-radius: 0 0 .5rem .5rem;
    box-shadow: 0 .5rem 1rem rgba(0,0,0,.12);
    max-height: 420px;
    overflow-y: auto;
}
#dash-search-dropdown.show { display: block; }

.dash-search-item {
    display: block;
    padding: .6rem .75rem;
    text-decoration: none;
    color: var(--bs-body-color);
    border-bottom: 1px solid var(--bs-border-color-translucent, rgba(0,0,0,.06));
    transition: background .12s;
    cursor: pointer;
}
.dash-search-item:hover,
.dash-search-item:focus {
    background: var(--bs-tertiary-bg, #f8f9fa);
    color: var(--bs-body-color);
    outline: none;
}
.dash-search-title {
    font-weight: 600;
    font-size: .875rem;
    line-height: 1.3;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.dash-search-snippet {
    font-size: .78rem;
    color: var(--bs-secondary-color, #6c757d);
    line-height: 1.35;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.dash-search-badge {
    font-size: .7rem;
    min-width: 36px;
    text-align: center;
    flex-shrink: 0;
    margin-top: 2px;
}
.dash-search-status {
    padding: .75rem 1rem;
    font-size: .85rem;
    display: flex;
    align-items: center;
}
.dash-search-footer {
    padding: .4rem .75rem;
    font-size: .75rem;
    display: flex;
    justify-content: space-between;
    border-top: 1px solid var(--bs-border-color-translucent, rgba(0,0,0,.06));
    background: var(--bs-tertiary-bg, #f8f9fa);
}

/* ========================================
   HR VACATION PLANS CALENDAR
   ======================================== */

/* CSS переменная для размера ячейки дня */
:root {
    --calendar-day-size: 18px;
}

/* Обёртка таблицы календаря */
.calendar-table-wrapper {
    overflow-x: auto;
    margin-bottom: 1rem;
}

.absence-calendar-wrapper {
    overflow-x: auto;
    max-width: 100%;
}

/* Таблица календаря */
.calendar-table {
    border-collapse: collapse;
    font-size: 0.75rem;
    min-width: max-content;
}

.calendar-table th,
.calendar-table td {
    padding: 0;
    vertical-align: middle;
}

/* Sticky колонка с именами сотрудников */
.absence-calendar-sticky {
    position: sticky;
    left: 0;
    z-index: 5;
    background: var(--bs-body-bg, #fff);
    min-width: 180px;
    max-width: 220px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    border-right: 2px solid var(--bs-border-color, #dee2e6);
}

[data-bs-theme="dark"] .absence-calendar-sticky {
    background: var(--bs-body-bg, #212529);
}

.absence-calendar-header {
    font-weight: 600;
    background: var(--bs-secondary-bg, #e9ecef) !important;
}

[data-bs-theme="dark"] .absence-calendar-header {
    background: var(--bs-tertiary-bg, #343a40) !important;
}

.absence-calendar-cell {
    font-size: 0.8rem;
}

/* Заголовок месяца */
.calendar-month-header {
    font-weight: 600;
    text-align: center;
    background: var(--bs-secondary-bg, #e9ecef);
    padding: 0.25rem !important;
}

[data-bs-theme="dark"] .calendar-month-header {
    background: var(--bs-tertiary-bg, #343a40);
}

.calendar-month-label {
    font-size: 0.75rem;
    font-weight: 600;
}

/* Строка с номерами дней */
.calendar-day-header {
    padding: 0 !important;
}

.calendar-month-days {
    display: grid;
    gap: 1px;
}

.calendar-day-number {
    display: flex;
    align-items: center;
    justify-content: center;
    width: var(--calendar-day-size);
    height: 16px;
    font-size: 0.6rem;
    font-weight: 500;
    color: var(--bs-secondary-color, #6c757d);
    background: var(--bs-body-bg, #fff);
}

[data-bs-theme="dark"] .calendar-day-number {
    background: var(--bs-body-bg, #212529);
}

/* Выходные дни в заголовке */
.calendar-day-number.weekend {
    background: rgba(108, 117, 125, 0.15);
    color: var(--bs-secondary-color, #6c757d);
}

/* Праздничные дни в заголовке */
.calendar-day-number.holiday {
    background: rgba(220, 53, 69, 0.2);
    color: var(--bs-danger, #dc3545);
    font-weight: 700;
}

/* Строка группы (отдел) */
.calendar-group-row td {
    background: var(--bs-secondary-bg, #e9ecef) !important;
    font-weight: 600;
    font-size: 0.8rem;
}

[data-bs-theme="dark"] .calendar-group-row td {
    background: var(--bs-tertiary-bg, #343a40) !important;
}

.calendar-cell-empty {
    background: var(--bs-secondary-bg, #e9ecef);
}

[data-bs-theme="dark"] .calendar-cell-empty {
    background: var(--bs-tertiary-bg, #343a40);
}

/* Ячейка тела календаря */
.calendar-body-cell {
    padding: 2px 0 !important;
}

/* Сетка ячеек месяца */
.calendar-month-cells {
    display: grid;
    gap: 1px;
}

/* Ячейка плана (квадратик) */
.calendar-plan-cell {
    width: var(--calendar-day-size);
    height: var(--calendar-day-size);
    border-radius: 2px;
    transition: transform 0.1s ease;
    cursor: default;
}

.calendar-plan-cell:hover {
    transform: scale(1.2);
    z-index: 10;
    position: relative;
}

/* Заполненная ячейка (есть план) */
.calendar-plan-cell.filled {
    cursor: pointer;
}

/* Выходные дни */
.calendar-plan-cell.weekend {
    background: rgba(108, 117, 125, 0.1) !important;
}

/* Праздничные дни */
.calendar-plan-cell.holiday {
    background: rgba(220, 53, 69, 0.15) !important;
    border: 1px dashed rgba(220, 53, 69, 0.4) !important;
}

/* Строка месяца в заголовке */
.calendar-month-row th {
    border-bottom: 1px solid var(--bs-border-color, #dee2e6);
}

/* Строка дней в заголовке */
.calendar-day-row th {
    border-bottom: 2px solid var(--bs-border-color, #dee2e6);
}

/* Адаптивность */
@media (max-width: 768px) {
    :root {
        --calendar-day-size: 14px;
    }
    
    .absence-calendar-sticky {
        min-width: 120px;
        max-width: 150px;
        font-size: 0.7rem;
    }
    
    .calendar-day-number {
        font-size: 0.5rem;
        height: 14px;
    }
}

/* ========================================
   HR PLANS PAGE - VIRTUAL SCROLL LAYOUT
   ======================================== */

/* Контейнер страницы планов с фиксированной высотой */
#vacationPlansApp {
    display: flex;
    flex-direction: column;
    height: calc(100vh - 56px); /* 56px - высота navbar */
    overflow: hidden;
}

/* Фиксированная шапка страницы (заголовок + фильтры + вкладки) */
.plans-header-fixed {
    flex-shrink: 0;
    background: var(--bs-body-bg, #fff);
    z-index: 10;
}

[data-bs-theme="dark"] .plans-header-fixed {
    background: var(--bs-body-bg, #212529);
}

/* Прокручиваемый контент */
.plans-content-scroll {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    min-height: 0; /* Важно для flex */
}

/* Таблица планов с фиксированной шапкой */
.plans-table-wrapper {
    height: 100%;
    overflow: auto;
}

.plans-table-wrapper .table thead {
    position: sticky;
    top: 0;
    z-index: 5;
    background: var(--bs-secondary-bg, #e9ecef);
}

[data-bs-theme="dark"] .plans-table-wrapper .table thead {
    background: var(--bs-tertiary-bg, #343a40);
}

/* Календарь с ограниченной высотой */
#plansCalendar {
    max-height: calc(100vh - 280px);
    overflow: auto;
}

/* Sticky заголовок таблицы календаря */
.calendar-table thead {
    position: sticky;
    top: 0;
    z-index: 6;
}

.calendar-table .calendar-month-row th,
.calendar-table .calendar-day-row th {
    background: var(--bs-secondary-bg, #e9ecef);
}

[data-bs-theme="dark"] .calendar-table .calendar-month-row th,
[data-bs-theme="dark"] .calendar-table .calendar-day-row th {
    background: var(--bs-tertiary-bg, #343a40);
}

/* Tab content занимает всё доступное пространство */
#vacationPlansApp .tab-content {
    flex: 1;
    min-height: 0;
    display: flex;
    flex-direction: column;
}

#vacationPlansApp .tab-pane {
    flex: 1;
    min-height: 0;
    display: none;
    flex-direction: column;
}

#vacationPlansApp .tab-pane.show.active {
    display: flex;
}

/* Карточка календаря занимает всё пространство */
#tab-calendar .card {
    flex: 1;
    min-height: 0;
    display: flex;
    flex-direction: column;
}

#tab-calendar .card-body {
    flex: 1;
    min-height: 0;
    overflow: hidden;
    padding: 0.5rem !important;
}

/* Список планов занимает всё пространство */
#tab-list .plans-table-wrapper {
    flex: 1;
    min-height: 0;
}

/* Форма добавления плана */
#tab-add {
    overflow-y: auto;
}

/* ========================================
   Интеграция Documents ↔ Documents V1
   ======================================== */

#v1AckLinkBlock {
    transition: all 0.2s ease;
}

#v1AckLinkBlock:hover {
    box-shadow: 0 0.25rem 0.75rem rgba(0, 0, 0, 0.1) !important;
}

#createAckModal .form-select[multiple] {
    border-radius: 0.375rem;
}

#createAckModal .form-select[multiple] option {
    padding: 0.35rem 0.5rem;
}

#createAckModal .form-select[multiple] option:checked {
    background: var(--bs-primary);
    color: #fff;
}

/* ========================================
   Feedback Module
   ======================================== */

.feedback-score-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.5rem;
    height: 2rem;
    font-weight: 600;
    border-radius: 0.5rem;
}

.feedback-task-escalated {
    border-left: 3px solid var(--bs-danger) !important;
}

.feedback-kpi-card .card-body {
    padding: 1.25rem;
}

.feedback-kpi-card .h4 {
    font-weight: 700;
    margin-bottom: 0;
}

/* --- Feedback v2: Score circles --- */
.fb-score-circle {
    width: 52px; height: 52px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-weight: 700; font-size: 1.1rem; color: #fff; flex-shrink: 0;
}
.fb-score-positive { background: linear-gradient(135deg, #22c55e, #16a34a); }
.fb-score-negative { background: linear-gradient(135deg, #ef4444, #dc2626); }
.fb-score-neutral  { background: linear-gradient(135deg, #f59e0b, #d97706); }

/* --- Feedback v2: Submission cards --- */
.fb-card-submission {
    border: none; border-radius: 12px;
    box-shadow: 0 1px 4px rgba(0,0,0,0.06); transition: box-shadow 0.2s, transform 0.15s;
    cursor: pointer; overflow: hidden;
}
.fb-card-submission:hover { box-shadow: 0 4px 16px rgba(0,0,0,0.12); transform: translateY(-1px); }
.fb-card-submission.negative { border-left: 4px solid #ef4444; }
.fb-card-submission.positive { border-left: 4px solid #22c55e; }

/* --- Feedback v2: Rating bars --- */
.fb-rating-bar { height: 8px; border-radius: 4px; background: #e5e7eb; overflow: hidden; }
.fb-rating-bar-fill { height: 100%; border-radius: 4px; transition: width 0.5s ease; }
.fb-rating-bar-fill.good  { background: linear-gradient(90deg, #22c55e, #4ade80); }
.fb-rating-bar-fill.mid   { background: linear-gradient(90deg, #f59e0b, #fbbf24); }
.fb-rating-bar-fill.bad   { background: linear-gradient(90deg, #ef4444, #f87171); }

/* --- Feedback v2: Answer detail cards --- */
.fb-answer-card { background: #f8fafc; border-radius: 10px; padding: 14px 16px; margin-bottom: 10px; border: 1px solid #e2e8f0; }
.fb-bool-yes { color: #16a34a; font-weight: 600; }
.fb-bool-no  { color: #dc2626; font-weight: 600; }
.fb-text-answer { background: #fff; border-radius: 8px; padding: 10px 14px; border: 1px solid #e2e8f0; font-style: italic; color: #475569; }
.fb-detail-header { background: linear-gradient(135deg, #f8fafc, #eef2ff); border-radius: 12px; padding: 20px; margin-bottom: 16px; }
.fb-stat-mini { text-align: center; padding: 8px 0; }
.fb-stat-mini .fb-stat-val { font-size: 1.5rem; font-weight: 700; line-height: 1; }
.fb-stat-mini .fb-stat-label { font-size: 0.75rem; color: #64748b; margin-top: 2px; }

/* --- Feedback v2: Dark theme --- */
[data-bs-theme="dark"] .fb-answer-card { background: #1e293b; border-color: #334155; }
[data-bs-theme="dark"] .fb-text-answer { background: #0f172a; border-color: #334155; color: #94a3b8; }
[data-bs-theme="dark"] .fb-detail-header { background: linear-gradient(135deg, #1e293b, #1a2744); }
[data-bs-theme="dark"] .fb-rating-bar { background: #334155; }
[data-bs-theme="dark"] .fb-stat-mini .fb-stat-label { color: #94a3b8; }
[data-bs-theme="dark"] .fb-bool-yes { color: #4ade80; }
[data-bs-theme="dark"] .fb-bool-no  { color: #f87171; }
[data-bs-theme="dark"] .fb-card-submission { box-shadow: 0 1px 4px rgba(0,0,0,0.2); }
[data-bs-theme="dark"] .fb-card-submission:hover { box-shadow: 0 4px 16px rgba(0,0,0,0.35); }
[data-bs-theme="dark"] #submissionModal .btn-close { filter: invert(1) grayscale(100%) brightness(200%); }

/* --- Feedback v2: Misc --- */
.fb-cursor-pointer { cursor: pointer; }
.fb-cursor-pointer:hover { background-color: rgba(var(--bs-primary-rgb), 0.04); }

/* ========================================
   Credentials Module - Action Buttons
   ======================================== */

/* Кнопки действий в таблице */
.action-buttons {
    display: flex;
    gap: 0.375rem;
    justify-content: flex-end;
    align-items: center;
}

.action-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    padding: 0;
    border: 1px solid transparent;
    border-radius: 0.375rem;
    background-color: transparent;
    color: var(--bs-body-color);
    font-size: 0.875rem;
    cursor: pointer;
    transition: all 0.15s ease-in-out;
}

.action-btn:hover {
    background-color: var(--bs-light);
    border-color: var(--bs-border-color);
}

.action-btn.edit:hover {
    background-color: rgba(13, 110, 253, 0.1);
    border-color: rgba(13, 110, 253, 0.3);
    color: var(--bs-primary);
}

.action-btn.delete:hover {
    background-color: rgba(220, 53, 69, 0.1);
    border-color: rgba(220, 53, 69, 0.3);
    color: var(--bs-danger);
}

.action-btn.shares:hover {
    background-color: rgba(25, 135, 84, 0.1);
    border-color: rgba(25, 135, 84, 0.3);
    color: var(--bs-success);
}

/* Кнопки для паролей */
.password-actions {
    display: flex;
    gap: 0.25rem;
}

.password-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.75rem;
    height: 1.75rem;
    padding: 0;
    border: 1px solid transparent;
    border-radius: 0.25rem;
    background-color: transparent;
    color: var(--bs-secondary);
    font-size: 0.75rem;
    cursor: pointer;
    transition: all 0.15s ease-in-out;
}

.password-btn:hover {
    background-color: var(--bs-light);
    border-color: var(--bs-border-color);
    color: var(--bs-body-color);
}

.password-display {
    font-family: 'Courier New', monospace;
    font-size: 0.875rem;
}

/* Dark theme для кнопок */
[data-bs-theme="dark"] .action-btn:hover {
    background-color: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.2);
}

[data-bs-theme="dark"] .action-btn.edit:hover {
    background-color: rgba(13, 110, 253, 0.2);
    border-color: rgba(13, 110, 253, 0.4);
    color: #6ea8fe;
}

[data-bs-theme="dark"] .action-btn.delete:hover {
    background-color: rgba(220, 53, 69, 0.2);
    border-color: rgba(220, 53, 69, 0.4);
    color: #ea868f;
}

[data-bs-theme="dark"] .action-btn.shares:hover {
    background-color: rgba(25, 135, 84, 0.2);
    border-color: rgba(25, 135, 84, 0.4);
    color: #75b798;
}

[data-bs-theme="dark"] .password-btn:hover {
    background-color: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.2);
    color: var(--bs-light);
}

/* ========================================
   REGULATORY MODULE
   ======================================== */
.reg-doc-card {
    cursor: pointer;
    transition: box-shadow 0.15s ease-in-out, border-color 0.15s ease-in-out;
}

.reg-doc-card:hover {
    box-shadow: 0 0.25rem 0.75rem rgba(0, 0, 0, 0.1);
    border-color: var(--bs-primary);
}

.reg-doc-card .card-title {
    font-size: 0.95rem;
    line-height: 1.3;
}

[data-bs-theme="dark"] .reg-doc-card:hover {
    box-shadow: 0 0.25rem 0.75rem rgba(255, 255, 255, 0.08);
}

.pwd-show-body {
    color: #000;
}

.pwd-show-wrap,
.pwd-show-view-wrap {
    max-width: 760px;
    margin: 48px auto;
    padding: 0 14px;
}

.pwd-show-view-wrap {
    margin-top: 28px;
}

.pwd-show-wrap-sm {
    max-width: 720px;
}

.pwd-show-card {
    border-radius: 14px;
    color: #000;
}

.pwd-show-lead,
.pwd-show-muted {
    color: var(--bs-secondary-color);
}

.pwd-show-lead {
    font-size: 1.02rem;
}

.pwd-show-mono {
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;
}

.pwd-show-field {
    display: grid;
    grid-template-columns: 1fr auto auto;
    gap: 8px;
    align-items: center;
    background: var(--bs-tertiary-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 12px;
    padding: 10px;
    margin-bottom: 10px;
}

.pwd-show-field input {
    border: 0;
    outline: 0;
    background: transparent;
    padding: 8px 10px;
    color: #000;
    font-size: 1.05rem;
    min-width: 0;
}

.pwd-show-field .btn {
    white-space: nowrap;
}

.pwd-show-section {
    padding: clamp(14px, 1.6vw, 18px);
    background: var(--bs-tertiary-bg);
    border-radius: 12px;
}

.pwd-show-section + .pwd-show-section {
    margin-top: 12px;
}

.pwd-show-rules li {
    margin-bottom: 4px;
}

.pwd-show-meta {
    font-size: .9rem;
}

.pwd-show-bigcode {
    font-size: clamp(20px, 2.6vw, 24px);
    letter-spacing: .4px;
}

@media (max-width: 767.98px) {
    .pwd-show-field,
    .pwd-show-field-password {
        grid-template-columns: 1fr;
    }

    .pwd-show-field .btn {
        width: 100%;
    }
}
