:root{
  --bg:#0b0e14; --bg2:#0f131c; --panel:#141926; --panel2:#19202e;
  --border:#222a3a; --border2:#2c3650;
  --text:#e7ecf3; --muted:#8a94a8; --muted2:#5f6a80;
  --accent:#6366f1; --accent2:#818cf8; --accent-glow:rgba(99,102,241,.35);
  --ok:#34d399; --warn:#fbbf24; --danger:#f87171;
  --radius:14px; --radius-sm:10px;
  --shadow:0 10px 40px rgba(0,0,0,.45);
  --sidebar-w:300px;
  font-family:system-ui,-apple-system,"Segoe UI",sans-serif;
}
*{box-sizing:border-box}
html{height:100%}
body{min-height:100%;margin:0;background:
  radial-gradient(1100px 600px at 12% -8%, rgba(99,102,241,.10), transparent 60%),
  radial-gradient(900px 500px at 100% 0%, rgba(56,189,248,.06), transparent 55%),
  var(--bg);
  background-attachment:fixed;background-repeat:no-repeat;
  color:var(--text);-webkit-font-smoothing:antialiased}
.boot{display:grid;place-items:center;height:100vh;color:var(--muted)}
button{font-family:inherit;cursor:pointer}
input,select,textarea{font-family:inherit}
a{color:var(--accent2);text-decoration:none}

/* ---------- LOGIN ---------- */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;
  background:linear-gradient(rgba(9,12,20,.66),rgba(9,12,20,.85)),url('/static/login-bg.svg') center/cover no-repeat fixed}
.login-card{width:100%;max-width:400px;background:linear-gradient(180deg,var(--panel),var(--bg2));
  border:1px solid var(--border);border-radius:20px;padding:38px 34px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.login-card::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;
  background:linear-gradient(90deg,transparent,var(--accent),transparent)}
.brand{display:flex;align-items:center;gap:12px;margin-bottom:6px}
.brand .logo{width:38px;height:38px;border-radius:11px;box-shadow:0 6px 20px var(--accent-glow);display:block}
.brand h1{font-size:1.12rem;margin:0;letter-spacing:.2px}
.brand span{color:var(--muted);font-size:.8rem}
.login-card h2{font-size:1.4rem;margin:22px 0 4px}
.login-card .sub{color:var(--muted);font-size:.9rem;margin-bottom:22px}
.field{margin-bottom:14px}
.field label{display:block;font-size:.78rem;color:var(--muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}
.input{width:100%;background:#0a0d14;border:1px solid var(--border2);color:var(--text);
  border-radius:var(--radius-sm);padding:.72rem .85rem;font-size:.95rem;transition:.15s}
.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.btn{border:0;border-radius:var(--radius-sm);padding:.72rem 1.1rem;font-size:.92rem;font-weight:600;
  color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent2));transition:.15s;box-shadow:0 6px 18px var(--accent-glow)}
.btn:hover{filter:brightness(1.08);transform:translateY(-1px)}
.btn.block{width:100%;margin-top:6px}
.btn.ghost{background:var(--panel2);box-shadow:none;color:var(--text);border:1px solid var(--border2)}
.btn.ghost:hover{border-color:var(--accent);transform:none}
.btn.danger{background:linear-gradient(135deg,#ef4444,#f87171);box-shadow:none}
.btn.sm{padding:.45rem .7rem;font-size:.82rem}
.err{color:var(--danger);font-size:.85rem;min-height:1.1em;margin-top:8px}
.loginlinks{text-align:center;margin-top:16px;font-size:.85rem;display:flex;gap:8px;justify-content:center;color:var(--muted2)}
.showpw{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--muted);margin-top:10px;cursor:pointer;user-select:none}
.showpw input{width:auto;margin:0}
.pwhint{font-size:.78rem;color:var(--muted2);margin-top:8px}

/* ---------- APP SHELL ---------- */
.shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;height:100vh}
.sidebar{background:linear-gradient(180deg,var(--bg2),var(--bg));border-right:1px solid var(--border);
  display:flex;flex-direction:column;padding:18px 14px;gap:6px;overflow-y:auto}
.sidebar .brand{padding:6px 8px 14px}
.user-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);
  padding:14px;margin-bottom:14px;display:flex;gap:12px;align-items:center;cursor:pointer;transition:border-color .12s}
.user-card:hover{border-color:var(--accent)}
.avatar{width:42px;height:42px;border-radius:12px;flex:0 0 auto;display:grid;place-items:center;font-weight:700;color:#fff;
  background:linear-gradient(135deg,#6366f1,#22d3ee)}
.user-card .meta{min-width:0}
.user-card .name{font-weight:600;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-card .ten{color:var(--muted);font-size:.78rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.badge{display:inline-block;font-size:.66rem;padding:.12rem .45rem;border-radius:999px;margin-top:4px;
  background:rgba(99,102,241,.18);color:var(--accent2);border:1px solid rgba(99,102,241,.3)}
.nav-label{font-size:.68rem;text-transform:uppercase;letter-spacing:.8px;color:var(--muted2);padding:12px 10px 6px}
.nav-item{display:flex;align-items:center;gap:11px;padding:.62rem .7rem;border-radius:10px;color:var(--muted);
  font-size:.9rem;border:1px solid transparent;transition:.12s;user-select:none}
.nav-item .ic{width:18px;height:18px;flex:0 0 auto;opacity:.9}
.nav-item:hover{background:var(--panel);color:var(--text)}
.nav-item.active{background:var(--panel2);color:#fff;border-color:var(--border2)}
.nav-item.active .ic{color:var(--accent2)}
.nav-group{margin-top:4px}
.nav-group>.nav-item{justify-content:space-between}
.nav-group .chev{transition:.2s;opacity:.6}
.nav-group.open .chev{transform:rotate(90deg)}
.nav-sub{display:none;margin:2px 0 2px 12px;padding-left:10px;border-left:1px solid var(--border2)}
.nav-group.open .nav-sub{display:block}
.nav-sub .nav-item{font-size:.85rem;padding:.5rem .6rem}
.sidebar .spacer{flex:1}
.trust-line{display:block;text-align:center;font-size:.72rem;color:var(--muted2);text-decoration:none;
  padding:8px 6px;margin:2px 4px 6px;border:1px solid var(--border);border-radius:9px;transition:.12s}
.trust-line:hover{color:var(--muted);border-color:var(--border2)}
@media(max-width:820px){.trust-line{font-size:.6rem;padding:6px 2px}}

/* ---------- MAIN ---------- */
.main{display:flex;flex-direction:column;min-width:0;background:var(--bg)}
.topbar{height:62px;flex:0 0 auto;border-bottom:1px solid var(--border);display:flex;align-items:center;
  gap:14px;padding:0 24px;background:rgba(15,19,28,.6);backdrop-filter:blur(8px)}
.topbar h2{font-size:1.08rem;margin:0;font-weight:650}
.topbar .crumb{color:var(--muted);font-size:.85rem}
.topbar .right{margin-left:auto;display:flex;gap:10px}
.back-btn{display:flex;align-items:center;gap:7px;background:var(--panel);border:1px solid var(--border2);
  color:var(--text);border-radius:10px;padding:.45rem .8rem;font-size:.85rem}
.back-btn:hover{border-color:var(--accent)}
.content{flex:1;overflow:auto;padding:26px}
.content.flush{padding:0}

/* ---------- WIDGETS ---------- */
.grid{display:grid;gap:16px}
.cards{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
.card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:18px;transition:.15s}
.card:hover{border-color:var(--border2);transform:translateY(-2px);box-shadow:0 8px 26px rgba(0,0,0,.35)}
.card.click{cursor:pointer}
.card h3{margin:0 0 6px;font-size:1rem}
.card p{margin:0;color:var(--muted);font-size:.85rem;line-height:1.45}
.card .row{display:flex;align-items:center;justify-content:space-between;margin-top:14px}
.pill{font-size:.72rem;padding:.2rem .55rem;border-radius:999px;border:1px solid var(--border2);color:var(--muted)}
.pill.on{color:var(--ok);border-color:rgba(52,211,153,.35);background:rgba(52,211,153,.1)}
.pill.off{color:var(--muted)}
.section-head{display:flex;align-items:center;justify-content:space-between;margin:0 0 18px}
.section-head h3{margin:0;font-size:1.15rem}
.section-head p{margin:2px 0 0;color:var(--muted);font-size:.85rem}
table{width:100%;border-collapse:collapse;font-size:.9rem}
th,td{text-align:left;padding:.7rem .8rem;border-bottom:1px solid var(--border)}
th{color:var(--muted);font-weight:500;font-size:.78rem;text-transform:uppercase;letter-spacing:.4px}
tr:hover td{background:var(--panel)}
.tablewrap{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.empty{display:grid;place-items:center;gap:10px;color:var(--muted);padding:60px 20px;text-align:center}
.empty .big{font-size:2.4rem;opacity:.5}
.notice{background:rgba(251,191,36,.07);border:1px solid rgba(251,191,36,.28);
  border-radius:10px;padding:14px 16px;color:var(--text);font-size:.88rem;margin-bottom:16px}
.editor-frame{width:100%;height:100%;border:0;background:#fff}
/* Nur-Lese-Workflow-Graph (Viewer) */
.wf-canvas{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  overflow:auto;max-height:calc(100vh - 260px);padding:8px}
.wf-edge{fill:none;stroke:var(--border2);stroke-width:2}
.wf-node rect{fill:var(--panel);stroke:var(--border2);stroke-width:1.5}
.wf-node:hover rect{stroke:var(--accent)}
.wf-node.off{opacity:.5}
.wf-nname{fill:var(--text);font:600 13px system-ui,sans-serif}
.wf-ntype{fill:var(--muted);font:11px ui-monospace,monospace}
/* Erste-Schritte-Stepper */
.gs-list{display:flex;flex-direction:column;gap:12px}
.gs-step{display:flex;gap:14px;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:18px}
.gs-step.done{opacity:.72}
.gs-num{width:34px;height:34px;flex:0 0 auto;border-radius:50%;display:grid;place-items:center;font-weight:700;
  color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent2))}
.gs-step.done .gs-num{background:linear-gradient(135deg,#16a34a,#34d399)}
.gs-body h4{margin:2px 0 5px;font-size:1rem}
.gs-body p{margin:0;color:var(--muted);font-size:.9rem;line-height:1.5}
.gs-cta{margin-top:12px}.gs-cta:empty{display:none}
/* Monitoring */
.mon-k{font-size:.72rem;text-transform:uppercase;letter-spacing:.6px;color:var(--muted2)}
.mon-v{font-size:1.6rem;font-weight:700;margin-top:4px}
.mon-bar{height:5px;border-radius:99px;background:var(--border);overflow:hidden;margin-top:5px;max-width:160px}
.mon-bar>div{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--accent),var(--accent2))}
.form{max-width:520px;display:grid;gap:14px}
textarea.input{min-height:90px;resize:vertical}
.flash{position:fixed;right:20px;bottom:20px;background:var(--panel2);border:1px solid var(--border2);
  border-radius:10px;padding:12px 16px;font-size:.88rem;box-shadow:var(--shadow);opacity:0;transform:translateY(8px);transition:.2s;z-index:50}
.flash.show{opacity:1;transform:none}
.flash.ok{border-color:rgba(52,211,153,.5)} .flash.err{border-color:rgba(248,113,113,.5)}
.rowbtns{display:inline-flex;gap:6px}
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(3px);display:grid;place-items:center;z-index:60;padding:20px}
.modal{background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--border2);border-radius:14px;padding:24px;width:min(500px,94vw);box-shadow:var(--shadow)}
.modal h3{margin:0 0 16px;font-size:1.1rem}
.modal .actions{display:flex;gap:8px;align-items:center;margin-top:18px}
@media(max-width:820px){:root{--sidebar-w:84px}.user-card .meta,.nav-item span,.nav-label{display:none}}

/* ---------- ONBOARDING-TOUR ---------- */
.tour-block{position:fixed;inset:0;z-index:190;background:transparent;transition:background .25s}
.tour-block.dim{background:rgba(6,9,15,.74)}
.tour-spot{position:fixed;display:none;border-radius:12px;border:2px solid var(--accent);
  box-shadow:0 0 0 9999px rgba(6,9,15,.72),0 0 0 4px var(--accent-glow);pointer-events:none;z-index:191;
  animation:tourpop .2s ease}
.tour-bubble{position:fixed;z-index:192;width:320px;max-width:92vw;
  background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--border2);
  border-radius:16px;padding:20px;box-shadow:var(--shadow);animation:tourpop .2s ease}
@keyframes tourpop{from{opacity:0;transform:scale(.97)}to{opacity:1}}
.tour-bubble .tour-step{font-size:.7rem;text-transform:uppercase;letter-spacing:.7px;color:var(--accent2);margin-bottom:6px}
.tour-bubble h3{margin:0 0 8px;font-size:1.08rem}
.tour-bubble p{margin:0;color:var(--muted);font-size:.9rem;line-height:1.5}
.tour-actions{display:flex;align-items:center;gap:8px;margin-top:18px}
.tour-skip{background:none;border:0;color:var(--muted2);font-size:.82rem;padding:.3rem 0}
.tour-skip:hover{color:var(--text)}

/* ---------- TENANT SWITCHER ---------- */
.input.sm{padding:.42rem .55rem;font-size:.85rem}
.tenant-switch{display:flex;gap:6px;align-items:center;margin:0 0 4px}
.tenant-switch select{flex:1;min-width:0}
.tenant-switch .btn{flex:0 0 auto;padding:.42rem .6rem;font-size:1rem;line-height:1}

/* ---------- LANDING (öffentlich) ---------- */
.landing{max-width:1120px;margin:0 auto;padding:0 24px 60px}
.lp-nav{display:flex;align-items:center;justify-content:space-between;padding:20px 0}
.lp-nav-cta{display:flex;gap:10px}
.lp-hero{text-align:center;padding:56px 0 40px}
.lp-badge{display:inline-flex;align-items:center;gap:8px;font-size:.82rem;color:var(--accent2);
  background:rgba(99,102,241,.1);border:1px solid rgba(99,102,241,.28);border-radius:999px;padding:.4rem .9rem;margin-bottom:22px}
.lp-badge svg{width:16px;height:16px}
.lp-hero h1{font-size:clamp(2rem,5vw,3.3rem);line-height:1.08;margin:0 0 18px;letter-spacing:-.5px}
.lp-hero h1 .grad{color:var(--accent2)}
.lp-sub{max-width:640px;margin:0 auto 28px;color:var(--muted);font-size:1.08rem;line-height:1.6}
.lp-hero-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.lp-hero-cta .btn{padding:.85rem 1.5rem;font-size:1rem}
.lp-trustline{margin-top:24px;color:var(--muted2);font-size:.85rem}
.lp-feats{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:16px;margin:36px 0}
.lp-feat{display:flex;gap:14px;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:18px}
.lp-feat-ic{color:var(--accent2);flex:0 0 auto}
.lp-feat h4{margin:2px 0 5px;font-size:.98rem}
.lp-feat p{margin:0;color:var(--muted);font-size:.85rem;line-height:1.45}
.lp-section{padding:48px 0;text-align:center}
.lp-section h2{font-size:clamp(1.5rem,3.5vw,2.1rem);margin:0 0 8px}
.lp-section-sub{color:var(--muted);margin:0 0 30px}
.lp-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;text-align:left}
.lp-step{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:22px;position:relative}
.lp-step-n{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;font-weight:700;color:#fff;
  background:linear-gradient(135deg,var(--accent),var(--accent2));margin-bottom:12px}
.lp-step h4{margin:0 0 6px;font-size:1.05rem}
.lp-step p{margin:0;color:var(--muted);font-size:.9rem;line-height:1.5}
.lp-plans{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px;text-align:left}
.lp-plan{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:24px 20px;display:flex;flex-direction:column;position:relative;transition:transform .15s,border-color .15s}
.lp-plan:hover{transform:translateY(-3px);border-color:var(--border2)}
.lp-plan.primary{border-color:var(--accent);box-shadow:0 10px 34px var(--accent-glow)}
.lp-plan-tag{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--accent),var(--accent2));
  color:#fff;font-size:.7rem;font-weight:700;padding:.22rem .7rem;border-radius:999px;letter-spacing:.4px}
.lp-plan-name{font-size:.9rem;color:var(--muted);text-transform:uppercase;letter-spacing:.6px}
.lp-plan-price{font-size:2rem;font-weight:700;margin:6px 0 14px}
.lp-plan-price span{font-size:.9rem;font-weight:400;color:var(--muted)}
.lp-plan ul{list-style:none;margin:0 0 18px;padding:0;flex:1}
.lp-plan li{padding:.4rem 0 .4rem 22px;position:relative;font-size:.88rem;color:var(--text);border-bottom:1px solid var(--border)}
.lp-plan li::before{content:"✓";position:absolute;left:0;color:var(--ok);font-weight:700}
.lp-ent{margin-top:24px;color:var(--muted)}
.lp-ent a{font-weight:600}
.lp-cta-final{text-align:center;padding:56px 24px;margin-top:20px;background:linear-gradient(135deg,rgba(99,102,241,.12),rgba(34,211,238,.06));
  border:1px solid var(--border2);border-radius:20px}
.lp-cta-final h2{margin:0 0 20px;font-size:clamp(1.4rem,3vw,2rem)}
.lp-cta-final .btn{padding:.85rem 1.7rem;font-size:1.02rem}
.lp-footer{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;
  margin-top:50px;padding-top:24px;border-top:1px solid var(--border);color:var(--muted2);font-size:.85rem}
.lp-footer-links{display:flex;gap:16px;align-items:center}
@media(max-width:560px){.lp-nav-cta #lpLogin{display:none}.lp-hero{padding:36px 0 28px}}

/* ---------- SPACE-PROVISIONING (Animation) ---------- */
.provision{text-align:center;padding:14px 6px 6px}
.provision h3{margin:14px 0 6px;font-size:1.12rem}
.provision .prov-msg{color:var(--muted);font-size:.9rem;min-height:1.3em;transition:opacity .2s}
.provision .prov-msg.err{color:var(--danger)}
.provision .prov-hint{color:var(--muted2);font-size:.8rem;margin-top:14px}
.spinner{width:48px;height:48px;margin:6px auto 0;border:4px solid var(--border2);border-top-color:var(--accent);
  border-radius:50%;animation:spin .8s linear infinite;box-shadow:0 0 22px var(--accent-glow)}
@keyframes spin{to{transform:rotate(360deg)}}
.prov-track{height:6px;margin:18px auto 4px;max-width:280px;background:var(--border);border-radius:99px;overflow:hidden}
.prov-bar{width:38%;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--accent),var(--accent2));
  animation:indet 1.5s ease-in-out infinite}
@keyframes indet{0%{transform:translateX(-120%)}100%{transform:translateX(330%)}}
.provision .check,.provision .cross{width:56px;height:56px;margin:6px auto 0;border-radius:50%;display:grid;place-items:center;
  font-size:1.8rem;font-weight:700;color:#fff;animation:pop .35s ease both}
.provision .check{background:linear-gradient(135deg,#16a34a,#34d399);box-shadow:0 0 24px rgba(52,211,153,.4)}
.provision .cross{background:linear-gradient(135deg,#dc2626,#f87171);box-shadow:0 0 24px rgba(248,113,113,.4)}
@keyframes pop{0%{transform:scale(.4);opacity:0}60%{transform:scale(1.15)}100%{transform:scale(1);opacity:1}}
