/* ZZ Keychain v3.0 — No-Scroll-by-Design
   Regeln großer Meister 2026-05-29:
   1. Scrollbalken NIEMALS sichtbar
   2. Login/Register/2FA/Lock/Modals passen in 100vh — kein Scroll nötig
   3. Nur Vault-Browser darf scrollen (Item-Liste + Detail-Pane), Balken trotzdem hidden

   Strategie ggü v2:
   - Layout-Dichte gewinnt — kompakter spacing, kein lockerer Wuchs
   - Card-padding var(--space-3) statt --space-4
   - title 28px statt 32px
   - field-gaps minimiert
   - hint = 1 zeile max
   - register: 2-Spalten-Layout für form
   - item-edit modal: 2-Spalten + max-height 100vh - 3rem
   - generator modal: kompakter Toggle-Grid 2-col
*/

@font-face { font-family: 'NotoSerifEC'; src: url('../assets/NotoSerifDisplay_ExtraCondensed-ExtraLight.ttf') format('truetype'); font-weight: 200; font-display: block; }
@font-face { font-family: 'NotoSerifEC'; src: url('../assets/NotoSerifDisplay_ExtraCondensed-Regular.ttf')    format('truetype'); font-weight: 400; font-display: block; }
@font-face { font-family: 'NotoSerifEC'; src: url('../assets/NotoSerifDisplay_ExtraCondensed-Bold.ttf')       format('truetype'); font-weight: 700; font-display: block; }
@font-face { font-family: 'Neue Montreal'; src: url('../assets/PPNeueMontreal-Light.otf')    format('opentype'); font-weight: 300; font-display: swap; }
@font-face { font-family: 'Neue Montreal'; src: url('../assets/PPNeueMontreal-Regular.otf')  format('opentype'); font-weight: 400; font-display: swap; }
@font-face { font-family: 'Neue Montreal'; src: url('../assets/PPNeueMontreal-Semibold.otf') format('opentype'); font-weight: 600; font-display: swap; }
@font-face { font-family: 'Glock'; src: url('../assets/GlockGrotesque2-Regular.otf') format('opentype'); font-weight: 400; font-display: swap; }
@font-face { font-family: 'Glock'; src: url('../assets/GlockGrotesque2-Medium.otf')  format('opentype'); font-weight: 500; font-display: swap; }

:root {
  --bg:#141414; --bg-2:#0d0d0d;
  --sf:#1f1f1f; --sf-2:#1a1a1a; --sf-h:#262626;
  --bd:rgba(255,255,255,.10); --bd-l:rgba(255,255,255,.16);
  --t:#f0f0f0; --t2:rgba(255,255,255,.72); --tm:rgba(255,255,255,.50); --td:rgba(255,255,255,.32);
  --ac:#c4966c; --ac-h:#d4a47a; --ac-soft:rgba(196,150,108,.16); --on-ac:#1a1a1a;
  --ok:#5fcb87; --err:#e55c5c; --warn:#fbbf24;
  --rad-xs:6px; --rad-sm:8px; --rad-md:10px; --rad-lg:14px; --rad-pill:999px;
  --s-1:.5rem; --s-2:1rem; --s-3:1.5rem; --s-4:2rem; --s-5:3rem; --s-6:4rem; --s-7:6rem;
  --body:'Neue Montreal',system-ui,-apple-system,sans-serif;
  --display:'Glock','Neue Montreal',sans-serif;
  --zz:'NotoSerifEC','Noto Serif Display',Georgia,serif;
  --mono:ui-monospace,'SF Mono',Menlo,monospace;
  --shadow-lg:0 30px 60px -10px rgba(0,0,0,.75);
  --shadow-md:0 12px 32px -10px rgba(0,0,0,.5);
  --sidebar-w:248px; --sidebar-w-collapsed:60px;
}

* , *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100vh; max-height: 100vh; overflow: hidden; }
body { background: var(--bg); color: var(--t); font: 400 14.5px/1.55 var(--body); -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }
img, svg { display: block; max-width: 100%; }

/* ─── Scrollbar (NIEMALS sichtbar) ───────────────────────────── */
html, body, * { scrollbar-width: none; -ms-overflow-style: none; }
*::-webkit-scrollbar { display: none; width: 0; height: 0; }

/* ─── Background stage ────────────────────────────────────────── */
.bg-stage { position: fixed; inset: 0; z-index: 0; overflow: hidden; background: #0a0907; }
.bg-stage::before {
  content: ''; position: absolute; inset: 0;
  background:
    radial-gradient(1200px 600px at 75% 20%, rgba(196,150,108,.22), transparent 60%),
    radial-gradient(900px 500px at 20% 80%, rgba(196,150,108,.12), transparent 60%),
    linear-gradient(135deg, #1d1612 0%, #0d0a08 60%, #050403 100%);
}
.bg-stage::after {
  content: ''; position: absolute; inset: 0;
  background-image: radial-gradient(rgba(255,255,255,.045) 1px, transparent 1px);
  background-size: 4px 4px; opacity: .55;
}
.bg-grad { position: fixed; inset: 0; z-index: 1; pointer-events: none;
  background: linear-gradient(90deg, rgba(0,0,0,.74) 0%, rgba(0,0,0,.48) 30%, rgba(0,0,0,.22) 60%, rgba(0,0,0,.10) 100%); }

/* ─── ZZ Statement ──────────────────────────────────────────── */
.statement {
  position: fixed; top: var(--s-3); left: calc(clamp(var(--s-3), 6vw, var(--s-7)) + var(--s-4));
  z-index: 5; font-family: var(--zz); font-size: 30px; font-weight: 200;
  letter-spacing: -.044em; color: var(--t); line-height: 1.1;
}
.statement .em { color: var(--t); font-weight: 400; letter-spacing: -.2em; margin-right: .2em; }
@media (max-width: 760px) { .statement { left: calc(var(--s-3) + var(--s-3)); font-size: 24px; } }

/* ─── Utility top-right ─────────────────────────────────────── */
.utility { position: fixed; top: var(--s-3); right: clamp(var(--s-3), 6vw, var(--s-7)); z-index: 5; display: flex; align-items: center; gap: var(--s-2); }
.lang {
  display: inline-flex; align-items: center; gap: .4rem;
  padding: .5rem .8rem; background: var(--ac-soft); border: .5px solid var(--bd-l);
  border-radius: var(--rad-pill); color: var(--t2); font: 600 12px/1 var(--body);
  letter-spacing: .06em; min-height: 34px;
}
.lang:hover { background: rgba(196,150,108,.24); border-color: var(--ac); color: var(--t); }
.lang .cur { color: var(--t); } .lang .sep { color: var(--td); } .lang .alt { color: var(--tm); }

/* ─── Stage (centered, no scroll) ──────────────────────────── */
.stage {
  position: fixed; inset: 0; z-index: 2;
  display: flex; align-items: center; justify-content: flex-start;
  padding: var(--s-3) var(--s-3) var(--s-3) clamp(var(--s-3), 6vw, var(--s-7));
}
@media (max-width: 760px) { .stage { justify-content: center; padding: 4.5rem var(--s-2) var(--s-2); } }

/* ─── Card (kompakter als v2) ────────────────────────────────── */
.card {
  width: 100%; max-width: 380px;
  background: rgba(24,24,24,.82);
  backdrop-filter: blur(24px) saturate(140%); -webkit-backdrop-filter: blur(24px) saturate(140%);
  border: .5px solid var(--bd-l); border-radius: var(--rad-lg);
  padding: var(--s-3) var(--s-3) calc(var(--s-3) + .25rem);
  display: flex; flex-direction: column; gap: .85rem;
  box-shadow: var(--shadow-lg), 0 1px 0 rgba(255,255,255,.05) inset;
  animation: cardIn .4s cubic-bezier(.2,.7,.2,1);
  max-height: calc(100vh - 6rem);
}
.card.wide { max-width: 540px; }
.card.wider { max-width: 640px; }
@keyframes cardIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }

/* ─── Title block ──────────────────────────────────────────── */
.title-block { display: flex; flex-direction: column; gap: .35rem; margin-bottom: .15rem; }
.title { font-family: var(--display); font-size: 26px; font-weight: 400; letter-spacing: -.015em; text-transform: lowercase; line-height: 1.2; color: var(--t); }
.subtitle { color: var(--t2); font-size: 13.5px; font-weight: 300; line-height: 1.5; }

/* ─── Form fields ─────────────────────────────────────────── */
.field { display: flex; flex-direction: column; gap: .35rem; }
.label { font-size: 11.5px; color: var(--t2); letter-spacing: .07em; text-transform: uppercase; font-weight: 600; line-height: 1.3; }
.inp {
  width: 100%; background: var(--sf-2); border: .5px solid var(--bd);
  border-radius: var(--rad-sm); padding: .7rem .9rem;
  color: var(--t); font: 14.5px var(--body); min-height: 40px;
  transition: border-color .12s, background .12s;
}
.inp:focus { outline: none; border-color: var(--ac); background: var(--sf); }
.inp::placeholder { color: var(--tm); }
.inp-wrap { position: relative; }
/* Text/Platzhalter darf nie unter dem Aktions-Icon liegen oder den Rand berühren */
.inp-wrap .inp { padding-right: 3rem; }
.inp-action {
  position: absolute; right: .55rem; top: 50%; transform: translateY(-50%);
  background: transparent; border: 0; color: var(--tm);
  width: 30px; height: 30px;
  display: inline-flex; align-items: center; justify-content: center; border-radius: var(--rad-sm);
}
.inp-action:hover { color: var(--ac); background: var(--ac-soft); }
.inp.code { text-align: center; letter-spacing: .25em; font: 600 20px var(--mono); padding-block: .75rem; min-height: 52px; }

.hint { color: var(--tm); font-size: 12.5px; margin-top: .15rem; line-height: 1.45; }
.hint a { color: var(--ac); }
.hint a:hover { color: var(--ac-h); }

/* ─── Buttons ─────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
  background: var(--ac); color: var(--on-ac);
  border: 0; border-radius: var(--rad-pill);
  font: 600 14px var(--body); padding: .8rem 1.35rem; min-height: 44px;
  transition: background .12s, transform .08s;
}
.btn:hover { background: var(--ac-h); }
.btn:active { transform: translateY(1px); }
.btn:disabled { opacity: .4; cursor: not-allowed; }
.btn.ghost { background: transparent; color: var(--t); border: .5px solid var(--bd-l); }
.btn.ghost:hover { background: var(--ac-soft); border-color: var(--ac); }
.btn.danger { background: rgba(229,92,92,.16); color: var(--err); border: .5px solid rgba(229,92,92,.32); }
.btn.danger:hover { background: rgba(229,92,92,.24); }
.btn.sm { padding: .55rem 1rem; font-size: 13px; min-height: 36px; }

/* ─── Icon button ─────────────────────────────────────────── */
.icon-btn {
  width: 36px; height: 36px; border-radius: var(--rad-sm);
  background: transparent; border: 0; color: var(--tm);
  display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.icon-btn:hover { background: var(--sf-h); color: var(--ac); }
.icon-btn:focus-visible { outline: 2px solid var(--ac); outline-offset: 1px; }
.icon-btn.lg { width: 42px; height: 42px; }

/* ─── Alert ─────────────────────────────────────────────── */
.alert { padding: .65rem .85rem; border-radius: var(--rad-sm); font-size: 13px; line-height: 1.45; display: flex; align-items: flex-start; gap: .55rem; }
.alert.err  { background: rgba(229,92,92,.12); border: .5px solid rgba(229,92,92,.32); color: #f4bdbd; }
.alert.ok   { background: rgba(95,203,135,.12); border: .5px solid rgba(95,203,135,.32); color: #b8ecc9; }
.alert.warn { background: rgba(251,191,36,.12); border: .5px solid rgba(251,191,36,.32); color: #f2dba0; }
.alert svg { flex-shrink: 0; margin-top: .15rem; }

/* ─── Divider with text ─────────────────────────────────── */
.div-text { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: .75rem; color: var(--tm); font-size: 11px; letter-spacing: .15em; text-transform: uppercase; font-weight: 600; margin: 0; }
.div-text::before, .div-text::after { content: ''; height: .5px; background: var(--bd); }

/* ─── Foot mini ─────────────────────────────────────────── */
.foot-mini {
  position: fixed; bottom: var(--s-3); left: clamp(var(--s-3), 6vw, var(--s-7));
  color: var(--td); font: 400 11.5px/1.4 var(--mono); letter-spacing: .04em; z-index: 4;
}
.foot-mini a { color: var(--tm); padding: 0 .2rem; }
.foot-mini a:hover { color: var(--ac); }

/* ─── App-shell (vault only — Scroll erlaubt) ──────────── */
.app {
  display: grid;
  grid-template-columns: var(--sidebar-w) 360px 1fr;
  grid-template-rows: 60px 1fr;
  grid-template-areas: "topbar topbar topbar" "sidebar list detail";
  height: 100vh; background: var(--bg);
  transition: grid-template-columns .25s cubic-bezier(.2,.7,.2,1);
}
.app.collapsed { grid-template-columns: var(--sidebar-w-collapsed) 360px 1fr; }
.app.collapsed .sidebar { padding: var(--s-2) .4rem; }
.app.collapsed .side-link { justify-content: center; padding: .6rem; }
.app.collapsed .side-link span:not(.ic-wrap), .app.collapsed .side-link .count { display: none; }
.app.collapsed .side-group h4 { display: none; }
.app.collapsed .side-group { margin-bottom: var(--s-2); padding-bottom: var(--s-2); border-bottom: .5px solid var(--bd); }
.app.collapsed .side-group:last-child { border: 0; }
.app.collapsed .brand-mini .sub { display: none; }

.app .topbar {
  grid-area: topbar; display: flex; align-items: center; gap: var(--s-2);
  padding: 0 var(--s-3); background: rgba(20,20,20,.92);
  backdrop-filter: blur(16px); border-bottom: .5px solid var(--bd);
  position: relative; z-index: 40;   /* über der tabs-bar (z-20) — sonst klemmt das App-Menü hinter dem Tab-Header (backdrop-filter erzeugt einen Stacking-Context) */
}
.app .sidebar { grid-area: sidebar; background: var(--sf-2); border-right: .5px solid var(--bd); padding: var(--s-2); overflow-y: auto; }
.app .list { grid-area: list; background: var(--bg); border-right: .5px solid var(--bd); overflow-y: auto; }
.app .detail { grid-area: detail; background: var(--bg-2); overflow-y: auto; }

.collapse-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px; border-radius: var(--rad-sm);
  background: transparent; border: 0; color: var(--tm); flex-shrink: 0;
}
.collapse-btn:hover { background: var(--sf-h); color: var(--ac); }

.brand-mini { display: inline-flex; align-items: center; gap: .6rem; color: var(--t); }
.brand-mini .zz { font-family: var(--zz); font-size: 24px; font-weight: 700; letter-spacing: -.2em; line-height: 1; padding-right: .2em; }
.brand-mini .sub { font-family: var(--display); font-size: 14px; color: var(--t2); border-left: 1px solid var(--bd-l); padding-left: .65rem; line-height: 1; }

.search {
  display: inline-flex; align-items: center; gap: .6rem;
  background: var(--sf); border: .5px solid var(--bd); border-radius: var(--rad-pill);
  padding: .55rem .9rem; flex: 1; min-width: 0; max-width: 540px;
  margin: 0 var(--s-2); min-height: 40px;
}
.search input { background: transparent; border: 0; outline: 0; color: var(--t); font: 14px var(--body); flex: 1; min-width: 0; }
.search input::placeholder { color: var(--tm); }
.search .kbd { color: var(--td); font: 11.5px var(--mono); padding: .2rem .45rem; border: .5px solid var(--bd); border-radius: 4px; flex-shrink: 0; }

.avatar { width: 34px; height: 34px; border-radius: 50%; background: var(--ac-soft); border: .5px solid var(--bd-l); color: var(--ac); display: grid; place-items: center; font: 600 12.5px var(--body); letter-spacing: .04em; flex-shrink: 0; }

/* ─── Sidebar ─────────────────────────────────────────── */
.side-group { margin-bottom: var(--s-3); }
.side-group h4 { font-size: 10.5px; color: var(--tm); letter-spacing: .15em; text-transform: uppercase; padding: .5rem .6rem .3rem; font-weight: 600; line-height: 1.4; }
.side-link {
  display: flex; align-items: center; gap: .65rem;
  padding: .55rem .65rem; border-radius: var(--rad-sm);
  color: var(--t2); font: 500 13.5px var(--body); min-height: 36px;
  transition: background .12s, color .12s; cursor: pointer;
}
.side-link:hover { background: var(--sf-h); color: var(--t); }
.side-link.active { background: var(--ac-soft); color: var(--t); }
.side-link.active .ic { color: var(--ac); }
.side-link .ic { width: 17px; height: 17px; color: var(--tm); flex-shrink: 0; }
.side-link .count { margin-left: auto; font: 500 11.5px var(--mono); color: var(--td); }
.side-link.active .count { color: var(--ac); }

/* ─── Items list ─────────────────────────────────────── */
.list-head { padding: var(--s-2) var(--s-3); border-bottom: .5px solid var(--bd); display: flex; flex-direction: column; gap: .25rem; position: sticky; top: 0; background: var(--bg); z-index: 1; }
.list-head h2 { font-family: var(--display); font-size: 19px; font-weight: 400; text-transform: lowercase; letter-spacing: -.005em; color: var(--t); line-height: 1.25; }
.list-head .meta { color: var(--tm); font: 12px var(--mono); line-height: 1.4; }

.item {
  display: grid; grid-template-columns: 38px 1fr 22px; gap: var(--s-2); align-items: center;
  padding: .85rem var(--s-3); border-bottom: .5px solid var(--bd);
  cursor: pointer; transition: background .12s; min-height: 60px;
}
.item:hover { background: var(--sf-2); }
.item.active { background: var(--ac-soft); border-left: 3px solid var(--ac); padding-left: calc(var(--s-3) - 3px); }
.item .ico { width: 34px; height: 34px; border-radius: var(--rad-sm); background: var(--sf-h); display: grid; place-items: center; color: var(--ac); font: 600 13.5px var(--body); flex-shrink: 0; overflow: hidden; }
.item .ico.web  { background: linear-gradient(135deg, #3a2a1f, #1f1715); }
.item .ico.note { background: linear-gradient(135deg, #3a3a2a, #1f1f15); color: #e3d18a; }
.item .ico.id   { background: linear-gradient(135deg, #2a2a3a, #15151f); color: #9aa3d4; }
.item .ico.ssh  { background: linear-gradient(135deg, #3a2a3a, #1f151f); color: #c490c5; }
/* Karten-Format: breiter, mit echtem Brand-Logo auf hellem Background — wie eine Mini-Kreditkarte */
.item .ico.card-fmt {
  width: 44px; height: 30px; border-radius: 4px;
  background: linear-gradient(135deg, #ffffff 0%, #f0f0f0 100%);
  display: grid; place-items: center; padding: 4px;
  box-shadow: 0 2px 6px rgba(0,0,0,.35), 0 1px 0 rgba(255,255,255,.08) inset;
}
.item .ico.card-fmt svg, .item .ico.card-fmt img { width: 100%; height: 100%; object-fit: contain; }
/* Brand-Logo Container — weißer Tile für color-SVGs */
.item .ico.brand {
  background: #ffffff; padding: 5px;
  box-shadow: 0 1px 3px rgba(0,0,0,.25);
}
.item .ico.brand svg, .item .ico.brand img { width: 100%; height: 100%; object-fit: contain; }
.item .ico.brand-dark { background: #1a1a1a; border: .5px solid var(--bd-l); }
.item .ico.brand-dark svg, .item .ico.brand-dark img { filter: invert(1); }
/* Item grid muss Karten-Format-Breite akzeptieren */
.item { grid-template-columns: 44px 1fr 22px !important; }
.item .name { display: flex; flex-direction: column; gap: .15rem; min-width: 0; }
.item .name .n1 { font: 500 13.5px var(--body); color: var(--t); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; line-height: 1.3; }
.item .name .n2 { font: 400 12.5px var(--body); color: var(--tm); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; line-height: 1.3; }
.item .chev { color: var(--td); }
.item.active .chev { color: var(--ac); }

/* ─── Detail pane ────────────────────────────────────── */
.detail-wrap { padding: var(--s-3) var(--s-4) var(--s-4); display: flex; flex-direction: column; gap: var(--s-2); max-width: 720px; }
.detail-head { display: flex; align-items: center; gap: var(--s-2); margin-bottom: var(--s-2); }
.detail-head .ico-lg { width: 56px; height: 56px; border-radius: var(--rad-md); background: linear-gradient(135deg, #3a2a1f, #1f1715); display: grid; place-items: center; color: var(--ac); font: 700 22px var(--body); flex-shrink: 0; }
.detail-head .h-name { font: 500 24px/1.2 var(--display); text-transform: lowercase; color: var(--t); letter-spacing: -.01em; }
.detail-head .h-meta { color: var(--tm); font: 13px var(--body); margin-top: .25rem; line-height: 1.4; }
.detail-actions { display: flex; gap: .5rem; flex-wrap: wrap; }

.row {
  display: grid; grid-template-columns: 140px 1fr auto;
  gap: var(--s-2); align-items: center;
  padding: .75rem .95rem; background: var(--sf-2); border: .5px solid var(--bd); border-radius: var(--rad-sm);
  margin-bottom: .35rem; min-height: 46px;
}
.row .k { color: var(--tm); font: 600 11.5px var(--body); letter-spacing: .07em; text-transform: uppercase; }
.row .v { color: var(--t); font: 14px var(--body); word-break: break-all; min-width: 0; line-height: 1.4; }
.row .v.mono { font-family: var(--mono); font-size: 13.5px; }
.row .v.dot  { letter-spacing: .4em; font-family: var(--mono); color: var(--ac); }
.row .row-actions { display: flex; gap: .3rem; }

.section-head { display: flex; align-items: center; gap: var(--s-1); margin: var(--s-2) 0 var(--s-1); padding: 0 .15rem; }
.section-head h3 { font: 600 12px var(--body); letter-spacing: .15em; text-transform: uppercase; color: var(--ac); }
.section-head::after { content: ''; flex: 1; height: .5px; background: var(--bd); }

.tag { display: inline-flex; align-items: center; gap: .3rem; padding: .25rem .55rem; background: var(--ac-soft); color: var(--ac); border-radius: 6px; font: 600 11.5px var(--body); letter-spacing: .04em; }

/* ─── Modal (no-scroll) ─────────────────────────────── */
.modal-shade { position: fixed; inset: 0; z-index: 50; background: rgba(0,0,0,.62); backdrop-filter: blur(8px); display: grid; place-items: center; padding: var(--s-2); }
.modal {
  background: rgba(24,24,24,.94); backdrop-filter: blur(24px);
  border: .5px solid var(--bd-l); border-radius: var(--rad-lg);
  width: 100%; max-width: 520px; max-height: calc(100vh - 2rem); overflow-y: auto;
  padding: var(--s-3);
  display: flex; flex-direction: column; gap: .75rem;
  box-shadow: var(--shadow-lg);
}
.modal.wide { max-width: 560px; }
/* Kopf bleibt beim Scrollen oben → Schließen-Button immer erreichbar (Modal nie „nicht schließbar") */
.modal-head {
  display: flex; align-items: center; justify-content: space-between;
  position: sticky; top: 0; z-index: 5;
  /* full-bleed über die Modal-Polster (negative L/R/Top), aber genug Boden-Clearance:
     der negative Top-Margin zieht die Folge-Zeile um --s-3 (24px) hoch, der Gap deckt
     nur 12px → ohne Boden-Margin überlappt der opake Header den Typ-Picker. */
  margin: calc(-1 * var(--s-3)) calc(-1 * var(--s-3)) var(--s-3);
  padding: var(--s-3) var(--s-3) .7rem;
  background: rgba(24,24,24,.97); backdrop-filter: blur(8px);
}
.modal-head .h { font: 500 22px var(--display); text-transform: lowercase; letter-spacing: -.01em; }
.modal-head .close { width: 34px; height: 34px; border-radius: 50%; background: var(--sf); border: .5px solid var(--bd); color: var(--t2); display: inline-flex; align-items: center; justify-content: center; }
.modal-head .close:hover { color: var(--ac); border-color: var(--ac); }

/* ─── Generator ─────────────────────────────────────── */
.pw-preview { background: var(--sf-2); border: .5px solid var(--bd); border-radius: var(--rad-sm); padding: .85rem 1rem; font: 600 17px var(--mono); color: var(--t); word-break: break-all; letter-spacing: .04em; line-height: 1.35; }
.pw-strength { height: 3px; border-radius: 999px; background: var(--sf); margin-top: .55rem; overflow: hidden; }
.pw-strength .bar { height: 100%; background: linear-gradient(90deg, var(--ok), var(--ac)); transition: width .25s; }

.tabs { display: flex; background: var(--sf-2); border-radius: var(--rad-pill); padding: .25rem; gap: .25rem; }
.tabs button { flex: 1; padding: .5rem .7rem; border: 0; background: transparent; color: var(--t2); border-radius: var(--rad-pill); font: 500 13px var(--body); min-height: 34px; }
.tabs button.active { background: var(--ac); color: var(--on-ac); font-weight: 600; }

.range { -webkit-appearance: none; appearance: none; width: 100%; height: 5px; background: var(--sf); border-radius: 999px; outline: 0; }
.range::-webkit-slider-thumb { -webkit-appearance: none; width: 18px; height: 18px; border-radius: 50%; background: var(--ac); cursor: pointer; box-shadow: 0 2px 8px rgba(196,150,108,.5); }
.range::-moz-range-thumb { width: 18px; height: 18px; border: 0; border-radius: 50%; background: var(--ac); cursor: pointer; }

.toggle-row { display: flex; align-items: center; gap: .65rem; padding: .4rem 0; }
.toggle-row label { flex: 1; color: var(--t); font: 13.5px var(--body); line-height: 1.4; }
/* KEIN accent-color (= nativer System-Tint, BBE-STD-DESIGN-001) — die custom .ck unten greift voll. */
.toggle-row .ck { flex-shrink: 0; }
.toggle-row .hint { font-size: 12px; color: var(--tm); margin-top: 0; }

@media (max-width: 1100px) {
  .app { grid-template-columns: var(--sidebar-w-collapsed) 320px 1fr; }
  .app .side-link span:not(.ic-wrap), .app .side-link .count { display: none; }
  .app .side-group h4 { display: none; }
  .app .side-link { justify-content: center; padding: .55rem; }
  .app .brand-mini .sub { display: none; }
}

/* ── Item-Kontextmenü "mehr" (verschieben nach · für AI freigeben) ── */
.more-wrap { position: relative; }
.more-menu { position: absolute; top: calc(100% + 6px); right: 0; z-index: 60; min-width: 232px; background: var(--sf); border: .5px solid var(--bd-l); border-radius: var(--rad-md); box-shadow: var(--shadow-md); padding: .4rem; }
.more-menu[hidden] { display: none; }
.mm-head { font: 11px var(--mono); text-transform: uppercase; letter-spacing: .1em; color: var(--td); padding: .55rem .6rem .3rem; }
.mm-item { display: flex; align-items: center; gap: .6rem; width: 100%; text-align: left; padding: .55rem .6rem; border-radius: var(--rad-sm); background: none; border: none; color: var(--t2); font: 13.5px var(--body); cursor: pointer; }
.mm-item:hover { background: var(--sf-h); color: var(--t); }
.mm-item.active { color: var(--ac); font-weight: 600; }
.mm-dot { width: 6px; height: 6px; border-radius: 50%; background: transparent; flex-shrink: 0; }
.mm-item.active .mm-dot { background: var(--ac); }
.mm-sep { height: .5px; background: var(--bd); margin: .35rem .3rem; }
.mm-item.ai { color: #8b7cf6; }
.mm-item.ai:hover { background: rgba(139,124,246,.12); }
.mm-item.ai svg { flex-shrink: 0; }
.mm-item.ai small { display: block; font-size: 11px; color: var(--tm); margin-top: .1rem; font-weight: 400; }

/* ════ ZZ dark-CI form controls (round-2) — nie System-Design ════ */
input[type="checkbox"], .ck {
  -webkit-appearance: none; appearance: none;
  width: 18px; height: 18px; flex-shrink: 0; margin: 0;
  background: var(--sf-2, #1a1a1a);
  border: 1px solid var(--bd-l, #3a3a3a);
  border-radius: 5px; cursor: pointer; position: relative;
  transition: background .12s, border-color .12s;
}
input[type="checkbox"]:hover, .ck:hover { border-color: var(--ac); }
input[type="checkbox"]:checked, .ck:checked {
  background-color: var(--ac, #c4966c); border-color: var(--ac, #c4966c);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230a0907' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: center; background-size: 12px;
}
input[type="checkbox"]:focus-visible, .ck:focus-visible { outline: 2px solid var(--ac); outline-offset: 1px; }

select, select.inp {
  -webkit-appearance: none; -moz-appearance: none; appearance: none;
  background-color: var(--sf, #141414); color: var(--t, #f0f0f0);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c4966c' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right .7rem center; background-size: 15px;
  padding-right: 2rem; cursor: pointer;
}
select option, select optgroup { background: var(--sf, #141414); color: var(--t, #f0f0f0); }

/* ════ CI-Custom-Dropdown (ersetzt native <select> — native Popups ignorieren
   auf macOS jegliches CSS und rendern weiß/System-Font) ════ */
.zz-select { position: relative; }
.zz-select-btn {
  display: flex; align-items: center; justify-content: space-between; gap: .5rem;
  width: 100%; text-align: left; cursor: pointer;
}
.zz-select-btn .zz-select-val { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.zz-select-btn .zz-select-val.placeholder { color: var(--tm); }
.zz-select-btn svg { flex-shrink: 0; color: var(--ac); transition: transform .15s; }
.zz-select[data-open="true"] .zz-select-btn { border-color: var(--ac); background: var(--sf); }
.zz-select[data-open="true"] .zz-select-btn svg { transform: rotate(180deg); }
.zz-select-pop {
  position: absolute; left: 0; right: 0; top: calc(100% + 5px); z-index: 60;
  background: var(--sf, #141414); border: .5px solid var(--bd-l, #3a3a3a);
  border-radius: var(--rad-sm); box-shadow: 0 14px 36px rgba(0,0,0,.55);
  padding: .3rem; max-height: 240px; overflow-y: auto;
}
.zz-select-pop[hidden] { display: none; }
.zz-opt {
  display: flex; align-items: center; gap: .5rem; padding: .5rem .55rem;
  border-radius: var(--rad-sm); cursor: pointer; color: var(--t);
  font: 14px var(--body); user-select: none;
}
.zz-opt .zz-opt-check { width: 15px; flex-shrink: 0; opacity: 0; color: var(--ac); }
.zz-opt:hover, .zz-opt.focus { background: var(--sf-2); }
.zz-opt[aria-selected="true"] { color: var(--ac); }
.zz-opt[aria-selected="true"] .zz-opt-check { opacity: 1; }

/* ════ Volle Settings-Oberfläche (aus settings-desktop.html, nativ gewired) ════ */
/* Settings-Popup-Shell (modal-shade, exakt aus settings-desktop.html) */
.set-shade{position:fixed;inset:0;z-index:80;background:rgba(0,0,0,.62);backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;padding:var(--s-2)}
.set-shade.open{display:flex}
.set-modal{max-width:980px;width:95vw;max-height:90vh;display:flex;flex-direction:column;padding:0;gap:0;overflow:hidden;background:var(--sf);border:.5px solid var(--bd);border-radius:var(--rad-lg);box-shadow:0 24px 80px rgba(0,0,0,.55)}
.set-top{display:flex;align-items:center;justify-content:space-between;padding:1.15rem 1.4rem;border-bottom:.5px solid var(--bd);flex-shrink:0}
.set-top .h{font:500 22px var(--display);text-transform:lowercase;letter-spacing:-.01em;color:var(--t)}
.set-top .sub{font:12px var(--mono);color:var(--tm);margin-top:.15rem}
.set-top .close{width:34px;height:34px;border-radius:50%;background:var(--sf);border:.5px solid var(--bd);color:var(--t2);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:color .14s,border-color .14s}
.set-top .close:hover{color:var(--ac);border-color:var(--ac)}
.set-main{display:flex;min-height:0;flex:1}
.set-nav{width:230px;flex-shrink:0;border-right:.5px solid var(--bd);padding:.85rem .6rem;display:flex;flex-direction:column;gap:.1rem;overflow-y:auto;scrollbar-width:none}
.set-nav::-webkit-scrollbar{display:none}
.set-nav .grp{font:11px var(--mono);text-transform:uppercase;letter-spacing:.12em;color:var(--td);padding:.85rem .75rem .35rem}
.set-nav .grp:first-child{padding-top:.2rem}
.set-tab{display:flex;align-items:center;gap:.7rem;padding:.62rem .75rem;border-radius:var(--rad-md);color:var(--t2);cursor:pointer;font:13.5px var(--body);min-height:42px;transition:background .14s,color .14s}
.set-tab:hover{background:var(--sf-h);color:var(--t)}
.set-tab.active{background:var(--ac-soft);color:var(--ac);font-weight:600}
.set-tab svg{width:17px;height:17px;flex-shrink:0;stroke-width:1.7}
/* Lange Labels (z. B. "werkzeuge & kontingent") max. 2 Zeilen, kein 3-Zeilen-Umbruch */
.set-tab .lbl{display:block;line-height:1.25;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.set-body{flex:1;min-width:0;padding:1.5rem 1.7rem;overflow-y:auto;scrollbar-width:none}
.set-body::-webkit-scrollbar{display:none}
.set-foot{display:flex;align-items:center;gap:.8rem;padding:1rem 1.4rem;border-top:.5px solid var(--bd);flex-shrink:0}
.set-foot .note{font:11.5px var(--mono);color:var(--td);margin-right:auto}
.set-pane{display:none}
.set-pane.active{display:block;animation:zzfade .2s ease}
@keyframes zzfade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.set-pane h2{font:500 19px var(--display);text-transform:lowercase;letter-spacing:-.01em;color:var(--t);margin:0 0 .25rem}
.set-pane .pane-lead{font:13px var(--body);color:var(--tm);margin:0 0 1.3rem;line-height:1.5;max-width:60ch}
.sec{border:.5px solid var(--bd);border-radius:var(--rad-lg);padding:1.15rem 1.2rem;margin-bottom:1.1rem;background:var(--sf-2)}
.sec-h{display:flex;align-items:center;gap:.55rem;font:600 13.5px var(--body);color:var(--t);margin-bottom:.95rem}
.badge-ext,.badge-native{font:10px var(--mono);text-transform:uppercase;letter-spacing:.08em;border-radius:var(--rad-pill);padding:.12rem .5rem;margin-left:auto;white-space:nowrap}
.badge-ext{color:#8b7cf6;border:.5px solid rgba(139,124,246,.5);background:rgba(139,124,246,.12)}
.badge-native{color:var(--ok);border:.5px solid rgba(95,203,135,.4);background:rgba(95,203,135,.1)}
.kv{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.7rem 0;border-bottom:.5px solid var(--bd)}
.kv:last-child{border-bottom:none}
.kv .kvk{font:13px var(--body);color:var(--t2)}
.kv .kvk small{display:block;color:var(--tm);font-size:11.5px;margin-top:.15rem;max-width:42ch;line-height:1.4}
.kv .kvv{font:13px var(--body);color:var(--t);text-align:right;display:flex;align-items:center;gap:.6rem;flex-shrink:0}
.kv .kvv.mono{font-family:var(--mono);font-size:12.5px}
.mini-btn{padding:.4rem .8rem;border-radius:var(--rad-sm);border:.5px solid var(--bd-l);background:var(--sf);color:var(--t2);font:12.5px var(--body);cursor:pointer;white-space:nowrap}
.mini-btn:hover{border-color:var(--ac);color:var(--ac)}
.mini-btn.danger{color:var(--err)}.mini-btn.danger:hover{border-color:var(--err);color:var(--err)}
.mini-btn:disabled{opacity:.5;cursor:not-allowed}
.st-on{color:var(--ok);font:600 12px var(--body)}.st-off{color:var(--tm);font:12px var(--body)}
.sw{position:relative;width:38px;height:22px;border-radius:var(--rad-pill);background:var(--sf-h);border:.5px solid var(--bd-l);cursor:pointer;flex-shrink:0;transition:background .16s}
.sw::after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:var(--tm);transition:transform .16s,background .16s}
.sw.on{background:var(--ac-soft);border-color:var(--ac)}.sw.on::after{transform:translateX(16px);background:var(--ac)}
.tbl{width:100%;border-collapse:collapse;font:13px var(--body)}
.tbl th{text-align:left;font:11px var(--mono);text-transform:uppercase;letter-spacing:.08em;color:var(--td);padding:.5rem .6rem;border-bottom:.5px solid var(--bd)}
.tbl td{padding:.65rem .6rem;border-bottom:.5px solid var(--bd);color:var(--t2);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl .dev-id{font:12px var(--mono);color:var(--tm)}
.tbl .pill{font:11px var(--mono);border-radius:var(--rad-pill);padding:.1rem .55rem;border:.5px solid}
.pill.allow{color:var(--ok);border-color:rgba(95,203,135,.4);background:rgba(95,203,135,.1)}
.quota-bar{height:8px;border-radius:var(--rad-pill);background:var(--sf-h);overflow:hidden;margin:.5rem 0 .35rem}
.quota-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--ac),var(--ac-h))}

/* Segmented-Control / Step-Reiter (z. B. Identität standard|sensibel) */
.zz-steps { display: inline-flex; gap: .4rem; }
.zz-step {
  padding: .45rem .95rem; cursor: pointer;
  background: var(--sf-2, #1a1a1a); border: .5px solid var(--bd-l, #3a3a3a);
  color: var(--t2); font: 600 12.5px var(--body); border-radius: var(--rad-sm);
  text-transform: lowercase; transition: all .12s;
}
.zz-step:hover { color: var(--t); }
.zz-step.active { background: var(--ac-soft); border-color: var(--ac); color: var(--ac); }

/* native Zahlen-Spinner aus (ersetzt durch CI-Stepper im Markup) */
input[type="number"] { -moz-appearance: textfield; appearance: textfield; }
input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

/* CI-Stepper (Zahl hoch/runter) — eine bordierte Pille, exakt symmetrisch:
   [ 40px − ] | [ 52px Zahl ] | [ 40px + ], alle 40px hoch, keine Doppelnähte. */
.zz-stepper {
  display: inline-flex; align-items: stretch; height: 40px;
  background: var(--sf-2, #1a1a1a); border: .5px solid var(--bd-l, #3a3a3a);
  border-radius: var(--rad-md, 8px); overflow: hidden;
}
.zz-stepper button {
  flex: 0 0 40px; width: 40px; height: 100%;
  background: transparent; color: var(--ac, #c4966c); border: 0; cursor: pointer;
  font: 500 19px var(--mono, monospace);
  display: grid; place-items: center; line-height: 0; padding: 0;
  transition: background .12s;
}
.zz-stepper button:first-child { border-right: .5px solid var(--bd-l, #3a3a3a); }
.zz-stepper button:last-child  { border-left:  .5px solid var(--bd-l, #3a3a3a); }
.zz-stepper button:hover { background: var(--ac-soft, rgba(196,150,108,.16)); }
.zz-stepper input {
  flex: 0 0 52px; width: 52px; height: 100%; min-height: 0 !important;
  text-align: center; padding: 0 !important; margin: 0 !important;
  border: 0 !important; border-radius: 0 !important; background: transparent !important;
  font: 600 15px var(--mono, monospace); color: var(--t);
}
.zz-stepper input:focus { outline: none; background: transparent !important; }

/* round-2: lange Werte (IBAN, Pass-Nr, Adresse) brechen im Container statt zu überlaufen */
.row .v { overflow-wrap: anywhere; word-break: break-word; min-width: 0; }

/* Settings-Nav: lange Abschnitts-Labels nicht abschneiden */
.item[data-setsec] .n1{white-space:normal;line-height:1.25;overflow:visible;text-overflow:clip}
.item[data-setsec]{min-height:44px;align-items:center}

/* ZZ-Wortmarke immer eng (-200) — überall konsistent */
.zz{letter-spacing:-.2em}
