@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;700&display=swap');

:root {
    --dark-gray: #263238;
    --medium-gray: #37474f;
    --light-gray: #455a64;
    --blue-dark: #1565c0;
    --blue-medium: #1976d2;
    --blue-light: #e3f2fd;
    --white: #ffffff;
    --text-light: #eceff1;
    --text-dark: #212121;
}

/* Основные стили */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    background-color: #263238;
    color: #eceff1;
    line-height: 1.6;
}

/* Хедер с информацией о пользователе */
.header {
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    background-color: var(--dark-gray);
    color: var(--white);
    padding: 15px 20px;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    z-index: 1002; /* Выше чем боковое меню */
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}

.user-info {
    display: flex;
    align-items: center;
    gap: 15px;
}

.user-info span {
    color: var(--white);
    font-weight: 500;
}

.user-name-link {
    cursor: pointer;
    padding: 8px 12px;
    border-radius: 6px;
    transition: background-color 0.2s ease;
}

.user-name-link:hover {
    background-color: rgba(255, 255, 255, 0.1);
}

.logout-btn {
    background-color: var(--red);
    color: white;
    border: none;
    padding: 8px 16px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 14px;
    font-weight: 500;
    transition: all 0.2s ease;
    white-space: nowrap;
}

.logout-btn:hover {
    background-color: #c62828;
    transform: translateY(-1px);
}

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

/* Общие стили секций. Добавляем отступ сверху для хедера */
.section {
    margin-top: 80px; /* Увеличен отступ для нового хедера */
}

/* Меню и боковая панель */
#menu-btn {
    background-color: var(--blue-medium);
    color: var(--white);
    border: none;
    padding: 10px 16px;
    cursor: pointer;
    font-size: 16px;
    font-weight: 500;
    position: fixed;
    top: 15px;
    left: 20px;
    z-index: 1003; /* Выше всех элементов */
    border-radius: 8px;
    box-shadow: 0 2px 6px rgba(0,0,0,0.2);
    transition: background-color 0.2s ease, transform 0.2s ease;
}

#menu-btn:hover {
    background-color: var(--blue-dark);
    transform: translateY(-2px);
}

#menu-btn:active {
    transform: translateY(0);
}

#sidebar {
    width: 240px;
    background-color: var(--medium-gray);
    color: var(--text-light);
    height: 100vh;
    position: fixed;
    top: 0;
    left: -240px;
    transition: left 0.3s ease;
    padding-top: 70px;
    z-index: 1001;
    box-shadow: 2px 0 10px rgba(0,0,0,0.3);
}

#sidebar.active {
    left: 0;
}

/* Добавляем overlay для закрытия меню при клике вне его */
.sidebar-overlay {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0,0,0,0.5);
    z-index: 1000;
}

.sidebar-overlay.active {
    display: block;
}

/* Навигация */
#sidebar nav ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

/* Выпадающее меню справочников */
.nav-item-with-submenu {
    position: relative;
}

.nav-submenu {
    list-style: none;
    padding: 0;
    margin: 0;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
    background-color: var(--dark-gray);
}

.nav-item-with-submenu.active .nav-submenu {
    max-height: 200px;
}

.nav-submenu li {
    padding: 0;
}

.nav-sublink {
    display: flex;
    align-items: center;
    padding: 10px 15px 10px 45px;
    color: var(--text-light);
    text-decoration: none;
    transition: all 0.3s ease;
    font-size: 14px;
}

.nav-sublink:hover {
    background-color: var(--medium-gray);
    color: var(--white);
}

.nav-dropdown-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
}

.nav-arrow {
    transition: transform 0.3s ease;
    font-size: 12px;
}

.nav-item-with-submenu.active .nav-arrow {
    transform: rotate(180deg);
}
#sidebar nav ul li {
    margin: 0;
}

#sidebar nav ul li a {
    display: block;
    padding: 14px 24px;
    color: var(--text-light);
    text-decoration: none;
    font-weight: 400;
    transition: background-color 0.2s ease;
}

#sidebar nav ul li a:hover {
    background-color: var(--light-gray);
}

/* Общие стили для секций */
.section {
    display: none;
    margin-left: 20px;
    padding: 30px;
    background-color: var(--medium-gray);
    border-radius: 12px;
    box-shadow: 0 2px 12px rgba(0,0,0,0.2);
    margin-top: 100px;
    margin-right: 20px;
    margin-bottom: 40px;
}

.section.active {
    display: block;
}

/* Секция проектов */
#projects-section {
    /* Стили наследуются от .section */
}

/* Секция сводной информации */
#summary-section {
    /* Стили наследуются от .section */
}

/* Фильтры и кнопки */
.filters-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 8px;
    margin-bottom: 12px;
}

.filters-right {
    display: flex;
    gap: 10px;
    align-items: center;
    margin-left: auto;
}

#add-project-btn {
    margin-right: 16px;
}

/* Таблицы */
table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 1px;
    background-color: var(--light-gray);
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
    border-radius: 8px;
    color: var(--text-light);
}

table th, table td {
    border: 1px solid var(--medium-gray);
    padding: 5px 5px;
    text-align: left;
}

table th {
    background-color: var(--blue-dark);
    color: var(--white);
    font-weight: 500;
}

/* Код: фиксированная ширина под 4 знака */
#projects-table th.code-col,
#projects-table td.code-col {
    min-width: 5%;
    max-width: 5%;
    width: 5%;
    text-align: left;
}

/* Стоимость: фиксированная ширина */
#projects-table th.cost-col,
#projects-table td.cost-col {
    min-width: 10%;
    max-width: 10%;
    width: 10%;
    text-align: left;
}

/* Действия: фиксированная ширина */
#projects-table th.action-col,
#projects-table td.action-col {
    min-width: 8%;
    max-width: 8%;
    width: 8%;
    text-align: left;
}

/* Кнопки в таблице */
.edit-btn, .delete-btn {
    background: none;
    border: none;
    cursor: pointer;
    font-size: 16px;
    margin: 0 2px;
    padding: 4px;
    border-radius: 4px;
    transition: background-color 0.2s ease;
}

.edit-btn:hover {
    background-color: var(--blue-dark);
}

.delete-btn:hover {
    background-color: #d32f2f;
}

/* Стили документов */
.documents-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
}

.documents-controls {
    display: flex;
    gap: 10px;
}

.breadcrumb {
    margin-bottom: 15px;
    padding: 10px;
    background: #f5f5f5;
    border-radius: 4px;
    font-size: 14px;
}

.documents-grid {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.document-item {
    display: flex;
    align-items: center;
    padding: 12px;
    background: white;
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    cursor: pointer;
    transition: background-color 0.2s;
}

.document-item:hover {
    background: #f8f9fa;
}

.folder-item {
    background: #f0f8ff;
    border-color: #add8e6;
}

.document-icon {
    font-size: 24px;
    margin-right: 12px;
}

.document-info {
    flex: 1;
}

.document-name {
    font-weight: 500;
    margin-bottom: 4px;
}

.document-details {
    font-size: 12px;
    color: #666;
}

.document-actions {
    display: flex;
    gap: 5px;
}

.small-btn {
    padding: 4px 8px;
    font-size: 12px;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    background: none;
}

.download-btn:hover {
    background: #e3f2fd;
}

.delete-btn:hover {
    background: #ffebee;
}

.empty-state {
    text-align: center;
    padding: 40px;
    color: #666;
    font-style: italic;
}

.upload-progress {
    margin: 20px 0;
    background: #f0f0f0;
    border-radius: 10px;
    overflow: hidden;
}

.upload-progress-bar {
    height: 20px;
    background: linear-gradient(90deg, #4CAF50, #45a049);
    transition: width 0.3s ease;
    width: 0%;
}

.upload-files-list {
    max-height: 200px;
    overflow-y: auto;
}

.upload-file-item {
    display: flex;
    justify-content: space-between;
    padding: 8px 0;
    border-bottom: 1px solid #eee;
}

/* Стили для модальных окон */
.modal {
    display: none;
    position: fixed;
    z-index: 1000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
}

/* Модальное окно с более высоким приоритетом */
.modal.modal-high-priority {
    z-index: 1100;
}

/* Модальное окно с наивысшим приоритетом */
.modal.modal-highest-priority {
    z-index: 1200;
}

.modal-content {
    background-color: var(--light-gray);
    margin: 5% auto;
    padding: 30px;
    border-radius: 12px;
    width: 80%;
    max-width: 600px;
    position: relative;
    color: var(--text-light);
}

.customer-selection-content {
    max-width: 50vw;
    width: 50%;
}

.customer-selection-content-large {
    max-width: 91vw;
    width: 91%;
}

.manager-modal-content {
    width: 50vw;
    max-width: 50vw;
}

.action-col-fixed {
    width: 150px !important;
    min-width: 150px !important;
    max-width: 150px !important;
}

/* Стили для двухколоночной формы руководителя */
.manager-form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    margin-bottom: 15px;
}

.manager-form-row {
    display: flex;
    gap: 15px;
    margin-bottom: 15px;
}

.manager-form-row .form-group {
    flex: 1;
    display: flex;
    flex-direction: column;
}

.manager-form-full-width {
    grid-column: 1 / -1;
}

#customers-selection-table th.action-col-fixed,
#customers-selection-table td.action-col-fixed,
#managers-selection-table th.action-col-fixed,
#managers-selection-table td.action-col-fixed {
    width: 120px;
    min-width: 120px;
    max-width: 120px;
    white-space: nowrap;
    text-align: center;
}

.close-btn {
    color: var(--text-light);
    float: right;
    font-size: 28px;
    font-weight: bold;
    cursor: pointer;
    position: absolute;
    right: 20px;
    top: 15px;
}

.close-btn:hover {
    color: var(--white);
}

/* Формы */
form {
    display: flex;
    flex-direction: column;
}

.form-row {
    display: flex;
    gap: 15px;
    margin-bottom: 15px;
}

.form-group {
    flex: 1;
    display: flex;
    flex-direction: column;
}

form label {
    margin-bottom: 5px;
    font-weight: 500;
    color: var(--text-light);
    font-size: 14px;
}

form input, form select, form textarea {
    padding: 10px;
    border: 1px solid var(--medium-gray);
    border-radius: 6px;
    background-color: var(--white);
    color: var(--text-dark);
    font-size: 14px;
}

form input:focus, form select:focus, form textarea:focus {
    outline: none;
    border-color: var(--blue);
    box-shadow: 0 0 0 2px rgba(33, 150, 243, 0.2);
}

form button[type="submit"] {
    margin-top: 20px;
    padding: 12px;
    background-color: var(--blue);
    color: var(--white);
    border: none;
    border-radius: 6px;
    cursor: pointer;
    font-size: 16px;
    font-weight: 500;
    transition: background-color 0.2s ease;
}

form button[type="submit"]:hover {
    background-color: var(--blue-dark);
}

/* Выбор заказчика */
.customer-selection {
    display: flex;
    gap: 10px;
    align-items: center;
}

.customer-selection input[readonly] {
    flex: 1;
    background-color: #f5f5f5;
}

.select-customer-btn {
    background-color: var(--blue);
    color: var(--white);
    border: none;
    padding: 10px 15px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 14px;
    white-space: nowrap;
}

.select-customer-btn:hover {
    background-color: var(--blue-dark);
}

/* Адаптивность для формы */
@media (max-width: 600px) {
    .form-row {
        flex-direction: column;
        gap: 0;
    }

    .form-group {
        margin-bottom: 15px;
    }
}

/* Поиск заказчиков */
.customer-search-row {
    display: flex;
    gap: 10px;
    margin-bottom: 20px;
    align-items: center;
}

.customer-search-row input {
    flex: 1;
}

.customers-table-container {
    max-height: 400px;
    overflow-y: auto;
    overflow-x: hidden;
    border: 1px solid var(--medium-gray);
    border-radius: 6px;
}

/* Адаптивность */
@media (max-width: 768px) {
    .section {
        margin-left: 10px;
        margin-right: 10px;
        margin-top: 90px;
        padding: 15px;
    }

    .filters-row {
        flex-direction: column;
        gap: 10px;
        align-items: stretch;
    }

    table {
        font-size: 12px;
    }

    .modal-content {
        width: 95%;
        margin: 10% auto;
        padding: 20px;
    }

    #menu-btn {
        top: 15px;
        left: 15px;
        padding: 8px 12px;
        font-size: 14px;
    }

    .header {
        padding: 10px 15px;
        padding-left: 70px;
    }
}idth: 5%;
    text-align: left;
    white-space: nowrap;
    letter-spacing: 1px;
}

/* Стоимость: одна строка, без переносов, без сокращений */
#projects-table th.cost-col,
#projects-table td.cost-col {
    white-space: nowrap;
    text-align: left;
    font-variant-numeric: tabular-nums;
}

/* Действие: минимальная ширина под 2 иконки, одна строка */
#projects-table th.action-col,
#projects-table td.action-col {
    min-width: 10%;
    max-width: 10%;
    width: 10%;
    text-align: center;
    white-space: nowrap;
    padding-left: 0;
    padding-right: 0;
}

.edit-project-btn, .delete-project-btn {
    width: 30px;
    height: 30px;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin: 0 2px;
}

/* Для всех ячеек: запрет переноса для стоимости и действия */
#projects-table td.cost-col,
#projects-table td.action-col {
    white-space: nowrap;
}

/* Кнопки */
button, .edit-btn, .delete-btn {
    background-color: var(--blue-medium);
    color: var(--white);
    border: none;
    padding: 8px 16px;
    cursor: pointer;
    border-radius: 6px;
    font-size: 14px;
    transition: background-color 0.2s ease, transform 0.2s ease;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
    margin: 4px;
}

button:hover, .edit-btn:hover, .delete-btn:hover {
    background-color: var(--blue-dark);
    transform: translateY(-2px);
}

button:active, .edit-btn:active, .delete-btn:active {
    transform: translateY(0);
}

/* Модальные окна */
.modal {
    display: none;
    position: fixed;
    z-index: 2000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: auto;
    background-color: rgba(0,0,0,0.5);
    backdrop-filter: blur(4px);
}

.modal-content {
    background-color: var(--medium-gray);
    margin: 15vh auto;
    padding: 24px;
    border-radius: 12px;
    width: auto;
    box-shadow: 0 4px 20px rgba(0,0,0,0.3);
    position: relative;
    color: var(--text-light);
}

.project-modal-content {
    width: 480px;
    max-width: 90vw;
}

/* Специальные стили для модального окна выбора заказчика */
.customer-selection-content {
    width: 1050px;
    max-width: 95vw;
}

.customer-selection-content-large {
    width: 1200px;
    max-width: 80vw;
}

.modal-content h3 {
    color: var(--white);
    font-weight: 500;
    font-size: 18px;
    margin-top: 0;
    margin-bottom: 18px;
}

.modal-content form label {
    display: block;
    margin-bottom: 8px;
    font-weight: 400;
    color: var(--text-light);
    font-size: 14px;
}

.modal-content input[type="text"],
.modal-content input[type="number"],
.modal-content input[type="date"],
.modal-content select {
    width: 100%;
    padding: 8px;
    margin-bottom: 1px;
    border: 1px solid var(--light-gray);
    border-radius: 6px;
    font-size: 14px;
    transition: border-color 0.2s ease;
    box-sizing: border-box;
    background-color: var(--light-gray);
    color: var(--text-light);
}

.modal-content input[type="text"]:focus,
.modal-content input[type="number"]:focus,
.modal-content input[type="date"]:focus,
.modal-content select:focus {
    border-color: var(--blue-medium);
    outline: none;
}

.modal-content button[type="submit"] {
    background-color: var(--blue-medium);
    color: var(--white);
    border: none;
    padding: 8px 16px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 14px;
    transition: background-color 0.2s ease, transform 0.2s ease;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
    margin-top: 6px;
    width: 100%;
}

.modal-content button[type="submit"]:hover {
    background-color: var(--blue-dark);
    transform: translateY(-2px);
}

.modal-content button[type="submit"]:active {
    transform: translateY(0);
}

.close-btn {
    color: #90a4ae;
    float: right;
    font-size: 24px;
    font-weight: bold;
    cursor: pointer;
    transition: color 0.2s ease;
    position: absolute;
    right: 18px;
    top: 16px;
    line-height: 1;
}

.close-btn:hover,
.close-btn:focus {
    color: var(--white);
}

/* Стили для выбора заказчика */
.customer-selection {
    display: flex;
    gap: 8px;
    align-items: flex-end;
    margin-bottom: 12px;
}

.customer-selection input[type="text"] {
    flex: 1;
    margin-bottom: 0;
}

.select-customer-btn {
    background-color: var(--blue-medium);
    color: var(--white);
    border: none;
    padding: 8px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 16px;
    white-space: nowrap;
    margin: 0;
    height: 36px;
    width: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.select-customer-btn:hover {
    background-color: var(--blue-dark);
}

/* Стили для модального окна выбора заказчика */
.customer-search-row {
    display: flex;
    gap: 12px;
    margin-bottom: 20px;
    align-items: center;
}

.customer-search-row input {
    flex: 1;
    margin-bottom: 0;
}

.customer-search-row button {
    margin: 0;
    white-space: nowrap;
}

.customers-table-container {
    max-height: 400px;
    overflow-y: auto;
    border: 1px solid var(--light-gray);
    border-radius: 6px;
}

#customers-selection-table {
    margin-top: 0;
    border-radius: 0;
}

#customers-selection-table th,
#customers-selection-table td {
    padding: 8px 12px;
}

/* Кнопки действий в таблице заказчиков */
.customer-action-btn {
    width: 28px;
    height: 28px;
    padding: 0;
    margin: 0 2px;
    font-size: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.select-customer-row-btn {
    background-color: #4caf50;
    font-size: 14px;
    padding: 4px 8px;
    margin-right: 4px;
    width: 30px;
    height: 30px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.select-customer-row-btn:hover {
    background-color: #45a049;
}

/* Навигация */
.nav-link {
    cursor: pointer;
    transition: background-color 0.2s ease;
}

.nav-link.active {
    background-color: var(--blue-dark);
    color: var(--white);
}

/* Выпадающее меню в навигации */
.nav-item-with-submenu {
    position: relative;
}

.nav-dropdown-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    position: relative;
}

.nav-arrow {
    font-size: 10px;
    transition: transform 0.2s ease;
    margin-left: auto;
}

.nav-item-with-submenu.active .nav-arrow {
    transform: rotate(180deg);
}

.nav-submenu {
    display: none;
    list-style: none;
    padding: 0;
    margin: 0;
    background-color: var(--dark-gray);
    border-left: 3px solid var(--blue-medium);
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
}

.nav-item-with-submenu.active .nav-submenu {
    display: block;
    max-height: 200px;
}

.nav-sublink {
    padding: 10px 15px 10px 25px;
    font-size: 14px;
    border-left: none;
}

.nav-sublink:hover {
    background-color: var(--medium-gray);
}

.nav-sublink.active {
    background-color: var(--blue-medium);
}

/* Заголовки */
h2, h3 {
    color: var(--white);
    font-weight: 500;
    margin-top: 0;
}

/* Элементы управления */
select, input, button {
    font-family: 'Roboto', sans-serif;
}

/* Обновлённые стили для сортировки и фильтрации */
.sortable-header {
    position: relative;
    cursor: pointer;
    user-select: none;
}

.sortable-header:hover {
    background-color: #455a64;
}

.sort-options {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    background-color: var(--white);
    border: 1px solid #e0e0e0;
    border-radius: 6px;
    padding: 10px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
    z-index: 1000;
    width: 200px;
    max-width: calc(100vw - 40px);
    color: var(--text-dark);
}

.sortable-header:hover .sort-options {
    display: block;
}

.sort-option {
    padding: 6px 10px;
    border-radius: 4px;
    margin-bottom: 4px;
    transition: background-color 0.2s ease;
}

.sort-option:hover {
    background-color: #1565c0;
}

.filter-options {
    margin-top: 10px;
    border-top: 1px solid #455a64;
    padding-top: 10px;
}

.filter-options label {
    display: block;
    margin-bottom: 6px;
    font-size: 14px;
}

.filter-options input {
    margin-right: 8px;
}

/* Стили для поиска */
.search-export {
    display: flex;
    gap: 10px;
    align-items: center;
}

#search-projects,
#customer-search {
    padding: 8px 12px;
    border-radius: 6px;
    border: 1px solid #455a64;
    background-color: #455a64;
    color: #eceff1;
    font-size: 14px;
    width: 300px;
}

#search-projects:focus,
#customer-search:focus {
    outline: none;
    border-color: #1976d2;
}

/* Фиксированная ширина столбца "Действия" */
#projects-table th:last-child,
#projects-table td:last-child {
    width: 120px;
    min-width: 120px;
    text-align: center;
}

/* Стили для кнопок действий */
.edit-btn, .delete-btn {
    width: 30px;
    height: 30px;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin: 0 2px;
}

/* Форматирование валюты */
.currency-input {
    position: relative;
    display: flex;
    align-items: center;
    background-color: var(--light-gray);
    border: 1px solid #455a64;
    border-radius: 6px;
    overflow: hidden;
}

.currency-input input {
    flex: 1;
    padding: 8px 12px;
    border: none;
    background: transparent;
    color: var(--text-color);
    font-size: 14px;
    text-align: right;
}

.currency-input input:focus {
    outline: none;
}

.currency-input:focus-within {
    border-color: var(--blue-medium);
    box-shadow: 0 0 0 2px rgba(33, 150, 243, 0.2);
}

.currency-symbol {
    padding: 8px 12px;
    background-color: var(--blue-dark);
    color: var(--white);
    font-weight: 500;
    font-size: 14px;
    border-left: 1px solid #455a64;
}

/* Индикатор загрузки таблицы */
#loading-indicator {
    display: none;
    text-align: center;
    padding: 20px;
}
/* Карта и диаграммы */
.summary-grid {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 20px;
    margin-bottom: 30px;
}

.map-container {
    background-color: var(--light-gray);
    padding: 20px;
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
    position: relative;
    min-height: 400px;
}

#map {
    width: 100%;
    height: 400px;
    border-radius: 4px;
    overflow: hidden;
}

.map-info, .map-error {
    position: absolute;
    top: 30px;
    left: 30px;
    background: rgba(255, 255, 255, 0.9);
    padding: 10px;
    border-radius: 5px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.2);
    font-size: 14px;
    z-index: 1000;
    max-width: 300px;
}

.map-error {
    background: rgba(244, 67, 54, 0.9);
    color: white;
}

.tasks-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    margin-top: 20px;
}

.overdue-tasks-container, .upcoming-tasks-container {
    background-color: var(--light-gray);
    padding: 20px;
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}

.overdue-tasks-container h3, .upcoming-tasks-container h3 {
    margin-top: 0;
    margin-bottom: 15px;
    color: var(--white);
    text-align: center;
    border-bottom: 1px solid var(--medium-gray);
    padding-bottom: 10px;
}

.overdue-task-item {
    background-color: var(--light-gray);
    border-left: 4px solid #f44336;
    padding: 12px;
    border-radius: 4px;
    margin-bottom: 4px;
    transition: background-color 0.2s ease;
}

.overdue-task-item:hover {
    background-color: #4a4a4a;
    transform: translateY(-1px);
}

.overdue-task-title {
    font-weight: bold;
    color: var(--white);
    margin-bottom: 6px;
}

.overdue-task-project {
    color: #90a4ae;
    font-size: 13px;
    margin-bottom: 4px;
}

.overdue-task-due {
    color: #f44336;
    font-size: 12px;
    font-weight: bold;
    margin-bottom: 4px;
}

.overdue-task-assignee {
    color: #81c784;
    font-size: 12px; 10px;
}

.overdue-tasks-list, .upcoming-tasks-list {
    max-height: 340px;
    overflow-y: auto;
    overflow-x: hidden;
    word-wrap: break-word;
}

.overdue-task-item, .upcoming-task-item {
    background-color: var(--medium-gray);
    border-radius: 8px;
    padding: 15px;
    margin-bottom: 12px;
    transition: all 0.2s ease;
    position: relative;
    word-wrap: break-word;
    overflow-wrap: break-word;
    min-width: 0;
    box-sizing: border-box;
}

.overdue-task-item {
    border-left: 4px solid #f44336;
}```text
.upcoming-task-item {
    border-left: 4px solid #ff9800;
}

.upcoming-task-item:hover {
    background-color: #4a4a4a;
    transform: translateY(-1px);
}

.overdue-task-item:hover {
    transform: translateX(3px);
    box-shadow: 0 4px 12px rgba(244, 67, 54, 0.2);
    border-left-width: 6px;
}

.upcoming-task-item:hover {
    transform: translateX(3px);
    box-shadow: 0 4px 12px rgba(255, 152, 0, 0.2);
    border-left-width: 6px;
}

.overdue-task-header, .upcoming-task-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 8px;
}

.overdue-task-title, .upcoming-task-title {
    font-weight: 600;
    color: var(--white);
    font-size: 14px;
    line-height: 1.3;
    flex: 1;
    margin-right: 10px;
    word-wrap: break-word;
    overflow-wrap: break-word;
    min-width: 0;
    max-width: calc(100% - 60px);
}

.overdue-task-days {
    background-color: #f44336;
    color: white;
    padding: 2px 8px;
    border-radius: 12px;
    font-size: 11px;
    font-weight: bold;
}

.upcoming-task-days {
    background-color: #ff9800;
    color: white;
    padding: 2px 8px;
    border-radius: 12px;
    font-size: 11px;
    font-weight: bold;
    white-space: nowrap;
}

.overdue-task-project, .upcoming-task-project {
    font-size: 12px;
    color: #90caf9;
    margin-bottom: 5px;
    display: flex;
    align-items: center;
    gap: 5px;
}

.overdue-task-assignee, .upcoming-task-assignee {
    font-size: 12px;
    color: #81c784;
    margin-bottom: 5px;
    display: flex;
    align-items: center;
    gap: 5px;
}

.overdue-task-due-date, .upcoming-task-due-date {
    font-size: 11px;
    color: var(--text-light);
    display: flex;
    align-items: center;
    gap: 5px;
}

.overdue-tasks-header, .upcoming-tasks-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 15px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--medium-gray);
}

.overdue-count {
    font-weight: 600;
    color: #f44336;
    font-size: 14px;
}

.upcoming-count {
    font-weight: 600;
    color: #ff9800;
    font-size: 14px;
}

.overdue-pagination, .upcoming-pagination {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 15px;
    padding-top: 15px;
    border-top: 1px solid var(--medium-gray);
}

.pagination-info {
    font-size: 12px;
    color: var(--text-light);
}

.pagination-controls {
    display: flex;
    align-items: center;
    gap: 10px;
}

.pagination-controls button {
    background-color: var(--blue-medium);
    color: white;
    border: none;
    padding: 6px 10px;
    border-radius: 4px;
    cursor: pointer;
    font-size: 14px;
    font-weight: bold;
    transition: background-color 0.2s ease;
}

.pagination-controls button:hover:not(:disabled) {
    background-color: var(--blue-dark);
}

.pagination-controls button:disabled {
    background-color: var(--medium-gray);
    cursor: not-allowed;
    opacity: 0.5;
}

.pagination-controls span {
    font-size: 12px;
    color: var(--text-light);
    font-weight: 500;
}

.overdue-tasks-content, .upcoming-tasks-content {
    max-height: 280px;
    overflow-y: auto;
    overflow-x: hidden;
    margin-bottom: 10px;
}

.overdue-tasks-content::-webkit-scrollbar,
.upcoming-tasks-content::-webkit-scrollbar {
    width: 6px;
}

.overdue-tasks-content::-webkit-scrollbar-track,
.upcoming-tasks-content::-webkit-scrollbar-track {
    background: var(--medium-gray);
    border-radius: 3px;
}

.overdue-tasks-content::-webkit-scrollbar-thumb,
.upcoming-tasks-content::-webkit-scrollbar-thumb {
    background: var(--blue-medium);
    border-radius: 3px;
}

.overdue-tasks-content::-webkit-scrollbar-thumb:hover,
.upcoming-tasks-content::-webkit-scrollbar-thumb:hover {
    background: var(--blue-dark);
}

@media (max-width: 768px) {
    .summary-grid {
        grid-template-columns: 1fr;
        gap: 15px;
    }
}

/* Стили для вкладки Бюджет */
.budget-overview {
    background-color: var(--light-gray);
    padding: 20px;
    border-radius: 8px;
    margin-bottom: 30px;
}

.budget-overview-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 20px;
}

.budget-item {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 15px;
    background-color: var(--medium-gray);
    border-radius: 6px;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
    border: 1px solid var(--light-gray);
}

.budget-item label {
    font-weight: 500;
    color: var(--text-light);
    font-size: 14px;
}

.budget-item span {
    font-weight: 600;
    color: var(--white);
    font-variant-numeric: tabular-nums;
    font-size: 18px;
    text-align: right;
}

.budget-sections {
    display: flex;
    flex-direction: column;
    gap: 30px;
}

.budget-section {
    background-color: var(--light-gray);
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
    overflow: hidden;
}

.budget-section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px;
    background-color: var(--medium-gray);
    border-bottom: 1px solid var(--light-gray);
}

.budget-section-header h4 {
    margin: 0;
    color: var(--white);
}

.budget-table-container {
    overflow-x: auto;
    background-color: var(--light-gray);
}

.budget-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 14px;
    background-color: var(--light-gray);
}

.budget-table th,
.budget-table td {
    padding: 12px;
    text-align: left;
    border-bottom: 1px solid var(--medium-gray);
}

.budget-table th {
    background-color: var(--blue-dark);
    font-weight: 600;
    color: var(--white);
}

.budget-table td {
    color: var(--text-light);
    background-color: var(--light-gray);
}

.budget-table tbody tr:hover {
    background-color: var(--medium-gray);
}

.budget-table tbody tr:hover td {
    background-color: var(--medium-gray);
}

.payment-status {
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 12px;
    font-weight: 500;
    text-align: center;
    display: inline-block;
    min-width: 80px;
    color: var(--white);
}

.payment-status.pending {
    background-color: #ff9800;
    color: var(--white);
}

.payment-status.partial {
    background-color: #2196f3;
    color: var(--white);
}

.payment-status.paid {
    background-color: #4caf50;
    color: var(--white);
}

.payment-status.overdue {
    background-color: #f44336;
    color: var(--white);
}

/* Стили для итоговой строки бюджета */
.budget-summary-row {
    background-color: var(--medium-gray) !important;
    font-size: 14px;
}

.budget-summary-row.budget-summary-complete {
    background-color: rgba(76, 175, 80, 0.2) !important;
    color: #4caf50 !important;
}

.budget-summary-row.budget-summary-pending {
    background-color: rgba(255, 152, 0, 0.2) !important;
    color: #ff9800 !important;
}

.budget-summary-row.budget-summary-excess {
    background-color: rgba(244, 67, 54, 0.2) !important;
    color: #f44336 !important;
}

.budget-summary-row td {
    background-color: transparent !important;
}

@media (max-width: 768px) {
    .budget-overview-grid {
        grid-template-columns: 1fr;
        gap: 15px;
    }

    .budget-section-header {
        flex-direction: column;
        gap: 15px;
        align-items: stretch;
    }

    .budget-table-container {
        overflow-x: scroll;
    }

    .budget-table {
        min-width: 600px;
    }
}

.charts-container {
    background-color: var(--light-gray);
    padding: 20px;
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
    height: 400px;
    display: flex;
    flex-direction: column;
}

.charts-container h3 {
    margin-top: 0;
    margin-bottom: 20px;
    text-align: center;
    flex-shrink: 0;
}

#projects-chart {
    display: block;
    margin: 0 auto;
    max-width: 100%;
    max-height: 300px;
    width: 100% !important;
    height: 300px !important;
}

.no-data-message {
    color: #90a4ae;
    font-style: italic;
    text-align: center;
    padding: 20px;
    margin: 0;
}

/* Стили для денежных полей */
.currency-field {
    position: relative;
}

.currency-field input {
    text-align: right;
    font-variant-numeric: tabular-nums;
}

/* Индикатор загрузки в модальных окнах */
.modal-loading-overlay {
    display: none;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(255, 255, 255, 0.7);
    z-index: 10;
    justify-content: center;
    align-items: center;
}

/* Стили для страницы детального просмотра проекта */
.project-detail-header {
    display: flex;
    align-items: center;
    gap: 20px;
    margin-bottom: 20px;
}

/* Стили для вкладки Бюджет */
.budget-section {
    padding: 20px 0;
}

.budget-summary {
    background-color: var(--light-gray);
    padding: 20px;
    border-radius: 8px;
    margin-bottom: 30px;
}

.budget-overview {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 15px;
    margin-top: 15px;
}

.budget-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 15px;
    background-color: var(--medium-gray);
    border-radius: 6px;
    border: 1px solid var(--light-gray);
}

.budget-item label {
    font-weight: 500;
    color: var(--text-light);
}

.cost-value {
    font-weight: 600;
    font-size: 16px;
    color: var(--white);
    font-variant-numeric: tabular-nums;
}

.cost-value.billed {
    color: #81c784;
}

.cost-value.remaining {
    color: #ffb74d;
}

.budget-breakdown {
    margin-bottom: 30px;
}

.yearly-budget-table,
.billing-table {
    margin-top: 15px;
    overflow-x: auto;
}

.yearly-budget-table table,
.billing-table table {
    width: 100%;
    min-width: 800px;
}

.yearly-budget-table th,
.yearly-budget-table td,
.billing-table th,
.billing-table td {
    text-align: left;
    padding: 12px 8px;
    white-space: nowrap;
}

/* Стили для документов */
.documents-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
}

.documents-controls {
    display: flex;
    gap: 10px;
}

.documents-breadcrumb {
    background-color: var(--medium-gray);
    padding: 10px 15px;
    border-radius: 6px;
    margin-bottom: 15px;
    font-size: 14px;
    color: var(--text-light);
}

.documents-container {
    background-color: var(--light-gray);
    border-radius: 8px;
    padding: 20px;
    min-height: 300px;
}

.documents-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 15px;
}

.document-item, .folder-item {
    background-color: var(--medium-gray);
    border-radius: 8px;
    padding: 15px;
    text-align: center;
    transition: all 0.2s ease;
    cursor: pointer;
    position: relative;
}

.document-item:hover, .folder-item:hover {
    background-color: var(--blue-medium);
    transform: translateY(-2px);
}

.folder-item {
    border: 2px dashed var(--blue-medium);
}

.document-icon, .folder-icon {
    font-size: 48px;
    margin-bottom: 10px;
    display: block;
}

.folder-icon {
    color: var(--blue-medium);
}

.document-name, .folder-name {
    font-weight: 500;
    margin-bottom: 5px;
    word-break: break-word;
}

.document-size {
    font-size: 12px;
    color: var(--text-light);
    margin-bottom: 10px;
}

.document-actions, .folder-actions {
    position: absolute;
    top: 5px;
    right: 5px;
    display: flex;
    gap: 5px;
    opacity: 0;
    transition: opacity 0.2s ease;
}

.document-item:hover .document-actions,
.folder-item:hover .folder-actions {
    opacity: 1;
}

.upload-progress {
    background-color: var(--medium-gray);
    border-radius: 8px;
    padding: 15px;
    margin-bottom: 15px;
    display: none;
}

.upload-progress-bar {
    width: 100%;
    height: 20px;
    background-color: var(--dark-gray);
    border-radius: 10px;
    overflow: hidden;
    margin-top: 10px;
}

.upload-progress-fill {
    height: 100%;
    background-color: var(--blue-medium);
    width: 0%;
    transition: width 0.3s ease;
}

.upload-file-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 8px 0;
    border-bottom: 1px solid var(--medium-gray);
}

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

@media (max-width: 768px) {
    .documents-header {
        flex-direction: column;
        gap: 15px;
        align-items: stretch;
    }

    .documents-controls {
        justify-content: center;
    }

    .documents-list {
        grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
        gap: 10px;
    }
}

.yearly-budget-table th:nth-child(2),
.yearly-budget-table th:nth-child(3),
.yearly-budget-table th:nth-child(4),
.yearly-budget-table th:nth-child(5),
.yearly-budget-table th:nth-child(6),
.yearly-budget-table td:nth-child(2),
.yearly-budget-table td:nth-child(3),
.yearly-budget-table td:nth-child(4),
.yearly-budget-table td:nth-child(5),
.yearly-budget-table td:nth-child(6) {
    text-align: right;
    font-variant-numeric: tabular-nums;
}

.billing-table th:nth-child(3),
.billing-table th:nth-child(4),
.billing-table th:nth-child(5),
.billing-table td:nth-child(3),
.billing-table td:nth-child(4),
.billing-table td:nth-child(5) {
    text-align: right;
    font-variant-numeric: tabular-nums;
}

.payment-status {
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 12px;
    font-weight: 500;
    text-align: center;
}

.payment-status.pending {
    background-color: #fff3cd;
    color: #856404;
}

.payment-status.paid {
    background-color: #d4edda;
    color: #155724;
}

.payment-status.partial {
    background-color: #cce7ff;
    color: #004085;
}

.payment-status.overdue {
    background-color: #f8d7da;
    color: #721c24;
}

.billing-history {
    margin-top: 30px;
}

@media (max-width: 768px) {
    .budget-overview {
        grid-template-columns: 1fr;
    }

    .yearly-budget-table,
    .billing-table {
        font-size: 14px;
    }
}

.back-btn {
    background-color: var(--medium-gray);
    color: var(--text-light);
    border: 1px solid var(--light-gray);
    padding: 8px 16px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 14px;
    transition: all 0.2s ease;
}

.back-btn:hover {
    background-color: var(--light-gray);
    transform: translateX(-2px);
}

.project-tabs {
    display: flex;
    gap: 2px;
    margin-bottom: 20px;
    border-bottom: 2px solid var(--light-gray);
}

.tab-btn {
    background-color: transparent;
    color: var(--text-light);
    border: none;
    padding: 12px 24px;
    cursor: pointer;
    font-size: 14px;
    border-radius: 6px 6px 0 0;
    transition: all 0.2s ease;
}

.tab-btn:hover {
    background-color: var(--light-gray);
}

.tab-btn.active {
    background-color: var(--blue-medium);
    color: var(--white);
}

.tab-content {
    display: none;
}

.tab-content.active {
    display: block;
}

.project-info-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 30px;
    margin-bottom: 30px;
}

.project-main-info,
.project-additional-info {
    background-color: var(--light-gray);
    padding: 20px;
    border-radius: 8px;
}

.project-main-info h3,
.project-additional-info h3 {
    margin-top: 0;
    margin-bottom: 20px;
    color: var(--white);
    border-bottom: 1px solid var(--medium-gray);
    padding-bottom: 10px;
}

.info-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 8px 0;
    border-bottom: 1px solid var(--medium-gray);
}

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

.info-item label {
    font-weight: 500;
    color: var(--text-light);
    margin-right: 10px;
}

.info-item span {
    color: var(--white);
    text-align: right;
}

.contractors-section {
    margin-top: 20px;
}

.section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 15px;
}

.section-header h4 {
    margin: 0;
    color: var(--white);
}

.small-btn {
    background-color: var(--blue-medium);
    color: var(--white);
    border: none;
    padding: 6px 12px;
    border-radius: 4px;
    cursor: pointer;
    font-size: 12px;
    transition: background-color 0.2s ease;
}

.small-btn:hover {
    background-color: var(--blue-dark);
}

.contractors-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.contractor-item {
    background-color: var(--medium-gray);
    padding: 12px;
    border-radius: 6px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.contractor-info h5 {
    margin: 0 0 5px 0;
    color: var(--white);
}

.contractor-info p {
    margin: 0;
    font-size: 12px;
    color: var(--text-light);
}

.contractor-actions {
    display: flex;
    gap: 5px;
}

.project-location {
    background-color: var(--light-gray);
    padding: 20px;
    border-radius: 8px;
}

.project-location h3 {
    margin-top: 0;
    margin-bottom: 15px;
    color: var(--white);
}

/* Стили для вкладки документов */
.documents-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
```text
    margin-bottom: 20px;
}

.documents-controls {
    display: flex;
    gap: 10px;
}

.documents-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 15px;
}

.document-item {
    background-color: var(--light-gray);
    padding: 15px;
    border-radius: 8px;
    text-align: center;
    border: 2px solid transparent;
    transition: all 0.2s ease;
}

.document-item:hover {
    border-color: var(--blue-medium);
    transform: translateY(-2px);
}

.document-icon {
    font-size: 32px;
    margin-bottom: 10px;
    display: block;
}

.document-name {
    font-weight: 500;
    color: var(--white);
    margin-bottom: 5px;
    word-break: break-word;
}

.document-size {
    font-size: 12px;
    color: var(--text-light);
    margin-bottom: 10px;
}

.document-actions {
    display: flex;
    gap: 5px;
    justify-content: center;
}

.document-actions button {
    padding: 4px 8px;
    font-size: 12px;
}

/* Стили для вкладки задач */
.tasks-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
}

.tasks-controls {
    display: flex;
    gap: 15px;
    align-items: center;
}

.task-filters {
    display: flex;
    gap: 10px;
}

.task-filters select {
    padding: 6px 12px;
    border-radius: 4px;
    border: 1px solid var(--light-gray);
    background-color: var(--light-gray);
    color: var(--text-light);
    font-size: 14px;
}

.tasks-board {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    min-height: 500px;
}

.task-column {
    background-color: var(--light-gray);
    border-radius: 8px;
    padding: 15px;
}

.task-column h4 {
    margin: 0 0 15px 0;
    color: var(--white);
    text-align: center;
    padding-bottom: 10px;
    border-bottom: 2px solid var(--medium-gray);
}

.task-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
    min-height: 400px;
    transition: background-color 0.2s ease;
}

/* Стили для drag and drop */
.task-list.drag-over {
    background-color: rgba(25, 118, 210, 0.1);
    border: 2px dashed var(--blue-medium);
    border-radius: 8px;
}

/* Стили для страницы всех задач */
#all-tasks-table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 20px;
    background-color: var(--light-gray);
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
    border-radius: 8px;
    color: var(--text-light);
}

#all-tasks-table th,
#all-tasks-table td {
    border: 1px solid var(--medium-gray);
    padding: 12px;
    text-align: left;
}

#all-tasks-table th {
    background-color: var(--blue-dark);
    color: var(--white);
    font-weight: 500;
}

#all-tasks-table td {
    background-color: var(--light-gray);
    color: var(--text-light);
}

.task-row {
    transition: background-color 0.2s ease;
    cursor: pointer;
}

.task-row:hover {
    background-color: var(--medium-gray);
}

.task-row:hover td {
    background-color: var(--medium-gray);
}

.task-row.overdue {
    background-color: rgba(244, 67, 54, 0.1);
}

.task-row.overdue td {
    background-color: rgba(244, 67, 54, 0.1);
}

.task-title-cell {
    max-width: 250px;
    position: relative;
}

.task-title {
    font-weight: 600;
    color: var(--white);
    margin-bottom: 4px;
}

.task-description {
    font-size: 12px;
    color: var(--text-light);
    line-height: 1.3;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

.project-cell {
    max-width: 200px;
    position: relative;
}

.project-link {
    color: var(--blue-medium);
    cursor: pointer;
    text-decoration: underline;
    font-weight: 500;
}

.project-link:hover {
    color: var(--blue-dark);
}

.status-badge, .priority-badge {
    display: inline-block;
    padding: 4px 12px;
    border-radius: 16px;
    font-size: 11px;
    font-weight: 600;
    text-align: center;
    color: white;
    min-width: 60px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    line-height: 1.2;
}

/* Статусы задач */
.status-new {
    background-color: #607d8b;
}

.status-inprogress {
    background-color: #2196f3;
}

.status-review {
    background-color: #ff9800;
}

.status-completed {
    background-color: #4caf50;
}

/* Приоритеты задач */
.priority-badge.low {
    background-color: #4caf50;
}

.priority-badge.medium {
    background-color: #ff9800;
}

.priority-badge.high {
    background-color: #f44336;
}

.priority-badge.critical {
    background-color: #9c27b0;
}

.progress-container {
    display: flex;
    align-items: center;
    gap: 8px;
}

.progress-container .progress-bar {
    flex: 1;
    height: 6px;
    background-color: var(--dark-gray);
    border-radius: 3px;
    overflow: hidden;
}

.progress-container .progress-fill {
    height: 100%;
    background-color: var(--blue-medium);
    transition: width 0.3s ease;
}

.progress-text {
    font-size: 12px;
    color: var(--white);
    min-width: 35px;
}

.overdue-date {
    color: #d32f2f;
    font-weight: bold;
    background-color: rgba(244, 67, 54, 0.1);
    padding: 2px 6px;
    border-radius: 4px;
}

/* Улучшение контрастности для фильтров */
.task-filters select {
    background-color: var(--white);
    color: var(--text-dark);
    border: 1px solid #ccc;
}

/* Улучшение видимости поиска */
#search-projects,
#customer-search {
    background-color: var(--white);
    color: var(--text-dark);
    border: 1px solid #ccc;
}

.view-btn {
    background-color: var(--blue-medium);
}

.task-item.dragging {
    transform: rotate(5deg);
    box-shadow: 0 8px 20px rgba(0,0,0,0.3);
    z-index: 1000;
}

.task-item {
    background-color: var(--medium-gray);
    border-radius: 6px;
    padding: 12px;
    border-left: 4px solid transparent;
    transition: all 0.2s ease;
    cursor: pointer;
}

.task-item:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 8px rgba(0,0,0,0.2);
}

.task-item.priority-low {
    border-left-color: #4caf50;
}

.task-item.priority-medium {
    border-left-color: #ff9800;
}

.task-item.priority-high {
    border-left-color: #f44336;
}

.task-item.priority-critical {
    border-left-color: #9c27b0;
}

.task-title {
    font-weight: 500;
    color: var(--white);
    margin-bottom: 8px;
    font-size: 14px;
}

.task-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
}

.task-priority {
    font-size: 12px;
    padding: 2px 6px;
    border-radius: 10px;
    color: var(--white);
}

.task-priority.low {
    background-color: #4caf50;
}

.task-priority.medium {
    background-color: #ff9800;
}

.task-priority.high {
    background-color: #f44336;
}

.task-priority.critical {
    background-color: #9c27b0;
}

.task-assignee {
    font-size: 12px;
    color: var(--text-light);
}

.task-progress {
    margin-bottom: 8px;
}

.progress-bar {
    width: 100%;
    height: 6px;
    background-color: var(--dark-gray);
    border-radius: 3px;
    overflow: hidden;
}

.progress-fill {
    height: 100%;
    background-color: var(--blue-medium);
}

.task-dates {
    font-size: 11px;
    color: var(--text-light);
    display: flex;
    justify-content: space-between;
}

.task-actions {
    display: flex;
    gap: 5px;
    margin-top: 8px;
}

.task-actions button {
    padding: 4px 8px;
    font-size: 11px;
    border-radius: 4px;
}

/* Стили для модального окна задачи */
.task-modal-content {
    width: 600px;
    max-width: 90vw;
}

.task-modal-content textarea {
    resize: vertical;
    min-height: 80px;
}

.completion-input {
    display: flex;
    align-items: center;
    gap: 10px;
}

.completion-input input[type="range"] {
    flex: 1;
}

#completion-display {
    font-weight: 500;
    color: var(--white);
    min-width: 35px;
}

.manager-selection {
    display: flex;
    gap: 8px;
    align-items: center;
}

.manager-selection input {
    flex: 1;
}

.select-manager-btn {
    background-color: var(--blue-medium);
    color: var(--white);
    border: none;
    padding: 8px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 16px;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.select-manager-btn:hover {
    background-color: var(--blue-dark);
}

/* Пагинация */
.pagination-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 20px 0;
    padding: 15px;
    background-color: var(--medium-gray);
    border-radius: 8px;
    border: 1px solid var(--light-gray);
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
    min-height: 60px;
}

.pagination-info {
    display: flex;
    flex-direction: column;
    gap: 10px;
    color: var(--text-light);
    font-size: 14px;
}

.pagination-stats {
    color: var(--text-light);
    font-size: 14px;
}

.page-size-selector {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
}

.page-size-selector label {
    color: var(--text-light);
    white-space: nowrap;
}

.page-size-selector select {
    background-color: var(--light-gray);
    color: var(--white);
    border: 1px solid var(--medium-gray);
    border-radius: 4px;
    padding: 4px 8px;
    font-size: 13px;
    min-width: 60px;
}

.pagination-controls {
    display: flex;
    gap: 5px;
    align-items: center;
}

.pagination-controls button {
    background-color: var(--light-gray);
    color: var(--white);
    border: 1px solid var(--medium-gray);
    padding: 8px 12px;
    border-radius: 4px;
    cursor: pointer;
    font-size: 14px;
    min-width: 36px;
    transition: all 0.2s ease;
    font-weight: 500;
}

.pagination-controls button:hover:not(:disabled) {
    background-color: var(--blue-medium);
    border-color: var(--blue-medium);
    transform: translateY(-1px);
}

.pagination-controls button.active {
    background-color: var(--blue-medium);
    border-color: var(--blue-medium);
    font-weight: 600;
    box-shadow: 0 2px 4px rgba(0,0,0,0.2);
}

.pagination-controls button:disabled {
    background-color: var(--dark-gray);
    color: #666;
    border-color: var(--dark-gray);
    cursor: not-allowed;
    opacity: 0.6;
}

.pagination-dots {
    color: var(--text-light);
    padding: 0 8px;
    font-size: 14px;
}

/* Адаптивность для пагинации */
@media (max-width: 768px) {
    .pagination-container {
        flex-direction: column;
        gap: 15px;
        text-align: center;
    }

    .pagination-info {
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
        gap: 15px;
    }

    .pagination-stats {
        font-size: 12px;
    }

    .page-size-selector {
        flex-direction: column;
        gap: 5px;
        font-size: 12px;
    }

    .page-size-selector label {
        font-size: 11px;
    }

    .page-size-selector select {
        font-size: 12px;
        padding: 3px 6px;
    }

    .pagination-controls {
        justify-content: center;
        flex-wrap: wrap;
    }

    .pagination-controls button {
        padding: 6px 10px;
        font-size: 12px;
        min-width: 32px;
    }
}

/* Адаптивность для задач */
@media (max-width: 768px) {
    .tasks-board {
        grid-template-columns: 1fr;
        gap: 15px;
    }

    .tasks-header {
        flex-direction: column;
        gap: 15px;
        align-items: stretch;
    }

    .tasks-controls {
        flex-direction: column;
        gap: 10px;
    }

    .task-filters {
        justify-content: space-between;
    }

    #all-tasks-table {
        font-size: 12px;
        overflow-x: auto;
        display: block;
        white-space: nowrap;
    }

    #all-tasks-table thead,
    #all-tasks-table tbody,
    #all-tasks-table th,
    #all-tasks-table td,
    #all-tasks-table tr {
        display: block;
    }

    #all-tasks-table thead tr {
        position: absolute;
        top: -9999px;
        left: -9999px;
    }

    #all-tasks-table tr {
        border: 1px solid #e0e0e0;
        margin-bottom: 10px;
        padding: 10px;
        border-radius: 8px;
        background-color: var(--white);
        white-space: normal;
    }

    #all-tasks-table td {
        border: none;
        padding: 5px 0;
        position: relative;
        padding-left: 30%;
    }

    #all-tasks-table td:before {
        content: attr(data-label) ": ";
        position: absolute;
        left: 6px;
        width: 25%;
        padding-right: 10px;
        white-space: nowrap;
        font-weight: 600;
        color: var(--text-dark);
    }

    .sort-options {
        position: fixed;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        width: 90%;
        max-width: 300px;
    }
}

/* Статистика проектов в одну строку */
.projects-stats-bar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background-color: var(--medium-gray);
    padding: 15px 20px;
    border-radius: 8px;
    margin-bottom: 20px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
    border: 1px solid var(--light-gray);
}

.projects-stats-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 5px;
    flex: 1;
    position: relative;
}

.projects-stats-item:not(:last-child)::after {
    content: '';
    position: absolute;
    right: -1px;
    top: 10%;
    height: 80%;
    width: 1px;
    background-color: var(--light-gray);
}

.projects-stats-value {
    font-size: 24px;
    font-weight: 700;
    color: var(--white);
    line-height: 1;
}

.projects-stats-label {
    font-size: 12px;
    color: var(--text-light);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    font-weight: 500;
    text-align: center;
}

.projects-stats-item.initiation .projects-stats-value {
    color: #4caf50;
}

.projects-stats-item.implementation .projects-stats-value {
    color: #2196f3;
}

.projects-stats-item.completed .projects-stats-value {
    color: #9c27b0;
}

.projects-stats-item.cancelled .projects-stats-value {
    color: #f44336;
}

.projects-stats-item.total .projects-stats-value {
    color: var(--blue-medium);
}

.projects-stats-item.cost .projects-stats-value {
    color: #ff9800;
    font-size: 20px;
}

/* Адаптивность для статистики */
@media (max-width: 768px) {
    .projects-stats-bar {
        flex-wrap: wrap;
        gap: 15px;
        padding: 15px;
    }

    .projects-stats-item {
        flex: 1 1 calc(50% - 7.5px);
        min-width: 120px;
    }

    .projects-stats-item:not(:last-child)::after {
        display: none;
    }

    .projects-stats-value {
        font-size: 20px;
    }

    .projects-stats-item.cost .projects-stats-value {
        font-size: 16px;
    }
}

@media (max-width: 480px) {
    .projects-stats-item {
        flex: 1 1 100%;
    }
}

/* Стили для выбора руководителя */
.manager-selection {
    display: flex;
    gap: 8px;
    align-items: flex-end;
    margin-bottom: 12px;
}

.manager-selection input[type="text"] {
    flex: 1;
    margin-bottom: 0;
}

/* Адаптивность для детальной страницы проекта */
@media (max-width: 768px) {
    .project-info-grid {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .project-detail-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
    }

    .documents-list {
        grid-template-columns: 1fr;
    }

    .documents-header {
        flex-direction: column;
        gap: 10px;
        align-items: stretch;
    }
}

/* Бейджи статусов проектов */
.status-badge {
    display: inline-block;
    padding: 4px 12px;
    border-radius: 16px;
    font-size: 12px;
    font-weight: 500;
    text-align: center;
    color: white;
    min-width: 80px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.status-badge.initiation {
    background-color: #4caf50;
    color: white;
}

.status-badge.implementation {
    background-color: #2196f3;
    color: white;
}

.status-badge.completed {
    background-color: #9c27b0;
    color: white;
}

.status-badge.cancelled {
    background-color: #f44336;
    color: white;
}

/* Спиннер */
.spinner {
    border: 4px solid #f3f3f3;
    border-top: 4px solid #1976d2;
    border-radius: 50%;
    width: 30px;
    height: 30px;
    animation: spin 1s linear infinite;
    align-items: center;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

#export-btn {
    background-color: #4caf50;
    color: white;
    border: none;
    padding: 8px 16px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 14px;
    transition: background-color 0.3s ease;
}

#export-btn:hover {
    background-color: #45a049;
}

#import-btn {
    background-color: #2196f3;
    color: white;
    border: none;
    padding: 8px 16px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 14px;
    transition: background-color 0.3s ease;
    margin-left: 10px;
}

#import-btn:hover {
    background-color: #1976d2;
}