@import url("/css/reset.css?v=split1");
@import url("/css/variables.css?v=split1");
@import url("/css/background.css?v=split1");
@import url("/css/typography.css?v=split1");
@import url("/css/layout.css?v=split1");
@import url("/css/components.css?v=split1");
@import url("/css/user-menu.css?v=split1");
@import url("/css/chapter-nav.css?v=split1");
@import url("/css/responsive.css?v=split1");
@import url('/css/fanfics/filters.css?v=rc2');
@import url('/css/admin.css');

/* ==== Global Typography (site-wide) ====================== */
:root{
  --app-font: "Manrope", system-ui, -apple-system, "Segoe UI", Roboto, "Noto Sans",
              "Helvetica Neue", Arial, sans-serif; /* было: "Times New Roman", Times, serif */
}

/* === Peach light palette =================================================== */
:root{
  --peach-ink:    #2f2523;   /* базовый тёмный текст на персиковом фоне */
  --peach-muted:  #7a5d56;   /* приглушённый текст */
  --peach-0:      #fcb07d;   /* самый светлый фон (page) */
  --peach-1:      #fcb07d;   /* фон карточек/панелей */
  --peach-2:      #fcb07d;   /* чуть плотнее (хедер/футер) */
  --peach-border: #fcb07d;   /* границы на светлой теме */
}

/* базовый цвет текста на светлой теме — чуть теплее чёрного */
body.light-theme{ color: var(--peach-ink); }

/* Базово весь текст сайта */
html, body {
  font-family: var(--app-font) !important;
}

/* Элементы управления и наши кнопки — наследуют от body */
input, select, textarea, button,
.button,
label,
.alert, .alert * {
  font-family: inherit !important;
}

/* Контентные блоки, где раньше мог быть другой шрифт */
.chapter-text,
.review-head,
nav, header, footer,
.dropdown, .user-menu,
.pill {
  font-family: inherit !important;
}

/* Quill: и тулбары, и редактор внутри — тоже Times New Roman */
.ql-snow .ql-toolbar,
.ql-snow .ql-tooltip,
.ql-container .ql-editor,
.ql-picker,
.ql-picker * {
  font-family: inherit !important;
}

/* Плейсхолдер Quill в том же шрифте */
.ql-editor.ql-blank::before {
  font-family: inherit !important;
}

/* На случай, если где-то заголовкам принудительно задавался иной шрифт */
h1, h2, h3, h4, h5, h6, p, span, a, li, dt, dd, small, strong, em {
  font-family: inherit !important;
}

/* === Quill: просмотр сохранённого контента === */
.ql-view {
  line-height: 1.6;
  word-wrap: break-word;
}
.ql-view p { margin: .4em 0; }
.ql-view h1, .ql-view h2, .ql-view h3 { margin: .6em 0 .3em; font-weight: 700; }
.ql-view ul, .ql-view ol { margin: .4em 0; padding-left: 1.4em; }
.ql-view blockquote {
  margin: .6em 0; padding-left: .9em; border-left: 3px solid #e5e7eb; color: #374151;
}
.dark-theme .ql-view blockquote { border-left-color: #444; color: #d1d5db; }
.ql-view a { text-decoration: underline; }

/* === Quill: компактная панель инструментов (глобально) === */
.ql-toolbar.ql-snow {
  padding: 2px 4px !important;
  border: 1px solid #e5e7eb; border-bottom: 0;
  border-radius: 10px 10px 0 0;
  background: #f8fafc;
}
.dark-theme .ql-toolbar.ql-snow { background: #26263a; border-color: #444; }
.ql-toolbar .ql-formats { margin-right: 4px !important; }

.ql-toolbar button,
.ql-toolbar .ql-picker-label,
.ql-toolbar .ql-picker-item {
  padding: 0 4px !important;
  height: 22px !important;
  line-height: 22px !important;
}
.ql-toolbar svg {
  width: 13px !important;
  height: 13px !important;
}
.ql-toolbar .ql-picker { font-size: 12px !important; }
.ql-toolbar .ql-picker-label::before { line-height: 22px !important; }
.ql-toolbar .ql-color-picker .ql-picker-item {
  width: 14px !important; height: 14px !important;
}

/* Коробка редактора */
.ql-container.ql-snow {
  border: 1px solid #e5e7eb; border-top: 0;
  border-radius: 0 0 10px 10px;
}
.ql-editor {
  min-height: 110px;
  padding: 10px 12px;
  background: #fff; color: #111827;
}
.ql-editor.ql-blank::before { color: #6b7280; }

.dark-theme .ql-container.ql-snow { border-color: #444; }
.dark-theme .ql-editor { background: #1f1f2e; color: #e5e7eb; }
.dark-theme .ql-editor.ql-blank::before { color: #9aa1b2; }
.dark-theme .ql-snow .ql-stroke { stroke: #d1d5db; }
.dark-theme .ql-snow .ql-fill,
.dark-theme .ql-snow .ql-stroke.ql-fill { fill: #d1d5db; }

/* Quill (snow): тёмная тема — выпадающие списки форматирования */
.dark-theme .ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-options {
  background: #2f3045 !important;
  border: 1px solid #555 !important;
  border-radius: 10px !important;
  padding: 4px !important;
  box-shadow: 0 10px 24px rgba(0,0,0,.35) !important;
  color: #e5e7eb !important;
  z-index: 1000; /* поверх карточек */
}
.dark-theme .ql-toolbar.ql-snow .ql-picker-options .ql-picker-item {
  color: #e5e7eb !important;
}
.dark-theme .ql-toolbar.ql-snow .ql-picker-options .ql-picker-item:hover,
.dark-theme .ql-toolbar.ql-snow .ql-selected {
  color: #ffffff !important;
}

/* На всякий случай: цвет текста текущей метки селектора */
.dark-theme .ql-toolbar.ql-snow .ql-picker-label {
  color: #e5e7eb !important;
}

/* === Кнопки: глобальные вариации (вне зависимости от хедера) ============== */
.button.small {
  padding: 6px 10px;
  min-height: 32px;
  border-radius: 8px;
  font-size: .9rem;
}
.button.secondary {
  background: #f3f4f6;
  color: #111827;
  border: 1px solid #e5e7eb;
}
.dark-theme .button.secondary {
  background: #3a3a55;
  color: #e5e7eb;
  border-color: #555;
}

/* === Cookie consent ===================================================== */
.cookie-banner{
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 4000;
  padding: 12px; display: none;
}
.cookie-banner[hidden]{ display: none !important; }
.cookie-banner--show{ display: block; }

.cookie-banner__content{
  max-width: 1100px; margin: 0 auto;
  border: 1px solid #e5e7eb; border-radius: 14px;
  background: #ffffff;
  box-shadow: 0 10px 28px rgba(17,24,39,.12);
  padding: 12px; display: grid; gap: 10px; align-items: center;
}
.cookie-banner__text{ color:#111827; line-height:1.45; }
.cookie-banner__text a{ color:#1a73e8; font-weight:700; text-decoration:none; border-bottom:1px solid transparent; }
.cookie-banner__text a:hover{ border-bottom-color:#1a73e8; }
.cookie-banner__actions{ display:flex; gap:8px; flex-wrap:wrap; }

.dark-theme .cookie-banner__content{
  background:#2a2a3c; border-color:#444; box-shadow: 0 12px 32px rgba(0,0,0,.45);
}
.dark-theme .cookie-banner__text{ color:#e5e7eb; }
.dark-theme .cookie-banner__text a{ color:#60a5fa; }
.dark-theme .cookie-banner__text a:hover{ border-bottom-color:#60a5fa; }

/* Панель настроек */
.cookie-panel{
  position: fixed; right: 16px; bottom: 72px; z-index: 4001;
  width: min(520px, 92vw);
  border: 1px solid #e5e7eb; border-radius: 12px;
  background:#fff; box-shadow: 0 16px 40px rgba(0,0,0,.18);
  display: none;
}
.cookie-panel[hidden]{ display: none !important; }
.cookie-panel--show{ display: block; }

.dark-theme .cookie-panel{
  background:#2a2a3c; border-color:#444; box-shadow: 0 24px 64px rgba(0,0,0,.6);
  color:#e5e7eb;
}

.cookie-panel__head{
  display:flex; align-items:center; justify-content:space-between;
  gap:8px; padding:10px 12px; border-bottom:1px dashed #e5e7eb;
}
.cookie-panel__title{ font-weight:800; }
.cookie-panel__close{
  display:inline-flex; align-items:center; justify-content:center;
  width:28px; height:28px; border-radius:8px; border:1px solid #e5e7eb; background:#f3f4f6; cursor:pointer;
}
.cookie-panel__close:hover{ background:#e5e7eb; }
.dark-theme .cookie-panel__head{ border-bottom-color:#444; }
.dark-theme .cookie-panel__close{ border-color:#555; background:#3a3a55; color:#e5e7eb; }
.dark-theme .cookie-panel__close:hover{ background:#343454; }

.cookie-panel__body{ padding:10px 12px; display:grid; gap:8px; }
.cookie-switch{ display:grid; grid-template-columns: auto 1fr; gap:4px 10px; align-items:center; }
.cookie-switch input{ width:18px; height:18px; }
.cookie-switch__title{ font-weight:700; }
.cookie-switch__desc{ grid-column: 2 / -1; font-size:.9rem; color:#6b7280; }
.dark-theme .cookie-switch__desc{ color:#cbd5e1; }

.cookie-panel__actions{ padding:10px 12px; display:flex; gap:8px; border-top:1px dashed #e5e7eb; }
.dark-theme .cookie-panel__actions{ border-top-color:#444; }

/* Скрытые элементы по умолчанию */
#cookie-banner[hidden],
#cookie-panel[hidden] { display: none !important; }

/* ======= Баннер ======= */
.cookie-banner {
  position: fixed;
  left: 50%;
  transform: translateX(-50%);
  bottom: calc(16px + env(safe-area-inset-bottom, 0px));
  width: min(960px, calc(100% - 24px));
  z-index: 4000;
  pointer-events: none; /* кликабельно только содержимое */
}
.cookie-banner__content {
  pointer-events: auto;
  display: flex; align-items: flex-start; gap: 12px; flex-wrap: wrap;
  padding: 12px 12px;
  border: 1px solid #e5e7eb; border-radius: 14px;
  background: #fff;
  box-shadow: 0 12px 32px rgba(0,0,0,.12);
}
.cookie-banner__text {
  flex: 1 1 360px;
  color: #111827;
}
.cookie-banner__text a {
  color: #1a73e8; font-weight: 700; text-decoration: none; border-bottom: 1px solid transparent;
}
.cookie-banner__text a:hover { border-bottom-color: #1a73e8; }

.cookie-banner__actions {
  display: flex; gap: 8px; flex-wrap: wrap; justify-content: flex-end;
}

/* Тёмная тема */
.dark-theme .cookie-banner__content {
  background: #2a2a3c; border-color: #444; box-shadow: 0 16px 40px rgba(0,0,0,.55);
}
.dark-theme .cookie-banner__text { color: #e5e7eb; }
.dark-theme .cookie-banner__text a { color: #60a5fa; }
.dark-theme .cookie-banner__text a:hover { border-bottom-color: #60a5fa; }

/* Мобилки: столбиком и растягиваем кнопки для удобства */
@media (max-width: 560px) {
  .cookie-banner__content { flex-direction: column; align-items: stretch; }
  .cookie-banner__actions { justify-content: stretch; }
  .cookie-banner .button { width: 100%; }
}

/* ======= Панель настроек ======= */
.cookie-panel {
  position: fixed;
  left: 50%; transform: translateX(-50%);
  bottom: calc(96px + env(safe-area-inset-bottom, 0px)); /* над баннером */
  width: min(620px, calc(100% - 24px));
  z-index: 5000;
  border: 1px solid #e5e7eb; border-radius: 14px;
  background: #fff;
  box-shadow: 0 20px 50px rgba(0,0,0,.2);
  padding: 12px;
}
.cookie-panel__head {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  padding-bottom: 8px; border-bottom: 1px dashed #e5e7eb;
}
.cookie-panel__title { font-weight: 800; }
.cookie-panel__close {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 36px; height: 36px;
  border-radius: 10px; border: 1px solid #e5e7eb; background: #f3f4f6; cursor: pointer;
}
.cookie-panel__close:hover { background: #e5e7eb; }

.cookie-panel__body { padding: 10px 2px; display: grid; gap: 10px; }
.cookie-switch {
  display: grid; grid-template-columns: auto 1fr; column-gap: 10px; align-items: center;
  padding: 10px; border: 1px solid #e5e7eb; border-radius: 10px; background: #f9fafb;
}
.cookie-switch input { width: 18px; height: 18px; }
.cookie-switch__title { font-weight: 700; }
.cookie-switch__desc { grid-column: 2; font-size: .9rem; color: #6b7280; }

.cookie-panel__actions {
  display: flex; gap: 8px; justify-content: flex-end;
  padding-top: 10px; border-top: 1px dashed #e5e7eb;
}

/* Тёмная тема для панели */
.dark-theme .cookie-panel { background: #2a2a3c; border-color: #444; box-shadow: 0 22px 60px rgba(0,0,0,.65); }
.dark-theme .cookie-panel__head { border-bottom-color: #4b5563; }
.dark-theme .cookie-panel__close { background: #3a3a55; border-color: #555; color: #e5e7eb; }
.dark-theme .cookie-panel__close:hover { background: #343454; }
.dark-theme .cookie-switch { background: #23233b; border-color: #444; }
.dark-theme .cookie-switch__desc { color: #9aa1b2; }
.dark-theme .cookie-panel__actions { border-top-color: #4b5563; }

/* На узких экранах – показываем панель чуть выше и по центру */
@media (max-width: 560px) {
  .cookie-panel {
    bottom: auto; top: 10vh;
    max-height: 80vh; overflow: auto;
  }
}

/* === Peach overrides for cookie UI (light theme) ========================= */
body.light-theme .cookie-banner__content{
  background: var(--peach-1);
  border-color: var(--peach-border);
  color: var(--peach-ink);
}
body.light-theme .cookie-panel{
  background: var(--peach-1);
  border-color: var(--peach-border);
  color: var(--peach-ink);
}
body.light-theme .cookie-switch{
  background: var(--peach-0);
  border-color: var(--peach-border);
}
body.light-theme .cookie-panel__head,
body.light-theme .cookie-panel__actions{
  border-color: var(--peach-border);
}

.qa .qa-bar{ background: linear-gradient(90deg,#7c82ff,#60a5fa 50%,#34d399) !important; }