@import"https://fonts.googleapis.com/css2?family=Share+Tech+Mono&family=Barlow:wght@300;400;500;600;700&family=Barlow+Condensed:wght@400;600;700&display=swap";.app-shell{display:flex;min-height:100vh}.app-main{flex:1;display:flex;flex-direction:column;min-width:0;transition:margin-left .2s}.sidebar-open .app-main{margin-left:var(--sidebar-width)}.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-width);background:var(--color-white);border-right:1px solid var(--b2);display:flex;flex-direction:column;flex-shrink:0;transform:translate(-100%);transition:transform .2s;z-index:100;overflow-y:auto}.sidebar--open{transform:translate(0)}.sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:99}.sidebar-brand{display:flex;align-items:center;gap:.625rem;padding:20px 18px 16px;border-bottom:1px solid var(--b2)}.sidebar-brand-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:var(--color-white);font-weight:700;font-size:.95rem;box-shadow:var(--glow-primary)}.sidebar-brand-text{font-family:var(--font-cond);font-weight:700;font-size:16px;letter-spacing:2px;color:var(--color-text)}.sidebar-nav{flex:1;padding:12px 0;overflow-y:auto}.sb-section{margin-top:.75rem}.sb-section-title{font-family:var(--font-mono);font-size:11px;color:var(--color-text-muted);letter-spacing:2px;text-transform:uppercase;padding:12px 18px 6px}.sb-item{display:flex;align-items:center;gap:10px;padding:9px 18px;cursor:pointer;font-size:14px;font-weight:500;color:var(--color-text-light);transition:all .2s;border-left:2px solid transparent;text-decoration:none;border-right:none;border-top:none;border-bottom:none;background:none;width:100%;text-align:left;font-family:var(--font-body)}.sb-item:hover{color:var(--color-text);background:#0000000a;text-decoration:none}.sb-item--active{color:var(--color-primary);background:#0066cc14;border-left-color:var(--color-primary);font-weight:600}.sb-item--sub{padding-left:1.75rem;font-size:13px}.sb-separator{height:1px;background:var(--b2);margin:8px 16px}.sb-icon{font-size:17px;width:20px;text-align:center;filter:grayscale(1);opacity:.55;flex-shrink:0}.sb-item--active .sb-icon{opacity:.75;filter:none}.sb-item:hover .sb-icon{opacity:.7}.sidebar-footer{border-top:1px solid var(--b2);padding:14px 16px}.sidebar-user{display:flex;align-items:center;gap:.625rem;padding:.375rem .5rem;margin-bottom:.375rem}.sidebar-user-avatar{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:var(--color-primary-light);color:var(--color-primary);font-weight:700;font-size:.85rem;flex-shrink:0}.sidebar-user-info{overflow:hidden}.sidebar-user-name{font-size:14px;font-weight:500;color:var(--color-text)}.sidebar-user-role{font-family:var(--font-mono);font-size:12px;color:var(--color-text-muted);margin-top:2px;text-transform:capitalize}.sb-logout{color:var(--color-danger);font-size:13px}.sb-logout:hover{border-color:var(--color-danger);color:var(--color-danger);background:#d32f2f0f}.app-header{display:flex;align-items:center;justify-content:space-between;height:70px;padding:0 28px;background:var(--color-white);border-bottom:1px solid var(--color-border);flex-shrink:0;position:sticky;top:0;z-index:50;box-shadow:0 1px 4px #0000000f}.header-left{display:flex;align-items:center;gap:14px}.header-menu-btn{display:none;background:none;border:none;font-size:1.25rem;cursor:pointer;color:var(--color-text);padding:.25rem}.header-breadcrumb{font-family:var(--font-cond);font-size:20px;font-weight:700;letter-spacing:1.5px;color:var(--color-text)}.header-right{display:flex;align-items:center;gap:10px}.header-user-avatar{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:var(--color-primary-light);color:var(--color-primary);font-weight:700;font-size:.85rem;cursor:default}.app-content{flex:1;padding:20px 28px;overflow-y:auto;display:flex;flex-direction:column;gap:18px}@media (max-width: 767px){.sidebar-open .app-main{margin-left:0}.header-menu-btn{display:block}.app-content{padding:1rem}.app-header{padding:0 1rem;height:56px}.header-breadcrumb{font-size:1rem}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e8eaed,#f4f5f7,#e8eaed);font-family:var(--font-cond),"Segoe UI",sans-serif;padding:1rem}.login-card{width:100%;max-width:400px;background:var(--color-white);border:1px solid rgba(0,102,204,.2);border-radius:16px;padding:40px 36px;box-shadow:0 8px 32px #00000014}.login-header{text-align:center;margin-bottom:28px}.login-logo{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:14px;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:var(--color-white);font-size:26px;font-weight:700;margin-bottom:12px;box-shadow:var(--glow-primary)}.login-logo-icon{font-size:1.5rem}.login-title{font-family:var(--font-cond);font-size:1.35rem;font-weight:700;letter-spacing:1px;color:var(--color-text);margin-bottom:.25rem}.login-subtitle{font-family:var(--font-mono);font-size:12px;color:var(--color-primary);letter-spacing:2px;text-transform:uppercase}.login-form .form-group{margin-bottom:1.25rem}.login-error{background:#d32f2f14;border:1px solid rgba(211,47,47,.3);border-radius:8px;padding:8px 12px;margin-bottom:16px;color:var(--color-danger);font-size:13px}.login-btn{width:100%;padding:13px;margin-top:8px;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));border:none;border-radius:8px;color:#fff;font-size:14px;font-family:var(--font-cond);font-weight:700;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:all .2s}.login-btn:hover{box-shadow:var(--glow-primary);filter:brightness(1.05)}@media (max-width: 480px){.login-card{padding:2rem 1.25rem;box-shadow:none;border-radius:0}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}a{text-decoration:none;color:inherit}:root{--color-bg:#f4f5f7;--color-white:#ffffff;--s2:#f0f1f3;--s3:#e6e8ec;--s4:#dcdfe3;--color-border:rgba(0,0,0,.08);--b2:rgba(0,0,0,.05);--b3:rgba(0,0,0,.03);--color-primary:#0066CC;--color-primary-dark:#004C99;--color-primary-light:#e6f0ff;--color-success:#00c853;--color-warning:#f9a825;--color-danger:#d32f2f;--color-info:#0066CC;--color-orange:#ef6c00;--color-text:#1a1a1a;--color-text-light:#5a5a5a;--color-text-muted:#9a9a9a;--font-mono:"Share Tech Mono",monospace;--font-body:"Barlow",sans-serif;--font-cond:"Barlow Condensed",sans-serif;--shadow-sm:0 1px 3px rgba(0,0,0,.04);--shadow-md:0 4px 12px rgba(0,0,0,.1);--glow-primary:0 0 20px rgba(0,102,204,.15);--glow-success:0 0 20px rgba(0,200,83,.15);--glow-danger:0 0 20px rgba(211,47,47,.15);--sidebar-width:240px;--radius:6px;--radius-lg:10px}html,body,#root{height:100%}body{font-family:var(--font-body);font-size:15px;background:var(--color-bg);color:var(--color-text);overflow-x:hidden}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:var(--s2)}::-webkit-scrollbar-thumb{background:silver;border-radius:2px}.loading-spinner{display:flex;align-items:center;justify-content:center;flex-direction:column;min-height:200px;font-family:var(--font-mono);font-size:14px;color:var(--color-text-muted)}@keyframes bu-spin{to{transform:rotate(360deg)}}.loading-spinner:before{content:"";display:block;width:24px;height:24px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:bu-spin .8s linear infinite;margin:0 auto .75rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 18px;border-radius:7px;border:none;cursor:pointer;font-family:var(--font-cond);font-size:14px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;transition:all .2s;line-height:1.4}.btn-primary{background:var(--color-primary);color:#fff;border:1px solid var(--color-primary)}.btn-primary:hover{background:var(--color-primary-dark);box-shadow:var(--glow-primary)}.btn-secondary{background:none;border:1px solid var(--color-border);color:var(--color-text-light)}.btn-secondary:hover{border-color:var(--color-primary);color:var(--color-primary)}.btn-danger{background:#d32f2f1f;border:1px solid rgba(211,47,47,.3);color:var(--color-danger)}.btn-danger:hover{background:#d32f2f38}.btn-sm{padding:5px 12px;font-size:12px}.btn-lg{padding:10px 22px;font-size:15px}.btn-disabled,.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.card{background:var(--color-white);border:1px solid var(--b2);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);padding:1.25rem}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--b2)}.card-header h2,.card-header h3{font-family:var(--font-cond);font-size:15px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--color-text-light)}.bu-table{width:100%;border-collapse:collapse}.bu-table th{font-family:var(--font-cond);font-size:12px;font-weight:600;color:var(--color-text-muted);letter-spacing:2px;text-transform:uppercase;padding:10px 14px;text-align:left;border-bottom:1px solid var(--b2);background:var(--s2);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.bu-table th:hover{color:var(--color-text-light)}.bu-table th .sort-arrow{margin-left:.25rem;font-size:.7rem}.bu-table td{font-size:14px;color:var(--color-text-light);padding:12px 14px;border-bottom:1px solid var(--b2);vertical-align:middle}.bu-table tr:hover td{background:#0066cc0a}.bu-table-empty{text-align:center;padding:2rem 1rem;color:var(--color-text-muted)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:1rem}.modal-content{background:var(--color-white);border:1px solid var(--color-border);border-radius:14px;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 24px #0000001f}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--b2)}.modal-header h2{font-family:var(--font-cond);font-size:18px;font-weight:700;letter-spacing:1px}.modal-close{background:none;border:none;font-size:1.25rem;cursor:pointer;color:var(--color-text-muted);padding:.25rem;line-height:1;transition:color .2s}.modal-close:hover{color:var(--color-text)}.modal-body{padding:24px;max-height:70vh;overflow-y:auto}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--b2)}.form-group{margin-bottom:1rem}.form-label{display:block;font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--color-text-muted);letter-spacing:2px;margin-bottom:5px}.form-input,.form-select,.form-textarea{width:100%;padding:9px 12px;background:var(--s2);border:1px solid var(--b2);border-radius:7px;color:var(--color-text);font-family:var(--font-body);font-size:14px;outline:none;transition:border-color .2s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-primary)}.form-input:disabled,.form-select:disabled,.form-textarea:disabled{background:var(--color-bg);cursor:not-allowed}.form-textarea{resize:vertical;min-height:70px}.form-select option{background:var(--color-white)}.badge{display:inline-flex;padding:3px 10px;border-radius:4px;font-family:var(--font-mono);font-size:12px;letter-spacing:1px;white-space:nowrap;line-height:1.4}.badge-status-offen,.badge-status-planung{background:#dbeafe;color:#1d4ed8}.badge-status-in_bearbeitung{background:#fef3c7;color:#b45309}.badge-status-aktiv{background:#00c8531f;color:var(--color-success)}.badge-status-pruefung{background:#ccfbf1;color:#0d9488}.badge-status-erledigt{background:#d1fae5;color:#047857}.badge-status-geprueft{background:#ccfbf1;color:#0d9488}.badge-status-abnahme{background:#ede9fe;color:#6d28d9}.badge-status-gewaehrleistung{background:#fef3c7;color:#b45309}.badge-status-abgeschlossen,.badge-status-geschlossen{background:#f3f4f6;color:#6b7280}.badge-status-abgelehnt{background:#fee2e2;color:#b91c1c}.badge-priority-niedrig{background:#f3f4f6;color:#6b7280}.badge-priority-mittel{background:#dbeafe;color:#1d4ed8}.badge-priority-hoch{background:#fef3c7;color:#b45309}.badge-priority-kritisch,.badge-type-mangel{background:#fee2e2;color:#b91c1c}.badge-type-behinderung,.badge-type-behinderungsanzeige,.badge-type-bedenkenanmeldung{background:#fef3c7;color:#b45309}.badge-type-nachtrag{background:#dbeafe;color:#1d4ed8}.badge-type-hinweis,.badge-type-allgemein{background:#f3f4f6;color:#6b7280}.badge-type-planabweichung,.badge-type-planfreigabe{background:#ede9fe;color:#6d28d9}.badge-type-sicherheit{background:#fee2e2;color:#b91c1c}.badge-type-abnahme{background:#ccfbf1;color:#0d9488}.badge-type-dokumentation{background:#f3f4f6;color:#6b7280}.badge-type-projektleiter{background:#0066cc1f;color:var(--color-primary)}.badge-type-bauleiter{background:#ede9fe;color:#6d28d9}.badge-type-techniker,.badge-type-extern{background:#f3f4f6;color:#6b7280}.badge-type-pruefer{background:#ccfbf1;color:#0d9488}.bu-toast-error{position:fixed;top:16px;left:50%;transform:translate(-50%) translateY(-120%);z-index:9999;background:var(--color-white);border:1px solid var(--color-danger);border-left:4px solid var(--color-danger);border-radius:6px;color:var(--color-text);font-size:13px;line-height:1.4;padding:10px 18px;max-width:480px;width:max-content;box-shadow:0 4px 20px #00000026;cursor:pointer;transition:transform .25s ease,opacity .25s ease;opacity:0;font-family:var(--font-cond);letter-spacing:.3px}.bu-toast-error.bu-toast-visible{transform:translate(-50%) translateY(0);opacity:1}.pagination{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem 0 0}.pagination-btn{padding:5px 12px;font-size:12px;font-family:var(--font-cond);font-weight:600;letter-spacing:1px;text-transform:uppercase;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-white);cursor:pointer;color:var(--color-text-light);transition:all .2s}.pagination-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-info{font-family:var(--font-mono);font-size:12px;color:var(--color-text-muted);letter-spacing:1px}.search-bar{display:flex;gap:10px;align-items:center}.search-input{padding:8px 14px;background:var(--s2);border:1px solid var(--b2);border-radius:7px;color:var(--color-text);font-family:var(--font-body);font-size:14px;outline:none;transition:border-color .2s;min-width:240px}.search-input:focus{border-color:var(--color-primary)}
