/* re:premium Password Manager — стили (только через var(--token)) */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; height: 100%; }
body {
  font-family: var(--font-sans);
  font-size: var(--text-body);
  color: var(--color-ink);
  background: var(--color-canvas);
  line-height: var(--lh-normal);
  -webkit-font-smoothing: antialiased;
}
button { font-family: inherit; cursor: pointer; }
a { color: var(--color-accent); text-decoration: none; }
a:hover { text-decoration: underline; }
.muted { color: var(--color-ink-2); }

/* ───────── Кнопки ───────── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
  height: var(--control-h); padding: 0 var(--space-6);
  border: 1px solid transparent; border-radius: var(--radius-pill);
  font-size: var(--text-body); font-weight: var(--fw-semibold);
  transition: background var(--dur-fast) var(--ease), transform var(--dur-fast) var(--ease);
}
.btn:active { transform: scale(.98); }
.btn:disabled { opacity: .5; cursor: not-allowed; }
.btn:focus-visible { outline: 2px solid var(--color-accent); outline-offset: 2px; }
.btn-primary { background: var(--color-action); color: var(--color-on-action); }
.btn-primary:hover:not(:disabled) { background: var(--color-action-600); }
.btn-secondary { background: var(--color-surface); color: var(--color-ink); border-color: var(--color-line); }
.btn-secondary:hover:not(:disabled) { background: var(--color-surface-2); }
.btn-ghost { background: transparent; color: var(--color-accent); }
.btn-ghost:hover:not(:disabled) { background: var(--color-accent-tint); }
.btn-danger { background: var(--color-danger); color: var(--color-on-action); }
.btn-danger:hover:not(:disabled) { background: var(--color-action-600); }
.btn-sm { height: var(--control-h-sm); padding: 0 var(--space-4); font-size: var(--text-subhead); }
.btn-block { width: 100%; }
.icon-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: var(--hit-min); height: var(--hit-min); min-width: var(--hit-min);
  border: none; background: transparent; color: var(--color-ink-2);
  border-radius: var(--radius-pill); font-size: var(--text-title3); line-height: 1;
  transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
}
.icon-btn:hover { background: var(--color-surface-2); color: var(--color-ink); }

/* ───────── Поля ───────── */
.field { display: flex; flex-direction: column; gap: var(--space-2); }
.field-label { font-size: var(--text-footnote); font-weight: var(--fw-semibold); color: var(--color-ink-2); }
.input, .select, .textarea {
  width: 100%; height: var(--control-h); padding: 0 var(--space-4);
  border: 1px solid var(--color-line); border-radius: var(--radius-md);
  background: var(--color-surface); color: var(--color-ink);
  font-family: inherit; font-size: var(--text-body);
  transition: border-color var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease);
}
.textarea { height: auto; min-height: calc(var(--control-h) * 2); padding: var(--space-3) var(--space-4); resize: vertical; }
.input:focus, .select:focus, .textarea:focus {
  outline: none; border-color: var(--color-accent);
  box-shadow: 0 0 0 3px var(--color-accent-tint);
}
.input::placeholder { color: var(--color-ink-3); }
.form-error { color: var(--color-danger); font-size: var(--text-subhead); margin: 0; }

/* ───────── Экран входа ───────── */
.auth-body { display: flex; align-items: center; justify-content: center; min-height: 100vh; padding: var(--space-5); }
.auth-card {
  width: 100%; max-width: 380px; background: var(--color-surface);
  border-radius: var(--radius-xl); box-shadow: var(--shadow-lg);
  padding: var(--space-8) var(--space-6); text-align: center;
}
.auth-logo { height: 32px; margin-bottom: var(--space-5); }
.auth-title { font-family: var(--font-display); font-size: var(--text-title2); margin: 0 0 var(--space-1); }
.auth-sub { color: var(--color-ink-2); margin: 0 0 var(--space-6); font-size: var(--text-subhead); }
.auth-form { display: flex; flex-direction: column; gap: var(--space-4); text-align: left; }
.auth-form .btn { margin-top: var(--space-2); }

/* ───────── Раскладка ───────── */
.layout { display: grid; grid-template-columns: 280px 1fr; height: 100vh; }
.sidebar {
  display: flex; flex-direction: column; background: var(--color-surface);
  border-right: 1px solid var(--color-line); padding: var(--space-5) var(--space-4);
}
.brand { display: flex; align-items: baseline; gap: var(--space-2); padding: 0 var(--space-2) var(--space-5); }
.brand-logo { height: 22px; }
.brand-sub { font-weight: var(--fw-bold); color: var(--color-ink-2); font-size: var(--text-subhead); }
.vault-nav { flex: 1; overflow-y: auto; }
.nav-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 var(--space-2) var(--space-3); color: var(--color-ink-2);
  font-size: var(--text-footnote); font-weight: var(--fw-bold); text-transform: uppercase; letter-spacing: .04em;
}
.vault-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--space-1); }
.vault-item {
  display: flex; align-items: center; gap: var(--space-3);
  padding: var(--space-3); border-radius: var(--radius-md);
  color: var(--color-ink); transition: background var(--dur-fast) var(--ease);
}
.vault-item:hover { background: var(--color-surface-2); }
.vault-item.active { background: var(--color-accent-tint); }
.vault-dot { width: var(--space-3); height: var(--space-3); border-radius: var(--radius-pill); flex: none; background: var(--color-accent); }
.vault-dot.action { background: var(--color-action); }
.vault-dot.success { background: var(--color-success); }
.vault-dot.warning { background: var(--color-warning); }
.vault-dot.ink { background: var(--color-ink); }
.vault-item-name { flex: 1; font-weight: var(--fw-medium); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.vault-item-count { color: var(--color-ink-3); font-size: var(--text-footnote); }

.sidebar-foot { border-top: 1px solid var(--color-line); padding-top: var(--space-4); margin-top: var(--space-4); display: flex; flex-direction: column; gap: var(--space-3); }
.nav-link { background: transparent; border: none; text-align: left; padding: var(--space-2) var(--space-3); border-radius: var(--radius-md); color: var(--color-ink-2); font-size: var(--text-subhead); }
.nav-link:hover { background: var(--color-surface-2); color: var(--color-ink); }
.user-chip { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-2) var(--space-3); }
.user-avatar { width: var(--space-8); height: var(--space-8); border-radius: var(--radius-pill); background: var(--color-action-tint); color: var(--color-action); display: inline-flex; align-items: center; justify-content: center; font-weight: var(--fw-bold); text-transform: uppercase; flex: none; }
.user-meta { flex: 1; display: flex; flex-direction: column; line-height: var(--lh-tight); overflow: hidden; }
.user-name { font-weight: var(--fw-semibold); font-size: var(--text-subhead); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.user-role { font-size: var(--text-caption); color: var(--color-ink-3); }

/* ───────── Основная область ───────── */
.main { display: flex; flex-direction: column; overflow: hidden; }
.topbar {
  display: flex; align-items: center; gap: var(--space-4);
  padding: var(--space-4) var(--space-6); border-bottom: 1px solid var(--color-line);
  background: var(--color-surface);
}
.search-box { flex: 1; max-width: 560px; }
.search-input { height: var(--control-h); border-radius: var(--radius-pill); }
.topbar-actions { display: flex; gap: var(--space-3); margin-left: auto; }
.content { flex: 1; overflow-y: auto; padding: var(--space-6); }

.empty-state { text-align: center; margin-top: var(--space-10); color: var(--color-ink-2); }
.empty-state h2 { font-family: var(--font-display); color: var(--color-ink); }

/* Заголовок хранилища */
.vault-header { display: flex; align-items: flex-start; gap: var(--space-4); margin-bottom: var(--space-5); }
.vault-header h1 { font-family: var(--font-display); font-size: var(--text-title1); margin: 0; }
.vault-header .muted { margin: var(--space-1) 0 0; }
.vault-header-actions { margin-left: auto; display: flex; gap: var(--space-2); }
.role-badge {
  display: inline-flex; align-items: center; padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-pill); font-size: var(--text-caption); font-weight: var(--fw-semibold);
  background: var(--color-surface-2); color: var(--color-ink-2);
}
.role-badge.owner { background: var(--color-action-tint); color: var(--color-action); }
.role-badge.editor { background: var(--color-accent-tint); color: var(--color-accent); }
.role-badge.admin { background: var(--color-ink); color: var(--color-on-dark); }

/* Папки-чипы */
.folder-bar { display: flex; flex-wrap: wrap; gap: var(--space-2); margin-bottom: var(--space-5); }
.chip {
  display: inline-flex; align-items: center; gap: var(--space-2);
  height: var(--control-h-sm); padding: 0 var(--space-4);
  border-radius: var(--radius-pill); border: 1px solid var(--color-line);
  background: var(--color-surface); color: var(--color-ink-2); font-size: var(--text-subhead);
}
.chip:hover { background: var(--color-surface-2); }
.chip.active { background: var(--color-ink); color: var(--color-on-dark); border-color: var(--color-ink); }

/* Список записей */
.pw-grid { display: grid; gap: var(--space-3); }
.pw-card {
  display: flex; align-items: center; gap: var(--space-4);
  background: var(--color-surface); border: 1px solid var(--color-line);
  border-radius: var(--radius-lg); padding: var(--space-4) var(--space-5);
  box-shadow: var(--shadow-sm); transition: box-shadow var(--dur-fast) var(--ease);
}
.pw-card:hover { box-shadow: var(--shadow-md); }
.pw-icon {
  width: var(--space-10); height: var(--space-10); border-radius: var(--radius-md);
  background: var(--color-surface-2); color: var(--color-ink-2);
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: var(--fw-bold); font-size: var(--text-title3); text-transform: uppercase; flex: none;
}
.pw-body { flex: 1; min-width: 0; }
.pw-name { font-weight: var(--fw-semibold); }
.pw-meta { color: var(--color-ink-2); font-size: var(--text-subhead); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.pw-actions { display: flex; gap: var(--space-1); }

/* Таблицы (админ/аудит/участники) */
.table { width: 100%; border-collapse: collapse; background: var(--color-surface); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-sm); }
.table th, .table td { text-align: left; padding: var(--space-3) var(--space-4); border-bottom: 1px solid var(--color-line); font-size: var(--text-subhead); }
.table th { color: var(--color-ink-2); font-weight: var(--fw-semibold); font-size: var(--text-footnote); text-transform: uppercase; letter-spacing: .03em; }
.table tr:last-child td { border-bottom: none; }
.section-title { font-family: var(--font-display); font-size: var(--text-title2); margin: 0 0 var(--space-4); }

/* ───────── Модалки ───────── */
.overlay { position: fixed; inset: 0; background: rgba(17,17,17,.4); display: flex; align-items: center; justify-content: center; padding: var(--space-5); z-index: 50; }
.modal { width: 100%; max-width: 520px; max-height: 90vh; overflow-y: auto; background: var(--color-surface); border-radius: var(--radius-xl); box-shadow: var(--shadow-lg); padding: var(--space-6); }
.modal-lg { max-width: 720px; }
.modal-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--space-5); }
.modal-head h3 { font-family: var(--font-display); font-size: var(--text-title2); margin: 0; }
.modal-body { display: flex; flex-direction: column; gap: var(--space-4); }
.modal-foot { display: flex; justify-content: flex-end; gap: var(--space-3); margin-top: var(--space-6); }
.row { display: flex; gap: var(--space-3); }
.row > * { flex: 1; }

.input-with-btn { display: flex; gap: var(--space-2); }
.input-with-btn .input { flex: 1; }

/* Генератор */
.gen-output { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: var(--text-title3); word-break: break-all; padding: var(--space-4); background: var(--color-surface-2); border-radius: var(--radius-md); text-align: center; }
.gen-controls { display: flex; flex-direction: column; gap: var(--space-3); }
.gen-len { display: flex; align-items: center; gap: var(--space-3); }
.gen-len input[type=range] { flex: 1; accent-color: var(--color-action); }
.checks { display: flex; flex-wrap: wrap; gap: var(--space-3); }
.check { display: inline-flex; align-items: center; gap: var(--space-2); font-size: var(--text-subhead); color: var(--color-ink-2); }
.check input { accent-color: var(--color-action); width: var(--space-4); height: var(--space-4); }

/* Toast */
.toast { position: fixed; bottom: var(--space-6); left: 50%; transform: translateX(-50%); background: var(--color-ink); color: var(--color-on-dark); padding: var(--space-3) var(--space-5); border-radius: var(--radius-pill); box-shadow: var(--shadow-md); z-index: 100; font-size: var(--text-subhead); }

.badge { display: inline-flex; align-items: center; padding: var(--space-1) var(--space-2); border-radius: var(--radius-pill); font-size: var(--text-caption); font-weight: var(--fw-semibold); background: var(--color-surface-2); color: var(--color-ink-2); }
.badge.on { background: var(--color-success); color: var(--color-on-action); }
.badge.off { background: var(--color-surface-2); color: var(--color-ink-3); }

/* Вложения */
.att-list { display: flex; flex-direction: column; gap: var(--space-2); margin-bottom: var(--space-2); }
.att-item { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-2) var(--space-3); background: var(--color-surface-2); border-radius: var(--radius-md); }
.att-name { flex: 1; font-size: var(--text-subhead); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.att-size { color: var(--color-ink-3); font-size: var(--text-footnote); }
.att-upload { display: inline-flex; width: fit-content; cursor: pointer; }

/* Код / моноширинный */
code { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: var(--text-footnote); background: var(--color-surface-2); padding: 0 var(--space-1); border-radius: var(--radius-xs); }

/* Коды восстановления 2FA */
.recov { margin-top: var(--space-4); padding: var(--space-4); background: var(--color-action-tint); border-radius: var(--radius-md); }
.recov-codes { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-2); margin: var(--space-3) 0; }
.recov-codes code { background: var(--color-surface); text-align: center; padding: var(--space-2); font-size: var(--text-subhead); }

@media (max-width: 760px) {
  .layout { grid-template-columns: 1fr; }
  .sidebar { display: none; }
}
