/* ============================================================
   CSE Workflow — App-Stylesheet (kein Framework, kein Inline)
   Dichte/Spacing aus Ticketsystem v2 übernommen: kompakt, flach,
   mobil-angepasst (Breakpoints 1024 / 768 / 600).
   ============================================================ */
:root{
  --c-navy:#16254c; --c-navy-2:#1e3263;
  --c-primary:#0078c0; --c-primary-hover:#005f99;
  --c-teal:#529f96; --c-teal-hover:#448a82;
  --c-danger:#dc2626; --c-danger-hover:#b91c1c;
  --c-bg:#f8f9fa; --c-surface:#fff; --c-surface-2:#f8fafc; --c-surface-3:#f1f5f9;
  --c-text:#3e3d3b; --c-muted:#64748b; --c-muted-2:#94a3b8; --c-heading:#374151;
  --c-border:#e5e7eb; --c-border-2:#d1d5db;
  /* flach wie v2; eigene Radien nur für Login-Karte */
  --radius:0; --radius-sm:4px; --radius-card:10px;
  --font:'Segoe UI',system-ui,-apple-system,sans-serif;
  --mono:'Cascadia Code','Fira Code',Consolas,monospace;
  --shadow:0 1px 2px rgba(0,0,0,.05); --shadow-lg:0 8px 24px rgba(0,0,0,.18);
  --header-h:52px; --sidebar-w:240px; --sidebar-w-md:200px;
  /* Spacing-Skala */
  --sp-1:.25rem; --sp-2:.5rem; --sp-3:.7rem; --sp-4:.9rem; --sp-5:1.2rem;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:var(--font);color:var(--c-text);background:var(--c-bg);line-height:1.45;min-height:100vh}
h1{font-size:1.45rem;font-weight:600}h2{font-size:1.15rem;font-weight:600}h3{font-size:1rem;font-weight:600}
a{color:var(--c-primary);text-decoration:none}a:hover{text-decoration:underline}
[data-lucide]{display:inline-block;vertical-align:-2px;width:16px;height:16px}

/* --- Buttons --- */
.btn{display:inline-flex;align-items:center;gap:.35rem;padding:.45rem .9rem;border:1px solid var(--c-border-2);
  background:var(--c-surface);color:var(--c-text);border-radius:var(--radius);font-size:.875rem;cursor:pointer;
  font-family:inherit;line-height:1.3;transition:background .15s,border-color .15s}
.btn:hover{background:#f9fafb;border-color:#9ca3af}
.btn:active{background:#f3f4f6}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn [data-lucide]{width:15px;height:15px}
.btn-primary{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}
.btn-primary:hover{background:var(--c-primary-hover);border-color:var(--c-primary-hover)}
.btn-success{background:var(--c-teal);color:#fff;border-color:var(--c-teal)}
.btn-success:hover{background:var(--c-teal-hover)}
.btn-danger{background:var(--c-danger);color:#fff;border-color:var(--c-danger)}
.btn-danger:hover{background:var(--c-danger-hover)}
.btn-sm{padding:.3rem .6rem;font-size:.8rem}
.btn-block{display:flex;width:100%;justify-content:center}
.link-btn{background:none;border:none;color:var(--c-primary);font-size:.8rem;cursor:pointer;font-family:inherit;padding:0}
.link-btn:hover{text-decoration:underline}

/* --- Formulare (v2-Dichte) --- */
.form-group{margin-bottom:.8rem}
.form-group label{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem;font-weight:500;font-size:.85rem;color:var(--c-heading)}
.form-control{width:100%;height:32px;padding:4px 8px;border:1px solid var(--c-border-2);border-radius:var(--radius);
  font-size:.9rem;line-height:1.4;font-family:inherit;color:var(--c-text);background:#fff;transition:border-color .15s,box-shadow .15s}
.form-control:focus{outline:none;border-color:var(--c-primary);box-shadow:0 0 0 3px rgba(0,120,192,.15)}
textarea.form-control{height:auto;min-height:80px;resize:vertical}
select.form-control{appearance:auto}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.9rem}
.form-msg{min-height:1rem;font-size:.82rem;margin:.15rem 0 .5rem}
.form-msg.is-error{color:var(--c-danger)}
.form-msg.is-ok{color:var(--c-teal)}

/* --- Hilfe-Icon an Feldern & Selects (v2-Muster: angehängtes Addon) --- */
.input-group{display:flex;align-items:stretch}
.input-group .form-control{flex:1;min-width:0;border-top-right-radius:0;border-bottom-right-radius:0;border-right:none}
.input-hint-icon{display:flex;align-items:center;justify-content:center;width:32px;flex-shrink:0;position:relative;
  background:var(--c-surface-3);border:1px solid var(--c-border-2);border-left:none;border-radius:var(--radius);
  color:var(--c-muted-2);cursor:help}
.input-hint-icon:hover{color:var(--c-heading);background:#e5e7eb}
.input-hint-icon [data-lucide]{width:14px;height:14px}
/* Fokus umschließt das ganze Feld inkl. Icon-Addon als eine Einheit */
.input-group:focus-within{box-shadow:0 0 0 3px rgba(0,120,192,.15);border-radius:var(--radius)}
.input-group:focus-within .form-control{border-color:var(--c-primary);box-shadow:none}
.input-group:focus-within .input-hint-icon{border-color:var(--c-primary)}
/* Tooltip als Span-Element — erlaubt HTML im Hinweis, kein title */
.hint-tooltip{display:none;position:absolute;bottom:calc(100% + 6px);right:0;
  background:var(--c-navy);color:#f1f5f9;font-size:.78rem;font-weight:400;line-height:1.45;
  padding:.45rem .65rem;border-radius:5px;white-space:normal;width:max-content;max-width:min(300px,80vw);
  text-align:left;z-index:100;pointer-events:none;box-shadow:var(--shadow-lg)}
.hint-tooltip::after{content:'';position:absolute;top:100%;right:12px;border:5px solid transparent;border-top-color:var(--c-navy)}
.input-hint-icon:hover .hint-tooltip,.input-hint-icon:focus-within .hint-tooltip{display:block}
/* Variante: Tooltip unterhalb (Felder am oberen Rand, unter fixed Header) */
.input-hint-icon.tip-below .hint-tooltip{bottom:auto;top:calc(100% + 6px)}
.input-hint-icon.tip-below .hint-tooltip::after{top:auto;bottom:100%;border-top-color:transparent;border-bottom-color:var(--c-navy)}

/* --- Panel (flach, kompakt) --- */
/* Panel sitzt flush im Content (kein Außen-Margin). Mehrere Panels separieren via .app-content gap. */
.panel{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);box-shadow:var(--shadow);margin:0}
.panel-header{display:flex;align-items:center;justify-content:space-between;padding:.55rem .9rem;border-bottom:1px solid var(--c-border);background:var(--c-surface-2)}
.panel-header h2{font-size:.95rem;display:flex;align-items:center;gap:.4rem}
.panel-header h2 [data-lucide]{width:17px;height:17px;color:var(--c-muted)}
.panel-meta{font-size:.78rem;color:var(--c-muted-2);font-weight:400}
.panel-body{padding:.9rem}
.panel-body.flush{padding:0}
.panel-footer{padding:.55rem .9rem;border-top:1px solid var(--c-border)}

/* --- Datentabellen (v2) --- */
.data-table{width:100%;border-collapse:collapse;font-size:.9rem}
.data-table th,.data-table td{padding:.5rem .7rem;text-align:left;vertical-align:top;border-bottom:1px solid var(--c-border)}
.data-table th{background:var(--c-surface-2);font-weight:600;font-size:.78rem;color:var(--c-muted);text-transform:uppercase;letter-spacing:.3px}
.data-table .data-row{cursor:pointer;transition:background .1s}
.data-table .data-row:hover{background:var(--c-surface-3)}
.data-table .data-row.selected{background:#eff6ff}

/* --- Badges --- */
.badge{display:inline-block;padding:.2rem .55rem;border-radius:var(--radius-sm);font-size:.78rem;font-weight:600;line-height:1.4;white-space:nowrap;background:#eef2f8;color:var(--c-primary)}

/* --- Auth-Seiten (Login / Force-Change) — etwas weicher --- */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;
  background:radial-gradient(900px 500px at 50% -10%,var(--c-navy-2),transparent),var(--c-navy)}
.auth-card{width:100%;max-width:380px;background:var(--c-surface);border-radius:var(--radius-card);box-shadow:var(--shadow-lg);padding:1.8rem}
.auth-brand{display:flex;align-items:center;gap:.7rem;margin-bottom:1.1rem}
.auth-logo{width:38px;height:38px;border-radius:9px;background:linear-gradient(135deg,var(--c-primary),var(--c-teal));
  color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:19px}
.auth-brand strong{display:block;font-size:1.02rem}
.auth-brand span{font-size:.76rem;color:var(--c-muted)}
.auth-hint{font-size:.84rem;color:var(--c-muted);margin-bottom:.9rem}
.auth-foot{margin-top:1.1rem;font-size:.74rem;color:var(--c-muted-2);text-align:center}

/* --- App-Header (eingeloggt) --- */
.app-header{position:fixed;top:0;left:0;right:0;height:var(--header-h);z-index:1000;display:flex;align-items:center;
  justify-content:space-between;padding:0 .8rem;background:var(--c-navy);color:#e5e7eb;box-shadow:var(--shadow)}
.app-header-left{display:flex;align-items:center;gap:.6rem}
.app-brand{display:flex;align-items:center;gap:.5rem}
.app-logo{width:28px;height:28px;border-radius:7px;background:linear-gradient(135deg,var(--c-primary),var(--c-teal));
  color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:15px}
.app-title{font-weight:700;font-size:.95rem}
.app-badge{font-size:.7rem;color:#94a3b8;background:rgba(255,255,255,.1);padding:.05rem .35rem;border-radius:3px}
/* Globales Suchfeld im Header — Input-Group mit angehängtem ?-Addon (dunkel) */
.header-search{display:flex;align-items:stretch;flex:1;max-width:460px;margin:0 .8rem;min-width:0;height:34px}
.header-search-input{flex:1;min-width:0;height:34px;padding:0 10px;border:1px solid rgba(255,255,255,.18);border-right:none;
  border-radius:6px 0 0 6px;background:rgba(255,255,255,.1);color:#e5e7eb;font-size:.85rem;font-family:inherit;appearance:none;-webkit-appearance:none}
.header-search-input::placeholder{color:#94a3b8}
.header-search-input:focus{outline:none}
.header-search-input::-webkit-search-cancel-button,.header-search-input::-webkit-search-decoration{display:none;-webkit-appearance:none}
.header-search-help{display:flex;align-items:center;justify-content:center;width:34px;flex-shrink:0;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.18);border-left:none;border-radius:0 6px 6px 0;
  color:#94a3b8;cursor:help;padding:0}
.header-search-help:hover{color:#e5e7eb;background:rgba(255,255,255,.14)}
.header-search-help [data-lucide]{width:15px;height:15px}
.header-search:focus-within{box-shadow:0 0 0 3px rgba(0,120,192,.25);border-radius:6px}
.header-search:focus-within .header-search-input,.header-search:focus-within .header-search-help{border-color:var(--c-primary)}

.app-header-right{display:flex;align-items:center;gap:.7rem;font-size:.85rem;flex-shrink:0}
.app-user{color:#cbd5e1}
/* Zahnrad-Klappmenü */
.app-menu{position:relative}
.app-menu-toggle{display:flex;align-items:center;gap:.4rem;height:34px;padding:0 .6rem;cursor:pointer;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);color:#e5e7eb;border-radius:var(--radius-sm);font-family:inherit;font-size:.85rem}
.app-menu-toggle:hover{background:rgba(255,255,255,.16)}
.app-menu-toggle .app-user-name{color:#e5e7eb;white-space:nowrap}
.app-menu-toggle .menu-caret{width:13px;height:13px;opacity:.7;transition:transform .15s}
.app-menu:has(.app-menu-dropdown.open) .menu-caret{transform:rotate(180deg)}
.app-menu-dropdown{display:none;position:absolute;right:0;top:calc(100% + 6px);min-width:230px;
  background:#fff;border:1px solid var(--c-border);box-shadow:var(--shadow-lg);border-radius:var(--radius-sm);padding:.3rem;z-index:1100}
.app-menu-dropdown.open{display:block}
.menu-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .6rem;color:var(--c-text);font-size:.85rem;cursor:pointer;border-radius:var(--radius-sm);text-decoration:none}
.menu-item:hover{background:var(--c-surface-3);text-decoration:none}
.menu-item [data-lucide]{width:16px;height:16px;color:var(--c-muted)}
.menu-divider{height:1px;background:var(--c-border);margin:.3rem .2rem}
.app-header .btn{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.15);color:#e5e7eb}
.app-header .btn:hover{background:rgba(255,255,255,.16)}
/* Burger nur mobil sichtbar */
.sidebar-burger{display:none;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);color:#e5e7eb;
  width:34px;height:34px;border-radius:var(--radius-sm);cursor:pointer;align-items:center;justify-content:center}

/* --- Layout: Sidebar + Content --- */
.app-layout{display:flex;padding-top:var(--header-h);min-height:100vh}
.app-sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--c-surface);border-right:1px solid var(--c-border);
  height:calc(100vh - var(--header-h));position:fixed;top:var(--header-h);left:0;overflow-y:auto;padding:.5rem;z-index:800}
.sidebar-title{display:flex;align-items:center;justify-content:space-between;padding:.2rem .35rem .45rem;
  font-size:.72rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--c-muted-2)}
.sidebar-collapse{background:none;border:none;color:var(--c-muted-2);cursor:pointer;padding:2px;display:flex;align-items:center}
.sidebar-collapse:hover{color:var(--c-primary)}
.sidebar-empty{color:var(--c-muted-2);font-size:.82rem;padding:.4rem}
.app-content{flex:1;margin-left:var(--sidebar-w);padding:0;width:100%;min-width:0;display:flex;flex-direction:column;gap:.7rem}
.sidebar-backdrop{display:none;position:fixed;inset:var(--header-h) 0 0 0;background:rgba(15,23,42,.4);z-index:790}

/* --- Klapp-Baum (Navigation) --- */
.wf-tree,.wf-children{list-style:none;margin:0;padding:0}
.wf-children{display:none;margin-left:.6rem;padding-left:.35rem;border-left:1px solid var(--c-border)}
.wf-node.open>.wf-children{display:block}
.wf-node-row{display:flex;align-items:center;gap:.1rem;border-radius:var(--radius-sm);cursor:pointer}
.wf-node-row:hover{background:var(--c-surface-3)}
.wf-toggle{background:none;border:none;cursor:pointer;color:var(--c-muted-2);padding:.25rem;display:flex;align-items:center;flex-shrink:0}
.wf-toggle [data-lucide]{width:14px;height:14px;transition:transform .15s}
.wf-node.open>.wf-node-row .wf-toggle [data-lucide]{transform:rotate(90deg)}
.wf-toggle-spacer{width:24px;flex-shrink:0}
.wf-node-label{display:flex;align-items:center;gap:.4rem;padding:.3rem .35rem;color:var(--c-text);font-size:.85rem;flex:1;min-width:0;user-select:none}
.wf-node-label [data-lucide]{width:15px;height:15px;color:var(--c-muted);flex-shrink:0}
.wf-node-label.active{color:var(--c-primary);font-weight:600}

/* --- Sidebar ganz einklappen (Desktop) --- */
.nav-reopen{display:none;position:fixed;left:0;top:calc(var(--header-h) + .4rem);z-index:810;width:22px;height:36px;
  background:var(--c-surface);border:1px solid var(--c-border);border-left:none;
  border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:var(--c-muted);cursor:pointer;align-items:center;justify-content:center}
.nav-reopen [data-lucide]{width:15px;height:15px}
@media(min-width:769px){
  .app-layout.nav-collapsed .app-sidebar{display:none}
  .app-layout.nav-collapsed .app-content{margin-left:0}
  .app-layout.nav-collapsed .nav-reopen{display:flex}
}

/* --- Kategorie-Übersicht (Sitemap an Hauptknoten) --- */
.wf-breadcrumb{display:flex;align-items:center;gap:.35rem;font-size:.8rem;color:var(--c-muted);padding:.45rem .2rem}
.wf-breadcrumb a{color:var(--c-primary)}
.wf-breadcrumb .sep{color:var(--c-muted-2)}
.wf-breadcrumb .current{color:var(--c-text);font-weight:600}
.wf-section-label{font-size:.72rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--c-muted-2);margin:.2rem 0 .5rem}
.wf-section-label:not(:first-child){margin-top:1.1rem}
.wf-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:.6rem}
.wf-cat-card{display:flex;align-items:center;gap:.6rem;padding:.6rem .7rem;border:1px solid var(--c-border);
  background:var(--c-surface);text-decoration:none;color:var(--c-text);transition:border-color .12s,background .12s;cursor:pointer}
.wf-cat-card:hover{border-color:var(--c-primary);background:var(--c-surface-2);text-decoration:none}
.wf-cat-ic{width:34px;height:34px;flex-shrink:0;display:flex;align-items:center;justify-content:center;
  background:var(--c-surface-3);color:var(--c-primary);border-radius:var(--radius-sm)}
.wf-cat-ic [data-lucide]{width:18px;height:18px}
.wf-cat-meta{display:flex;flex-direction:column;min-width:0}
.wf-cat-meta strong{font-size:.9rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wf-cat-meta span{font-size:.76rem;color:var(--c-muted)}
.wf-entry-list{list-style:none;margin:0;padding:0}
.wf-entry{display:flex;align-items:center;gap:.6rem;padding:.45rem .35rem;border-bottom:1px solid var(--c-border);cursor:pointer}
.wf-entry:last-child{border-bottom:none}
.wf-entry:hover{background:var(--c-surface-3)}
.wf-entry-title{flex:1;min-width:0;font-size:.88rem;color:var(--c-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wf-entry-meta{font-size:.76rem;color:var(--c-muted-2);white-space:nowrap}
.badge-anleitung{background:#e0f2fe;color:#0369a1}
.badge-bestpractice{background:#dcfce7;color:#15803d}
.badge-arbeitsanweisung{background:#fee2e2;color:#b91c1c}
.badge-workflow{background:#ede9fe;color:#6d28d9}

/* --- Formular-Aktionen / Checkbox --- */
.form-actions{display:flex;align-items:center;gap:.5rem;margin-top:1rem;flex-wrap:wrap}
.form-actions-spacer{flex:1}
.checkbox-line{display:flex;align-items:center;gap:.45rem;height:32px}
.checkbox-line input[type=checkbox]{width:16px;height:16px}
.checkbox-label{font-size:.85rem;color:var(--c-text);font-weight:400;margin:0}

/* --- Tabellen-Zeilenaktionen --- */
.wf-row-actions{white-space:nowrap;text-align:right}
.wf-row-actions .btn{padding:.25rem .4rem}
.wf-row-actions .btn [data-lucide]{width:15px;height:15px}

/* --- Sidebar-Verwaltungsbereich --- */
.sidebar-title-mt{margin-top:.6rem;border-top:1px solid var(--c-border)}
.nav-link{cursor:pointer}
.nav-link.active{color:var(--c-primary);font-weight:600;background:var(--c-surface-3)}

/* --- Rechte-Matrix --- */
.matrix-table th.matrix-role{text-align:center;white-space:nowrap}
.matrix-table .matrix-cell{text-align:center}
.matrix-table .matrix-cell input{width:16px;height:16px}
.matrix-group td{background:var(--c-surface-2);font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.4px;color:var(--c-muted)}
.matrix-key{font-family:var(--mono);font-size:.72rem;color:var(--c-muted-2)}
.matrix-note{display:flex;align-items:center;gap:.4rem;margin-top:.8rem;font-size:.8rem;color:var(--c-muted)}
.matrix-note [data-lucide]{width:15px;height:15px;flex-shrink:0;color:var(--c-primary)}

/* --- Kategorie-Verwaltung / Dialoge --- */
.kat-indent{display:inline-flex;align-items:center;gap:.35rem}
.kat-indent-1{padding-left:1.2rem}.kat-indent-2{padding-left:2.4rem}
.kat-indent-3{padding-left:3.6rem}.kat-indent-4{padding-left:4.8rem}.kat-indent-5{padding-left:6rem}
.kat-empty{padding:1rem;color:var(--c-muted-2);font-size:.85rem}
.radio-line{display:flex;align-items:center;gap:.45rem;margin-bottom:.4rem}
.radio-line input{width:16px;height:16px;flex-shrink:0}
.wf-node-label [data-lucide="lock"]{color:var(--c-danger)}

/* --- Einträge / Editor --- */
.wf-section-head{display:flex;align-items:center;justify-content:space-between;margin-top:1.1rem;margin-bottom:.5rem}
.wf-section-head .wf-section-label{margin:0}
.gjs-hidden{display:none}
.gjs-blocks{display:flex;flex-wrap:wrap;gap:.3rem;margin-bottom:.4rem}
.gjs-editor{border:1px solid var(--c-border-2);border-radius:var(--radius)}
.eintrag-inhalt{font-size:.95rem;line-height:1.6}
.eintrag-inhalt h1,.eintrag-inhalt h2,.eintrag-inhalt h3{margin:.8rem 0 .4rem}
.eintrag-inhalt p{margin:.5rem 0}
.eintrag-inhalt ul,.eintrag-inhalt ol{margin:.5rem 0 .5rem 1.4rem}
.eintrag-inhalt pre{background:#0b1220;color:#e2e8f0;padding:.8rem;border-radius:var(--radius);overflow:auto;font-family:var(--mono);font-size:.85rem}
.eintrag-inhalt hr{border:none;border-top:1px solid var(--c-border);margin:1rem 0}
.wf-box{padding:.7rem .9rem;border-radius:var(--radius);margin:.6rem 0;border-left:4px solid}
.wf-box-hint,.wf-box-info{background:#eff6ff;border-color:var(--c-primary)}
.wf-box-warn,.wf-box-warnung{background:#fef2f2;border-color:var(--c-danger)}
.wf-box-erfolg{background:#f0fdf4;border-color:var(--c-teal)}
.wf-box-tipp{background:#fffbeb;border-color:#eab308}
.wf-figure{margin:.6rem 0}.wf-figure img{max-width:100%;height:auto;border-radius:var(--radius)}
.wf-figure figcaption{font-size:.8rem;color:var(--c-muted);margin-top:.3rem}
.wf-code{background:#0b1220;color:#e2e8f0;padding:.8rem;border-radius:var(--radius);overflow:auto;font-family:var(--mono);font-size:.85rem}
.wf-hr{border:none;border-top:1px solid var(--c-border);margin:1rem 0}
.element-preview{border:1px dashed var(--c-border-2);border-radius:var(--radius);padding:1rem;background:var(--c-surface-2)}
/* Template-Builder */
.tpl-el{border:1px solid var(--c-border);border-radius:var(--radius);margin-bottom:.6rem;overflow:hidden}
.tpl-el-head{display:flex;align-items:center;justify-content:space-between;padding:.4rem .6rem;background:var(--c-surface-2);border-bottom:1px solid var(--c-border)}
.tpl-el-name{font-size:.85rem;font-weight:600;display:flex;align-items:center;gap:.4rem}
.tpl-el-body{padding:.7rem .8rem}
.tpl-palette{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.4rem}
.tpl-palette-btn{display:flex;flex-direction:column;align-items:center;gap:.3rem;width:96px;padding:.7rem .4rem;
  border:1px solid var(--c-border-2);border-radius:var(--radius);background:var(--c-surface);cursor:pointer;
  font-size:.75rem;color:var(--c-text);text-align:center;transition:border-color .12s,background .12s}
.tpl-palette-btn:hover{border-color:var(--c-primary);background:var(--c-surface-2)}
.tpl-palette-btn [data-lucide]{width:20px;height:20px;color:var(--c-primary)}

/* --- Notifications --- */
.notifications{position:fixed;bottom:.9rem;right:.9rem;z-index:2000;display:flex;flex-direction:column;gap:.45rem}
.note{padding:.6rem .9rem;border-radius:var(--radius-sm);background:#fff;box-shadow:var(--shadow-lg);font-size:.85rem;border-left:4px solid var(--c-primary);opacity:1;transition:opacity .3s}
.note-ok{border-left-color:var(--c-teal)} .note-error{border-left-color:var(--c-danger)}
.note-out{opacity:0}
.note-persist{padding-right:1.8rem;max-width:340px}
.note-close{position:absolute;top:.3rem;right:.5rem;cursor:pointer;color:var(--c-muted-2);font-size:1rem;line-height:1}
.note-close:hover{color:var(--c-text)}
.note{position:relative}

/* --- Fehlerseite --- */
.errorpage{max-width:720px;margin:3rem auto;padding:1.8rem;text-align:center}
.errorpage-detail{text-align:left;background:#f5f5f5;padding:.9rem;border-radius:var(--radius-sm);margin-top:1.2rem;font-family:var(--mono);font-size:.8rem;overflow:auto}

/* ============================================================
   RESPONSIVE (v2-Breakpoints)
   ============================================================ */
@media(max-width:1024px){
  :root{--sidebar-w:var(--sidebar-w-md)}
  .app-content{margin-left:var(--sidebar-w-md)}
}
@media(max-width:768px){
  .sidebar-burger{display:inline-flex}
  .app-sidebar{transform:translateX(-100%);transition:transform .2s ease;width:280px;box-shadow:2px 0 8px rgba(0,0,0,.15)}
  .app-sidebar.open{transform:translateX(0)}
  .app-content{margin-left:0}
  .sidebar-backdrop.show{display:block}
  .app-title{font-size:.9rem}
  .app-user{display:none}
}
@media(max-width:600px){
  .form-row,.form-row-3{grid-template-columns:1fr}
  .auth-card{padding:1.4rem}
  .app-menu-toggle .app-user-name{display:none}
}
