/* --- Шрифты --- */
@font-face { font-family: 'Hack'; src: url('fonts/hack-regular.woff2') format('woff2'); font-weight: normal; font-style: normal; font-display: swap; }
@font-face { font-family: 'Hack'; src: url('fonts/hack-bold.woff2') format('woff2'); font-weight: bold; font-style: normal; font-display: swap; }
@font-face { font-family: 'Hack'; src: url('fonts/hack-italic.woff2') format('woff2'); font-weight: normal; font-style: italic; font-display: swap; }
@font-face { font-family: 'Hack'; src: url('fonts/hack-bolditalic.woff2') format('woff2'); font-weight: bold; font-style: italic; font-display: swap; }

/* --- Переменные (Светлая тема по умолчанию) --- */
:root {
    --primary-font: 'Hack', monospace;
    --secondary-font: sans-serif;
    --primary-color: #0d88a7;
    --background-color: #f8f8f8;
    --section-background: white;
    --border-color: #e0e0e0;
    --code-background: #f0f0f0;
    --code-input-background: #f5f5f5;
    --button-gradient-start: #42a5f5;
    --button-gradient-end: #4caf50;
    --hover-background: #e0e0e0;
    --focus-shadow-color: rgba(66, 133, 244, 0.2);
    --text-color: #333;
    --code-text-color: #444;
    --light-red-hover: #e57373;
    --delete-button-color: #888;
    --copy-button-color: #555;
    --clear-button-color: #888;
    --animation-speed: 0.15s;
    --reset-button-gradient-start: #e57373;
    --reset-button-gradient-end: #81c784;
    --icon-button-size: 30px;
    --icon-button-font-size: 1.2em;
    --icon-button-border-radius: 8px;
    --icon-button-bg: #f0f0f0;
    --icon-button-bg-hover: #e5e5e5;
    --icon-button-bg-active: #dcdcdc;
    --icon-button-border: #ccc;
    --icon-button-shadow: none;
    --icon-button-gap: 6px;
    --control-button-bg: #eee;
    --control-button-hover-bg: #ddd;
    --control-button-text: #333;
    --control-button-height: 35px;
    --control-button-height-small: 30px;
    --user-message-bg: #e0f1f1;
    --model-message-bg: #e5f0f0;
    --user-message-text: #333;
    --model-message-text: #333;
    --message-border-color: #077a7c;
    --user-message-border-color: #c1c1c1;
    --scrollbar-thumb: #c1c1c1;
    --scrollbar-track: #f1f1f1;
    --pagination-button-bg: #e0e0e0;
    --pagination-button-hover-bg: #d0d0d0;
    --pagination-button-active-bg: var(--primary-color);
    --pagination-button-active-text: white;
    --pagination-button-disabled-opacity: 0.5;
    --modal-overlay-bg: rgba(0,0,0,0.6);
    --modal-content-bg: var(--section-background);
    --modal-content-text: var(--text-color);
    --modal-close-button-text: var(--text-color);
    --drag-over-bg: rgba(66, 133, 244, 0.1);
    --drag-over-border: #e0f1f1;
    --info-summary-button-bg: var(--control-button-bg);
    --info-summary-button-text: var(--control-button-text);
    --info-summary-button-hover-bg: var(--control-button-hover-bg);
    --info-summary-button-active-bg: #ccc;
    /* Цвета для ролей */
    --user-label-color: #555858;  /* Оранжево-желтый */
    --model-label-color: #077a7c; /* Синий */
}

/* --- Темная тема --- */
body.dark-theme {
    --background-color: #212121;
    --section-background: #333333;
    --border-color: #555555;
    --code-background: #424242;
    --code-input-background: #3a3a3a;
    --hover-background: #505050;
    --focus-shadow-color: rgba(66, 133, 244, 0.3);
    --text-color: #e0e0e0;
    --code-text-color: #ccc;
    --light-red-hover: #ef9a9a;
    --delete-button-color: #aaa;
    --copy-button-color: #bbb;
    --clear-button-color: #aaa;
    --icon-button-bg: #444;
    --icon-button-bg-hover: #555;
    --icon-button-bg-active: #666;
    --icon-button-border: #666;
    --control-button-bg: #555;
    --control-button-hover-bg: #666;
    --control-button-text: #eee;
    --user-message-bg: #222b39;
    --model-message-bg: #262d31;
    --user-message-text: #e0e0e0;
    --model-message-text: #e0e0e0;
    --message-border-color: #4a4a4a;
    --user-message-border-color: #212121;
    --scrollbar-thumb: #555;
    --scrollbar-track: #333;
    --pagination-button-bg: #555;
    --pagination-button-hover-bg: #666;
    --pagination-button-active-text: white;
    --modal-overlay-bg: rgba(0,0,0,0.7);
    --modal-content-bg: var(--section-background);
    --modal-content-text: var(--text-color);
    --modal-close-button-text: var(--text-color);
    --drag-over-bg: rgba(66, 133, 244, 0.15);
    --drag-over-border: #64b5f6;
    --info-summary-button-bg: var(--control-button-bg);
    --info-summary-button-text: var(--control-button-text);
    --info-summary-button-hover-bg: var(--control-button-hover-bg);
    --info-summary-button-active-bg: #444;
    /* Цвета для ролей в темной теме */
    --user-label-color: #ffb74d; /* Светлее оранжево-желтый */
    --model-label-color: #90caf9; /* Светлее синий */
}

/* --- Общие стили --- */
body { font-family: var(--secondary-font); padding: 20px; padding-top: 60px; padding-bottom: 60px; background-color: var(--background-color); color: var(--text-color); line-height: 1.6; font-size: 16px; display: flex; flex-direction: column; align-items: center; box-sizing: border-box; transition: background-color 0.3s ease, color 0.3s ease; transform-origin: top center; zoom: 1; min-height: 100vh; scroll-behavior: smooth; } *, *::before, *::after { box-sizing: inherit; } .main-content-wrapper { width: 100%; max-width: 900px; display: flex; flex-direction: column; align-items: center; }

/* --- Стили секций --- */
.section { width: 100%; margin-bottom: 25px; border: 1px solid var(--border-color); padding: 15px; border-radius: 8px; background-color: var(--section-background); box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1); transition: box-shadow var(--animation-speed) ease-in-out, background-color 0.3s ease, border-color 0.3s ease, opacity 0.3s ease, max-height 0.3s ease-out, padding 0.3s ease-out, margin 0.3s ease-out; } .section:hover { box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15); }
#chatDisplayArea { width: 100%; display: flex; flex-direction: column; } #chatContainer { padding: 10px; position: relative; order: 1; } #mainPaginationControls { order: 2; }
.section-header { font-size: 1.4em; margin-bottom: 15px; padding-bottom: 8px; display: flex; align-items: center; color: var(--text-color); gap: var(--icon-button-gap); transition: color 0.3s ease; font-family: var(--primary-font); } .section-header input { font-size: inherit; border: none; border-bottom: 1px dashed var(--border-color); outline: none; font-weight: bold; color: inherit; background-color: transparent; font-family: var(--primary-font); flex-grow: 1; min-width: 50px; margin-right: 0; padding-bottom: 2px; transition: border-color var(--animation-speed) ease, color 0.3s ease; } .section-header input:focus { border-bottom: 1px solid var(--primary-color); outline: none; } .section-header .clear-header-button { margin-left: 0; flex-shrink: 0; position: static; } body.dark-theme .section-header input { border-bottom-color: var(--border-color); } body.dark-theme .section-header input:focus { border-bottom-color: var(--primary-color); }
#chatContainer p:first-child { color: #888; text-align: center; font-style: italic; } body.dark-theme #chatContainer p:first-child { color: #aaa; }
.hidden-section { max-height: 0; padding-top: 0; padding-bottom: 0; margin-bottom: 0; border-width: 0; opacity: 0; overflow: hidden; pointer-events: none; } .section.visible-section { max-height: 1000px; padding-top: 15px; padding-bottom: 15px; margin-bottom: 25px; border-width: 1px; opacity: 1; pointer-events: auto; }

/* --- Стили для сворачиваемых сообщений --- */
.collapsible-message { border: 1px solid var(--message-border-color); border-radius: 8px; margin-bottom: 10px; overflow: hidden; transition: background-color 0.3s ease, border-color 0.3s ease; }
.collapsible-message.user {
    margin-left: auto;
    max-width: 85%;
    background-color: var(--user-message-bg);
    border-color: var(--user-message-border-color);
    border-radius: 8px;
    margin-bottom: 10px;
    overflow: hidden;
    transition: background-color 0.3s ease, border-color 0.3s ease;
}
.collapsible-message.model {
    margin-right: auto;
    max-width: 85%;
    background-color: var(--model-message-bg);
    border-color: var(--message-border-color);
    border-radius: 8px;
    margin-bottom: 10px;
    overflow: hidden;
    transition: background-color 0.3s ease, border-color 0.3s ease;
}
body.dark-theme .collapsible-message.user {
    border-color: var(--user-message-border-color);
}
body.dark-theme .collapsible-message.model {
    border-color: var(--message-border-color);
}
.message-header { padding: 8px 12px; cursor: pointer; user-select: none; position: relative; font-weight: normal; /* Убираем жирность */ font-family: var(--secondary-font); display: flex; align-items: center; justify-content: space-between; transition: background-color 0.2s ease; background-color: inherit; color: inherit; }
.message-header:hover { background-color: rgba(0, 0, 0, 0.05); } body.dark-theme .message-header:hover { background-color: rgba(255, 255, 255, 0.08); } .message-header:focus-visible { outline: 2px solid var(--primary-color); outline-offset: -2px; border-radius: 4px; }
.message-header-left { display: flex; align-items: center; flex-grow: 1; overflow: hidden; margin-right: 10px; }
.message-header-left::before { content: '▶'; display: inline-block; margin-right: 8px; font-size: 0.8em; transition: transform 0.2s ease; flex-shrink: 0; align-self: center; }
.collapsible-message.expanded .message-header-left::before { transform: rotate(90deg); }

/* Новые стили для номера и роли */
.message-number { font-size: 0.9em; font-weight: normal; margin-right: 4px; flex-shrink: 0; }
.role-label { font-size: 0.9em; font-weight: normal; margin-right: 8px; flex-shrink: 0; }
.message-number.user, .role-label.user { color: var(--user-label-color); }
.message-number.model, .role-label.model { color: var(--model-label-color); }
/* Выравнивание для User */
.collapsible-message.user .message-header { flex-direction: row-reverse; } /* Разворачиваем весь хедер */
.collapsible-message.user .message-header-left { flex-direction: row-reverse; justify-content: flex-end; /* Прижимаем к правому краю обертки */ margin-right: 0; margin-left: 10px;}
.collapsible-message.user .message-header-left::before { order: 3; margin-left: 8px; margin-right: 0; } /* Индикатор справа */
.collapsible-message.user .role-label { order: 1; margin-right: 4px; margin-left: 0; } /* Роль перед номером */
.collapsible-message.user .message-number { order: 2; margin-right: 0; margin-left: 0;} /* Номер после роли */
.collapsible-message.user .preview-text { order: 0; text-align: right; margin-right: 8px; margin-left: 0; flex-grow: 1; /* Важно, чтобы занимал место */}
/* Кнопка модалки остается справа */
.collapsible-message.user .open-modal-button { order: 4; /* После индикатора */ }

.message-header .preview-text { font-weight: normal; font-style: italic; opacity: 0.8; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; color: inherit; flex-grow: 1; min-width: 50px; } /* Убрали margin-left */
.message-header .open-modal-button { display: inline-flex; align-items: center; justify-content: center; width: 24px; height: 24px; padding: 0; margin: 0; border: 1px solid var(--icon-button-border); border-radius: 5px; background-color: var(--icon-button-bg); color: var(--copy-button-color); font-size: 1em; /* Сделаем чуть крупнее */ line-height: 1; cursor: pointer; opacity: 0.8; transition: all var(--animation-speed) ease; flex-shrink: 0; box-shadow: none; user-select: none; margin-left: 5px; }
.message-header .open-modal-button:hover { opacity: 1; background-color: var(--icon-button-bg-hover); } .message-header .open-modal-button:focus-visible { outline: 2px solid var(--primary-color); outline-offset: 1px; box-shadow: 0 0 0 2px var(--focus-shadow-color); }

.message-content { padding: 0px 12px 12px 12px; max-height: 0; overflow: hidden; transition: max-height 0.3s ease-out, padding-top 0.3s ease-out; background-color: inherit; color: inherit; }
.collapsible-message.expanded .message-content { max-height: 300px; overflow-y: auto; padding-top: 10px; border-top: 1px solid rgba(128, 128, 128, 0.3); scrollbar-width: thin; scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track); /*overscroll-behavior: contain; */ /* УБРАНО */ }
.collapsible-message.expanded .message-content::-webkit-scrollbar { width: 8px; } .collapsible-message.expanded .message-content::-webkit-scrollbar-track { background: var(--scrollbar-track); border-radius: 4px; } .collapsible-message.expanded .message-content::-webkit-scrollbar-thumb { background-color: var(--scrollbar-thumb); border-radius: 4px; border: 2px solid var(--scrollbar-track); } .collapsible-message.expanded .message-content::-webkit-scrollbar-thumb:hover { background-color: #a1a1a1; } body.dark-theme .collapsible-message.expanded .message-content::-webkit-scrollbar-thumb:hover { background-color: #777; } body.dark-theme .collapsible-message.expanded .message-content { border-top-color: rgba(180, 180, 180, 0.3); }
.collapsible-message .message { float: none; margin: 0; padding: 0; max-width: 100%; border-radius: 0; background-color: transparent !important; border: none; color: inherit; font-size: 1em; font-family: var(--secondary-font); line-height: 1.5; } .collapsible-message .message::before { content: none; }
/* Стили для элементов Markdown внутри .message-content (без изменений) */
/* ... */
.message-content p { margin-top: 0; margin-bottom: 0.8em; } .message-content p:last-child { margin-bottom: 0; } .message-content code { background-color: rgba(0, 0, 0, 0.08); padding: 3px 6px; border-radius: 4px; font-family: var(--primary-font); font-size: 0.9em; overflow-wrap: break-word; color: var(--code-text-color); } body.dark-theme .message-content code { background-color: rgba(255, 255, 255, 0.1); color: var(--code-text-color); } .message-content pre { background-color: var(--code-background); padding: 12px; border-radius: 6px; overflow-x: auto; white-space: pre; margin: 0.8em 0; border: 1px solid var(--border-color); transition: background-color 0.3s ease, border-color 0.3s ease; } .message-content pre code { background-color: transparent; padding: 0; border: none; color: var(--code-text-color); } body.dark-theme .message-content pre code { color: var(--code-text-color); } .message-content ul, .message-content ol { margin-left: 25px; padding-left: 0; margin-top: 0.5em; margin-bottom: 0.8em; } .message-content li { margin-bottom: 5px; } .message-content ul ul, .message-content ol ol, .message-content ul ol, .message-content ol ul { margin-top: 0.3em; margin-bottom: 0.3em; } .message-content h1, .message-content h2, .message-content h3, .message-content h4, .message-content h5, .message-content h6 { margin-top: 1em; margin-bottom: 0.5em; font-weight: bold; line-height: 1.3; font-family: var(--secondary-font); color: inherit; } .message-content h1 { font-size: 1.6em; } .message-content h2 { font-size: 1.4em; } .message-content h3 { font-size: 1.2em; } .message-content h4 { font-size: 1.1em; } .message-content h5 { font-size: 1.0em; font-weight: bold; } .message-content h6 { font-size: 0.95em; font-weight: bold; color: #666; } body.dark-theme .message-content h6 { color: #aaa; } .message-content blockquote { border-left: 3px solid #ccc; padding-left: 15px; margin-left: 5px; margin-top: 0.8em; margin-bottom: 0.8em; color: #555; font-style: italic; } body.dark-theme .message-content blockquote { border-left-color: #666; color: #bbb; } .message-content blockquote p { margin-bottom: 0.3em; font-style: normal; } .message-content hr { border: none; border-top: 1px solid var(--border-color); margin: 1.5em 0; transition: border-color 0.3s ease; } .message-content a { color: var(--primary-color); text-decoration: none; } .message-content a:hover { text-decoration: underline; } .message-content img { max-width: 100%; height: auto; display: block; margin: 0.8em 0; border-radius: 4px; }

/* --- Стили полей ввода и кнопок (Info/Summary) --- */
/* ... (без изменений) ... */
.code-input-wrapper { position: relative; } #chatInfoText, #summaryText { display: block; width: 100%; min-height: 80px; padding: 10px; padding-right: calc(var(--icon-button-size) * 2 + var(--icon-button-gap) + 8px); border: 1px solid var(--border-color); border-radius: 5px; font-family: var(--primary-font); font-size: 0.95em; white-space: pre-wrap; resize: vertical; color: var(--text-color); transition: border-color var(--animation-speed) ease, box-shadow var(--animation-speed) ease, background-color 0.3s ease, color 0.3s ease; background-color: var(--code-input-background); } #chatInfoText:focus, #summaryText:focus { outline: none; border-color: var(--primary-color); box-shadow: 0 0 0 2px var(--focus-shadow-color); } body.dark-theme #chatInfoText, body.dark-theme #summaryText { background-color: var(--code-input-background); color: var(--text-color); border-color: var(--border-color); } .code-input-wrapper .copy-code-button { position: absolute; top: 8px; right: 8px; z-index: 2; } .code-input-wrapper .clear-input-button { position: absolute; top: calc(8px + var(--icon-button-size) + var(--icon-button-gap)); right: 8px; z-index: 2; }

/* --- Иконочные кнопки --- */
/* ... (без изменений) ... */
.clear-input-button, .clear-header-button, .copy-code-button { display: inline-flex; align-items: center; justify-content: center; width: var(--icon-button-size); height: var(--icon-button-size); padding: 0; margin: 0; border: 1px solid var(--icon-button-border); border-radius: var(--icon-button-border-radius); background-color: var(--icon-button-bg); color: var(--copy-button-color); font-size: var(--icon-button-font-size); line-height: 1; cursor: pointer; opacity: 1.0; transition: background-color var(--animation-speed) ease, border-color var(--animation-speed) ease, color var(--animation-speed) ease, box-shadow var(--animation-speed) ease, opacity 0.2s ease; flex-shrink: 0; box-shadow: var(--icon-button-shadow); user-select: none; position: relative; } .clear-input-button:disabled, .clear-header-button:disabled, .copy-code-button:disabled { opacity: 0.5; cursor: not-allowed; } .clear-input-button:hover, .clear-header-button:hover, .copy-code-button:hover { background-color: var(--icon-button-bg-hover); border-color: #bbb; } body.dark-theme .clear-input-button:hover, body.dark-theme .clear-header-button:hover, body.dark-theme .copy-code-button:hover { border-color: #888; background-color: var(--icon-button-bg-hover); } .clear-input-button:active, .clear-header-button:active, .copy-code-button:active { background-color: var(--icon-button-bg-active); } .clear-input-button:focus-visible, .clear-header-button:focus-visible, .copy-code-button:focus-visible, #theme-toggle-container > button:focus-visible, #zoom-controls-container > button:focus-visible, #reset-button-container > button:focus-visible, #bottom-right-controls > button:focus-visible, #loadChatButton:focus-visible, #helpButton:focus-visible, #downloadButton:focus-visible, #toggleInfoButton:focus-visible, #toggleSummaryButton:focus-visible { outline: 2px solid var(--primary-color); outline-offset: 1px; box-shadow: 0 0 0 2px var(--focus-shadow-color); } .clear-input-button, .clear-header-button { color: var(--clear-button-color); } .clear-input-button:hover, .clear-header-button:hover { color: #333; } body.dark-theme .clear-input-button:hover, body.dark-theme .clear-header-button:hover { color: #eee; } .copy-code-button { color: var(--copy-button-color); } .copy-code-button:hover { color: #000; } body.dark-theme .copy-code-button:hover { color: #fff; }

/* --- Фиксированные кнопки управления --- */
/* ... (без изменений) ... */
#theme-toggle-container, #zoom-controls-container, #reset-button-container, #bottom-right-controls { position: fixed; z-index: 1000; display: flex; align-items: center; gap: 6px; background-color: rgba(255, 255, 255, 0.8); padding: 5px 8px; border-radius: 8px; box-shadow: 0 1px 4px rgba(0,0,0,0.25); transition: background-color 0.3s ease; -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px); } body.dark-theme #theme-toggle-container, body.dark-theme #zoom-controls-container, body.dark-theme #reset-button-container, body.dark-theme #bottom-right-controls { background-color: rgba(60, 60, 60, 0.8); } #theme-toggle-container { top: 10px; left: 10px; } #zoom-controls-container { top: 10px; right: 10px; } #reset-button-container { bottom: 10px; left: 10px; } #bottom-right-controls { bottom: 10px; right: 10px; } #theme-toggle-container > button, #zoom-controls-container > button, #reset-button-container > button, #bottom-right-controls > button, #loadChatButton { width: var(--control-button-height); height: var(--control-button-height); padding: 0; font-size: 1.1em; cursor: pointer; border: 1px solid var(--icon-button-border); border-radius: 5px; background-color: var(--control-button-bg); color: var(--control-button-text); transition: background-color 0.2s ease, border-color 0.2s ease, color 0.3s ease, box-shadow 0.2s ease; user-select: none; background-image: none; box-shadow: none; margin: 0; display: inline-flex; align-items: center; justify-content: center; line-height: 1; flex-shrink: 0; } #theme-toggle-container > button:hover, #zoom-controls-container > button:hover, #reset-button-container > button:hover, #bottom-right-controls > button:hover, #loadChatButton:hover { background-color: var(--control-button-hover-bg); transform: none; box-shadow: none; } #zoom-controls-container label[for="fileFormat"] { color: var(--control-button-text); margin: 0; padding: 0 4px; font-size: 0.9em; white-space: nowrap; } #zoom-controls-container #fileFormat { height: var(--control-button-height); padding: 0 8px; font-size: 0.9em; border-radius: 5px; background-color: var(--control-button-bg); color: var(--control-button-text); border: 1px solid var(--icon-button-border); vertical-align: middle; transition: background-color 0.2s ease, border-color 0.2s ease, color 0.3s ease; font-family: var(--primary-font); flex-shrink: 0; -webkit-appearance: none; appearance: none; padding-right: 25px; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23333'%3E%3Cpath d='M8 11L3 6h10L8 11z'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 8px center; background-size: 12px 12px; } body.dark-theme #zoom-controls-container #fileFormat { background-color: var(--control-button-bg); color: var(--control-button-text); border-color: var(--icon-button-border); background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23eee'%3E%3Cpath d='M8 11L3 6h10L8 11z'/%3E%3C/svg%3E"); } #zoom-controls-container #fileFormat:hover, #zoom-controls-container #fileFormat:focus { border-color: var(--primary-color); outline: none; } #scrollToBottomButton.scroll-button { font-size: 1.5em; background-image: none; } #scrollToBottomButton.scroll-button:focus-visible { outline: 2px solid var(--primary-color); outline-offset: 1px; box-shadow: 0 0 0 2px var(--focus-shadow-color); } #toggleInfoButton, #toggleSummaryButton, #toggleAllMessagesButton {
    background-color: var(--info-summary-button-bg);
    color: var(--info-summary-button-text);
    font-size: 1.3em;
}
#toggleInfoButton.active, #toggleSummaryButton.active, #toggleAllMessagesButton.active {
    background-color: var(--info-summary-button-active-bg);
    box-shadow: inset 0 1px 2px rgba(0,0,0,0.2);
}

/* --- Стили для Drag and Drop (без изменений) --- */
/* ... */
body.drag-over { outline: 3px dashed var(--drag-over-border); outline-offset: -10px; background-color: var(--drag-over-bg); transition: outline 0.2s ease, background-color 0.2s ease, outline-offset 0.2s ease; } body.drag-over::before { content: "Перетащите JSON файл сюда"; position: fixed; top: 50%; left: 50%; transform: translate(-50%, -50%); font-size: 1.5em; font-weight: bold; color: var(--drag-over-border); background-color: rgba(255, 255, 255, 0.8); padding: 15px 25px; border-radius: 10px; z-index: 1001; pointer-events: none; border: 2px dashed var(--drag-over-border); } body.dark-theme.drag-over::before { background-color: rgba(0, 0, 0, 0.8); color: var(--drag-over-border); border-color: var(--drag-over-border); }

/* --- Стили для основной пагинации (Числовые кнопки) --- */
#mainPaginationControls { text-align: center; margin-top: 20px; margin-bottom: 10px; padding-bottom: 5px; /* Небольшой отступ снизу */}
#mainPaginationControls button { margin: 0 3px; padding: 5px 10px; font-size: 0.95em; cursor: pointer; border: 1px solid var(--border-color); background-color: var(--pagination-button-bg); color: var(--text-color); border-radius: 4px; transition: background-color 0.2s ease, border-color 0.2s ease, color 0.3s ease; font-family: var(--secondary-font); min-width: 30px; }
#mainPaginationControls button:hover:not(:disabled) { background-color: var(--pagination-button-hover-bg); border-color: #bbb; } body.dark-theme #mainPaginationControls button:hover:not(:disabled) { border-color: #888; }
#mainPaginationControls button.active { background-color: var(--pagination-button-active-bg); color: var(--pagination-button-active-text); border-color: var(--pagination-button-active-bg); font-weight: bold; cursor: default; }
#mainPaginationControls button:disabled { opacity: var(--pagination-button-disabled-opacity); cursor: not-allowed; }
#mainPaginationControls span { /* Для многоточия */ margin: 0 5px; color: var(--text-color); display: inline-block; padding: 5px 0; }

/* --- Адаптивность (без изменений) --- */
@media (max-width: 768px) { /* ... */ } @media (max-width: 480px) { /* ... */ }
