/* Onboarding v2 — auth screens + setup checklist (design 2026-06-12) */
.onbv2-subtitle { color: #6b6b70; font-size: 14px; text-align: center; margin: 4px 0 20px; }
.onbv2-switch { text-align: center; margin-top: 16px; font-size: 14px; color: #6b6b70; }
.onbv2-switch a { color: #111; font-weight: 600; text-decoration: none; }

#signup-v2-categories { display: flex; flex-direction: column; gap: 8px; }
.onbv2-cat {
  display: flex; align-items: center; gap: 12px;
  border: 1px solid #e3e3e6; border-radius: 10px;
  padding: 14px 16px; cursor: pointer; background: #fff;
  font-weight: 600; font-size: 15px;
}
.onbv2-cat[aria-checked="true"] { border: 2px solid #111; background: #f4f4f6; }
.onbv2-cat .onbv2-check { margin-left: auto; width: 20px; height: 20px; border-radius: 50%;
  border: 1.5px solid #d4d4d8; }
.onbv2-cat[aria-checked="true"] .onbv2-check { background: #111; border-color: #111; }

#signup-v2-subtypes { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 10px; }
.onbv2-subtype {
  border: 1px solid #e3e3e6; border-radius: 999px; padding: 8px 14px;
  font-size: 13px; cursor: pointer; background: #fff;
}
.onbv2-subtype[aria-checked="true"] { background: #111; color: #fff; border-color: #111; }

.onbv2-consent { display: flex; gap: 10px; align-items: flex-start; font-size: 13px;
  color: #6b6b70; margin: 14px 0; cursor: pointer; }

/* Setup checklist card (dashboard) */
.setup-checklist { background: var(--card); border: 1px solid var(--line-2); border-radius: 12px;
  padding: 20px; margin-bottom: 20px; }
.setup-checklist h3 { font-size: 16px; margin-bottom: 4px; }
.setup-checklist .progress { font-size: 13px; color: var(--ink-2); margin-bottom: 12px; }
.setup-checklist ul { list-style: none; }
.setup-checklist li { display: flex; align-items: center; gap: 10px; padding: 10px 0;
  border-top: 1px solid var(--hover-2); font-size: 14px; }
.setup-checklist li.done { color: var(--ink-3); text-decoration: line-through; }
.setup-checklist li.blocked { opacity: 0.5; }
.setup-checklist li button { margin-left: auto; }

/* Email verification banner */
.verify-banner { background: #FFFBEB; border: 1px solid #FDE68A; color: #92400E;
  border-radius: 10px; padding: 10px 16px; margin-bottom: 16px; font-size: 14px;
  display: flex; align-items: center; gap: 12px; }
.verify-banner button { margin-left: auto; }

/* ── Onboarding v2: auth screens — faithful port of the 2026-06-12 design
   bundle (LEVIAPAY Login offline.html, theme-light dir-raster tokens).
   Scoped under body.onbv2-auth so legacy auth stays pixel-identical. ── */
body.onbv2-auth #login-screen {
  --bg: #ffffff; --ink: #0e0e14; --ink-2: #5b5b67; --ink-3: #9a9aa6;
  --line: rgba(14, 14, 20, 0.1); --line-2: rgba(14, 14, 20, 0.16);
  --card: #ffffff; --field: #ffffff; --hover: rgba(14, 14, 20, 0.045);
  --success: #15875a; --accent: #111111; --accent-ink: #ffffff;
  --shadow: 0 1px 2px rgba(14, 14, 20, 0.05), 0 1px 0 rgba(14, 14, 20, 0.02);
  --fs-xs: 11px; --fs-sm: 13px; --fs-body: 14px; --r-ctl: 5px; --r-card: 5px;

  min-height: 100vh; width: 100%;
  display: flex; flex-direction: column; align-items: center;
  padding: 56px 20px 28px;
  background: var(--bg); color: var(--ink);
  font-family: "Plus Jakarta Sans", system-ui, -apple-system, sans-serif;
}
body.onbv2-auth #login-screen .authv2-center {
  flex: 1; width: 100%;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
}
body.onbv2-auth #login-screen .login-card,
body.onbv2-auth #login-screen .signup-card {
  width: 100%; max-width: 430px; margin: 0 auto;
  background: transparent; border: 0; box-shadow: none; padding: 0;
}
/* brand block (logo + subtitle) sits ABOVE the card */
body.onbv2-auth #login-screen .authv2-brand {
  display: flex; flex-direction: column; align-items: center; gap: 13px;
  margin-bottom: 28px; text-align: center;
}
body.onbv2-auth #login-screen .authv2-brand .auth-logo {
  height: 30px; width: auto; display: block; margin: 0;
}
body.onbv2-auth #login-screen .authv2-brand p,
body.onbv2-auth #login-screen .auth-sub {
  font-size: var(--fs-body); color: var(--ink-2); font-weight: 500; margin: 0;
}
/* the white card = the form */
body.onbv2-auth #login-screen .authv2-card {
  background: var(--card); border: 1px solid var(--line);
  border-radius: var(--r-card); box-shadow: var(--shadow);
  padding: 24px;
  display: flex; flex-direction: column; gap: 16px;
}
body.onbv2-auth #login-screen .authv2-card .form-group,
body.onbv2-auth #login-screen .authv2-card .field {
  display: flex; flex-direction: column; gap: 7px; margin: 0;
}
body.onbv2-auth #login-screen .authv2-card label {
  font-size: var(--fs-sm); color: var(--ink-2); font-weight: 600; margin: 0;
}
body.onbv2-auth #login-screen .authv2-card input[type="email"],
body.onbv2-auth #login-screen .authv2-card input[type="password"],
body.onbv2-auth #login-screen .authv2-card input[type="text"],
body.onbv2-auth #login-screen .authv2-card input[type="tel"] {
  height: 42px; padding: 0 14px; width: 100%;
  border: 1px solid var(--line-2); border-radius: var(--r-ctl);
  background: var(--field); color: var(--ink);
  font-size: var(--fs-body); font-family: inherit; outline: 0;
  box-shadow: none;
}
body.onbv2-auth #login-screen .authv2-card input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(17, 17, 17, 0.16);
}
body.onbv2-auth #login-screen .btn-primary {
  display: inline-flex; align-items: center; justify-content: center;
  width: 100%; height: 44px; padding: 0 14px;
  background: var(--accent); color: var(--accent-ink);
  border: 1px solid var(--accent); border-radius: var(--r-ctl);
  font-size: var(--fs-body); font-weight: 700; letter-spacing: -0.01em;
  font-family: inherit; cursor: pointer;
}
body.onbv2-auth #login-screen .btn-primary:hover { background: #2a2a2e; border-color: #2a2a2e; }
body.onbv2-auth #login-screen .btn-primary:active { transform: translateY(0.5px); }
/* password eye toggle */
body.onbv2-auth #login-screen .auth-pwwrap { position: relative; }
body.onbv2-auth #login-screen .auth-pwwrap input { padding-right: 44px; }
body.onbv2-auth #login-screen .auth-pweye {
  position: absolute; top: 0; right: 0; height: 100%; width: 42px;
  appearance: none; border: 0; background: transparent; cursor: pointer;
  display: grid; place-items: center; color: var(--ink-3);
}
body.onbv2-auth #login-screen .auth-pweye:hover { color: var(--ink); }
/* links + after-rows */
body.onbv2-auth #login-screen .authv2-after { display: flex; justify-content: flex-end; }
body.onbv2-auth #login-screen .authv2-after a,
body.onbv2-auth #login-screen .auth-link {
  font-size: var(--fs-sm) !important; font-weight: 700; color: var(--accent) !important;
  text-decoration: none;
}
body.onbv2-auth #login-screen .authv2-after a:hover,
body.onbv2-auth #login-screen .auth-link:hover { text-decoration: underline; }
body.onbv2-auth #login-screen .login-toggle {
  display: flex; align-items: center; justify-content: center; gap: 6px;
  margin-top: 22px; font-size: var(--fs-sm); color: var(--ink-2); font-weight: 500;
}
body.onbv2-auth #login-screen .login-toggle a { font-weight: 700; color: var(--accent); text-decoration: none; }
body.onbv2-auth #login-screen .login-toggle a:hover { text-decoration: underline; }
/* business type picker (design verbatim) */
body.onbv2-auth #login-screen .auth-types { display: flex; flex-direction: column; gap: 8px; }
body.onbv2-auth #login-screen .auth-type {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 13px; border: 1.5px solid var(--line); border-radius: var(--r-ctl);
  background: var(--field); cursor: pointer; appearance: none;
  font-family: inherit; text-align: left; color: var(--ink);
  transition: border-color 0.12s, background 0.12s;
}
body.onbv2-auth #login-screen .auth-type:hover { border-color: var(--line-2); }
body.onbv2-auth #login-screen .auth-type.sel {
  border-color: var(--accent); background: rgba(17, 17, 17, 0.06);
}
body.onbv2-auth #login-screen .auth-type-ic {
  width: 34px; height: 34px; flex: 0 0 34px; border-radius: 1px;
  border-radius: calc(var(--r-ctl) - 4px);
  display: grid; place-items: center;
  background: var(--card); border: 1px solid var(--line); color: var(--ink-2);
}
body.onbv2-auth #login-screen .auth-type.sel .auth-type-ic {
  color: var(--accent); border-color: rgba(17, 17, 17, 0.35);
}
body.onbv2-auth #login-screen .auth-type-l { flex: 1; font-size: var(--fs-body); font-weight: 700; }
body.onbv2-auth #login-screen .auth-type-check {
  width: 18px; height: 18px; flex: 0 0 18px; border-radius: 50%;
  border: 1.5px solid var(--line-2); display: grid; place-items: center; color: transparent;
}
body.onbv2-auth #login-screen .auth-type.sel .auth-type-check {
  background: var(--accent); border-color: var(--accent); color: var(--accent-ink);
}
/* subtype pills (LEVIAPAY addition — styled with the same tokens) */
body.onbv2-auth #login-screen #signup-v2-subtypes { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 2px; }
body.onbv2-auth #login-screen .onbv2-subtype {
  border: 1.5px solid var(--line); border-radius: var(--r-ctl); padding: 7px 12px;
  font-size: var(--fs-sm); font-weight: 600; cursor: pointer;
  background: var(--field); color: var(--ink-2); font-family: inherit;
}
body.onbv2-auth #login-screen .onbv2-subtype[aria-checked="true"] {
  background: var(--accent); color: var(--accent-ink); border-color: var(--accent);
}
/* consent checkbox (design verbatim) */
body.onbv2-auth #login-screen .auth-check {
  display: flex; align-items: flex-start; gap: 10px; cursor: pointer;
  font-size: var(--fs-sm); color: var(--ink-2); font-weight: 500; line-height: 1.5; margin: 0;
}
body.onbv2-auth #login-screen .auth-check input {
  appearance: none; width: 18px; height: 18px; flex: 0 0 18px; margin: 1px 0 0;
  border: 1.5px solid var(--line-2); border-radius: 2px;
  background: var(--field); cursor: pointer; display: grid; place-items: center;
}
body.onbv2-auth #login-screen .auth-check input:checked { background: var(--accent); border-color: var(--accent); }
body.onbv2-auth #login-screen .auth-check input:checked::after {
  content: ""; width: 9px; height: 5px; margin-top: -2px;
  border-left: 2px solid var(--accent-ink); border-bottom: 2px solid var(--accent-ink);
  transform: rotate(-45deg);
}
/* status footer (design verbatim) */
body.onbv2-auth #login-screen .status-dropup { display: none; }
body.onbv2-auth #login-screen .auth-foot {
  width: 100%; display: flex; flex-direction: column; align-items: center;
  justify-content: center; gap: 12px; margin-top: 44px;
}
body.onbv2-auth #login-screen .auth-foot-row {
  display: flex; align-items: center; gap: 6px 20px; flex-wrap: wrap; justify-content: center;
}
body.onbv2-auth #login-screen .auth-sys {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: var(--fs-sm); font-weight: 600; color: var(--ink-2); white-space: nowrap;
}
body.onbv2-auth #login-screen .auth-dot {
  width: 8px; height: 8px; border-radius: 50%; background: var(--success); flex-shrink: 0;
}
body.onbv2-auth #login-screen .auth-dot.degraded { background: #b45309; }
body.onbv2-auth #login-screen .auth-dot.outage { background: #b91c1c; }
body.onbv2-auth #login-screen .auth-statuslink {
  display: inline-flex; align-items: center; gap: 7px;
  height: 33px; padding: 0 12px; border: 1px solid var(--line-2); border-radius: var(--r-ctl);
  background: var(--card); color: var(--ink); text-decoration: none; cursor: pointer;
  font-family: inherit; font-size: var(--fs-xs); font-weight: 600;
  transition: background 0.14s;
}
body.onbv2-auth #login-screen .auth-statuslink:hover { background: var(--hover); }
body.onbv2-auth #login-screen .auth-statuslink svg { color: var(--ink-3); }
/* forgot-password + MFA cards inherit the card treatment via .authv2-card (JS adds it) */
body.onbv2-auth #login-screen #forgot-password-card h2 {
  font-size: 21px; font-weight: 800; letter-spacing: -0.02em;
}

/* ── Onboarding v2: email-verification gate card ── */
body.onbv2-auth #login-screen .verifyv2 { text-align: center; align-items: center; }
body.onbv2-auth #login-screen .verifyv2-ic {
  width: 46px; height: 46px; border-radius: 5px;
  border: 1px solid rgba(14, 14, 20, 0.1); background: #fff;
  display: grid; place-items: center; color: #0e0e14; margin: 0 auto;
}
body.onbv2-auth #login-screen .verifyv2-text {
  font-size: 14px; color: #5b5b67; line-height: 1.55; margin: 0;
}
body.onbv2-auth #login-screen .verifyv2-text strong { color: #0e0e14; }
body.onbv2-auth #login-screen .verifyv2-resend {
  background: transparent; border: 1px solid rgba(14, 14, 20, 0.16);
  border-radius: 5px; height: 36px; font-size: 13px; font-weight: 600;
  color: #0e0e14; width: 100%; cursor: pointer; font-family: inherit;
}
body.onbv2-auth #login-screen .verifyv2-resend:hover { background: rgba(14, 14, 20, 0.045); }

/* ── Onboarding v2: dashboard setup card ("Einrichtung — {Branche}") ──
   Verbatim port of the dashboard design bundle's setup.css (theme-light,
   dir-raster tokens inlined). Lives in #setup-checklist-root. */
body.onbv2-auth .setupv2 {
  background: var(--card); border: 1px solid var(--line); border-radius: 5px;
  box-shadow: var(--shadow);
  padding: 20px; margin-bottom: 20px;
  font-family: "Plus Jakarta Sans", system-ui, -apple-system, sans-serif;
  color: var(--ink);
}
body.onbv2-auth .setupv2-head {
  display: flex; align-items: center; justify-content: space-between;
  gap: 14px; margin-bottom: 18px;
}
body.onbv2-auth .setupv2-title {
  font-size: 16px; font-weight: 700; letter-spacing: -0.015em; margin: 0;
  white-space: nowrap;
}
body.onbv2-auth .setupv2-sub {
  margin: 3px 0 0; font-size: 13px; color: var(--ink-2); font-weight: 500;
}
body.onbv2-auth .setupv2-meta {
  font-size: 13px; color: var(--ink-3); font-weight: 500; white-space: nowrap;
  flex-shrink: 0; font-variant-numeric: tabular-nums;
}
body.onbv2-auth .setupv2-prog {
  height: 5px; border-radius: 3px; background: var(--hover-2); overflow: hidden;
  margin: 4px 0 6px;
}
body.onbv2-auth .setupv2-prog span {
  display: block; height: 100%; border-radius: 3px; background: var(--solid);
  transition: width 0.3s ease;
}
body.onbv2-auth .setupv2-mail {
  display: flex; align-items: center; gap: 11px;
  margin-top: 10px; padding: 11px 14px;
  border: 1px solid var(--line); border-radius: 5px;
  background: var(--hover-2); color: var(--ink-2);
  font-size: 13px; font-weight: 500; flex-wrap: wrap;
}
body.onbv2-auth .setupv2-mail svg { flex-shrink: 0; color: var(--ink-3); }
body.onbv2-auth .setupv2-mail-txt { flex: 1; min-width: 200px; }
body.onbv2-auth .setupv2-steps { margin-top: 6px; }
body.onbv2-auth .setupv2-row {
  display: flex; align-items: center; gap: 14px; padding: 13px 0;
  border-top: 1px solid var(--line);
}
body.onbv2-auth .setupv2-row:first-child { border-top: 0; }
body.onbv2-auth .setupv2-num {
  width: 28px; height: 28px; flex: 0 0 28px; border-radius: 50%;
  border: 1.5px solid var(--line-2); color: var(--ink-2);
  display: grid; place-items: center;
  font-size: 11px; font-weight: 800;
}
body.onbv2-auth .setupv2-num.ok {
  background: #15875a; border-color: #15875a; color: #fff; /* white check on green, both themes */
}
body.onbv2-auth .setupv2-row-main { flex: 1; min-width: 0; }
body.onbv2-auth .setupv2-row-t { font-size: 14px; font-weight: 700; }
body.onbv2-auth .setupv2-row-s { font-size: 13px; color: var(--ink-2); margin-top: 1px; }
body.onbv2-auth .setupv2-row.done .setupv2-row-t { color: var(--ink-3); }
body.onbv2-auth .setupv2-row.done .setupv2-row-s { color: var(--ink-3); }
/* buttons (design .btn .btn-ghost/.btn-quiet .btn-sm) */
body.onbv2-auth .setupv2-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  height: 31px; padding: 0 11px; border-radius: 5px;
  font-size: 11px; font-weight: 600; letter-spacing: -0.01em;
  font-family: inherit; cursor: pointer; white-space: nowrap;
  border: 1px solid transparent; transition: background 0.14s, border-color 0.14s;
}
body.onbv2-auth .setupv2-btn.ghost {
  background: var(--card); color: var(--ink); border-color: var(--line-2);
}
body.onbv2-auth .setupv2-btn.ghost:hover:not(:disabled):not(.gated) {
  background: var(--hover);
}
body.onbv2-auth .setupv2-btn.quiet { background: transparent; color: var(--ink-2); }
body.onbv2-auth .setupv2-btn.quiet:hover:not(:disabled) {
  background: var(--hover); color: var(--ink);
}
body.onbv2-auth .setupv2-liverow {
  display: flex; align-items: center; gap: 14px;
  border-top: 1px solid var(--line); padding-top: 14px; margin-top: 2px;
}
body.onbv2-auth .setupv2-livebtn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  height: 36px; padding: 0 14px; border-radius: 5px;
  background: var(--solid); color: var(--solid-ink); border: 1px solid var(--solid);
  font-size: 13px; font-weight: 600; font-family: inherit; cursor: pointer;
}
body.onbv2-auth .setupv2-livebtn:hover:not(:disabled):not(.gated) { background: var(--solid-hover); }
/* gate: lock + tooltip (design verbatim) */
body.onbv2-auth .gate-wrap { position: relative; display: inline-flex; }
body.onbv2-auth .gate-wrap .gated { opacity: 0.55; cursor: not-allowed; }
body.onbv2-auth .gate-tip {
  position: absolute; bottom: calc(100% + 9px); left: 50%;
  transform: translateX(-50%) translateY(2px);
  width: max-content; max-width: 250px; text-align: center;
  background: #0e0e14; color: #fff;
  padding: 7px 11px; border-radius: 8px;
  font-size: 12.5px; font-weight: 600; line-height: 1.45;
  opacity: 0; pointer-events: none;
  transition: opacity 0.14s ease, transform 0.14s ease;
  box-shadow: 0 8px 24px rgba(14, 14, 20, 0.16); z-index: 60;
}
body.onbv2-auth .gate-tip::after {
  content: ""; position: absolute; top: 100%; left: 50%;
  transform: translateX(-50%);
  border: 5px solid transparent; border-top-color: #0e0e14;
}
body.onbv2-auth .gate-wrap:hover .gate-tip,
body.onbv2-auth .gate-wrap:focus-within .gate-tip {
  opacity: 1; transform: translateX(-50%) translateY(0);
}

/* ══════════════════════════════════════════════════════════════════════
   SettingsV2 — tabbed settings UI (design 2026-06-12)
   ALL selectors scoped under body.onbv2-auth #settings-v2-root
   ══════════════════════════════════════════════════════════════════════ */
body.onbv2-auth #settings-v2-root {
  font-family: "Plus Jakarta Sans", system-ui, -apple-system, sans-serif;
  color: var(--ink);
}

/* Tab bar */
body.onbv2-auth #settings-v2-root .sv2-tabs {
  display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 20px;
}
body.onbv2-auth #settings-v2-root .sv2-chip {
  appearance: none; border: 1px solid var(--line); background: var(--card);
  height: 34px; padding: 0 14px; border-radius: 4px; /* dir-raster --r-chip */
  font-size: 13px; font-weight: 600; color: var(--ink-2);
  cursor: pointer; font-family: inherit;
  transition: background .14s, color .14s, border-color .14s;
}
body.onbv2-auth #settings-v2-root .sv2-chip:hover {
  background: var(--hover); color: var(--ink);
}
body.onbv2-auth #settings-v2-root .sv2-chip.active {
  background: var(--solid); color: var(--solid-ink); border-color: var(--solid);
}

/* Content area */
body.onbv2-auth #settings-v2-root .sv2-content {
  display: flex; flex-direction: column; gap: 16px;
}

/* Card */
body.onbv2-auth #settings-v2-root .sv2-card {
  background: var(--card); border: 1px solid var(--line); border-radius: 5px;
  box-shadow: var(--shadow);
  padding: 20px;
}
body.onbv2-auth #settings-v2-root .sv2-card-head {
  display: flex; align-items: center; justify-content: flex-start;
  gap: 8px; margin-bottom: 16px;
}
body.onbv2-auth #settings-v2-root .sv2-card-title {
  font-size: 15px; font-weight: 700; letter-spacing: -0.015em; margin: 0;
}

/* Grid 2-col */
body.onbv2-auth #settings-v2-root .sv2-grid2 {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px 16px;
}
@media (max-width: 600px) {
  body.onbv2-auth #settings-v2-root .sv2-grid2 { grid-template-columns: 1fr; }
}

/* Address group */
body.onbv2-auth #settings-v2-root .sv2-address-group {
  display: flex; flex-direction: column; gap: 6px;
}
body.onbv2-auth #settings-v2-root .sv2-address-label {
  font-size: 12px; font-weight: 600; color: var(--ink-2); margin-bottom: 0;
}
body.onbv2-auth #settings-v2-root .sv2-grid-plzcity {
  display: grid; grid-template-columns: 120px 1fr; gap: 8px;
}

/* Labels + inputs */
body.onbv2-auth #settings-v2-root .sv2-label {
  display: flex; flex-direction: column; gap: 5px;
  font-size: 12px; font-weight: 600; color: var(--ink-2);
}
body.onbv2-auth #settings-v2-root .sv2-input {
  height: 36px; padding: 0 10px; border-radius: 5px;
  border: 1px solid var(--line-2); background: var(--field);
  font-size: 13px; font-family: inherit; color: var(--ink);
  outline: none; transition: border-color .14s;
  width: 100%; box-sizing: border-box;
}
body.onbv2-auth #settings-v2-root .sv2-input:focus {
  border-color: var(--solid);
}
body.onbv2-auth #settings-v2-root .sv2-mono {
  font-variant-numeric: tabular-nums; font-feature-settings: "tnum";
}
body.onbv2-auth #settings-v2-root .sv2-url-input {
  flex: 1; min-width: 0;
}

/* Buttons */
body.onbv2-auth #settings-v2-root .sv2-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 7px;
  height: 36px; padding: 0 14px; border-radius: 5px;
  font-size: 13px; font-weight: 600; font-family: inherit; cursor: pointer;
  border: 1px solid transparent; transition: background .14s, border-color .14s;
  white-space: nowrap;
}
body.onbv2-auth #settings-v2-root .sv2-btn:disabled {
  opacity: 0.5; cursor: not-allowed;
}
body.onbv2-auth #settings-v2-root .sv2-btn-primary {
  background: var(--solid); color: var(--solid-ink); border-color: var(--solid);
}
body.onbv2-auth #settings-v2-root .sv2-btn-primary:hover:not(:disabled) {
  background: var(--solid-hover);
}
body.onbv2-auth #settings-v2-root .sv2-btn-ghost {
  background: var(--card); color: var(--ink); border-color: var(--line-2);
}
body.onbv2-auth #settings-v2-root .sv2-btn-ghost:hover:not(:disabled) {
  background: var(--hover);
}

/* Footer row */
body.onbv2-auth #settings-v2-root .sv2-footer {
  display: flex; gap: 8px; margin-top: 16px; justify-content: flex-end;
}

/* Separator */
body.onbv2-auth #settings-v2-root .sv2-sep {
  border: 0; border-top: 1px solid var(--line); margin: 16px 0;
}

/* Status chips — design: pill with leading dot (.status ok) */
body.onbv2-auth #settings-v2-root .sv2-status {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 5px 12px; border-radius: 999px;
  font-size: 11px; font-weight: 700; letter-spacing: .01em;
  background: var(--hover-2); color: var(--ink-2); white-space: nowrap;
}
body.onbv2-auth #settings-v2-root .sv2-status .sv2-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: currentColor; flex: 0 0 7px;
}
body.onbv2-auth #settings-v2-root .sv2-status.ok {
  background: rgba(21,135,90,.12); color: #15875a;
}

/* Toggle rows */
body.onbv2-auth #settings-v2-root .sv2-trow {
  display: flex; align-items: center; gap: 16px;
  padding: 16px 0; border-top: 1px solid var(--line);
}
body.onbv2-auth #settings-v2-root .sv2-trow:first-child { border-top: 0; }
body.onbv2-auth #settings-v2-root .sv2-trow-text { flex: 1; min-width: 0; }
body.onbv2-auth #settings-v2-root .sv2-trow-label {
  display: block; font-size: 14px; font-weight: 700; color: var(--ink);
}
body.onbv2-auth #settings-v2-root .sv2-trow-sub {
  display: block; font-size: 12px; color: var(--ink-2); margin-top: 3px;
}

/* Toggle switch — design: 46×27 track, 21px thumb */
body.onbv2-auth #settings-v2-root .sv2-toggle {
  position: relative; display: inline-block; width: 46px; height: 27px;
  flex-shrink: 0; cursor: pointer;
}
body.onbv2-auth #settings-v2-root .sv2-toggle-inp {
  opacity: 0; width: 0; height: 0; position: absolute;
}
body.onbv2-auth #settings-v2-root .sv2-toggle-track {
  position: absolute; inset: 0; border-radius: 999px;
  background: var(--line-2); transition: background .16s;
}
body.onbv2-auth #settings-v2-root .sv2-toggle-track::after {
  content: ""; position: absolute; width: 21px; height: 21px; border-radius: 50%;
  background: #fff; top: 3px; left: 3px;
  box-shadow: 0 1px 3px rgba(0,0,0,.3);
  transition: left .16s;
}
body.onbv2-auth #settings-v2-root .sv2-toggle-inp:checked + .sv2-toggle-track {
  background: var(--solid);
}
body.onbv2-auth #settings-v2-root .sv2-toggle-inp:checked + .sv2-toggle-track::after {
  left: 22px;
}
body.onbv2-auth #settings-v2-root .sv2-toggle-inp:disabled + .sv2-toggle-track {
  opacity: 0.5; cursor: not-allowed;
}

/* Hint / description text */
body.onbv2-auth #settings-v2-root .sv2-desc {
  font-size: 13px; color: var(--ink-2); margin: 0 0 14px;
}
body.onbv2-auth #settings-v2-root .sv2-hint {
  font-size: 13px; color: var(--ink-3); margin: 8px 0;
}
body.onbv2-auth #settings-v2-root .sv2-note {
  font-size: 12px; color: var(--ink-3); margin: 12px 0 0; font-style: italic;
}

/* Error messages */
body.onbv2-auth #settings-v2-root .sv2-error {
  font-size: 13px; color: #b91c1c; margin-top: 8px; padding: 8px 10px;
  background: rgba(185,28,28,.06); border-radius: 4px;
}

/* Kassen register cards */
body.onbv2-auth #settings-v2-root .sv2-registers {
  display: flex; flex-direction: column; gap: 10px; margin-bottom: 4px;
}
body.onbv2-auth #settings-v2-root .sv2-register-card {
  border: 1px solid var(--line); border-radius: 4px; padding: 22px;
  background: var(--hover);
}
body.onbv2-auth #settings-v2-root .sv2-register-head {
  display: flex; align-items: center; justify-content: space-between;
  gap: 10px; margin-bottom: 18px;
}
body.onbv2-auth #settings-v2-root .sv2-register-name {
  font-size: 19px; font-weight: 800; letter-spacing: -0.01em;
}
body.onbv2-auth #settings-v2-root .sv2-register-info {
  /* design: boxed tiles, min 200px, long serials wrap inside their tile */
  display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 12px;
  margin-bottom: 18px;
}
body.onbv2-auth #settings-v2-root .sv2-register-actions {
  border-top: 1px solid var(--line); padding-top: 16px;
}
body.onbv2-auth #settings-v2-root .sv2-tile {
  display: flex; flex-direction: column; gap: 8px; min-width: 0;
  background: var(--card); border: 1px solid var(--line); border-radius: 4px;
  padding: 13px 15px;
}
body.onbv2-auth #settings-v2-root .sv2-tile-label {
  font-size: 11px; font-weight: 700; color: var(--ink-3); text-transform: uppercase;
  letter-spacing: .06em;
}
body.onbv2-auth #settings-v2-root .sv2-tile-value {
  font-size: 13px; color: var(--ink); overflow-wrap: anywhere; min-width: 0;
}
body.onbv2-auth #settings-v2-root .sv2-tile-value:not(.sv2-mono) {
  font-weight: 700;
}
body.onbv2-auth #settings-v2-root .sv2-fin-ok {
  color: #15875a;
}

/* Finanzwesen grid — design: flex row above a separator, save button 42px */
body.onbv2-auth #settings-v2-root .sv2-fin-grid {
  display: flex; gap: 18px; align-items: flex-end; flex-wrap: wrap;
  margin-top: 24px; padding-top: 22px; border-top: 1px solid var(--line);
}
body.onbv2-auth #settings-v2-root .sv2-fin-grid > .sv2-label {
  flex: 1 1 240px;
}
body.onbv2-auth #settings-v2-root .sv2-fin-grid > .sv2-btn {
  height: 42px; flex: 0 0 auto;
}

/* Booking URL row */
body.onbv2-auth #settings-v2-root .sv2-url-row {
  display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin: 10px 0;
}

/* settings v2 — design-fidelity pass (page head, full-width spans, i-badges) */
body.onbv2-auth #settings-v2-root .sv2-page-head {
  margin: 4px 0 18px;
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 16px;
}
body.onbv2-auth #settings-v2-root .sv2-head-actions {
  display: flex; align-items: center; gap: 10px;
}
body.onbv2-auth #settings-v2-root .sv2-page-title {
  font-size: 26px; font-weight: 800; letter-spacing: -0.02em; margin: 0 0 4px;
}
body.onbv2-auth #settings-v2-root .sv2-page-sub {
  font-size: 14px; color: var(--ink-2); margin: 0;
}
body.onbv2-auth #settings-v2-root .sv2-span-full { grid-column: 1 / -1; }
body.onbv2-auth #settings-v2-root .sv2-ibadge {
  width: 17px; height: 17px; border-radius: 50%;
  background: var(--line-2); color: var(--card);
  display: inline-grid; place-items: center; flex: 0 0 17px;
  font-size: 11px; font-weight: 800; font-style: italic; line-height: 1;
  cursor: help; margin-left: 6px; vertical-align: middle;
  position: relative;
}
body.onbv2-auth #settings-v2-root .sv2-ibadge[data-tip]::after {
  content: attr(data-tip);
  position: absolute; bottom: calc(100% + 8px); left: 50%;
  transform: translateX(-50%);
  background: var(--solid); color: var(--card);
  font-size: 12px; font-weight: 500; font-style: normal; line-height: 1.45;
  padding: 8px 12px; border-radius: 5px;
  width: max-content; max-width: 240px; text-align: left;
  white-space: normal; opacity: 0; pointer-events: none;
  transition: opacity .12s; z-index: 60;
}
body.onbv2-auth #settings-v2-root .sv2-ibadge[data-tip]:hover::after {
  opacity: 1;
}
body.onbv2-auth #settings-v2-root .sv2-logo-preview {
  height: 36px; max-width: 120px; object-fit: contain;
  border-radius: 4px; border: 1px solid var(--line);
  /* receipt logos are printed on white — keep a white tile in dark too */
  background: #fff; padding: 2px;
}
body.onbv2-auth #settings-v2-root .sv2-card-sub {
  font-size: 13px; color: var(--ink-2); margin: -8px 0 18px;
}
body.onbv2-auth #settings-v2-root .sv2-label-row {
  display: inline-flex; align-items: center; gap: 6px;
}
