/* ZZ Keychain v4.0 — Mobile-First + lowercase-Konsistenz + Hover/Motion
   Direktiven großer Meister 2026-05-29:
   1. Mobile-first: alle Komponenten responsive ab 320px
   2. Register: 1-Spalte (2-spaltig auf Mobile unpraktisch — wie Zabazingo Cloud)
   3. Generator-Toggles + alles: lowercase wie Cloud (keine Capital-Letters am Anfang)
   4. Index + alle Cards: Hover-Lift + Motion + klickbar
   5. Scrollbalken bleiben global unsichtbar (Regel aus feedback_scrollbars_invisible)

   Base = Mobile (375px), dann @min-width breakpoints aufsteigend
*/

@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); --ac-glow:rgba(196,150,108,.32); --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);
  --motion-fast: cubic-bezier(.2,.7,.2,1);
  --motion-bounce: cubic-bezier(.34,1.56,.64,1);
  --sidebar-w: 240px;
  --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; -webkit-tap-highlight-color: transparent; }
a { color: inherit; text-decoration: none; -webkit-tap-highlight-color: transparent; }
button { font: inherit; cursor: pointer; -webkit-tap-highlight-color: transparent; }
img, svg { display: block; max-width: 100%; }

/* Scrollbar unsichtbar (Regel global) */
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%);
  animation: bgDrift 24s ease-in-out infinite alternate;
}
.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;
}
@keyframes bgDrift {
  from { transform: translate3d(0,0,0) scale(1); }
  to   { transform: translate3d(-2%,1%,0) scale(1.04); }
}
.bg-grad { position: fixed; inset: 0; z-index: 1; pointer-events: none;
  background: linear-gradient(180deg, rgba(0,0,0,.5) 0%, rgba(0,0,0,.2) 30%, rgba(0,0,0,.08) 60%, rgba(0,0,0,.05) 100%); }

/* ─── ZZ Statement ────────────────────────────────────────── */
.statement {
  position: fixed; top: var(--s-2); left: var(--s-3);
  z-index: 5; font-family: var(--zz); font-size: 22px; 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; }

/* ─── Utility ─────────────────────────────────────────────── */
.utility { position: fixed; top: var(--s-2); right: var(--s-2); z-index: 5; display: flex; align-items: center; gap: var(--s-1); }
.lang {
  display: inline-flex; align-items: center; gap: .4rem;
  padding: .5rem .75rem; 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: 36px;
  transition: background .2s var(--motion-fast), border-color .2s var(--motion-fast), color .2s var(--motion-fast), transform .15s var(--motion-fast);
}
.lang:hover, .lang:focus-visible { background: rgba(196,150,108,.26); border-color: var(--ac); color: var(--t); transform: translateY(-1px); }
.lang:active { transform: translateY(0); }
.lang .cur { color: var(--t); } .lang .sep { color: var(--td); } .lang .alt { color: var(--tm); }

/* ─── Stage ───────────────────────────────────────────────── */
.stage {
  position: fixed; inset: 0; z-index: 2;
  display: flex; align-items: center; justify-content: center;
  padding: 4.25rem var(--s-2) var(--s-3);
}

/* ─── Card (mobile-first, full-width auf Mobile) ───────────── */
.card {
  width: 100%; max-width: 100%;
  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);
  display: flex; flex-direction: column; gap: .9rem;
  box-shadow: var(--shadow-lg), 0 1px 0 rgba(255,255,255,.05) inset;
  animation: cardIn .45s var(--motion-fast);
  max-height: calc(100vh - 5.5rem);
}
@keyframes cardIn { from { opacity: 0; transform: translateY(12px); } 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: .75rem .95rem;
  color: var(--t); font: 15px var(--body); min-height: 44px;
  transition: border-color .15s var(--motion-fast), background .15s var(--motion-fast);
}
.inp:focus { outline: none; border-color: var(--ac); background: var(--sf); }
.inp::placeholder { color: var(--tm); }
.inp-wrap { position: relative; }
.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: 32px; height: 32px;
  display: inline-flex; align-items: center; justify-content: center; border-radius: var(--rad-sm);
  transition: color .15s, background .15s;
}
.inp-action:hover { color: var(--ac); background: var(--ac-soft); }
.inp.code { text-align: center; letter-spacing: .25em; font: 600 22px var(--mono); padding-block: .85rem; min-height: 56px; }

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

/* ─── Buttons ────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .55rem;
  background: var(--ac); color: var(--on-ac);
  border: 0; border-radius: var(--rad-pill);
  font: 600 14.5px var(--body); padding: .85rem 1.4rem; min-height: 46px;
  transition: background .2s var(--motion-fast), transform .12s var(--motion-fast), box-shadow .2s var(--motion-fast);
}
.btn:hover, .btn:focus-visible { background: var(--ac-h); box-shadow: 0 8px 24px -8px var(--ac-glow); transform: translateY(-1px); }
.btn:active { transform: translateY(0); box-shadow: 0 2px 8px -4px var(--ac-glow); }
.btn:disabled { opacity: .4; cursor: not-allowed; transform: none; box-shadow: none; }
.btn.ghost { background: transparent; color: var(--t); border: .5px solid var(--bd-l); }
.btn.ghost:hover { background: var(--ac-soft); border-color: var(--ac); box-shadow: 0 6px 18px -8px rgba(0,0,0,.4); }
.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); box-shadow: 0 6px 18px -8px rgba(229,92,92,.32); }
.btn.sm { padding: .6rem 1.05rem; font-size: 13px; min-height: 38px; }

/* ─── Icon button ───────────────────────────────────────── */
.icon-btn {
  width: 38px; height: 38px; border-radius: var(--rad-sm);
  background: transparent; border: 0; color: var(--tm);
  display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0;
  transition: background .15s var(--motion-fast), color .15s var(--motion-fast), transform .12s var(--motion-fast);
}
.icon-btn:hover { background: var(--sf-h); color: var(--ac); transform: scale(1.08); }
.icon-btn:active { transform: scale(.96); }
.icon-btn:focus-visible { outline: 2px solid var(--ac); outline-offset: 1px; }
.icon-btn.lg { width: 44px; height: 44px; }

/* ─── Alert ─────────────────────────────────────────────── */
.alert { padding: .7rem .85rem; border-radius: var(--rad-sm); font-size: 13px; line-height: 1.5; 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: .1rem 0; }
.div-text::before, .div-text::after { content: ''; height: .5px; background: var(--bd); }

/* ─── Foot mini ──────────────────────────────────────────── */
.foot-mini {
  position: fixed; bottom: var(--s-2); left: 50%; transform: translateX(-50%);
  color: var(--td); font: 400 11.5px/1.4 var(--mono); letter-spacing: .04em; z-index: 4;
  text-align: center; padding: 0 var(--s-2);
}
.foot-mini a { color: var(--tm); padding: 0 .25rem; transition: color .15s; }
.foot-mini a:hover { color: var(--ac); }

/* ─── App-shell (mobile-first: list fills, sidebar+detail hidden) ──── */
.app {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: 56px 1fr;
  grid-template-areas: "topbar" "list";
  height: 100vh; background: var(--bg);
}
.app .topbar {
  grid-area: topbar; display: flex; align-items: center; gap: var(--s-1);
  padding: 0 var(--s-2); background: rgba(20,20,20,.94);
  backdrop-filter: blur(16px); border-bottom: .5px solid var(--bd);
  z-index: 25;
}
/* Mobile: nur essential buttons (Hamburger+Brand+Search+Avatar), Generator/Plus/Settings hidden */
.app .topbar .topbar-extras { display: none; }
@media (min-width: 600px) {
  .app .topbar .topbar-extras { display: flex; align-items: center; gap: .5rem; }
}
.app .list   { grid-area: list;   background: var(--bg); overflow-y: auto; min-width: 0; }
.app .detail { grid-area: detail; background: var(--bg-2); overflow-y: auto; min-width: 0; display: none; }

.collapse-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 38px; height: 38px; border-radius: var(--rad-sm);
  background: transparent; border: 0; color: var(--tm); flex-shrink: 0;
  transition: background .15s, color .15s, transform .12s;
}
.collapse-btn:hover { background: var(--sf-h); color: var(--ac); }
.collapse-btn:active { transform: scale(.94); }

.brand-mini { display: inline-flex; align-items: center; gap: .55rem; color: var(--t); transition: opacity .15s; }
.brand-mini:hover { opacity: .85; }
.brand-mini .zz { font-family: var(--zz); font-size: 22px; font-weight: 700; letter-spacing: -.2em; line-height: 1; padding-right: .2em; }
.brand-mini .sub { font-family: var(--display); font-size: 13.5px; color: var(--t2); border-left: 1px solid var(--bd-l); padding-left: .6rem; line-height: 1; }

.search {
  display: inline-flex; align-items: center; gap: .55rem;
  background: var(--sf); border: .5px solid var(--bd); border-radius: var(--rad-pill);
  padding: .5rem .85rem; flex: 1; min-width: 0;
  min-height: 38px;
  transition: border-color .15s;
}
.search:focus-within { border-color: var(--ac); }
.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: 11px var(--mono); padding: .15rem .4rem; 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; transition: transform .15s; }
.avatar:hover { transform: scale(1.06); }

/* Sidebar (Mobile: drawer slide-in via .open · Tablet+: static grid cell) */
.app .sidebar {
  grid-area: sidebar;
  background: var(--sf-2); border-right: .5px solid var(--bd);
  padding: var(--s-2); overflow-y: auto;
  position: fixed; top: 56px; left: 0; bottom: 0;
  width: 80%; max-width: 280px; z-index: 20;
  transform: translateX(-100%);
  transition: transform .25s var(--motion-fast);
}
.app.open .sidebar { transform: translateX(0); box-shadow: 0 20px 60px rgba(0,0,0,.6); }
.app.open::before { content: ''; position: fixed; inset: 56px 0 0; background: rgba(0,0,0,.55); z-index: 15; }

/* Sidebar groups */
.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: .65rem .7rem; border-radius: var(--rad-sm);
  color: var(--t2); font: 500 14px var(--body); min-height: 40px;
  transition: background .15s var(--motion-fast), color .15s var(--motion-fast), transform .1s;
  cursor: pointer;
}
.side-link:hover { background: var(--sf-h); color: var(--t); transform: translateX(2px); }
.side-link:active { transform: translateX(0); }
.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-2) .85rem; 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-2); border-bottom: .5px solid var(--bd);
  cursor: pointer;
  transition: background .15s var(--motion-fast), transform .1s, padding-left .15s;
  min-height: 60px;
}
.item:hover { background: var(--sf-2); }
.item:active { transform: scale(.995); }
.item.active { background: var(--ac-soft); border-left: 3px solid var(--ac); padding-left: calc(var(--s-2) - 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; transition: transform .15s; }
.item:hover .ico { transform: rotate(-2deg) scale(1.05); }
.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; }
.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; }
.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-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); transition: transform .15s, color .15s; }
.item:hover .chev { transform: translateX(2px); color: var(--ac); }
.item.active .chev { color: var(--ac); }

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

.row {
  display: grid;
  grid-template-columns: 1fr;
  gap: .3rem;
  padding: .75rem .95rem; background: var(--sf-2); border: .5px solid var(--bd); border-radius: var(--rad-sm);
  margin-bottom: .35rem; min-height: 46px;
  transition: border-color .15s, background .15s;
}
.row:hover { background: var(--sf); border-color: var(--bd-l); }
.row .k { color: var(--tm); font: 600 11px var(--body); letter-spacing: .07em; text-transform: uppercase; line-height: 1.3; }
.row .v-row { display: flex; align-items: center; gap: .5rem; }
.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: .25rem; flex-shrink: 0; justify-self: start; }

/* Tablet+: rows 3-column (key | value | actions) — wie cloud-vault */
@media (min-width: 600px) {
  .row { grid-template-columns: 150px 1fr auto; gap: var(--s-2); align-items: center; }
  .row .row-actions { justify-self: end; }
}

.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: .3rem .6rem; background: var(--ac-soft); color: var(--ac); border-radius: 6px; font: 600 11.5px var(--body); letter-spacing: .04em; transition: background .15s, transform .12s; cursor: pointer; }
.tag:hover { background: rgba(196,150,108,.24); transform: translateY(-1px); }

/* ─── Modal (mobile-first: full-screen-bottom-sheet style on small) ─── */
.modal-shade { position: fixed; inset: 0; z-index: 50; background: rgba(0,0,0,.6); backdrop-filter: blur(8px); display: flex; align-items: flex-end; justify-content: center; padding: 0; animation: fadeIn .25s var(--motion-fast); }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }

.modal {
  background: rgba(24,24,24,.96); backdrop-filter: blur(24px);
  border: .5px solid var(--bd-l);
  border-radius: var(--rad-lg) var(--rad-lg) 0 0;
  width: 100%; max-width: 100%; max-height: calc(100vh - 2rem); overflow-y: auto;
  padding: var(--s-3);
  display: flex; flex-direction: column; gap: .75rem;
  box-shadow: var(--shadow-lg);
  animation: modalUp .35s var(--motion-fast);
}
@keyframes modalUp { from { transform: translateY(40px); opacity: 0; } to { transform: none; opacity: 1; } }
.modal-head { display: flex; align-items: center; justify-content: space-between; }
.modal-head .h { font: 500 22px var(--display); text-transform: lowercase; letter-spacing: -.01em; }
.modal-head .close {
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--sf); border: .5px solid var(--bd); color: var(--t2);
  display: inline-flex; align-items: center; justify-content: center;
  transition: color .15s, border-color .15s, transform .12s;
}
.modal-head .close:hover { color: var(--ac); border-color: var(--ac); transform: rotate(90deg); }

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

.tabs { display: flex; background: var(--sf-2); border-radius: var(--rad-pill); padding: .25rem; gap: .25rem; }
.tabs button { flex: 1; padding: .55rem .7rem; border: 0; background: transparent; color: var(--t2); border-radius: var(--rad-pill); font: 500 13px var(--body); min-height: 36px; transition: background .2s, color .2s; }
.tabs button:hover { color: var(--t); }
.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: 20px; height: 20px; border-radius: 50%; background: var(--ac); cursor: pointer; box-shadow: 0 2px 8px rgba(196,150,108,.5); transition: transform .12s, box-shadow .15s; }
.range::-webkit-slider-thumb:hover { transform: scale(1.15); box-shadow: 0 4px 14px var(--ac-glow); }
.range::-moz-range-thumb { width: 20px; height: 20px; border: 0; border-radius: 50%; background: var(--ac); cursor: pointer; }

.toggle-row { display: flex; align-items: center; gap: .65rem; padding: .5rem 0; }
.toggle-row label { flex: 1; color: var(--t); font: 13.5px var(--body); line-height: 1.4; text-transform: lowercase; }   /* v4: Labels lowercase */
/* KEIN accent-color (= nativer System-Tint, BBE-STD-DESIGN-001) — die custom .ck greift voll. */
.toggle-row .ck { flex-shrink: 0; }
.toggle-row .hint { font-size: 12px; color: var(--tm); margin-top: 0; text-transform: none; }   /* Hint behält Original-Case (A-Z, 0 O 1 l I) */

/* ─── Tablet (≥ 600px): card constrained ───────────── */
@media (min-width: 600px) {
  .statement { top: var(--s-3); left: calc(clamp(var(--s-3), 6vw, var(--s-7)) + var(--s-4)); font-size: 28px; }
  .utility { top: var(--s-3); right: clamp(var(--s-3), 6vw, var(--s-7)); }
  .stage { justify-content: flex-start; padding: var(--s-3) var(--s-3) var(--s-3) clamp(var(--s-3), 6vw, var(--s-7)); }
  .card { max-width: 400px; }
  .card.wide { max-width: 460px; }
  .card.wider { max-width: 560px; }
  .foot-mini { left: clamp(var(--s-3), 6vw, var(--s-7)); transform: none; text-align: left; }

  /* Modal: centered card on tablet/desktop */
  .modal-shade { align-items: center; padding: var(--s-3); }
  .modal { border-radius: var(--rad-lg); max-width: 540px; }
  .modal.wide { max-width: 700px; }
}

/* ─── Tablet (≥ 768px): Sidebar permanent, 2-Pane ──── */
@media (min-width: 768px) {
  .app {
    grid-template-columns: var(--sidebar-w) 1fr;
    grid-template-areas: "topbar topbar" "sidebar list";
  }
  .app .sidebar {
    position: static; transform: none;
    width: auto; max-width: none;
    top: auto; left: auto; bottom: auto; z-index: auto;
    box-shadow: none;
  }
  .app.open .sidebar { box-shadow: none; }
  .app.open::before { content: none; }
  .collapse-btn { display: none; }
  .app .topbar { padding: 0 var(--s-3); }
}

/* ─── Desktop (≥ 1024px): 3-Pane mit Detail ────────── */
@media (min-width: 1024px) {
  .app {
    grid-template-columns: var(--sidebar-w) 360px 1fr;
    grid-template-areas: "topbar topbar topbar" "sidebar list detail";
  }
  .app .list { border-right: .5px solid var(--bd); }
  .app .detail { display: block; }
}

/* ════ 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); }

/* 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; }

/* ════ Volle Settings-Oberfläche (aus settings-desktop.html, nativ gewired) ════ */
/* Settings-Popup als Vollbild-Sheet (mobiles Modal-Idiom, wie art-shade) */
.set-shade{position:fixed;inset:0;z-index:80;background:var(--bg);display:none;flex-direction:column}
.set-shade.open{display:flex}
.set-modal{display:flex;flex-direction:column;width:100%;height:100%;max-height:100%;background:var(--bg);overflow:hidden}
.set-top{display:flex;align-items:center;justify-content:space-between;gap:.6rem;padding:calc(var(--s-2) + env(safe-area-inset-top,0px)) var(--s-2) .85rem;border-bottom:.5px solid var(--bd);flex-shrink:0;position:sticky;top:0;background:var(--bg);z-index:2}
.set-top .h{font:400 19px var(--display);text-transform:lowercase;letter-spacing:-.005em;color:var(--t)}
.set-top .sub{font:11.5px var(--mono);color:var(--tm);margin-top:.15rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:70vw}
.set-top .close{width:36px;height:36px;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}
.set-top .close:hover{color:var(--ac);border-color:var(--ac)}
.set-main{display:flex;flex-direction:column;min-height:0;flex:1}
/* Nav als horizontale Reiter-Leiste oben */
.set-nav{display:flex;flex-direction:row;gap:.4rem;overflow-x:auto;overflow-y:hidden;padding:.6rem var(--s-2);border-bottom:.5px solid var(--bd);flex-shrink:0;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.set-nav::-webkit-scrollbar{display:none}
.set-nav .grp{display:none}
.set-tab{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .8rem;border-radius:var(--rad-pill);border:.5px solid var(--bd-l);background:var(--sf);color:var(--t2);cursor:pointer;font:13px var(--body);white-space:nowrap;flex-shrink:0;transition:background .14s,color .14s,border-color .14s}
.set-tab svg{width:16px;height:16px;flex-shrink:0;stroke-width:1.7}
.set-tab.active{background:var(--ac-soft);border-color:var(--ac);color:var(--ac);font-weight:600}
.set-tab .lbl{display:inline-block;line-height:1.2}
.set-body{flex:1;min-width:0;padding:var(--s-2) var(--s-2) var(--s-4);overflow-y:auto;-webkit-overflow-scrolling:touch}
.set-foot{display:flex;align-items:center;gap:.7rem;padding:.85rem var(--s-2) calc(.85rem + env(safe-area-inset-bottom,0px));border-top:.5px solid var(--bd);flex-shrink:0}
.set-foot .note{font:11px var(--mono);color:var(--td);margin-right:auto;display:none}
.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))}

/* CI-Stepper (Zahl hoch/runter) — eine bordierte Pille, exakt symmetrisch */
.zz-stepper {
  display: inline-flex; align-items: stretch; height: 42px;
  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 44px; width: 44px; height: 100%;
  background: transparent; color: var(--ac, #c4966c); border: 0; cursor: pointer;
  font: 500 20px 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 54px; width: 54px; 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 16px 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}
