/* ===========================================================================
   KeyPassword — тёмный «крепостной» интерфейс
   =========================================================================== */
:root, [data-theme="dark"] {
  --bg: #0b0e15;
  --bg2: #141a26;
  --panel: rgba(255, 255, 255, 0.038);
  --panel-2: rgba(255, 255, 255, 0.066);
  --border: rgba(255, 255, 255, 0.08);
  --border-strong: rgba(255, 255, 255, 0.14);
  --text: #e8edf6;
  --muted: #889;
  --accent: #4f83e8;
  --accent2: #3a6fd6;
  --accent3: #6a9bf0;
  --accent-soft: rgba(79, 131, 232, 0.13);
  --input-bg: rgba(0, 0, 0, 0.24);
  --hover: rgba(255, 255, 255, 0.045);
  --code-bg: rgba(0, 0, 0, 0.30);
  --glow1: rgba(58, 111, 214, 0.16);
  --glow2: rgba(79, 131, 232, 0.10);
  --shadow: 0 16px 44px rgba(0, 0, 0, 0.42);
  --bar-bg: rgba(11, 14, 21, 0.62);
  --side-bg: rgba(11, 14, 21, 0.34);
  --aurora-op: 0.22;
  --danger: #f43f5e;
  --ok: #22c55e;
  --warn: #f59e0b;
  --folder-ic: #e0a83a;             /* цвет иконки папки по умолчанию (без выбранного) */
  --radius: 16px;
  --radius-sm: 10px;
  --grad: linear-gradient(135deg, var(--accent2), var(--accent3));
  font-synthesis: none;
}

[data-theme="light"] {
  --bg: #eef2f8;
  --bg2: #ffffff;
  --panel: rgba(255, 255, 255, 0.82);
  --panel-2: rgba(58, 111, 214, 0.055);
  --border: rgba(28, 41, 74, 0.1);
  --border-strong: rgba(28, 41, 74, 0.17);
  --text: #1a2742;
  --muted: #5d6982;
  --accent: #3a6fd6;
  --accent2: #2c5cc4;
  --accent3: #5a8ce8;
  --accent-soft: rgba(58, 111, 214, 0.09);
  --input-bg: #ffffff;
  --hover: rgba(58, 111, 214, 0.05);
  --code-bg: rgba(58, 111, 214, 0.06);
  --glow1: rgba(58, 111, 214, 0.11);
  --glow2: rgba(90, 140, 232, 0.07);
  --shadow: 0 16px 38px rgba(30, 58, 138, 0.11);
  --bar-bg: rgba(255, 255, 255, 0.68);
  --side-bg: rgba(255, 255, 255, 0.46);
  --aurora-op: 0.3;
  --folder-ic: #d2982a;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: "Segoe UI", system-ui, -apple-system, Roboto, sans-serif;
  background: radial-gradient(1200px 700px at 80% -10%, var(--glow1) 0%, transparent 60%),
              radial-gradient(900px 600px at -10% 110%, var(--glow2) 0%, transparent 55%),
              var(--bg);
  color: var(--text);
  min-height: 100vh;
  min-height: 100dvh;                 /* мобильные браузеры: высота без учёта прячущейся адресной строки */
  overflow: hidden;
  -webkit-font-smoothing: antialiased;
  -webkit-text-size-adjust: 100%;     /* не «раздувать» шрифт при повороте на iOS */
  -webkit-tap-highlight-color: transparent;  /* без серой вспышки при тапе */
  overscroll-behavior-y: none;        /* приложение-подобное поведение: без pull-to-refresh/«отскока» */
  transition: background-color .3s ease, color .3s ease;
}

/* Плавное переключение темы: класс .theme-anim вешается на <html> ТОЛЬКО на время
   смены темы и задаёт ОДИН одинаковый переход всем элементам (перекрывая их
   собственные hover-переходы с разной длительностью). Поэтому вся страница
   меняет цвета одновременно и плавно, а после снятия класса hover-анимации
   возвращаются как были. transition-delay:0 — чтобы ничто не запаздывало. */
.theme-anim,
.theme-anim *,
.theme-anim *::before,
.theme-anim *::after {
  transition: background-color .30s ease, border-color .30s ease, color .30s ease,
              fill .30s ease, stroke .30s ease, box-shadow .30s ease,
              outline-color .30s ease !important;
  transition-delay: 0s !important;
}
@media (prefers-reduced-motion: reduce) {
  .theme-anim, .theme-anim *, .theme-anim *::before, .theme-anim *::after { transition: none !important; }
}

/* --- Фоновый эффект: одно спокойное мягкое свечение сверху.
   Строгий вид: без анимации, без «радуги», без клеточной сетки. --- */
.aurora {
  position: fixed; inset: -22% -10% auto -10%; height: 55vh; z-index: -2;
  pointer-events: none;
  background: radial-gradient(58% 100% at 70% 0%, var(--glow1), transparent 66%),
              radial-gradient(46% 100% at 24% 6%, var(--glow2), transparent 70%);
  filter: blur(54px); opacity: var(--aurora-op);
}

/* --- Переключатель темы (фиксирован сверху справа) --- */
.theme-toggle {
  position: fixed; top: calc(16px + env(safe-area-inset-top)); right: calc(18px + env(safe-area-inset-right)); z-index: 90;
  width: 40px; height: 40px; border-radius: 12px; cursor: pointer;
  background: var(--panel); border: 1px solid var(--border); color: var(--text);
  backdrop-filter: blur(12px); display: inline-flex; align-items: center; justify-content: center;
  font-size: 18px; transition: background .15s, border-color .15s, transform .1s; box-shadow: var(--shadow); }
.theme-toggle:hover { border-color: var(--accent); color: var(--accent); }
.theme-toggle:active { transform: scale(.94); }

#app { height: 100vh; height: 100dvh; }
.view { height: 100vh; height: 100dvh; }
.view.center { display: flex; align-items: center; justify-content: center; padding: 24px; }
.hidden { display: none !important; }

/* --- Логотип-щит --- */
.brand-mark {
  width: 76px; height: 84px; margin: 0 auto;
  background: var(--grad);
  -webkit-mask: var(--shield) center/contain no-repeat;
  mask: var(--shield) center/contain no-repeat;
  filter: drop-shadow(0 6px 22px rgba(79, 131, 232,.45));
  --shield: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 26'%3E%3Cpath d='M12 0 1 4.4v8.2C1 19.6 5.6 24.9 12 26c6.4-1.1 11-6.4 11-13.4V4.4z'/%3E%3Ccircle cx='12' cy='10.5' r='2.6' fill='black'/%3E%3Crect x='10.9' y='11' width='2.2' height='6' rx='1' fill='black'/%3E%3C/svg%3E");
  animation: pulse 3.5s ease-in-out infinite;
}
@keyframes pulse { 50% { filter: drop-shadow(0 6px 30px rgba(79,131,232,.6)); } }
.brand-mark.small { width: 56px; height: 62px; }
.brand-mark.tiny  { width: 26px; height: 29px; animation: none; }

.brand { text-align: center; margin-bottom: 26px; }
.brand.compact { margin-bottom: 20px; }
.brand h1 { font-size: 26px; font-weight: 700; letter-spacing: .3px; margin-top: 14px;
  background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent; }
.brand h2 { font-size: 21px; margin-top: 12px; }
.muted { color: var(--muted); font-size: 14px; margin-top: 6px; }

/* --- Карточки авторизации --- */
.card {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  backdrop-filter: blur(20px) saturate(115%);
  box-shadow: var(--shadow);
}
.auth-card { width: 100%; max-width: 400px; padding: 36px 32px; }
.auth-card.wide { max-width: 480px; }
.seed-card { width: 100%; max-width: 560px; padding: 32px; }

/* --- Поля --- */
.field { display: block; margin-bottom: 16px; }
.field > span { display: block; font-size: 13px; color: var(--muted); margin-bottom: 7px; }

/* Палитра цвета иконки папки (редактор папки) */
.swatches { display: flex; flex-wrap: wrap; gap: 9px; }
.swatch { width: 30px; height: 30px; border-radius: 9px; cursor: pointer; padding: 0;
  background: var(--sw, var(--panel-2)); border: 2px solid transparent; position: relative;
  transition: transform .1s ease, border-color .12s, box-shadow .12s; }
.swatch:hover { transform: scale(1.1); }
.swatch.sel { border-color: var(--text); box-shadow: 0 0 0 3px var(--accent-soft); }
.swatch.sel:not(.swatch-none)::after { content: '✓'; position: absolute; inset: 0;
  display: grid; place-items: center; color: #fff; font-size: 14px; font-weight: 700; text-shadow: 0 1px 2px rgba(0,0,0,.55); }
.swatch-none { background: var(--panel-2); color: var(--folder-ic); display: grid; place-items: center; font-size: 16px; }
.swatch-none::before { content: '⌀'; }
/* «Свой цвет» — палитра в конце ряда: радуга-подсказка, пока цвет не выбран; затем сам цвет */
.swatch-custom { overflow: hidden;
  background: conic-gradient(from 90deg, #f43f5e, #f59e0b, #22c55e, #06b6d4, #4f83e8, #a855f7, #ec4899, #f43f5e); }
.swatch-custom.has-color { background: var(--sw); }
.swatch-custom .swatch-picker { position: absolute; inset: 0; width: 100%; height: 100%; margin: 0;
  opacity: 0; border: none; padding: 0; cursor: pointer; }
.swatch-custom::after { pointer-events: none; }   /* галочка «выбрано» не перехватывает клик по палитре */

/* Палитра иконок папки (выбор иконки из набора; первая — стандартная) */
.icon-swatches { display: flex; flex-wrap: wrap; gap: 8px; }
.icon-swatch { width: 36px; height: 36px; border-radius: 9px; cursor: pointer; padding: 0;
  background: var(--panel-2); border: 2px solid transparent; color: var(--folder-ic);
  display: grid; place-items: center;
  transition: transform .1s ease, border-color .12s, box-shadow .12s, color .12s; }
.icon-swatch svg { width: 20px; height: 20px; display: block; }
.icon-swatch:hover { transform: scale(1.1); }
.icon-swatch.sel { border-color: var(--accent); color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
/* Плитка «Своя» — загрузка собственной картинки (превью заполняет плитку) */
.icon-custom { overflow: hidden; color: var(--muted); }
.icon-custom img { width: 100%; height: 100%; object-fit: cover; display: block; }
.icon-custom .ico-up { font-size: 20px; line-height: 1; font-weight: 300; }
.icon-custom.sel { color: var(--accent); }

/* Оформление записи: иконка-картинка + палитра в редакторе */
.appearance { display: flex; flex-wrap: wrap; gap: 16px; align-items: center; }
.ico-pick { display: flex; align-items: center; gap: 10px; }
.ico-preview { width: 52px; height: 52px; border-radius: 13px; flex-shrink: 0; overflow: hidden;
  display: grid; place-items: center; font-size: 22px; color: var(--muted);
  background: var(--input-bg); border: 1px dashed var(--border-strong); }
.ico-preview img { width: 100%; height: 100%; object-fit: cover; display: block; }
/* превью-иконка = кнопка загрузки (отдельной кнопки «Загрузить» больше нет) */
button.ico-preview { cursor: pointer; padding: 0; font: inherit; font-size: 22px;
  transition: border-color .15s, box-shadow .15s, color .15s; }
button.ico-preview:hover { border-color: var(--accent); color: var(--accent); box-shadow: 0 0 0 3px rgba(79,131,232,.16); }
button.ico-preview.readonly { cursor: default; pointer-events: none; }
/* Превью записи в режиме «аватар»: живой предпросмотр выбранного цвета карточки —
   цветной фон + тёмная жирная буква (как на самой карточке). */
.ico-preview.as-avatar { color: #051018; font-weight: 700; border-style: solid; border-color: transparent; }
button.ico-preview.as-avatar:hover { color: #051018; }
.ico-btns { display: flex; flex-direction: column; gap: 6px; }
.colors-host { flex: 1; min-width: 220px; }
.colors-host.readonly { pointer-events: none; opacity: .6; }
input[type=text], input[type=password], textarea {
  width: 100%; padding: 12px 14px; font-size: 15px; color: var(--text);
  background: var(--input-bg); border: 1px solid var(--border); border-radius: var(--radius-sm);
  outline: none; transition: border-color .15s, box-shadow .15s; font-family: inherit;
}
textarea { resize: vertical; }
input:focus, textarea:focus { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(79,131,232,.15); }
input::placeholder, textarea::placeholder { color: #4d586f; }

.pw-wrap { position: relative; display: flex; align-items: center; gap: 4px; }
.pw-wrap input { flex: 1; padding-right: 8px; }

/* --- Кнопки --- */
.btn {
  font: inherit; font-size: 14px; font-weight: 600; cursor: pointer;
  padding: 11px 18px; border-radius: var(--radius-sm); border: 1px solid transparent;
  transition: transform .08s, filter .15s, background .15s; color: var(--text);
}
.btn:active { transform: translateY(1px) scale(.99); }
.btn.block { width: 100%; margin-top: 6px; }
.btn.primary { background: var(--grad); color: #fff; border: none; box-shadow: 0 8px 24px rgba(79,131,232,.32); }
.btn.primary:hover { filter: brightness(1.08); }
.btn.subtle { background: var(--panel-2); border: 1px solid var(--border); }
.btn.subtle:hover { background: var(--border); }
.btn.danger-ghost { background: transparent; border: 1px solid rgba(244,63,94,.4); color: #ff8da0; }
.btn.danger-ghost:hover { background: rgba(244,63,94,.12); }
.btn:disabled { opacity: .45; cursor: not-allowed; }

.ghost-icon { background: transparent; border: none; color: var(--muted); cursor: pointer;
  font-size: 16px; padding: 6px 8px; border-radius: 8px; transition: background .15s, color .15s; }
.ghost-icon:hover { background: var(--panel-2); color: var(--text); }
.ghost-icon.big { font-size: 20px; }

.link { background: none; border: none; color: var(--accent); cursor: pointer; font: inherit;
  font-size: 13px; margin-top: 16px; display: block; width: 100%; text-align: center; }
.link:hover { text-decoration: underline; }

/* --- Индикатор надёжности --- */
.strength { height: 5px; background: rgba(255,255,255,.08); border-radius: 3px; margin-top: 8px; overflow: hidden; }
.strength-bar { height: 100%; width: 0; border-radius: 3px; transition: width .25s, background .25s; }
[data-theme="light"] .strength { background: rgba(28,41,74,.10); }   /* трек виден и на светлом фоне */
/* Индикатор надёжности под полем пароля записи: полоса + краткая подпись уровня */
.pw-strength { display: flex; align-items: center; gap: 10px; margin-top: 8px; }
.pw-strength .strength { flex: 1; margin-top: 0; }
.pw-strength .gen-strength-text { font-size: 12.5px; white-space: nowrap; }

.hint { font-size: 12.5px; color: var(--muted); margin: 4px 0 16px; line-height: 1.5;
  background: rgba(245,158,11,.07); border: 1px solid rgba(245,158,11,.18); padding: 10px 12px; border-radius: 10px; }
.hint.danger { background: rgba(244,63,94,.08); border-color: rgba(244,63,94,.22); color: #ffadbb; }
.error { color: #ff8da0; font-size: 13px; min-height: 18px; margin-top: 10px; text-align: center; }

.checkbox { display: flex; align-items: center; gap: 10px; font-size: 13.5px; color: var(--text); cursor: pointer; margin: 6px 0 18px; }
.checkbox input { width: 17px; height: 17px; accent-color: var(--accent); cursor: pointer; }

/* --- Двухфакторная аутентификация (TOTP) --- */
.totp-card { max-width: 420px; }
/* QR-код для сканирования аутентификатором: белая «карточка», чтобы код читался
   камерой независимо от темы оформления. SVG растягивается на всю ширину. */
.totp-qr { width: 200px; max-width: 70%; margin: 4px auto 16px; padding: 12px;
  background: #fff; border-radius: 12px; box-shadow: 0 1px 4px rgba(0,0,0,.18); }
.totp-qr svg { display: block; width: 100%; height: auto; }
.totp-secret-box { background: var(--input-bg); border: 1px solid var(--border); border-radius: 12px;
  padding: 14px; margin-bottom: 16px; }
.totp-secret-cap { display: block; font-size: 11px; text-transform: uppercase; letter-spacing: .6px; color: var(--muted); margin-bottom: 8px; }
.totp-secret-row { display: flex; align-items: center; gap: 8px; margin-bottom: 12px; }
#totp-secret { flex: 1; min-width: 0; font-family: ui-monospace, Menlo, Consolas, monospace; font-size: 15px;
  letter-spacing: 1px; word-break: break-all; color: var(--text); background: var(--code-bg);
  padding: 9px 11px; border-radius: 8px; }
#totp-code { text-align: center; font-family: ui-monospace, Menlo, Consolas, monospace; font-size: 24px;
  letter-spacing: 8px; font-weight: 700; }
a#totp-link { text-decoration: none; text-align: center; display: block; margin: 0; }
/* Бейдж статуса 2FA в карточке пользователя */
.totp-badge { font-size: 11px; font-weight: 600; padding: 2px 9px; border-radius: 999px; margin-left: 8px; vertical-align: middle; }
.totp-badge.on { background: rgba(34,197,94,.14); color: #6ee7a8; }
.totp-badge.off { background: rgba(136,136,153,.16); color: var(--muted); }
.totp-badge.wait { background: rgba(245,158,11,.14); color: var(--warn); }

/* --- Seed-фраза --- */
.seed-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 9px; margin: 8px 0 18px; }
.seed-word { display: flex; align-items: center; gap: 8px; background: var(--input-bg);
  border: 1px solid var(--border); border-radius: 10px; padding: 9px 11px; font-size: 14px; }
.seed-word b { color: var(--muted); font-size: 11px; min-width: 18px; font-weight: 600; }
.seed-actions { text-align: center; margin-bottom: 10px; }

/* --- Загрузчик --- */
.loader { width: 46px; height: 46px; border-radius: 50%;
  border: 3px solid rgba(255,255,255,.12); border-top-color: var(--accent); animation: spin .8s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* =========================== Главное окно =========================== */
#view-main { display: flex; flex-direction: column; }
.topbar {
  /* position+z-index обязательны: backdrop-filter создаёт у шапки собственный
     контекст наложения и «запирает» в нём выпадающее меню (.menu-pop, z-index:30).
     Без явного z-index шапка (контекст с z-index:auto) оказывается НИЖЕ .main-body
     (position:relative, идёт позже в DOM) — и содержимое страницы перекрывает меню,
     делая кнопку «Выйти» некликабельной. z-index:40 — выше тела, ниже модалок (50)/
     меню папки (60)/тостов (80). */
  position: relative; z-index: 40;
  display: flex; align-items: center; gap: 18px; padding: 12px 68px 12px 20px;
  border-bottom: 1px solid var(--border); background: var(--bar-bg); backdrop-filter: blur(14px);
}
.topbar-brand { display: flex; align-items: center; gap: 9px; font-weight: 700; font-size: 16px; }
.search { flex: 1; max-width: 520px; position: relative; }
.search input { padding-left: 38px; background: var(--input-bg); }
.search-ico { position: absolute; left: 13px; top: 50%; transform: translateY(-50%); color: var(--muted); font-size: 17px; }
.topbar-actions { display: flex; align-items: center; gap: 8px; margin-left: auto; }
.topbar-burger { display: none; }                       /* кнопка-гамбургер — только на узких экранах */
#add-btn .bico, #admin-btn .bico { margin-right: 6px; }
.sidebar-backdrop { display: none; }                    /* затемнение под выезжающим меню — только на мобиле */

.menu { position: relative; }
.menu-pop { position: absolute; right: 0; top: 44px; background: var(--bg2); border: 1px solid var(--border-strong);
  border-radius: 12px; box-shadow: var(--shadow); padding: 6px; min-width: 210px; z-index: 30; }
.menu-pop button { display: block; width: 100%; text-align: left; background: none; border: none; color: var(--text);
  padding: 10px 12px; border-radius: 8px; cursor: pointer; font: inherit; font-size: 14px; }
.menu-pop button:hover { background: var(--panel-2); }

/* --- Колокольчик уведомлений --- */
.notif { position: relative; }
#notif-btn { position: relative; }
.notif-badge { position: absolute; top: -1px; right: -1px; min-width: 17px; height: 17px; padding: 0 4px; box-sizing: border-box;
  display: inline-flex; align-items: center; justify-content: center; background: var(--danger); color: #fff;
  font-size: 10.5px; font-weight: 700; line-height: 1; border-radius: 9px; border: 2px solid var(--bar-bg); }
.notif-pop { position: absolute; right: 0; top: 44px; width: 340px; max-width: 86vw; background: var(--bg2);
  border: 1px solid var(--border-strong); border-radius: 14px; box-shadow: var(--shadow); z-index: 30; overflow: hidden; }
.notif-head { display: flex; align-items: center; justify-content: space-between;
  padding: 12px 14px; border-bottom: 1px solid var(--border); font-size: 13.5px; font-weight: 600; }
.link-sm { background: none; border: none; color: var(--accent); cursor: pointer; font: inherit; font-size: 12.5px; }
.link-sm:hover { text-decoration: underline; }
.link-sm.danger { color: var(--danger); }
.notif-actions { display: flex; gap: 14px; }
.notif-list { max-height: 60vh; overflow-y: auto; padding: 6px; }
.notif-item { display: flex; align-items: flex-start; gap: 10px; width: 100%; text-align: left; background: none;
  border: none; color: var(--text); padding: 10px; border-radius: 10px; cursor: pointer; font: inherit; }
.notif-item:hover { background: var(--panel-2); }
.notif-dot { flex-shrink: 0; width: 8px; height: 8px; margin-top: 5px; border-radius: 50%; background: transparent; }
.notif-item.unread .notif-dot { background: var(--accent); }
.notif-item.unread .notif-title { font-weight: 600; }
.notif-body { min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.notif-title { font-size: 13.5px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.notif-sub { font-size: 12px; color: var(--warn); }
.notif-sub.expired { color: var(--danger); }
.notif-empty { padding: 22px 14px; text-align: center; color: var(--muted); font-size: 13px; }

/* --- Статус временного пароля (просмотр записи + карточка списка) --- */
.temp-status { display: inline-flex; align-items: center; gap: 6px; font-size: 12.5px; font-weight: 600;
  padding: 4px 11px; border-radius: 999px; background: var(--accent-soft); color: var(--accent); }
.temp-status.soon { background: rgba(245,158,11,.13); color: var(--warn); }
.temp-status.expired { background: rgba(244,63,94,.13); color: var(--danger); }
.dp-temp-row { display: flex; flex-wrap: wrap; align-items: center; gap: 8px 12px; margin-bottom: 14px; }
.temp-reminders { font-size: 12.5px; color: var(--muted); margin-left: auto; }
.entry-temp { flex-shrink: 0; font-size: 12px; line-height: 1; margin-left: 4px; }
.entry-temp.soon { filter: none; }

.main-body { flex: 1; display: flex; overflow: hidden; position: relative; }
.sidebar { width: 230px; flex-shrink: 0; min-width: 160px; max-width: 520px;
  border-right: 1px solid var(--border); padding: 16px 12px; display: flex; flex-direction: column;
  background: var(--side-bg); }

/* ===================== Панель поиска (заменяет дерево) ===================== */
.search-panel { flex: 1; min-height: 0; display: flex; flex-direction: column; gap: 12px; }
.sf-head { display: flex; align-items: center; justify-content: space-between; }
.sf-title { font-size: 13px; font-weight: 600; color: var(--text); letter-spacing: .3px; }
.sf-scroll { flex: 1; min-height: 0; overflow-y: auto; display: flex; flex-direction: column; gap: 18px; padding-right: 2px; }
.sf-sec-cap { font-size: 11px; text-transform: uppercase; letter-spacing: .6px; color: var(--muted); margin-bottom: 9px; }
/* Цвета — ряд кружков-свотчей (показываем только реально используемые) */
.sf-colors { display: flex; flex-wrap: wrap; gap: 7px; align-items: center; }
.sf-color { width: 26px; height: 26px; border-radius: 50%; border: 1px solid var(--border-strong); cursor: pointer;
  display: grid; place-items: center; background: transparent; padding: 0; transition: transform .1s; }
.sf-color:hover { transform: scale(1.12); }
.sf-color .sf-dot { width: 18px; height: 18px; border-radius: 50%; background: var(--sf-c, var(--muted)); }
.sf-color.none .sf-dot { background: var(--panel-2); border: 1px dashed var(--border-strong); }
.sf-color.all { width: auto; height: 26px; border-radius: 13px; padding: 0 12px; font-size: 12px; color: var(--muted); }
.sf-color.active { border-color: var(--accent); box-shadow: 0 0 0 2px var(--accent-soft); }
.sf-color.all.active { color: var(--accent); }
/* Теги — каждый с новой строки + счётчик; прокрутка вместе с .sf-scroll */
.sf-tags { display: flex; flex-direction: column; gap: 4px; }
.sf-tag { display: flex; align-items: center; gap: 8px; width: 100%; text-align: left; padding: 8px 10px; border-radius: 9px;
  background: transparent; border: 1px solid transparent; cursor: pointer; color: var(--muted); font-size: 13px; transition: background .12s, color .12s; }
.sf-tag:hover { background: var(--panel); color: var(--text); }
.sf-tag.active { background: rgba(79,131,232,.12); color: var(--accent); border-color: rgba(79,131,232,.35); }
.sf-tag-name { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.sf-tag-n { flex-shrink: 0; font-size: 11px; background: var(--panel-2); padding: 1px 8px; border-radius: 10px; }
.sf-tag.active .sf-tag-n { background: rgba(79,131,232,.2); }
.sf-empty { padding: 10px; font-size: 13px; }
.sf-foot { flex-shrink: 0; }
#sf-reset { width: 100%; justify-content: center; }
/* Заголовок результатов поиска + чипы активных фильтров */
.sr-count { font-size: 13px; color: var(--muted); font-weight: 500; }
.sr-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 6px; }
.sr-chip { display: inline-flex; align-items: center; gap: 6px; padding: 3px 5px 3px 10px; border-radius: 14px;
  background: var(--panel-2); border: 1px solid var(--border); font-size: 12px; color: var(--text); }
.sr-chip-dot { width: 12px; height: 12px; border-radius: 50%; display: inline-block; flex-shrink: 0; }
.sr-chip-dot.none { border: 1px dashed var(--border-strong); }
.sr-chip-x { background: transparent; border: none; color: var(--muted); cursor: pointer; font-size: 12px; padding: 0 3px; line-height: 1; }
.sr-chip-x:hover { color: var(--danger); }
/* Перетаскиваемая граница сайдбара */
.sidebar-resizer { flex-shrink: 0; width: 6px; margin-left: -3px; cursor: col-resize; z-index: 5;
  background: transparent; transition: background .15s; position: relative; }
.sidebar-resizer::after { content: ''; position: absolute; inset: 0 2px; border-radius: 2px; }
.sidebar-resizer:hover::after, .sidebar-resizer.dragging::after { background: var(--accent); box-shadow: 0 0 10px rgba(79,131,232,.5); }
body.col-resizing { cursor: col-resize; user-select: none; }
#categories { display: flex; flex-direction: column; gap: 3px; flex: 1; overflow-y: auto; }
.cat { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border-radius: 10px; cursor: pointer;
  font-size: 14px; color: var(--muted); transition: background .12s, color .12s; border: 1px solid transparent; }
.cat:hover { background: var(--panel); color: var(--text); }
.cat.active { background: rgba(79,131,232,.12); color: var(--accent); border-color: rgba(79,131,232,.35); }
.cat .ico { width: 18px; text-align: center; }
.cat .count { margin-left: auto; font-size: 12px; background: var(--panel-2); padding: 1px 8px; border-radius: 10px; color: var(--muted); }
.sidebar-foot { font-size: 11.5px; padding: 8px 12px; }

.entries { flex: 1; overflow-y: auto; padding: 20px; display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 360px)); gap: 14px;
  /* grid-auto-rows: min-content — иначе при align-content:start строки грида схлопывают
     карточки (у .entry overflow:hidden обнуляет их авто-минимум), и аватар/действия
     обрезаются. min-content держит строку по натуральной высоте карточки. */
  grid-auto-rows: min-content;
  align-content: start; justify-content: start; }
.entry {
  background: var(--panel); border: 1px solid var(--border); border-radius: 14px; padding: 16px; cursor: pointer;
  transition: transform .12s, border-color .15s, background .15s; position: relative; overflow: hidden;
}
.entry::before { content: ''; position: absolute; inset: 0 auto 0 0; width: 3px; background: var(--grad); opacity: .8; }
.entry:hover { transform: translateY(-3px); border-color: var(--border-strong); background: var(--panel-2); }
.entry-top { display: flex; align-items: center; gap: 12px; margin-bottom: 10px; }
.avatar { width: 40px; height: 40px; border-radius: 11px; display: grid; place-items: center; font-weight: 700;
  font-size: 16px; color: #051018; flex-shrink: 0; overflow: hidden; }
.avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.entry-title { font-weight: 600; font-size: 15px; }
.entry-user { font-size: 13px; color: var(--muted); margin-top: 2px; word-break: break-all; }
.entry-meta { display: flex; align-items: center; gap: 8px; margin-top: 12px; }
.entry-fav { color: var(--warn); margin-left: auto; font-size: 14px; }
.entry-actions { display: flex; gap: 6px; }
.chip-btn { font-size: 12px; padding: 5px 10px; border-radius: 8px; background: var(--input-bg); border: 1px solid var(--border);
  color: var(--muted); cursor: pointer; transition: all .12s; }
.chip-btn:hover { color: var(--text); border-color: var(--accent); background: rgba(79,131,232,.1); }

/* --- Теги: чип-инпут в модалке --- */
.tags-input { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; min-height: 42px;
  padding: 7px 10px; background: var(--input-bg); border: 1px solid var(--border); border-radius: 10px; cursor: text; }
.tags-input:focus-within { border-color: var(--accent); }
.tags-input.readonly { cursor: default; }
.tags-chips { display: contents; }
.tag-chip { display: inline-flex; align-items: center; gap: 5px; font-size: 12.5px; line-height: 1;
  padding: 5px 8px; border-radius: 999px; background: rgba(79,131,232,.12); border: 1px solid #4f83e855; color: var(--text); }
.tag-x { border: none; background: none; color: var(--muted); cursor: pointer; font-size: 12px; padding: 0; line-height: 1; }
.tag-x:hover { color: var(--err, #ef4444); }
#f-tags-input { flex: 1; min-width: 90px; border: none; background: none; padding: 4px 2px; color: var(--text); font-size: 13px; outline: none; }

/* --- Теги: отображение на карточках/в списке --- */
.entry-tags { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 10px; }
.etag { font-size: 11px; line-height: 1; padding: 3px 8px; border-radius: 999px;
  background: var(--hover); border: 1px solid var(--border); color: var(--muted); white-space: nowrap; }
/* Строчный вид: теги показываем ЦЕЛИКОМ (не режем по буквам до «Сет…»). Каждый тег —
   полный, не сжимается; если в строку не влезают — лишнее мягко затухает справа. */
.entry-tags.inline { margin-top: 0; flex: 1 1 0; min-width: 0; overflow: hidden; flex-wrap: nowrap;
  -webkit-mask-image: linear-gradient(to right, #000 calc(100% - 16px), transparent);
          mask-image: linear-gradient(to right, #000 calc(100% - 16px), transparent); }
.entry-tags.inline .etag { flex-shrink: 0; }
/* Кнопка «Теги» (строчный вид, когда тегов много) + всплывающее окно со всеми тегами. */
.tags-chip { flex-shrink: 0; display: inline-flex; align-items: center; gap: 6px; font-size: 11px; line-height: 1;
  padding: 4px 9px; border-radius: 999px; background: var(--hover); border: 1px solid var(--border);
  color: var(--muted); font-family: inherit; cursor: pointer; transition: color .12s, border-color .12s; }
.tags-chip:hover { color: var(--text); border-color: var(--border-strong); }
.tags-chip-n { font-size: 10px; background: rgba(255,255,255,.10); padding: 0 5px; border-radius: 999px; }
.tags-pop { position: fixed; z-index: 80; display: none; flex-wrap: wrap; gap: 5px; max-width: 320px;
  padding: 8px; background: var(--bg2); border: 1px solid var(--border-strong); border-radius: 10px;
  box-shadow: var(--shadow); }

/* --- Переключатель вида (карточки / список) --- */
.view-switch { display: inline-flex; gap: 2px; background: var(--input-bg);
  border: 1px solid var(--border); border-radius: 9px; padding: 2px; flex-shrink: 0; }
.vs-btn { font-size: 14px; line-height: 1; padding: 5px 9px; border: none; border-radius: 7px; cursor: pointer;
  background: transparent; color: var(--muted); transition: background .12s, color .12s; }
.vs-btn:hover { color: var(--text); }
.vs-btn.active { background: var(--grad); color: #fff; }

/* --- Списочный вид --- */
.entries.as-list { display: flex; flex-direction: column; gap: 8px; max-width: 880px; }
.entry.row { display: flex; align-items: center; gap: 12px; padding: 10px 14px; margin: 0; }
.entry.row:hover { transform: none; }
.entry.row .avatar.sm { width: 32px; height: 32px; border-radius: 9px; font-size: 14px; }
/* фиксированная колонка имени — кнопки выстраиваются в ровный столбец */
.entry.row .row-main { flex: 0 0 170px; min-width: 0; display: flex; flex-direction: column; gap: 1px; }
.entry.row .entry-title { font-size: 14px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.entry.row .entry-user { margin-top: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.entry.row .entry-actions { flex-shrink: 0; }
.entry.row .entry-fav { margin-left: 0; }
.entry.row .row-loc { flex-shrink: 0; font-size: 11px; margin-left: 2px; }
@media (max-width: 620px) {
  .entry.row .row-main { flex-basis: 130px; }
  .entry.row .row-loc { display: none; }
}

/* Пагинатор — список записей (закреплён снизу прокручиваемого контейнера) и история действий */
.pager { display: flex; justify-content: center; align-items: center; gap: 6px; flex-wrap: wrap; padding: 12px 8px 6px; }
/* Пагинатор — в КОНЦЕ списка (полная ширина грида), а не «прилипший» ко дну:
   sticky/bottom давал эффект «висящей» панели поверх карточек при прокрутке. */
.entries .pager { grid-column: 1 / -1; margin-top: 6px;
  border-top: 1px solid var(--border);
  flex-wrap: nowrap; overflow-x: auto; justify-content: safe center; }
.pg-btn { min-width: 32px; height: 32px; padding: 0 9px; border-radius: 9px; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center; font-size: 13px;
  background: var(--panel); border: 1px solid var(--border); color: var(--text);
  transition: background .12s, border-color .12s, color .12s; }
.pg-btn:hover:not(:disabled):not(.active) { background: var(--panel-2); border-color: var(--border-strong); }
.pg-btn.active { background: var(--accent); border-color: var(--accent); color: #fff; cursor: default; }
.pg-btn:disabled { opacity: .4; cursor: default; }
.pg-gap { color: var(--muted); padding: 0 2px; user-select: none; }

.empty { grid-column: 1/-1; text-align: center; color: var(--muted); padding: 80px 20px; }
.empty .big { font-size: 52px; opacity: .35; margin-bottom: 14px; }

/* Подсветка записи, открытой в панели справа */
.entry.selected { border-color: var(--accent); background: var(--panel-2); }
.entry.selected::before { opacity: 1; width: 4px; }

/* =================== Панель просмотра записи (справа) =================== */
.detail-panel { width: 600px; flex-shrink: 0; min-width: 340px; max-width: 80vw;
  border-left: 1px solid var(--border);
  background: var(--side-bg); display: flex; flex-direction: column; overflow: hidden;
  animation: dp-in .18s ease; }
@keyframes dp-in { from { opacity: 0; transform: translateX(16px); } }
/* Перетаскиваемая ЛЕВАЯ граница панели записи — зеркало .sidebar-resizer (тянем
   влево → панель шире, вправо → уже). Сосед панели, поэтому переживает её перерисовку. */
.detail-resizer { flex-shrink: 0; width: 6px; margin-right: -3px; cursor: col-resize; z-index: 5;
  background: transparent; transition: background .15s; position: relative; }
.detail-resizer::after { content: ''; position: absolute; inset: 0 2px; border-radius: 2px; }
.detail-resizer:hover::after, .detail-resizer.dragging::after { background: var(--accent); box-shadow: 0 0 10px rgba(79,131,232,.5); }

/* просмотр и редактор делят панель: каждый — колонка во всю высоту со скроллом тела */
#dp-view, .dp-edit { flex: 1; min-height: 0; display: flex; flex-direction: column; }
.dp-edit-head { display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 16px 16px 12px; border-bottom: 1px solid var(--border); }
.dp-edit-head h3 { font-size: 16px; font-weight: 700; }
.dp-edit-body { flex: 1; overflow-y: auto; padding: 16px; }
.dp-edit-foot { display: flex; align-items: center; gap: 10px; padding: 14px 16px; border-top: 1px solid var(--border); }

.dp-head { display: flex; align-items: flex-start; gap: 12px; padding: 16px 16px 12px; border-bottom: 1px solid var(--border); }
.dp-id { display: flex; align-items: center; gap: 12px; min-width: 0; flex: 1; }
.dp-titles { min-width: 0; }
.dp-title { font-weight: 700; font-size: 16px; display: flex; align-items: center; gap: 6px; overflow: hidden; text-overflow: ellipsis; }
.dp-fav { color: var(--warn); }
/* Кликабельная звезда в заголовке записи — личное избранное (вкл/выкл). */
.dp-fav-btn { flex-shrink: 0; background: none; border: none; cursor: pointer; font-size: 17px; line-height: 1;
  color: var(--muted); padding: 2px 4px; border-radius: 6px; transition: color .12s, transform .12s; }
.dp-fav-btn:hover { color: var(--warn); transform: scale(1.18); }
.dp-fav-btn.on { color: var(--warn); }
.dp-sub { font-size: 12px; margin-top: 3px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dp-tools { display: flex; gap: 2px; flex-shrink: 0; }
.dp-tools .ghost-icon.danger:hover { color: #ff8da0; }

.dp-tabs { display: flex; gap: 4px; padding: 8px 12px 0; border-bottom: 1px solid var(--border); }
.dp-tab { background: none; border: none; border-bottom: 2px solid transparent; color: var(--muted);
  font: inherit; font-size: 13.5px; padding: 8px 10px; cursor: pointer; transition: color .12s, border-color .12s; }
.dp-tab:hover { color: var(--text); }
.dp-tab.active { color: var(--accent); border-bottom-color: var(--accent); }

.dp-body { flex: 1; overflow-y: auto; padding: 14px 16px; }

.dp-field { margin-bottom: 10px; }
.dp-label { font-size: 12px; color: var(--muted); margin-bottom: 4px; }
/* Все поля одной высоты (min-height) и с одинаковыми компактными отступами; одиночная
   строка вертикально по центру. Многострочные значения (заметки) растут вниз — там текст
   и кнопки прижаты к верху. */
.dp-val { display: flex; align-items: center; gap: 6px; min-height: 42px; background: var(--input-bg);
  border: 1px solid var(--border); border-radius: 10px; padding: 6px 6px 6px 12px; }
.dp-val:has(.dp-notes) { align-items: flex-start; padding-top: 9px; padding-bottom: 9px; }
.dp-text { flex: 1; min-width: 0; font-size: 14px; word-break: break-word; line-height: 1.45; }
.dp-pass { font-family: ui-monospace, Menlo, Consolas, monospace; letter-spacing: 1px; }
.dp-notes { white-space: pre-wrap; }
.dp-link { color: var(--accent); text-decoration: none; word-break: break-all; }
.dp-link:hover { text-decoration: underline; }
.dp-acts { display: flex; gap: 1px; flex-shrink: 0; }
.dp-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.dp-meta { font-size: 11.5px; margin-top: 18px; padding-top: 12px; border-top: 1px solid var(--border); line-height: 1.6; }

/* Вкладка «История действий» — лента */
.dp-timeline { display: flex; flex-direction: column; }
.dp-evt { display: flex; gap: 11px; padding: 10px 0; border-bottom: 1px solid var(--border); }
.dp-evt:last-child { border-bottom: none; }
.dp-evt-ico { width: 28px; height: 28px; border-radius: 8px; flex-shrink: 0; display: grid; place-items: center;
  background: var(--panel-2); font-size: 14px; }
.dp-evt-main { min-width: 0; flex: 1; }
.dp-evt-text { font-size: 13.5px; line-height: 1.4; word-break: break-word; }
.dp-evt-det { color: var(--muted); }
.dp-evt-time { font-size: 11.5px; margin-top: 2px; }
.dp-empty { text-align: center; padding: 44px 10px; }
.dp-loading { display: grid; place-items: center; padding: 44px 10px; }
.loader.small { width: 26px; height: 26px; border-width: 3px; }

/* Узкие экраны: панель выезжает поверх списка записей (ресайз отключён) */
@media (max-width: 880px) {
  .detail-panel { position: absolute; top: 0; right: 0; bottom: 0; width: min(420px, 100%);
    max-width: 100%; z-index: 20; box-shadow: -12px 0 40px rgba(0,0,0,.4); }
  .detail-resizer { display: none; }
}

/* =========================== Модалки =========================== */
.modal-backdrop { position: fixed; inset: 0; background: rgba(3,5,12,.7); backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center; z-index: 50; padding: 20px; }
.modal { width: 100%; max-width: 520px; background: var(--bg2); border: 1px solid var(--border-strong);
  border-radius: 18px; box-shadow: var(--shadow); max-height: 92vh; display: flex; flex-direction: column;
  animation: pop .18s ease; }
.modal.small { max-width: 420px; }
@keyframes pop { from { transform: scale(.95) translateY(10px); opacity: 0; } }
.modal-head { display: flex; align-items: center; justify-content: space-between; padding: 18px 22px; border-bottom: 1px solid var(--border); }
.modal-head h3 { font-size: 17px; }
.modal-body { padding: 20px 22px; overflow-y: auto; }
/* Мини-модалка короткая (одно-два поля) — собственная прокрутка ей не нужна, а
   видимое переполнение даёт выпадающему списку папок выходить за её края (см. .drop-up). */
#mini-body { overflow: visible; }
.modal-foot { display: flex; align-items: center; gap: 10px; padding: 16px 22px; border-top: 1px solid var(--border); }
.spacer { flex: 1; }

/* --- Доп. поля записи (логины/пароли/произвольные) --- */
.add-field-btn { margin: -4px 0 18px; display: inline-flex; }
.xfield { margin-bottom: 12px; }
.xfield > span { display: block; font-size: 13px; color: var(--muted); margin-bottom: 7px; }
.xfield-head { display: flex; align-items: center; gap: 6px; margin-bottom: 7px; }
.xfield-head .xname { flex: 1; padding: 8px 12px; font-size: 13.5px; font-weight: 600; }
.xfield .del-field:hover { color: #ff8da0; }

/* --- TOTP в просмотре: крупный код + кольцо обратного отсчёта (как в Authenticator) --- */
.totp-code { font-size: 19px; letter-spacing: 2px; cursor: pointer; }
.totp-code:not(.muted):hover { color: var(--accent); }
.totp-ring-wrap { display: inline-grid; place-items: center; width: 22px; height: 22px; margin-right: 2px; }
.totp-ring { width: 22px; height: 22px; transform: rotate(-90deg); }
.totp-ring-bg { fill: none; stroke: var(--border-strong); stroke-width: 3; }
.totp-ring-fg { fill: none; stroke: var(--accent); stroke-width: 3.4; stroke-linecap: round;
  transition: stroke-dasharray .25s linear; }
.totp-row.totp-soon .totp-ring-fg { stroke: var(--warn); transition: none; }
.totp-row.totp-soon .totp-code { color: var(--warn); }

/* --- TOTP: компактная настройка в форме --- */
.xtotp { background: var(--panel-2); border: 1px solid var(--border); border-radius: 12px; padding: 12px 12px 10px; }
.xtotp .totp-secret { flex: 1; min-width: 0; font-family: ui-monospace, Menlo, Consolas, monospace; letter-spacing: .5px; }
.totp-preview { flex-shrink: 0; min-width: 84px; text-align: center; font-family: ui-monospace, Menlo, Consolas, monospace;
  font-size: 15px; letter-spacing: 1.5px; color: var(--accent); padding: 0 4px; }
.totp-preview.muted { color: var(--muted); font-size: 13px; letter-spacing: 0; }
.totp-adv { margin-top: 9px; }
.totp-adv-toggle { background: transparent; border: none; color: var(--muted); cursor: pointer; font-size: 12px; padding: 2px 0; }
.totp-adv-toggle:hover { color: var(--text); }
.totp-adv-body { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 9px; }
.totp-opt { display: flex; flex-direction: column; gap: 4px; font-size: 11.5px; color: var(--muted); }
.totp-opt select, .totp-opt input { padding: 7px 9px; font-size: 13px; }
.totp-opt .totp-period { width: 84px; }

/* --- Вложения --- */
.att-section { margin-top: 4px; }
.att-list { display: flex; flex-direction: column; gap: 6px; margin: 4px 0 10px; }
.att-item { display: flex; align-items: center; gap: 10px; background: var(--input-bg);
  border: 1px solid var(--border); border-radius: 10px; padding: 8px 12px; }
.att-item.staged { border-style: dashed; }
.att-name { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  color: var(--accent); text-decoration: none; font-size: 13.5px; }
a.att-name:hover { text-decoration: underline; }
.att-size { flex-shrink: 0; font-size: 12px; color: var(--muted); }
.att-del:hover { color: #ff8da0; }
.att-empty { font-size: 13px; padding: 6px 2px; }

.gen-output { display: flex; align-items: center; gap: 8px; background: var(--code-bg); border: 1px solid var(--border);
  border-radius: 10px; padding: 12px 14px; margin-bottom: 16px; }
.gen-output code { flex: 1; font-family: "Cascadia Code", Consolas, monospace; font-size: 16px; letter-spacing: .3px;
  word-break: break-all; color: var(--accent); min-height: 20px; }
.gen-opts { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 6px; }
.gen-opts .checkbox { margin: 0; }
input[type=range] { width: 100%; accent-color: var(--accent); }

/* ===================== Расширенный генератор пароля ===================== */
.modal.gen-modal { max-width: 760px; }
#gen-regen { font-size: 17px; }

/* Две колонки: слева параметры пароля, справа правила генерации */
.gen-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: start; }
.gen-col { min-width: 0; }
.gen-col-cap { display: block; font-size: 13px; color: var(--muted); margin-bottom: 11px; }
@media (max-width: 640px) { .gen-cols { grid-template-columns: 1fr; gap: 0; } }

/* --- Блок «проверка на безопасность» --- */
.gen-sec { background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius-sm);
  padding: 13px 15px; margin-bottom: 18px; }
.gen-sec-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 9px; }
.gen-sec-cap { font-size: 12.5px; color: var(--muted); }
.gen-strength-text { font-size: 13.5px; font-weight: 700; color: var(--muted); }
.gen-strength-text.vweak  { color: var(--danger); }
.gen-strength-text.weak   { color: #fb923c; }
.gen-strength-text.mid    { color: var(--warn); }
.gen-strength-text.strong { color: var(--ok); }
.gen-strength-text.vstrong{ color: var(--accent3); }
.gen-sec .strength { height: 7px; margin-top: 0; }
.strength-bar.vweak  { background: var(--danger); }
.strength-bar.weak   { background: #fb923c; }
.strength-bar.mid    { background: var(--warn); }
.strength-bar.strong { background: var(--ok); }
.strength-bar.vstrong{ background: linear-gradient(90deg, var(--ok), var(--accent3)); }
.gen-sec-meta { display: flex; flex-wrap: wrap; gap: 6px 18px; margin-top: 11px; font-size: 12.5px; color: var(--muted); }
.gen-sec-meta b { color: var(--text); font-variant-numeric: tabular-nums; }

/* --- Длина --- */
.gen-len-field { margin-bottom: 18px; }
.gen-len-head { display: flex; align-items: baseline; justify-content: space-between; }
.gen-len-head b { font-size: 17px; color: var(--accent); font-variant-numeric: tabular-nums; }
.gen-range-hint { display: flex; justify-content: space-between; font-size: 11px; color: var(--muted); margin-top: 2px; }

/* --- Карточки типов символов (один столбец — полный образец набора виден) --- */
.gen-types { display: grid; grid-template-columns: 1fr; gap: 8px; margin-top: 6px; }
.gen-type { display: block; cursor: pointer; margin: 0; }
.gen-type input { position: absolute; opacity: 0; pointer-events: none; }
.gen-type-card { display: flex; align-items: center; gap: 10px; position: relative; height: 100%;
  background: var(--input-bg); border: 1.5px solid var(--border); border-radius: var(--radius-sm);
  padding: 11px 12px; transition: border-color .15s, background .15s; }
.gen-type:hover .gen-type-card { border-color: var(--border-strong); }
.gen-type input:checked + .gen-type-card { border-color: var(--accent); background: var(--accent-soft); }
.gen-type-ico { flex-shrink: 0; width: 30px; height: 30px; display: grid; place-items: center;
  background: var(--accent-soft); color: var(--accent); border-radius: 8px;
  font-family: "Cascadia Code", Consolas, monospace; font-weight: 700; font-size: 15px; }
.gen-type-body { min-width: 0; flex: 1; display: flex; flex-direction: column; gap: 2px; }
.gen-type-title { font-size: 13px; font-weight: 600; color: var(--text); }
.gen-type-sample { font-family: "Cascadia Code", Consolas, monospace; font-size: 10.5px; color: var(--muted);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.gen-type-check { flex-shrink: 0; width: 20px; height: 20px; display: grid; place-items: center;
  border: 1.5px solid var(--border-strong); border-radius: 50%; color: transparent; font-size: 12px;
  transition: background .15s, border-color .15s, color .15s; }
.gen-type input:checked + .gen-type-card .gen-type-check { background: var(--accent); border-color: var(--accent); color: #fff; }

/* --- Доп. правила: переключатели-тумблеры --- */
.gen-rules { display: flex; flex-direction: column; gap: 12px; margin: 4px 0 18px; }
.gen-switch { display: flex; align-items: center; gap: 12px; cursor: pointer; margin: 0; font-size: 13px; color: var(--text); }
.gen-switch > span:first-child { flex: 1; line-height: 1.35; }
.gen-switch input { position: absolute; opacity: 0; pointer-events: none; }
.gen-switch-track { flex-shrink: 0; width: 40px; height: 22px; border-radius: 22px;
  background: var(--border-strong); position: relative; transition: background .18s; }
.gen-switch-thumb { position: absolute; top: 3px; left: 3px; width: 16px; height: 16px; border-radius: 50%;
  background: #fff; transition: transform .18s; box-shadow: 0 1px 3px rgba(0,0,0,.3); }
.gen-switch input:checked + .gen-switch-track { background: var(--accent); }
.gen-switch input:checked + .gen-switch-track .gen-switch-thumb { transform: translateX(18px); }
.gen-switch input:focus-visible + .gen-switch-track { outline: 2px solid var(--accent3); outline-offset: 2px; }

/* --- Сегментный выбор «начать/закончить с» (стопкой в правой колонке) --- */
.gen-seg-field { margin-bottom: 16px; }
.gen-seg-field:last-child { margin-bottom: 0; }
.gen-seg { display: flex; gap: 3px; background: var(--input-bg); border: 1px solid var(--border);
  border-radius: 10px; padding: 3px; }
.gen-seg button { flex: 1; padding: 7px 2px; font: inherit; font-size: 11.5px; border: none; background: transparent;
  color: var(--muted); border-radius: 7px; cursor: pointer; white-space: nowrap; transition: background .15s, color .15s; }
.gen-seg button:hover { color: var(--text); }
.gen-seg button.active { background: var(--accent); color: #fff; }

/* --- Советы по безопасности --- */
.gen-tips { margin-top: 18px; border: 1px solid var(--border); border-radius: var(--radius-sm);
  background: var(--panel); padding: 0 14px; }
.gen-tips summary { cursor: pointer; list-style: none; padding: 12px 0; font-size: 13.5px; font-weight: 600; color: var(--text); }
.gen-tips summary::-webkit-details-marker { display: none; }
.gen-tips summary::after { content: '▾'; float: right; color: var(--muted); transition: transform .18s; }
.gen-tips[open] summary::after { transform: rotate(180deg); }
.gen-tips-list { margin: 0; padding: 0 0 12px 20px; display: flex; flex-direction: column; gap: 8px;
  font-size: 12.5px; line-height: 1.5; color: var(--muted); }
.gen-tips-list b { color: var(--text); }

/* ===================== Временный пароль (форма записи) ===================== */
.pwtype-seg { max-width: 320px; }
.gen-seg.seg-disabled { opacity: .55; pointer-events: none; }
.temp-config { border: 1px solid var(--border); border-left: 3px solid var(--accent); border-radius: var(--radius-sm);
  background: var(--panel); padding: 14px; margin: -6px 0 16px; }
.temp-dates { display: flex; gap: 12px; }
.temp-dates .field { flex: 1; margin-bottom: 12px; }
.temp-config input[type=date], .temp-notify input[type=number] {
  width: 100%; padding: 9px 11px; background: var(--input-bg); color: var(--text);
  border: 1px solid var(--border); border-radius: var(--radius-sm); font: inherit; }
.temp-config input[type=date] { color-scheme: dark; }
[data-theme="light"] .temp-config input[type=date] { color-scheme: light; }
#f-notify-btn { margin-bottom: 0; }
.temp-notify { margin-top: 12px; }
.notify-cfg-cap { display: block; font-size: 12.5px; color: var(--muted); margin-bottom: 9px; }
.offset-chips { display: flex; flex-wrap: wrap; gap: 7px; min-height: 8px; margin-bottom: 10px; }
.offset-chip { display: inline-flex; align-items: center; gap: 6px; background: var(--accent-soft); color: var(--accent);
  border: 1px solid rgba(79,131,232,.3); border-radius: 999px; padding: 4px 6px 4px 11px; font-size: 12.5px; font-weight: 600; }
.offset-del { background: none; border: none; color: var(--accent); cursor: pointer; font-size: 12px; line-height: 1;
  padding: 2px 4px; border-radius: 50%; }
.offset-del:hover { background: rgba(79,131,232,.2); }
.offset-empty { font-size: 12.5px; color: var(--muted); font-style: italic; }
.offset-add { display: flex; gap: 8px; }
.offset-add input { flex: 1; max-width: 120px; padding: 8px 11px; background: var(--input-bg); color: var(--text);
  border: 1px solid var(--border); border-radius: var(--radius-sm); font: inherit; }
.offset-add .btn { margin: 0; flex-shrink: 0; }
.offset-presets { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; margin-top: 10px; font-size: 12px; }
.offset-presets button { background: var(--input-bg); border: 1px solid var(--border); color: var(--muted);
  border-radius: 8px; padding: 4px 10px; cursor: pointer; font: inherit; font-size: 12px; }
.offset-presets button:hover { color: var(--text); border-color: var(--border-strong); }
.temp-config.ro .offset-add, .temp-config.ro .offset-presets { display: none; }
.temp-hint { margin: 12px 0 0; }

/* --- Тост --- */
.toast { position: fixed; bottom: calc(26px + env(safe-area-inset-bottom)); left: 50%; transform: translateX(-50%) translateY(20px);
  background: var(--bg2); border: 1px solid var(--border-strong); color: var(--text); padding: 12px 20px;
  border-radius: 12px; box-shadow: var(--shadow); font-size: 14px; opacity: 0; transition: all .25s; z-index: 80; }
.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }
.toast.ok { border-color: rgba(34,197,94,.4); }
.toast.err { border-color: rgba(244,63,94,.4); }

::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-thumb { background: rgba(255,255,255,.1); border-radius: 6px; border: 2px solid transparent; background-clip: padding-box; }
::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,.2); background-clip: padding-box; }

/* =========================== Multi-user добавления =========================== */
select {
  width: 100%; padding: 11px 14px; font: inherit; font-size: 15px; color: var(--text);
  background: var(--input-bg); border: 1px solid var(--border); border-radius: var(--radius-sm); outline: none;
}
select:focus { border-color: var(--accent); }
select option { background: var(--bg2); }

/* Кастомный выбор папки (с цветными иконками вместо нативного <select>) */
.cdrop { position: relative; }
.cdrop-btn { width: 100%; display: flex; align-items: center; gap: 8px; padding: 11px 14px;
  font: inherit; font-size: 15px; color: var(--text); background: var(--input-bg);
  border: 1px solid var(--border); border-radius: var(--radius-sm); cursor: pointer; text-align: left;
  transition: border-color .15s; }
.cdrop-btn:hover { border-color: var(--border-strong); }
.cdrop.open .cdrop-btn { border-color: var(--accent); }
.cdrop-cur { flex: 1; min-width: 0; display: flex; align-items: center; gap: 8px; overflow: hidden; }
.cdrop-label { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cdrop-caret { flex-shrink: 0; color: var(--muted); font-size: 12px; transition: transform .15s; }
.cdrop.open .cdrop-caret { transform: rotate(180deg); }
.cdrop-menu { position: absolute; left: 0; right: 0; top: calc(100% + 4px); z-index: 30;
  max-height: 240px; overflow-y: auto; background: var(--bg2); border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm); box-shadow: var(--shadow); padding: 5px; }
.cdrop-item { width: 100%; display: flex; align-items: center; gap: 8px; padding: 9px 10px;
  background: transparent; border: none; border-radius: 8px; cursor: pointer; color: var(--text);
  font: inherit; font-size: 14px; text-align: left; }
.cdrop-item:hover { background: var(--hover); }
.cdrop-item.sel { background: var(--accent-soft); color: var(--accent); }
.cdrop-empty { padding: 12px; font-size: 13px; text-align: center; }
.cdrop-disabled { opacity: .65; pointer-events: none; }
/* Выпадающий список папок внутри мини-модалки (восстановление из корзины) не должен
   обрезаться телом модалки и порождать его прокрутку: разрешаем меню выходить за края
   (#mini-body перекрывает overflow от .modal-body) и открываем его ВВЕРХ — над кнопкой. */
.cdrop.drop-up .cdrop-menu { top: auto; bottom: calc(100% + 4px); }


/* --- Меню пользователя --- */
.menu-user { padding: 8px 12px 10px; border-bottom: 1px solid var(--border); margin-bottom: 6px; }
.menu-user b { display: block; font-size: 14px; }
.menu-user span { font-size: 12px; color: var(--muted); }

/* --- Дерево офис -> папка --- */
#tree { display: flex; flex-direction: column; gap: 2px; overflow-y: auto; }
.tree-all { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border-radius: 10px; cursor: pointer;
  font-size: 14px; color: var(--muted); border: 1px solid transparent; }
.tree-all:hover { background: var(--panel); color: var(--text); }
.tree-all.active { background: rgba(79,131,232,.12); color: var(--accent); border-color: rgba(79,131,232,.35); }
/* «Избранное»: золотая звезда + счётчик, выровненный вправо (как у папок) */
.fav-ico { color: var(--warn); }
.trash-ico { font-size: 12px; }
.tree-all .count { margin-left: auto; flex-shrink: 0; font-size: 11px; background: var(--panel-2);
  padding: 1px 7px; border-radius: 10px; color: var(--muted); }

/* --- Корзина: карточки, мета (кто/откуда/когда), действия, фильтры по удалившему --- */
.trash-card:hover { transform: none; }                 /* не "приподнимаем" — действуют кнопки */
.trash-meta { display: flex; flex-wrap: wrap; align-items: center; gap: 6px 12px; margin-top: 10px; font-size: 12px; color: var(--muted); }
.trash-meta .tmeta-from { display: inline-flex; align-items: center; gap: 5px; min-width: 0; }
.trash-meta .tmeta-from .kind svg { width: 13px; height: 13px; }
.trash-meta .tmeta-time { margin-left: auto; flex-shrink: 0; }
.trash-actions { display: flex; gap: 8px; margin-top: 12px; }
.trash-filters { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; }
.tchip { display: inline-flex; align-items: center; gap: 6px; padding: 5px 11px; border-radius: 999px;
  background: var(--panel-2); border: 1px solid transparent; color: var(--muted); cursor: pointer; font-size: 13px; }
.tchip:hover { color: var(--text); }
.tchip.active { background: var(--accent-soft); border-color: rgba(79,131,232,.35); color: var(--accent); }
.tchip-n { font-size: 11px; background: rgba(255,255,255,.10); padding: 0 6px; border-radius: 999px; }

/* --- Импортированные: иконка в дереве, карточки, мета, действия --- */
.imported-ico { font-size: 13px; }
.imported-card:hover { transform: none; }               /* не "приподнимаем" — действуют кнопки */
.imported-card .entry-sub { font-size: 12px; margin-top: 2px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.imported-meta { display: flex; flex-wrap: wrap; align-items: center; gap: 6px 12px; margin-top: 10px; font-size: 12px; color: var(--muted); }
.imported-meta .tmeta-time { margin-left: auto; flex-shrink: 0; }
.imp-src { display: inline-flex; align-items: center; max-width: 170px; overflow: hidden; text-overflow: ellipsis;
  white-space: nowrap; background: var(--panel-2); padding: 1px 8px; border-radius: 999px; }
.imported-actions { display: flex; gap: 8px; margin-top: 12px; }
.imported-head-actions { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 10px; }

/* --- Мастер импорта паролей --- */
.import-modal { max-width: 640px; width: 100%; }
.imp-drop { border: 2px dashed var(--border-strong); border-radius: 14px; padding: 34px 24px; text-align: center;
  cursor: pointer; transition: border-color .15s, background .15s; }
.imp-drop:hover, .imp-drop.drag { border-color: var(--accent); background: var(--accent-soft); }
.imp-drop-ico { font-size: 40px; line-height: 1; }
.imp-drop-main { margin-top: 12px; font-size: 15px; }
.imp-drop-sub { margin-top: 12px; font-size: 12.5px; line-height: 1.55; }
.imp-fileinfo { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; padding: 10px 12px;
  background: var(--panel-2); border-radius: 10px; font-size: 13px; }
.imp-opts { display: flex; flex-wrap: wrap; gap: 12px 18px; margin: 16px 0; align-items: center; }
.imp-opt { display: inline-flex; align-items: center; gap: 8px; font-size: 13px; color: var(--text); }
.imp-check { cursor: pointer; }
.imp-check input { width: 16px; height: 16px; accent-color: var(--accent); cursor: pointer; }
.imp-opt select, .imp-map-sel { padding: 8px 10px; font-size: 13px; color: var(--text); font-family: inherit;
  background: var(--input-bg); border: 1px solid var(--border); border-radius: var(--radius-sm); outline: none; cursor: pointer; }
.imp-opt select:focus, .imp-map-sel:focus { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(79,131,232,.15); }
.imp-map-cap, .imp-preview-cap { font-size: 13px; font-weight: 600; margin: 6px 0 8px; }
.imp-preview-cap { margin-top: 16px; }
.imp-map-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px 16px; }
.imp-map-row { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.imp-map-label { font-size: 12px; color: var(--muted); }
.imp-map-sel { width: 100%; }
.imp-preview-wrap { margin-top: 4px; max-height: 230px; overflow: auto; border: 1px solid var(--border); border-radius: 10px; }
.imp-preview { width: 100%; border-collapse: collapse; font-size: 12.5px; }
.imp-preview th { text-align: left; padding: 8px 10px; position: sticky; top: 0; z-index: 1;
  background: var(--panel-2); color: var(--muted); font-weight: 600; }
.imp-preview td { padding: 7px 10px; border-top: 1px solid var(--border); max-width: 180px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.imp-preview .imp-url { color: var(--muted); }
.imp-mask { letter-spacing: 2px; color: var(--muted); }

/* --- Множественный выбор: чекбоксы на карточках + панель массовых действий --- */
/* Чекбокс — лишь индикатор и виден ТОЛЬКО в режиме выбора (.entries.selecting). Вне его
   карточка по клику открывается — никаких «невидимых, но кликабельных» углов. В режиме
   выбора цель клика — вся карточка (pointer-events:none пропускает клик к ней). */
.sel-box { display: none; position: absolute; top: 9px; left: 9px; z-index: 4; width: 20px; height: 20px; padding: 0;
  border-radius: 6px; border: 2px solid var(--border-strong); background: var(--bg2); pointer-events: none;
  transition: background .12s, border-color .12s; place-items: center; }
.entries.selecting .sel-box { display: grid; }
.sel-box.on { background: var(--accent); border-color: var(--accent); }
.sel-box.on::after { content: '✓'; color: #fff; font-size: 13px; font-weight: 800; line-height: 1; }
.entry.sel-on { border-color: var(--accent); }
.entry.sel-on::before { opacity: 1; width: 4px; }                /* акцентная полоса слева — как у выбранной */
/* В режиме выбора вся карточка — цель клика; лёгкая подсветка при наведении */
.entries.selecting .entry { cursor: pointer; }
.entries.selecting .entry:hover { border-color: var(--accent); }
/* В списочном виде чекбокс — в потоке слева (не оверлей) */
.entry.row .sel-box { position: static; flex-shrink: 0; }

/* Полоса массовых действий — отдельной строкой под шапкой раздела (между заголовком и
   списком). Появляется только в режиме выбора. Не оверлей — ничего не перекрывает и
   не сталкивается с пагинатором. */
.bulkbar { display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  margin: 10px 20px 0; padding: 8px 12px; background: var(--bg2); border: 1px solid var(--border-strong);
  border-radius: 12px; box-shadow: var(--shadow); }
.bulk-count { font-size: 13px; color: var(--text); white-space: nowrap; margin-right: 2px; }
.bulk-count b { color: var(--accent); }
/* Кнопка массового действия: иконка + подпись. На десктопе видно обе части;
   на мобиле подпись прячется (см. брейкпоинт) — кнопка становится компактной иконкой. */
.bulk-btn { display: inline-flex; align-items: center; gap: 6px; }
.bulk-btn .bl-ico { line-height: 1; }
/* Правый блок шапки: переключатель вида + кнопка «Выбрать» (всегда у правого края) */
.head-right { margin-left: auto; display: inline-flex; align-items: center; gap: 8px; flex-shrink: 0; }
.select-toggle { font-size: 13px; padding: 6px 12px; border-radius: 9px; cursor: pointer; white-space: nowrap;
  border: 1px solid var(--border-strong); background: var(--input-bg); color: var(--text);
  display: inline-flex; align-items: center; gap: 6px; transition: border-color .12s, color .12s, background .12s; }
.select-toggle:hover { border-color: var(--accent); color: var(--accent); }
.select-toggle.active { background: var(--grad); color: #fff; border-color: transparent; }
.tree-office { margin-top: 8px; }
.tree-office-name { display: flex; align-items: center; gap: 7px; padding: 8px 10px; font-size: 12px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .4px; color: var(--muted); cursor: pointer; border-radius: 8px; }
.tree-office-name:hover { background: var(--panel); }
.tree-office-name .city { color: var(--accent); flex-shrink: 0; }
.tree-folder { display: flex; align-items: center; gap: 6px; padding: 9px 12px 9px 10px; border-radius: 10px; cursor: pointer;
  font-size: 14px; color: var(--muted); border: 1px solid transparent; }
.tree-folder:hover { background: var(--panel); color: var(--text); }
.tree-folder.active { background: rgba(79,131,232,.12); color: var(--accent); border-color: rgba(79,131,232,.35); }
/* Иконка папки — общая для дерева, прав, групп и любых других мест */
.kind { flex-shrink: 0; color: var(--folder-ic); display: inline-flex; align-items: center; }
.kind svg { width: 15px; height: 15px; display: block; }
/* Папка со своей картинкой-иконкой (приоритет над набором) */
.kind-img img { width: 16px; height: 16px; border-radius: 4px; object-fit: cover; display: block; }
.trash-meta .tmeta-from .kind-img img { width: 14px; height: 14px; border-radius: 3px; }
.tree-folder .count { margin-left: auto; flex-shrink: 0; font-size: 11px; background: var(--panel-2); padding: 1px 7px; border-radius: 10px; }
/* папка видна только как путь к доступной вложенной — выбрать её нельзя */
.tree-folder.no-access { opacity: .5; cursor: default; font-style: italic; }
.tree-folder.no-access:hover { background: transparent; color: var(--muted); }
.tree-folder.no-access .kind { filter: grayscale(1); }
.na-tag { margin-left: auto; flex-shrink: 0; font-size: 10px; padding: 1px 7px; border-radius: 10px;
  color: var(--muted); border: 1px solid var(--border); white-space: nowrap; }
.tree-empty { color: var(--muted); font-size: 13px; padding: 16px 12px; line-height: 1.5; }
/* стрелки сворачивания + обрезка длинных имён */
.tw-toggle { flex: 0 0 18px; height: 20px; display: inline-flex; align-items: center; justify-content: center;
  font-size: 15px; color: var(--muted); cursor: pointer; user-select: none; }
.tw-toggle:not(.blank):hover { color: var(--accent); }
.tw-toggle.blank { visibility: hidden; cursor: default; }
.tf-name { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.to-name { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; min-width: 0; }
/* админ-управление структурой в дереве */
.tree-add-office { width: 100%; margin-bottom: 8px; padding: 9px; border-radius: 10px; border: 1px dashed var(--border-strong);
  background: transparent; color: var(--accent); cursor: pointer; font: inherit; font-size: 13px; font-weight: 600; }
.tree-add-office:hover { background: rgba(79,131,232,.08); border-color: var(--accent); }
/* панель инструментов дерева — «Свернуть всё / Развернуть всё» */
.tree-toolbar { display: flex; justify-content: flex-end; margin-bottom: 6px; }
.tree-tool-btn { padding: 4px 9px; border-radius: 8px; border: 1px solid var(--border);
  background: var(--panel-2); color: var(--muted); cursor: pointer; font: inherit; font-size: 12px; line-height: 1.2; }
.tree-tool-btn:hover { color: var(--text); border-color: var(--accent); background: rgba(79,131,232,.12); }
.tree-folder, .tree-office-name { position: relative; }
.tree-actions { display: none; position: absolute; right: 6px; top: 50%; transform: translateY(-50%);
  align-items: center; gap: 3px; padding-left: 18px; background: linear-gradient(90deg, transparent, var(--bg2) 35%); }
.tree-folder:hover .tree-actions, .tree-office-name:hover .tree-actions { display: flex; }
.ta-btn { width: 22px; height: 22px; flex-shrink: 0; border-radius: 6px; border: 1px solid var(--border);
  background: var(--panel-2); color: var(--muted); cursor: pointer; font-size: 12px; line-height: 1;
  display: inline-flex; align-items: center; justify-content: center; padding: 0; }
.ta-btn:hover { color: var(--text); border-color: var(--accent); background: rgba(79,131,232,.16); }
.ta-btn.danger:hover { color: #ff8da0; border-color: rgba(244,63,94,.45); background: rgba(244,63,94,.14); }
/* кнопка перемещения на краю списка (первая «выше» / последняя «ниже») — недоступна */
.ta-btn:disabled { opacity: .26; cursor: default; pointer-events: none; }

/* Меню действий папки («⋯») — крепится к body, поэтому не обрезается деревом */
.folder-menu { position: fixed; z-index: 60; background: var(--bg2); border: 1px solid var(--border-strong);
  border-radius: 10px; box-shadow: var(--shadow); padding: 5px; min-width: 188px; }
.folder-menu button { display: flex; align-items: center; gap: 10px; width: 100%; text-align: left;
  background: none; border: none; color: var(--text); padding: 9px 11px; border-radius: 7px; cursor: pointer;
  font: inherit; font-size: 13.5px; }
.folder-menu button:hover { background: var(--panel-2); }
.folder-menu button.danger { color: #ff8da0; }
.folder-menu button.danger:hover { background: rgba(244,63,94,.14); }
.folder-menu .fm-ico { width: 16px; text-align: center; flex-shrink: 0; opacity: .9; }
/* раскрывающаяся категория («Перемещение») и её флайаут-подменю */
.folder-menu button.has-sub .fm-arrow { margin-left: auto; padding-left: 12px; opacity: .55; font-size: 11px; }
.folder-submenu { z-index: 61; }

/* Перетаскивание (drag-and-drop на Pointer Events): своя папка / переносимая
   запись — «хваталка»; источник жеста гаснет, пока летит «призрак». */
.tree-folder[data-drag="1"], .entry[data-drag-entry="1"] { cursor: grab; }
.tree-folder.dragging, .entry.dragging { opacity: .4; }
/* активная цель: куда упадёт папка (станет её новым родителем) */
.tree-folder.drag-over { background: rgba(79,131,232,.20); color: var(--text);
  border-color: var(--accent); box-shadow: inset 0 0 0 1px var(--accent); }
/* «призрак» перетаскиваемой папки — летит за курсором */
.kp-drag-ghost { position: fixed; left: 0; top: 0; z-index: 80; pointer-events: none;
  max-width: 240px; padding: 6px 12px; border-radius: 8px;
  font-size: 13px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  background: var(--bg2); color: var(--text); border: 1px solid var(--accent);
  box-shadow: var(--shadow); opacity: .96; }
/* во время жеста — курсор «захвата» везде и без выделения текста */
body.kp-dragging, body.kp-dragging * { cursor: grabbing !important; }
body.kp-dragging { user-select: none; }

/* --- Плавное обновление после переноса записи -------------------------------
   Карточка-источник мягко гаснет на месте (держа свою ячейку), затем список
   перестраивается и соседи FLIP-анимацией доезжают на освободившееся место.
   Папка-приёмник (и оставшаяся в «Все доступные» запись) коротко подсвечивается. */
.entry.leaving { opacity: 0; transform: scale(.85); pointer-events: none;
  transition: opacity .19s ease, transform .19s ease; }
.entry.flipping { transition: transform .26s cubic-bezier(.2,.7,.3,1); z-index: 2; will-change: transform; }
.entry.flipping:hover { transform: none; }   /* не воевать с hover-подъёмом во время проезда */
.entry.just-moved { animation: kp-flash .95s ease; }
.tree-folder.just-dropped { animation: kp-flash .95s ease; }
@keyframes kp-flash {
  from { box-shadow: inset 0 0 0 999px rgba(79,131,232,.20); }
  to   { box-shadow: inset 0 0 0 999px rgba(79,131,232,0); }
}
@media (prefers-reduced-motion: reduce) {
  .entry.leaving, .entry.flipping { transition: none; }
  .entry.just-moved, .tree-folder.just-dropped { animation: none; }
}

/* --- Заголовок над записями --- */
.entries-wrap { flex: 1; display: flex; flex-direction: column; overflow: hidden; position: relative; }
.entries-head { padding: 16px 20px 0; display: flex; align-items: center; gap: 10px; }
.entries-head h2 { font-size: 18px; }
.entries-head .lvl-badge { font-size: 11px; padding: 2px 9px; border-radius: 10px; border: 1px solid var(--border-strong); color: var(--muted); }
.entries-head .lvl-edit { color: #6ee7a8; border-color: rgba(34,197,94,.4); }
.entries-head .lvl-view { color: #93c5fd; border-color: rgba(79,131,232,.4); }
.entries-head .lvl-none { color: #fca5a5; border-color: rgba(244,63,94,.4); }

/* --- Вкладки админки --- */
.tabs { display: flex; gap: 4px; }
.tab { background: transparent; border: none; color: var(--muted); font: inherit; font-size: 14px; font-weight: 600;
  padding: 8px 16px; border-radius: 10px; cursor: pointer; }
.tab:hover { background: var(--panel); color: var(--text); }
.tab.active { background: var(--panel-2); color: #fff; }
.admin-body { flex: 1; overflow-y: auto; padding: 22px; }
.admin-tab { max-width: 1120px; margin: 0 auto; }
.admin-toolbar { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.admin-toolbar h3 { font-size: 18px; }

/* ===================== История действий (журнал) ===================== */
.act-toolbar { flex-wrap: wrap; gap: 12px; }
.act-search-box { position: relative; display: flex; align-items: center; flex: 1; min-width: 220px; max-width: 440px;
  background: var(--input-bg); border: 1px solid var(--border); border-radius: 10px; padding: 0 10px; }
.act-search-box .search-ico { color: var(--muted); font-size: 15px; }
.act-search-box input { flex: 1; background: transparent; border: none; outline: none; color: var(--text); padding: 9px 8px; font-size: 14px; }
.act-filters { display: flex; flex-wrap: wrap; gap: 7px; margin: 6px 0 4px; }
.act-chip { display: inline-flex; align-items: center; gap: 6px; padding: 5px 10px; border-radius: 16px; cursor: pointer;
  background: var(--panel-2); border: 1px solid var(--border); color: var(--muted); font-size: 12.5px; transition: background .12s, color .12s; }
.act-chip:hover { color: var(--text); }
.act-chip.active { background: rgba(79,131,232,.14); color: var(--accent); border-color: rgba(79,131,232,.4); }
.act-chip-ico { font-size: 13px; }
.act-chip-n { font-size: 11px; background: rgba(0,0,0,.18); padding: 0 6px; border-radius: 9px; }
.act-chip.active .act-chip-n { background: rgba(79,131,232,.22); }
.act-chip.reset { background: transparent; color: var(--danger); border-color: transparent; }
.act-chip.reset:hover { background: rgba(244,63,94,.1); }
.act-results { margin-top: 8px; }
.act-feed { display: flex; flex-direction: column; }
.act-row { display: flex; gap: 12px; padding: 11px 4px; border-bottom: 1px solid var(--border); }
.act-row:last-child { border-bottom: none; }
.act-ico { width: 32px; height: 32px; flex-shrink: 0; border-radius: 9px; display: grid; place-items: center;
  background: var(--panel-2); font-size: 15px; }
.act-main { min-width: 0; flex: 1; }
.act-line { font-size: 14px; line-height: 1.45; word-break: break-word; }
.act-target { color: var(--accent); font-weight: 500; }
.act-detail { font-size: 13px; }
.act-meta { font-size: 11.5px; margin-top: 2px; }
.act-role { color: var(--muted); }
.act-userhead { font-size: 12.5px; margin: 2px 0 10px; }

/* --- Таблица --- */
.table-wrap { border: 1px solid var(--border); border-radius: 14px; overflow: hidden; }
.data-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.data-table th { text-align: left; padding: 12px 14px; color: var(--muted); font-weight: 600; font-size: 12.5px;
  background: var(--hover); border-bottom: 1px solid var(--border); }
.data-table td { padding: 11px 14px; border-bottom: 1px solid var(--border); vertical-align: middle; }
.data-table tr:last-child td { border-bottom: none; }
.data-table tr:hover td { background: var(--hover); }
.role-badge { font-size: 11px; padding: 2px 9px; border-radius: 10px; font-weight: 600; }
.role-admin { background: rgba(56,189,248,.18); color: #bae6fd; }
.role-user { background: rgba(79,131,232,.16); color: #bfdbfe; }
/* В светлой теме светлый текст бейджа сливался с бледным фоном — делаем тёмным и читаемым.
   Префикс .role-badge поднимает специфичность выше базового .role-badge.role-custom (ниже по файлу). */
[data-theme="light"] .role-badge.role-admin  { background: rgba(56,189,248,.20);  color: #075985; }
[data-theme="light"] .role-badge.role-user   { background: rgba(79,131,232,.16);  color: #1e40af; }
[data-theme="light"] .role-badge.role-custom { background: rgba(168,139,250,.20); color: #6d28d9; }
.row-actions { display: flex; gap: 4px; flex-wrap: wrap; }
.vault-pw-cell { font-family: "Cascadia Code", Consolas, monospace; color: var(--accent); }

/* --- Структура (офисы/папки) --- */
#structure-list { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; align-items: start; }
.struct-office { border: 1px solid var(--border); border-radius: 14px; overflow: hidden; }
@media (max-width: 900px) { #structure-list { grid-template-columns: 1fr; } }
.struct-office-head { display: flex; align-items: center; gap: 8px; padding: 14px 16px; background: var(--hover); }
.struct-office-head .title b { font-weight: 700; font-size: 15px; }
.struct-folders { padding: 8px 16px 14px; display: flex; flex-direction: column; gap: 8px; }
.struct-folder { display: flex; align-items: center; gap: 8px; padding: 9px 12px; background: var(--input-bg);
  border: 1px solid var(--border); border-radius: 10px; font-size: 14px; }
/* имя (обрезается) и блок кнопок (не сжимается) */
.st-toggle { flex: 0 0 14px; height: 18px; display: inline-flex; align-items: center; justify-content: center;
  font-size: 10px; color: var(--muted); cursor: pointer; user-select: none; }
.st-toggle:not(.blank):hover { color: var(--accent); }
.st-toggle.blank { visibility: hidden; cursor: default; }
.struct-name { flex: 1; min-width: 0; display: flex; align-items: center; gap: 8px; overflow: hidden; }
.struct-name b { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.struct-name .city { flex-shrink: 0; color: var(--accent); font-size: 13px; }
.struct-name .ico { flex-shrink: 0; }
.struct-actions { flex-shrink: 0; display: flex; gap: 4px; align-items: center; }

/* --- Доступы: дерево офис → папки с селекторами уровня (вкладка «Доступы») --- */
.perm-office { margin-bottom: 12px; }
.perm-row { display: flex; align-items: center; gap: 10px; padding: 9px 10px; border-radius: 10px; }
.perm-row.office-row { background: var(--hover); font-weight: 600; }
.perm-row.folder-row { padding-left: 24px; }
.perm-row.cabinet-row { padding-left: 24px; font-weight: 600; }
.perm-row.employee-row { padding-left: 46px; }
.perm-row .name { flex: 1; min-width: 0; font-size: 14px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.perm-row select { width: auto; min-width: 130px; flex-shrink: 0; padding: 6px 10px; font-size: 13px; }
.perm-row select.perm-casc { min-width: 118px; font-size: 12px; color: var(--muted); }
.perm-row select.perm-casc:disabled { opacity: .4; }

/* Бейдж фактического (унаследованного) доступа в строке прав */
.perm-row .eff-badge { flex-shrink: 0; font-size: 11.5px; padding: 2px 8px; border-radius: 999px;
  border: 1px solid var(--border); white-space: nowrap; }
.eff-badge.eff-view { color: #38bdf8; border-color: #38bdf855; background: #38bdf812; }
.eff-badge.eff-edit { color: #34d399; border-color: #34d39955; background: #34d39912; }
.eff-badge.eff-none { color: var(--muted); }
.perm-hint { font-size: 12px; line-height: 1.5; margin: 0 0 10px; padding: 8px 10px;
  background: var(--hover); border-radius: 8px; }

/* Папки верхнего уровня в дереве — выделены жирным (вложенность через inline-отступ) */
.tree-folder.top { font-weight: 600; color: var(--text); }

.btn.mini { padding: 6px 11px; font-size: 12.5px; }

/* =========================== Админ-панель (новая) =========================== */
#view-admin { display: flex; flex-direction: column; }
.admin-shell { flex: 1; display: flex; overflow: hidden; }

/* Левая вертикальная навигация по разделам */
.admin-nav { width: 280px; flex-shrink: 0; border-right: 1px solid var(--border); background: var(--side-bg);
  padding: 16px 12px; display: flex; flex-direction: column; gap: 3px; overflow-y: auto; }
.nav-group-title { font-size: 11px; text-transform: uppercase; letter-spacing: .5px; color: var(--muted);
  font-weight: 700; padding: 8px 12px 6px; }
.nav-item { display: flex; align-items: center; gap: 11px; width: 100%; padding: 11px 13px; border-radius: 10px;
  border: 1px solid transparent; background: none; color: var(--muted); font: inherit; font-size: 14px;
  text-align: left; cursor: pointer; transition: background .12s, color .12s; }
.nav-item .ico { width: 18px; text-align: center; flex-shrink: 0; }
.nav-item .nav-label { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.nav-item:hover:not(.disabled) { background: var(--panel); color: var(--text); }
.nav-item.active { background: rgba(79,131,232,.12); color: var(--accent); border-color: rgba(79,131,232,.35); font-weight: 600; }
.nav-item.disabled { opacity: .5; cursor: default; }
.soon { font-size: 10px; padding: 1px 7px; border-radius: 999px; border: 1px solid var(--border);
  color: var(--muted); text-transform: uppercase; letter-spacing: .3px; flex-shrink: 0; }
.nav-item .soon { margin-left: auto; }

/* Контент раздела */
.admin-content { flex: 1; overflow-y: auto; padding: 24px 28px; }
.admin-content-inner { max-width: 1080px; margin: 0 auto; }

/* Горизонтальные вкладки (Пользователи/Роли/Группы и под-вкладки пользователя) */
.htabs { display: flex; gap: 2px; border-bottom: 1px solid var(--border); margin-bottom: 22px; }
.htabs.sub { margin-bottom: 18px; }
.htab { display: inline-flex; align-items: center; gap: 7px; background: none; border: none; font: inherit;
  font-size: 14px; font-weight: 600; color: var(--muted); padding: 11px 14px; cursor: pointer;
  border-bottom: 2px solid transparent; margin-bottom: -1px; }
.htab:hover:not(:disabled) { color: var(--text); }
.htab.active { color: var(--accent); border-bottom-color: var(--accent); }
.htab:disabled { opacity: .5; cursor: default; }

/* Список пользователей — кликабельные карточки */
.user-list { display: flex; flex-direction: column; gap: 8px; }
.user-card { display: flex; align-items: center; gap: 14px; padding: 12px 16px; border: 1px solid var(--border);
  border-radius: 12px; background: var(--panel); cursor: pointer;
  transition: border-color .15s, background .15s, transform .12s; }
.user-card:hover { border-color: var(--border-strong); background: var(--panel-2); transform: translateX(3px); }
.user-card .u-main { flex: 1; min-width: 0; }
.user-card .u-name { font-weight: 600; font-size: 15px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.user-card .u-login { font-size: 13px; color: var(--muted); margin-top: 1px; }
.user-card .chev { color: var(--muted); font-size: 20px; flex-shrink: 0; line-height: 1; }

.avatar.lg { width: 54px; height: 54px; border-radius: 14px; font-size: 22px; }

/* Шапка детального экрана пользователя */
.back-link { background: none; border: none; color: var(--muted); font: inherit; font-size: 13px;
  cursor: pointer; padding: 0; margin-bottom: 16px; }
.back-link:hover { color: var(--accent); }
.user-detail-head { display: flex; align-items: center; gap: 16px; margin-bottom: 22px; }
.user-detail-head h2 { font-size: 20px; }
.user-detail-head .sub { display: flex; align-items: center; gap: 9px; font-size: 13px; color: var(--muted); margin-top: 4px; }
.user-detail-head .udh-main { flex: 1; min-width: 0; }
.detail-head-actions { margin-left: auto; display: flex; gap: 4px; flex-shrink: 0; }

/* Бейдж «из группы» в дереве доступов — визуально отличается от «наследует» */
.eff-badge.eff-group { color: #c4b5fd; border-color: #a78bfa55; background: #a78bfa14; }

/* Карточка участника группы — не кликабельна (действие — кнопка ✕ справа) */
.user-card.static { cursor: default; }
.user-card.static:hover { transform: none; border-color: var(--border); background: var(--panel); }

/* Панель действий над участниками / выбор пользователей в модалке */
.members-toolbar { display: flex; justify-content: flex-end; margin-bottom: 14px; }
.pick-list { display: flex; flex-direction: column; gap: 4px; max-height: 50vh; overflow-y: auto;
  border: 1px solid var(--border); border-radius: 10px; padding: 6px; }
.pick-row { display: flex; align-items: center; gap: 10px; padding: 9px 10px; border-radius: 8px; cursor: pointer;
  transition: background .12s; }
.pick-row:hover { background: var(--hover); }
.pick-row input { width: 16px; height: 16px; accent-color: var(--accent); cursor: pointer; flex-shrink: 0; }
.pick-name { flex: 1; min-width: 0; font-size: 14px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* --- Роли: бейджи и редактор возможностей --- */
.role-badge.role-custom { background: rgba(168,139,250,.16); color: #d6c8ff; }
.role-tag { font-size: 10px; padding: 1px 7px; border-radius: 999px; border: 1px solid var(--border);
  color: var(--muted); text-transform: uppercase; letter-spacing: .3px; margin-left: 6px; vertical-align: middle; }

.role-edit { max-width: 760px; }
.cap-grid { display: flex; flex-direction: column; gap: 14px; margin-top: 4px; }
.cap-cat { border: 1px solid var(--border); border-radius: 12px; padding: 12px 14px; background: var(--panel); }
.cap-cat-title { font-size: 12px; text-transform: uppercase; letter-spacing: .5px; color: var(--muted);
  font-weight: 700; margin-bottom: 8px; }
.cap-row { display: flex; align-items: flex-start; gap: 11px; padding: 8px 8px; border-radius: 9px; cursor: pointer;
  transition: background .12s; }
.cap-row:hover { background: var(--hover); }
.cap-row input { width: 17px; height: 17px; margin-top: 1px; accent-color: var(--accent); cursor: pointer; flex-shrink: 0; }
.cap-row input:disabled { cursor: default; }
.cap-main { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.cap-label { font-size: 14px; }
.cap-desc { font-size: 12.5px; line-height: 1.4; }
.role-save-bar { margin-top: 18px; display: flex; justify-content: flex-end; }

/* Карточки на вкладке «Права и настройки» */
.settings-grid { display: flex; flex-direction: column; gap: 14px; max-width: 660px; }
.setting-card { border: 1px solid var(--border); border-radius: 12px; padding: 16px 18px; background: var(--panel); }
.setting-card h4 { font-size: 14px; margin-bottom: 4px; }
.setting-card p { font-size: 13px; color: var(--muted); margin-bottom: 12px; line-height: 1.5; }
.setting-card .setting-row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.setting-card .setting-row .muted { font-size: 12.5px; }

@media (max-width: 820px) {
  .sidebar { width: 190px; }
  .admin-nav { width: 220px; }
}
@media (max-width: 720px) {
  /* ---------- Шапка: компактная, с гамбургером ---------- */
  /* env(safe-area-inset-*) — учитываем вырез/скруглённые углы (iPhone X+ и т. п.):
     шапка прижата к статус-бару, поэтому добавляем верхний/боковые отступы безопасной зоны. */
  .topbar { gap: 8px; padding: 10px 50px 10px 10px;
    padding-top: calc(10px + env(safe-area-inset-top));
    padding-left: calc(10px + env(safe-area-inset-left));
    padding-right: calc(50px + env(safe-area-inset-right)); }
  .topbar-burger { display: inline-flex; }
  #view-main .topbar-brand { display: none; }            /* экономим место — слева гамбургер (в админке остаётся «←») */
  .search { max-width: none; min-width: 0; }
  .topbar-actions { gap: 3px; }
  #add-btn, #admin-btn { padding: 9px 11px; }
  #add-btn .blabel, #admin-btn .blabel { display: none; }   /* кнопки-иконки */
  #add-btn .bico, #admin-btn .bico { margin-right: 0; font-size: 16px; }
  .theme-toggle { width: 34px; height: 34px; font-size: 16px;
    top: calc(11px + env(safe-area-inset-top)); right: calc(9px + env(safe-area-inset-right)); }

  /* ---------- Тач-таргеты: на тач-экранах кнопки-иконки должны быть «пальце-доступны»
     (≈44px). Десктоп не трогаем — правила только в мобильном брейкпоинте. ---------- */
  .ghost-icon { padding: 9px 10px; }
  .ghost-icon.big { padding: 8px 10px; }
  .pw-wrap .ghost-icon { min-width: 40px; min-height: 40px; display: inline-flex; align-items: center; justify-content: center; }
  .chip-btn { padding: 8px 12px; font-size: 13px; }      /* быстрое копирование на карточке */
  .tree-folder { padding: 11px 12px; }                   /* пункты дерева папок */
  .select-toggle { padding: 9px 14px; }
  .pg-btn { min-width: 38px; height: 38px; }             /* пагинация */
  .dp-tab { padding: 10px 12px; }                        /* вкладки в карточке записи */
  .sf-tag { padding: 10px 12px; }                        /* фильтры-теги в поиске */

  /* ---------- Боковая панель → выезжающий слева ящик ---------- */
  .sidebar { position: absolute; top: 0; left: 0; bottom: 0; z-index: 30; display: flex;
    width: 290px; max-width: 86%; min-width: 0; background: var(--bg); border-right: 1px solid var(--border);
    padding: 14px 12px; padding-left: calc(12px + env(safe-area-inset-left));
    transform: translateX(-100%); transition: transform .25s ease; }
  /* Тень только у ОТКРЫТОГО ящика: иначе её правый край вылезал из-за левой кромки
     экрана и в светлой теме читался как тёмная полоса слева. */
  .main-body.drawer-open .sidebar { transform: translateX(0); box-shadow: 12px 0 44px rgba(0,0,0,.5); }
  .sidebar-backdrop { display: block; position: absolute; inset: 0; z-index: 25; background: rgba(0,0,0,.55);
    opacity: 0; pointer-events: none; transition: opacity .25s; }
  .main-body.drawer-open .sidebar-backdrop { opacity: 1; pointer-events: auto; }
  .sidebar-resizer { display: none; }

  /* ---------- Список записей ---------- */
  .entries { grid-template-columns: 1fr; padding: 14px; gap: 10px;
    padding-bottom: calc(14px + env(safe-area-inset-bottom)); }
  .entries.as-list { max-width: none; }
  .entries-head { padding: 14px 14px 0; flex-wrap: wrap; }

  /* ---------- Панель записи: полноэкранный непрозрачный оверлей ---------- */
  .detail-panel { width: 100%; min-width: 0; max-width: 100%; left: 0; right: 0;
    border-left: none; background: var(--bg); }
  /* нижние панели кнопок в карточке записи — над домашним индикатором */
  .dp-edit-foot { padding-bottom: calc(14px + env(safe-area-inset-bottom)); }
  .dp-body, .dp-edit-body { padding-bottom: calc(16px + env(safe-area-inset-bottom)); }

  /* ---------- Модалки на всю ширину ---------- */
  .modal-backdrop { padding: 12px; padding-bottom: calc(12px + env(safe-area-inset-bottom)); }
  .modal, .modal.small, .import-modal { max-width: 100%; }
  .modal-foot { padding-bottom: calc(16px + env(safe-area-inset-bottom)); }
  .imp-map-grid { grid-template-columns: 1fr; }   /* сопоставление колонок — в один столбец */

  /* Поповеры шапки (уведомления, меню): на узком экране НЕ привязываем к кнопке
     (right:0 от колокольчика уводил широкий поповер за левый край). Делаем .notif/.menu
     статиками — поповер якорится к .topbar и растягивается на всю ширину под шапкой. */
  .notif, .menu { position: static; }
  .notif-pop, .menu-pop {
    top: calc(100% + 4px); left: 10px; right: 10px; width: auto; min-width: 0; max-width: none; }

  /* Панель массового выбора: компактно — только иконки у кнопок (подписи скрыты),
     уменьшенные отступы. Иначе кнопки с подписями занимали несколько строк. */
  .bulkbar { margin: 8px 12px 0; padding: 6px 8px; gap: 6px; }
  .bulk-btn .bl-txt { display: none; }
  .bulk-btn { gap: 0; padding: 9px 11px; }
  .bulk-count { font-size: 12px; white-space: normal; }

  /* iOS зумит страницу при фокусе на ТЕКСТОВОМ поле со шрифтом < 16px — поэтому ровно 16px.
     Селекторы повторяют базовые `input[type=text]/[type=password]` (та же специфичность +
     правило ниже по файлу), иначе базовые 15px перебьют общий `input`. Нативный <select>
     зум не вызывает (открывает колесо-пикер) — его не трогаем. */
  input[type=text], input[type=password], input[type=number], input[type=date],
  input[type=email], input[type=search], input[type=tel], textarea,
  .temp-config input[type=date], .temp-notify input[type=number],
  .offset-add input { font-size: 16px; }

  /* ---------- Админка ---------- */
  .admin-shell { flex-direction: column; }
  .admin-nav { width: 100%; flex-direction: row; flex-wrap: nowrap; overflow-x: auto; gap: 6px;
    border-right: none; border-bottom: 1px solid var(--border); padding: 8px 10px; }
  .admin-nav .nav-group-title { display: none; }
  .admin-nav .nav-item { width: auto; flex-shrink: 0; padding: 9px 13px; }
  .admin-content { padding: 16px 14px; padding-bottom: calc(16px + env(safe-area-inset-bottom)); }
  .htabs { overflow-x: auto; white-space: nowrap; -webkit-overflow-scrolling: touch; }
  .htab { flex-shrink: 0; }
  .user-detail-head { gap: 12px; }
  .act-toolbar { gap: 10px; }
  .act-search-box { max-width: none; }
  /* права/доступы: имя занимает строку целиком, оба селекта (уровень + каскад) — строку под ним */
  .perm-row { flex-wrap: wrap; row-gap: 8px; }
  .perm-row .name { flex-basis: 100%; }
  .perm-row select, .perm-row select.perm-casc { flex: 1; min-width: 0; }

  /* ---------- Формы входа/восстановления ---------- */
  .seed-grid { grid-template-columns: repeat(2, 1fr); }
  .auth-card { padding: 28px 20px; }
}

/* Очень узкие экраны (≤380px): код-сэмплы в генераторе не должны распирать карточку */
@media (max-width: 380px) {
  .gen-type-sample { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .seed-grid { grid-template-columns: 1fr 1fr; gap: 7px; }
}
