@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f0f4f9;--surface:#fff;--surface2:#f5f7fb;--surface3:#edf0f7;--border:#dde3ef;--border2:#c8d0e0;--accent:#0057ff;--accent-light:#e8efff;--accent-mid:#0057ff1f;--blue-dark:#003db5;--green:#059669;--green-light:#ecfdf5;--orange:#d97706;--orange-light:#fffbeb;--red:#dc2626;--red-light:#fef2f2;--purple:#7c3aed;--purple-light:#f5f3ff;--text:#0f172a;--text2:#475569;--text3:#94a3b8;--shadow:0 1px 3px #00000014;--shadow-md:0 4px 12px #00000014;--shadow-lg:0 20px 40px #0000001a;--sidebar:240px;--topbar:58px;--font:"Plus Jakarta Sans",sans-serif;--mono:"JetBrains Mono",monospace;--r:10px;--r-lg:14px}html,body{background:var(--bg);height:100%;color:var(--text);font-family:var(--font);-webkit-font-smoothing:antialiased;font-size:14px}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}.shell{height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar);min-width:var(--sidebar);background:var(--surface);border-right:1px solid var(--border);flex-direction:column;display:flex;box-shadow:2px 0 8px #0000000a}.logo{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:18px 16px 14px;display:flex}.logo img{object-fit:contain;max-width:160px;height:36px}.logo-txt{color:var(--accent);font-size:15px;font-weight:800}.logo-sub{font-size:9px;font-family:var(--mono);color:var(--text3);letter-spacing:1.5px;text-transform:uppercase;margin-top:1px}.nav{flex:1;padding:10px;overflow-y:auto}.nav-sec{letter-spacing:2px;color:var(--text3);text-transform:uppercase;font-size:9px;font-family:var(--mono);padding:12px 8px 4px}.nav-item{border-radius:var(--r);cursor:pointer;color:var(--text2);border:1px solid #0000;align-items:center;gap:10px;margin-bottom:2px;padding:8px 10px;font-size:13px;font-weight:600;text-decoration:none;transition:all .14s;display:flex}.nav-item:hover{background:var(--surface2);color:var(--text)}.nav-item.active{background:var(--accent-light);color:var(--accent);border-color:#0057ff26}.nav-dot{background:var(--surface2);border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:17px;display:flex}.nav-item.active .nav-dot{background:var(--accent-mid)}.nav-badge{background:var(--red);color:#fff;font-size:10px;font-family:var(--mono);text-align:center;border-radius:10px;min-width:18px;margin-left:auto;padding:1px 6px;font-weight:600}.nav-badge.orange{background:var(--orange)}.sidebar-foot{border-top:1px solid var(--border);background:var(--surface2);align-items:center;gap:10px;padding:12px;display:flex}.avatar{background:var(--accent-light);width:34px;height:34px;color:var(--accent);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:800;display:flex}.uname{color:var(--text);font-size:12px;font-weight:700}.urole{color:var(--text3);font-size:10px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.5px}.main{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.topbar{height:var(--topbar);background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:12px;padding:0 24px;display:flex}.topbar-title{color:var(--text);flex:1;font-size:15px;font-weight:800}.topbar-right{align-items:center;gap:8px;display:flex}.alert-pill{background:var(--red-light);color:var(--red);font-size:11px;font-family:var(--mono);cursor:pointer;border:1px solid #dc262633;border-radius:20px;align-items:center;gap:5px;padding:5px 12px;font-weight:600;display:flex}.page-content{flex:1;padding:24px;overflow-y:auto}.ph{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:22px;display:flex}.ph-title{color:var(--text);letter-spacing:-.3px;font-size:20px;font-weight:800}.ph-sub{color:var(--text3);font-size:12px;font-family:var(--mono);margin-top:3px}.ph-actions{flex-shrink:0;gap:8px;display:flex}.kpi-grid{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px;display:grid}.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow);padding:18px}.kpi-top{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.kpi-icon{border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;font-size:18px;display:flex}.kpi-label{color:var(--text3);text-transform:uppercase;letter-spacing:.8px;font-size:11px;font-weight:600}.kpi-val{letter-spacing:-.5px;font-size:26px;font-weight:800;line-height:1}.kpi-sub{color:var(--text3);font-size:11px;font-family:var(--mono);margin-top:4px}.btn{border-radius:var(--r);cursor:pointer;font-size:13px;font-weight:700;font-family:var(--font);white-space:nowrap;box-shadow:var(--shadow);border:none;align-items:center;gap:6px;padding:8px 16px;transition:all .15s;display:inline-flex}.btn-sm{box-shadow:none;padding:5px 12px;font-size:12px}.btn-xs{box-shadow:none;padding:3px 9px;font-size:11px}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--blue-dark)}.btn-ghost{background:var(--surface);color:var(--text2);border:1px solid var(--border);box-shadow:var(--shadow)}.btn-ghost:hover{background:var(--surface2);color:var(--text)}.btn-success{background:var(--green-light);color:var(--green);box-shadow:none;border:1px solid #05966933}.btn-danger{background:var(--red-light);color:var(--red);box-shadow:none;border:1px solid #dc262633}.btn-warning{background:var(--orange-light);color:var(--orange);box-shadow:none;border:1px solid #d9770633}.btn-purple{background:var(--purple-light);color:var(--purple);box-shadow:none;border:1px solid #7c3aed33}.btn:disabled{opacity:.4;cursor:not-allowed}.badge{font-size:11px;font-weight:700;font-family:var(--mono);white-space:nowrap;border-radius:20px;align-items:center;gap:4px;padding:3px 10px;display:inline-flex}.b-neu{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe}.b-lauf{color:#92400e;background:#fef3c7;border:1px solid #fde68a}.b-done{background:var(--green-light);color:var(--green);border:1px solid #a7f3d0}.b-stop{background:var(--red-light);color:var(--red);border:1px solid #fecaca}.b-wart{background:var(--purple-light);color:var(--purple);border:1px solid #ddd6fe}.b-norm{background:var(--surface2);color:var(--text2);border:1px solid var(--border)}.b-hoch{background:var(--orange-light);color:var(--orange);border:1px solid #fed7aa}.b-krit{background:var(--red-light);color:var(--red);border:1px solid #fecaca}.b-admin{background:var(--purple-light);color:var(--purple);border:1px solid #ddd6fe}.b-tech{background:var(--accent-light);color:var(--accent);border:1px solid #bfdbfe}.b-buero{background:var(--green-light);color:var(--green);border:1px solid #a7f3d0}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow);padding:20px}.ticket{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);cursor:pointer;box-shadow:var(--shadow);margin-bottom:8px;transition:all .15s;display:flex;overflow:hidden}.ticket:hover{box-shadow:var(--shadow-md);border-color:var(--border2)}.ticket-prio-bar{flex-shrink:0;width:4px}.prio-krit .ticket-prio-bar{background:var(--red)}.prio-hoch .ticket-prio-bar{background:var(--orange)}.prio-norm .ticket-prio-bar{background:#e2e8f0}.ticket-body{flex:1;min-width:0;padding:14px 16px}.ticket-head{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:6px;display:flex}.ticket-id{font-size:10px;font-family:var(--mono);color:var(--accent);margin-bottom:2px;font-weight:600}.ticket-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:700;overflow:hidden}.ticket-badges{flex-wrap:wrap;flex-shrink:0;gap:5px;display:flex}.ticket-meta{color:var(--text3);font-size:11px;font-family:var(--mono);flex-wrap:wrap;gap:12px;margin-top:6px;display:flex}.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow);overflow:auto hidden}table{border-collapse:collapse;width:100%;min-width:500px}thead{background:var(--surface2)}th{text-align:left;text-transform:uppercase;letter-spacing:1.5px;color:var(--text3);font-size:10px;font-family:var(--mono);white-space:nowrap;border-bottom:1px solid var(--border);padding:10px 16px;font-weight:600}td{border-top:1px solid var(--border);color:var(--text);padding:12px 16px;font-size:13px}tr:hover td{background:var(--surface2)}tr.cp{cursor:pointer}.km{background:var(--purple-light);color:var(--purple);font-size:10px;font-family:var(--mono);border:1px solid #7c3aed33;border-radius:6px;align-items:center;gap:4px;padding:2px 9px;font-weight:600;display:inline-flex}.two-col{grid-template-columns:1fr 1fr;gap:18px;display:grid}.three-col{grid-template-columns:1fr 1fr 1fr;gap:14px;display:grid}.sh{justify-content:space-between;align-items:center;gap:10px;margin-bottom:14px;display:flex}.sh-title{color:var(--text);font-size:14px;font-weight:800}.tabs{background:var(--surface2);border-radius:var(--r);border:1px solid var(--border);gap:2px;margin-bottom:20px;padding:4px;display:flex;overflow-x:auto}.tab{cursor:pointer;text-align:center;color:var(--text3);white-space:nowrap;border-radius:7px;flex:1;min-width:fit-content;padding:7px 14px;font-size:12px;font-weight:700;transition:all .14s}.tab.active{background:var(--surface);color:var(--accent);box-shadow:var(--shadow)}.dg{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin-bottom:16px;display:grid}.di{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:12px}.di.full{grid-column:1/-1}.dk{color:var(--text3);font-size:10px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px;font-weight:600}.dv{color:var(--text);font-size:13px;font-weight:600}.tl{border-left:2px solid var(--border);padding-left:16px}.tl-item{padding:0 0 14px 20px;position:relative}.tl-dot{background:var(--surface);border:2px solid var(--border2);border-radius:50%;width:14px;height:14px;position:absolute;top:3px;left:-9px}.tl-dot.accent{border-color:var(--accent);background:var(--accent-light)}.tl-dot.done{border-color:var(--green);background:var(--green-light)}.tl-time{color:var(--text3);font-size:10px;font-family:var(--mono)}.tl-text{color:var(--text);margin-top:2px;font-size:13px}.fg{grid-template-columns:1fr 1fr;gap:14px;display:grid}.fg .full{grid-column:span 2}.fgroup{flex-direction:column;gap:5px;display:flex}label{color:var(--text2);letter-spacing:.2px;font-size:11px;font-weight:600}input,select,textarea{background:var(--surface);border:1.5px solid var(--border);color:var(--text);font-size:13px;font-family:var(--font);border-radius:8px;outline:none;width:100%;padding:9px 12px;transition:border-color .15s,box-shadow .15s}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #0057ff1a}textarea{resize:vertical;min-height:80px}.fa{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;margin-top:20px;padding-top:16px;display:flex}.overlay{z-index:300;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a73;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);width:100%;max-width:600px;max-height:90vh;box-shadow:var(--shadow-lg);padding:28px;position:relative;overflow-y:auto}.modal-title{color:var(--text);margin-bottom:20px;padding-right:30px;font-size:17px;font-weight:800}.modal-x{background:var(--surface2);border:1px solid var(--border);color:var(--text3);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;width:30px;height:30px;font-size:16px;display:flex;position:absolute;top:16px;right:16px}hr{border:none;border-top:1px solid var(--border);margin:16px 0}.info-box{background:var(--accent-light);color:var(--accent);font-size:11px;font-family:var(--mono);border:1px solid #0057ff26;border-radius:8px;margin-top:12px;padding:10px 14px}.warn-box{background:var(--red-light);color:var(--red);border:1px solid #dc262633;border-radius:8px;align-items:center;gap:10px;margin-bottom:14px;padding:12px 16px;font-size:13px;font-weight:600;display:flex}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px;margin-bottom:16px;display:grid}.photo-item{aspect-ratio:4/3;background:var(--surface2);border:1px solid var(--border);border-radius:8px;position:relative;overflow:hidden}.photo-item img{object-fit:cover;width:100%;height:100%}.photo-add{aspect-ratio:4/3;border:1.5px dashed var(--border2);cursor:pointer;color:var(--text3);border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:4px;font-size:11px;font-weight:600;display:flex}.photo-add:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.search-wrap{position:relative}.search-wrap input{padding-left:36px}.search-icon{color:var(--text3);pointer-events:none;font-size:14px;position:absolute;top:50%;left:11px;transform:translateY(-50%)}.filter-row{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.filter-row .search-wrap{flex:1;min-width:200px}.stat-bar{background:var(--surface3);border-radius:3px;height:6px;margin-top:8px;overflow:hidden}.stat-fill{background:var(--accent);border-radius:3px;height:100%}.contract-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);cursor:pointer;box-shadow:var(--shadow);align-items:center;gap:14px;margin-bottom:8px;padding:16px;transition:all .15s;display:flex}.contract-card:hover{box-shadow:var(--shadow-md)}.contract-icon{background:var(--purple-light);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:20px;display:flex}.contract-body{flex:1;min-width:0}.contract-name{color:var(--text);font-size:14px;font-weight:700}.contract-meta{color:var(--text3);font-size:11px;font-family:var(--mono);flex-wrap:wrap;gap:10px;margin-top:3px;display:flex}.contract-right{text-align:right;flex-shrink:0}.contract-price{color:var(--text);font-size:15px;font-weight:800}.contract-cycle{color:var(--text3);font-size:10px;font-family:var(--mono)}.loading{height:200px;color:var(--text3);font-family:var(--mono);justify-content:center;align-items:center;gap:10px;font-size:12px;display:flex}@keyframes spin{to{transform:rotate(360deg)}}.spinner{border:2px solid var(--border2);border-top-color:var(--accent);border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin}.empty{text-align:center;color:var(--text3);padding:60px 20px}.empty-icon{margin-bottom:12px;font-size:40px}.empty-text{font-size:14px}.mob-overlay{z-index:150;background:#0006;display:none;position:fixed;inset:0}.mob-overlay.show{display:block}.menu-btn{color:var(--text2);cursor:pointer;background:0 0;border:none;padding:4px;font-size:22px;display:none}.login-wrap{background:linear-gradient(135deg,#f0f4f9 0%,#e8edf5 100%);justify-content:center;align-items:center;min-height:100vh;padding:16px;display:flex}.login-box{width:100%;max-width:380px}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:28px}@keyframes fadein{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}.fadein{animation:.2s fadein}.settings-grid{grid-template-columns:220px 1fr;gap:20px;display:grid}.settings-nav{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);height:fit-content;box-shadow:var(--shadow);padding:8px}.settings-nav-item{cursor:pointer;color:var(--text2);border-radius:8px;align-items:center;gap:8px;margin-bottom:2px;padding:9px 12px;font-size:13px;font-weight:600;transition:all .14s;display:flex}.settings-nav-item:hover{background:var(--surface2);color:var(--text)}.settings-nav-item.active{background:var(--accent-light);color:var(--accent)}@media (width<=768px){.sidebar{z-index:200;transition:transform .25s;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0);box-shadow:4px 0 30px #00000026}.menu-btn{display:flex!important}.page-content{padding:16px}.kpi-grid{grid-template-columns:repeat(2,1fr);gap:10px}.two-col,.three-col,.fg{grid-template-columns:1fr}.fg .full{grid-column:span 1}.modal{padding:20px}.settings-grid{grid-template-columns:1fr}}
