/* ============================================================================
   QO7 Panel — Precision-Designsystem (Suite2-Port, 2026-06-10)
   Verbindliche Token-Quelle: webmail-app/public/css/webmail-precision.css
   (neutrale #111317-Flächen, 1px-Linien #363b49, Radien 4/8px, KEINE Glows).
   Theme: html[data-theme="dark|light"] + html[data-brand="qo7"], Key localStorage.qo7Theme.
   Ersetzt app.css (skin-2) vollständig; app.css bleibt nur als Rollback liegen.
   Gliederung: 1 Tokens · 2 Legacy-Aliase · 3 Basis · 4 Shell · 5 Auth ·
               6 Portierte Komponenten (skin-2) · 7 Responsive
   ========================================================================== */

/* ===== 1. Tokens ===== */
:root{
  --font-display:"Funnel Display",system-ui,sans-serif;
  --font-sans:"Funnel Sans",system-ui,sans-serif;
  --font-mono:"Geist Mono",ui-monospace,monospace;
  --ease:cubic-bezier(.2,.7,.2,1);
  --radius:4px; --radius-lg:8px;
  --ok:#34d3c0; --warn:#e6c46b; --err:#ff7d72; --info:#7fb4e8;
}
:root, html[data-brand="qo7"]{ /* dark = Default */
  --bg:#111317; --bg-2:#0d0f13; --bg-deep:#0c0e12;
  --surface:#1b1f27; --surface-2:#232834; --surface-3:#2a2f3a;
  --line:#363b49; --line-2:#4a505f;
  --text:#e9eaef; --text-2:#b7bec6; --text-3:#8c95a0;
  --acc:#ff7d2b; --acc-2:#ffa468; --acc-ink:#1c0d02;
  --acc-dim:rgba(255,125,43,.12); --acc-line:rgba(255,125,43,.40);
}
html[data-theme="light"]{
  --bg:#f5f7f6; --bg-2:#eef1f0; --bg-deep:#e9eceb;
  --surface:#ffffff; --surface-2:#f1f4f3; --surface-3:#e6ebe9;
  --line:#e2e5e4; --line-2:#d0d5d3;
  --text:#14181a; --text-2:#45504d; --text-3:#76817d;
  --acc:#d8600c; --acc-2:#b44e07; --acc-ink:#ffffff;
  --acc-dim:rgba(216,96,12,.08); --acc-line:rgba(216,96,12,.32);
  --ok:#1f9d63; --warn:#a9762a; --err:#bb4a3d; --info:#2f6fb0;
}

/* ===== 2. Legacy-Aliase =====
   Brücke für Bestands-Views/Inline-Styles (skin-2- und Alt-Familie).
   NUR von Blade-Inline-Styles konsumieren — neues CSS nutzt kanonische Namen.
   Abbau view-weise; danach Block löschen. */
:root{
  --ink:var(--text); --ink2:var(--text-2); --ink3:var(--text-3);
  --ink-1:var(--text); --ink-2:var(--text-2); --ink-3:var(--text-3); --ink-4:var(--text-3);
  --panel:var(--surface); --panel-2:var(--surface-2); --card:var(--surface);
  --accent:var(--acc); --accent-dim:var(--acc-dim); --accent-text:var(--acc-2);
  --accent-soft:var(--acc-dim);
  --hand:var(--acc-2); --hand-f:var(--font-display);
  --sans:var(--font-sans); --head:var(--font-display); --mono:var(--font-mono);
  --danger:var(--err);
  --ok-soft:color-mix(in srgb,var(--ok) 12%,transparent);
  --warn-soft:color-mix(in srgb,var(--warn) 14%,transparent);
  --danger-soft:color-mix(in srgb,var(--err) 12%,transparent);
  --info-soft:color-mix(in srgb,var(--info) 12%,transparent);
}

/* ===== 3. Basis ===== */
*{box-sizing:border-box}
html{scroll-behavior:smooth;color-scheme:dark}
html[data-theme="light"]{color-scheme:light}
body{margin:0;background:var(--bg);color:var(--text);font-family:var(--font-sans);
  font-weight:300;font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased}
body::before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:radial-gradient(55rem 30rem at 80% -10%,var(--acc-dim),transparent 72%)}
a{color:inherit;text-decoration:none} /* wie skin-2: Links dekorieren nur gezielt (.legal a, .article-body a, …) */
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600}
b,strong{font-weight:600}
button{font-family:inherit}
.mono{font-family:var(--font-mono)}
.muted{color:var(--text-3)}
img{max-width:100%}
:focus-visible{outline:2px solid var(--acc-line);outline-offset:2px}
.sr{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}
.is-light{display:none}
html[data-theme="light"] .is-light{display:inline-block}
html[data-theme="light"] .is-dark{display:none}

/* ===== 4. Shell: Topbar · gnav · subnav · Footer · Impersonation ===== */
.topbar{position:sticky;top:0;z-index:40;display:flex;align-items:center;gap:1rem;
  padding:.6rem 1.2rem;background:color-mix(in srgb,var(--bg) 88%,transparent);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:.55rem;font-family:var(--font-display);
  font-weight:700;font-size:1.05rem;text-decoration:none}
.brand .sq{width:13px;height:13px;border-radius:3px;background:var(--acc)}
.brand .logo-img{height:20px;width:auto}
/* Logo-Paar: Sichtbarkeit mit voller Spezifität (schlägt .brand .logo-img),
   damit im Dark-Default nur is-dark, im Light nur is-light erscheint. */
.brand .logo-img.is-light{display:none}
.brand .logo-img.is-dark{display:block}
html[data-theme="light"] .brand .logo-img.is-light{display:block}
html[data-theme="light"] .brand .logo-img.is-dark{display:none}
.brand .sub{font-family:var(--font-mono);font-size:.7rem;color:var(--text-3);font-weight:400;
  border-left:1px solid var(--line-2);padding-left:.55rem}
.tb-right{margin-left:auto;display:flex;align-items:center;gap:.45rem}
.icon-btn{position:relative;width:34px;height:34px;border-radius:var(--radius);
  border:1px solid var(--line-2);background:transparent;color:var(--text);cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;text-decoration:none}
.icon-btn:hover{border-color:var(--acc-line)}
.icon-btn svg{width:17px;height:17px}
.nbadge{position:absolute;top:-4px;right:-4px;min-width:15px;height:15px;padding:0 3px;
  background:var(--err);color:var(--bg);font-family:var(--font-mono);font-size:9.5px;
  font-weight:600;border-radius:99px;display:flex;align-items:center;justify-content:center;line-height:1}
.av{width:30px;height:30px;border-radius:50%;background:var(--acc-dim);color:var(--acc);
  border:1px solid var(--acc-line);display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--font-mono);font-size:.7rem;text-decoration:none;overflow:hidden;flex-shrink:0}
.av img{width:100%;height:100%;object-fit:cover}
.upg{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--font-mono);font-size:.74rem;
  color:var(--acc);background:var(--acc-dim);border:1px solid var(--acc-line);
  border-radius:var(--radius);padding:.4rem .7rem;text-decoration:none}
.upg:hover{border-color:var(--acc)}
.upg svg{width:14px;height:14px}
.tb-link{display:inline-flex;align-items:center;gap:.35rem;font-family:var(--font-mono);
  font-size:.74rem;color:var(--text-2);border:1px solid var(--line-2);border-radius:var(--radius);
  padding:.4rem .7rem;text-decoration:none}
.tb-link:hover{color:var(--text);border-color:var(--acc-line)}
.tb-link svg{width:14px;height:14px}
.gnav{display:flex;gap:.2rem;padding:0 1.2rem;border-bottom:1px solid var(--line);
  background:var(--bg-2);overflow-x:auto;scrollbar-width:none}
.gnav::-webkit-scrollbar{display:none}
.gnav a{display:inline-flex;align-items:center;gap:.4rem;border-bottom:2px solid transparent;
  color:var(--text-2);font-family:var(--font-mono);font-size:.8rem;padding:.65rem .8rem;
  text-decoration:none;white-space:nowrap}
.gnav a:hover{color:var(--text)}
.gnav a.on{color:var(--text);border-bottom-color:var(--acc)}
.gnav a svg{width:15px;height:15px;flex-shrink:0;opacity:.75}
.gnav a.on svg,.gnav a:hover svg{opacity:1}
.gnav a.on svg{stroke:var(--acc)}
.gnav .badge{font-family:var(--font-mono);font-size:.62rem;background:var(--acc);color:var(--acc-ink);
  border-radius:99px;padding:0 .4rem;font-weight:600}
.gnav .badge.warn{background:var(--warn);color:var(--bg-deep)}
.subnav{display:flex;gap:.15rem;padding:.45rem 1.2rem;border-bottom:1px solid var(--line);
  background:var(--surface);overflow-x:auto;scrollbar-width:none}
.subnav::-webkit-scrollbar{display:none}
.subnav a{border:1px solid transparent;border-radius:99px;color:var(--text-2);
  font-family:var(--font-mono);font-size:.74rem;padding:.3rem .7rem;text-decoration:none;white-space:nowrap}
.subnav a:hover{color:var(--text);border-color:var(--line-2)}
.subnav a.on{color:var(--acc);background:var(--acc-dim);border-color:var(--acc-line)}
.impbar{background:var(--acc-dim);border-bottom:1px solid var(--acc-line)}
.impbar-inner{max-width:84rem;margin:0 auto;padding:.45rem 1.2rem;display:flex;align-items:center;
  gap:.6rem;font-size:.84rem}
.impbar-inner form{margin-left:auto}
.impbar-dot{width:8px;height:8px;border-radius:50%;background:var(--acc);flex-shrink:0}
.impbar-btn{font-family:var(--font-mono);font-size:.72rem;border:1px solid var(--acc-line);
  background:transparent;color:var(--acc);border-radius:var(--radius);padding:.3rem .6rem;cursor:pointer}
.impbar-btn:hover{background:var(--acc);color:var(--acc-ink)}
.foot{border-top:1px solid var(--line);background:var(--bg-2);margin-top:2.5rem}
.foot .in{max-width:84rem;margin:0 auto;padding:1.1rem 1.2rem;display:grid;
  grid-template-columns:1fr auto 1fr;align-items:center;gap:1rem;font-family:var(--font-mono);
  font-size:.74rem;color:var(--text-3)}
/* 3 Kinder: links/mittig/rechts — Mitte exakt zentriert (1fr auto 1fr).
   2 Kinder: erstes links, letztes rechts (Spalte 2 bleibt leer). */
.foot .in>:first-child{grid-column:1;text-align:left}
.foot .in>:nth-child(2):not(:last-child){grid-column:2;text-align:center}
.foot .in>:last-child{grid-column:3;text-align:right}
.foot a{color:var(--text-2);text-decoration:none}
.foot a:hover{color:var(--text)}
.seg{display:inline-flex;border:1px solid var(--line-2);border-radius:var(--radius);overflow:hidden}
.seg button,.seg a{padding:.28rem .65rem;background:transparent;border:0;color:var(--text-2);
  cursor:pointer;font-family:var(--font-mono);font-size:.72rem;text-decoration:none}
.seg button[aria-pressed="true"],.seg a.on{background:var(--acc);color:var(--acc-ink);font-weight:600}

/* ===== 5. Auth (Login/Register/2FA — Muster aus webmail views-precision) ===== */
.auth{min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr}
.auth-brand{background:var(--bg-2);border-right:1px solid var(--line);padding:2.6rem 2.8rem;
  display:flex;flex-direction:column;gap:1.6rem}
.auth-tag{font-size:2rem;line-height:1.2;margin:1.2rem 0 0;max-width:22rem}
.auth-tag .hl{color:var(--acc);font-style:italic}
.auth-pts{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.9rem;
  font-size:.92rem;color:var(--text-2)}
.auth-pts li{display:flex;gap:.7rem;align-items:flex-start}
.auth-pts .ic{flex-shrink:0;width:30px;height:30px;border-radius:var(--radius);
  border:1px solid var(--line-2);display:grid;place-items:center;color:var(--acc)}
.auth-pts .ic svg{width:15px;height:15px}
.auth-foot{margin-top:auto}
.auth-form{display:grid;place-items:center;padding:2rem 1.4rem}
.auth-form .card{width:100%;max-width:24rem}
.auth-theme{position:fixed;top:1rem;right:1rem;z-index:50}
.legal{font-family:var(--font-mono);font-size:.72rem;color:var(--text-3)}
.legal a{color:var(--acc);text-decoration:underline;text-underline-offset:2px}
.auth-row{display:flex;align-items:center;justify-content:space-between;gap:.6rem;font-size:.82rem;margin:.7rem 0}
.auth-row label{display:flex;gap:.4rem;align-items:center}
.auth-row a{color:var(--text-2)}
.auth-row a:hover{color:var(--text)}
.authfoot{margin-top:1rem;font-family:var(--font-mono);font-size:.74rem;color:var(--text-3)}
.authfoot a{color:var(--acc);text-decoration:underline;text-underline-offset:2px}

/* ===== 6. Portierte Komponenten (skin-2 → Precision) ===== */

/* Layout-Grundgerüst */
.wrap{max-width:1180px;margin:0 auto;padding:30px 22px 80px}
.u-narrow{max-width:820px}

/* Kommandozeile & Seitenkopf */
.cmdline{font-family:var(--font-mono);font-size:13px;color:var(--text-3);margin-bottom:18px}
.cmdline .p{color:var(--acc)}
.cmdline .c{color:var(--text)}
.cmdline .greet{color:var(--text-3)}
.cmdline .caret{display:inline-block;width:8px;height:15px;background:var(--acc);margin-left:7px;vertical-align:-2px;animation:qo7blink 1.1s steps(1) infinite}
@keyframes qo7blink{50%{opacity:0}}
.hrow{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:26px}
h1{font-size:27px;letter-spacing:-.025em}
h1 .mono{font-family:var(--font-mono);color:var(--acc);font-weight:500}
h1 .hand{font-family:var(--font-display);color:var(--acc-2);font-weight:600;font-size:.82em;margin-left:6px}
.hsub{font-family:var(--font-mono);font-size:12.5px;color:var(--text-2);margin-top:6px}
.hsub .ok{color:var(--acc)}
.newbtn{display:inline-flex;align-items:center;gap:8px;background:var(--acc);color:var(--acc-ink);border:0;font-family:var(--font-mono);font-weight:500;font-size:13px;padding:10px 16px;border-radius:var(--radius);cursor:pointer}
.newbtn svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2.4}
.pagehead{display:flex;align-items:baseline;gap:10px;margin-bottom:2px}
.pagehead h2{font-family:var(--font-sans);font-weight:700;font-size:18px;letter-spacing:-.3px;color:var(--text)}
.pagehead .note{font-family:var(--font-display);font-size:18px;color:var(--acc-2);font-weight:600;border:0;background:none;padding:0;margin:0;display:inline}
.foot-note{margin-top:36px;text-align:center;font-size:12.5px;color:var(--text-3)}
.ptitle{margin-bottom:22px}
.ptitle h1{font-size:24px;font-weight:600;letter-spacing:-.02em}
.ptitle p{color:var(--text-2);font-size:14px;margin-top:5px}
.lead{color:var(--text-2);font-size:14px;margin:4px 0 14px;line-height:1.55}
.lead .note{font-family:var(--font-display);color:var(--acc-2);font-size:1.25em;border:0;background:none;padding:0;display:inline}
.lead .note svg{display:none}
.lbl{font-family:var(--font-mono);font-size:12px;color:var(--text-2);text-transform:uppercase;letter-spacing:.08em;margin:0 0 14px}
.lbl::before{content:"// ";color:var(--acc)}
.crumb{font-family:var(--font-mono);font-size:12px;color:var(--text-3);margin-bottom:16px}
.crumb a{color:var(--text-2);text-decoration:none}
.crumb a:hover{color:var(--acc)}
.sectit{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.sectit h2{font-family:var(--font-mono);font-size:12px;color:var(--text-2);text-transform:uppercase;letter-spacing:.1em;font-weight:500}
.sectit h2::before{content:"// ";color:var(--acc)}
.cnt{font-family:var(--font-mono);font-size:12px;color:var(--text-3);text-decoration:none}
a.cnt:hover{color:var(--acc)}

/* Status-Readout */
.readout{font-family:var(--font-mono);font-size:12px;border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);margin-bottom:30px;display:grid;grid-template-columns:repeat(4,1fr)}
.ro{padding:14px 18px;border-right:1px solid var(--line)}
.ro:last-child{border-right:0}
.ro .k{color:var(--text-3);font-size:11px;letter-spacing:.04em;margin-bottom:6px}
.ro .v{font-family:var(--font-display);font-size:20px;font-weight:600;letter-spacing:-.02em}
.ro .v small{font-family:var(--font-mono);font-size:11px;color:var(--text-3);font-weight:400}

/* Stack-Karten */
.stacks{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.stack{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);overflow:hidden;transition:border-color .15s,transform .15s}
.stack:hover{border-color:var(--acc-line);transform:translateY(-2px)}
.stack-h{padding:16px 16px 0;display:flex;align-items:center;gap:11px}
.stack-ic{width:40px;height:40px;border-radius:var(--radius);background:var(--surface-2);border:1px solid var(--line);display:grid;place-items:center;font-family:var(--font-mono);font-weight:600;font-size:13px;color:var(--acc);flex:none}
.stack-id{flex:1;min-width:0}
.stack-id b{font-size:15px;font-weight:600;display:block;letter-spacing:-.01em}
.stack-id .dom{font-family:var(--font-mono);font-size:11.5px;color:var(--text-3)}
.led{width:8px;height:8px;border-radius:50%;flex:none;position:relative}
.led.on{background:var(--ok)}
.led.dep{background:var(--warn)}
.stack-spec{padding:14px 16px;font-family:var(--font-mono);font-size:11.5px;color:var(--text-2);display:flex;gap:14px}
.stack-spec span{display:flex;align-items:center;gap:6px}
.stack-spec .lbl{color:var(--text-3);margin:0;text-transform:none;letter-spacing:0;font-size:inherit;font-family:var(--font-mono)}
.stack-spec .lbl::before{content:""}
.stack-act{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line)}
.act{display:flex;align-items:center;justify-content:center;gap:6px;padding:11px 4px;font-family:var(--font-mono);font-size:11px;color:var(--text-2);border-right:1px solid var(--line);cursor:pointer;transition:.12s}
.act:last-child{border-right:0}
.act:hover{background:var(--acc-dim);color:var(--acc)}
.act svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:1.8}
.stack.add{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:9px;border-style:dashed;cursor:pointer;min-height:170px;color:var(--text-2)}
.stack.add:hover{border-color:var(--acc);color:var(--acc)}
.stack.add .p{width:42px;height:42px;border-radius:var(--radius);border:1px solid var(--line);display:grid;place-items:center}
.stack.add svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2}
.stack.add b{font-size:14px;font-weight:600;font-family:var(--font-sans)}
.stack.add span{font-family:var(--font-mono);font-size:11px;color:var(--text-3)}

/* Erweiterungen zu Abschnitt 4: Avatar-Größe + Admin-Badge */
.av-lg{width:64px;height:64px;border-radius:var(--radius-lg);font-size:22px;flex:none}
.adminbadge{font-family:var(--font-mono);font-weight:700;font-size:9px;letter-spacing:1px;text-transform:uppercase;color:var(--acc-ink);background:var(--acc);padding:2px 6px;border-radius:var(--radius);margin-left:7px;vertical-align:middle}

/* Stack-Detailkopf & Tabs */
.stack-head{display:flex;align-items:center;gap:14px;margin-bottom:22px}
.stack-head .sh-ic{width:46px;height:46px;border-radius:var(--radius-lg);background:var(--surface-2);border:1px solid var(--line);display:grid;place-items:center;font-family:var(--font-mono);font-weight:600;color:var(--acc)}
.stack-head h1{font-size:23px;font-weight:600;letter-spacing:-.02em;display:flex;align-items:center;gap:10px}
.stack-head .dom{font-family:var(--font-mono);font-size:12.5px;color:var(--text-3)}
.stack-head .led{width:9px;height:9px;border-radius:50%}
.stack-head .led.on{background:var(--ok)}
.stack-head .spacer{flex:1}
.open-site{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:12.5px;color:var(--text);text-decoration:none;border:1px solid var(--line);padding:8px 14px;border-radius:var(--radius)}
.open-site:hover{border-color:var(--acc);color:var(--acc)}
.open-site svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:1.8}
.stabs{display:flex;align-items:center;gap:2px;border-bottom:1px solid var(--line);margin-bottom:26px;position:relative;flex-wrap:wrap}
.stabs a{position:relative;padding:11px 15px;font-size:13.5px;font-weight:450;color:var(--text-2);text-decoration:none;background:none;border:0;cursor:pointer;font-family:var(--font-sans)}
.stabs a:hover{color:var(--text)}
.stabs a.on{color:var(--text);font-weight:550}
.stabs a.on::after{content:"";position:absolute;left:15px;right:15px;bottom:-1px;height:2px;background:var(--acc)}

/* Sicherheits-Checks, "Bald"-QA-Items, Gefahrenzone */
.check{display:flex;align-items:center;gap:12px;padding:14px 18px;border-top:1px solid var(--line-2)}
.check .ci{width:30px;height:30px;border-radius:var(--radius);display:grid;place-items:center;flex:none}
.check .ci svg{width:17px;height:17px;fill:none;stroke:currentColor;stroke-width:2}
.check.okk .ci{background:color-mix(in srgb,var(--ok) 12%,transparent);color:var(--ok)}
.check.wn .ci{background:color-mix(in srgb,var(--warn) 12%,transparent);color:var(--warn)}
.check .ct{flex:1;min-width:0}
.check .ct b{font-size:13.5px;font-weight:600}
.check .ct p{font-size:12.5px;color:var(--text-3);margin-top:2px;line-height:1.5}
.check .fix{font-family:var(--font-mono);font-size:12px;color:var(--acc);text-decoration:none;flex:none}
.check .fix:hover{text-decoration:underline}
.qa-soon{display:flex;align-items:center;gap:11px;padding:13px 18px;border-top:1px solid var(--line-2);color:var(--text-3);font-size:13.5px}
.qa-soon .qi{width:30px;height:30px;border-radius:var(--radius);background:var(--surface-2);display:grid;place-items:center;color:var(--text-3);flex:none}
.qa-soon .qi svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.9}
.qa-soon .qa-soon-badge{margin-left:auto}
.qa-actionbtn{display:flex;align-items:center;gap:11px;width:100%;background:none;border:0;border-top:1px solid var(--line-2);cursor:pointer;text-align:left;padding:13px 18px;color:var(--text);font-size:13.5px}
.qa-actionbtn:hover{background:var(--surface-2)}
.qa-actionbtn .qi{width:30px;height:30px;border-radius:var(--radius);background:var(--surface-2);display:grid;place-items:center;color:var(--acc);flex:none}
.qa-actionbtn .qi svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.9}
.qa-actionbtn .qa-label{flex:1}
.qa-actionbtn .arr{margin-left:auto;color:var(--text-3)}
.qa-actionbtn .arr svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2}
.card.danger .card-h{border-bottom-color:color-mix(in srgb,var(--err) 30%,transparent)}
.card.danger .card-h h2{color:var(--err)}

/* Log-Viewer */
.logwrap{overflow:hidden}
.logtabs{display:flex;gap:2px;border-bottom:1px solid var(--line);padding:0 8px}
.logtab{background:none;border:0;cursor:pointer;font-family:var(--font-sans);font-size:13.5px;color:var(--text-2);padding:12px 14px;position:relative;display:inline-flex;align-items:center;gap:7px}
.logtab:hover{color:var(--text)}
.logtab.is-active{color:var(--text);font-weight:550}
.logtab.is-active::after{content:"";position:absolute;left:14px;right:14px;bottom:-1px;height:2px;background:var(--acc)}
.logtab-count{font-family:var(--font-mono);font-size:11px;color:var(--text-3);background:var(--surface-2);border-radius:var(--radius);padding:1px 6px}
.logtab-count-empty{opacity:.5}
.logfilter{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.logfilter-search-wrap{display:flex;align-items:center;gap:7px;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius);padding:6px 10px;flex:1;min-width:180px}
.logfilter-search-wrap svg{stroke:var(--text-3);flex:none}
.logfilter-search{border:0;background:none;outline:none;color:var(--text);font-family:var(--font-sans);font-size:13px;flex:1}
.logfilter-chips{display:flex;gap:5px}
.chip{font-family:var(--font-mono);font-size:11.5px;border:1px solid var(--line);background:var(--surface);color:var(--text-2);border-radius:var(--radius);padding:4px 9px;cursor:pointer}
.chip:hover{border-color:var(--acc);color:var(--acc)}
.chip.is-active{background:var(--acc-dim);border-color:var(--acc);color:var(--acc)}
.logfilter-count{font-family:var(--font-mono);font-size:11.5px;color:var(--text-3);margin-left:auto}
.logbox{max-height:520px;overflow:auto;background:var(--bg);font-family:var(--font-mono);font-size:12px}
.ll{padding:4px 16px;border-bottom:1px solid var(--line-2);color:var(--text-2);white-space:pre-wrap;word-break:break-all;line-height:1.5}
.ll-2xx{color:var(--ok)}
.ll-3xx{color:var(--text-2)}
.ll-4xx{color:var(--warn)}
.ll-5xx{color:var(--err)}
.logempty{padding:40px 20px;text-align:center;color:var(--text-3);font-size:13px;line-height:1.6}

/* Datenbank-Detail-Panel */
.db-detail{padding:18px 22px}
.db-detail-head{display:flex;align-items:center;gap:8px;margin-bottom:14px}
.db-detail-head svg{color:var(--acc);flex:none;fill:none;stroke:currentColor}
.db-detail-head h4{font-size:14px;font-weight:600}
.db-detail-head small{color:var(--text-3);font-size:11.5px}
.db-detail-close{margin-left:auto;background:none;border:0;cursor:pointer;color:var(--text-3)}
.db-detail-close:hover{color:var(--text)}
.db-conn{display:grid;grid-template-columns:1fr 1fr;gap:0 24px;margin-bottom:16px}
.db-conn-row{display:flex;flex-direction:column;gap:3px;padding:9px 0;border-bottom:1px solid var(--line-2)}
.db-conn-label{font-size:11.5px;color:var(--text-3)}
.db-conn-value{display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:13px;color:var(--text)}
.db-conn-copy{background:none;border:0;cursor:pointer;color:var(--text-3);padding:2px;display:grid;place-items:center}
.db-conn-copy:hover{color:var(--acc)}
.db-conn-copy svg{fill:none;stroke:currentColor}
.db-conn-hint{font-family:var(--font-sans);font-size:11px;color:var(--text-3)}
.db-conn-pw{display:flex;align-items:center;gap:14px;padding:12px 14px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);margin-bottom:14px;flex-wrap:wrap}
.db-conn-pw-meta{flex:1;min-width:200px}
.db-conn-pw-title{font-weight:600;font-size:13px}
.db-conn-pw-text{font-size:11.5px;color:var(--text-3);line-height:1.5;margin-top:2px}
.db-conn-pw-btn{flex:none;white-space:nowrap}
.db-health{border-top:1px solid var(--line-2);padding-top:14px;margin-bottom:14px}
.db-health-head{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.db-health-head svg{color:var(--acc);fill:none;stroke:currentColor}
.db-health-head b{font-size:13px}
.db-health-head small{color:var(--text-3);font-size:11.5px}
.db-health-actions{display:flex;gap:8px;flex-wrap:wrap}
.db-conn-foot{display:flex;gap:8px;align-items:flex-start;font-size:11.5px;color:var(--text-3);line-height:1.5}
.db-conn-foot svg{color:var(--acc);flex:none;margin-top:1px;fill:none;stroke:currentColor}
.db-conn-foot code{font-family:var(--font-mono);background:var(--surface-2);padding:1px 5px;border-radius:var(--radius)}
.db-health-result{margin-top:10px;font-size:12.5px;line-height:1.55}
.db-health-result table{width:100%;border-collapse:collapse;background:var(--surface-2);border-radius:var(--radius);overflow:hidden;margin:6px 0}
.db-health-result th{text-align:left;padding:6px 10px;font-size:11px;color:var(--text-3);font-weight:600;text-transform:uppercase;letter-spacing:.04em;background:var(--surface)}
.db-health-result td{padding:6px 10px;font-size:12px;border-top:1px solid var(--line-2)}
.db-health-result .pill-ok{background:color-mix(in srgb,var(--ok) 12%,transparent);color:var(--ok);padding:1px 8px;border-radius:var(--radius);font-size:11px;font-weight:600}
.db-health-result .pill-warn{background:color-mix(in srgb,var(--warn) 12%,transparent);color:var(--warn);padding:1px 8px;border-radius:var(--radius);font-size:11px;font-weight:600}
.db-health-result .pill-err{background:color-mix(in srgb,var(--err) 12%,transparent);color:var(--err);padding:1px 8px;border-radius:var(--radius);font-size:11px;font-weight:600}

/* Zugang: info-grid-Wert mit Copy, SSH-Key/Sub-User-Empty */
.ig-val{display:flex;align-items:center;gap:7px;min-width:0;font-family:var(--font-mono);font-size:13px;color:var(--text);flex-wrap:wrap}
.ig-copy{width:24px;height:24px;border-radius:var(--radius);flex:none;background:none;border:0;cursor:pointer;color:var(--text-3);display:grid;place-items:center;padding:0}
.ig-copy:hover{color:var(--acc)}
.ig-copy svg{width:13px;height:13px;fill:none;stroke:currentColor}
.subuser-empty{text-align:center;padding:34px 20px;color:var(--text-3)}
.subuser-empty-icon{width:40px;height:40px;border-radius:var(--radius-lg);background:var(--surface-2);border:1px solid var(--line);display:grid;place-items:center;margin:0 auto 12px;color:var(--text-3)}
.subuser-empty-icon svg{width:20px;height:20px;fill:none;stroke:currentColor}
.subuser-empty b{display:block;font-size:14px;color:var(--text);font-weight:600}
.subuser-empty p{font-size:12.5px;margin-top:6px;line-height:1.55;max-width:480px;margin-left:auto;margin-right:auto}

/* Karten & Grids */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);margin-bottom:16px}
.card-h{padding:16px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
.card-h h2{font-size:14px;font-weight:600;letter-spacing:-.01em}
.card-h p{font-size:12.5px;color:var(--text-3);margin-top:3px;font-weight:400;line-height:1.5}
.card-h .right{display:flex;align-items:center;gap:9px}
.hint{font-family:var(--font-mono);font-size:11.5px;color:var(--text-3)}
.card-b{padding:18px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.kv{display:grid;grid-template-columns:1fr 1fr;gap:0}
.kv .row{padding:13px 0;border-bottom:1px solid var(--line-2);display:flex;flex-direction:column;gap:4px}
.kv .k{font-size:12px;color:var(--text-3)}
.kv .v{font-family:var(--font-mono);font-size:13px;color:var(--text)}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-weight:500;font-size:.78rem;padding:9px 15px;border-radius:var(--radius);border:1px solid var(--line);background:var(--surface);color:var(--text);cursor:pointer;text-decoration:none}
.btn:hover{border-color:var(--acc);color:var(--acc)}
.btn svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:1.9}
.btn-primary{background:var(--acc);border-color:var(--acc);color:var(--acc-ink)}
.btn-primary:hover{color:var(--acc-ink);filter:brightness(1.08)}
.btn-danger{color:var(--err);border-color:color-mix(in srgb,var(--err) 45%,transparent)}
.btn-danger:hover{color:var(--err);border-color:var(--err);background:color-mix(in srgb,var(--err) 12%,transparent)}
.btn-ghost{background:transparent;border-color:transparent;color:var(--text-2)}
.btn-ghost:hover{border-color:var(--acc-line);color:var(--text)}
.btn-row{display:flex;gap:10px;flex-wrap:wrap}
.btn-sm{padding:6px 11px;font-size:.72rem}
.btn-sm svg{width:13px;height:13px}
.btn-lg{padding:11px 18px;font-size:.84rem}
.btn-block{width:100%;justify-content:center}
.btn-soon{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border:1px dashed var(--line);border-radius:var(--radius);color:var(--text-3);background:transparent;font-size:.78rem;font-weight:500;cursor:not-allowed;user-select:none;line-height:1.4;font-family:var(--font-mono);vertical-align:middle}
.btn-soon-badge{background:var(--line-2);color:var(--text-3);font-size:9.5px;letter-spacing:.04em;padding:1px 7px;border-radius:var(--radius);font-weight:600;text-transform:uppercase}
.btn-sm.btn-soon{padding:5px 10px;font-size:.72rem;gap:5px;border-radius:var(--radius)}
.btn-action{background:var(--surface-2);color:var(--text-3);border-color:var(--line)}
.btn-action:hover{border-color:var(--acc);color:var(--acc)}
.btn-action.is-rolling svg{animation:dice-roll .4s ease-out}
@keyframes dice-roll{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}

/* E-Mail: Mail-Setup-Config, DNS-Records, Autoresponder, Archiv-Badge */
.mail-cfg{display:flex;flex-direction:column;gap:4px}
.mail-cfg-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 12px;font-size:12.5px}
.mail-cfg-row span:first-child{color:var(--text-3);flex:none}
.mail-cfg-val{display:flex;align-items:center;gap:6px;font-family:var(--font-mono);flex:1;min-width:0;justify-content:flex-end;text-align:right}
.mail-cfg-val b{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.mail-cfg-val small{flex:none}
.maildns-recs{display:flex;flex-direction:column;gap:8px;margin-top:12px}
.maildns-rec{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:8px 10px}
.maildns-rec-h{display:flex;align-items:center;gap:8px;margin-bottom:5px}
.maildns-rec-tag{font-size:10.5px;font-weight:700;letter-spacing:.03em;color:var(--acc);background:var(--acc-dim);padding:2px 7px;border-radius:var(--radius);flex:none}
.maildns-rec-host{font-size:11.5px;color:var(--text-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}
.maildns-rec-type{font-size:10.5px;color:var(--text-3);font-family:var(--font-mono);flex:none}
.maildns-rec .pwcopy{flex:none}
.maildns-rec-val{display:block;font-family:var(--font-mono);font-size:11.5px;color:var(--text);word-break:break-all;line-height:1.45}
.maildns-rec-note{display:block;font-size:11.5px;color:var(--text-3);font-style:italic;line-height:1.45}
.appicon{width:1em;height:1em;display:inline-block;vertical-align:-0.14em;flex:none}
.ar-toggle{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--text-2);cursor:pointer}
.ar-range{display:grid;grid-template-columns:1fr 1fr;gap:10px;background:var(--surface-2);padding:12px;border:1px solid var(--line);border-radius:var(--radius);margin:0}
.ar-range-item{display:flex;flex-direction:column;gap:4px}
.ar-range-item label{font-size:11.5px;color:var(--text-3)}
.mail-archive-badge{display:inline-flex;align-items:center;gap:5px;font-family:var(--font-mono);font-size:10.5px;padding:2px 7px;border-radius:var(--radius);border:1px solid var(--line);color:var(--text-3);margin-left:6px}
.mail-archive-badge svg{width:11px;height:11px;fill:none;stroke:currentColor}
.mail-archive-badge-active{color:var(--ok);border-color:color-mix(in srgb,var(--ok) 30%,transparent)}
.dnslist{display:flex;flex-direction:column}
.dnsrow{padding:14px 18px;border-top:1px solid var(--line-2)}
.dnsrow:first-child{border-top:0}
.dnsrow-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:4px}
.dnsrow-title{display:flex;align-items:center;gap:9px;min-width:0}
.dnsrow-title b{font-weight:600;font-size:14px;color:var(--text)}
.dnsrow-tag{display:inline-flex;align-items:center;justify-content:center;min-width:54px;padding:3px 9px;border-radius:var(--radius);background:var(--surface-2);color:var(--text-2);font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.04em}
.dnsrow-desc{font-size:12.5px;color:var(--text-3);line-height:1.5;margin-bottom:10px}
.dnsrow-codewrap{display:flex;flex-direction:column;gap:5px}
.dnsrow-codelabel{font-size:11px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.05em}
.dnsrow-code{display:flex;align-items:flex-start;gap:8px;padding:9px 11px;border-radius:var(--radius);border:1px solid var(--line-2);background:var(--surface-2)}
.dnsrow-code code{flex:1;min-width:0;font-family:var(--font-mono);font-size:12px;color:var(--text);word-break:break-all;line-height:1.5;background:transparent;padding:0;max-height:140px;overflow-y:auto}
.dnsrow-code .pwcopy{margin-top:1px;width:28px;height:28px;border-radius:var(--radius)}
.dnsrow-code .pwcopy svg{width:13px;height:13px}
.dnsrow-code.is-active{border-color:color-mix(in srgb,var(--ok) 45%,transparent);background:color-mix(in srgb,var(--ok) 12%,transparent)}
.dnsrow-code.is-todo{border-color:var(--acc-line);background:var(--acc-dim)}
.dnsrow-code.is-todo code{color:var(--acc-2)}
.dnsrow-mxsplit{display:flex;gap:8px;align-items:flex-end;flex-wrap:wrap}
.dnsrow-mxfield{display:flex;flex-direction:column;gap:3px;min-width:0}
.dnsrow-mxfield:first-child{flex:0 0 auto}
.dnsrow-mxfield:last-child{flex:1 1 200px;min-width:0}
.dnsrow-mxkey{font-size:10.5px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.04em;padding-left:2px}
.dnsrow-code-mxprio{min-width:0}
.dnsrow-code-mxprio code{flex:0 0 auto;padding-right:4px}

/* Tabellen & Pills */
.tbl{width:100%;border-collapse:collapse;font-size:13.5px}
.tbl th{text-align:left;font-family:var(--font-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.03em;color:var(--text-3);font-weight:500;padding:10px 14px;border-bottom:1px solid var(--line)}
.tbl td{padding:13px 14px;border-bottom:1px solid var(--line-2);color:var(--text);vertical-align:middle}
.tbl tr:hover td{background:var(--surface-2)}
.tbl .mono{font-family:var(--font-mono);font-size:12.5px;color:var(--text-2)}
.pill{font-family:var(--font-mono);font-size:11px;padding:4px 9px;border-radius:var(--radius);display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);color:var(--text-2)}
.pill .d{width:6px;height:6px;border-radius:50%}
.pill:not(.ok):not(.warn):not(.acc):not(.err):not(.info) .d{display:none}
.pill.ok{color:var(--ok);border-color:color-mix(in srgb,var(--ok) 30%,transparent)}
.pill.ok .d{background:var(--ok)}
.pill.warn{color:var(--warn);border-color:color-mix(in srgb,var(--warn) 30%,transparent)}
.pill.warn .d{background:var(--warn)}
.pill.acc{color:var(--acc);border-color:var(--acc-line)}
.pill.acc .d{background:var(--acc)}
.pill.err{color:var(--err);border-color:color-mix(in srgb,var(--err) 45%,transparent)}
.pill.err .d{background:var(--err)}
.pill.info{color:var(--info);border-color:color-mix(in srgb,var(--info) 45%,transparent)}
.pill.info .d{background:var(--info)}
.state-off{font-family:var(--font-mono);font-size:12px;color:var(--text-3)}
.st{font-family:var(--font-mono);font-size:12px;display:inline-flex;align-items:center;gap:4px}
.st .d{width:6px;height:6px;border-radius:50%;background:currentColor;flex:none}
.st.ok,.st.on{color:var(--ok)}
.st.run{color:var(--warn)}
.st.err,.st.susp{color:var(--err)}
.st.idle{color:var(--text-3)}
/* Tickets-Listing: SLA-Breach als Inline-Warn-Indicator */
.tkt-sla-warn{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;background:color-mix(in srgb,var(--err) 12%,transparent);color:var(--err);border-radius:50%;border:1px solid color-mix(in srgb,var(--err) 40%,transparent)}
details.adv-card>summary{cursor:pointer;list-style:none}
details.adv-card>summary::-webkit-details-marker{display:none}
details.adv-card>summary::after{content:"";width:8px;height:8px;border-right:2px solid var(--text-3);border-bottom:2px solid var(--text-3);transform:rotate(45deg);transition:transform .15s;flex:none;margin-left:8px}
details.adv-card[open]>summary::after{transform:rotate(-135deg)}
details.adv-card>summary h2{flex:1}

/* Ticket-Maßnahmen: Kunden-Dropdown im Ticket-Detail
   (portiert aus suite2-4 app.css .tk-menu-wrap/.tk-menu/.qa-select, tokenisiert) */
.qa-select{background:var(--surface);border:1px solid var(--line-2);border-radius:var(--radius-lg);color:var(--text);font-family:var(--font-mono);font-size:12.5px;padding:6px 9px;cursor:pointer;display:inline-flex;align-items:center;gap:5px}
.qa-select:hover,.qa-select[aria-expanded="true"]{border-color:var(--acc-line);color:var(--acc)}
.tk-menu-wrap{position:relative;margin-left:auto}
.tk-menu{position:absolute;top:115%;right:0;min-width:13rem;background:var(--surface);border:1px solid var(--line-2);border-radius:var(--radius-lg);box-shadow:0 14px 34px -14px rgba(0,0,0,.5);padding:5px;display:none;z-index:25}
.tk-menu.open{display:block}
.tk-menu a,.tk-menu button{display:flex;align-items:center;gap:8px;width:100%;text-align:left;background:none;border:0;color:var(--text-2);font-family:var(--font-sans);font-size:13px;padding:8px 10px;border-radius:var(--radius);cursor:pointer;text-decoration:none}
.tk-menu a:hover,.tk-menu button:hover{background:var(--surface-2);color:var(--text)}
.tk-menu a svg,.tk-menu button svg{color:var(--text-3);flex:none}

/* Domains: Aktions-Dropdown (details/summary) */
.dom-actions{position:relative;display:inline-block}
.dom-actions-summary{list-style:none;cursor:pointer;font-family:var(--font-mono);font-size:12px;color:var(--text-2);display:inline-flex;align-items:center;gap:4px;padding:5px 9px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface)}
.dom-actions-summary:hover{border-color:var(--acc);color:var(--acc)}
.dom-actions-summary::-webkit-details-marker{display:none}
.dom-actions[open] .dom-actions-summary{border-color:var(--acc);color:var(--acc)}
/* position:fixed → entkommt dem overflow-Clip des .u-scroll-x-Wrappers; top/left setzt app.js */
.dom-actions-menu{position:fixed;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:8px;width:320px;max-width:92vw;z-index:1000;box-shadow:0 14px 34px -14px rgba(0,0,0,.5);text-align:left}
.dom-actions-section{padding:8px 6px}
.dom-actions-label{font-size:12.5px;font-weight:500;margin-bottom:6px;display:flex;align-items:center;gap:6px;color:var(--text)}
.dom-actions-select{width:100%;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius);padding:7px 10px;font-size:13px;color:var(--text);margin-bottom:6px;font-family:var(--font-sans)}
.dom-actions-btn{display:flex;width:100%;box-sizing:border-box;justify-content:center}
.dom-actions-remove{width:100%;background:none;border:0;cursor:pointer;text-align:left;display:flex;align-items:center;gap:6px;color:var(--err);font-size:12.5px;padding:4px 0}
/* Mail-Partial-Bibliothek (U1): Menü-Einträge im Postfach-Aktionen-Dropdown (Button + Link einheitlich) */
.dom-actions-item{display:flex;align-items:center;gap:7px;width:100%;box-sizing:border-box;background:none;border:0;cursor:pointer;font-family:var(--font-sans);font-size:12.5px;font-weight:500;color:var(--text);padding:7px 8px;border-radius:var(--radius);text-align:left;text-decoration:none}
.dom-actions-item:hover{background:var(--surface-2);color:var(--acc)}
.dom-actions-item.danger{color:var(--err)}
.dom-actions-item.danger:hover{background:var(--surface-2);color:var(--err)}
.dom-actions-item svg{width:13px;height:13px;flex:none}
.dom-actions-item .pill{margin-left:auto}
.dom-actions-sep{border-top:1px solid var(--line-2);margin:2px 6px}
.dom-actions-menu form{margin:0}
/* Domain-Anker der Mail-Zentrale: Deep-Link #domain-<slug> nicht unter der Topbar verstecken */
.mail-domain-card{scroll-margin-top:84px}

/* Domains: Verzeichnis-Browser */
.fb-wrap{max-width:100%}
.fbrowser{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--surface-2)}
.fb-bar{display:flex;align-items:center;gap:8px;padding:8px 10px;border-bottom:1px solid var(--line);background:var(--surface)}
.fb-up{background:none;border:1px solid var(--line);border-radius:var(--radius);padding:4px;cursor:pointer;color:var(--text-2);display:grid;place-items:center}
.fb-up:disabled{opacity:.4;cursor:default}
.fb-crumb{font-family:var(--font-mono);font-size:12px;color:var(--text-2)}
.fb-list{max-height:210px;overflow-y:auto;padding:6px}
.fb-item{display:flex;align-items:center;gap:8px;width:100%;background:none;border:0;cursor:pointer;text-align:left;padding:8px 10px;border-radius:var(--radius);color:var(--text);font-size:13px;font-family:var(--font-mono)}
.fb-item:hover{background:var(--surface)}
.fb-ico{color:var(--acc);display:grid;place-items:center}
.fb-empty{padding:14px;font-size:12.5px;color:var(--text-3);text-align:center}
.fb-selected{margin-top:8px;font-size:12.5px;color:var(--text-2)}
.fb-selected code{font-family:var(--font-mono);color:var(--acc)}
.fb-manual{margin-top:8px;font-size:12.5px;color:var(--text-2)}
.fb-manual summary{cursor:pointer}
.fb-manual .inp{margin-top:6px}
.dhelp-ic{width:40px;height:40px;border-radius:var(--radius-lg);background:var(--acc-dim);color:var(--acc);display:grid;place-items:center;flex:none}
.dhelp-ic svg{width:20px;height:20px}

/* Pakete / Preis-Karten */
.pkg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:8px}
.pkg-card{position:relative;border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);padding:22px 20px;display:flex;flex-direction:column}
.pkg-card.is-popular{border-color:var(--acc)}
.pkg-card.is-current{border-color:var(--ok)}
.pkg-badge-pop{position:absolute;top:-10px;left:20px;background:var(--acc);color:var(--acc-ink);font-family:var(--font-mono);font-size:11px;padding:3px 10px;border-radius:var(--radius)}
.pkg-head h3{font-size:18px;font-weight:600;letter-spacing:-.02em}
.pkg-sub{font-size:12.5px;color:var(--text-3);margin-top:2px}
.pkg-price{margin:16px 0 4px}
.pkg-price-num{font-size:30px;font-weight:600;letter-spacing:-.02em}
.pkg-price-unit{display:block;font-size:11.5px;color:var(--text-3);margin-top:2px}
.pkg-recommend{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--text-2);padding:10px 0;border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2);margin:14px 0}
.pkg-recommend svg{width:16px;height:16px;flex:none;stroke:var(--acc)}
.pkg-features{list-style:none;display:flex;flex-direction:column;gap:9px;margin:4px 0 18px;flex:1}
.pkg-features li{display:flex;align-items:flex-start;gap:9px;font-size:13px}
.pkg-features svg{width:16px;height:16px;flex:none;margin-top:1px}
.pkg-btn{width:100%;justify-content:center}

/* Neuer-Stack-Wizard */
.creator{max-width:1180px;margin:0 auto;padding:30px 22px 80px}
.creator h1{font-size:27px;font-weight:600;letter-spacing:-.025em;margin-top:6px}
.step{display:flex;align-items:center;gap:10px;margin:24px 0 6px}
.step .n{width:24px;height:24px;border-radius:var(--radius);background:var(--acc-dim);color:var(--acc);display:grid;place-items:center;font-family:var(--font-mono);font-weight:600;font-size:12px;flex:none}
.step h3{font-size:15px;font-weight:600}
.choices{display:grid;gap:12px;margin-bottom:8px}
.choice{display:flex;align-items:center;gap:12px;padding:14px 16px;border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);cursor:pointer;transition:.15s}
.choice:hover{border-color:var(--acc)}
.choice.sel{border-color:var(--acc);background:var(--acc-dim)}
.choice .ic{width:42px;height:42px;border-radius:var(--radius);background:var(--surface-2);border:1px solid var(--line);display:grid;place-items:center;color:var(--text);flex:none}
.choice.sel .ic{color:var(--acc);border-color:var(--acc)}
.choice .ic svg{width:24px;height:24px}
.choice b{font-size:14px;font-weight:600}
.choice p{font-size:12px;color:var(--text-3);margin-top:1px}
.tpls{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin-bottom:8px}
.tpl{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);overflow:hidden;cursor:pointer;transition:.15s}
.tpl:hover{border-color:var(--acc)}
.tpl.sel{border-color:var(--acc)}
.tpl .thumb{height:64px;display:grid;place-items:center;background:var(--surface-2);border-bottom:1px solid var(--line)}
.tpl .meta{padding:10px 12px}
.tpl .meta b{font-size:13px;font-weight:600;display:block}
.tpl .meta span{font-size:11.5px;color:var(--text-3)}
.tpl.sel .meta b{color:var(--acc)}
/* App-Icons in Install-/Wizard-Karten (Marken-Logos als SVG).
   Marken-Akzentfarben bewusst als Hex (Markenfarben, keine Statusfarben).
   Spezifität .ic.ic-app(.ic-*) + Source-Order ersetzt die alten !important. */
.ic.ic-app{display:grid;place-items:center;background:var(--acc-dim);color:var(--acc);border-radius:var(--radius);overflow:hidden}
.ic.ic-app svg{width:74%;height:74%;display:block;object-fit:contain}
.ic.ic-app .ic-text{font-family:var(--font-display);font-weight:800;font-size:15px;letter-spacing:-.5px;line-height:1}
.ic.ic-app.ic-typo3{color:#FF8700;background:#3A2A18}
.ic.ic-app.ic-wordpress{color:#5AA0C4;background:#1A2A33}
.ic.ic-app.ic-git{color:#FF7459;background:#3A1E18}
.ic.ic-app.ic-nextcloud{color:#3DA8DC;background:#0F2333}
.ic.ic-app.ic-laravel{color:#FF5D54;background:#2E1614}
html[data-theme="light"] .ic.ic-app.ic-typo3{color:#FF8700;background:#FFF1E0}
html[data-theme="light"] .ic.ic-app.ic-wordpress{color:#21759B;background:#E5EEF3}
html[data-theme="light"] .ic.ic-app.ic-git{color:#F05133;background:#FDE9E4}
html[data-theme="light"] .ic.ic-app.ic-nextcloud{color:#0082C9;background:#E1F0F8}
html[data-theme="light"] .ic.ic-app.ic-laravel{color:#FF2D20;background:#FCE6E3}
.dhelp{margin:4px 0 16px}
.dhelp-label{font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);margin-bottom:8px}
.dhelp-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}
.dhelp-card{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);padding:14px 16px}
.dhelp-card-head{display:flex;gap:11px;align-items:flex-start}
.dhelp-card-title{font-size:13.5px;font-weight:600;display:block}
.dhelp-card-desc{font-size:12px;color:var(--text-3);margin-top:2px;line-height:1.45}
.dhelp-card-actions{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.dhelp-chip{font-family:var(--font-mono);font-size:12px;border:1px solid var(--line);background:var(--surface-2);color:var(--text-2);border-radius:var(--radius);padding:5px 10px;cursor:pointer}
.dhelp-chip:hover{border-color:var(--acc);color:var(--acc)}
.dhelp-chip-strong{border-color:var(--acc);color:var(--acc)}
.createbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:18px}
.createbar-toggle{margin-right:auto}
.createbar.is-live{border-top-color:color-mix(in srgb,var(--err) 45%,transparent)}
.createbar.is-live .install-modeswitch-label{color:var(--err);font-weight:600}
.createbar.is-live .btn-primary{background:var(--err);border-color:var(--err)}
.install-modeswitch{display:flex;align-items:center;gap:9px;cursor:pointer;font-size:12.5px;color:var(--text-2)}
.install-modeswitch input{display:none}
.install-modeswitch-track{width:38px;height:22px;border-radius:22px;background:var(--line);position:relative;transition:.2s;flex:none}
.install-modeswitch-thumb{position:absolute;width:16px;height:16px;border-radius:50%;background:#fff;top:3px;left:3px;transition:.2s}
.install-modeswitch input:checked + .install-modeswitch-track{background:var(--acc)}
.install-modeswitch input:checked + .install-modeswitch-track .install-modeswitch-thumb{transform:translateX(16px)}
.install-modeswitch-label{font-size:13px;color:var(--text-2);line-height:1.4}
.tip{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius-lg);padding:14px 16px;font-size:12.5px;color:var(--text-2);line-height:1.55}
.qa-soon-badge{background:var(--acc-dim);color:var(--acc);font-size:9.5px;padding:1px 6px;border-radius:var(--radius);text-transform:uppercase;font-weight:700;letter-spacing:.3px}

/* Formulare */
.field{margin-bottom:16px}
.field label{display:block;font-size:12.5px;color:var(--text-2);margin-bottom:7px}
.inp{width:100%;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius);padding:10px 13px;font-family:var(--font-sans);font-size:14px;color:var(--text)}
.inp:focus{outline:none;border-color:var(--acc)}
select.inp,textarea.inp{font-family:var(--font-sans)}
/* Custom-Look für ALLE Selects (Sven 2026-06-11: native OS-Dropdowns brachen das
   Precision-Design). appearance:none entfernt den nativen Pfeil; eigener Chevron als
   SVG-Background (neutrales Grau, liest auf hell+dunkel). Das GESCHLOSSENE Control ist
   damit voll im Design; die geöffnete Optionsliste rendert das OS (cross-browser nicht
   stylebar — wie bei Stripe/Linear/GitHub). Chevron-Farbe wird im Dark-Block nachgezogen. */
select{appearance:none;-webkit-appearance:none;-moz-appearance:none;cursor:pointer}
select::-ms-expand{display:none}
select:hover{border-color:var(--line-2)}
/* Chevron + Padding an der HÖHER-spezifischen select.<klasse>-Regel, damit sie das
   `background`-Shorthand von .inp (setzt background-image:none) gewinnt. */
select.inp,select.dom-actions-select,select.fm-edsel{
  padding-right:34px;background-repeat:no-repeat;background-position:right 11px center;background-size:16px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%238c95a0' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")}
/* Feld mit eingelassenem Aktions-Button (z. B. Passwort-Würfel im Register-Form).
   Positionierung hier gescoped, weil .btn-action global der Skin-2-Button-Modifier ist. */
.field.has-action{position:relative}
.field.has-action .inp{padding-right:42px}
.field.has-action .btn-action{position:absolute;right:6px;bottom:6px;width:30px;height:30px;padding:0;border:1px solid var(--line);border-radius:50%;background:var(--surface-2);color:var(--text-3);display:grid;place-items:center;cursor:pointer;transition:border-color .15s,color .15s}
.field.has-action .btn-action:hover{border-color:var(--acc);color:var(--acc)}
.field.has-action .btn-action svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2}
.pwcopy{background:none;border:0;cursor:pointer;color:var(--text-3);display:grid;place-items:center;padding:4px}
.pwcopy:hover{color:var(--acc)}
.pwcopy.copied{color:var(--ok)}
.pwcopy svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:1.8}
.ta{width:100%;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius);padding:10px 13px;font-family:var(--font-sans);font-size:14px;color:var(--text);min-height:90px;resize:vertical}
.ta:focus{outline:none;border-color:var(--acc)}
.note{display:flex;gap:12px;padding:14px 16px;border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface-2);font-size:13px;color:var(--text-2);line-height:1.55;margin-bottom:16px}
.note svg{width:18px;height:18px;flex:none;margin-top:1px;fill:none;stroke:var(--acc);stroke-width:1.9}
.note.acc{border-color:var(--acc-line)}
.note b{color:var(--text)}
.frow{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:14px 18px;border-top:1px solid var(--line-2)}
.frow:first-of-type{border-top:0}
.frow .fl{display:flex;flex-direction:column;gap:2px;min-width:0}
.frow .fl b{font-size:13.5px;font-weight:600}
.frow .fl span{font-size:12px;color:var(--text-3)}
.frow .inp,.frow select.inp{width:auto;flex:0 1 300px;min-width:0}
.frow .btn{flex:none}
.switch{position:relative;display:inline-block;width:42px;height:24px;flex:none}
.switch input{opacity:0;width:0;height:0;position:absolute}
.switch .slider{position:absolute;inset:0;background:var(--line);border-radius:24px;transition:.2s;cursor:pointer}
.switch .slider::before{content:"";position:absolute;width:18px;height:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s}
.switch input:checked + .slider{background:var(--acc)}
.switch input:checked + .slider::before{transform:translateX(18px)}
/* QO7-Checkbox: native Checkbox durch design-konformes Quadrat ersetzt
   (Häkchen als ::before-Winkel in var(--acc-ink) — funktioniert in beiden Themes;
   Fokus-Ring kommt vom globalen :focus-visible in Abschnitt 3). */
input[type="checkbox"]:not(.switch input):not(.install-modeswitch input){appearance:none;-webkit-appearance:none;width:16px;height:16px;flex:none;border:1px solid var(--line-2);border-radius:var(--radius);background:var(--surface-2);cursor:pointer;display:inline-grid;place-content:center;vertical-align:middle;margin:0;transition:background .12s,border-color .12s}
input[type="checkbox"]:not(.switch input):not(.install-modeswitch input):hover{border-color:var(--acc)}
input[type="checkbox"]:not(.switch input):not(.install-modeswitch input):checked{background:var(--acc);border-color:var(--acc)}
input[type="checkbox"]:not(.switch input):not(.install-modeswitch input):checked::before{content:"";width:9px;height:5px;border-left:2px solid var(--acc-ink);border-bottom:2px solid var(--acc-ink);transform:rotate(-45deg) translate(1px,-1px)}
input[type="checkbox"]:not(.switch input):not(.install-modeswitch input):disabled{opacity:.55;cursor:not-allowed}
/* Radios im selben Skin wie Checkboxen (2026-06-13: waren nativ-blau → Bruch
   neben orangenen Checkboxen, „Neuer Kunde"-Formular). Rund + Akzent-Punkt. */
input[type="radio"]{appearance:none;-webkit-appearance:none;width:16px;height:16px;flex:none;border:1px solid var(--line-2);border-radius:50%;background:var(--surface-2);cursor:pointer;display:inline-grid;place-content:center;vertical-align:middle;margin:0;transition:background .12s,border-color .12s}
input[type="radio"]:hover{border-color:var(--acc)}
input[type="radio"]:checked{border-color:var(--acc)}
input[type="radio"]:checked::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--acc)}
input[type="radio"]:disabled{opacity:.55;cursor:not-allowed}
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 20px;padding:4px 18px 10px;background:none;border-radius:0}
.info-grid .ig{padding:11px 0;border-top:1px solid var(--line-2);display:flex;flex-direction:column;gap:3px;background:none}
.info-grid .ig span{font-size:12px;color:var(--text-3)}
.info-grid .ig b{font-family:var(--font-mono);font-size:13px}
.rowact{font-family:var(--font-mono);font-size:12px;color:var(--acc);text-decoration:none;flex:none;display:inline-flex;align-items:center;gap:5px}
.rowact:hover{text-decoration:underline}
.inp-date{font-family:var(--font-sans);font-size:13.5px;padding:7px 10px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);color:var(--text);min-width:140px;line-height:1.3;transition:border-color .15s;cursor:pointer}
.inp-date:hover{border-color:var(--acc)}
.inp-date:focus{outline:none;border-color:var(--acc)}
.inp-date::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.7;padding:2px;transition:opacity .15s}
.inp-date:hover::-webkit-calendar-picker-indicator{opacity:1}

/* Hilfe: Artikel, Empty, Bewertung, Suche, QA-Liste */
.article-body{font-size:14.5px;line-height:1.7;color:var(--text-2)}
.article-body h2{font-size:20px;font-weight:600;color:var(--text);margin:22px 0 8px;letter-spacing:-.01em}
.article-body h3{font-size:16px;font-weight:600;color:var(--text);margin:18px 0 6px}
.article-body h4{font-size:14px;font-weight:600;color:var(--text);margin:14px 0 5px}
.article-body p{margin:0 0 12px}
.article-body ul,.article-body ol{margin:0 0 12px 22px}
.article-body li{margin-bottom:5px}
.article-body a{color:var(--acc);text-decoration:underline}
.article-body blockquote{border-left:3px solid var(--acc);padding:4px 0 4px 14px;margin:0 0 12px;color:var(--text-2)}
.article-body code{font-family:var(--font-mono);font-size:.9em;background:var(--surface-2);padding:1px 5px;border-radius:var(--radius)}
.article-body pre{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius);padding:12px 14px;overflow:auto;font-family:var(--font-mono);font-size:12.5px;margin:0 0 12px}
.article-body hr{border:0;border-top:1px solid var(--line);margin:18px 0}
.empty{text-align:center;padding:50px 20px;color:var(--text-3)}
.empty > svg{width:34px;height:34px;fill:none;stroke:var(--text-3);stroke-width:1.5;margin-bottom:12px}
.rate{display:inline-flex;gap:6px}
.rate svg{width:30px;height:30px;fill:none;stroke:var(--text-3);stroke-width:1.6;cursor:pointer;transition:.12s}
.rate svg:hover,.rate svg.on{stroke:var(--acc);fill:var(--acc)}
.bigsearch{display:flex;align-items:center;gap:10px;padding:12px 15px;border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface-2);margin-bottom:18px;font-family:var(--font-mono)}
.bigsearch:focus-within{border-color:var(--acc)}
.bigsearch .bs-prompt{flex:none;font-size:13px;color:var(--text-3);white-space:nowrap;user-select:none}
.bigsearch .bs-prompt b{color:var(--text-2);font-weight:400}
.bigsearch .bs-prompt .sign{color:var(--acc);font-weight:700}
.bigsearch svg{width:16px;height:16px;fill:none;stroke:var(--text-3);stroke-width:2;flex:none}
.bigsearch input{flex:1;border:0;background:none;color:var(--text);font-family:var(--font-mono);font-size:13.5px;outline:none;caret-color:var(--acc)}
.bigsearch input::placeholder{color:var(--text-3)}
.qa{display:flex;flex-direction:column}
.qa a{display:flex;align-items:center;gap:11px;padding:13px 18px;border-top:1px solid var(--line-2);color:var(--text);text-decoration:none;font-size:13.5px}
.qa a:first-child{border-top:0}
.qa a:hover{background:var(--surface-2)}
.qa .qi{width:30px;height:30px;border-radius:var(--radius);background:var(--surface-2);display:grid;place-items:center;color:var(--acc);flex:none}
.qa .qi svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.9}
.qa .arr{margin-left:auto;color:var(--text-3)}
.qa .arr svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2}

/* Admin: KPI-Karten, Hilfe-Center, Ressourcen-Balken, Plan-Quick */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:18px}
.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:18px}
.kpi .ic{width:36px;height:36px;border-radius:var(--radius-lg);display:grid;place-items:center;margin-bottom:12px;background:var(--acc-dim);color:var(--acc)}
.kpi .ic svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2}
.kpi h3{font-family:var(--font-display);font-weight:600;font-size:26px;letter-spacing:-1px;line-height:1;color:var(--text)}
.kpi .l{color:var(--text-2);font-size:13px;margin-top:5px}
.arow2{display:grid;grid-template-columns:1.5fr 1fr;gap:16px}
.hc-cat{margin-bottom:16px}
.hc-cat .card-h .cnt{font-family:var(--font-mono);font-size:11px;color:var(--text-3);text-transform:none;letter-spacing:0}
.hc-art{display:flex;align-items:center;gap:14px;padding:13px 18px;border-top:1px solid var(--line-2)}
.hc-art:first-of-type{border-top:0}
.hc-art .hc-t{flex:1;min-width:0}
.hc-art .hc-t b{font-weight:600;font-size:14px;color:var(--text);display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hc-art .hc-slug{font-family:var(--font-mono);font-size:11.5px;color:var(--text-3);margin-top:2px}
.hc-art .hc-sort{font-family:var(--font-mono);font-size:11.5px;color:var(--text-3);flex:none}
.hc-art .hc-actions{display:flex;gap:6px;align-items:center;white-space:nowrap;flex:none}
.resbar{display:grid;grid-template-columns:80px 1fr 100px 180px;gap:14px;align-items:center;font-size:13px}
.resbar-label{font-weight:600;color:var(--text-2)}
.resbar-track{height:8px;border-radius:20px;background:var(--line-2);overflow:hidden}
.resbar-track i{display:block;height:100%;border-radius:20px;transition:width .3s}
.resbar-val{text-align:right;color:var(--text);font-weight:600}
.resbar-sub{font-size:12px;color:var(--text-3)}
.plan-quick{position:relative;display:inline-block;vertical-align:middle}
.plan-quick > summary{list-style:none;cursor:pointer}
.plan-quick > summary::-webkit-details-marker{display:none}
.plan-quick-menu{position:absolute;right:0;top:calc(100% + 4px);z-index:50;min-width:240px;padding:10px 12px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:0 14px 34px -14px rgba(0,0,0,.5)}
.plan-quick[open] > summary{background:var(--acc-dim);color:var(--acc);border-color:var(--acc)}

/* Utilities */
.u-ink{color:var(--text)}
.u-ink3{color:var(--text-3)}
.u-accent{color:var(--acc)}
.u-link{color:var(--text-2);text-decoration:none}
.u-scroll-x{overflow-x:auto}
.u-mt-12{margin-top:12px}
.u-mt-16{margin-top:16px}
.u-fs-16{font-size:16px}
.u-fw-500{font-weight:500}
.u-fw-600{font-weight:600}
.u-row{display:flex;align-items:center;gap:9px;padding:6px 0;font-size:14px}
.u-row-end{padding:0 18px 18px;display:flex;justify-content:flex-end}
.u-foot-row{max-width:1120px;margin:0 auto;padding:20px 28px;display:flex;flex-wrap:wrap;gap:16px;align-items:center;font-size:13px;color:var(--text-3)}
.u-hand-r{margin-left:auto;font-family:var(--font-display);font-size:15px;color:var(--acc)}
.u-sep-top{border-top:1px solid var(--line);margin-top:40px}
.u-meta{font-size:13px;color:var(--text-3)}
.u-full-c{width:100%;justify-content:center}

/* Stack-Overview: 2-Spalten-Layout, Systemcheck-Ring, Warn-Items */
.ovgrid{display:grid;grid-template-columns:320px 1fr;gap:16px}
.ovcol{display:flex;flex-direction:column;gap:16px;min-width:0}
.ring-card{padding:24px 18px 20px;text-align:center;position:relative}
.ring{width:140px;height:140px;margin:4px auto 14px;position:relative}
.ring svg{transform:rotate(-90deg)}
.ring .val{position:absolute;inset:0;display:grid;place-items:center}
.ring .val b{font-family:var(--font-display);font-weight:600;font-size:28px;letter-spacing:-1px;line-height:1;color:var(--text)}
.ring .val span{font-size:11px;color:var(--text-3);display:block;margin-top:3px}
.ring-note{font-family:var(--font-display);font-size:18px;color:var(--acc-2);font-weight:600}
.ring-doodle{position:absolute;top:18px;right:30px;width:20px;height:20px;color:var(--acc);opacity:.7;transform:rotate(12deg)}
.warn-item{display:flex;gap:12px;padding:14px 18px;border-top:1px solid var(--line-2);align-items:flex-start}
.warn-item:first-of-type{border-top:0}
.warn-item .wi{width:30px;height:30px;border-radius:var(--radius);background:color-mix(in srgb,var(--warn) 12%,transparent);color:var(--warn);display:grid;place-items:center;flex:none}
.warn-item .wi svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2}
.warn-item .wt b{font-weight:600;font-size:14px;color:var(--text)}
.warn-item .wt p{font-size:13px;color:var(--text-2);margin-top:1px}
.warn-item .fix{margin-left:auto;font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;text-decoration:none;align-self:center}
.warn-item .fix:hover{color:var(--acc)}
.warn-item.ok .wi{background:color-mix(in srgb,var(--ok) 12%,transparent);color:var(--ok)}

/* Welcome-Card (einmalige Backend-Credentials) */
.welcome-card{margin:0 0 22px;padding:20px 24px;background:var(--acc-dim);border:1px solid var(--acc-line);border-radius:var(--radius-lg)}
.welcome-head{display:flex;align-items:flex-start;gap:14px;margin-bottom:16px}
.welcome-head h2{font-family:var(--font-sans);font-size:18px;font-weight:700;margin:0 0 4px;color:var(--text)}
.welcome-head p{margin:0;font-size:13px;color:var(--text-2);line-height:1.5}
.welcome-icon{flex:none;width:36px;height:36px;border-radius:50%;background:var(--acc);color:var(--acc-ink);display:flex;align-items:center;justify-content:center}
.welcome-icon svg{width:18px;height:18px;fill:none;stroke:currentColor}
.welcome-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 16px;max-width:780px}
.welcome-row{display:flex;align-items:center;gap:12px;padding:8px 12px;background:var(--surface);border-radius:var(--radius);border:1px solid var(--line)}
.welcome-row-pw{grid-column:1/-1;background:color-mix(in srgb,var(--warn) 12%,transparent);border-color:color-mix(in srgb,var(--warn) 40%,transparent)}
.welcome-label{flex:none;min-width:90px;font-size:11.5px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.04em}
.welcome-value{flex:1;display:flex;align-items:center;gap:8px;min-width:0}
.welcome-value code,.welcome-value a{font-family:var(--font-mono);font-size:13px;color:var(--text);background:none;padding:0;border:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}
.welcome-value a{text-decoration:none;color:var(--acc)}
.welcome-value a:hover{text-decoration:underline}
.welcome-copy{flex:none;background:none;border:0;padding:4px 6px;cursor:pointer;color:var(--text-3);border-radius:var(--radius);transition:color .12s,background .12s}
.welcome-copy svg{fill:none;stroke:currentColor}
.welcome-copy:hover{color:var(--acc);background:var(--acc-dim)}
.welcome-foot{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-top:14px;padding-top:14px;border-top:1px solid color-mix(in srgb,var(--acc) 20%,transparent)}
.welcome-foot small{font-size:12px;color:var(--text-2);line-height:1.5}

/* Install-Erfolg (Dry-Run-OK) */
.install-success-body{padding:32px 28px 24px;text-align:center;max-width:520px;margin:0 auto}
.install-success-icon{width:64px;height:64px;border-radius:50%;background:color-mix(in srgb,var(--ok) 12%,transparent);color:var(--ok);display:grid;place-items:center;margin:0 auto 18px}
.install-success-icon svg{width:32px;height:32px;fill:none;stroke:currentColor;stroke-width:2.4}
.install-success-body h3{font-family:var(--font-sans);font-weight:700;font-size:20px;color:var(--text);margin-bottom:10px;letter-spacing:-.2px}
.install-success-body p{font-size:14px;color:var(--text-2);line-height:1.6;margin-bottom:8px}
.install-success-body .install-success-meta{color:var(--text-3);font-size:13px;margin-top:14px;font-style:italic}
.install-success-actions{padding:14px 20px;border-top:1px solid var(--line-2);display:flex;gap:10px;flex-wrap:wrap;align-items:center;justify-content:center;background:var(--surface-2)}
.install-success-hint{font-size:12.5px;color:var(--text-3)}

/* Install-Progress (Live-Polling) */
.install-progress{overflow:hidden}
.install-progress-body{display:flex;align-items:flex-start;gap:18px;padding:24px}
.install-progress-icon{flex:none;width:54px;height:54px;border-radius:var(--radius-lg);background:var(--acc-dim);color:var(--acc);display:grid;place-items:center}
.install-progress-icon svg{width:26px;height:26px;fill:none;stroke:currentColor;stroke-width:2}
.install-progress-body b{font-family:var(--font-sans);font-weight:700;font-size:16px;color:var(--text);display:inline-flex;align-items:center;gap:6px}
.install-progress-body p{font-size:13.5px;color:var(--text-2);margin:4px 0 8px;line-height:1.55}
.install-progress-body small{font-size:12px;color:var(--text-3);font-variant-numeric:tabular-nums}
.install-progress-fail .install-progress-icon{background:color-mix(in srgb,var(--err) 12%,transparent);color:var(--err)}
.install-spinner{width:26px;height:26px;border:3px solid var(--acc-dim);border-top-color:var(--acc);border-radius:50%;animation:spin .9s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.install-progress-dots{display:inline-flex;gap:2px;margin-left:1px}
.install-progress-dots span{width:4px;height:4px;border-radius:50%;background:var(--text-3);animation:dots 1.4s ease-in-out infinite}
.install-progress-dots span:nth-child(2){animation-delay:.2s}
.install-progress-dots span:nth-child(3){animation-delay:.4s}
@keyframes dots{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-2px)}}

/* 7-Schritte-Provisioning-Liste */
.prov-steps{list-style:none;margin:0;padding:14px 20px;border-top:1px solid var(--line-2);display:flex;flex-direction:column;gap:6px}
.prov-step{display:flex;align-items:center;gap:11px;padding:7px 10px;border-radius:var(--radius);font-size:13px;color:var(--text-3);transition:background .15s,color .15s}
.prov-step-icon{flex:none;width:22px;height:22px;display:grid;place-items:center;position:relative;border:1.5px solid var(--line);border-radius:50%;background:var(--surface-2);transition:border-color .15s,background .15s}
.prov-step-icon > *{position:absolute;inset:0;display:grid;place-items:center}
.prov-step-check{width:12px;height:12px;color:var(--acc-ink);opacity:0;transform:scale(.6);transition:opacity .15s,transform .15s;fill:none;stroke:currentColor}
.prov-step-spinner{width:13px;height:13px;border:2px solid color-mix(in srgb,var(--acc) 30%,transparent);border-top-color:var(--acc);border-radius:50%;animation:spin .9s linear infinite;opacity:0}
.prov-step-dot{width:6px;height:6px;border-radius:50%;background:var(--text-3);opacity:1;transition:opacity .15s}
.prov-step.is-complete{color:var(--text-2)}
.prov-step.is-complete .prov-step-icon{background:var(--acc);border-color:var(--acc)}
.prov-step.is-complete .prov-step-check{opacity:1;transform:scale(1)}
.prov-step.is-complete .prov-step-dot{opacity:0}
.prov-step.is-current{background:var(--acc-dim);color:var(--acc);font-weight:600}
.prov-step.is-current .prov-step-icon{border-color:var(--acc);background:var(--surface-2)}
.prov-step.is-current .prov-step-spinner{opacity:1}
.prov-step.is-current .prov-step-dot{opacity:0}
.prov-step.is-failed{background:color-mix(in srgb,var(--err) 12%,transparent);color:var(--err);font-weight:600}
.prov-step.is-failed .prov-step-icon{border-color:var(--err);background:var(--surface)}
.prov-step.is-failed .prov-step-check{opacity:0}
.prov-step.is-failed .prov-step-spinner{opacity:0}
.prov-step.is-failed .prov-step-dot{opacity:1;background:var(--err);width:8px;height:8px}

/* Status-/Fehler-Banner im Install-Form */
.ov-banner-ok{margin-top:20px;padding:11px 16px;background:color-mix(in srgb,var(--ok) 12%,transparent);border:1px solid color-mix(in srgb,var(--ok) 35%,transparent);color:var(--ok);border-radius:var(--radius-lg);font-size:13.5px}
.ov-banner-err{margin-top:20px;padding:11px 16px;background:color-mix(in srgb,var(--err) 12%,transparent);border:1px solid color-mix(in srgb,var(--err) 40%,transparent);color:var(--err);border-radius:var(--radius-lg);font-size:13.5px}

/* Toast (app.js showToast) */
.toast{position:fixed;bottom:24px;right:24px;background:var(--text);color:var(--bg);padding:11px 16px 11px 14px;border-radius:var(--radius-lg);font-size:13px;font-weight:500;box-shadow:0 14px 34px -14px rgba(0,0,0,.5);z-index:200;opacity:0;transform:translateY(8px);transition:opacity .22s,transform .22s;max-width:340px;line-height:1.4}
.toast.is-show{opacity:1;transform:translateY(0)}
.toast-soon{border-left:3px solid var(--acc);padding-left:13px}

/* PW-Modal (app.js DB-Zugangsdaten) */
.pwmodal{position:fixed;inset:0;z-index:300;display:grid;place-items:center;padding:20px}
/* hidden MUSS gewinnen — sonst steht jedes permanent gerenderte Modal (z. B.
   Archiv-Buchung im Stack-Mail-Tab) dauerhaft offen und JS-Toggles wirken nicht. */
.pwmodal[hidden]{display:none}
.pwmodal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(2px)}
.pwmodal-card{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px;max-width:480px;width:100%;box-shadow:0 14px 34px -14px rgba(0,0,0,.5)}
.pwmodal-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.pwmodal-icon{width:42px;height:42px;border-radius:var(--radius-lg);background:var(--acc-dim);color:var(--acc-2);display:grid;place-items:center;flex:none}
.pwmodal-icon svg{width:22px;height:22px}
.pwmodal-card h3{font-family:var(--font-display);font-weight:700;font-size:18px;color:var(--text);letter-spacing:-.2px}
.pwmodal-card > p{font-size:13.5px;color:var(--text-2);line-height:1.55;margin:0 0 16px}
.pwmodal-pwbox{display:flex;align-items:center;gap:10px;padding:14px 16px;border-radius:var(--radius-lg);background:var(--acc-dim);border:1px dashed var(--acc);margin-bottom:18px}
.pwmodal-pwbox code{flex:1;min-width:0;font-family:var(--font-mono);font-size:16px;color:var(--acc-2);font-weight:600;letter-spacing:1px;word-break:break-all;background:transparent;padding:0}
.pwmodal-pwbox .pwcopy{width:34px;height:34px;border-radius:var(--radius);flex:none}
.pwmodal-pwbox .pwcopy svg{width:15px;height:15px}
.pwmodal-actions{display:flex;justify-content:flex-end;gap:10px}
.db-reset-ack{background:color-mix(in srgb,var(--warn) 12%,transparent);border:1px solid color-mix(in srgb,var(--warn) 45%,transparent);color:var(--text)}

/* File-Picker (Drag&Drop, app.js-Hooks drag-over/has-files) */
.filepicker{display:flex;flex-direction:column;gap:8px}
.filepicker-drop{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--bg);border:2px dashed var(--line);border-radius:var(--radius-lg);cursor:pointer;transition:border-color .15s ease,background .15s ease;user-select:none}
.filepicker-drop:hover,.filepicker-drop.drag-over{border-color:var(--acc);background:var(--acc-dim)}
.filepicker-drop.has-files{padding:10px 14px}
.filepicker-drop.has-files .filepicker-icon svg{width:18px;height:18px}
.filepicker-icon{flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--acc-dim);color:var(--acc-2);border-radius:50%}
.filepicker-drop.has-files .filepicker-icon{width:32px;height:32px}
.filepicker-text{flex:1;font-size:13.5px;line-height:1.4}
.filepicker-text b{color:var(--text);font-weight:600}
.filepicker-or{color:var(--text-3);font-weight:400}
.filepicker-text small{display:block;color:var(--text-3);font-size:11.5px;margin-top:2px}
.filepicker-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}
.filepicker-item{display:flex;align-items:center;gap:10px;padding:7px 12px;background:var(--surface-2);border-radius:var(--radius);font-size:13px}
.filepicker-item svg{flex-shrink:0;color:var(--text-3)}
.filepicker-item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-2);font-weight:500}
.filepicker-item-size{color:var(--text-3);font-family:var(--font-mono);font-size:11.5px;flex-shrink:0}
.filepicker-item-rm{flex-shrink:0;background:none;border:none;cursor:pointer;width:22px;height:22px;display:flex;align-items:center;justify-content:center;color:var(--text-3);border-radius:50%;transition:color .12s ease,background .12s ease;padding:0}
.filepicker-item-rm:hover{background:color-mix(in srgb,var(--err) 12%,transparent);color:var(--err)}
.filepicker-err{padding:7px 12px;background:color-mix(in srgb,var(--err) 12%,transparent);color:var(--err);border-radius:var(--radius);font-size:12px}

/* Backup-Spinner-Modal (app.js, Vollbild während Snapshot) */
.bkspin{position:fixed;inset:0;z-index:400;display:grid;place-items:center;padding:20px}
.bkspin-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px)}
.bkspin-card{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:36px 32px;max-width:460px;width:100%;text-align:center;box-shadow:0 14px 34px -14px rgba(0,0,0,.5)}
.bkspin-ring{width:64px;height:64px;margin:0 auto 18px;display:grid;place-items:center}
.bkspin-ring svg{width:64px;height:64px;animation:bkspin-rotate 1.2s linear infinite}
@keyframes bkspin-rotate{from{transform:rotate(0)}to{transform:rotate(360deg)}}
.bkspin-card h3{font-family:var(--font-display);font-weight:700;font-size:20px;color:var(--text);margin:0 0 10px}
.bkspin-card p{font-size:13px;color:var(--text-2);line-height:1.55;margin:0 0 18px}
.bkspin-progress{height:8px;background:var(--line-2);border-radius:4px;overflow:hidden;margin:4px 0 18px;position:relative}
.bkspin-progress-bar{position:absolute;top:0;left:0;height:100%;width:0;background:linear-gradient(90deg,var(--acc),var(--ok));border-radius:4px;animation:bkspin-fill 45s linear forwards}
@keyframes bkspin-fill{0%{width:5%}20%{width:30%}50%{width:60%}80%{width:85%}100%{width:95%}}
.bkspin-steps{display:flex;justify-content:space-between;gap:8px;padding:14px 0;border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2);margin-bottom:4px}
.bkspin-step{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;font-size:11.5px;font-weight:600}
.bkspin-step-dot{width:14px;height:14px;border-radius:50%;background:var(--line);position:relative;flex:none}
.bkspin-step-1{color:var(--acc-2);animation:bkspin-s1-text 12s linear forwards}
.bkspin-step-1 .bkspin-step-dot{background:var(--acc);animation:bkspin-s1-dot 12s linear forwards}
.bkspin-step-2{color:var(--text-3);animation:bkspin-s2-text 24s linear forwards}
.bkspin-step-2 .bkspin-step-dot{animation:bkspin-s2-dot 24s linear forwards}
.bkspin-step-3{color:var(--text-3);animation:bkspin-s3-text 24s linear forwards}
.bkspin-step-3 .bkspin-step-dot{animation:bkspin-s3-dot 24s linear forwards}
@keyframes bkspin-s1-dot{0%,80%{background:var(--acc)}100%{background:var(--ok)}}
@keyframes bkspin-s1-text{0%,80%{color:var(--acc-2)}100%{color:var(--ok)}}
@keyframes bkspin-s2-dot{0%,40%{background:var(--line)}45%,90%{background:var(--acc)}100%{background:var(--ok)}}
@keyframes bkspin-s2-text{0%,40%{color:var(--text-3)}45%,90%{color:var(--acc-2)}100%{color:var(--ok)}}
@keyframes bkspin-s3-dot{0%,90%{background:var(--line)}95%,100%{background:var(--acc)}}
@keyframes bkspin-s3-text{0%,90%{color:var(--text-3)}95%,100%{color:var(--acc-2)}}

/* QO7-Datepicker-Popup (datepicker.js) */
.qo7-dp-input{cursor:pointer;caret-color:transparent}
.qo7-dp-popup{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:0 14px 34px -14px rgba(0,0,0,.5);padding:12px;width:268px;font-family:var(--font-sans);color:var(--text);user-select:none;animation:qo7-dp-pop .12s ease-out}
@keyframes qo7-dp-pop{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.qo7-dp-head{display:flex;align-items:center;gap:4px;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid var(--line-2)}
.qo7-dp-title{flex:1;text-align:center;font-family:var(--font-display);font-weight:700;font-size:14px;color:var(--text);letter-spacing:.01em}
.qo7-dp-nav{flex:none;width:28px;height:28px;display:grid;place-items:center;background:none;border:1px solid transparent;border-radius:var(--radius);color:var(--text-2);font-size:18px;line-height:1;cursor:pointer;transition:background .12s,color .12s,border-color .12s;font-family:var(--font-sans)}
.qo7-dp-nav:hover{background:var(--line-2);color:var(--acc);border-color:var(--line)}
.qo7-dp-today{flex:none;width:24px;height:24px;display:grid;place-items:center;background:none;border:1px solid transparent;border-radius:50%;color:var(--text-3);cursor:pointer;font-size:10px;line-height:1;transition:background .12s,color .12s}
.qo7-dp-today:hover{background:var(--acc-dim);color:var(--acc)}
.qo7-dp-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px}
.qo7-dp-weekdays span{text-align:center;font-size:10.5px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;padding:3px 0}
.qo7-dp-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.qo7-dp-day{aspect-ratio:1/1;display:grid;place-items:center;background:none;border:1px solid transparent;border-radius:var(--radius);color:var(--text);font-size:12.5px;font-weight:500;cursor:pointer;transition:background .1s,color .1s,border-color .1s;font-family:var(--font-sans)}
.qo7-dp-day:hover:not(:disabled){background:var(--acc-dim);color:var(--acc-2);border-color:var(--acc-line)}
.qo7-dp-day.is-today{color:var(--acc);font-weight:700;border-color:color-mix(in srgb,var(--acc) 30%,transparent)}
.qo7-dp-day.is-selected{background:var(--acc);color:var(--acc-ink);font-weight:700;border-color:transparent}
.qo7-dp-day.is-selected:hover{background:var(--acc);color:var(--acc-ink)}
.qo7-dp-day-other{color:var(--text-3);opacity:.4}
.qo7-dp-day.is-disabled{color:var(--text-3);opacity:.35;cursor:not-allowed}

/* Responsive (portierte skin-2-Breakpoints) */
@media(max-width:860px){
  .readout{grid-template-columns:1fr 1fr}
  .ovgrid{grid-template-columns:1fr}
  .kpis{grid-template-columns:1fr 1fr}
  .arow2{grid-template-columns:1fr}
  .resbar{grid-template-columns:60px 1fr 80px;gap:10px}
  .resbar-sub{display:none}
}
@media(max-width:820px){
  .grid2,.stacks,.readout{grid-template-columns:1fr}
  .wrap{padding:24px 16px 60px}
  .pkg-grid{grid-template-columns:1fr}
  .frow{flex-direction:column;align-items:stretch;gap:8px}
  .frow .inp,.frow select.inp{flex:1 1 auto}
  .info-grid{grid-template-columns:1fr}
}
@media(max-width:640px){
  .db-conn{grid-template-columns:1fr}
  .welcome-grid{grid-template-columns:1fr}
  .toast{left:14px;right:14px;bottom:14px;max-width:none}
}
/* Tabellen als gestapelte Karten auf Mobile (Opt-in .tbl-cards, Titel aus data-label) */
@media(max-width:640px){
  .tbl-cards > thead{display:none}
  .tbl-cards,.tbl-cards > tbody,.tbl-cards > tbody > tr,.tbl-cards > tbody > tr > td{display:block;width:100%}
  .tbl-cards > tbody > tr{border:1px solid var(--line-2);border-radius:var(--radius-lg);margin:0 0 12px;padding:4px 0}
  .tbl-cards > tbody > tr:last-child{margin-bottom:0}
  .tbl-cards > tbody > tr > td{border:0;padding:9px 16px;display:flex;justify-content:space-between;align-items:center;gap:14px;text-align:right;font-size:13px}
  .tbl-cards > tbody > tr > td::before{content:attr(data-label);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-3);text-align:left;flex:none;white-space:nowrap}
  .tbl-cards > tbody > tr > td.no-label{justify-content:flex-end;flex-wrap:wrap;gap:6px;white-space:normal}
  .tbl-cards > tbody > tr > td.no-label::before{display:none}
  .tbl-cards > tbody > tr > td[colspan]{display:block;text-align:left}
  .tbl-cards > tbody > tr > td[colspan]::before{display:none}
}

/* ===== 7. Responsive ===== */
@media (max-width:860px){
  .auth{grid-template-columns:1fr}
  .auth-brand{border-right:0;border-bottom:1px solid var(--line)}
}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* ===== Monitoring (M-2) =====
   #15 — Board (Gruppen-Karten) + Check-Detail. NUR Skin-Tokens (light+dark
   über die Token-Ebenen). `.bars` = Port der Suite2-Sparkline (Design-Quelle
   app.css Z. 133–135), bewusst OHNE Glow (Precision-Linie: keine Glows). */
.subnav a svg{width:13px;height:13px;vertical-align:-2px;margin-right:5px}
.hsub .err{color:var(--err)}
.mon-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(480px,100%),1fr));gap:16px;align-items:start}
.mon-grid .card{margin-bottom:0}
.mon-meta{display:flex;gap:22px;flex-wrap:wrap;align-items:flex-end;padding:14px 18px;border-bottom:1px solid var(--line)}
.mon-stat{display:flex;flex-direction:column;gap:4px;min-width:84px}
.mon-stat .k{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--text-3)}
.mon-stat .v{font-family:var(--font-display);font-size:18px;font-weight:600;letter-spacing:-.02em;color:var(--text);line-height:1.15}
.mon-stat .v.sm{font-family:var(--font-mono);font-size:12.5px;font-weight:500}
.mon-stat .v small{display:block;font-family:var(--font-mono);font-size:10.5px;color:var(--text-3);font-weight:400;margin-top:2px}
.mon-stat.grow{flex:1 1 160px;min-width:160px}
/* Sparkline/Balken-Chart (Höhen-% kommen als erlaubte Inline-Styles aus _bars) */
.bars{display:flex;align-items:flex-end;gap:3px;height:44px}
.bars i{flex:1;background:var(--acc-line);border-radius:2px 2px 0 0;min-height:3px}
.bars i.hl{background:var(--acc)}
.bars i.dn{background:var(--err)}
.bars i.na{background:var(--line)}
.bars.sm{height:20px;gap:2px;width:110px;flex:none}
.bars.lg{height:120px;gap:2px}
.mon-axis{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:10.5px;color:var(--text-3);margin-top:6px}
/* Kopf/Zeilen */
.mon-h1{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.mon-type-tag{min-width:0;padding:2px 7px;font-size:10px;vertical-align:1px}
.mon-check-sub{display:block;font-size:11px;max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mon-until{display:block;font-size:10.5px;margin-top:2px}
.mon-note{font-size:13px}
.mon-empty b{display:block;color:var(--text);font-size:14px}
.mon-empty p{font-size:12.5px;margin-top:6px}
/* Flash-Karten (ok/err) — Klassen statt Inline-Styles */
.mon-flash{margin-bottom:14px}
.mon-flash .fm{padding:12px 18px;font-weight:600;display:flex;align-items:center;gap:8px}
.mon-flash .fm svg{width:16px;height:16px;flex:none}
.mon-flash.ok{border-color:color-mix(in srgb,var(--ok) 45%,transparent)}
.mon-flash.ok .fm{color:var(--ok)}
.mon-flash.err{border-color:color-mix(in srgb,var(--err) 45%,transparent)}
.mon-flash.err .fm{color:var(--err)}
/* Pause-Dialog (details/.plan-quick mit nativem Select .inp) */
.mon-pause-menu{text-align:left}
.mon-pause-menu form{display:flex;flex-direction:column;gap:8px;margin:0}
.mon-pause-label{font-size:12.5px;font-weight:600;color:var(--text)}
.mon-pause-hint{font-size:11px;color:var(--text-3);line-height:1.5}
/* Letzte Fehl-Läufe (Roh-Detail-Texte) */
.mon-fails{display:flex;flex-direction:column}
.mon-fail{display:flex;gap:12px;align-items:flex-start;padding:10px 18px;border-top:1px solid var(--line-2);font-size:12.5px}
.mon-fail:first-child{border-top:0}
.mon-fail-time{flex:none;color:var(--text-3);font-size:11.5px;padding-top:1px}
.mon-fail-detail{color:var(--text-2);font-family:var(--font-mono);font-size:12px;word-break:break-word;line-height:1.5}
/* kleine Utilities des Monitoring-Blocks */
.u-ta-r{text-align:right}
.u-form-inline{display:inline;margin:0}
/* ---------- Modale Dialoge (P1d/P2a, 2026-06-13) ----------
   <dialog class="card">: .card-Margins kippen das margin:auto des UA-Stylesheets
   (Dialog klebte am unteren Rand — Sven-Review). Zentrierung erzwingen + Backdrop. */
dialog.card{margin:auto;max-height:88vh;overflow:auto}
dialog.card::backdrop{background:rgba(8,10,14,.55)}
