*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:#f5f5f5;min-height:100vh;color:#333}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:#f5f5f5;padding:20px}.login-card{background:#fff;border-radius:16px;box-shadow:0 2px 12px #00000014;padding:40px;width:100%;max-width:400px}.logo-container{text-align:center;margin-bottom:40px}.logo-container img{height:80px;width:auto}.login-title{font-size:24px;color:#333;margin-bottom:30px;font-weight:400}.form-group{margin-bottom:20px}.form-input{width:100%;padding:14px 16px;border:none;background:#f5f5f5;border-radius:10px;font-size:15px;color:#333;transition:background .3s}.form-input:focus{outline:none;background:#ebebeb}.form-input::placeholder{color:#999}.password-input-wrapper{position:relative}.password-toggle{position:absolute;right:16px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:#666;padding:0;display:flex;align-items:center}.forgot-password{text-align:right;margin-bottom:20px}.forgot-password a{color:#007aff;text-decoration:none;font-size:14px}.remember-me{display:flex;align-items:center;margin-bottom:30px}.remember-me input[type=checkbox]{margin-right:8px}.remember-me label{font-size:14px;color:#666;cursor:pointer}.submit-button{width:100%;padding:16px;background:#000;color:#fff;border:none;border-radius:25px;font-size:16px;font-weight:500;cursor:pointer;transition:background .3s}.submit-button:hover:not(:disabled){background:#333}.submit-button:disabled{background:#999;cursor:not-allowed}.error-message{background:#fee;color:#c33;padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:14px}.field-error{color:#c33;font-size:13px;margin-top:5px}.app-layout{display:flex;min-height:100vh}.sidebar{width:260px;background:#fff;border-right:1px solid #eee;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100}.sidebar-header{display:flex;align-items:center;gap:12px;padding:24px 20px;border-bottom:1px solid #f0f0f0}.sidebar-logo{height:36px;width:auto}.sidebar-brand{font-size:20px;font-weight:600;color:#333}.sidebar-nav{flex:1;padding:12px 10px;display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:10px;color:#666;text-decoration:none;font-size:15px;font-weight:400;transition:all .2s}.nav-item:hover{background:#f5f5f5;color:#333}.nav-item.active{background:#000;color:#fff}.nav-item.active svg{stroke:#fff}.sidebar-footer{padding:16px;border-top:1px solid #f0f0f0}.sidebar-user{padding:8px 4px;margin-bottom:8px}.sidebar-user-info{display:flex;align-items:center;gap:10px}.sidebar-user-name{font-size:14px;font-weight:500;color:#333}.sidebar-role-badge{padding:2px 10px;border-radius:12px;font-size:11px;font-weight:500}.sidebar-role-badge.admin{background:#007aff;color:#fff}.sidebar-role-badge.user{background:#8bc34a;color:#fff}.sidebar-logout{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:1px solid #e0e0e0;border-radius:10px;background:transparent;color:#666;font-size:14px;cursor:pointer;transition:all .2s}.sidebar-logout:hover:not(:disabled){background:#f5f5f5;border-color:#ccc;color:#333}.sidebar-logout:disabled{opacity:.5;cursor:not-allowed}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:56px;background:#fff;border-bottom:1px solid #eee;align-items:center;padding:0 16px;gap:12px;z-index:90}.menu-toggle{background:none;border:none;padding:4px;cursor:pointer;color:#333;display:flex;align-items:center}.mobile-logo{display:flex;align-items:center;gap:8px}.mobile-logo img{height:28px}.mobile-logo span{font-size:18px;font-weight:600}.sidebar-overlay{display:none;position:fixed;inset:0;background:#0000004d;z-index:99}.main-content{flex:1;margin-left:260px;padding:32px;max-width:100%;min-height:100vh}.page-header{margin-bottom:24px}.page-header h1{font-size:28px;font-weight:600;color:#1a1a1a;margin-bottom:4px}.page-subtitle{font-size:14px;color:#888;display:flex;align-items:center;gap:8px}.btn-back{display:inline-flex;align-items:center;gap:4px;background:none;border:none;color:#666;font-size:14px;cursor:pointer;padding:4px 0;margin-bottom:8px;transition:color .2s}.btn-back:hover{color:#000}.card{background:#fff;border-radius:14px;box-shadow:0 1px 4px #0000000f;overflow:hidden}.card-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #f0f0f0}.card-header h2{font-size:16px;font-weight:600;color:#333}.card-title{font-size:16px;font-weight:600;color:#333;padding:20px 24px 0;margin-bottom:12px}.btn-link{background:none;border:none;color:#007aff;font-size:14px;cursor:pointer;font-weight:500}.btn-link:hover{text-decoration:underline}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:#fff;border-radius:14px;box-shadow:0 1px 4px #0000000f;padding:24px;display:flex;align-items:center;gap:16px;cursor:pointer;transition:box-shadow .2s,transform .2s}.stat-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-1px)}.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon.projects{background:#e8f5e9;color:#2e7d32}.stat-icon.gutachten{background:#e3f2fd;color:#1565c0}.stat-info{display:flex;flex-direction:column}.stat-number{font-size:28px;font-weight:700;color:#1a1a1a;line-height:1}.stat-label{font-size:14px;color:#888;margin-top:4px}.search-box{display:flex;align-items:center;gap:10px;background:#f5f5f5;border-radius:10px;padding:10px 14px;flex:1;max-width:500px}.search-box svg{color:#999;flex-shrink:0}.search-input{border:none;background:transparent;font-size:14px;color:#333;outline:none;width:100%}.search-input::placeholder{color:#999}.table-responsive{overflow-x:auto}.data-table{width:100%;border-collapse:collapse}.data-table thead th{padding:12px 16px;font-size:12px;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.5px;text-align:left;white-space:nowrap;border-bottom:1px solid #f0f0f0}.data-table tbody tr{transition:background .15s}.data-table tbody tr:not(:last-child){border-bottom:1px solid #f8f8f8}.data-table tbody tr:hover{background:#fafafa}.data-table tbody td{padding:14px 16px;font-size:14px;color:#555;white-space:nowrap}.td-primary{color:#1a1a1a!important;font-weight:500}.clickable-row{cursor:pointer}.code-badge{display:inline-block;padding:3px 10px;background:#f0f0f0;border-radius:6px;font-size:13px;font-family:SF Mono,Consolas,monospace;color:#555}.count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0 8px;background:#f0f0f0;border-radius:14px;font-size:13px;font-weight:600;color:#555}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500}.status-badge.status-done{background:#e8f5e9;color:#2e7d32}.status-badge.status-progress{background:#fff3e0;color:#e65100}.status-badge.status-new{background:#f5f5f5;color:#888}.step-badge{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;font-size:14px;font-weight:600}.step-badge.done{background:#e8f5e9;color:#2e7d32}.step-badge.pending{background:#f5f5f5;color:#ccc}.role-badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500}.role-badge.admin{background:#007aff;color:#fff}.role-badge.user{background:#8bc34a;color:#fff}.detail-grid{display:grid;grid-template-columns:1fr;gap:20px}.detail-rows{padding:0 24px 20px}.detail-row{display:flex;padding:10px 0;border-bottom:1px solid #f5f5f5}.detail-row:last-child{border-bottom:none}.detail-label{font-size:13px;color:#888;min-width:160px;flex-shrink:0}.detail-value{font-size:14px;color:#333;font-weight:400}.pdf-preview{display:flex;flex-direction:column;gap:20px}.pdf-page{background:#fff;border-radius:14px;box-shadow:0 1px 4px #0000000f;padding:32px}.pdf-cover-logo{text-align:center;margin-bottom:32px}.pdf-cover-logo img{height:64px}.pdf-title{text-align:center;font-size:36px;font-weight:700;color:#2c3e50;letter-spacing:4px;margin-bottom:8px}.pdf-divider{width:80px;height:3px;background:#c0392b;margin:0 auto 16px;border-radius:2px}.pdf-gutachten-nr{text-align:center;font-size:16px;color:#666;margin-bottom:40px}.pdf-info-block{margin-bottom:24px}.pdf-info-row{display:flex;padding:8px 0}.pdf-info-label{font-size:14px;color:#666;min-width:240px;flex-shrink:0}.pdf-info-value{font-size:14px;color:#333}.pdf-section-title{font-size:20px;font-weight:600;color:#2c3e50;margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid #f0f0f0}.pdf-subsection{margin-bottom:24px}.pdf-subsection h3{font-size:14px;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;padding:0 24px}.progress-steps{display:flex;align-items:center;justify-content:center;gap:0;padding:20px 0}.progress-step{display:flex;flex-direction:column;align-items:center;gap:10px;padding:0 24px}.progress-step .step-icon{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:600}.progress-step.done .step-icon{background:#e8f5e9;color:#2e7d32}.progress-step.pending .step-icon{background:#f5f5f5;color:#ccc}.progress-step span{font-size:13px;color:#666;font-weight:500}.step-connector{width:60px;height:2px;background:#e0e0e0;margin-bottom:28px}.empty-state{padding:40px 24px;text-align:center}.empty-state p{font-size:14px;color:#999}.loading-container{display:flex;justify-content:center;padding:60px 0}.loading-fullscreen{display:flex;justify-content:center;align-items:center;height:100vh}.spinner{width:32px;height:32px;border:3px solid rgba(0,0,0,.1);border-top-color:#333;border-radius:50%;animation:spin .8s linear infinite}.spinner.dark{border-color:#0000001a;border-top-color:#333}@keyframes spin{to{transform:rotate(360deg)}}.alert{padding:14px 20px;border-radius:10px;margin-bottom:16px;display:flex;align-items:center;gap:12px;font-size:14px}.alert.info{background:#e3f2fd;color:#1976d2}.alert.warning{background:#fff3e0;color:#f57c00}.dashboard-container{min-height:100vh;background:#f5f5f5}.navbar{background:#fff;box-shadow:0 2px 4px #0000001a;padding:16px 0}.navbar-content{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;align-items:center}.navbar-logo{display:flex;align-items:center;gap:12px}.navbar-logo img{height:40px}.navbar-brand{font-size:20px;font-weight:500;color:#333}.navbar-right{display:flex;align-items:center;gap:16px}.user-name{font-size:15px;color:#666}.logout-button{padding:8px 20px;background:transparent;color:#666;border:1px solid #ddd;border-radius:20px;font-size:14px;cursor:pointer;transition:all .3s}.logout-button:hover:not(:disabled){background:#f5f5f5;border-color:#999}.logout-button:disabled{opacity:.5;cursor:not-allowed}.dashboard-content{max-width:1200px;margin:40px auto;padding:0 20px}.welcome-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:30px;margin-bottom:20px}.welcome-title{font-size:28px;color:#333;margin-bottom:10px}.info-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:24px}.info-card-title{font-size:18px;color:#333;margin-bottom:20px;font-weight:500}.info-row{display:flex;padding:12px 0;border-bottom:1px solid #f0f0f0}.info-row:last-child{border-bottom:none}.info-label{font-weight:500;color:#666;min-width:120px}.info-value{color:#333}.alert-title{font-weight:500;margin-bottom:4px}@media(max-width:1024px){.sidebar{transform:translate(-100%);transition:transform .3s ease}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block}.mobile-header{display:flex}.main-content{margin-left:0;padding:72px 16px 24px}.pdf-info-row{flex-direction:column;gap:2px}.pdf-info-label{min-width:auto;font-size:12px}.detail-row{flex-direction:column;gap:2px}.detail-label{min-width:auto}.progress-steps{flex-direction:column;gap:8px}.step-connector{width:2px;height:24px;margin-bottom:0}}@media(max-width:768px){.stats-grid{grid-template-columns:1fr}.card-header{flex-direction:column;gap:12px;align-items:stretch}.search-box{max-width:100%}.navbar-content{flex-direction:column;gap:12px}.navbar-right{flex-wrap:wrap;justify-content:center}.data-table tbody td,.data-table thead th{padding:10px 12px;font-size:13px}}
