/* CSS переменные темы Bootstrap */
:root {
    --bs-blue: #377dff;
    --bs-indigo: #6610f2;
    --bs-purple: #6f42c1;
    --bs-pink: #d63384;
    --bs-red: #ed4c78;
    --bs-orange: #fd7e14;
    --bs-yellow: #f5ca99;
    --bs-green: #198754;
    --bs-teal: #00c9a7;
    --bs-cyan: #09a5be;
    --bs-white: #fff;
    --bs-gray: #202325;
    --bs-gray-dark: #2a2d30;
    --bs-gray-100: #2c2f32;
    --bs-gray-200: #2f3235;
    --bs-gray-300: #4b5055;
    --bs-gray-400: #3d4145;
    --bs-gray-500: #34373a;
    --bs-gray-600: #202325;
    --bs-gray-700: #25282a;
    --bs-gray-800: #2a2d30;
    --bs-gray-900: #1e2022;
    --bs-primary: #377dff;
    --bs-secondary: #6d747b;
    --bs-success: #00c9a7;
    --bs-info: #09a5be;
    --bs-warning: #f5ca99;
    --bs-danger: #ed4c78;
    --bs-light: #2c2f32;
    --bs-dark: #fff;
    --bs-primary-rgb: 55, 125, 255;
    --bs-secondary-rgb: 108.89062, 116.15, 123.40937;
    --bs-success-rgb: 0, 201, 167;
    --bs-info-rgb: 9, 165, 190;
    --bs-warning-rgb: 245, 202, 153;
    --bs-danger-rgb: 237, 76, 120;
    --bs-light-rgb: 44.34375, 47.3, 50.25625;
    --bs-dark-rgb: 255, 255, 255;
    --bs-white-rgb: 255, 255, 255;
    --bs-black-rgb: 0, 0, 0;
    --bs-body-color-rgb: 196.88125, 200.3, 203.71875;
    --bs-body-bg-rgb: 30, 32, 34;
    --bs-font-sans-serif: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    --bs-font-monospace: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    --bs-gradient: linear-gradient(180deg, rgba(255, 255, 255, 0.15), rgba(255, 255, 255, 0));
    --bs-body-font-family: Inter, sans-serif;
    --bs-body-font-size: 0.875rem;
    --bs-body-font-weight: 400;
    --bs-body-line-height: 1.5;
    --bs-body-color: #c5c8cc;
    --bs-body-bg: #1e2022;
}

/* Общие стили для всех страниц */

body {
    background-color: #1e2022;
    font-family: var(--bs-body-font-family);
    color: var(--bs-body-color);
    font-size: var(--bs-body-font-size);
    font-weight: var(--bs-body-font-weight);
    line-height: var(--bs-body-line-height);
    overflow-x: hidden;
}

.card {
    border: none;
    border-radius: 12px;
    background-color: #25282a;
    border-color: #25282a;
}

.card-body {
    background-color: #25282a;
    border-radius: 12px;
}

/* Глобальные стили для всех form-control и form-select - одинаковые по всему сайту */
input[type="text"].form-control,
input[type="password"].form-control,
input[type="email"].form-control,
input[type="number"].form-control,
input[type="date"].form-control,
input.form-control,
textarea.form-control,
select.form-control,
.form-control,
body input[type="text"].form-control,
body input[type="password"].form-control,
body input.form-control,
body .form-control {
    background-color: var(--bs-gray-700) !important;
    border: 1px solid var(--bs-gray-600) !important;
    border-color: var(--bs-gray-600) !important;
    border-width: 1px !important;
    border-style: solid !important;
    color: var(--bs-body-color) !important;
    height: 38px !important;
    min-height: 38px !important;
    max-height: 38px !important;
    padding: 0.375rem 0.75rem !important;
    padding-block: 0.375rem !important;
    padding-inline: 0.75rem !important;
    font-size: 0.875rem !important;
    line-height: 1.5 !important;
    border-radius: 0.375rem !important;
    transition: all 0.3s ease !important;
    display: block !important;
    width: 100% !important;
    font-weight: 400 !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
    background-clip: padding-box !important;
    box-sizing: border-box !important;
    overflow: visible !important;
    overflow-clip-margin: 0 !important;
}

/* Для textarea разрешаем большую высоту, но сохраняем остальные стили */
textarea.form-control {
    height: auto !important;
    min-height: 38px !important;
}

input[type="text"].form-control:focus,
input[type="password"].form-control:focus,
input[type="email"].form-control:focus,
input[type="number"].form-control:focus,
input[type="date"].form-control:focus,
input.form-control:focus,
textarea.form-control:focus,
select.form-control:focus,
.form-control:focus,
body input[type="text"].form-control:focus,
body input[type="password"].form-control:focus,
body input.form-control:focus,
body .form-control:focus {
    background-color: var(--bs-gray-700) !important;
    border-color: var(--bs-primary) !important;
    border-width: 1px !important;
    border-style: solid !important;
    color: var(--bs-body-color) !important;
    box-shadow: 0 0 0 0.25rem rgba(var(--bs-primary-rgb), 0.25) !important;
    outline: 0 !important;
    outline-offset: 0 !important;
}

select.form-select,
.form-select,
body select.form-select,
body .form-select {
    background-color: var(--bs-gray-700) !important;
    border: 1px solid var(--bs-gray-600) !important;
    border-color: var(--bs-gray-600) !important;
    border-width: 1px !important;
    border-style: solid !important;
    color: var(--bs-body-color) !important;
    height: 38px !important;
    min-height: 38px !important;
    max-height: 38px !important;
    padding: 0.375rem 0.75rem !important;
    padding-block: 0.375rem !important;
    padding-inline: 0.75rem !important;
    font-size: 0.875rem !important;
    line-height: 1.5 !important;
    border-radius: 0.375rem !important;
    transition: all 0.3s ease !important;
    display: block !important;
    width: 100% !important;
    font-weight: 400 !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
    background-clip: padding-box !important;
    box-sizing: border-box !important;
    overflow: visible !important;
}

select.form-select:focus,
.form-select:focus,
body select.form-select:focus,
body .form-select:focus {
    background-color: var(--bs-gray-700) !important;
    border-color: var(--bs-primary) !important;
    border-width: 1px !important;
    border-style: solid !important;
    color: var(--bs-body-color) !important;
    box-shadow: 0 0 0 0.25rem rgba(var(--bs-primary-rgb), 0.25) !important;
    outline: 0 !important;
    outline-offset: 0 !important;
}

.form-label {
    color: var(--bs-body-color);
    font-weight: 500;
    margin-bottom: 8px;
}

.card-title,
h1, h2, h3, h4, h5, h6 {
    color: var(--bs-dark);
}

.btn-primary {
    border-radius: 8px;
    padding: 12px;
    font-weight: 600;
    transition: all 0.3s ease;
    background-color: var(--bs-primary);
    border-color: var(--bs-primary);
}

.btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(var(--bs-primary-rgb), 0.4);
    background-color: var(--bs-primary);
    border-color: var(--bs-primary);
}

.shadow-lg {
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.5) !important;
}

/* Дополнительные стили для будущих страниц - удалены неиспользуемые */

/* Dashboard стили */
.header-section {
    background-color: #1e2022;
    padding: 20px 0;
    min-height: 60px;
}

.nav-panel {
    background-color: #25282a;
    border-radius: 20px 20px 0 0;
    padding: 15px 0;
    margin: 0 auto;
    max-width: fit-content;
    box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.3);
    display: flex;
    justify-content: center;
    width: 100%;
    box-sizing: border-box;
}

.nav-panel .container-fluid {
    width: auto;
    padding: 0 20px;
}

.nav-panel-content {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    gap: 15px;
    flex-wrap: nowrap;
    width: auto;
}

.nav-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 20px;
    color: rgba(255, 255, 255, 0.9);
    text-decoration: none;
    border-radius: 10px;
    transition: all 0.2s ease;
    font-weight: 500;
    background: linear-gradient(135deg, rgba(42, 45, 48, 0.95) 0%, rgba(30, 33, 38, 0.95) 100%);
    border: 1px solid rgba(255, 255, 255, 0.1);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2),
                inset 0 1px 0 rgba(255, 255, 255, 0.05);
    backdrop-filter: blur(10px);
}

.nav-item-account {
    background: rgba(255, 255, 255, 0.03);
    padding: 8px 12px;
    font-size: 0.875rem;
}

.nav-item-account .nav-user-name {
    font-weight: 600;
    max-width: 150px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-size: 0.875rem;
}

.nav-item-account .nav-logout-chip {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: rgba(220, 53, 69, 0.2);
    color: var(--bs-danger);
    border-radius: 999px;
    padding: 3px 10px;
    font-size: 0.75rem;
    font-weight: 600;
    transition: all 0.3s ease;
    border: 1px solid rgba(220, 53, 69, 0.35);
}

.nav-item-account i {
    font-size: 0.95rem;
}

.nav-item-account:hover .nav-logout-chip {
    background: var(--bs-danger);
    color: var(--bs-white);
    border-color: transparent;
}

.nav-item-account:hover .nav-user-name {
    color: var(--bs-white);
}

.nav-item:hover {
    background: linear-gradient(135deg, rgba(52, 55, 58, 0.95) 0%, rgba(40, 43, 48, 0.95) 100%);
    border-color: rgba(255, 255, 255, 0.15);
    color: rgba(255, 255, 255, 1);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3),
                inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.nav-item.active {
    background: linear-gradient(135deg, rgba(var(--bs-primary-rgb), 0.2) 0%, rgba(var(--bs-primary-rgb), 0.1) 100%);
    border-color: rgba(var(--bs-primary-rgb), 0.4);
    color: var(--bs-primary);
    box-shadow: 0 2px 8px rgba(var(--bs-primary-rgb), 0.3),
                inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.nav-item i {
    font-size: 1.1rem;
}

.main-content {
    padding: 30px 20px;
    min-height: calc(100vh - 200px);
    overflow-x: hidden;
    max-width: 100%;
}

.tab-content {
    display: none;
}

.tab-content.active {
    display: block;
}

/* Таблица */
.table {
    background-color: #2c2f32;
    margin-bottom: 0;
    border-radius: 8px;
    overflow: hidden;
    width: 100%;
    table-layout: auto;
}

.table-responsive {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    max-width: 100%;
}

.table thead th {
    background-color: #2c2f32;
    border-bottom: 2px solid var(--bs-gray-700);
    color: var(--bs-body-color);
    font-weight: 600;
    padding: 15px;
}

.table tbody {
    background-color: #2c2f32;
}

.table tbody td {
    padding: 15px;
    border-bottom: 1px solid var(--bs-gray-700);
    vertical-align: middle;
    background-color: #2c2f32;
}

.table tbody tr:hover {
    background-color: var(--bs-gray-800);
}

/* Пагинация */
.pagination {
    margin-top: 20px;
}

.page-link {
    background-color: var(--bs-gray-800);
    border-color: var(--bs-gray-700);
    color: var(--bs-body-color);
    padding: 10px 15px;
}

.page-link:hover {
    background-color: var(--bs-gray-700);
    border-color: var(--bs-gray-600);
    color: var(--bs-primary);
}

.page-item.active .page-link {
    background-color: var(--bs-primary);
    border-color: var(--bs-primary);
    color: var(--bs-white);
}

.page-item.disabled .page-link {
    background-color: var(--bs-gray-900);
    border-color: var(--bs-gray-700);
    color: var(--bs-gray-600);
    cursor: not-allowed;
}

/* Форма загрузки */
.form-text {
    color: var(--bs-gray-400);
    font-size: 0.875rem;
    margin-top: 5px;
}

/* Страница загрузки */
.upload-page-container {
    padding: 2rem 0;
    min-height: calc(100vh - 200px);
}

@media (min-width: 1200px) {
    .upload-page-container .col-xl-7 {
        flex: 0 0 auto;
        width: 54%;
    }
}

.upload-card {
    background: linear-gradient(135deg, rgba(30, 33, 36, 0.95) 0%, rgba(25, 28, 32, 0.95) 100%);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 16px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.4), 0 4px 16px rgba(0, 0, 0, 0.3);
    overflow: hidden;
    position: relative;
}

.upload-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--bs-primary) 0%, rgba(var(--bs-primary-rgb), 0.5) 50%, var(--bs-primary) 100%);
    background-size: 200% 100%;
    animation: shimmer 3s infinite;
}

@keyframes shimmer {
    0% {
        background-position: -200% 0;
    }
    100% {
        background-position: 200% 0;
    }
}

.upload-card-header {
    background: linear-gradient(135deg, rgba(13, 110, 253, 0.15) 0%, rgba(13, 110, 253, 0.05) 100%);
    padding: 1.5rem 2rem;
    text-align: center;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    position: relative;
    overflow: hidden;
}

.upload-card-header::before {
    content: '';
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background: radial-gradient(circle, rgba(13, 110, 253, 0.1) 0%, transparent 70%);
    animation: pulse 4s infinite;
}

@keyframes pulse {
    0%, 100% {
        opacity: 0.5;
        transform: scale(1);
    }
    50% {
        opacity: 0.8;
        transform: scale(1.1);
    }
}

.upload-header-icon {
    width: 80px;
    height: 80px;
    margin: 0 auto 1.5rem;
    background: linear-gradient(135deg, rgba(13, 110, 253, 0.2) 0%, rgba(13, 110, 253, 0.1) 100%);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px solid rgba(13, 110, 253, 0.3);
    box-shadow: 0 4px 16px rgba(13, 110, 253, 0.2);
    position: relative;
    z-index: 1;
}

.upload-header-icon i {
    font-size: 2.5rem;
    color: var(--bs-primary);
    animation: float 3s ease-in-out infinite;
}

@keyframes float {
    0%, 100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-10px);
    }
}

.upload-title {
    font-size: 1.5rem;
    font-weight: 700;
    color: #ffffff;
    margin-bottom: 0.5rem;
    position: relative;
    z-index: 1;
}

.upload-subtitle {
    color: rgba(255, 255, 255, 0.7);
    font-size: 0.9rem;
    margin: 0;
    position: relative;
    z-index: 1;
}

.upload-card-body {
    padding: 2rem;
}

.upload-form-group {
    margin-bottom: 1.5rem;
}

.upload-label {
    display: flex;
    align-items: center;
    font-weight: 600;
    color: #ffffff;
    margin-bottom: 0.75rem;
    font-size: 1rem;
}

.upload-label i {
    color: var(--bs-primary);
    font-size: 1.1rem;
}

.upload-input {
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    color: #ffffff;
    padding: 0.75rem 1rem;
    transition: all 0.3s ease;
}

.upload-input:focus {
    background: rgba(255, 255, 255, 0.08);
    border-color: var(--bs-primary);
    box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.25);
    color: #ffffff;
}

.upload-input::placeholder {
    color: rgba(255, 255, 255, 0.4);
}

.upload-hint {
    display: flex;
    align-items: center;
    color: rgba(255, 255, 255, 0.6);
    font-size: 0.875rem;
    margin-top: 0.5rem;
}

.upload-hint i {
    color: rgba(255, 255, 255, 0.5);
}

/* Drag and Drop область */
.file-upload-area {
    border: 2px dashed rgba(13, 110, 253, 0.4);
    border-radius: 16px;
    padding: 3rem 2rem;
    text-align: center;
    background: linear-gradient(135deg, rgba(13, 110, 253, 0.05) 0%, rgba(13, 110, 253, 0.02) 100%);
    cursor: pointer;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    min-height: 240px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
}

.file-upload-area::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(13, 110, 253, 0.1), transparent);
    transition: left 0.5s;
}

.file-upload-area:hover::before {
    left: 100%;
}

.file-upload-area:hover {
    border-color: var(--bs-primary);
    background: linear-gradient(135deg, rgba(13, 110, 253, 0.1) 0%, rgba(13, 110, 253, 0.05) 100%);
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(13, 110, 253, 0.2);
}

.file-upload-area.drag-over {
    border-color: var(--bs-primary);
    background: linear-gradient(135deg, rgba(13, 110, 253, 0.15) 0%, rgba(13, 110, 253, 0.08) 100%);
    transform: scale(1.02);
    box-shadow: 0 12px 32px rgba(13, 110, 253, 0.3);
}

.file-upload-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    position: relative;
    z-index: 1;
}

.file-upload-icon-wrapper {
    width: 100px;
    height: 100px;
    background: linear-gradient(135deg, rgba(13, 110, 253, 0.2) 0%, rgba(13, 110, 253, 0.1) 100%);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px solid rgba(13, 110, 253, 0.3);
    margin-bottom: 0.5rem;
    transition: all 0.3s ease;
}

.file-upload-area:hover .file-upload-icon-wrapper {
    transform: scale(1.1);
    box-shadow: 0 8px 24px rgba(13, 110, 253, 0.3);
}

.file-upload-icon {
    font-size: 3.5rem;
    color: var(--bs-primary);
    animation: bounce 2s infinite;
}

@keyframes bounce {
    0%, 100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-8px);
    }
}

.file-upload-text {
    color: #ffffff;
    font-size: 1.2rem;
    font-weight: 500;
    margin: 0;
}

.file-upload-link {
    color: var(--bs-primary);
    text-decoration: none;
    font-weight: 600;
    border-bottom: 2px solid transparent;
    transition: all 0.3s ease;
    display: inline-block;
}

.file-upload-link:hover {
    color: var(--bs-primary);
    border-bottom-color: var(--bs-primary);
    transform: translateY(-1px);
}

.file-upload-hint {
    color: rgba(255, 255, 255, 0.6);
    font-size: 0.9rem;
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
}

.file-upload-hint i {
    color: rgba(255, 255, 255, 0.5);
}

.file-selected-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    position: relative;
    z-index: 1;
}

.file-selected-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    padding: 1.5rem;
    background: rgba(25, 135, 84, 0.1);
    border-radius: 12px;
    border: 1px solid rgba(25, 135, 84, 0.3);
    width: 100%;
}

.file-selected-icon {
    font-size: 4rem;
    color: var(--bs-success);
    margin-bottom: 0.5rem;
    animation: scaleIn 0.3s ease;
}

@keyframes scaleIn {
    0% {
        transform: scale(0);
    }
    100% {
        transform: scale(1);
    }
}

.file-selected-name {
    color: #ffffff;
    font-size: 1.1rem;
    font-weight: 600;
    margin: 0;
    word-break: break-all;
    text-align: center;
}

.upload-alert {
    background: linear-gradient(135deg, rgba(255, 193, 7, 0.15) 0%, rgba(255, 193, 7, 0.05) 100%);
    border: 1px solid rgba(255, 193, 7, 0.3);
    border-radius: 12px;
    color: #ffffff;
    padding: 1rem 1.5rem;
}

.upload-progress-container {
    margin-top: 1.5rem;
}

.upload-progress-wrapper {
    background: rgba(255, 255, 255, 0.05);
    border-radius: 12px;
    padding: 1.5rem;
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.upload-progress {
    height: 12px;
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.1);
    overflow: hidden;
    box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.2);
}

.upload-progress .progress-bar {
    background: linear-gradient(90deg, var(--bs-primary) 0%, rgba(var(--bs-primary-rgb), 0.8) 100%);
    box-shadow: 0 2px 8px rgba(13, 110, 253, 0.4);
    position: relative;
}

.upload-progress .progress-text {
    color: #ffffff;
    font-weight: 600;
    font-size: 0.75rem;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
}

.upload-progress-status {
    color: rgba(255, 255, 255, 0.8);
    font-size: 0.9rem;
    margin-top: 0.75rem;
    margin-bottom: 0;
    text-align: center;
}

.upload-submit-wrapper {
    margin-top: 1.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.upload-submit-btn {
    background: linear-gradient(135deg, var(--bs-primary) 0%, rgba(var(--bs-primary-rgb), 0.9) 100%);
    border: none;
    border-radius: 12px;
    padding: 1rem 2rem;
    font-size: 1.1rem;
    font-weight: 600;
    box-shadow: 0 4px 16px rgba(13, 110, 253, 0.3);
    transition: all 0.3s ease;
    width: 100%;
    position: relative;
    overflow: hidden;
}

.upload-submit-btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
    transition: left 0.5s;
}

.upload-submit-btn:hover::before {
    left: 100%;
}

.upload-submit-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(13, 110, 253, 0.4);
    background: linear-gradient(135deg, rgba(var(--bs-primary-rgb), 1) 0%, rgba(var(--bs-primary-rgb), 0.95) 100%);
}

.upload-submit-btn:active {
    transform: translateY(0);
    box-shadow: 0 4px 12px rgba(13, 110, 253, 0.3);
}

/* Уведомления */
/* Стили для страницы уведомлений */
#notificationsList {
    position: relative;
}

.notification-badge {
    position: absolute;
    top: -5px;
    right: -5px;
    font-size: 0.7rem;
    padding: 0;
    border-radius: 50%;
    min-width: 20px;
    min-height: 20px;
    width: 20px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    line-height: 1;
    z-index: 10;
}

.nav-item {
    position: relative;
}

/* Стили для карточек уведомлений */
#notificationsList .card {
    background: linear-gradient(135deg, rgba(30, 33, 36, 0.95) 0%, rgba(25, 28, 32, 0.95) 100%);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 12px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.3), 0 2px 4px rgba(0, 0, 0, 0.2);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    overflow: hidden;
    position: relative;
    margin-bottom: 16px;
}

#notificationsList .card::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 4px;
    background: linear-gradient(180deg, rgba(var(--bs-primary-rgb), 0.3) 0%, rgba(var(--bs-primary-rgb), 0.1) 100%);
    opacity: 0;
    transition: opacity 0.3s ease;
}

#notificationsList .card.border-primary {
    border-left: 4px solid var(--bs-primary);
    background: linear-gradient(135deg, rgba(13, 110, 253, 0.1) 0%, rgba(30, 33, 36, 0.95) 100%);
    box-shadow: 0 4px 12px rgba(13, 110, 253, 0.2), 0 2px 4px rgba(0, 0, 0, 0.3);
}

#notificationsList .card.border-primary::before {
    opacity: 1;
    background: linear-gradient(180deg, var(--bs-primary) 0%, rgba(var(--bs-primary-rgb), 0.5) 100%);
}

#notificationsList .card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.4), 0 4px 8px rgba(0, 0, 0, 0.3);
    border-color: rgba(255, 255, 255, 0.2);
    cursor: pointer;
}

#notificationsList .card.border-primary:hover {
    box-shadow: 0 8px 20px rgba(13, 110, 253, 0.3), 0 4px 8px rgba(0, 0, 0, 0.3);
}

#notificationsList .card-body {
    padding: 20px;
}

#notificationsList .card-title {
    font-size: 1.1rem;
    font-weight: 600;
    color: #ffffff;
    margin-bottom: 12px;
    display: flex;
    align-items: center;
    gap: 8px;
}

#notificationsList .card-text {
    color: rgba(255, 255, 255, 0.85);
    font-size: 0.95rem;
    line-height: 1.6;
    margin-bottom: 12px;
    word-wrap: break-word;
}

#notificationsList .card .text-muted {
    color: rgba(255, 255, 255, 0.6) !important;
    font-size: 0.85rem;
}

#notificationsList .card .badge {
    font-size: 0.75rem;
    padding: 6px 12px;
    border-radius: 6px;
    font-weight: 500;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

#notificationsList .card .badge.bg-primary {
    background: linear-gradient(135deg, rgba(13, 110, 253, 0.9) 0%, rgba(10, 88, 202, 0.9) 100%) !important;
    animation: pulse 2s infinite;
}

@keyframes pulse {
    0%, 100% {
        opacity: 1;
    }
    50% {
        opacity: 0.8;
    }
}

#notificationsList .card .badge.bg-warning {
    background: linear-gradient(135deg, rgba(255, 193, 7, 0.9) 0%, rgba(255, 152, 0, 0.9) 100%) !important;
    color: #000 !important;
}

#notificationsList .card .btn-outline-primary {
    border-color: rgba(var(--bs-primary-rgb), 0.5);
    color: var(--bs-primary);
    transition: all 0.3s ease;
}

#notificationsList .card .btn-outline-primary:hover {
    background: var(--bs-primary);
    border-color: var(--bs-primary);
    transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(var(--bs-primary-rgb), 0.3);
}

.notification-item {
    background-color: var(--bs-gray-800);
    border: 1px solid var(--bs-gray-700);
    border-radius: 8px;
    padding: 15px;
    margin-bottom: 15px;
    transition: all 0.3s ease;
}

.notification-item:hover {
    background-color: var(--bs-gray-700);
    border-color: var(--bs-gray-600);
}

.notification-item.unread {
    background-color: var(--bs-gray-700);
    border-left: 3px solid var(--bs-primary);
}

.notification-item.read {
    opacity: 0.7;
}

.notification-header {
    display: flex;
    justify-content: space-between;
    align-items: start;
    margin-bottom: 10px;
}

.notification-title {
    color: var(--bs-body-color);
    font-weight: 600;
    font-size: 1rem;
    margin: 0;
}

.notification-item.unread .notification-title {
    color: var(--bs-white);
}

.notification-date {
    color: var(--bs-gray-400);
    font-size: 0.875rem;
    white-space: nowrap;
    margin-left: 15px;
}

.notification-text {
    color: var(--bs-body-color);
    font-size: 0.9rem;
    margin-bottom: 10px;
    line-height: 1.5;
}

.notification-actions {
    display: flex;
    gap: 10px;
    margin-top: 10px;
}

.notification-empty {
    text-align: center;
    padding: 40px 20px;
    color: var(--bs-gray-400);
}

.notification-empty i {
    font-size: 3rem;
    margin-bottom: 15px;
    opacity: 0.5;
}

/* Модальное окно комментариев (на весь экран) */
.comments-modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: #1e2022;
    z-index: 2000;
    display: none;
    flex-direction: column;
    overflow: hidden;
}

.comments-modal.active {
    display: flex;
}

.comments-modal-header {
    background-color: #25282a;
    border-bottom: 1px solid var(--bs-gray-700);
    padding: 15px 20px;
    display: flex;
    align-items: center;
    gap: 20px;
    flex-shrink: 0;
}

.btn-back {
    background-color: transparent;
    border: 1px solid var(--bs-gray-600);
    color: var(--bs-body-color);
    padding: 8px 16px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    gap: 8px;
    transition: all 0.3s ease;
}

.btn-back:hover {
    background-color: var(--bs-gray-700);
    border-color: var(--bs-primary);
    color: var(--bs-primary);
}

.comments-modal-title {
    color: var(--bs-white);
    margin: 0;
    font-size: 1.5rem;
}

.comments-modal-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    padding: 20px;
    padding-bottom: 0;
    position: relative;
}

.comments-list {
    flex: 1;
    overflow-y: auto;
    padding-right: 10px;
    padding-bottom: 180px;
    min-height: 0;
}

.comment-item {
    background: linear-gradient(135deg, rgba(37, 40, 42, 0.95) 0%, rgba(30, 33, 36, 0.95) 100%);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 12px;
    padding: 16px;
    margin-bottom: 12px;
    transition: all 0.3s ease;
    position: relative;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

.comment-item:hover {
    background: linear-gradient(135deg, rgba(42, 45, 48, 0.98) 0%, rgba(35, 38, 42, 0.98) 100%);
    border-color: rgba(255, 255, 255, 0.12);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
    transform: translateY(-1px);
}

.comment-item.reply {
    margin-left: 32px;
    padding-left: 20px;
    background: linear-gradient(135deg, rgba(30, 33, 36, 0.6) 0%, rgba(25, 28, 32, 0.6) 100%);
    border-left: 2px solid rgba(255, 255, 255, 0.1);
    border-radius: 0 12px 12px 0;
}

.comment-item.reply::before {
    content: '';
    position: absolute;
    left: -2px;
    top: 0;
    bottom: 0;
    width: 2px;
    background: linear-gradient(180deg, var(--bs-primary) 0%, rgba(var(--bs-primary-rgb), 0.3) 100%);
    border-radius: 0;
}

.comment-item.comment-hidden {
    border-left: 3px solid rgba(108, 117, 125, 0.6);
    background: linear-gradient(135deg, rgba(108, 117, 125, 0.15) 0%, rgba(108, 117, 125, 0.08) 100%);
}

.binding-list {
    max-height: 360px;
    overflow-y: auto;
    padding-right: 6px;
}

.binding-group {
    margin-bottom: 18px;
}

.binding-group-title {
    font-weight: 600;
    margin-bottom: 8px;
    color: var(--bs-gray-50);
    display: flex;
    align-items: center;
    gap: 8px;
}

.binding-item {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border: 1px solid #202325;
    background-color: var(--bs-gray-700);
    color: var(--bs-body-color);
    border-radius: 10px;
    padding: 10px 14px;
    margin-bottom: 8px;
    transition: all 0.2s ease;
    cursor: pointer;
}

.binding-item:hover {
    background-color: var(--bs-gray-700);
    border-color: var(--bs-primary);
}

.binding-item.active {
    border-color: var(--bs-primary);
    background-color: rgba(13, 110, 253, 0.18);
    color: var(--bs-primary);
}

.binding-item .binding-item-name {
    font-weight: 500;
}

.binding-item .binding-item-meta {
    font-size: 0.85rem;
    color: var(--bs-gray-400);
}

.binding-item.disabled {
    cursor: not-allowed;
    opacity: 0.65;
}

.binding-item.disabled:hover {
    background-color: var(--bs-gray-800);
    border-color: var(--bs-gray-700);
    color: var(--bs-gray-400);
}

.binding-empty {
    text-align: center;
    color: var(--bs-gray-500);
    padding: 32px 0;
    font-size: 0.95rem;
}

.binding-summary {
    background: linear-gradient(135deg, rgb(37 40 42), rgba(13, 110, 253, 0.02));
    border: 1px solid rgb(32 35 37);
    border-radius: 14px;
    padding: 18px 20px;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.binding-summary:hover {
    border-color: rgba(13, 110, 253, 0.35);
    box-shadow: 0 6px 18px rgba(13, 110, 253, 0.08);
}

.binding-summary-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 14px;
    gap: 12px;
}

.binding-summary-title {
    font-weight: 600;
    color: var(--bs-white);
    font-size: 1rem;
}

.binding-summary-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background-color: rgba(13, 110, 253, 0.15);
    border: 1px solid rgba(13, 110, 253, 0.3);
    border-radius: 999px;
    padding: 6px 16px;
    font-size: 0.85rem;
    color: var(--bs-primary);
    white-space: nowrap;
}

.binding-summary-pill-empty {
    background-color: rgba(108, 117, 125, 0.18);
    border-color: rgba(108, 117, 125, 0.35);
    color: var(--bs-gray-300);
}

.binding-summary-body {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 12px;
}

.binding-summary-body .btn {
    flex-shrink: 0;
}

.binding-summary-status {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 0.875rem;
    color: var(--bs-gray-400);
}

.binding-summary-status i {
    font-size: 0.5rem;
    color: var(--bs-gray-500);
}

.binding-summary-status.active i {
    color: var(--bs-success);
}

.binding-summary-status.active {
    color: var(--bs-success);
}

.binding-summary-value {
    font-size: 0.875rem;
    color: var(--bs-gray-200);
    font-weight: 500;
    padding: 4px 10px;
    background-color: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 6px;
    min-width: 150px;
    max-width: 250px;
    text-align: right;
    border: none;
    outline: none;
    cursor: default;
}

.binding-summary-value::placeholder {
    color: var(--bs-gray-500);
    font-weight: 400;
}

.comment-highlight {
    animation: commentHighlight 1.6s ease;
}

@keyframes commentHighlight {
    0% {
        box-shadow: 0 0 0 rgba(13, 110, 253, 0.4);
    }
    50% {
        box-shadow: 0 0 0 8px rgba(13, 110, 253, 0.15);
    }
    100% {
        box-shadow: 0 0 0 rgba(13, 110, 253, 0);
    }
}

.comment-badge {
    display: inline-flex;
    align-items: center;
    padding: 2px 6px;
    border-radius: 4px;
    font-size: 0.65rem;
    font-weight: 500;
    margin-bottom: 0;
    margin-right: 6px;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.15);
    opacity: 0.85;
}

/* Агент - зеленый */
.comment-badge.comment-role-agent,
.comment-badge.agent {
    background: linear-gradient(135deg, rgba(25, 135, 84, 0.9) 0%, rgba(20, 108, 67, 0.9) 100%);
    color: #ffffff;
    border: 1px solid rgba(25, 135, 84, 0.5);
}

/* Тимлидер - синий */
.comment-badge.comment-role-team-leader,
.comment-badge.team-leader {
    background: linear-gradient(135deg, rgba(13, 110, 253, 0.9) 0%, rgba(10, 88, 202, 0.9) 100%);
    color: #ffffff;
    border: 1px solid rgba(13, 110, 253, 0.5);
}

/* Хед-менеджер - оранжевый */
.comment-badge.comment-role-head-manager,
.comment-badge.head-manager {
    background: linear-gradient(135deg, rgba(255, 152, 0, 0.9) 0%, rgba(255, 111, 0, 0.9) 100%);
    color: #ffffff;
    border: 1px solid rgba(255, 152, 0, 0.5);
}

/* Администратор - красный */
.comment-badge.comment-role-admin,
.comment-badge.comment-role-administrator,
.comment-badge.administrator {
    background: linear-gradient(135deg, rgba(220, 53, 69, 0.9) 0%, rgba(176, 42, 55, 0.9) 100%);
    color: #ffffff;
    border: 1px solid rgba(220, 53, 69, 0.5);
}

/* Система */
.comment-badge.comment-role-system,
.comment-badge.system {
    background: linear-gradient(135deg, rgba(108, 117, 125, 0.9) 0%, rgba(86, 94, 100, 0.9) 100%);
    color: #ffffff;
    border: 1px solid rgba(108, 117, 125, 0.5);
}

.comment-author {
    font-weight: 600;
    margin-bottom: 0;
    font-size: 0.95rem;
    display: inline-block;
    color: rgba(255, 255, 255, 0.95);
}

/* Агент - зеленый */
.comment-author.comment-role-agent,
.comment-author.agent {
    color: rgba(25, 135, 84, 0.9);
}

/* Тимлидер - синий */
.comment-author.comment-role-team-leader,
.comment-author.team-leader {
    color: rgba(13, 110, 253, 0.9);
}

/* Хед-менеджер - оранжевый */
.comment-author.comment-role-head-manager,
.comment-author.head-manager {
    color: rgba(255, 152, 0, 0.9);
}

/* Администратор - красный */
.comment-author.comment-role-admin,
.comment-author.comment-role-administrator,
.comment-author.administrator {
    color: rgba(220, 53, 69, 0.9);
}

/* Система */
.comment-author.comment-role-system,
.comment-author.system {
    color: rgba(108, 117, 125, 0.9);
}

.comment-text {
    color: rgba(255, 255, 255, 0.9);
    margin-bottom: 12px;
    line-height: 1.6;
    white-space: pre-wrap;
    font-size: 0.95rem;
    padding: 8px 0;
}

.comment-actions {
    display: flex;
    gap: 8px;
    margin-top: 8px;
    padding-top: 8px;
    border-top: 1px solid rgba(255, 255, 255, 0.05);
}

.comment-actions .btn {
    padding: 6px 12px;
    font-size: 0.85rem;
    border-radius: 6px;
    transition: all 0.2s ease;
}

.comment-actions .btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
}

.comment-date {
    color: rgba(255, 255, 255, 0.5);
    font-size: 0.8rem;
    margin-top: 0;
    display: inline-block;
    margin-left: auto;
    font-weight: 400;
}

.comment-header {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 12px;
    padding-bottom: 10px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.comment-replies {
    margin-top: 4px;
    margin-left: 0;
}

.comments-form-container {
    position: fixed;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    background-color: #1e2022;
    border-top: 1px solid var(--bs-gray-700);
    border-radius: 20px 20px 0 0;
    padding: 15px 20px;
    z-index: 10;
    max-width: 800px;
    width: calc(100% - 2rem);
    max-width: min(800px, calc(100vw - 2rem));
    box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.5);
    box-sizing: border-box;
}

.comments-form-container .card {
    margin-bottom: 0;
}

.comments-form-container .card-body {
    padding: 15px;
}

.comments-form-container .card-title {
    font-size: 1rem;
    margin-bottom: 10px;
}

.comments-form-container textarea {
    font-size: 0.875rem !important;
    padding: 0.375rem 0.75rem !important;
    min-height: 60px !important;
    height: auto !important;
}

.comments-form-container .btn {
    padding: 8px 16px;
    font-size: 0.9rem;
}


/* Кастомный скроллбар для списка комментариев */
.comments-list::-webkit-scrollbar {
    width: 8px;
}

.comments-list::-webkit-scrollbar-track {
    background: var(--bs-gray-800);
    border-radius: 4px;
}

.comments-list::-webkit-scrollbar-thumb {
    background: var(--bs-gray-600);
    border-radius: 4px;
}

.comments-list::-webkit-scrollbar-thumb:hover {
    background: var(--bs-gray-500);
}

/* Фильтры */
.filters-container {
    background: linear-gradient(135deg, rgba(42, 45, 48, 0.95) 0%, rgba(30, 33, 38, 0.95) 100%);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 16px;
    padding: 20px 24px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3),
                0 1px 3px rgba(0, 0, 0, 0.2),
                inset 0 1px 0 rgba(255, 255, 255, 0.05);
    backdrop-filter: blur(10px);
    position: relative;
    overflow: hidden;
    transition: all 0.3s ease;
}

.filters-main-row {
    position: relative;
    z-index: 1;
}

#toggleFiltersBtn {
    transition: all 0.2s ease;
    font-weight: 500;
}

#toggleFiltersBtn:hover {
    transform: translateY(-1px);
    box-shadow: 0 2px 8px rgba(var(--bs-primary-rgb), 0.3);
}

#toggleFiltersBtn.active {
    background: linear-gradient(135deg, var(--bs-primary) 0%, rgba(var(--bs-primary-rgb), 0.9) 100%);
    border-color: var(--bs-primary);
    color: white;
    box-shadow: 0 2px 8px rgba(var(--bs-primary-rgb), 0.3);
}

.filters-panel {
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    padding-top: 20px;
    margin-top: 20px;
    animation: slideDown 0.3s ease;
}

.filters-panel.d-none {
    display: none !important;
}

@keyframes slideDown {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.filters-container::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg, 
        transparent 0%, 
        var(--bs-primary) 50%, 
        transparent 100%);
    opacity: 0.6;
}

.filters-container .form-label {
    color: rgba(255, 255, 255, 0.9);
    font-weight: 600;
    margin-bottom: 10px;
    font-size: 0.875rem;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    display: flex;
    align-items: center;
    gap: 6px;
}

.filters-container .form-label::before {
    content: '';
    display: inline-block;
    width: 3px;
    height: 14px;
    background: linear-gradient(180deg, var(--bs-primary) 0%, rgba(var(--bs-primary-rgb), 0.6) 100%);
    border-radius: 2px;
}

.filters-container .form-control,
.filters-container .form-select {
    background-color: rgba(30, 33, 38, 0.8);
    border: 1px solid rgba(255, 255, 255, 0.1);
    color: rgba(255, 255, 255, 0.95);
    transition: all 0.2s ease;
}

.filters-container .form-control:focus,
.filters-container .form-select:focus {
    background-color: rgba(30, 33, 38, 0.95);
    border-color: var(--bs-primary);
    box-shadow: 0 0 0 3px rgba(var(--bs-primary-rgb), 0.15);
    color: rgba(255, 255, 255, 1);
}

.filters-container .form-control::placeholder {
    color: rgba(255, 255, 255, 0.5);
}

.filters-container .btn-white {
    background: linear-gradient(135deg, rgba(30, 33, 38, 0.9) 0%, rgba(42, 45, 48, 0.9) 100%);
    border: 1px solid rgba(255, 255, 255, 0.12);
    color: rgba(255, 255, 255, 0.9);
    transition: all 0.2s ease;
}

.filters-container .btn-white:hover {
    background: linear-gradient(135deg, rgba(42, 45, 48, 0.95) 0%, rgba(50, 53, 58, 0.95) 100%);
    border-color: rgba(255, 255, 255, 0.2);
    color: rgba(255, 255, 255, 1);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

/* Стили для фильтров и форм теперь наследуются от глобальных .form-control и .form-select */

#resetFiltersBtn {
    margin-top: 10px;
}

/* Tom Select стили - применяются везде */
.ts-wrapper {
    background-color: var(--bs-gray-700) !important;
    border: 1px solid var(--bs-gray-600) !important;
    border-radius: 0.375rem !important;
    min-height: 38px !important;
    height: 38px !important;
}

.ts-control {
    background-color: var(--bs-gray-700) !important;
    border: none !important;
    color: var(--bs-body-color) !important;
    min-height: 38px !important;
    height: 38px !important;
    padding: 0.375rem 0.75rem !important;
    font-size: 0.875rem !important;
    line-height: 1.5 !important;
}

.ts-control input {
    color: var(--bs-body-color) !important;
    font-size: 0.875rem !important;
    line-height: 1.5 !important;
    height: auto !important;
    padding: 0 !important;
}

.ts-control .items-placeholder {
    font-size: 0.875rem !important;
    line-height: 1.5 !important;
}

.ts-control .item {
    font-size: 0.875rem !important;
    line-height: 1.5 !important;
}

.ts-control .ts-input {
    font-size: 0.875rem !important;
    line-height: 1.5 !important;
}

/* Input group стили - чтобы инпут внутри input-group тоже использовал правильные стили */
.input-group .form-control {
    height: 38px !important;
    min-height: 38px !important;
    padding: 0.375rem 0.75rem !important;
    font-size: 0.875rem !important;
    line-height: 1.5 !important;
}

.ts-dropdown {
    background-color: var(--bs-gray-800);
    border: 1px solid var(--bs-gray-600);
}

.ts-dropdown .option {
    color: var(--bs-body-color);
}

.ts-dropdown .option.active {
    background-color: var(--bs-primary);
    color: var(--bs-white);
}

.ts-dropdown .option:hover {
    background-color: var(--bs-gray-700);
}

.ts-dropdown .dropdown-input {
    background-color: var(--bs-gray-700);
    color: var(--bs-body-color);
    border: 1px solid var(--bs-gray-600);
}

/* Кнопка btn-white для фильтров */
.btn-white {
    background-color: var(--bs-gray-700);
    border: 1px solid var(--bs-gray-600);
    color: var(--bs-body-color);
}

.btn-white:hover {
    background-color: var(--bs-gray-600);
    border-color: var(--bs-gray-500);
    color: var(--bs-body-color);
}

.btn-white:focus {
    background-color: var(--bs-gray-700);
    border-color: var(--bs-primary);
    color: var(--bs-body-color);
    box-shadow: 0 0 0 0.25rem rgba(var(--bs-primary-rgb), 0.25);
}

/* Стили для кнопок фильтров */
.filters-container .btn-primary {
    background: linear-gradient(135deg, var(--bs-primary) 0%, rgba(var(--bs-primary-rgb), 0.9) 100%);
    border: none;
    box-shadow: 0 2px 8px rgba(var(--bs-primary-rgb), 0.3);
    transition: all 0.2s ease;
    font-weight: 500;
}

.filters-container .btn-primary:hover {
    background: linear-gradient(135deg, rgba(var(--bs-primary-rgb), 0.95) 0%, var(--bs-primary) 100%);
    box-shadow: 0 4px 12px rgba(var(--bs-primary-rgb), 0.4);
    transform: translateY(-1px);
}

.filters-container .btn-primary:active {
    transform: translateY(0);
    box-shadow: 0 2px 6px rgba(var(--bs-primary-rgb), 0.3);
}

.filters-container .btn-outline-secondary {
    border: 1px solid var(--bs-gray-600);
    color: var(--bs-body-color);
    background-color: transparent;
    transition: all 0.2s ease;
    font-weight: 500;
}

.filters-container .btn-outline-secondary:hover {
    background-color: var(--bs-gray-700);
    border-color: var(--bs-gray-500);
    color: var(--bs-body-color);
    transform: translateY(-1px);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

.filters-container .btn-outline-secondary:active {
    transform: translateY(0);
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.15);
}

/* daterangepicker стили */
#js-daterangepicker-predefined {
    background-color: var(--bs-gray-700);
    border: 1px solid var(--bs-gray-600);
    color: var(--bs-body-color);
    height: 38px;
    padding: 0.375rem 0.75rem;
    font-size: 0.875rem;
    display: flex;
    align-items: center;
    justify-content: flex-start;
}

#js-daterangepicker-predefined:hover {
    background-color: var(--bs-gray-600);
    border-color: var(--bs-gray-500);
    color: var(--bs-body-color);
}

#js-daterangepicker-predefined:focus {
    background-color: var(--bs-gray-700);
    border-color: var(--bs-primary);
    color: var(--bs-body-color);
    box-shadow: 0 0 0 0.25rem rgba(var(--bs-primary-rgb), 0.25);
}

#js-daterangepicker-predefined i {
    margin-right: 0;
}

#js-daterangepicker-predefined .js-daterangepicker-predefined-preview {
    margin-left: 0.5rem;
}

/* daterangepicker календарь */
.daterangepicker {
    border: none;
    font-family: Inter, sans-serif;
    z-index: 98;
    background-color: #2a2d30;
    box-shadow: 0 .6125rem 2.5rem .6125rem rgba(30,32,34,.35);
    margin-top: 0;
    border-radius: .75rem;
    font-size: 0.875rem;
}

.daterangepicker.opensright::after,
.daterangepicker.opensright::before {
    left: 1rem;
}

.daterangepicker.opensright {
    left: auto !important;
    right: 1rem !important;
    max-width: calc(100vw - 2rem);
}

.daterangepicker::after,
.daterangepicker::before {
    top: 0;
    border-bottom-color: #2a2d30;
    border-bottom-width: 0;
}

.daterangepicker.drop-up::before {
    border-top-color: #2a2d30;
}

.daterangepicker .drp-calendar {
    max-width: 14rem;
    min-width: 14rem;
    width: 14rem;
}

.daterangepicker .drp-calendar.left {
    padding: 0.75rem 0.75rem;
}

.daterangepicker .drp-calendar.right {
    padding: 0.75rem 0.5rem 0.75rem 0.75rem;
    overflow: visible;
    box-sizing: border-box;
}

.daterangepicker th.next,
.daterangepicker th.prev {
    min-width: auto;
    width: 1.875rem;
    height: 1.875rem;
    color: rgba(255,255,255,.7);
    font-size: .75rem;
    border-radius: 50%;
}

.daterangepicker th.next:hover,
.daterangepicker th.prev:hover {
    background-color: rgba(255,255,255,.1);
}

.daterangepicker th.next:hover .daterangepicker-custom-arrow,
.daterangepicker th.prev:hover .daterangepicker-custom-arrow {
    color: rgba(255,255,255,.7);
}

.daterangepicker .calendar-table {
    background-color: #2a2d30;
    border-width: 0;
    width: 100%;
    box-sizing: border-box;
}

.daterangepicker .calendar-table table {
    border-collapse: separate;
    border-spacing: 0 .25rem;
    width: 100%;
    table-layout: fixed;
}

.daterangepicker .calendar-table th:not(.month) {
    color: #4b5055;
    font-weight: 600;
    text-transform: uppercase;
    font-size: .75rem;
    padding: 0.25rem 0;
}

.daterangepicker .calendar-table th.month {
    font-size: .8125rem;
    font-weight: 600;
}

.daterangepicker .calendar-table td {
    min-width: 1.875rem;
    width: 1.875rem;
    height: 1.875rem;
    font-size: .8125rem;
    line-height: 1.875rem;
}

.daterangepicker .calendar-table .next span,
.daterangepicker .calendar-table .prev span {
    border-color: #c5c8cc;
}

/* Стили для страницы статистики */
.statistics-container {
    padding: 0;
}

.statistics-container .card {
    background: linear-gradient(135deg, rgba(42, 45, 48, 0.95) 0%, rgba(30, 33, 38, 0.95) 100%);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 16px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3),
                0 1px 3px rgba(0, 0, 0, 0.2),
                inset 0 1px 0 rgba(255, 255, 255, 0.05);
    overflow: hidden;
}


/* Таблица событий */
#eventsTable {
    margin-bottom: 0;
}

#eventsTable thead th {
    background: linear-gradient(135deg, rgba(42, 45, 48, 0.95) 0%, rgba(30, 33, 38, 0.95) 100%);
    border-bottom: 2px solid rgba(55, 125, 255, 0.3);
    color: rgba(255, 255, 255, 0.9);
    font-weight: 600;
    font-size: 0.875rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 12px 16px;
    position: sticky;
    top: 0;
    z-index: 10;
}

#eventsTable tbody tr {
    transition: all 0.2s ease;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

#eventsTable tbody tr:hover {
    background: linear-gradient(135deg, rgba(55, 125, 255, 0.1) 0%, rgba(55, 125, 255, 0.05) 100%);
    transform: translateX(2px);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

#eventsTable tbody td {
    padding: 14px 16px;
    vertical-align: middle;
    color: rgba(255, 255, 255, 0.85);
    font-size: 0.9rem;
}

#eventsTable tbody td i {
    color: rgba(255, 255, 255, 0.6);
    font-size: 0.9rem;
}

/* Badge цвета для типов событий */
/* Grid контейнер для скриншотов - отдельная страница и таб */
.screenshots-page-container {
    width: 100%;
}

.screenshots-grid-container,
#screenshotsGrid,
.statistics-container #screenshotsGrid,
.statistics-container .card-body #screenshotsGrid,
#screenshotsTab #screenshotsGrid,
#screenshotsTab .card-body #screenshotsGrid,
.statistics-container .screenshots-grid-container,
#screenshotsTab .screenshots-grid-container {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 1rem !important;
    padding: 1rem !important;
    width: 100% !important;
    box-sizing: border-box !important;
    align-items: start !important;
    grid-auto-rows: auto !important;
    grid-auto-flow: row !important;
    /* Переопределяем Bootstrap */
    flex-direction: unset !important;
    flex-wrap: unset !important;
    flex: unset !important;
    flex-basis: unset !important;
    flex-grow: unset !important;
    flex-shrink: unset !important;
}

/* Переопределяем Bootstrap для card-body внутри таба со скриншотами */
#screenshotsTab .card-body,
.statistics-container #screenshotsTab .card-body {
    display: block !important;
    flex-direction: unset !important;
    flex-wrap: unset !important;
}

/* Grid items */
.screenshot-grid-item,
.statistics-container .screenshot-grid-item,
#screenshotsGrid .screenshot-grid-item,
#screenshotsTab .screenshot-grid-item,
.statistics-container .card-body .screenshot-grid-item,
#screenshotsTab .card-body .screenshot-grid-item,
.screenshots-grid-container .screenshot-grid-item {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
    position: relative !important;
    display: block !important;
    /* Фиксированное соотношение сторон 4:3 через padding-bottom */
    height: 0 !important;
    padding-bottom: 75% !important; /* 4/3 = 0.75 */
    /* Переопределяем Bootstrap */
    flex: unset !important;
    flex-basis: unset !important;
    flex-grow: unset !important;
    flex-shrink: unset !important;
}

/* Миниатюры скриншотов в grid - ссылки */
#screenshotsModal .screenshot-thumbnail-link,
#screenshotsModal a.screenshot-thumbnail-link,
#screenshotsModal .screenshot-grid-item a,
#screenshotsModal #screenshotsGrid a,
.screenshot-thumbnail-link,
.statistics-container .screenshot-thumbnail-link,
#screenshotsGrid .screenshot-thumbnail-link,
#screenshotsTab .screenshot-thumbnail-link,
.screenshot-grid-item a {
    display: block !important;
    text-decoration: none !important;
    width: 100% !important;
    height: 100% !important;
    max-width: 100% !important;
    max-height: 100% !important;
    overflow: hidden !important;
    border-radius: 8px !important;
    border: 2px solid rgba(255, 255, 255, 0.1) !important;
    transition: all 0.2s ease !important;
    cursor: pointer !important;
    background: rgba(255, 255, 255, 0.05) !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    box-sizing: border-box !important;
    min-width: 0 !important;
    min-height: 0 !important;
}

/* Миниатюры скриншотов в grid - изображения */
.screenshot-table-thumbnail,
.screenshot-grid-item img,
.screenshot-thumbnail-link img,
.statistics-container .screenshot-table-thumbnail,
#screenshotsGrid img,
#screenshotsTab .screenshot-table-thumbnail,
.statistics-container .screenshot-grid-item img,
#screenshotsTab .screenshot-grid-item img,
.screenshots-grid-container img {
    width: 100% !important;
    height: 100% !important;
    max-width: 100% !important;
    max-height: 100% !important;
    object-fit: cover !important;
    object-position: center !important;
    display: block !important;
    transition: transform 0.2s ease !important;
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: border-box !important;
    min-width: 0 !important;
    min-height: 0 !important;
    /* Ограничиваем размер миниатюры */
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
}

.screenshot-thumbnail-link:hover {
    border-color: var(--bs-primary) !important;
    box-shadow: 0 4px 12px rgba(13, 110, 253, 0.4) !important;
}

.screenshot-thumbnail-link:hover .screenshot-table-thumbnail {
    transform: scale(1.05) !important;
}

/* Пустые места для скриншотов */
.screenshot-empty {
    pointer-events: none !important;
}

.screenshot-empty-placeholder {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    height: 100% !important;
    background: rgba(255, 255, 255, 0.05) !important;
    border-radius: 8px !important;
    border: 2px dashed rgba(255, 255, 255, 0.1) !important;
    box-sizing: border-box !important;
    user-select: none !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
}

.screenshot-empty-placeholder i {
    font-size: 2rem !important;
    color: rgba(255, 255, 255, 0.3) !important;
}

.view-screenshot-btn {
    padding: 0.25rem 0.5rem !important;
    font-size: 0.875rem !important;
}

/* GLightbox кастомизация для темной темы */
.glightbox-clean .gslide-description {
    background: rgba(0, 0, 0, 0.8) !important;
    color: #fff !important;
}

.glightbox-clean .gslide-title {
    color: #fff !important;
}

.glightbox-clean .gprev,
.glightbox-clean .gnext {
    background: rgba(255, 255, 255, 0.1) !important;
    backdrop-filter: blur(10px) !important;
}

.glightbox-clean .gprev:hover,
.glightbox-clean .gnext:hover {
    background: rgba(255, 255, 255, 0.2) !important;
}

.glightbox-clean .gclose {
    background: rgba(255, 255, 255, 0.1) !important;
    backdrop-filter: blur(10px) !important;
}

.glightbox-clean .gclose:hover {
    background: rgba(255, 255, 255, 0.2) !important;
}

/* Стили для страницы статистики */
.statistics-container {
    padding: 0;
}

.statistics-main-card,
.statistics-screenshots-card {
    background: linear-gradient(135deg, rgba(37, 40, 42, 0.95) 0%, rgba(30, 33, 36, 0.95) 100%);
    border: 1px solid rgba(255, 255, 255, 0.1);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
    border-radius: 16px;
    overflow: hidden;
}


.statistics-filters {
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.05) 0%, rgba(255, 255, 255, 0.02) 100%);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 12px;
    padding: 1.25rem;
    backdrop-filter: blur(10px);
}

.statistics-filters .form-label {
    color: rgba(255, 255, 255, 0.9);
    font-weight: 500;
    margin-bottom: 0.5rem;
}

.statistics-table-wrapper {
    border-radius: 12px;
    overflow: hidden;
    background: rgba(30, 33, 36, 0.5);
    border: 1px solid rgba(255, 255, 255, 0.1);
}

#eventsTable {
    margin-bottom: 0;
    background: transparent;
}

#eventsTable thead {
    background: linear-gradient(135deg, rgba(55, 125, 255, 0.2) 0%, rgba(55, 125, 255, 0.1) 100%);
    border-bottom: 2px solid rgba(55, 125, 255, 0.3);
}

#eventsTable thead th {
    color: #ffffff;
    font-weight: 600;
    font-size: 0.875rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 1rem 0.75rem;
    border-bottom: 2px solid rgba(55, 125, 255, 0.3);
    vertical-align: middle;
}

#eventsTable tbody tr {
    transition: all 0.2s ease;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

#eventsTable tbody tr:hover {
    background: rgba(55, 125, 255, 0.1);
    transform: translateX(2px);
}

#eventsTable tbody td {
    color: rgba(255, 255, 255, 0.9);
    padding: 1rem 0.75rem;
    vertical-align: middle;
}

.statistics-table-wrapper .badge {
    display: inline-flex;
    align-items: center;
    gap: 0.28rem;
    padding: 0.26rem 0.7rem;
    font-size: 0.7rem;
    font-weight: 700;
    border-radius: 999px;
    letter-spacing: 0.3px;
    border: 1px solid transparent;
    box-shadow: 0 5px 12px rgba(0, 0, 0, 0.3), inset 0 1px 0 rgba(255, 255, 255, 0.12);
    text-transform: uppercase;
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.32);
    position: relative;
    overflow: hidden;
}

.statistics-table-wrapper .badge.bg-success {
    background:
        radial-gradient(circle at 20% 30%, rgba(80, 255, 200, 0.45), transparent 55%),
        linear-gradient(135deg, rgba(30, 190, 140, 0.85), rgba(10, 95, 65, 0.92)) !important;
    border-color: rgba(76, 220, 167, 0.55) !important;
    color: #f1fff8 !important;
    box-shadow: 0 8px 18px rgba(17, 122, 82, 0.45), inset 0 2px 8px rgba(255, 255, 255, 0.08);
}

.statistics-table-wrapper .badge.bg-primary {
    background:
        radial-gradient(circle at 25% 25%, rgba(120, 180, 255, 0.5), transparent 60%),
        linear-gradient(135deg, rgba(55, 125, 255, 0.85), rgba(30, 75, 190, 0.95)) !important;
    border-color: rgba(105, 160, 255, 0.6) !important;
    color: #eef3ff !important;
    box-shadow: 0 8px 18px rgba(45, 95, 210, 0.5), inset 0 2px 8px rgba(255, 255, 255, 0.08);
}

.statistics-table-wrapper .badge.bg-info {
    background:
        radial-gradient(circle at 25% 25%, rgba(120, 235, 255, 0.45), transparent 60%),
        linear-gradient(135deg, rgba(15, 175, 215, 0.85), rgba(5, 105, 150, 0.95)) !important;
    border-color: rgba(40, 195, 235, 0.55) !important;
    color: #effcff !important;
    box-shadow: 0 8px 18px rgba(5, 120, 165, 0.45), inset 0 2px 8px rgba(255, 255, 255, 0.08);
}

.statistics-table-wrapper .badge.bg-warning {
    background:
        radial-gradient(circle at 20% 25%, rgba(255, 220, 120, 0.55), transparent 55%),
        linear-gradient(135deg, rgba(230, 150, 15, 0.88), rgba(170, 85, 0, 0.95)) !important;
    border-color: rgba(255, 200, 110, 0.55) !important;
    color: #fafafa !important;
    box-shadow: 0 8px 18px rgba(255, 193, 7, 0.45), inset 0 2px 8px rgba(255, 255, 255, 0.08);
}

.statistics-table-wrapper .badge.bg-purple {
    background:
        radial-gradient(circle at 20% 25%, rgba(210, 160, 255, 0.45), transparent 55%),
        linear-gradient(135deg, rgba(125, 70, 210, 0.85), rgba(80, 35, 150, 0.92)) !important;
    border-color: rgba(174, 129, 255, 0.55) !important;
    color: #faf0ff !important;
    box-shadow: 0 8px 18px rgba(95, 55, 190, 0.45), inset 0 2px 8px rgba(255, 255, 255, 0.08);
}

.statistics-table-wrapper .badge.bg-secondary {
    background:
        radial-gradient(circle at 20% 25%, rgba(180, 185, 195, 0.25), transparent 50%),
        linear-gradient(135deg, rgba(90, 95, 100, 0.8), rgba(45, 48, 54, 0.95)) !important;
    border-color: rgba(255, 255, 255, 0.15) !important;
    color: rgba(255, 255, 255, 0.9) !important;
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.4), inset 0 2px 8px rgba(255, 255, 255, 0.06);
}

.statistics-table-wrapper .badge.bg-danger {
    background:
        radial-gradient(circle at 18% 25%, rgba(255, 150, 170, 0.45), transparent 55%),
        linear-gradient(135deg, rgba(215, 45, 65, 0.88), rgba(130, 20, 40, 0.95)) !important;
    border-color: rgba(230, 95, 115, 0.6) !important;
    color: #ffeef1 !important;
    box-shadow: 0 8px 18px rgba(150, 25, 45, 0.45), inset 0 2px 8px rgba(255, 255, 255, 0.08);
}

.statistics-table-wrapper .badge.badge-active {
    background:
        radial-gradient(circle at 10% 20%, rgba(255, 255, 255, 0.35), transparent 60%),
        linear-gradient(135deg, rgba(0, 224, 255, 0.95), rgba(0, 150, 255, 0.9)) !important;
    border-color: rgba(0, 200, 255, 0.7) !important;
    color: #ffffff !important;
    box-shadow: 0 0 15px rgba(0, 200, 255, 0.55), inset 0 1px 6px rgba(255, 255, 255, 0.25);
    text-shadow: 0 0 8px rgba(0, 255, 255, 0.65);
}

.screenshot-badge-btn {
    border: none;
    border-radius: 999px;
    padding: 0.3rem 0.85rem;
    font-size: 0.8rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    background: linear-gradient(135deg, rgba(55, 125, 255, 0.25) 0%, rgba(30, 80, 170, 0.2) 100%);
    color: rgba(255, 255, 255, 0.92);
    border: 1px solid rgba(55, 125, 255, 0.4);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3), inset 0 1px 0 rgba(255, 255, 255, 0.06);
    transition: all 0.2s ease;
    cursor: pointer;
    min-width: 88px;
}

.screenshot-badge-btn.is-active:hover {
    background: linear-gradient(135deg, rgba(70, 140, 255, 0.35) 0%, rgba(45, 95, 190, 0.3) 100%);
    border-color: rgba(90, 160, 255, 0.6);
    color: #ffffff;
    transform: translateY(-1px);
}

.screenshot-badge-btn.is-disabled,
.screenshot-badge-btn:disabled {
    background: linear-gradient(135deg, rgba(80, 80, 85, 0.35) 0%, rgba(55, 55, 60, 0.3) 100%);
    border-color: rgba(255, 255, 255, 0.08);
    color: rgba(255, 255, 255, 0.45);
    box-shadow: none;
    cursor: not-allowed;
}

#eventsPagination {
    margin-top: 1.5rem;
}

#eventsPagination .pagination {
    margin-bottom: 0;
}

#eventsPagination .page-link {
    background: rgba(37, 40, 42, 0.8);
    border: 1px solid rgba(255, 255, 255, 0.1);
    color: rgba(255, 255, 255, 0.9);
    transition: all 0.2s ease;
}

#eventsPagination .page-link:hover {
    background: rgba(55, 125, 255, 0.2);
    border-color: var(--bs-primary);
    color: #ffffff;
    transform: translateY(-2px);
}

#eventsPagination .page-item.active .page-link {
    background: linear-gradient(135deg, var(--bs-primary) 0%, rgba(var(--bs-primary-rgb), 0.9) 100%);
    border-color: var(--bs-primary);
    color: #ffffff;
    box-shadow: 0 2px 8px rgba(var(--bs-primary-rgb), 0.4);
}

#eventsPagination .page-item.disabled .page-link {
    background: rgba(37, 40, 42, 0.4);
    border-color: rgba(255, 255, 255, 0.05);
    color: rgba(255, 255, 255, 0.3);
    cursor: not-allowed;
}

/* Стили для пагинации скриншотов */
#screenshotsPagination .pagination {
    margin-bottom: 0;
}

#screenshotsPagination .page-link {
    background: rgba(37, 40, 42, 0.8);
    border: 1px solid rgba(255, 255, 255, 0.1);
    color: rgba(255, 255, 255, 0.9);
    transition: all 0.2s ease;
    padding: 0.5rem 0.75rem;
}

#screenshotsPagination .page-link:hover {
    background: rgba(55, 125, 255, 0.2);
    border-color: var(--bs-primary);
    color: #ffffff;
    transform: translateY(-2px);
}

#screenshotsPagination .page-item.active .page-link {
    background: linear-gradient(135deg, var(--bs-primary) 0%, rgba(var(--bs-primary-rgb), 0.9) 100%);
    border-color: var(--bs-primary);
    color: #ffffff;
    box-shadow: 0 2px 8px rgba(var(--bs-primary-rgb), 0.4);
}

#screenshotsPagination .page-item.disabled .page-link {
    background: rgba(37, 40, 42, 0.4);
    border-color: rgba(255, 255, 255, 0.05);
    color: rgba(255, 255, 255, 0.3);
    cursor: not-allowed;
}

.daterangepicker .calendar-table .next:hover span,
.daterangepicker .calendar-table .prev:hover span {
    border-color: rgba(255,255,255,.7);
}

.daterangepicker td.available:not(.in-range) {
    border-radius: 50%;
}

.daterangepicker td.available:hover:not(.active) {
    color: rgba(255,255,255,.7);
    background-color: rgba(255,255,255,.1);
}

.daterangepicker td.in-range {
    color: #c5c8cc;
    background-color: #25282a;
}

.daterangepicker td.active.start-date.end-date,
.daterangepicker td.today.start-date.end-date {
    border-radius: 50%;
}

.daterangepicker td.active,
.daterangepicker td.active:hover {
    color: #fff;
    background-color: #377dff;
}

.daterangepicker td.active.start-date {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
    border-top-left-radius: 50rem;
    border-bottom-left-radius: 50rem;
}

.daterangepicker td.active.end-date {
    border-top-right-radius: 50rem;
    border-bottom-right-radius: 50rem;
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}

.daterangepicker td.off,
.daterangepicker td.off.end-date,
.daterangepicker td.off.in-range,
.daterangepicker td.off.start-date {
    color: rgba(143,149,156,.5);
    background-color: transparent;
}

.daterangepicker .drp-buttons,
.daterangepicker.show-ranges.ltr .drp-calendar.left {
    border-color: #2f3235;
}

.daterangepicker .drp-buttons {
    padding: 0.75rem 0.75rem;
}

.daterangepicker .drp-buttons .btn {
    font-size: .8125rem;
    font-weight: 400;
    padding: .5rem 0.75rem;
}

.daterangepicker .cancelBtn {
    background-color: #25282a;
    border-color: #2f3235;
}

.daterangepicker .cancelBtn.active,
.daterangepicker .cancelBtn:active,
.daterangepicker .cancelBtn:focus,
.daterangepicker .cancelBtn:hover {
    color: #fff;
    box-shadow: 0 3px 6px -2px rgba(32,35,37,.25);
}

.daterangepicker .drp-selected {
    color: #fff;
}

.daterangepicker .ranges ul {
    min-width: 8rem;
    padding-top: .375rem;
    padding-bottom: .375rem;
}

.daterangepicker .ranges li {
    color: rgba(255,255,255,.7);
    font-size: .8125rem;
    line-height: 1.4;
    border-radius: .3125rem;
    padding: .375rem 0.75rem;
    margin-left: .5rem;
    margin-right: .5rem;
}

.daterangepicker .ranges li:hover {
    color: #fff;
    background-color: transparent;
}

.daterangepicker .ranges li.active {
    color: #fff;
    background-color: rgba(255,255,255,.1);
}

.daterangepicker select.ampmselect,
.daterangepicker select.hourselect,
.daterangepicker select.minuteselect,
.daterangepicker select.secondselect {
    cursor: pointer;
    width: 3.5rem;
    font-size: .8125rem;
    color: #fff;
    background-color: transparent;
    border-color: #2f3235;
    padding: .25rem .25rem;
    border-radius: .5rem;
}

.daterangepicker select.ampmselect:hover,
.daterangepicker select.hourselect:hover,
.daterangepicker select.minuteselect:hover,
.daterangepicker select.secondselect:hover {
    color: #fff;
}

@media (max-width: 776.98px) {
    .daterangepicker {
        width: auto;
        max-width: 19rem;
    }

    .daterangepicker .drp-calendar {
        max-width: 100%;
    }

    .daterangepicker .drp-calendar,
    .daterangepicker .ranges {
        float: none;
    }

    .daterangepicker .ranges ul {
        width: 100%;
        margin: 0;
    }

    .daterangepicker .drp-selected {
        display: block;
        margin-bottom: 1rem;
    }
}

/* Админ панель */
.admin-panel-container {
    display: flex;
    gap: 2rem;
    min-height: calc(100vh - 200px);
    overflow-x: hidden;
    max-width: 100%;
}

.admin-sidebar {
    width: 250px;
    flex-shrink: 0;
    background-color: var(--bs-gray-800);
    border-radius: 12px;
    padding: 1.5rem;
    height: fit-content;
    position: sticky;
    top: 2rem;
}

.admin-menu {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.admin-menu-item {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 12px 20px;
    border-radius: 10px;
    cursor: pointer;
    transition: all 0.2s ease;
    color: rgba(255, 255, 255, 0.9);
    background: linear-gradient(135deg, rgba(42, 45, 48, 0.95) 0%, rgba(30, 33, 38, 0.95) 100%);
    border: 1px solid rgba(255, 255, 255, 0.1);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2),
                inset 0 1px 0 rgba(255, 255, 255, 0.05);
    backdrop-filter: blur(10px);
    font-weight: 500;
    margin-bottom: 8px;
}

.admin-menu-item:hover {
    background: linear-gradient(135deg, rgba(52, 55, 58, 0.95) 0%, rgba(40, 43, 48, 0.95) 100%);
    border-color: rgba(255, 255, 255, 0.15);
    color: rgba(255, 255, 255, 1);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3),
                inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.admin-menu-item.active {
    background: linear-gradient(135deg, rgba(var(--bs-primary-rgb), 0.2) 0%, rgba(var(--bs-primary-rgb), 0.1) 100%);
    border-color: rgba(var(--bs-primary-rgb), 0.4);
    color: var(--bs-primary);
    box-shadow: 0 2px 8px rgba(var(--bs-primary-rgb), 0.3),
                inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.admin-menu-item.active:hover {
    background: linear-gradient(135deg, rgba(var(--bs-primary-rgb), 0.25) 0%, rgba(var(--bs-primary-rgb), 0.15) 100%);
    border-color: rgba(var(--bs-primary-rgb), 0.5);
    color: var(--bs-primary);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(var(--bs-primary-rgb), 0.4),
                inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

.admin-menu-item i {
    font-size: 1.25rem;
    color: inherit;
}

.admin-menu-item.active i {
    color: var(--bs-primary);
}

.admin-content {
    flex: 1;
    min-width: 0;
}

.admin-section {
    display: none;
}

.admin-section.active {
    display: block;
}

.admin-list {
    display: grid;
    gap: 1rem;
}

.admin-list-item {
    background-color: var(--bs-gray-800);
    border: 1px solid var(--bs-gray-700);
    border-radius: 8px;
    padding: 1rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: all 0.2s;
}

.admin-list-item:hover {
    background-color: var(--bs-gray-700);
    border-color: var(--bs-gray-600);
}

.admin-list-item-info {
    flex: 1;
}

.admin-list-item-info h5 {
    margin: 0 0 0.25rem 0;
    font-size: 1rem;
}

.admin-list-item-info p {
    margin: 0;
    color: var(--bs-body-color);
    opacity: 0.7;
    font-size: 0.875rem;
}

.admin-list-item-actions {
    display: flex;
    gap: 0.5rem;
}

.admin-form-container {
    margin-top: 2rem;
}

.admin-form-container.d-none {
    display: none !important;
}

.admin-form-container:not(.d-none) {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
}

.admin-form-container .card {
    background-color: var(--bs-gray-800);
    border: 1px solid var(--bs-gray-700);
}

/* Убеждаемся, что стили применяются к элементам формы внутри admin-form-container */
/* Стили для форм в админ-панели */
.admin-panel-container .form-control,
.admin-panel-container input[type="text"].form-control,
.admin-panel-container input[type="password"].form-control,
.admin-panel-container input.form-control,
.admin-panel-container form .form-control,
.admin-panel-container form input[type="text"].form-control,
.admin-panel-container form input[type="password"].form-control,
.admin-panel-container #userFormContainer .form-control,
.admin-panel-container #teamFormContainer .form-control,
.admin-panel-container #departmentFormContainer .form-control,
.admin-panel-container #officeFormContainer .form-control,
.admin-form-container input[type="text"].form-control,
.admin-form-container input[type="password"].form-control,
.admin-form-container input.form-control,
.admin-form-container .form-control,
.admin-form-container form input[type="text"].form-control,
.admin-form-container form input[type="password"].form-control,
.admin-form-container form input.form-control,
.admin-form-container form .form-control,
.admin-form-container .filters-container input[type="text"].form-control,
.admin-form-container .filters-container input[type="password"].form-control,
.admin-form-container .filters-container input.form-control,
.admin-form-container .filters-container .form-control,
.admin-form-container .filters-container form input[type="text"].form-control,
.admin-form-container .filters-container form input[type="password"].form-control,
.admin-form-container .filters-container form input.form-control,
.admin-form-container .filters-container form .form-control,
.admin-form-container .filters-container form .row .col-md-6 input[type="text"].form-control,
.admin-form-container .filters-container form .row .col-md-6 input[type="password"].form-control,
.admin-form-container .filters-container form .row .col-md-6 input.form-control,
.admin-form-container .filters-container form .row .col-md-6 .form-control,
.admin-form-container .filters-container form .row .col-md-6 .mb-3 input[type="text"].form-control,
.admin-form-container .filters-container form .row .col-md-6 .mb-3 input[type="password"].form-control,
.admin-form-container .filters-container form .row .col-md-6 .mb-3 input.form-control,
.admin-form-container .filters-container form .row .col-md-6 .mb-3 .form-control,
#userFirstName.form-control,
#userLastName.form-control,
#userLogin.form-control,
#userPassword.form-control,
#teamName.form-control,
#departmentName.form-control,
#officeName.form-control {
    background-color: var(--bs-gray-200) !important;
    border: 1px solid var(--bs-gray-400) !important;
    border-color: var(--bs-gray-400) !important;
    color: var(--bs-body-color) !important;
    height: 38px;
    min-height: 38px;
    max-height: 38px;
    padding: 0.375rem 0.75rem;
    padding-block: 0.375rem;
    padding-inline: 0.75rem;
    font-size: 0.875rem;
    line-height: 1.5;
    border-radius: 0.375rem;
    transition: all 0.3s ease;
    display: block;
    width: 100%;
    font-weight: 400;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-clip: padding-box;
    box-sizing: border-box;
    overflow: visible;
    overflow-clip-margin: 0;
}

.admin-panel-container .form-control:focus,
.admin-panel-container input[type="text"].form-control:focus,
.admin-panel-container input[type="password"].form-control:focus,
.admin-panel-container input.form-control:focus,
.admin-panel-container form .form-control:focus,
.admin-panel-container form input[type="text"].form-control:focus,
.admin-panel-container form input[type="password"].form-control:focus,
.admin-form-container input[type="text"].form-control:focus,
.admin-form-container input[type="password"].form-control:focus,
.admin-form-container input.form-control:focus,
.admin-form-container .form-control:focus,
.admin-form-container form input[type="text"].form-control:focus,
.admin-form-container form input[type="password"].form-control:focus,
.admin-form-container form input.form-control:focus,
.admin-form-container form .form-control:focus,
.admin-form-container .filters-container input[type="text"].form-control:focus,
.admin-form-container .filters-container input[type="password"].form-control:focus,
.admin-form-container .filters-container input.form-control:focus,
.admin-form-container .filters-container .form-control:focus,
.admin-form-container .filters-container form input[type="text"].form-control:focus,
.admin-form-container .filters-container form input[type="password"].form-control:focus,
.admin-form-container .filters-container form input.form-control:focus,
.admin-form-container .filters-container form .form-control:focus,
#userFirstName.form-control:focus,
#userLastName.form-control:focus,
#userLogin.form-control:focus,
#userPassword.form-control:focus,
#teamName.form-control:focus,
#departmentName.form-control:focus,
#officeName.form-control:focus {
    background-color: var(--bs-gray-200) !important;
    border-color: var(--bs-primary) !important;
    color: var(--bs-body-color) !important;
    box-shadow: 0 0 0 0.25rem rgba(var(--bs-primary-rgb), 0.25);
    outline: 0;
    outline-offset: 0;
}

/* Стили для select в админ-панели */
.admin-panel-container .form-select,
.admin-panel-container select.form-select,
.admin-panel-container form .form-select,
.admin-panel-container form select.form-select,
.admin-panel-container #userFormContainer .form-select,
.admin-panel-container #teamFormContainer .form-select,
.admin-panel-container #departmentFormContainer .form-select,
.admin-panel-container #officeFormContainer .form-select,
.admin-form-container select.form-select,
.admin-form-container .form-select,
.admin-form-container form select.form-select,
.admin-form-container form .form-select,
.admin-form-container .filters-container select.form-select,
.admin-form-container .filters-container .form-select,
.admin-form-container .filters-container form select.form-select,
.admin-form-container .filters-container form .form-select,
.admin-form-container .filters-container form .row .col-md-6 select.form-select,
.admin-form-container .filters-container form .row .col-md-6 .form-select,
.admin-form-container .filters-container form .row .col-md-6 .mb-3 select.form-select,
.admin-form-container .filters-container form .row .col-md-6 .mb-3 .form-select {
    background-color: var(--bs-gray-200) !important;
    border: 1px solid var(--bs-gray-400) !important;
    border-color: var(--bs-gray-400) !important;
    color: var(--bs-body-color) !important;
    height: 38px;
    min-height: 38px;
    max-height: 38px;
    padding: 0.375rem 0.75rem;
    padding-block: 0.375rem;
    padding-inline: 0.75rem;
    font-size: 0.875rem;
    line-height: 1.5;
    border-radius: 0.375rem;
    transition: all 0.3s ease;
    display: block;
    width: 100%;
    font-weight: 400;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-clip: padding-box;
    box-sizing: border-box;
    overflow: visible;
}

.admin-panel-container .form-select:focus,
.admin-panel-container select.form-select:focus,
.admin-panel-container form .form-select:focus,
.admin-panel-container form select.form-select:focus,
.admin-form-container select.form-select:focus,
.admin-form-container .form-select:focus,
.admin-form-container form select.form-select:focus,
.admin-form-container form .form-select:focus,
.admin-form-container .filters-container select.form-select:focus,
.admin-form-container .filters-container .form-select:focus,
.admin-form-container .filters-container form select.form-select:focus,
.admin-form-container .filters-container form .form-select:focus {
    background-color: var(--bs-gray-200) !important;
    border-color: var(--bs-primary) !important;
    color: var(--bs-body-color) !important;
    box-shadow: 0 0 0 0.25rem rgba(var(--bs-primary-rgb), 0.25);
    outline: 0;
    outline-offset: 0;
}

/* Tom Select стили внутри admin-form-container и admin-panel-container */
.admin-panel-container .ts-wrapper,
.admin-panel-container .card .card-body .ts-wrapper,
.admin-panel-container .card .card-body form .ts-wrapper,
.admin-form-container .ts-wrapper,
.admin-form-container .card .card-body .ts-wrapper,
.admin-form-container .card .card-body form .ts-wrapper,
.admin-form-container .card .card-body form .row .col-md-6 .ts-wrapper,
.admin-form-container .card .card-body form .row .col-md-6 .mb-3 .ts-wrapper {
    background-color: var(--bs-gray-200) !important;
    border: 1px solid var(--bs-gray-400) !important;
    border-radius: 0.375rem !important;
    min-height: 38px !important;
    height: 38px !important;
    max-height: 38px !important;
    padding: 0 !important;
    width: 100% !important;
    display: block !important;
    box-sizing: border-box !important;
}

.admin-panel-container .ts-control,
.admin-panel-container .card .card-body .ts-control,
.admin-panel-container .card .card-body form .ts-control,
.admin-form-container .ts-control,
.admin-form-container .card .card-body .ts-control,
.admin-form-container .card .card-body form .ts-control,
.admin-form-container .card .card-body form .row .col-md-6 .ts-control,
.admin-form-container .card .card-body form .row .col-md-6 .mb-3 .ts-control {
    background-color: var(--bs-gray-200) !important;
    border: none !important;
    color: var(--bs-body-color) !important;
    min-height: 38px !important;
    height: 38px !important;
    max-height: 38px !important;
    padding: 0.375rem 0.75rem !important;
    padding-block: 0.375rem !important;
    padding-inline: 0.75rem !important;
    font-size: 0.875rem !important;
    line-height: 1.5 !important;
    width: 100% !important;
    display: flex !important;
    align-items: center !important;
    box-sizing: border-box !important;
}

.admin-panel-container .ts-control input,
.admin-panel-container .card .card-body .ts-control input,
.admin-panel-container .card .card-body form .ts-control input,
.admin-form-container .ts-control input,
.admin-form-container .card .card-body .ts-control input,
.admin-form-container .card .card-body form .ts-control input,
.admin-form-container .card .card-body form .row .col-md-6 .ts-control input,
.admin-form-container .card .card-body form .row .col-md-6 .mb-3 .ts-control input {
    color: var(--bs-body-color) !important;
    font-size: 0.875rem !important;
    line-height: 1.5 !important;
    height: auto !important;
    min-height: auto !important;
    padding: 0 !important;
    padding-block: 0 !important;
    padding-inline: 0 !important;
    margin: 0 !important;
    border: none !important;
    background: transparent !important;
    box-sizing: border-box !important;
}

.admin-panel-container .ts-control .items-placeholder,
.admin-panel-container .card .card-body .ts-control .items-placeholder,
.admin-panel-container .card .card-body form .ts-control .items-placeholder,
.admin-form-container .ts-control .items-placeholder,
.admin-form-container .card .card-body .ts-control .items-placeholder,
.admin-form-container .card .card-body form .ts-control .items-placeholder,
.admin-form-container .card .card-body form .row .col-md-6 .ts-control .items-placeholder,
.admin-form-container .card .card-body form .row .col-md-6 .mb-3 .ts-control .items-placeholder {
    font-size: 0.875rem !important;
    line-height: 1.5 !important;
    color: var(--bs-body-color) !important;
    opacity: 0.6 !important;
}

.admin-panel-container .ts-control .item,
.admin-panel-container .card .card-body .ts-control .item,
.admin-panel-container .card .card-body form .ts-control .item,
.admin-form-container .ts-control .item,
.admin-form-container .card .card-body .ts-control .item,
.admin-form-container .card .card-body form .ts-control .item,
.admin-form-container .card .card-body form .row .col-md-6 .ts-control .item,
.admin-form-container .card .card-body form .row .col-md-6 .mb-3 .ts-control .item {
    font-size: 0.875rem !important;
    line-height: 1.5 !important;
    color: var(--bs-body-color) !important;
}

.admin-form-container .ts-control .ts-input,
.admin-form-container .card .card-body .ts-control .ts-input,
.admin-form-container .card .card-body form .ts-control .ts-input,
.admin-form-container .card .card-body form .row .col-md-6 .ts-control .ts-input,
.admin-form-container .card .card-body form .row .col-md-6 .mb-3 .ts-control .ts-input {
    font-size: 0.875rem !important;
    line-height: 1.5 !important;
}

.admin-panel-container .ts-dropdown,
.admin-panel-container .card .card-body .ts-dropdown,
.admin-panel-container .card .card-body form .ts-dropdown,
.admin-form-container .ts-dropdown,
.admin-form-container .card .card-body .ts-dropdown,
.admin-form-container .card .card-body form .ts-dropdown {
    background-color: var(--bs-gray-800) !important;
    border: 1px solid var(--bs-gray-400) !important;
}

.admin-panel-container .ts-dropdown .option,
.admin-panel-container .card .card-body .ts-dropdown .option,
.admin-panel-container .card .card-body form .ts-dropdown .option,
.admin-form-container .ts-dropdown .option,
.admin-form-container .card .card-body .ts-dropdown .option,
.admin-form-container .card .card-body form .ts-dropdown .option {
    color: var(--bs-body-color) !important;
    font-size: 0.875rem !important;
    padding: 0.375rem 0.75rem !important;
}

.admin-form-container .ts-dropdown .option.active,
.admin-form-container .card .card-body .ts-dropdown .option.active,
.admin-form-container .card .card-body form .ts-dropdown .option.active {
    background-color: var(--bs-primary) !important;
    color: var(--bs-white) !important;
}

.admin-panel-container .ts-dropdown .option:hover,
.admin-panel-container .card .card-body .ts-dropdown .option:hover,
.admin-panel-container .card .card-body form .ts-dropdown .option:hover,
.admin-form-container .ts-dropdown .option:hover,
.admin-form-container .card .card-body .ts-dropdown .option:hover,
.admin-form-container .card .card-body form .ts-dropdown .option:hover {
    background-color: var(--bs-gray-700) !important;
}

.admin-panel-container .ts-dropdown .dropdown-input,
.admin-panel-container .card .card-body .ts-dropdown .dropdown-input,
.admin-panel-container .card .card-body form .ts-dropdown .dropdown-input,
.admin-form-container .ts-dropdown .dropdown-input,
.admin-form-container .card .card-body .ts-dropdown .dropdown-input,
.admin-form-container .card .card-body form .ts-dropdown .dropdown-input {
    background-color: var(--bs-gray-200) !important;
    color: var(--bs-body-color) !important;
    border: 1px solid var(--bs-gray-400) !important;
    font-size: 0.875rem !important;
    padding: 0.375rem 0.75rem !important;
}

/* Кнопка генерации пароля - высота как у инпута */
#generatePasswordBtn {
    height: 38px;
    min-height: 38px;
    display: flex;
    align-items: center;
    justify-content: center;
    white-space: nowrap;
}

/* Input group для пароля - чтобы кнопка была на одном уровне */
/* Эти стили объединены с общими стилями input-group ниже */

.admin-panel-container .input-group .btn,
.admin-panel-container #userFormContainer .input-group .btn {
    position: relative !important;
    z-index: 2 !important;
    margin-left: -1px !important;
    border-top-left-radius: 0 !important;
    border-bottom-left-radius: 0 !important;
    border-top-right-radius: 0.375rem !important;
    border-bottom-right-radius: 0.375rem !important;
    display: inline-flex !important;
    align-items: center !important;
    white-space: nowrap !important;
    height: 38px !important;
    min-height: 38px !important;
    max-height: 38px !important;
    padding: 0.375rem 0.75rem !important;
    flex-shrink: 0 !important;
}

/* Input group стили внутри admin-form-container и admin-panel-container */
.admin-panel-container .input-group,
.admin-panel-container #userFormContainer .input-group {
    display: flex !important;
    flex-wrap: nowrap !important;
    align-items: stretch !important;
    width: 100% !important;
    position: relative !important;
}

.admin-panel-container .input-group .form-control,
.admin-panel-container #userFormContainer .input-group .form-control,
.admin-form-container .input-group .form-control,
.admin-form-container .card .card-body .input-group .form-control,
.admin-form-container .card .card-body form .input-group .form-control,
.admin-form-container .card .card-body form .row .col-md-6 .input-group .form-control,
.admin-form-container .card .card-body form .row .col-md-6 .mb-3 .input-group .form-control {
    background-color: var(--bs-gray-200) !important;
    border: 1px solid var(--bs-gray-400) !important;
    border-color: var(--bs-gray-400) !important;
    border-width: 1px !important;
    border-style: solid !important;
    color: var(--bs-body-color) !important;
    height: 38px !important;
    min-height: 38px !important;
    max-height: 38px !important;
    padding: 0.375rem 0.75rem !important;
    padding-block: 0.375rem !important;
    padding-inline: 0.75rem !important;
    font-size: 0.875rem !important;
    line-height: 1.5 !important;
    border-radius: 0 !important;
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
    transition: all 0.3s ease !important;
    flex: 1 1 auto !important;
    flex-grow: 1 !important;
    width: 1% !important;
    min-width: 0 !important;
    font-weight: 400 !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
    background-clip: padding-box !important;
    box-sizing: border-box !important;
    overflow: visible !important;
    overflow-clip-margin: 0 !important;
}

/* ============================================
   КАСТОМНОЕ МОДАЛЬНОЕ ОКНО ПРИВЯЗКИ
   Полностью переопределяет Bootstrap стили
   ============================================ */

/* Backdrop (затемнение фона) */
.binding-modal.modal-backdrop,
.binding-modal + .modal-backdrop,
#bindingModal.modal + .modal-backdrop {
    background-color: rgba(0, 0, 0, 0.75) !important;
    opacity: 1 !important;
}

/* Dialog контейнер */
.binding-modal .modal-dialog {
    margin: 1.75rem auto !important;
    max-width: 1000px !important;
    overflow-x: hidden !important;
}

.binding-modal .modal-dialog-centered {
    display: flex !important;
    align-items: center !important;
    min-height: calc(100% - 3.5rem) !important;
}

/* Основной контент модального окна */
.binding-modal .modal-content {
    background: linear-gradient(135deg, rgba(30, 33, 36, 0.98) 0%, rgba(25, 28, 32, 0.98) 100%) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-radius: 16px !important;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5) !important;
    color: #f1f3f5 !important;
    display: flex !important;
    flex-direction: column !important;
    max-width: 100% !important;
    pointer-events: auto !important;
    position: relative !important;
    width: 100% !important;
    overflow-x: hidden !important;
}

/* Header (шапка) */
.binding-modal .modal-header {
    display: flex !important;
    flex-shrink: 0 !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 20px 24px !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12) !important;
    background: linear-gradient(135deg, rgba(13, 110, 253, 0.15) 0%, rgba(13, 110, 253, 0.05) 100%) !important;
    border-top-left-radius: 16px !important;
    border-top-right-radius: 16px !important;
}

.binding-modal .modal-title {
    margin: 0 !important;
    line-height: 1.5 !important;
    font-size: 1.25rem !important;
    font-weight: 600 !important;
    color: #ffffff !important;
    display: flex !important;
    align-items: center !important;
}

.binding-modal .btn-close {
    padding: 0.5rem !important;
    margin: -0.5rem -0.5rem -0.5rem auto !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0.375rem !important;
    opacity: 0.7 !important;
    cursor: pointer !important;
    color: #f1f3f5 !important;
    font-size: 1.5rem !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    text-shadow: 0 1px 0 #fff !important;
    filter: invert(1) grayscale(100%) brightness(200%) !important;
    transition: opacity 0.15s ease-in-out !important;
}

.binding-modal .btn-close:hover {
    opacity: 1 !important;
    color: #fff !important;
}

.binding-modal .btn-close:focus {
    outline: none !important;
    box-shadow: 0 0 0 0.25rem rgba(255, 255, 255, 0.25) !important;
}

/* Body (тело модального окна) */
.binding-modal .modal-body {
    position: relative !important;
    flex: 1 1 auto !important;
    padding: 24px !important;
    background-color: #1e2124 !important;
    color: #f1f3f5 !important;
    overflow-x: hidden !important;
}

/* Поисковая строка */
.binding-modal .modal-body .mb-3 {
    margin-bottom: 1rem !important;
}

.binding-modal .form-label {
    color: rgba(255, 255, 255, 0.9) !important;
    font-weight: 600 !important;
    font-size: 0.95rem !important;
    margin-bottom: 8px !important;
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
}

.binding-modal .form-control {
    display: block !important;
    width: 100% !important;
    padding: 0.75rem 1rem !important;
    font-size: 1rem !important;
    font-weight: 400 !important;
    line-height: 1.5 !important;
    color: #f1f3f5 !important;
    background-color: rgba(255, 255, 255, 0.05) !important;
    background-clip: padding-box !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 8px !important;
    transition: all 0.3s ease !important;
    appearance: none !important;
}

.binding-modal .form-control:focus {
    color: #f1f3f5 !important;
    background-color: rgba(255, 255, 255, 0.08) !important;
    border-color: var(--bs-primary) !important;
    outline: 0 !important;
    box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.25) !important;
}

.binding-modal .form-control::placeholder {
    color: rgba(255, 255, 255, 0.55) !important;
    opacity: 1 !important;
}

/* Список привязок */
.binding-modal .binding-list {
    max-height: 400px !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    padding: 16px !important;
    background: linear-gradient(135deg, rgba(37, 40, 42, 0.95) 0%, rgba(30, 33, 36, 0.95) 100%) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 12px !important;
    color: #e9ecef !important;
    margin-top: 16px !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3) !important;
}

.binding-modal .binding-list::-webkit-scrollbar {
    width: 8px !important;
}

.binding-modal .binding-list::-webkit-scrollbar-track {
    background: #1e2124 !important;
    border-radius: 4px !important;
}

.binding-modal .binding-list::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.2) !important;
    border-radius: 4px !important;
}

.binding-modal .binding-list::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 255, 255, 0.3) !important;
}

.binding-modal .binding-group {
    margin-bottom: 20px !important;
    background: linear-gradient(135deg, rgba(37, 40, 42, 0.6) 0%, rgba(30, 33, 36, 0.6) 100%) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 12px !important;
    padding: 12px !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2) !important;
    overflow-x: hidden !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

.binding-modal .binding-group:last-child {
    margin-bottom: 0 !important;
}

.binding-modal .binding-group-title {
    font-weight: 600 !important;
    font-size: 1rem !important;
    margin-bottom: 12px !important;
    color: #ffffff !important;
    padding: 8px 12px !important;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.08) 0%, rgba(255, 255, 255, 0.03) 100%) !important;
    border-radius: 6px !important;
    display: flex !important;
    align-items: center !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
}

.binding-modal .binding-item {
    width: 100% !important;
    max-width: 100% !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 12px 16px !important;
    margin-bottom: 8px !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 8px !important;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.05) 0%, rgba(255, 255, 255, 0.02) 100%) !important;
    color: #e9ecef !important;
    cursor: pointer !important;
    font-size: 0.95rem !important;
    transition: all 0.3s ease !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
}

.binding-modal .binding-item:hover:not(.disabled) {
    background: linear-gradient(135deg, rgba(13, 110, 253, 0.25) 0%, rgba(13, 110, 253, 0.15) 100%) !important;
    border-color: rgba(13, 110, 253, 0.5) !important;
    color: #ffffff !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 8px rgba(13, 110, 253, 0.2) !important;
}

.binding-modal .binding-item.active {
    background: linear-gradient(135deg, rgba(13, 110, 253, 0.4) 0%, rgba(13, 110, 253, 0.3) 100%) !important;
    border-color: rgba(13, 110, 253, 0.7) !important;
    color: #ffffff !important;
    font-weight: 500 !important;
    box-shadow: 0 2px 8px rgba(13, 110, 253, 0.3) !important;
}

.binding-modal .binding-item.disabled {
    cursor: not-allowed !important;
    opacity: 0.45 !important;
    background-color: rgba(255, 255, 255, 0.02) !important;
}

.binding-modal .binding-item.disabled:hover {
    background-color: rgba(255, 255, 255, 0.02) !important;
    border-color: rgba(255, 255, 255, 0.1) !important;
    color: #e2e6ea !important;
    transform: none !important;
}

.binding-modal .binding-item-name {
    font-weight: 500 !important;
    flex: 1 !important;
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

.binding-modal .binding-item-meta {
    font-size: 0.85rem !important;
    color: rgba(255, 255, 255, 0.6) !important;
    margin-left: 12px !important;
}

.binding-modal .binding-item.active .binding-item-meta {
    color: rgba(255, 255, 255, 0.8) !important;
}

/* Иерархическая структура для привязки */
.binding-modal .binding-item.binding-office {
    background: linear-gradient(135deg, rgba(37, 40, 42, 0.95) 0%, rgba(30, 33, 36, 0.95) 100%) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    margin-bottom: 12px !important;
    padding: 14px 18px !important;
    font-weight: 600 !important;
}

.binding-modal .binding-item.binding-office:hover:not(.disabled) {
    background: linear-gradient(135deg, rgba(13, 110, 253, 0.3) 0%, rgba(13, 110, 253, 0.2) 100%) !important;
    border-color: rgba(13, 110, 253, 0.6) !important;
}

.binding-modal .binding-item.binding-office.active {
    background: linear-gradient(135deg, rgba(13, 110, 253, 0.5) 0%, rgba(13, 110, 253, 0.4) 100%) !important;
    border-color: rgba(13, 110, 253, 0.8) !important;
}

.binding-modal .binding-item.binding-department {
    background: linear-gradient(135deg, rgba(30, 33, 36, 0.8) 0%, rgba(25, 28, 32, 0.8) 100%) !important;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    margin-left: 0 !important;
    margin-bottom: 8px !important;
    padding: 12px 16px 12px 40px !important;
    font-weight: 500 !important;
    font-size: 0.9rem !important;
    position: relative !important;
}

.binding-modal .binding-item.binding-department:hover:not(.disabled) {
    background: linear-gradient(135deg, rgba(13, 110, 253, 0.25) 0%, rgba(13, 110, 253, 0.15) 100%) !important;
    border-color: rgba(13, 110, 253, 0.5) !important;
}

.binding-modal .binding-item.binding-department.active {
    background: linear-gradient(135deg, rgba(13, 110, 253, 0.4) 0%, rgba(13, 110, 253, 0.3) 100%) !important;
    border-color: rgba(13, 110, 253, 0.7) !important;
}

.binding-modal .binding-item.binding-team {
    background: linear-gradient(135deg, rgba(25, 28, 32, 0.7) 0%, rgba(20, 23, 27, 0.7) 100%) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    margin-left: 0 !important;
    margin-bottom: 6px !important;
    padding: 10px 14px 10px 60px !important;
    font-weight: 400 !important;
    font-size: 0.85rem !important;
    position: relative !important;
}

.binding-modal .binding-item.binding-team:hover:not(.disabled) {
    background: linear-gradient(135deg, rgba(13, 110, 253, 0.2) 0%, rgba(13, 110, 253, 0.12) 100%) !important;
    border-color: rgba(13, 110, 253, 0.4) !important;
}

.binding-modal .binding-item.binding-team.active {
    background: linear-gradient(135deg, rgba(13, 110, 253, 0.35) 0%, rgba(13, 110, 253, 0.25) 100%) !important;
    border-color: rgba(13, 110, 253, 0.6) !important;
}

/* Иконки в иерархии */
.binding-modal .binding-item.binding-office i {
    color: var(--bs-primary) !important;
    font-size: 1.1rem !important;
}

.binding-modal .binding-item.binding-department i {
    color: rgba(255, 255, 255, 0.8) !important;
    font-size: 1rem !important;
}

.binding-modal .binding-item.binding-team i {
    color: rgba(255, 255, 255, 0.7) !important;
    font-size: 0.9rem !important;
}

.binding-modal .binding-item.active i {
    color: #ffffff !important;
}

/* Визуальная линия связи для вложенности */
.binding-modal .binding-item.binding-department::before {
    content: '';
    position: absolute;
    left: 12px;
    top: 0;
    bottom: 0;
    width: 2px;
    background: linear-gradient(180deg, var(--bs-primary) 0%, rgba(var(--bs-primary-rgb), 0.3) 100%);
    border-radius: 2px;
}

.binding-modal .binding-item.binding-team::before {
    content: '';
    position: absolute;
    left: 32px;
    top: 0;
    bottom: 0;
    width: 2px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.4) 0%, rgba(255, 255, 255, 0.2) 100%);
    border-radius: 2px;
}

.binding-modal .binding-item.binding-department,
.binding-modal .binding-item.binding-team {
    position: relative;
}

/* Badge статуса в binding modal */
.binding-modal .badge {
    padding: 6px 12px !important;
    font-size: 0.875rem !important;
    font-weight: 500 !important;
    border-radius: 6px !important;
}

.binding-modal .badge.bg-success {
    background: linear-gradient(135deg, rgba(25, 135, 84, 0.2) 0%, rgba(25, 135, 84, 0.1) 100%) !important;
    border: 1px solid rgba(25, 135, 84, 0.3) !important;
    color: var(--bs-success) !important;
}

/* Footer (подвал) */
.binding-modal .modal-footer {
    display: flex !important;
    flex-wrap: wrap !important;
    flex-shrink: 0 !important;
    align-items: center !important;
    justify-content: flex-end !important;
    padding: 16px 24px !important;
    border-top: 1px solid rgba(255, 255, 255, 0.12) !important;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.05) 0%, rgba(255, 255, 255, 0.02) 100%) !important;
    border-bottom-left-radius: 16px !important;
    border-bottom-right-radius: 16px !important;
    gap: 12px !important;
}

.binding-modal .modal-footer .btn {
    display: inline-flex !important;
    align-items: center !important;
    font-weight: 500 !important;
    line-height: 1.5 !important;
    text-align: center !important;
    text-decoration: none !important;
    vertical-align: middle !important;
    cursor: pointer !important;
    user-select: none !important;
    border: 1px solid transparent !important;
    padding: 0.625rem 1.25rem !important;
    font-size: 0.95rem !important;
    border-radius: 8px !important;
    transition: all 0.3s ease !important;
}

.binding-modal .modal-footer .btn-secondary {
    color: #fff !important;
    background: linear-gradient(135deg, #6c757d 0%, #5c636a 100%) !important;
    border-color: #6c757d !important;
}

.binding-modal .modal-footer .btn-secondary:hover {
    color: #fff !important;
    background: linear-gradient(135deg, #5c636a 0%, #565e64 100%) !important;
    border-color: #565e64 !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px rgba(108, 117, 125, 0.4) !important;
}

.binding-modal .modal-footer .btn-secondary:focus {
    color: #fff !important;
    background: linear-gradient(135deg, #5c636a 0%, #565e64 100%) !important;
    border-color: #565e64 !important;
    box-shadow: 0 0 0 0.25rem rgba(130, 138, 145, 0.5) !important;
}

.binding-modal .modal-footer .btn-primary {
    background: linear-gradient(135deg, var(--bs-primary) 0%, rgba(var(--bs-primary-rgb), 0.9) 100%) !important;
    border-color: var(--bs-primary) !important;
    color: #fff !important;
}

.binding-modal .modal-footer .btn-primary:hover {
    background: linear-gradient(135deg, rgba(var(--bs-primary-rgb), 1) 0%, rgba(var(--bs-primary-rgb), 0.95) 100%) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 16px rgba(13, 110, 253, 0.4) !important;
}

/* Анимация появления */
.binding-modal.fade .modal-dialog {
    transition: transform 0.3s ease-out !important;
    transform: translate(0, -50px) !important;
}

.binding-modal.show .modal-dialog {
    transform: none !important;
}

.binding-modal.fade {
    transition: opacity 0.15s linear !important;
}

/* ============================================
   МОДАЛЬНОЕ ОКНО "СДЕЛАТЬ ПУБЛИЧНЫМ"
   Стили в темной теме сайта
   ============================================ */

/* Backdrop */
.make-public-modal.modal-backdrop,
.make-public-modal + .modal-backdrop,
#makePublicModal.modal + .modal-backdrop {
    background-color: rgba(0, 0, 0, 0.75) !important;
    opacity: 1 !important;
}

/* Dialog контейнер */
.make-public-modal .modal-dialog {
    margin: 1.75rem auto !important;
    max-width: 900px !important;
    overflow-x: hidden !important;
}

.make-public-modal .modal-dialog-centered {
    display: flex !important;
    align-items: center !important;
    min-height: calc(100% - 3.5rem) !important;
}

/* Основной контент */
.make-public-modal .modal-content {
    background: linear-gradient(135deg, rgba(30, 33, 36, 0.98) 0%, rgba(25, 28, 32, 0.98) 100%) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-radius: 16px !important;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5) !important;
    color: #f1f3f5 !important;
    display: flex !important;
    flex-direction: column !important;
    max-width: 100% !important;
    pointer-events: auto !important;
    position: relative !important;
    width: 100% !important;
    overflow-x: hidden !important;
}

/* Header */
.make-public-modal .modal-header {
    display: flex !important;
    flex-shrink: 0 !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 20px 24px !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12) !important;
    background: linear-gradient(135deg, rgba(13, 110, 253, 0.15) 0%, rgba(13, 110, 253, 0.05) 100%) !important;
    border-top-left-radius: 16px !important;
    border-top-right-radius: 16px !important;
}

.make-public-modal .modal-title {
    margin: 0 !important;
    line-height: 1.5 !important;
    font-size: 1.25rem !important;
    font-weight: 600 !important;
    color: #ffffff !important;
    display: flex !important;
    align-items: center !important;
}

.make-public-modal .modal-title i {
    color: var(--bs-primary) !important;
}

.make-public-modal .btn-close {
    padding: 0.5rem !important;
    margin: -0.5rem -0.5rem -0.5rem auto !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0.375rem !important;
    opacity: 0.7 !important;
    cursor: pointer !important;
    color: #f1f3f5 !important;
    font-size: 1.5rem !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    filter: invert(1) grayscale(100%) brightness(200%) !important;
    transition: opacity 0.15s ease-in-out !important;
}

.make-public-modal .btn-close:hover {
    opacity: 1 !important;
    color: #fff !important;
}

.make-public-modal .btn-close:focus {
    outline: none !important;
    box-shadow: 0 0 0 0.25rem rgba(255, 255, 255, 0.25) !important;
}

/* Body */
.make-public-modal .modal-body {
    position: relative !important;
    flex: 1 1 auto !important;
    padding: 24px !important;
    background-color: #1e2124 !important;
    color: #f1f3f5 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
}

.make-public-info {
    color: rgba(255, 255, 255, 0.7) !important;
    font-size: 0.95rem !important;
}

.make-public-info i {
    color: var(--bs-primary) !important;
}

/* Карточки */
.make-public-card {
    background: linear-gradient(135deg, rgba(37, 40, 42, 0.95) 0%, rgba(30, 33, 36, 0.95) 100%) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 12px !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3) !important;
    overflow: hidden !important;
    margin-bottom: 1rem !important;
}

.make-public-card-header {
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.08) 0%, rgba(255, 255, 255, 0.03) 100%) !important;
    padding: 12px 16px !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
}

.make-public-card-header h6 {
    color: #ffffff !important;
    font-weight: 600 !important;
    font-size: 1rem !important;
    margin: 0 !important;
    display: flex !important;
    align-items: center !important;
}

.make-public-card-header i {
    color: var(--bs-primary) !important;
}

.make-public-card-header-success {
    background: linear-gradient(135deg, rgba(25, 135, 84, 0.2) 0%, rgba(25, 135, 84, 0.1) 100%) !important;
    border-bottom: 1px solid rgba(25, 135, 84, 0.3) !important;
}

.make-public-card-header-success i {
    color: var(--bs-success) !important;
}

.make-public-card-success {
    border-color: rgba(25, 135, 84, 0.3) !important;
}

.make-public-card-body {
    padding: 16px !important;
    background-color: rgba(255, 255, 255, 0.02) !important;
}

/* Иерархия */
.make-public-hierarchy {
    padding: 16px !important;
    max-height: 250px !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    background-color: rgba(255, 255, 255, 0.02) !important;
}

.make-public-hierarchy::-webkit-scrollbar {
    width: 8px !important;
}

.make-public-hierarchy::-webkit-scrollbar-track {
    background: #1e2124 !important;
    border-radius: 4px !important;
}

.make-public-hierarchy::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.2) !important;
    border-radius: 4px !important;
}

.make-public-hierarchy::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 255, 255, 0.3) !important;
}

/* Элементы иерархии */
.make-public-modal .form-check {
    padding: 12px 16px !important;
    margin-bottom: 8px !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 8px !important;
    background-color: rgba(255, 255, 255, 0.03) !important;
    transition: all 0.3s ease !important;
}

.make-public-modal .form-check:hover {
    background-color: rgba(13, 110, 253, 0.15) !important;
    border-color: rgba(13, 110, 253, 0.3) !important;
}

/* Карточки иерархии */
.make-public-modal .hierarchy-office-card,
.make-public-modal .hierarchy-department-card,
.make-public-modal .hierarchy-team-card {
    background-color: rgba(255, 255, 255, 0.03) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 8px !important;
    color: #e9ecef !important;
    transition: all 0.3s ease !important;
}

.make-public-modal .hierarchy-office-card:hover,
.make-public-modal .hierarchy-department-card:hover,
.make-public-modal .hierarchy-team-card:hover {
    background-color: rgba(13, 110, 253, 0.15) !important;
    border-color: rgba(13, 110, 253, 0.3) !important;
}

.make-public-modal .hierarchy-selected-office,
.make-public-modal .hierarchy-selected-department,
.make-public-modal .hierarchy-selected-team {
    background-color: rgba(13, 110, 253, 0.25) !important;
    border-color: rgba(13, 110, 253, 0.5) !important;
}

/* Переопределение Bootstrap border классов */
.make-public-modal .border {
    border-color: rgba(255, 255, 255, 0.1) !important;
}

.make-public-modal .text-muted {
    color: rgba(255, 255, 255, 0.6) !important;
}

/* Лейблы в иерархии */
.make-public-modal .hierarchy-office-card label,
.make-public-modal .hierarchy-department-card label,
.make-public-modal .hierarchy-team-card label {
    color: #e9ecef !important;
}

.make-public-modal .hierarchy-selected-office label,
.make-public-modal .hierarchy-selected-department label,
.make-public-modal .hierarchy-selected-team label {
    color: #ffffff !important;
}

/* Иконки в иерархии */
.make-public-modal .hierarchy-office-card i,
.make-public-modal .hierarchy-department-card i,
.make-public-modal .hierarchy-team-card i {
    color: rgba(255, 255, 255, 0.7) !important;
}

.make-public-modal .hierarchy-selected-office i,
.make-public-modal .hierarchy-selected-department i,
.make-public-modal .hierarchy-selected-team i {
    color: var(--bs-primary) !important;
}

/* Все элементы внутри иерархии */
.make-public-hierarchy * {
    color: inherit !important;
}

.make-public-hierarchy .fw-bold,
.make-public-hierarchy .fw-semibold {
    color: #ffffff !important;
}

.make-public-hierarchy .small {
    color: rgba(255, 255, 255, 0.8) !important;
}

.make-public-modal .form-check-input {
    width: 1.25em !important;
    height: 1.25em !important;
    margin-top: 0.25em !important;
    background-color: #343a40 !important;
    border: 1px solid rgba(255, 255, 255, 0.3) !important;
    cursor: pointer !important;
}

.make-public-modal .form-check-input:checked {
    background-color: var(--bs-primary) !important;
    border-color: var(--bs-primary) !important;
}

.make-public-modal .form-check-input:focus {
    border-color: var(--bs-primary) !important;
    box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25) !important;
}

.make-public-modal .form-check-label {
    color: #e9ecef !important;
    font-size: 0.95rem !important;
    cursor: pointer !important;
    margin-left: 8px !important;
}

/* Бейджи выбранных элементов */
.make-public-modal .badge {
    padding: 6px 12px !important;
    font-size: 0.875rem !important;
    font-weight: 500 !important;
    border-radius: 6px !important;
    background: linear-gradient(135deg, rgba(13, 110, 253, 0.2) 0%, rgba(13, 110, 253, 0.1) 100%) !important;
    border: 1px solid rgba(13, 110, 253, 0.3) !important;
    color: #ffffff !important;
}

/* Footer */
.make-public-modal .modal-footer {
    display: flex !important;
    flex-wrap: wrap !important;
    flex-shrink: 0 !important;
    align-items: center !important;
    justify-content: flex-end !important;
    padding: 16px 24px !important;
    border-top: 1px solid rgba(255, 255, 255, 0.12) !important;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.05) 0%, rgba(255, 255, 255, 0.02) 100%) !important;
    border-bottom-left-radius: 16px !important;
    border-bottom-right-radius: 16px !important;
    gap: 12px !important;
}

.make-public-modal .modal-footer .btn {
    display: inline-flex !important;
    align-items: center !important;
    font-weight: 500 !important;
    line-height: 1.5 !important;
    text-align: center !important;
    text-decoration: none !important;
    vertical-align: middle !important;
    cursor: pointer !important;
    user-select: none !important;
    border: 1px solid transparent !important;
    padding: 0.625rem 1.25rem !important;
    font-size: 0.95rem !important;
    border-radius: 8px !important;
    transition: all 0.3s ease !important;
}

.make-public-modal .modal-footer .btn-secondary {
    color: #fff !important;
    background: linear-gradient(135deg, #6c757d 0%, #5c636a 100%) !important;
    border-color: #6c757d !important;
}

.make-public-modal .modal-footer .btn-secondary:hover {
    background: linear-gradient(135deg, #5c636a 0%, #565e64 100%) !important;
    border-color: #565e64 !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px rgba(108, 117, 125, 0.4) !important;
}

.make-public-modal .modal-footer .btn-primary {
    background: linear-gradient(135deg, var(--bs-primary) 0%, rgba(var(--bs-primary-rgb), 0.9) 100%) !important;
    border-color: var(--bs-primary) !important;
    color: #fff !important;
}

.make-public-modal .modal-footer .btn-primary:hover {
    background: linear-gradient(135deg, rgba(var(--bs-primary-rgb), 1) 0%, rgba(var(--bs-primary-rgb), 0.95) 100%) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 16px rgba(13, 110, 253, 0.4) !important;
}

.make-public-modal .modal-footer .btn-outline-danger {
    color: var(--bs-danger) !important;
    border-color: var(--bs-danger) !important;
    background: transparent !important;
}

.make-public-modal .modal-footer .btn-outline-danger:hover {
    background: var(--bs-danger) !important;
    color: #fff !important;
    transform: translateY(-1px) !important;
}

/* Кнопка "Убрать все доступы" - синий крестик */
.make-public-modal #clearAllAccessesBtn i {
    color: #dc3545 !important;
}

.make-public-modal #clearAllAccessesBtn:hover i {
    color: #fff !important;
}

/* Анимация появления */
.make-public-modal.fade .modal-dialog {
    transition: transform 0.3s ease-out !important;
    transform: translate(0, -50px) !important;
}

.make-public-modal.show .modal-dialog {
    transform: none !important;
}

.make-public-modal.fade {
    transition: opacity 0.15s linear !important;
}

.binding-modal.fade:not(.show) {
    opacity: 0 !important;
}

.binding-modal.show {
    display: block !important;
}

/* Стили для модального окна "Сделать публичным" */
#organizationHierarchy {
  scrollbar-width: thin;
  scrollbar-color: #6c757d #f8f9fa;
}

#organizationHierarchy::-webkit-scrollbar {
  width: 8px;
}

#organizationHierarchy::-webkit-scrollbar-track {
  background: #f8f9fa;
  border-radius: 4px;
}

#organizationHierarchy::-webkit-scrollbar-thumb {
  background: #6c757d;
  border-radius: 4px;
}

#organizationHierarchy::-webkit-scrollbar-thumb:hover {
  background: #5a6268;
}

#organizationHierarchy .form-check-input:checked {
  background-color: #0d6efd;
  border-color: #0d6efd;
}

#organizationHierarchy .form-check-input:focus {
  border-color: #86b7fe;
  outline: 0;
  box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
}

#organizationHierarchy label {
  user-select: none;
}

#organizationHierarchy label:hover {
  color: #0d6efd !important;
}

#organizationHierarchy .border {
  transition: all 0.2s ease;
}

#organizationHierarchy .border:hover {
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  transform: translateX(2px);
}

/* Улучшенные цвета для карточек */
.hierarchy-office-card {
  background-color: #ffffff;
  border-color: #dee2e6;
  border-width: 1px;
  color: #212529;
}

.hierarchy-selected-office {
  background-color: #0d6efd !important;
  border-color: #0d6efd !important;
  border-width: 2px !important;
  color: #ffffff !important;
}

.hierarchy-selected-office label {
  color: #ffffff !important;
  font-weight: 700 !important;
}

.hierarchy-department-card {
  background-color: #ffffff;
  border-color: #dee2e6;
  border-width: 1px;
  border-left: 1px solid #dee2e6;
  color: #212529;
}

.hierarchy-selected-department {
  background-color: #ffc107 !important;
  border-color: #ffc107 !important;
  border-width: 2px !important;
  border-left: 4px solid #ffc107 !important;
  color: #ffffff !important;
}

.hierarchy-selected-department label {
  color: #ffffff !important;
  font-weight: 600 !important;
}

.hierarchy-team-card {
  background-color: #f8f9fa;
  border-color: #dee2e6;
  border-width: 1px;
  color: #212529;
}

.hierarchy-selected-team {
  background-color: #198754 !important;
  border-color: #198754 !important;
  border-width: 2px !important;
  color: #ffffff !important;
}

.hierarchy-selected-team label {
  color: #ffffff !important;
  font-weight: 500 !important;
}

#currentAccessesList .badge,
#selectedAccessesList .badge {
  transition: all 0.2s ease;
}

#currentAccessesList .badge:hover,
#selectedAccessesList .badge:hover {
  transform: translateY(-2px);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

/* Кастомные цвета для новых оценок */
.badge.bg-purple,
.bg-purple {
  background-color: #6f42c1 !important;
  color: #ffffff !important;
}

.badge.bg-purple-subtle,
.bg-purple-subtle {
  background-color: rgba(111, 66, 193, 0.15) !important;
}

.text-purple-emphasis {
  color: #6f42c1 !important;
}

.badge.bg-orange,
.bg-orange {
  background-color: #ff8c00 !important;
  color: #ffffff !important;
}

.badge.bg-orange-subtle,
.bg-orange-subtle {
  background-color: rgba(255, 140, 0, 0.15) !important;
}

.text-orange-emphasis {
  color: #ff8c00 !important;
}

/* Глобальные стили для кнопок в стиле админ-панели */
.btn-success,
.btn.btn-success {
    background: linear-gradient(135deg, rgba(42, 45, 48, 0.95) 0%, rgba(30, 33, 38, 0.95) 100%) !important;
    color: #198754 !important;
    border-color: rgba(25, 135, 84, 0.3) !important;
    border: 1px solid rgba(25, 135, 84, 0.3) !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2),
                inset 0 1px 0 rgba(255, 255, 255, 0.05) !important;
    backdrop-filter: blur(10px);
    transition: all 0.2s ease !important;
    font-weight: 500 !important;
}

.btn-success:hover,
.btn.btn-success:hover {
    background: linear-gradient(135deg, rgba(52, 55, 58, 0.95) 0%, rgba(40, 43, 48, 0.95) 100%) !important;
    border-color: rgba(25, 135, 84, 0.5) !important;
    color: #198754 !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3),
                inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
}

.btn-success:active,
.btn.btn-success:active {
    transform: translateY(0) !important;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2) !important;
}

.btn-danger,
.btn.btn-danger {
    background: linear-gradient(135deg, rgba(42, 45, 48, 0.95) 0%, rgba(30, 33, 38, 0.95) 100%) !important;
    color: #dc3545 !important;
    border-color: rgba(220, 53, 69, 0.3) !important;
    border: 1px solid rgba(220, 53, 69, 0.3) !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2),
                inset 0 1px 0 rgba(255, 255, 255, 0.05) !important;
    backdrop-filter: blur(10px);
    transition: all 0.2s ease !important;
    font-weight: 500 !important;
}

.btn-danger:hover,
.btn.btn-danger:hover {
    background: linear-gradient(135deg, rgba(52, 55, 58, 0.95) 0%, rgba(40, 43, 48, 0.95) 100%) !important;
    border-color: rgba(220, 53, 69, 0.5) !important;
    color: #dc3545 !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3),
                inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
}

.btn-danger:active,
.btn.btn-danger:active {
    transform: translateY(0) !important;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2) !important;
}

.btn-secondary,
.btn.btn-secondary {
    background: linear-gradient(135deg, rgba(42, 45, 48, 0.95) 0%, rgba(30, 33, 38, 0.95) 100%) !important;
    color: rgba(255, 255, 255, 0.9) !important;
    border-color: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2),
                inset 0 1px 0 rgba(255, 255, 255, 0.05) !important;
    backdrop-filter: blur(10px);
    transition: all 0.2s ease !important;
    font-weight: 500 !important;
}

.btn-secondary:hover,
.btn.btn-secondary:hover {
    background: linear-gradient(135deg, rgba(52, 55, 58, 0.95) 0%, rgba(40, 43, 48, 0.95) 100%) !important;
    border-color: rgba(255, 255, 255, 0.15) !important;
    color: rgba(255, 255, 255, 1) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3),
                inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
}

.btn-secondary:active,
.btn.btn-secondary:active {
    transform: translateY(0) !important;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2) !important;
}

.btn-info,
.btn.btn-info {
    background: linear-gradient(135deg, rgba(42, 45, 48, 0.95) 0%, rgba(30, 33, 38, 0.95) 100%) !important;
    color: var(--bs-primary) !important;
    border-color: rgba(var(--bs-primary-rgb), 0.3) !important;
    border: 1px solid rgba(var(--bs-primary-rgb), 0.3) !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2),
                inset 0 1px 0 rgba(255, 255, 255, 0.05) !important;
    backdrop-filter: blur(10px);
    transition: all 0.2s ease !important;
    font-weight: 500 !important;
}

.btn-info:hover,
.btn.btn-info:hover {
    background: linear-gradient(135deg, rgba(52, 55, 58, 0.95) 0%, rgba(40, 43, 48, 0.95) 100%) !important;
    border-color: rgba(var(--bs-primary-rgb), 0.5) !important;
    color: var(--bs-primary) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3),
                inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
}

.btn-info:active,
.btn.btn-info:active {
    transform: translateY(0) !important;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2) !important;
}


/* Дополнительные стили для страницы статистики */
.statistics-main-card .card-body,
.statistics-screenshots-card .card-body {
    padding: 1.5rem;
}

.statistics-date-picker .form-control {
    background-color: rgba(30, 33, 38, 0.8) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    color: rgba(255, 255, 255, 0.95) !important;
}

.statistics-date-picker .form-control:focus {
    background-color: rgba(30, 33, 38, 0.95) !important;
    border-color: var(--bs-primary) !important;
    box-shadow: 0 0 0 3px rgba(var(--bs-primary-rgb), 0.15) !important;
    color: rgba(255, 255, 255, 1) !important;
}


.statistics-filters .form-select {
    background-color: rgba(30, 33, 38, 0.8) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    color: rgba(255, 255, 255, 0.95) !important;
}

.statistics-filters .form-select:focus {
    background-color: rgba(30, 33, 38, 0.95) !important;
    border-color: var(--bs-primary) !important;
    box-shadow: 0 0 0 3px rgba(var(--bs-primary-rgb), 0.15) !important;
    color: rgba(255, 255, 255, 1) !important;
}

.dashboard-container {
    display: flex;
    gap: 20px;
    height: calc(100vh - 200px);
}

.dashboard-main {
    flex: 0 0 80%;
    overflow-y: auto;
}

.dashboard-sidebar {
    flex: 0 0 20%;
    display: flex;
    flex-direction: column;
    gap: 20px;
    overflow-y: auto;
}

.recent-requests-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.recent-request-item {
    padding: 8px 12px;
    border-left: 3px solid;
    background-color: rgba(255, 255, 255, 0.03);
    border-radius: 4px;
    cursor: pointer;
    transition: background-color 0.2s;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.recent-request-item:hover {
    background-color: rgba(255, 255, 255, 0.05);
}

.recent-request-item.pending {
    border-left-color: #ffc107; /* желтый для ожидающих */
}

.recent-request-item.approved {
    border-left-color: #198754; /* зеленый для одобренных */
}

.recent-request-item.rejected {
    border-left-color: #dc3545; /* красный для отклоненных */
}

.recent-request-user {
    font-weight: 600;
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.95);
    line-height: 1.2;
}

.recent-request-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.recent-request-type {
    font-size: 0.8rem;
    color: rgba(255, 255, 255, 0.8);
    line-height: 1.2;
}

.recent-request-status {
    font-size: 0.7rem;
    color: rgba(255, 255, 255, 0.6);
    display: inline-block;
    padding: 2px 6px;
    border-radius: 3px;
    margin-top: 2px;
}

.recent-request-status.pending {
    background-color: rgba(255, 193, 7, 0.2);
    color: #ffc107;
}

.recent-request-status.approved {
    background-color: rgba(25, 135, 84, 0.2);
    color: #198754;
}

.recent-request-status.rejected {
    background-color: rgba(220, 53, 69, 0.2);
    color: #dc3545;
}

.notifications-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.notification-item {
    padding: 8px 12px;
    border-left: 3px solid;
    background-color: rgba(255, 255, 255, 0.03);
    border-radius: 4px;
    cursor: pointer;
    transition: background-color 0.2s;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.notification-item:hover {
    background-color: rgba(255, 255, 255, 0.05);
}

.notification-item.work {
    border-left-color: #198754; /* зеленый */
}

.notification-item.end-work {
    border-left-color: #dc3545; /* красный для завершения работы */
}

.notification-item.call {
    border-left-color: #0d6efd; /* синий */
}

.notification-item.break {
    border-left-color: #fd7e14; /* оранжевый */
}

.notification-item.lunch {
    border-left-color: #fd7e14; /* оранжевый */
}

.notification-item.birthday {
    border-left-color: #ffc107; /* желтый */
}

.notification-item.marathon {
    border-left-color: #6f42c1; /* фиолетовый */
}

.notification-user {
    font-weight: 600;
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.95);
    line-height: 1.2;
}

.notification-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.notification-text {
    font-size: 0.8rem;
    color: rgba(255, 255, 255, 0.8);
    line-height: 1.2;
}

.notification-time {
    font-size: 0.7rem;
    color: rgba(255, 255, 255, 0.6);
}

.dashboard-section-header {
    background: linear-gradient(135deg, rgba(42, 45, 48, 0.95) 0%, rgba(30, 33, 38, 0.95) 100%);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 16px 16px 0 0;
    padding: 12px 16px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3),
                0 1px 3px rgba(0, 0, 0, 0.2),
                inset 0 1px 0 rgba(255, 255, 255, 0.05);
    backdrop-filter: blur(10px);
    position: relative;
    overflow: hidden;
    transition: all 0.3s ease;
}

.dashboard-section-header::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg, 
        transparent 0%, 
        var(--bs-primary) 50%, 
        transparent 100%);
    opacity: 0.6;
}

.dashboard-section-header h4,
.dashboard-section-header h5 {
    color: rgba(255, 255, 255, 0.9);
    font-weight: 600;
    margin: 0;
    position: relative;
    z-index: 1;
}

.dashboard-section-header .badge {
    position: relative;
    z-index: 1;
}

.user-status-indicator {
    display: inline-block;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    margin-right: 8px;
    vertical-align: middle;
}

.user-status-indicator.active {
    background-color: #198754;
    box-shadow: 0 0 6px rgba(25, 135, 84, 0.6);
}

.user-status-indicator.inactive {
    background-color: #6c757d;
}

.stats-buttons {
    display: flex;
    gap: 8px;
    align-items: center;
    justify-content: space-between;
    width: 100%;
}

.stats-buttons .btn {
    font-size: 0.8rem;
    padding: 4px 12px;
    white-space: nowrap;
    background: linear-gradient(135deg, rgba(42, 45, 48, 0.95) 0%, rgba(30, 33, 38, 0.95) 100%);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    color: rgba(255, 255, 255, 0.9);
    transition: all 0.2s ease;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2),
                inset 0 1px 0 rgba(255, 255, 255, 0.05);
    backdrop-filter: blur(10px);
}

.stats-buttons .btn:hover {
    background: linear-gradient(135deg, rgba(52, 55, 58, 0.95) 0%, rgba(40, 43, 48, 0.95) 100%);
    border-color: rgba(255, 255, 255, 0.15);
    color: rgba(255, 255, 255, 1);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3),
                inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.stats-buttons .btn:active {
    transform: translateY(0);
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.2),
                inset 0 1px 2px rgba(0, 0, 0, 0.2);
}

.stats-analytics-btn {
    padding: 4px 8px !important;
    min-width: 32px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.stats-tooltip-content {
    font-size: 0.85rem;
    line-height: 1.5;
}

/* Улучшенные стили для tooltips */
.tooltip {
    font-size: 0.875rem;
}

.tooltip-inner {
    background: linear-gradient(135deg, rgba(42, 45, 48, 0.98) 0%, rgba(30, 33, 38, 0.98) 100%);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    padding: 10px 12px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4),
                0 1px 3px rgba(0, 0, 0, 0.3);
    backdrop-filter: blur(10px);
    color: rgba(255, 255, 255, 0.95);
    max-width: 300px;
    text-align: left;
    line-height: 1.6;
}

.tooltip-inner strong {
    color: rgba(255, 255, 255, 1);
    font-weight: 600;
}

.tooltip.bs-tooltip-top .tooltip-arrow::before {
    border-top-color: rgba(255, 255, 255, 0.1);
}

.tooltip.bs-tooltip-bottom .tooltip-arrow::before {
    border-bottom-color: rgba(255, 255, 255, 0.1);
}

.tooltip.bs-tooltip-start .tooltip-arrow::before {
    border-left-color: rgba(255, 255, 255, 0.1);
}

.tooltip.bs-tooltip-end .tooltip-arrow::before {
    border-right-color: rgba(255, 255, 255, 0.1);
}

/* Стили для модального окна запросов на одобрение */
.approval-request-modal.modal-backdrop,
.approval-request-modal + .modal-backdrop,
#approvalRequestModal.modal + .modal-backdrop {
    background-color: rgba(0, 0, 0, 0.8) !important;
    opacity: 1 !important;
    backdrop-filter: blur(4px);
}

.approval-request-modal .modal-dialog {
    margin: 1.75rem auto !important;
    max-width: 500px !important;
}

.approval-request-modal .modal-content {
    background: linear-gradient(135deg, rgba(42, 45, 48, 0.95) 0%, rgba(30, 33, 38, 0.95) 100%) !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    border-radius: 16px !important;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3),
                0 1px 3px rgba(0, 0, 0, 0.2),
                inset 0 1px 0 rgba(255, 255, 255, 0.05) !important;
    color: #f1f3f5 !important;
    overflow: hidden;
    position: relative;
    backdrop-filter: blur(10px);
}

.approval-request-modal .modal-content::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg, 
        transparent 0%, 
        var(--bs-primary) 50%, 
        transparent 100%);
    opacity: 0.6;
    z-index: 1;
}

.approval-request-modal .modal-header {
    background: linear-gradient(135deg, rgba(42, 45, 48, 0.95) 0%, rgba(30, 33, 38, 0.95) 100%) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
    padding: 14px 18px !important;
    border-radius: 16px 16px 0 0 !important;
    position: relative;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3),
                0 1px 3px rgba(0, 0, 0, 0.2),
                inset 0 1px 0 rgba(255, 255, 255, 0.05);
    backdrop-filter: blur(10px);
}

.approval-request-modal .modal-title {
    margin: 0 !important;
    font-size: 1.1rem !important;
    font-weight: 600 !important;
    color: rgba(255, 255, 255, 0.9) !important;
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
}

.approval-request-modal .modal-title i {
    font-size: 1.2rem !important;
    color: var(--bs-primary);
}

.approval-request-modal .btn-close {
    filter: brightness(0) invert(1) !important;
    opacity: 0.7 !important;
    transition: all 0.2s ease !important;
    padding: 4px !important;
    border-radius: 4px !important;
}

.approval-request-modal .btn-close:hover {
    opacity: 1 !important;
    background: rgba(255, 255, 255, 0.1) !important;
}

.approval-request-modal .modal-body {
    padding: 18px !important;
    background: transparent !important;
    color: #f1f3f5 !important;
    position: relative;
}

.approval-request-info {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.approval-request-info .info-item {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding-bottom: 14px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.approval-request-info .info-item:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.approval-request-info .info-label {
    font-size: 0.8rem;
    color: rgba(255, 255, 255, 0.6);
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 8px;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.approval-request-info .info-label i {
    color: var(--bs-primary);
    font-size: 0.95rem;
    width: 18px;
    text-align: center;
}

.approval-request-info .info-value {
    font-size: 0.95rem;
    color: rgba(255, 255, 255, 0.9);
    font-weight: 400;
    line-height: 1.5;
    padding-left: 26px;
}

.approval-request-info .message-text,
.approval-request-info .admin-comment-text {
    background: rgba(255, 255, 255, 0.05);
    padding: 12px;
    border-radius: 8px;
    border-left: 3px solid var(--bs-primary);
    white-space: pre-wrap;
    word-wrap: break-word;
    margin-top: 2px;
    font-size: 0.9rem;
    line-height: 1.5;
}

.approval-request-info .admin-comment-input {
    background: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    color: #f1f3f5 !important;
    border-radius: 8px !important;
    padding: 10px 12px !important;
    font-size: 0.9rem !important;
    line-height: 1.5 !important;
    transition: all 0.3s ease !important;
    resize: vertical !important;
    min-height: 70px !important;
    margin-top: 2px;
}

.approval-request-info .admin-comment-input:focus {
    background: rgba(255, 255, 255, 0.08) !important;
    border-color: var(--bs-primary) !important;
    box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.25) !important;
    color: #f1f3f5 !important;
    outline: none !important;
}

.approval-request-info .admin-comment-input::placeholder {
    color: rgba(255, 255, 255, 0.4) !important;
    font-style: italic;
}

.approval-request-info .status-badge {
    padding: 4px 10px;
    border-radius: 6px;
    font-weight: 600;
    font-size: 0.8rem;
    display: inline-block;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.approval-request-info .status-badge.status-pending {
    background: rgba(255, 193, 7, 0.2);
    color: #ffc107;
    border: 1px solid rgba(255, 193, 7, 0.3);
}

.approval-request-info .status-badge.status-approved {
    background: rgba(25, 135, 84, 0.2);
    color: #198754;
    border: 1px solid rgba(25, 135, 84, 0.3);
}

.approval-request-info .status-badge.status-rejected {
    background: rgba(220, 53, 69, 0.2);
    color: #dc3545;
    border: 1px solid rgba(220, 53, 69, 0.3);
}

.approval-request-modal .modal-footer {
    background: transparent !important;
    border-top: 1px solid rgba(255, 255, 255, 0.08) !important;
    padding: 14px 18px !important;
    border-radius: 0 0 16px 16px !important;
    display: flex !important;
    gap: 8px !important;
    justify-content: flex-end !important;
}

.approval-request-modal .modal-footer .btn {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    font-weight: 500 !important;
    padding: 8px 16px !important;
    border-radius: 8px !important;
    transition: all 0.2s ease !important;
    font-size: 0.875rem !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2),
                inset 0 1px 0 rgba(255, 255, 255, 0.05) !important;
    backdrop-filter: blur(10px);
}

.approval-request-modal .modal-footer .btn-success {
    background: linear-gradient(135deg, rgba(42, 45, 48, 0.95) 0%, rgba(30, 33, 38, 0.95) 100%) !important;
    color: #198754 !important;
    border-color: rgba(25, 135, 84, 0.3) !important;
}

.approval-request-modal .modal-footer .btn-success:hover {
    background: linear-gradient(135deg, rgba(52, 55, 58, 0.95) 0%, rgba(40, 43, 48, 0.95) 100%) !important;
    border-color: rgba(25, 135, 84, 0.5) !important;
    color: #198754 !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3),
                inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
}

.approval-request-modal .modal-footer .btn-danger {
    background: linear-gradient(135deg, rgba(42, 45, 48, 0.95) 0%, rgba(30, 33, 38, 0.95) 100%) !important;
    color: #dc3545 !important;
    border-color: rgba(220, 53, 69, 0.3) !important;
}

.approval-request-modal .modal-footer .btn-danger:hover {
    background: linear-gradient(135deg, rgba(52, 55, 58, 0.95) 0%, rgba(40, 43, 48, 0.95) 100%) !important;
    border-color: rgba(220, 53, 69, 0.5) !important;
    color: #dc3545 !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3),
                inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
}

.approval-request-modal .modal-footer .btn-secondary {
    background: linear-gradient(135deg, rgba(42, 45, 48, 0.95) 0%, rgba(30, 33, 38, 0.95) 100%) !important;
    color: rgba(255, 255, 255, 0.9) !important;
    border-color: rgba(255, 255, 255, 0.1) !important;
}

.approval-request-modal .modal-footer .btn-secondary:hover {
    background: linear-gradient(135deg, rgba(52, 55, 58, 0.95) 0%, rgba(40, 43, 48, 0.95) 100%) !important;
    border-color: rgba(255, 255, 255, 0.15) !important;
    color: rgba(255, 255, 255, 1) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3),
                inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
}

.approval-request-modal.fade .modal-dialog {
    transition: transform 0.3s ease-out !important;
    transform: translate(0, -30px) !important;
}

.approval-request-modal.show .modal-dialog {
    transform: translate(0, 0) !important;
}

.approval-request-modal.fade {
    transition: opacity 0.2s linear !important;
}

.approval-request-modal.show {
    opacity: 1 !important;
}

