/* ============================================================
   seif — дизайн-система
   Локальные шрифты, OKLCH-палитра, светлая и тёмная темы.
   ============================================================ */

@font-face{font-family:Inter;font-weight:400;font-style:normal;font-display:swap;src:url("fonts/inter-400.woff2") format("woff2")}
@font-face{font-family:Inter;font-weight:500;font-style:normal;font-display:swap;src:url("fonts/inter-500.woff2") format("woff2")}
@font-face{font-family:Inter;font-weight:600;font-style:normal;font-display:swap;src:url("fonts/inter-600.woff2") format("woff2")}
@font-face{font-family:Inter;font-weight:700;font-style:normal;font-display:swap;src:url("fonts/inter-700.woff2") format("woff2")}
@font-face{font-family:"JetBrains Mono";font-weight:400;font-style:normal;font-display:swap;src:url("fonts/mono-400.woff2") format("woff2")}
@font-face{font-family:"JetBrains Mono";font-weight:500;font-style:normal;font-display:swap;src:url("fonts/mono-500.woff2") format("woff2")}

/* ── токены ── */
:root{
  --font:Inter,system-ui,-apple-system,"Segoe UI",sans-serif;
  --mono:"JetBrains Mono",ui-monospace,"Cascadia Code",Consolas,monospace;

  /* fixed type scale (ratio ~1.2) */
  --t-xs:.75rem; --t-sm:.8125rem; --t-base:.875rem; --t-md:.9375rem;
  --t-lg:1.0625rem; --t-xl:1.375rem; --t-2xl:1.75rem;

  --sp-1:4px; --sp-2:8px; --sp-3:12px; --sp-4:16px; --sp-5:20px;
  --sp-6:24px; --sp-8:32px; --sp-10:40px; --sp-12:48px;

  --r-sm:7px; --r:10px; --r-lg:14px; --r-xl:18px; --r-full:999px;

  --dur:.16s; --ease:cubic-bezier(.22,1,.36,1);

  --z-dropdown:100; --z-sticky:200; --z-backdrop:300; --z-modal:400; --z-toast:500;
}

/* ── светлая тема (по умолчанию) ── */
:root,[data-theme="light"]{
  --bg:oklch(.985 .003 230);
  --surface:oklch(1 0 0);
  --surface-2:oklch(.972 .004 230);     /* nav / toolbar — второй нейтральный слой */
  --elevated:oklch(1 0 0);
  --border:oklch(.915 .005 230);
  --border-strong:oklch(.86 .008 230);
  --ink:oklch(.24 .012 250);
  --ink-2:oklch(.46 .015 250);
  --ink-3:oklch(.55 .018 250);
  --accent:oklch(.55 .105 195);
  --accent-hover:oklch(.49 .11 195);
  --accent-ink:oklch(1 0 0);
  --accent-soft:oklch(.95 .032 195);
  --accent-soft-bd:oklch(.88 .05 195);
  --danger:oklch(.55 .19 25);
  --danger-soft:oklch(.96 .04 25);
  --warn:oklch(.62 .13 70);
  --warn-soft:oklch(.95 .05 80);
  --success:oklch(.55 .12 155);
  --success-soft:oklch(.95 .045 155);
  --ring:oklch(.55 .105 195 / .45);
  --shadow-sm:0 1px 2px oklch(.2 .02 250/.06),0 1px 3px oklch(.2 .02 250/.08);
  --shadow-md:0 4px 12px oklch(.2 .02 250/.10),0 2px 4px oklch(.2 .02 250/.06);
  --shadow-lg:0 16px 40px oklch(.2 .02 250/.16),0 4px 12px oklch(.2 .02 250/.10);
  --avatar-ink:oklch(1 0 0);
  color-scheme:light;
}

/* ── тёмная тема ── */
[data-theme="dark"]{
  --bg:oklch(.175 .012 250);
  --surface:oklch(.215 .013 250);
  --surface-2:oklch(.195 .013 250);
  --elevated:oklch(.245 .015 250);
  --border:oklch(.30 .013 250);
  --border-strong:oklch(.38 .016 250);
  --ink:oklch(.95 .006 250);
  --ink-2:oklch(.76 .012 250);
  --ink-3:oklch(.63 .016 250);
  --accent:oklch(.74 .115 190);
  --accent-hover:oklch(.80 .115 190);
  --accent-ink:oklch(.20 .03 215);
  --accent-soft:oklch(.30 .045 200);
  --accent-soft-bd:oklch(.40 .06 200);
  --danger:oklch(.68 .16 25);
  --danger-soft:oklch(.30 .07 25);
  --warn:oklch(.80 .13 80);
  --warn-soft:oklch(.32 .06 80);
  --success:oklch(.72 .13 155);
  --success-soft:oklch(.30 .06 155);
  --ring:oklch(.74 .115 190 / .5);
  --shadow-sm:0 1px 2px oklch(0 0 0/.3);
  --shadow-md:0 4px 14px oklch(0 0 0/.4);
  --shadow-lg:0 18px 48px oklch(0 0 0/.55);
  --avatar-ink:oklch(.16 .02 250);
  color-scheme:dark;
}

/* ── тёплая кремовая (стиль Claude) ── */
[data-theme="claude-cream"]{
  --bg:#FAF9F5; --surface:#FFFFFF; --surface-2:#F2F0E9; --elevated:#FFFFFF;
  --border:#E8E5DC; --border-strong:#D8D3C6;
  --ink:#2B2925; --ink-2:#605A50; --ink-3:#857F73;
  --accent:#C8613D; --accent-hover:#B5512F; --accent-ink:#FFFFFF;
  --accent-soft:#F6E8E0; --accent-soft-bd:#E8CBBA;
  --danger:#B53D2E; --danger-soft:#F7E5E2; --warn:#9C6A14; --warn-soft:#F4EAD6;
  --success:#3D7A5B; --success-soft:#E3EFE8; --ring:rgba(200,97,61,.32);
  --shadow-sm:0 1px 2px rgba(60,50,40,.05),0 1px 3px rgba(60,50,40,.07);
  --shadow-md:0 4px 12px rgba(60,50,40,.08),0 2px 4px rgba(60,50,40,.05);
  --shadow-lg:0 16px 40px rgba(60,50,40,.14),0 4px 12px rgba(60,50,40,.08);
  --avatar-ink:#FFFFFF; color-scheme:light;
}

/* ── тёплая тёмно-угольная (стиль Claude) ── */
[data-theme="claude-dark"]{
  --bg:#1F1E1D; --surface:#262624; --surface-2:#211F1E; --elevated:#2D2B28;
  --border:#393633; --border-strong:#4A4641;
  --ink:#ECE9E2; --ink-2:#A8A299; --ink-3:#827C72;
  --accent:#D97757; --accent-hover:#E18A6E; --accent-ink:#21130C;
  --accent-soft:#3A2A22; --accent-soft-bd:#4E382C;
  --danger:#E0695C; --danger-soft:#3A2522; --warn:#D6A24E; --warn-soft:#352B1C;
  --success:#6FB58C; --success-soft:#243029; --ring:rgba(217,119,87,.45);
  --shadow-sm:0 1px 2px rgba(0,0,0,.3);
  --shadow-md:0 4px 14px rgba(0,0,0,.4);
  --shadow-lg:0 18px 48px rgba(0,0,0,.55);
  --avatar-ink:#21130C; color-scheme:dark;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  background:var(--bg);color:var(--ink);font-family:var(--font);
  font-size:var(--t-base);line-height:1.5;overflow:hidden;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;user-select:none;
}
::selection{background:var(--accent-soft);color:var(--ink)}

/* скроллбары — лёгкие, но не «изобретённые» */
*::-webkit-scrollbar{width:11px;height:11px}
*::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--r-full);
  border:3px solid transparent;background-clip:padding-box}
*::-webkit-scrollbar-thumb:hover{background:var(--ink-3)}

.ic{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.75;
  stroke-linecap:round;stroke-linejoin:round;flex:0 0 auto}
.ic-sm{width:15px;height:15px}.ic-lg{width:22px;height:22px}
.hidden{display:none!important}

/* ── кнопки: все состояния ── */
button{font:inherit;color:inherit;border:0;background:none;cursor:pointer}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);
  height:36px;padding:0 var(--sp-4);border-radius:var(--r-sm);font-weight:600;
  font-size:var(--t-base);transition:background var(--dur) var(--ease),
  border-color var(--dur),color var(--dur),box-shadow var(--dur),transform .05s}
.btn:active{transform:translateY(.5px)}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
.btn-primary{background:var(--accent);color:var(--accent-ink);box-shadow:var(--shadow-sm)}
.btn-primary:hover:not(:disabled){background:var(--accent-hover)}
.btn-soft{background:var(--surface);border:1px solid var(--border);color:var(--ink)}
.btn-soft:hover{background:var(--surface-2);border-color:var(--border-strong)}
.btn-danger{background:transparent;border:1px solid var(--danger);color:var(--danger)}
.btn-danger:hover{background:var(--danger);color:oklch(1 0 0)}
.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;
  border-radius:var(--r-sm);color:var(--ink-2);transition:background var(--dur),color var(--dur)}
.icon-btn:hover{background:var(--surface-2);color:var(--ink)}
.icon-btn.on{color:var(--accent)}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.btn:focus-visible,.icon-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

/* ── поля ── */
.input,textarea.input{width:100%;height:38px;padding:0 var(--sp-3);background:var(--surface);
  border:1px solid var(--border);border-radius:var(--r-sm);color:var(--ink);font:inherit;
  font-size:var(--t-md);outline:none;transition:border-color var(--dur),box-shadow var(--dur);user-select:text}
.input::placeholder{color:var(--ink-3)}
/* убрать встроенную кнопку показа пароля Edge/WebView2 (дублирует наш «глаз») */
input::-ms-reveal,input::-ms-clear{display:none}
.input:hover{border-color:var(--border-strong)}
.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--ring)}
textarea.input{height:auto;min-height:72px;padding:var(--sp-3);line-height:1.55;resize:vertical}
.lbl{display:block;font-size:var(--t-sm);font-weight:500;color:var(--ink-2);margin:0 0 var(--sp-2)}
.field{margin-bottom:var(--sp-4)}

.pw-wrap{position:relative;display:flex}
.pw-wrap .input{padding-right:40px}
.pw-wrap .reveal{position:absolute;right:4px;top:50%;transform:translateY(-50%);width:30px;height:30px}

/* индикатор силы */
.strength{display:flex;gap:5px;margin-top:8px}
.strength i{flex:1;height:4px;border-radius:var(--r-full);background:var(--border);transition:background var(--dur)}
.strength-label{font-size:var(--t-xs);color:var(--ink-3);margin-top:5px}

/* ============================================================
   GATE — экран входа
   ============================================================ */
#gate{position:fixed;inset:0;display:grid;place-items:center;padding:var(--sp-6);background:var(--bg)}
.gate-card{width:100%;max-width:344px;text-align:center}
.brandmark{width:56px;height:56px;border-radius:var(--r-lg);margin:0 auto var(--sp-4);
  display:grid;place-items:center;background:var(--accent);color:var(--accent-ink);box-shadow:var(--shadow-md)}
.brandmark .ic{width:28px;height:28px;stroke-width:2}
.wordmark{font-size:var(--t-2xl);font-weight:700;letter-spacing:-.02em}
.gate-sub{color:var(--ink-2);margin:var(--sp-2) 0 var(--sp-6);font-size:var(--t-md)}
.gate-card form{display:flex;flex-direction:column;gap:var(--sp-3);text-align:left}
.gate-card .btn{height:42px;margin-top:var(--sp-1)}
.gate-err{color:var(--danger);font-size:var(--t-sm);min-height:18px;text-align:center}
.gate-hint{color:var(--ink-3);font-size:var(--t-xs);margin-top:var(--sp-5);line-height:1.5}

/* ============================================================
   APP — оболочка
   ============================================================ */
#app{display:none;grid-template-rows:56px 1fr;grid-template-columns:200px 320px 1fr;height:100%}
#app.show{display:grid}
.tablewrap{grid-column:2/4;grid-row:2;display:none;overflow:auto;background:var(--bg)}
#app.mode-table .listcol,#app.mode-table .detail{display:none}
#app.mode-table .tablewrap{display:block}
#app.mode-full .listcol{display:none}
#app.mode-full .detail{grid-column:2/4}

.topbar{grid-column:1/4;grid-row:1;display:flex;align-items:center;gap:var(--sp-4);height:56px;
  padding:0 var(--sp-4);border-bottom:1px solid var(--border);background:var(--surface-2)}
.brand{display:flex;align-items:center;gap:var(--sp-2);font-weight:700;font-size:var(--t-lg);letter-spacing:-.01em}
.brand .mk{width:26px;height:26px;border-radius:var(--r-sm);display:grid;place-items:center;
  background:var(--accent);color:var(--accent-ink)}
.brand .mk .ic{width:15px;height:15px;stroke-width:2}
.searchbar{position:relative;flex:1;max-width:460px}
.searchbar .ic{position:absolute;left:11px;top:50%;transform:translateY(-50%);width:16px;height:16px;
  stroke:var(--ink-3);pointer-events:none}
.searchbar input{width:100%;height:36px;padding:0 var(--sp-3) 0 34px;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--r-sm);color:var(--ink);font:inherit;font-size:var(--t-base);
  outline:none;transition:border-color var(--dur),box-shadow var(--dur);user-select:text}
.searchbar input::placeholder{color:var(--ink-3)}
.searchbar input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--ring)}
.topbar .spacer{flex:1}

/* боковая навигация */
.nav{grid-column:1;grid-row:2;background:var(--surface-2);border-right:1px solid var(--border);
  display:flex;flex-direction:column;padding:var(--sp-3);gap:2px;min-height:0}
.nav-item{display:flex;align-items:center;gap:var(--sp-3);height:38px;padding:0 var(--sp-3);
  border-radius:var(--r-sm);color:var(--ink-2);font-weight:500;font-size:var(--t-md);
  transition:background var(--dur),color var(--dur);text-align:left;width:100%}
.nav-item .ic{stroke:currentColor}
.nav-item:hover{background:var(--surface);color:var(--ink)}
.nav-item.active{background:var(--accent-soft);color:var(--accent);font-weight:600}
.nav-item .count{margin-left:auto;font-size:var(--t-xs);color:var(--ink-3);font-weight:500}
.nav-item.active .count{color:var(--accent)}
.nav-sep{height:1px;background:var(--border);margin:var(--sp-3) var(--sp-2)}
.nav .foot{margin-top:auto}

/* колонка списка */
.listcol{grid-column:2;grid-row:2;display:flex;flex-direction:column;border-right:1px solid var(--border);min-height:0;background:var(--bg)}
.listcol-head{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-4) var(--sp-4) var(--sp-2)}
.listcol-head .ttl{font-size:var(--t-lg);font-weight:700;letter-spacing:-.01em}
.listcol-head .spacer{flex:1}
.sortsel{height:30px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);
  color:var(--ink-2);font:inherit;font-size:var(--t-sm);padding:0 var(--sp-2);outline:none;cursor:pointer}
.new-row{padding:0 var(--sp-4) var(--sp-3)}
.new-row .btn{width:100%}
.list{flex:1;overflow-y:auto;padding:0 var(--sp-3) var(--sp-4)}

.item{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-3);
  border-radius:var(--r);cursor:pointer;transition:background var(--dur);position:relative}
.item:hover{background:var(--surface-2)}
.item.selected{background:var(--accent-soft)}
.item.selected .t{color:var(--accent)}
.avatar{width:36px;height:36px;border-radius:var(--r);flex:0 0 auto;display:grid;place-items:center;
  font-weight:600;font-size:var(--t-md);color:var(--avatar-ink)}
.item .meta{min-width:0;flex:1}
.item .t{font-weight:600;font-size:var(--t-md);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.item .s{color:var(--ink-3);font-size:var(--t-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.item .star{color:var(--warn);display:flex}
.item .badges{display:flex;gap:4px;align-items:center}

.list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--sp-3);
  text-align:center;color:var(--ink-3);padding:var(--sp-12) var(--sp-5);height:100%;font-size:var(--t-sm)}
.list-empty .ic{width:34px;height:34px;stroke:var(--border-strong);stroke-width:1.5}

/* панель деталей */
.detail{grid-column:3;grid-row:2;overflow-y:auto;min-width:0;background:var(--bg)}
.detail-inner{max-width:860px;padding:var(--sp-8) var(--sp-10)}
.empty{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:var(--sp-4);color:var(--ink-3);text-align:center;padding:var(--sp-10)}
.empty .ic{width:46px;height:46px;stroke:var(--border-strong);stroke-width:1.4}
.empty .h{font-size:var(--t-lg);font-weight:600;color:var(--ink-2)}

.dhead{display:flex;align-items:center;gap:var(--sp-4);margin-bottom:var(--sp-6)}
.dhead .avatar{width:52px;height:52px;border-radius:var(--r-lg);font-size:var(--t-xl)}
.dhead .htext{min-width:0;flex:1}
.dhead h1{font-size:var(--t-xl);font-weight:700;letter-spacing:-.015em;white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis}
.dhead .host{color:var(--ink-3);font-size:var(--t-sm);margin-top:2px;user-select:text}
.dhead .star-btn{color:var(--ink-3)}
.dhead .star-btn.on{color:var(--warn)}

.frow{display:flex;align-items:center;gap:var(--sp-2);background:var(--surface);
  border:1px solid var(--border);border-radius:var(--r);padding:10px var(--sp-3);margin-bottom:var(--sp-3)}
.frow .fmeta{min-width:0;flex:1}
.frow .fl{font-size:var(--t-xs);color:var(--ink-3);font-weight:500;margin-bottom:1px}
.frow .fv{font-size:var(--t-md);user-select:text;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.frow .fv.mono{font-family:var(--mono);font-size:var(--t-base);letter-spacing:.01em}
.frow .fv.empty-val{color:var(--ink-3)}
.frow.notes{align-items:flex-start}
.frow.notes .fv{white-space:pre-wrap;line-height:1.55}
.frow .acts{display:flex;gap:2px;flex:0 0 auto}
.copybtn.done{color:var(--success)}

/* TOTP */
.totp .code{font-family:var(--mono);font-size:1.25rem;font-weight:500;letter-spacing:.12em}
.totp-ring{position:relative;width:30px;height:30px;flex:0 0 auto}
.totp-ring svg{transform:rotate(-90deg)}
.totp-ring .track{stroke:var(--border)}
.totp-ring .prog{stroke:var(--accent);transition:stroke-dashoffset 1s linear}
.totp-ring .num{position:absolute;inset:0;display:grid;place-items:center;font-size:10px;color:var(--ink-2);font-weight:600}

.dmeta{margin-top:var(--sp-5);color:var(--ink-3);font-size:var(--t-xs);display:flex;gap:var(--sp-4)}
.dactions{display:flex;gap:var(--sp-3);margin-top:var(--sp-6)}

/* форма */
.form .field{margin-bottom:var(--sp-4)}
.pwfield{display:flex;gap:var(--sp-2)}.pwfield .pw-wrap{flex:1}
.gen{margin-top:var(--sp-3);background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r);padding:var(--sp-3);display:none}
.gen.open{display:block}
.gen .grow{display:flex;align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-3)}
.gen .grow input[type=range]{flex:1;accent-color:var(--accent)}
.gen .lenval{font-family:var(--mono);width:28px;text-align:right;color:var(--ink-2)}
.gen .opts{display:flex;gap:var(--sp-4);flex-wrap:wrap}
.gen .opts label{display:flex;align-items:center;gap:6px;color:var(--ink-2);font-size:var(--t-sm);cursor:pointer}
.gen .opts input{accent-color:var(--accent)}
.form-err{color:var(--danger);font-size:var(--t-sm);min-height:18px}
.form-actions{display:flex;align-items:center;gap:var(--sp-3);margin-top:var(--sp-2)}
.form-actions .spacer{flex:1}

/* аудит */
.audit{padding:var(--sp-8) var(--sp-10);max-width:1320px}
.audit h1{font-size:var(--t-xl);font-weight:700;margin-bottom:var(--sp-2);letter-spacing:-.015em}
.audit .sub{color:var(--ink-2);margin-bottom:var(--sp-6);font-size:var(--t-md)}
.audit-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:var(--sp-5);margin-bottom:var(--sp-4)}
.audit-card h2{font-size:var(--t-md);font-weight:600;display:flex;align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-3)}
.audit-card h2 .tag{margin-left:auto;font-size:var(--t-xs);font-weight:600;padding:2px 8px;border-radius:var(--r-full)}
.tag-ok{background:var(--success-soft);color:var(--success)}
.tag-warn{background:var(--warn-soft);color:var(--warn)}
.tag-bad{background:var(--danger-soft);color:var(--danger)}
.audit-row{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-2) 0;border-top:1px solid var(--border);cursor:pointer}
.audit-row:hover .arl{color:var(--accent)}
.audit-row .arl{font-weight:500}.audit-row .ars{color:var(--ink-3);font-size:var(--t-sm);margin-left:auto}
.audit-ok{color:var(--ink-3);font-size:var(--t-sm);padding-top:var(--sp-1)}

/* настройки */
.settings{padding:var(--sp-8) var(--sp-10);max-width:1320px}
.settings h1{font-size:var(--t-xl);font-weight:700;margin-bottom:var(--sp-6);letter-spacing:-.015em}
.set-row{display:flex;align-items:center;gap:var(--sp-4);padding:var(--sp-4) 0;border-bottom:1px solid var(--border);flex-wrap:wrap}
.set-row .si{flex:1 1 300px;min-width:240px}.set-row .si .t{font-weight:600;font-size:var(--t-md)}
.set-row .si .d{color:var(--ink-3);font-size:var(--t-sm);margin-top:2px}
.seg{display:flex;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-sm);padding:2px}
.seg button{padding:5px 12px;border-radius:5px;font-size:var(--t-sm);font-weight:500;color:var(--ink-2)}
.seg button.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}

/* ── модалка (только для подтверждений/ввода пароля) ── */
.modal{position:fixed;inset:0;background:oklch(.15 .02 250/.5);display:none;place-items:center;
  padding:var(--sp-6);z-index:var(--z-modal);backdrop-filter:blur(3px)}
.modal.open{display:grid}
.modal-card{width:100%;max-width:380px;background:var(--elevated);border:1px solid var(--border);
  border-radius:var(--r-xl);box-shadow:var(--shadow-lg);padding:var(--sp-6)}
.modal-card h2{font-size:var(--t-lg);margin-bottom:var(--sp-4)}
.modal-card p{color:var(--ink-2);margin-bottom:var(--sp-5);font-size:var(--t-md)}
.modal-actions{display:flex;justify-content:flex-end;gap:var(--sp-3);margin-top:var(--sp-5)}

/* ── тост ── */
#toast{position:fixed;left:50%;bottom:var(--sp-6);transform:translateX(-50%) translateY(16px);
  background:var(--ink);color:var(--bg);padding:10px var(--sp-5);border-radius:var(--r);box-shadow:var(--shadow-lg);
  font-weight:500;font-size:var(--t-base);display:flex;align-items:center;gap:var(--sp-2);
  opacity:0;pointer-events:none;transition:opacity var(--dur),transform var(--dur) var(--ease);z-index:var(--z-toast)}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
#toast .ic{stroke:var(--accent)}

/* версия */
.gate-ver{color:var(--ink-3);font-size:var(--t-xs);margin-top:var(--sp-5)}
.nav-foot{margin-top:auto;padding:var(--sp-3);color:var(--ink-3);font-size:var(--t-xs);text-align:center}

/* бейдж кода 2FA в списке/таблице */
.badges .ic{stroke:var(--ink-3)}
.item .star .ic{stroke:var(--warn);fill:var(--warn)}

/* ── табличный режим ── */
.dtable{display:flex;flex-direction:column;min-height:0}
.dtable-head{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-4) var(--sp-6) var(--sp-3)}
.dtable-head .ttl{font-size:var(--t-lg);font-weight:700}
.dtable-head .spacer{flex:1}
.thead,.trow{display:grid;grid-template-columns:minmax(180px,2fr) minmax(160px,2fr) minmax(140px,1.6fr) 110px 84px;
  align-items:center;gap:var(--sp-4);padding:0 var(--sp-6)}
.thead{position:sticky;top:0;background:var(--surface-2);border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);z-index:1}
.thead .th{padding:10px 0;font-size:var(--t-sm);font-weight:600;color:var(--ink-2);cursor:pointer;
  display:flex;align-items:center;gap:5px;user-select:none}
.thead .th:hover{color:var(--ink)}
.thead .th .ar{font-size:9px;color:var(--accent)}
.tbody{overflow-y:auto}
.trow{min-height:52px;border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--dur)}
.trow:hover{background:var(--surface-2)}
.trow.selected{background:var(--accent-soft)}
.tcell{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:var(--t-md)}
.tcell.dim{color:var(--ink-3);font-size:var(--t-sm)}
.tcell.name{display:flex;align-items:center;gap:var(--sp-3);font-weight:600}
.tcell.name .avatar{width:30px;height:30px;border-radius:var(--r-sm);font-size:var(--t-sm)}
.tcell.acts{display:flex;gap:2px;justify-content:flex-end}

/* ── журнал ── */
.logwrap{padding:var(--sp-8) var(--sp-10);max-width:1320px}
.logwrap h1{font-size:var(--t-xl);font-weight:700;letter-spacing:-.015em}
.logwrap .sub{color:var(--ink-2);margin:var(--sp-1) 0 var(--sp-5);font-size:var(--t-md)}
.log-tools{display:flex;gap:var(--sp-2);margin-bottom:var(--sp-5)}
.log-row{display:flex;gap:var(--sp-3);align-items:center;padding:10px 0;border-bottom:1px solid var(--border)}
.log-ic{width:32px;height:32px;border-radius:var(--r-sm);display:grid;place-items:center;
  background:var(--surface-2);color:var(--ink-2);flex:0 0 auto}
.log-ic.danger{background:var(--danger-soft);color:var(--danger)}
.log-ic.accent{background:var(--accent-soft);color:var(--accent)}
.log-main{flex:1;min-width:0}
.log-act{font-weight:500}.log-act b{font-weight:600}
.log-time{color:var(--ink-3);font-size:var(--t-sm);white-space:nowrap}
.log-empty{color:var(--ink-3);padding:var(--sp-8);text-align:center}

/* ── корзина ── */
.trashwrap{padding:var(--sp-8) var(--sp-10);max-width:1320px}
.trashwrap .htop{display:flex;align-items:center;margin-bottom:var(--sp-2)}
.trashwrap h1{font-size:var(--t-xl);font-weight:700;letter-spacing:-.015em;flex:1}
.trashwrap .sub{color:var(--ink-2);margin-bottom:var(--sp-5);font-size:var(--t-md)}
.trash-row{display:flex;align-items:center;gap:var(--sp-3);background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r);padding:10px var(--sp-4);margin-bottom:var(--sp-2)}
.trash-row .tinfo{flex:1;min-width:0}
.trash-row .tt{font-weight:600}
.trash-row .ts{color:var(--ink-3);font-size:var(--t-sm)}

/* ── архив паролей в детали ── */
.history{margin-top:var(--sp-6);border-top:1px solid var(--border);padding-top:var(--sp-5)}
.history h3{font-size:var(--t-sm);color:var(--ink-2);font-weight:600;margin-bottom:var(--sp-3);
  display:flex;align-items:center;gap:6px}
.hist-row{display:flex;align-items:center;gap:var(--sp-2);background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-sm);padding:8px var(--sp-3);margin-bottom:6px}
.hist-row .hv{flex:1;font-family:var(--mono);font-size:var(--t-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;user-select:text}
.hist-row .ht{color:var(--ink-3);font-size:var(--t-xs);white-space:nowrap}

/* ── статистика в настройках ── */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--sp-3);margin-bottom:var(--sp-6)}
.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:var(--sp-4)}
.stat .n{font-size:var(--t-xl);font-weight:700;letter-spacing:-.01em}
.stat .n.bad{color:var(--danger)}
.stat .l{color:var(--ink-3);font-size:var(--t-sm);margin-top:2px}

/* ── контекстное меню ── */
.ctxmenu{position:fixed;z-index:var(--z-dropdown);background:var(--elevated);border:1px solid var(--border);
  border-radius:var(--r);box-shadow:var(--shadow-lg);padding:5px;min-width:184px;display:none}
.ctxmenu.open{display:block}
.ctxmenu button{display:flex;align-items:center;gap:var(--sp-3);width:100%;padding:8px var(--sp-3);
  border-radius:var(--r-sm);color:var(--ink-2);font-size:var(--t-md);text-align:left;transition:background var(--dur),color var(--dur)}
.ctxmenu button:hover{background:var(--surface-2);color:var(--ink)}
.ctxmenu button.danger:hover{background:var(--danger-soft);color:var(--danger)}
.ctxmenu .ic{stroke:currentColor}
.ctxmenu .sep{height:1px;background:var(--border);margin:5px 4px}

/* ── генератор: энтропия ── */
.gen .entropy{display:flex;align-items:center;gap:var(--sp-2);margin-top:var(--sp-3)}
.gen .ent-bar{flex:1;height:5px;border-radius:var(--r-full);background:var(--border);overflow:hidden}
.gen .ent-fill{height:100%;border-radius:var(--r-full);width:0;transition:width .25s var(--ease),background .25s}
.gen .ent-label{font-size:var(--t-xs);color:var(--ink-2);white-space:nowrap;min-width:110px;text-align:right;font-variant-numeric:tabular-nums}
.gen .opts .ex{flex-basis:100%;margin-top:2px}

/* ── выбор типа записи ── */
.type-pick{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:var(--sp-4)}
.type-pick button{display:flex;align-items:center;gap:7px;padding:8px 12px;border:1px solid var(--border);
  border-radius:var(--r-sm);color:var(--ink-2);font-size:var(--t-sm);font-weight:500;background:var(--surface);transition:border-color var(--dur),color var(--dur),background var(--dur)}
.type-pick button:hover{border-color:var(--border-strong);color:var(--ink)}
.type-pick button.on{border-color:var(--accent-soft-bd);color:var(--accent);background:var(--accent-soft)}
.type-pick .ic{stroke:currentColor}
.type-badge{display:inline-flex;align-items:center;gap:5px;font-size:var(--t-xs);color:var(--ink-3);
  background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-full);padding:2px 9px}
.type-badge .ic{stroke:currentColor;width:13px;height:13px}
.tcell.tp{color:var(--ink-3);font-size:var(--t-sm)}
textarea.mono{font-family:var(--mono);font-size:var(--t-sm);line-height:1.5}

/* ── выбор темы в настройках ── */
.themes{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}
.themes button{padding:7px 12px;border:1px solid var(--border);border-radius:var(--r-sm);
  font-size:var(--t-sm);font-weight:500;color:var(--ink-2);background:var(--surface);transition:border-color var(--dur),color var(--dur),background var(--dur)}
.themes button:hover{border-color:var(--border-strong);color:var(--ink)}
.themes button.on{border-color:var(--accent-soft-bd);color:var(--accent);background:var(--accent-soft)}

/* ── подключения ── */
.conn-note{color:var(--ink-3);font-size:var(--t-sm);line-height:1.55;margin-bottom:var(--sp-3)}
.mono{font-family:var(--mono)}
.audit-card .set-row{border-bottom:1px solid var(--border)}
.audit-card .set-row:last-child{border-bottom:0}

@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}
