*{margin:0;padding:0;box-sizing:border-box}:root{--qims-primary: #38bdf8;--qims-primary-hover: #0ea5e9;--qims-primary-active: #0284c7;--qims-primary-ring: rgba(56,189,248,.2);--qims-primary-text: #38bdf8;--qims-confirm: #22c55e;--qims-confirm-hover: #16a34a;--qims-confirm-active: #15803d;--qims-confirm-ring: rgba(34,197,94,.2);--qims-confirm-text: #0f172a;--qims-bg: #0f172a;--qims-surface: #1e293b;--qims-surface-2: #334155;--qims-surface-hover: #3f526a;--qims-text-muted: #64748b;--qims-text-on-primary: #0f172a;--qims-border-subtle: #475569;--qims-ok-text: #4ade80;--qims-ok-bg: #14532d;--qims-ok-border: #166534;--qims-ok-dot: #22c55e;--qims-nok-text: #f87171;--qims-nok-bg: #450a0a;--qims-nok-border: #7f1d1d;--qims-nok-dot: #ef4444;--qims-gz-text: #fbbf24;--qims-gz-bg: #451a03;--qims-gz-border: #78350f;--qims-gz-dot: #f59e0b;--qims-info-text: #60a5fa;--qims-info-bg: #172554;--qims-info-border: #1d4ed8;--qims-info-dot: #3b82f6;--qims-critical-text: #fca5a5;--qims-critical-bg: #450a0a;--qims-critical-border: #dc2626;--qims-red: #38bdf8;--qims-dark: #0f172a;--qims-gray: #334155;--qims-light-gray: #1e293b;--qims-border: #334155;--qims-text: #f1f5f9;--qims-label: #94a3b8}html{background-color:#0f172a}body{font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-size:14px;background-color:var(--qims-bg);color:var(--qims-text);padding:0;margin:0}#app{width:100%;min-height:100vh;display:flex;flex-direction:column}.app-header{background-color:var(--qims-bg);padding:14px 24px;display:flex;align-items:center;gap:14px}.app-header .logo-text{font-size:22px;font-weight:700;color:#fff;letter-spacing:2px;text-transform:uppercase}.app-header .header-divider{width:2px;height:24px;background-color:var(--qims-primary)}.app-header .header-subtitle{font-size:14px;font-weight:400;color:#94a3b8;letter-spacing:.5px}.main-content{padding:24px;flex:1;display:flex;flex-direction:column}.toolbar{display:flex;gap:12px;margin-bottom:16px;align-items:center;flex-wrap:wrap}.toolbar input[type=text]{height:36px;padding:4px 12px;border:1px solid var(--qims-border);border-radius:4px;font-size:14px;font-family:inherit;min-width:280px;background-color:var(--qims-surface);color:var(--qims-text)}.toolbar input[type=text]:focus{outline:none;border-color:var(--qims-primary);box-shadow:0 0 0 2px var(--qims-primary-ring)}.toolbar .btn{height:36px;padding:0 20px;border:1px solid var(--qims-border);background-color:var(--qims-surface);font-size:14px;font-family:inherit;font-weight:500;cursor:pointer;border-radius:4px;transition:all .15s ease;color:var(--qims-text)}.toolbar .btn:hover{background-color:var(--qims-surface-2);border-color:var(--qims-border-subtle)}.toolbar .btn-primary{background-color:var(--qims-primary);color:var(--qims-text-on-primary);border:none}.toolbar .btn-primary:hover{background-color:var(--qims-primary-hover)}.btn-confirm{background:var(--qims-confirm);color:var(--qims-confirm-text);border:none;border-radius:6px;padding:8px 16px;font-weight:500;cursor:pointer;transition:background .15s}.btn-confirm:hover{background:var(--qims-confirm-hover)}.btn-confirm:active{background:var(--qims-confirm-active)}.btn-confirm:focus{outline:none;box-shadow:0 0 0 3px var(--qims-confirm-ring)}.btn-confirm:disabled{background:var(--qims-surface-2);color:var(--qims-text-muted);cursor:not-allowed}.toolbar .count{margin-left:auto;font-size:13px;color:var(--qims-label)}.context-menu{position:fixed;background:var(--qims-surface);border:1px solid var(--qims-border);border-radius:6px;padding:4px;box-shadow:0 4px 16px #0006;z-index:200;min-width:160px}.context-menu-item{display:flex;align-items:center;gap:10px;padding:8px 12px;font-size:13px;cursor:pointer;border-radius:4px;color:var(--qims-text);transition:background .1s}.context-menu-item:hover{background:var(--qims-surface-2)}.context-menu-item.ok:hover{background:#14532d}.context-menu-item.nok:hover{background:#450a0a}.context-menu-item.gz:hover{background:#451a03}.context-menu-group-label{padding:6px 12px 4px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--qims-label)}.context-menu-divider{height:1px;background:#334155;margin:4px 0}.dot{width:10px;height:10px;border-radius:50%;display:inline-block}.dot-ok{background:#22c55e}.dot-nok{background:#ef4444}.dot-gz{background:#f59e0b}.dot-clear{background:#475569}.badge-ok{background:#14532d;color:#4ade80;border:1px solid #166534}.badge-nok{background:#450a0a;color:#f87171;border:1px solid #7f1d1d}.badge-gz{background:#451a03;color:#fbbf24;border:1px solid #78350f}tbody tr.row-ok{border-left:3px solid #22c55e}tbody tr.row-nok{border-left:3px solid #ef4444}tbody tr.row-gz{border-left:3px solid #f59e0b}thead th{position:relative}.th-label{cursor:pointer}.th-filter-btn{background:none;border:1px solid rgba(255,255,255,.25);border-radius:3px;color:#ffffff80;cursor:pointer;font-size:11px;padding:2px 5px;margin-left:6px;vertical-align:middle;transition:all .15s}.th-filter-btn:after{content:"\2ae7"}.th-filter-btn:hover{color:#fff;background:rgba(255,255,255,.15);border-color:#fff6}.th-filter-btn.filtered{color:#fff;background:#fbbf24;border-color:#fbbf24}th.filtered{background-color:#3f526a!important}.col-filter-dropdown{background:var(--qims-surface);border:1px solid var(--qims-border);border-radius:6px;box-shadow:0 4px 16px #0006;z-index:200;min-width:200px;max-width:300px;padding:8px}.col-filter-header{display:flex;gap:4px;margin-bottom:6px;padding-bottom:6px;border-bottom:1px solid #334155}.col-filter-header button{padding:3px 8px;border:1px solid var(--qims-border);border-radius:3px;background:var(--qims-surface);font-size:11px;cursor:pointer;color:var(--qims-text)}.col-filter-header button:hover{background:var(--qims-surface-2)}.col-filter-clear{color:var(--qims-primary)!important;border-color:var(--qims-primary)!important}.col-filter-list{max-height:250px;overflow-y:auto}.col-filter-item{display:flex;align-items:center;gap:6px;padding:3px 4px;font-size:12px;cursor:pointer;border-radius:3px;color:var(--qims-text)}.col-filter-item:hover{background:var(--qims-surface-hover)}.col-filter-item input[type=checkbox]{accent-color:var(--qims-primary)}.col-filter-item span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px}.col-filter-apply{display:block;width:100%;margin-top:6px;padding:6px;background:var(--qims-primary);color:var(--qims-text-on-primary);border:none;border-radius:4px;font-size:12px;font-family:inherit;font-weight:500;cursor:pointer}.col-filter-apply:hover{background:var(--qims-primary-hover)}.user-input-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.65);display:flex;align-items:center;justify-content:center;z-index:300}.user-input-modal{background:var(--qims-surface);border-radius:8px;padding:24px;width:400px;box-shadow:0 8px 30px #00000080}.user-input-modal h3{font-size:16px;font-weight:700;color:var(--qims-text);margin-bottom:16px}.user-input-field{margin-bottom:16px}.user-input-field label{display:block;font-size:11px;font-weight:500;color:var(--qims-label);text-transform:uppercase;letter-spacing:.3px;margin-bottom:4px}.user-input-field input,.user-input-field select,.user-input-field textarea{width:100%;padding:8px 10px;border:1px solid var(--qims-border);border-radius:4px;font-size:14px;font-family:inherit;box-sizing:border-box;background-color:var(--qims-surface);color:var(--qims-text)}.user-input-field input:focus,.user-input-field select:focus,.user-input-field textarea:focus{outline:none;border-color:var(--qims-primary);box-shadow:0 0 0 2px var(--qims-primary-ring)}.user-input-buttons{display:flex;gap:8px;justify-content:flex-end}.user-input-buttons button{padding:8px 20px;border-radius:4px;font-size:13px;font-family:inherit;font-weight:500;cursor:pointer}.ui-cancel{border:1px solid var(--qims-border);background:var(--qims-surface);color:var(--qims-text)}.ui-confirm{background:var(--qims-primary);color:var(--qims-text-on-primary);border:none}.ui-confirm:hover{background:var(--qims-primary-hover)}.ui-button-group{display:flex;flex-direction:column;gap:8px}.ui-option-btn{width:100%;padding:14px 20px;border:2px solid var(--qims-border);border-radius:8px;background:var(--qims-surface);font-size:15px;font-family:inherit;font-weight:500;color:var(--qims-text);cursor:pointer;transition:all .15s;text-align:left}.ui-option-btn:hover{border-color:var(--qims-primary);background:#1e3a5f}.ui-option-btn:active{background:#172554}.column-toggle-wrapper{position:relative}.column-toggle-menu{position:absolute;top:100%;left:0;margin-top:4px;background:var(--qims-surface);border:1px solid var(--qims-border);border-radius:6px;padding:8px 4px;box-shadow:0 4px 12px #0006;z-index:50;min-width:200px;max-height:400px;overflow-y:auto}.column-toggle-item{display:flex;align-items:center;gap:8px;padding:5px 10px;font-size:13px;cursor:pointer;border-radius:3px;color:var(--qims-text)}.column-toggle-item:hover{background:var(--qims-surface-hover)}.column-toggle-item input[type=checkbox]{accent-color:var(--qims-primary)}.table-container{flex:1;background-color:var(--qims-surface);border-radius:6px;box-shadow:0 1px 4px #0006;overflow:auto}table{width:100%;border-collapse:collapse;font-size:13px}thead{position:sticky;top:0;z-index:1}thead th{background-color:var(--qims-surface-2);color:var(--qims-text);padding:10px 12px;text-align:left;font-weight:500;font-size:12px;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;cursor:pointer;user-select:none}thead th:hover{background-color:#3f526a}thead th.sorted-asc:after{content:" \25b2";font-size:10px}thead th.sorted-desc:after{content:" \25bc";font-size:10px}tbody tr{border-bottom:1px solid #334155;transition:background-color .1s ease}tbody tr:hover{background-color:#3f526a!important;cursor:pointer}tbody tr:hover td{color:var(--qims-text)}tbody tr:nth-child(even){background-color:#243247}tbody tr:nth-child(even):hover{background-color:#3f526a}tbody td{padding:8px 12px;white-space:nowrap}.badge{display:inline-block;padding:2px 8px;border-radius:3px;font-size:11px;font-weight:500}.badge-ja{background-color:#14532d;color:#4ade80;border:1px solid #166534}.badge-nein{background-color:#450a0a;color:#f87171;border:1px solid #7f1d1d}.btn-delete{background:none;border:none;color:var(--qims-label);cursor:pointer;font-size:16px;padding:2px 6px;border-radius:3px}.btn-delete:hover{background-color:#450a0a;color:#f87171}.empty-state{text-align:center;padding:60px 20px;color:var(--qims-label)}.empty-state .icon{font-size:48px;margin-bottom:16px;opacity:.3}.empty-state p{font-size:16px}.tab-bar{display:flex;background-color:var(--qims-surface);border-bottom:2px solid #334155;padding:0 24px}.tab{padding:10px 24px;border:none;background:none;font-size:14px;font-family:inherit;font-weight:500;color:var(--qims-label);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s ease}.tab:hover{color:var(--qims-text)}.tab.active{color:var(--qims-primary);border-bottom-color:var(--qims-primary)}.dropdown-manager{display:flex;gap:24px;flex:1}.kategorie-sidebar{width:240px;flex-shrink:0;background-color:var(--qims-surface);border-radius:6px;box-shadow:0 1px 4px #0006;padding:16px 0}.kategorie-sidebar h3{font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.4px;color:var(--qims-label);padding:0 16px 12px;border-bottom:1px solid #334155}#kategorieList{list-style:none;padding:8px 0}#kategorieList li{padding:10px 16px;cursor:pointer;font-size:14px;color:var(--qims-text);transition:all .1s ease;border-left:3px solid transparent}#kategorieList li:hover{background-color:var(--qims-surface-2)}#kategorieList li.active{background-color:#172554;color:var(--qims-primary);border-left-color:var(--qims-primary);font-weight:500}.kategorie-content{flex:1;background-color:var(--qims-surface);border-radius:6px;box-shadow:0 1px 4px #0006;padding:20px 24px;display:flex;flex-direction:column}.kategorie-header h3{font-size:18px;font-weight:700;color:var(--qims-text);margin-bottom:16px}.add-row{display:flex;gap:10px;margin-bottom:20px}.add-row input[type=text]{flex:1;height:36px;padding:4px 12px;border:1px solid var(--qims-border);border-radius:4px;font-size:14px;font-family:inherit;background-color:var(--qims-surface);color:var(--qims-text)}.add-row input[type=text]:focus{outline:none;border-color:var(--qims-primary);box-shadow:0 0 0 2px var(--qims-primary-ring)}.add-row .btn{height:36px;padding:0 20px;font-size:14px;font-family:inherit;font-weight:500;cursor:pointer;border-radius:4px;transition:all .15s ease}.add-row .btn-primary{background-color:var(--qims-primary);color:var(--qims-text-on-primary);border:none}.add-row .btn-primary:hover{background-color:var(--qims-primary-hover)}.werte-list{flex:1}.wert-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid #334155;transition:background-color .1s ease}.wert-item:hover{background-color:var(--qims-surface-hover)}.wert-text{font-size:14px;color:var(--qims-text)}.werte-list .empty,.werte-list .error,.werte-list .loading{text-align:center;padding:40px 20px;color:var(--qims-label);font-size:14px}.werte-list .error{color:var(--qims-nok-text)}.status-bar{padding:6px 24px;font-size:12px;color:var(--qims-label);background-color:#334155;border-top:1px solid #475569}.status-bar.connected{color:#4ade80}.status-bar.disconnected{color:#f87171;font-weight:500}.critical-banner{background:#450a0a;border:1px solid #dc2626;border-radius:6px;padding:12px 16px;color:#fca5a5;font-weight:500;display:flex;align-items:center;gap:10px}.critical-banner .icon{color:#dc2626;font-size:16px;flex-shrink:0}.login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--qims-bg)}.login-card{background:var(--qims-surface);border:1px solid var(--qims-border);border-radius:12px;padding:40px;width:420px;max-width:92vw}.login-logo{text-align:center;margin-bottom:32px}.login-logo-text{display:block;font-size:32px;font-weight:700;letter-spacing:4px;color:#fff}.login-logo-sub{display:block;font-size:13px;color:var(--qims-label);margin-top:4px;letter-spacing:.5px}.login-error-banner{background:#450a0a;border:1px solid #7f1d1d;border-radius:6px;padding:12px 16px;color:#fca5a5;font-size:13px;margin-bottom:20px;display:flex;align-items:flex-start;gap:8px}.login-form{display:flex;flex-direction:column;gap:16px}.login-field label{display:block;font-size:13px;color:var(--qims-label);margin-bottom:6px;font-weight:500}.login-field input{width:100%;height:52px;padding:0 16px;background:var(--qims-bg);border:1px solid var(--qims-border);border-radius:8px;color:var(--qims-text);font-size:15px;outline:none;transition:border-color .15s}.login-field input:focus{border-color:var(--qims-primary);box-shadow:0 0 0 3px var(--qims-primary-ring)}.login-pw-wrap{position:relative}.login-pw-wrap input{padding-right:48px}.login-pw-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--qims-label);font-size:16px;padding:4px;line-height:1}.login-btn{height:52px;background:var(--qims-primary);color:var(--qims-text-on-primary);border:none;border-radius:8px;font-size:15px;font-weight:700;letter-spacing:1px;cursor:pointer;transition:background .15s;margin-top:4px}.login-btn:hover:not(:disabled){background:var(--qims-primary-hover)}.login-btn:disabled{opacity:.5;cursor:not-allowed}.login-footer{text-align:center;margin-top:24px}.login-server-status{font-size:12px;color:var(--qims-text-muted)}.login-server-status.ok{color:var(--qims-ok-text)}.login-server-status.err{color:var(--qims-nok-text)}.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:4px;vertical-align:middle}.ok-dot{background:var(--qims-ok-dot)}.err-dot{background:var(--qims-nok-dot)}.header-spacer{flex:1}.profile-chip{display:flex;align-items:center;gap:8px;background:var(--qims-surface);border:1px solid var(--qims-border);border-radius:20px;padding:6px 14px;cursor:pointer;user-select:none;transition:background .15s}.profile-chip:hover{background:var(--qims-surface-2)}.profile-name{font-size:13px;color:var(--qims-text);font-weight:500}.role-badge{font-size:11px;font-weight:700;padding:2px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.5px}.role-viewer{background:#334155;color:#94a3b8}.role-operator{background:rgba(56,189,248,.15);color:#38bdf8}.role-supervisor{background:rgba(251,146,60,.15);color:#fb923c}.role-admin{background:rgba(248,113,113,.15);color:#f87171}.profile-caret{font-size:10px;color:var(--qims-label)}.profile-dropdown{position:fixed;background:var(--qims-surface);border:1px solid var(--qims-border);border-radius:8px;min-width:200px;box-shadow:0 8px 24px #0006;z-index:9000;overflow:hidden}.profile-dropdown-header{padding:14px 16px}.profile-dropdown-name{font-weight:600;font-size:14px;color:var(--qims-text)}.profile-dropdown-role{font-size:12px;color:var(--qims-label);margin-top:2px}.profile-dropdown-divider{height:1px;background:var(--qims-border)}.profile-dropdown-item{display:block;width:100%;padding:12px 16px;background:none;border:none;color:var(--qims-text);font-size:14px;text-align:left;cursor:pointer;transition:background .1s}.profile-dropdown-item:hover{background:var(--qims-surface-2)}.profile-dropdown-logout{color:var(--qims-nok-text)}.fd-layout{display:flex;gap:16px;flex:1;min-height:0}.fd-sidebar{width:240px;flex-shrink:0;background:var(--qims-white);border-radius:6px;box-shadow:0 1px 4px #00000014;padding:12px;overflow-y:auto}.fd-sidebar h3{font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.4px;color:var(--qims-label);margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid #eee}.fd-pz-item{display:flex;align-items:center;gap:10px;padding:10px 12px;margin-bottom:6px;border:1px solid var(--qims-border);border-radius:6px;cursor:pointer;transition:all .15s ease;position:relative}.fd-pz-item:hover{border-color:#aaa;background:var(--qims-light-gray)}.fd-pz-item.selected{border-color:var(--qims-red);background:#fef0f3;box-shadow:0 0 0 2px #a500341a}.fd-pz-icon{width:36px;height:36px;border-radius:8px;background:var(--qims-red);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;flex-shrink:0}.fd-pz-info{flex:1;min-width:0}.fd-pz-name{font-size:13px;font-weight:600;color:var(--qims-dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fd-pz-steps{font-size:11px;color:var(--qims-label);margin-top:2px}.fd-pz-delete{position:absolute;top:6px;right:6px;background:none;border:none;color:#ccc;cursor:pointer;font-size:13px;padding:2px 4px;border-radius:3px;transition:all .15s}.fd-pz-delete:hover{color:var(--qims-red);background:#fce4ec}.fd-add-pz{width:100%;padding:10px;margin-top:8px;border:2px dashed var(--qims-border);border-radius:6px;background:transparent;cursor:pointer;font-size:13px;font-family:inherit;font-weight:500;color:var(--qims-label);transition:all .15s}.fd-add-pz:hover{border-color:var(--qims-red);color:var(--qims-red);background:#fef8f9}.fd-canvas-wrapper{flex:1;background:var(--qims-white);border-radius:6px;box-shadow:0 1px 4px #00000014;overflow-y:auto;min-height:0;display:flex;flex-direction:column}.fd-toolbar{padding:10px 16px;border-bottom:1px solid #eee;display:flex;align-items:center;gap:12px}.fd-toolbar input{font-size:16px;font-weight:600;border:1px solid transparent;padding:4px 8px;border-radius:4px;color:var(--qims-dark);font-family:inherit;flex:1}.fd-toolbar input:focus{outline:none;border-color:var(--qims-red)}.fd-toolbar-btns{display:flex;gap:6px;flex-shrink:0}.fd-toolbar-btns .btn{height:32px;padding:0 14px;border:1px solid var(--qims-border);background:var(--qims-white);font-size:13px;font-family:inherit;font-weight:500;cursor:pointer;border-radius:4px;color:var(--qims-text);transition:all .15s}.fd-toolbar-btns .btn:hover{background:var(--qims-light-gray)}.fd-toolbar-btns .btn-primary{background:var(--qims-red);color:#fff;border:none}.fd-toolbar-btns .btn-primary:hover{background:#8a002c}.fd-toolbar-btns .btn-activate{background:var(--qims-confirm);color:var(--qims-confirm-text);border:none}.fd-toolbar-btns .btn-activate:hover{background:var(--qims-confirm-hover)}.fd-canvas{padding:30px 40px;display:flex;flex-direction:column;align-items:center;min-height:500px;flex:1}.fd-empty{text-align:center;padding:60px 20px;color:#bbb;font-size:14px}.fd-step{width:380px;border:2px solid var(--qims-border);border-radius:8px;background:var(--qims-white);cursor:pointer;transition:all .15s;position:relative}.fd-step:hover{border-color:#aaa;box-shadow:0 2px 8px #00000014}.fd-step.selected{border-color:var(--qims-red);box-shadow:0 0 0 3px #a500341f}.fd-step-header{padding:12px 16px;display:flex;align-items:center;gap:12px;border-radius:6px}.fd-step-icon{width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;flex-shrink:0}.fd-step-info{flex:1;min-width:0}.fd-step-type{font-size:10px;text-transform:uppercase;letter-spacing:.3px;color:var(--qims-label)}.fd-step-title{font-size:14px;font-weight:600;color:var(--qims-dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fd-step-meta{font-size:11px;color:var(--qims-label);flex-shrink:0}.fd-step-delete{position:absolute;top:8px;right:8px;background:none;border:none;color:#ccc;cursor:pointer;font-size:14px;padding:2px 4px;border-radius:3px;opacity:0;transition:opacity .15s}.fd-step:hover .fd-step-delete{opacity:1}.fd-step-delete:hover{color:var(--qims-red);background:#fce4ec}.fd-connector{display:flex;flex-direction:column;align-items:center;padding:2px 0;position:relative}.fd-connector-line{width:2px;height:20px;background:var(--qims-border)}.fd-connector-arrow{width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:8px solid var(--qims-border)}.fd-add-step-btn{width:28px;height:28px;border-radius:50%;border:2px solid var(--qims-border);background:var(--qims-white);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--qims-label);transition:all .15s;margin:2px 0}.fd-add-step-btn:hover{border-color:var(--qims-red);color:var(--qims-red);background:#fef0f3}.fd-add-step-final{margin-top:16px;padding:10px 24px;border:2px dashed var(--qims-border);border-radius:8px;background:transparent;cursor:pointer;font-size:13px;font-family:inherit;font-weight:500;color:var(--qims-label);transition:all .15s}.fd-add-step-final:hover{border-color:var(--qims-red);color:var(--qims-red);background:#fef8f9}.fd-type-menu{position:absolute;left:50%;transform:translate(-50%);top:100%;background:#fff;border:1px solid #ddd;border-radius:6px;padding:6px;box-shadow:0 4px 12px #00000026;z-index:50;min-width:180px}.fd-type-menu-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:4px;cursor:pointer;font-size:13px;color:var(--qims-text);transition:background .1s}.fd-type-menu-item:hover{background:var(--qims-light-gray)}.fd-type-menu-icon{width:24px;height:24px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}.fd-properties{width:300px;flex-shrink:0;background:var(--qims-white);border-radius:6px;box-shadow:0 1px 4px #00000014;padding:16px;overflow-y:auto}.fd-properties h3{font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.4px;color:var(--qims-label);margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid #eee}.fd-prop-empty{text-align:center;padding:40px 16px;color:#bbb;font-size:13px}.fd-prop-group{margin-bottom:12px}.fd-prop-group label{display:block;font-size:11px;font-weight:500;color:var(--qims-label);text-transform:uppercase;letter-spacing:.3px;margin-bottom:4px}.fd-prop-group input[type=text],.fd-prop-group input[type=number],.fd-prop-group select,.fd-prop-group textarea{width:100%;padding:6px 8px;border:1px solid var(--qims-border);border-radius:4px;font-size:13px;font-family:inherit;color:var(--qims-text);box-sizing:border-box}.fd-prop-group textarea{min-height:60px;resize:vertical}.fd-prop-group input:focus,.fd-prop-group select:focus,.fd-prop-group textarea:focus{outline:none;border-color:var(--qims-red);box-shadow:0 0 0 2px #a500341f}.fd-prop-group .checkbox-row{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--qims-text)}.fd-prop-group .checkbox-row input[type=checkbox]{accent-color:var(--qims-red)}.fd-prop-back{display:block;margin-bottom:14px;padding:6px 10px;background:none;border:1px solid var(--qims-border);border-radius:4px;cursor:pointer;font-size:12px;font-family:inherit;color:var(--qims-label);transition:all .15s}.fd-prop-back:hover{border-color:var(--qims-red);color:var(--qims-red)}.fd-prop-delete{width:100%;margin-top:16px;padding:8px;border:1px solid #e57373;background:#fff;color:#c62828;border-radius:4px;cursor:pointer;font-size:13px;font-family:inherit;transition:all .15s}.fd-prop-delete:hover{background:#fce4ec}.fd-icon-picker{display:flex;gap:6px;flex-wrap:wrap}.fd-icon-opt{width:32px;height:32px;border-radius:6px;border:2px solid var(--qims-border);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;cursor:pointer;transition:all .15s;color:var(--qims-text)}.fd-icon-opt:hover{border-color:var(--qims-red);background:#fef0f3}.fd-icon-opt.selected{border-color:var(--qims-red);background:var(--qims-red);color:#fff}.fd-field-list{border:1px solid #eee;border-radius:4px;margin-bottom:8px;max-height:240px;overflow-y:auto}.fd-field-empty{text-align:center;padding:12px;color:#bbb;font-size:12px}.fd-field-item{display:flex;align-items:center;gap:8px;padding:6px 10px;border-bottom:1px solid #f0f0f0;cursor:pointer;transition:background .1s;font-size:13px}.fd-field-item:last-child{border-bottom:none}.fd-field-item:hover{background:var(--qims-light-gray)}.fd-field-item.selected{background:#fef0f3;border-left:3px solid var(--qims-red)}.fd-field-type-badge{width:22px;height:22px;border-radius:4px;background:#e8e8e8;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#555;flex-shrink:0}.fd-field-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--qims-text)}.fd-field-remove{background:none;border:none;color:#ccc;cursor:pointer;font-size:13px;padding:1px 4px;border-radius:3px;opacity:0;transition:opacity .15s}.fd-field-item:hover .fd-field-remove{opacity:1}.fd-field-remove:hover{color:var(--qims-red);background:#fce4ec}.fd-form-rows{margin-bottom:8px}.fd-form-row-label{display:flex;align-items:center;justify-content:space-between;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--qims-label);padding:6px 0 4px;margin-top:6px}.fd-row-remove{background:none;border:none;color:#ccc;cursor:pointer;font-size:12px;padding:1px 3px;border-radius:3px}.fd-row-remove:hover{color:var(--qims-red);background:#fce4ec}.fd-add-row-btn{width:100%;padding:6px;margin-top:6px;border:1px dashed var(--qims-border);border-radius:4px;background:transparent;cursor:pointer;font-size:12px;font-family:inherit;color:var(--qims-label);transition:all .15s}.fd-add-row-btn:hover{border-color:var(--qims-red);color:var(--qims-red)}.fd-field-toolbox{margin-top:10px;margin-bottom:10px}.fd-field-toolbox label{display:block;font-size:11px;font-weight:500;color:var(--qims-label);text-transform:uppercase;letter-spacing:.3px;margin-bottom:6px}.fd-field-toolbox-items{display:flex;gap:4px;flex-wrap:wrap}.fd-field-add-btn{width:34px;height:34px;border:1px solid var(--qims-border);border-radius:4px;background:var(--qims-white);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--qims-text);transition:all .15s}.fd-field-add-btn:hover{border-color:var(--qims-red);color:var(--qims-red);background:#fef0f3}.fd-auto-values textarea{font-family:monospace;font-size:12px;min-height:50px}.fd-dropdown-values{max-height:150px;overflow-y:auto;border:1px solid #eee;border-radius:4px;margin-bottom:6px}.fd-dropdown-values .empty,.fd-dropdown-values .loading,.fd-dropdown-values .error{text-align:center;padding:10px 8px;color:var(--qims-label);font-size:12px;margin:0}.fd-dropdown-values .error{color:var(--qims-red)}.fd-dd-value{display:flex;align-items:center;justify-content:space-between;padding:5px 8px;border-bottom:1px solid #f0f0f0;font-size:12px}.fd-dd-value:last-child{border-bottom:none}.fd-dd-value:hover{background:var(--qims-light-gray)}.fd-dd-del{background:none;border:none;color:#ccc;cursor:pointer;font-size:13px;padding:1px 4px;border-radius:3px}.fd-dd-del:hover{color:var(--qims-red);background:#fce4ec}.fd-dropdown-add{display:flex;gap:4px}.fd-dropdown-add input{flex:1;height:28px;padding:2px 8px;border:1px solid var(--qims-border);border-radius:4px;font-size:12px;font-family:inherit;box-sizing:border-box}.fd-dropdown-add input:focus{outline:none;border-color:var(--qims-red)}.fd-btn-add-dd{width:28px;height:28px;border:1px solid var(--qims-border);border-radius:4px;background:var(--qims-white);cursor:pointer;font-size:16px;color:var(--qims-text);display:flex;align-items:center;justify-content:center}.fd-btn-add-dd:hover{background:var(--qims-light-gray);border-color:var(--qims-red);color:var(--qims-red)}.fb-form-list{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;z-index:100}.fb-form-list-content{background:var(--qims-white);border-radius:8px;padding:24px;width:500px;max-height:70vh;overflow-y:auto;box-shadow:0 8px 30px #00000026}.fb-form-list-content h3{font-size:16px;font-weight:700;margin-bottom:16px;color:var(--qims-dark)}.fb-form-list-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border:1px solid #eee;border-radius:4px;margin-bottom:6px;cursor:pointer;transition:all .1s}.fb-form-list-item:hover{background:var(--qims-light-gray);border-color:var(--qims-border)}.fb-form-list-item .name{font-weight:500}.fb-form-list-item .meta{font-size:12px;color:var(--qims-label)}.fb-form-list-item .active-badge{font-size:11px;padding:2px 8px;background:#e8f5e9;color:#2e7d32;border-radius:3px;font-weight:500}.fb-form-list-close{margin-top:12px;width:100%;padding:8px;border:1px solid var(--qims-border);background:var(--qims-white);cursor:pointer;border-radius:4px;font-size:13px;font-family:inherit}.fb-form-list-close:hover{background:var(--qims-light-gray)}.workflow-builder{display:flex;gap:16px;flex:1;min-height:0}.wf-palette{width:200px;flex-shrink:0;display:flex;flex-direction:column;gap:12px}.wf-palette-panel{background:var(--qims-white);border-radius:6px;box-shadow:0 1px 4px #00000014;padding:12px}.wf-palette-panel h3{font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.4px;color:var(--qims-label);margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid #eee}.wf-palette-item{display:flex;align-items:center;gap:8px;padding:8px 10px;margin-bottom:4px;border:1px solid var(--qims-border);border-radius:4px;cursor:grab;font-size:13px;color:var(--qims-text);transition:all .15s;user-select:none}.wf-palette-item:hover{border-color:var(--qims-red);background:#fef0f3}.wf-palette-item .icon{width:24px;height:24px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}.wf-palette-item .icon.trigger{background:#1565c0}.wf-palette-item .icon.email{background:#2e7d32}.wf-palette-item .icon.delay{background:#ef6c00}.wf-palette-item .icon.condition{background:#7b1fa2}.wf-palette-item .icon.setvalue{background:#00838f}.wf-list-item{display:flex;align-items:center;gap:8px;padding:8px 10px;margin-bottom:4px;border:1px solid var(--qims-border);border-radius:4px;cursor:pointer;font-size:13px;transition:all .15s;position:relative}.wf-list-item:hover{border-color:#aaa;background:var(--qims-light-gray)}.wf-list-item.selected{border-color:var(--qims-red);background:#fef0f3}.wf-list-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--qims-text)}.wf-list-active{font-size:9px;font-weight:600;padding:2px 6px;background:#e8f5e9;color:#2e7d32;border-radius:3px;flex-shrink:0}.wf-list-delete{background:none;border:none;color:#ccc;cursor:pointer;font-size:13px;padding:1px 4px;border-radius:3px;opacity:0;transition:opacity .15s}.wf-list-item:hover .wf-list-delete{opacity:1}.wf-list-delete:hover{color:var(--qims-red);background:#fce4ec}.wf-add-wf-btn{width:100%;padding:8px;margin-top:6px;border:1px dashed var(--qims-border);border-radius:4px;background:transparent;cursor:pointer;font-size:12px;font-family:inherit;color:var(--qims-label);transition:all .15s}.wf-add-wf-btn:hover{border-color:var(--qims-red);color:var(--qims-red)}.wf-palette-item .icon.userinput{background:#6a1b9a}.wf-palette-item .icon.showtext{background:#0277bd}.wf-toolbar{display:flex;flex-direction:column;gap:6px}.wf-toolbar .btn{height:32px;padding:0 12px;border:1px solid var(--qims-border);background:var(--qims-white);font-size:13px;font-family:inherit;font-weight:500;cursor:pointer;border-radius:4px;color:var(--qims-text);transition:all .15s;text-align:center}.wf-toolbar .btn:hover{background:var(--qims-light-gray)}.wf-toolbar .btn-primary{background:var(--qims-red);color:#fff;border:none}.wf-toolbar .btn-primary:hover{background:#8a002c}.wf-canvas-wrapper{flex:1;background:var(--qims-white);border-radius:6px;box-shadow:0 1px 4px #00000014;overflow-y:auto;min-height:0}.wf-canvas-header{padding:12px 16px;border-bottom:1px solid #eee;display:flex;align-items:center}.wf-canvas-header input{font-size:16px;font-weight:600;border:1px solid transparent;padding:4px 8px;border-radius:4px;color:var(--qims-dark);font-family:inherit;flex:1}.wf-canvas-header input:focus{outline:none;border-color:var(--qims-red)}.wf-canvas{padding:30px 40px;display:flex;flex-direction:column;align-items:center;min-height:500px}.wf-node{width:340px;border:2px solid var(--qims-border);border-radius:8px;background:var(--qims-white);cursor:pointer;transition:all .15s;position:relative}.wf-node:hover{border-color:#aaa;box-shadow:0 2px 8px #00000014}.wf-node.selected{border-color:var(--qims-red);box-shadow:0 0 0 3px #a500341f}.wf-node-header{padding:10px 14px;display:flex;align-items:center;gap:10px;border-radius:6px 6px 0 0}.wf-node-header.trigger{background:#e3f2fd;border-bottom:2px solid #1565c0}.wf-node-header.email{background:#e8f5e9;border-bottom:2px solid #2e7d32}.wf-node-header.delay{background:#fff3e0;border-bottom:2px solid #ef6c00}.wf-node-header.condition{background:#f3e5f5;border-bottom:2px solid #7b1fa2}.wf-node-header.set_value,.wf-node-header.setvalue{background:#e0f7fa;border-bottom:2px solid #00838f}.wf-node-header.user_input,.wf-node-header.userinput{background:#f3e5f5;border-bottom:2px solid #6a1b9a}.wf-node-header.show_text,.wf-node-header.showtext{background:#e1f5fe;border-bottom:2px solid #0277bd}.wf-node-icon{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff}.wf-node-icon.trigger{background:#1565c0}.wf-node-icon.email{background:#2e7d32}.wf-node-icon.delay{background:#ef6c00}.wf-node-icon.condition{background:#7b1fa2}.wf-node-icon.set_value,.wf-node-icon.setvalue{background:#00838f}.wf-node-icon.user_input,.wf-node-icon.userinput{background:#6a1b9a}.wf-node-icon.show_text,.wf-node-icon.showtext{background:#0277bd}.wf-node-title{font-size:13px;font-weight:600;color:var(--qims-dark)}.wf-node-type{font-size:10px;text-transform:uppercase;letter-spacing:.3px;color:var(--qims-label)}.wf-node-body{padding:10px 14px;font-size:12px;color:var(--qims-label);min-height:30px}.wf-node-delete{position:absolute;top:8px;right:8px;background:none;border:none;color:#ccc;cursor:pointer;font-size:14px;padding:2px 4px;border-radius:3px;opacity:0;transition:opacity .15s}.wf-node:hover .wf-node-delete{opacity:1}.wf-node-delete:hover{color:var(--qims-red);background:#fce4ec}.wf-connector{display:flex;flex-direction:column;align-items:center;padding:4px 0}.wf-connector-line{width:2px;height:24px;background:var(--qims-border)}.wf-connector-arrow{width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:8px solid var(--qims-border)}.wf-add-btn{width:28px;height:28px;border-radius:50%;border:2px solid var(--qims-border);background:var(--qims-white);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--qims-label);transition:all .15s;margin:4px 0}.wf-add-btn:hover{border-color:var(--qims-red);color:var(--qims-red);background:#fef0f3}.wf-branches{display:flex;gap:40px;align-items:flex-start;position:relative}.wf-branch{display:flex;flex-direction:column;align-items:center}.wf-branch-label{font-size:11px;font-weight:600;padding:3px 12px;border-radius:10px;margin-bottom:4px}.wf-branch-label.yes{background:#e8f5e9;color:#2e7d32}.wf-branch-label.no{background:#fce4ec;color:#c62828}.wf-dropzone{width:340px;border:2px dashed #d0d0d0;border-radius:8px;padding:20px;text-align:center;color:#bbb;font-size:13px;transition:all .15s;margin-top:8px}.wf-dropzone.drag-over{border-color:var(--qims-red);background:#fef8f9;color:var(--qims-red)}.wf-properties{width:300px;flex-shrink:0;background:var(--qims-white);border-radius:6px;box-shadow:0 1px 4px #00000014;padding:16px;overflow-y:auto}.wf-properties h3{font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.4px;color:var(--qims-label);margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid #eee}.wf-prop-group{margin-bottom:12px}.wf-prop-group label{display:block;font-size:11px;font-weight:500;color:var(--qims-label);text-transform:uppercase;letter-spacing:.3px;margin-bottom:4px}.wf-prop-group input[type=text],.wf-prop-group input[type=number],.wf-prop-group select,.wf-prop-group textarea{width:100%;padding:6px 8px;border:1px solid var(--qims-border);border-radius:4px;font-size:13px;font-family:inherit;color:var(--qims-text)}.wf-prop-group textarea{min-height:80px;resize:vertical}.wf-prop-group input:focus,.wf-prop-group select:focus,.wf-prop-group textarea:focus{outline:none;border-color:var(--qims-red);box-shadow:0 0 0 2px #a500341f}.wf-prop-row{display:flex;gap:8px}.wf-prop-row .wf-prop-group{flex:1}.wf-prop-empty{text-align:center;padding:40px 16px;color:#bbb;font-size:13px}.wf-prop-delete{width:100%;margin-top:16px;padding:8px;border:1px solid #e57373;background:#fff;color:#c62828;border-radius:4px;cursor:pointer;font-size:13px;font-family:inherit}.wf-prop-delete:hover{background:#fce4ec}.db-admin-locked{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:16px;padding:60px;text-align:center}.db-admin-locked-msg{color:#888;font-size:14px;margin:0}.db-admin-locked-form{display:flex;gap:8px}.db-admin-locked-form input{padding:8px 12px;border:1px solid #444;border-radius:4px;background:#1e1e1e;color:#fff;font-size:14px;width:280px}.db-admin-locked-form button{padding:8px 16px;background:#2196f3;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px}.db-admin{display:flex;flex-direction:column;flex:1;gap:16px;min-height:0}.db-admin-top{display:flex;gap:16px;min-height:0;flex:1}.db-tables{width:200px;flex-shrink:0;background:var(--qims-white);border-radius:6px;box-shadow:0 1px 4px #00000014;padding:12px}.db-tables h3{font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.4px;color:var(--qims-label);margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid #eee}.db-table-item{padding:8px 10px;margin-bottom:2px;border-radius:4px;cursor:pointer;font-size:13px;font-family:monospace;color:var(--qims-text);transition:all .1s;border-left:3px solid transparent}.db-table-item:hover{background:var(--qims-light-gray)}.db-table-item.active{background:var(--qims-surface-2);color:var(--qims-primary);border-left-color:var(--qims-primary);font-weight:500}.db-data{flex:1;display:flex;flex-direction:column;background:var(--qims-white);border-radius:6px;box-shadow:0 1px 4px #00000014;overflow:hidden;min-height:0}.db-data-header{padding:10px 14px;border-bottom:1px solid #eee;display:flex;align-items:center;gap:10px;flex-shrink:0}.db-data-header h3{font-size:14px;font-weight:600;color:var(--qims-dark)}.db-btn-add-col,.db-btn-add-row{padding:4px 12px;border:1px solid var(--qims-border);border-radius:4px;background:var(--qims-white);font-size:12px;font-family:inherit;font-weight:500;cursor:pointer;color:var(--qims-text);transition:all .15s}.db-btn-add-col:hover,.db-btn-add-row:hover{background:var(--qims-light-gray);border-color:var(--qims-red);color:var(--qims-red)}.db-data-header .row-count{font-size:12px;color:var(--qims-label);margin-left:auto}.db-data-scroll{flex:1;overflow:auto}.db-data table{width:100%;border-collapse:collapse;font-size:12px;font-family:monospace}.db-data thead th{background:var(--qims-dark);color:var(--qims-white);padding:8px 10px;text-align:left;font-size:11px;font-weight:500;white-space:nowrap;position:sticky;top:0;z-index:1}.db-data tbody td{padding:6px 10px;border-bottom:1px solid #f0f0f0;white-space:nowrap;max-width:300px;overflow:hidden;text-overflow:ellipsis}.db-data tbody tr:hover{background:#f8f8f8}.db-data tbody td.editable{cursor:text}.db-data tbody td.editable:hover{background:#fffde7}.db-data tbody td.editing{padding:2px}.db-data tbody td.editing input{width:100%;padding:4px 6px;border:2px solid var(--qims-red);border-radius:3px;font-size:12px;font-family:monospace;outline:none}.db-data .null-value{color:#bbb;font-style:italic}.db-row-delete{background:none;border:none;color:#ccc;cursor:pointer;font-size:14px;padding:2px 6px;border-radius:3px}.db-row-delete:hover{background:#fce4ec;color:#c62828}.db-row-delete.confirm{background:#c62828;color:#fff;font-size:11px;padding:2px 8px;white-space:nowrap}.db-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;z-index:100}.db-modal{background:var(--qims-white);border-radius:8px;padding:24px;width:380px;box-shadow:0 8px 30px #00000026}.db-modal h3{font-size:16px;font-weight:700;margin-bottom:16px;color:var(--qims-dark)}.db-modal-field{margin-bottom:12px}.db-modal-field label{display:block;font-size:12px;font-weight:500;color:var(--qims-label);margin-bottom:4px}.db-modal-field input,.db-modal-field select{width:100%;height:34px;padding:4px 10px;border:1px solid var(--qims-border);border-radius:4px;font-size:13px;font-family:inherit}.db-modal-field input:focus,.db-modal-field select:focus{outline:none;border-color:var(--qims-red);box-shadow:0 0 0 2px #a500341f}.db-modal-buttons{display:flex;gap:8px;justify-content:flex-end;margin-top:20px}.db-modal-btn{padding:8px 20px;border-radius:4px;font-size:13px;font-family:inherit;font-weight:500;cursor:pointer;border:1px solid var(--qims-border);background:var(--qims-white);color:var(--qims-text)}.db-modal-btn:hover{background:var(--qims-light-gray)}.db-modal-btn.confirm{background:var(--qims-primary);color:var(--qims-confirm-text);border:none}.db-modal-btn.confirm:hover{background:var(--qims-primary-hover)}.db-console{background:var(--qims-white);border-radius:6px;box-shadow:0 1px 4px #00000014;padding:14px;flex-shrink:0}.db-console h3{font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.4px;color:var(--qims-label);margin-bottom:8px}.db-console-input{display:flex;gap:8px}.db-console textarea{flex:1;height:60px;padding:8px;border:1px solid var(--qims-border);border-radius:4px;font-size:13px;font-family:monospace;color:var(--qims-text);resize:vertical}.db-console textarea:focus{outline:none;border-color:var(--qims-red);box-shadow:0 0 0 2px #a500341f}.db-console .btn-run{padding:0 20px;background:var(--qims-dark);color:var(--qims-white);border:none;border-radius:4px;font-size:13px;font-family:inherit;font-weight:500;cursor:pointer;align-self:flex-end;height:36px}.db-console .btn-run:hover{background:#333}.db-console-result{margin-top:8px;font-size:12px;font-family:monospace;color:var(--qims-label);max-height:200px;overflow:auto}.db-console-result.error{color:var(--qims-red)}.db-console-result table{width:100%;border-collapse:collapse;margin-top:4px}.db-console-result th{background:#f5f5f5;padding:4px 8px;text-align:left;font-size:11px;border:1px solid #e0e0e0}.db-console-result td{padding:4px 8px;border:1px solid #e0e0e0;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pruefplan{display:flex;flex-direction:column;flex:1;gap:16px;min-height:0}.pp-toolbar{display:flex;gap:12px;align-items:center}.pp-toolbar .btn{height:36px;padding:0 20px;border:1px solid var(--qims-border);background:var(--qims-surface);font-size:14px;font-family:inherit;font-weight:500;cursor:pointer;border-radius:4px;color:var(--qims-text)}.pp-toolbar .btn:hover{background:var(--qims-surface-2)}.pp-toolbar .btn-primary{background:var(--qims-primary);color:var(--qims-text-on-primary);border:none}.pp-toolbar .btn-primary:hover{background:var(--qims-primary-hover)}.pp-toolbar .count{margin-left:auto;font-size:13px;color:var(--qims-label)}.pp-table{flex:1;background:var(--qims-surface);border-radius:6px;box-shadow:0 1px 4px #0006;overflow:auto}.pp-table table{width:100%;border-collapse:collapse;font-size:13px}.pp-table thead th{background:var(--qims-surface-2);color:var(--qims-text);padding:10px 12px;text-align:left;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;position:sticky;top:0}.pp-table tbody tr{border-bottom:1px solid #334155}.pp-table tbody tr:hover{background:#243247}.pp-table tbody td{padding:10px 12px;white-space:nowrap}.pp-status{display:inline-block;padding:3px 10px;border-radius:3px;font-size:11px;font-weight:600}.pp-status.faellig{background:#450a0a;color:#f87171}.pp-status.gebracht,.pp-status.heute{background:#451a03;color:#fbbf24}.pp-status.ok{background:#14532d;color:#4ade80}.pp-status.inaktiv{background:#334155;color:#94a3b8}.pp-messung-link{color:var(--qims-primary);text-decoration:none;font-weight:600;font-size:12px}.pp-messung-link:hover{text-decoration:underline}.pp-view-toggle{display:flex;border:1px solid var(--qims-border);border-radius:4px;overflow:hidden}.pp-view-btn{padding:6px 16px;border:none;background:var(--qims-surface);font-size:13px;font-family:inherit;font-weight:500;cursor:pointer;color:var(--qims-label);transition:all .15s}.pp-view-btn:not(:last-child){border-right:1px solid var(--qims-border)}.pp-view-btn.active{background:var(--qims-primary);color:var(--qims-text-on-primary)}.pp-view-btn:hover:not(.active){background:var(--qims-surface-2)}.pp-haeufigkeit{font-size:12px;color:var(--qims-label)}.pp-actions{display:flex;gap:6px}.pp-actions button{background:none;border:none;cursor:pointer;font-size:14px;padding:2px 6px;border-radius:3px;color:var(--qims-label)}.pp-actions button:hover{background:#334155;color:var(--qims-text)}.pp-actions button.delete:hover{background:#450a0a;color:#f87171}.pp-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.65);display:flex;align-items:center;justify-content:center;z-index:100}.pp-modal{background:var(--qims-surface);border-radius:8px;padding:24px;width:480px;box-shadow:0 8px 30px #00000080}.pp-modal h3{font-size:16px;font-weight:700;margin-bottom:16px;color:var(--qims-text)}.pp-modal-row{display:flex;gap:12px}.pp-modal-field{margin-bottom:12px;flex:1}.pp-modal-field label{display:block;font-size:12px;font-weight:500;color:var(--qims-label);margin-bottom:4px}.pp-modal-field input,.pp-modal-field select{width:100%;height:34px;padding:4px 10px;border:1px solid var(--qims-border);border-radius:4px;font-size:13px;font-family:inherit;background-color:var(--qims-surface);color:var(--qims-text)}.pp-modal-field input:focus,.pp-modal-field select:focus{outline:none;border-color:var(--qims-primary);box-shadow:0 0 0 2px var(--qims-primary-ring)}.pp-modal-buttons{display:flex;gap:8px;justify-content:flex-end;margin-top:20px}.pp-modal-buttons button{padding:8px 20px;border-radius:4px;font-size:13px;font-family:inherit;font-weight:500;cursor:pointer}.pp-modal-buttons .cancel{border:1px solid var(--qims-border);background:var(--qims-surface);color:var(--qims-text)}.pp-modal-buttons .confirm{background:var(--qims-primary);color:var(--qims-text-on-primary);border:none}.pp-modal-buttons .confirm:hover{background:var(--qims-primary-hover)}.stats-dashboard{display:flex;flex-direction:column;gap:20px;flex:1;overflow-y:auto}.stats-kpis{display:flex;gap:16px}.kpi-card{flex:1;background:var(--qims-surface);border-radius:8px;box-shadow:0 1px 4px #0006;padding:20px;display:flex;flex-direction:column;align-items:center;text-align:center}.kpi-value{font-size:36px;font-weight:700;line-height:1;margin-bottom:6px}.kpi-value.green{color:#4ade80}.kpi-value.red{color:#f87171}.kpi-value.orange{color:#fbbf24}.kpi-value.dark{color:#f1f5f9}.kpi-label{font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.4px;color:var(--qims-label)}.kpi-sub{font-size:11px;color:var(--qims-text-muted);margin-top:4px}.stats-row{display:flex;gap:16px}.stats-card{flex:1;background:var(--qims-surface);border-radius:8px;box-shadow:0 1px 4px #0006;padding:20px}.stats-card h3{font-size:13px;font-weight:600;color:var(--qims-text);margin-bottom:16px}.donut-container{display:flex;align-items:center;gap:24px}.donut{width:140px;height:140px;border-radius:50%;position:relative;flex-shrink:0}.donut-hole{position:absolute;top:25%;left:25%;width:50%;height:50%;border-radius:50%;background:var(--qims-surface);display:flex;align-items:center;justify-content:center;flex-direction:column}.donut-hole .donut-total{font-size:22px;font-weight:700;color:#f1f5f9}.donut-hole .donut-label{font-size:10px;color:var(--qims-label)}.donut-legend{display:flex;flex-direction:column;gap:8px}.donut-legend-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--qims-text)}.legend-dot{width:12px;height:12px;border-radius:3px;flex-shrink:0}.legend-dot.ok{background:#22c55e}.legend-dot.nok{background:#ef4444}.legend-dot.gz{background:#f59e0b}.legend-dot.none{background:#475569}.legend-value{margin-left:auto;font-weight:600;min-width:30px;text-align:right}.bar-chart{display:flex;flex-direction:column;gap:10px}.bar-row{display:flex;align-items:center;gap:10px}.bar-label{width:120px;font-size:12px;color:var(--qims-text);text-align:right;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bar-track{flex:1;height:24px;background:#334155;border-radius:4px;overflow:hidden;position:relative}.bar-fill{height:100%;border-radius:4px;transition:width .5s ease;min-width:2px}.bar-fill.red{background:#ef4444}.bar-fill.green{background:#22c55e}.bar-fill.orange{background:#f59e0b}.bar-fill.dark{background:#38bdf8}.bar-count{width:45px;font-size:12px;font-weight:600;color:var(--qims-text);text-align:right;flex-shrink:0}.stacked-bar-track{flex:1;height:24px;background:#334155;border-radius:4px;overflow:hidden;display:flex}.stacked-segment{height:100%;transition:width .5s ease}.stacked-segment.ok{background:#22c55e}.stacked-segment.nok{background:#ef4444}.stacked-segment.gz{background:#f59e0b}.pp-status-cards{display:flex;gap:12px}.pp-status-card{flex:1;padding:16px;border-radius:6px;text-align:center}.pp-status-card.overdue{background:#450a0a}.pp-status-card.today{background:#451a03}.pp-status-card.planned{background:#14532d}.pp-status-card.done{background:#172554}.pp-status-card .pp-num{font-size:28px;font-weight:700}.pp-status-card.overdue .pp-num{color:#f87171}.pp-status-card.today .pp-num{color:#fbbf24}.pp-status-card.planned .pp-num{color:#4ade80}.pp-status-card.done .pp-num{color:#60a5fa}.pp-status-card .pp-lbl{font-size:11px;font-weight:500;text-transform:uppercase;color:var(--qims-label);margin-top:4px}.wf-log-list{display:flex;flex-direction:column;gap:6px}.wf-log-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:4px;background:var(--qims-surface-2);font-size:12px}.wf-log-icon{width:24px;height:24px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}.wf-log-icon.email{background:#22c55e}.wf-log-icon.condition{background:#a78bfa}.wf-log-icon.trigger{background:#3b82f6}.wf-log-icon.delay{background:#f59e0b}.wf-log-details{flex:1;color:var(--qims-text)}.wf-log-time{font-size:11px;color:var(--qims-label);flex-shrink:0}.stats-empty{text-align:center;padding:30px;color:var(--qims-text-muted);font-size:13px}.settings-page{max-width:700px;margin:0 auto}.settings-section{background:var(--qims-surface);border-radius:8px;box-shadow:0 1px 4px #0006;padding:24px;margin-bottom:16px}.settings-section-header{display:flex;align-items:center;gap:8px;margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid #334155}.settings-menu-name{flex:1;font-size:16px;font-weight:700;border:1px solid transparent;padding:4px 8px;border-radius:4px;color:var(--qims-text);font-family:inherit;background:transparent}.settings-menu-name:focus{outline:none;border-color:var(--qims-primary)}.settings-menu-delete{background:none;border:none;color:var(--qims-label);cursor:pointer;font-size:18px;padding:4px 8px;border-radius:4px}.settings-menu-delete:hover{color:#f87171;background:#450a0a}.cm-add-menu-btn{width:100%;padding:14px;border:2px dashed var(--qims-border);border-radius:8px;background:transparent;cursor:pointer;font-size:14px;font-family:inherit;font-weight:500;color:var(--qims-label);transition:all .15s;margin-bottom:16px}.cm-add-menu-btn:hover{border-color:var(--qims-primary);color:var(--qims-primary);background:#1e3a5f}.settings-section h3{font-size:16px;font-weight:700;color:var(--qims-text);margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid #334155}.settings-field{margin-bottom:14px}.settings-field label{display:block;font-size:12px;font-weight:500;color:var(--qims-label);text-transform:uppercase;letter-spacing:.3px;margin-bottom:4px}.settings-field select,.settings-field input[type=text]{width:100%;height:34px;padding:4px 10px;border:1px solid var(--qims-border);border-radius:4px;font-size:13px;font-family:inherit;box-sizing:border-box;background-color:var(--qims-surface);color:var(--qims-text)}.settings-field select:focus,.settings-field input:focus{outline:none;border-color:var(--qims-primary);box-shadow:0 0 0 2px var(--qims-primary-ring)}.checkbox-row{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--qims-text)}.checkbox-row input[type=checkbox]{accent-color:var(--qims-primary)}.cm-items-list{border:1px solid var(--qims-border);border-radius:6px;margin-bottom:10px}.cm-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-bottom:1px solid var(--qims-border)}.cm-item:last-child{border-bottom:none}.cm-color-dot{width:20px;height:20px;border-radius:4px;border:1px solid rgba(255,255,255,.1);cursor:pointer;flex-shrink:0}.cm-item input[type=text]{flex:1;height:30px;padding:2px 8px;border:1px solid var(--qims-border);border-radius:4px;font-size:13px;font-family:inherit;background-color:var(--qims-surface);color:var(--qims-text)}.cm-item input:focus{outline:none;border-color:var(--qims-primary)}.cm-item-delete{background:none;border:none;color:var(--qims-label);cursor:pointer;font-size:16px;padding:2px 6px;border-radius:3px}.cm-item-delete:hover{color:#f87171;background:#450a0a}.cm-add-btn{width:100%;padding:10px;border:2px dashed var(--qims-border);border-radius:6px;background:transparent;cursor:pointer;font-size:13px;font-family:inherit;color:var(--qims-label);transition:all .15s}.cm-add-btn:hover{border-color:var(--qims-primary);color:var(--qims-primary);background:#1e3a5f}.cm-color-picker{position:absolute;background:var(--qims-surface);border:1px solid var(--qims-border);border-radius:6px;padding:8px;box-shadow:0 4px 12px #0006;z-index:50;display:flex;gap:6px;flex-wrap:wrap;width:180px}.cm-color-option{width:28px;height:28px;border-radius:4px;cursor:pointer;border:2px solid transparent;transition:all .1s}.cm-color-option:hover{border-color:var(--qims-text);transform:scale(1.1)}.cm-color-option.selected{border-color:var(--qims-text)}.settings-save-btn{padding:10px 30px;background:var(--qims-primary);color:var(--qims-text-on-primary);border:none;border-radius:4px;font-size:14px;font-family:inherit;font-weight:500;cursor:pointer;transition:background .15s}.settings-save-btn:hover{background:var(--qims-primary-hover)}.settings-toast{display:inline-block;margin-left:12px;font-size:13px;color:#4ade80;font-weight:500;opacity:0;transition:opacity .3s}.settings-toast.visible{opacity:1}
