:root{color:#161616;background:#f3f3f1;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:#f3f3f1}button,input{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed}code{border:1px solid #d9d9d4;border-radius:12px;background:#f8f8f6;padding:2px 5px}.app-shell{width:min(1500px,calc(100% - 32px));margin:0 auto;padding:24px 0 44px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:118px;border:1px solid #222222;border-radius:32px;background:#111;color:#f8f8f5;box-shadow:0 22px 60px #1111112e;padding:28px 30px;margin-bottom:12px}.eyebrow{margin:0 0 4px;color:#a5f0bf;font-size:.82rem;font-weight:800;letter-spacing:0;text-transform:uppercase}h1,h2,p{margin-top:0}h1{margin-bottom:0;font-size:2.2rem;line-height:1.1;color:#f8f8f5}h2{margin-bottom:8px;font-size:1.2rem}.header-login,.refresh-button,.login-form button,.icon-button,.header-login button{display:inline-flex;align-items:center;justify-content:center;gap:8px}.header-login{justify-content:space-between;max-width:none;min-height:48px;border:1px solid rgba(255,255,255,.12);border-radius:999px;background:#1d1d1d;color:#f5f5f0;padding:6px 6px 6px 16px;font-size:.9rem;font-weight:700;min-width:0}.refresh-button,.login-form button{min-height:38px;border:0;border-radius:999px;background:#111;color:#fff;padding:0 16px;font-weight:700}.header-login span{overflow:visible;text-overflow:clip;white-space:normal;min-width:0}.header-login button{min-height:36px;border:0;border-radius:999px;background:#eeeeea;color:#1a1a18;padding:0 13px;font-weight:800;white-space:nowrap}.metrics-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:14px}.metric{display:grid;grid-template-columns:auto 1fr;align-items:center;column-gap:9px;row-gap:6px;min-height:112px;border:1px solid #deded8;border-radius:28px;background:#fff;box-shadow:0 18px 44px #14141412;padding:20px;position:relative;overflow:hidden}.metric:before{content:"";position:absolute;inset:14px 14px auto auto;width:10px;height:10px;border-radius:999px;background:#86efac}.metric:nth-child(2):before{background:#d6d3cb}.metric:nth-child(3):before{background:#f4b4a8}.metric:nth-child(4):before{background:#b8c7ff}.metric svg{color:#1e1e1c}.metric span{color:#73736c;font-size:.9rem;font-weight:700}.metric strong{grid-column:1 / -1;font-size:2.15rem;line-height:1;color:#111}.upload-panel{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:76px;border:1px dashed #cfcfc8;border-radius:28px;background:#fff;box-shadow:0 18px 44px #1414140f;padding:14px 16px 14px 18px;margin-bottom:14px;transition:border-color .14s ease,background .14s ease,transform .14s ease}.upload-panel.dragging{border-color:#111;background:#f7fff9;transform:translateY(-1px)}.upload-panel.uploading{border-color:#111}.upload-panel.success{border-color:#a5f0bf;background:#f3fff6}.upload-panel.error{border-color:#f4b4a8;background:#fff8f5}.upload-panel>div{display:grid;grid-template-columns:auto auto;align-items:center;column-gap:9px;row-gap:2px}.upload-panel svg{grid-row:1 / 3;color:#111}.upload-panel strong{color:#111;font-size:.98rem}.upload-panel span{color:#6f6f68;font-size:.88rem}.upload-button{display:inline-flex;align-items:center;justify-content:center;min-height:42px;border-radius:999px;background:#111;color:#fff;padding:0 16px;font-size:.9rem;font-weight:800;white-space:nowrap;cursor:pointer}.upload-button input{display:none}.toolbar{display:grid;grid-template-columns:minmax(240px,1fr) auto auto;gap:12px;align-items:center;margin-bottom:14px}.search-field{display:flex;align-items:center;gap:10px;min-height:52px;border:1px solid #deded8;border-radius:999px;background:#fff;box-shadow:0 14px 34px #1414140f;padding:0 18px}.search-field svg{color:#76766f;flex:0 0 auto}.search-field input{width:100%;min-width:0;border:0;outline:0;background:transparent;color:#111}.segmented-control{display:inline-flex;min-height:52px;overflow:hidden;border:1px solid #deded8;border-radius:999px;background:#fff;box-shadow:0 14px 34px #1414140f;padding:5px}.segmented-control button{border:0;border-radius:999px;background:transparent;color:#585852;padding:0 12px;font-size:.9rem;font-weight:700;white-space:nowrap}.segmented-control button.active{background:#111;color:#fff}.refresh-button{background:#fff;color:#1a1a18;border:1px solid #deded8;box-shadow:0 14px 34px #1414140f;white-space:nowrap;min-height:52px;padding:0 18px}.refresh-button.loading{background:#111;color:#fff}.refresh-button.success{border-color:#a5f0bf;background:#ddf8e6;color:#14532d}.refresh-button.error{border-color:#f4b4a8;background:#fff0ec;color:#7b2119}.table-wrap{overflow:auto;border:1px solid #deded8;border-radius:28px;background:#fff;box-shadow:0 24px 70px #14141417}table{width:100%;border-collapse:collapse;table-layout:fixed;min-width:980px}th,td{border-bottom:1px solid #eeeeea;padding:12px;text-align:left;vertical-align:top}th{position:sticky;top:0;z-index:1;background:#f7f7f4;color:#66665f;font-size:.72rem;font-weight:800;text-transform:uppercase}.col-ebes{width:13%}.col-hersteller{width:19%}.col-status,.col-betrag{width:12%}.col-date,.col-updated{width:11%}.col-docs{width:22%}.sort-button{display:inline-flex;align-items:center;justify-content:flex-start;gap:6px;width:100%;min-height:26px;border:0;background:transparent;color:inherit;padding:0;font-size:inherit;font-weight:inherit;text-align:left;text-transform:inherit}.sort-button svg{color:#94948c;flex:0 0 auto}.sort-button.active{color:#111}.sort-button.active svg{color:#111}tbody tr:last-child td{border-bottom:0}tbody tr:hover{background:#fafaf7}td strong,td span{display:block}td small{display:block;margin-top:3px;color:#77776f}td.col-hersteller span,td.col-hersteller small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.review-flag{display:inline-flex;margin-top:5px;border-radius:999px;background:#fff2d5;color:#7a4d00;padding:3px 8px;font-size:.72rem;font-weight:800}.status-list,.document-actions{display:flex;flex-wrap:wrap;gap:5px}.col-status .status-list,.col-docs .document-actions{flex-wrap:nowrap}.status-pill{display:inline-flex;align-items:center;gap:4px;min-height:26px;border-radius:999px;padding:0 8px;font-size:.72rem;font-weight:800}.status-pill svg{width:12px;height:12px}.status-pill.done{background:#ddf8e6;color:#14532d}.status-pill.missing{background:#f0f0ec;color:#6f6f68}.icon-button{min-height:29px;border:1px solid #deded8;border-radius:999px;background:#f8f8f5;color:#171715;padding:0 8px;font-size:.72rem;font-weight:800;transition:border-color .14s ease,background .14s ease,color .14s ease}.icon-button svg{width:13px;height:13px}.col-betrag,.col-date,.col-updated{white-space:nowrap}.icon-button:not(:disabled):hover{border-color:#111;background:#111;color:#fff}.icon-button:disabled{opacity:.38}.empty-state,.error-banner{border:1px solid #deded8;border-radius:28px;background:#fff;box-shadow:0 24px 70px #14141417}.empty-state{display:grid;place-items:center;min-height:260px;padding:30px;text-align:center;color:#66665f}.empty-state.compact{min-height:180px}.empty-state svg{color:#111;margin-bottom:10px}.empty-state p{max-width:680px;margin-bottom:0}.login-screen{display:grid;place-items:center;min-height:100vh;background:#050505;padding:24px}.login-stack{display:grid;justify-items:center;gap:28px;width:min(100%,520px)}.login-panel{display:grid;gap:18px;width:100%;border:1px solid rgba(255,255,255,.1);border-radius:36px;background:#101010;box-shadow:0 34px 90px #0000006b;padding:34px;color:#f8f8f5}.login-logo{color:#fff;margin:0;font-size:clamp(4.8rem,11vw,9.5rem);font-weight:950;line-height:.82;letter-spacing:0;text-align:center}.login-brand{text-align:center}.login-panel p{color:#aaa99f;margin-bottom:0}.login-form{display:grid;grid-template-columns:1fr;gap:10px}.login-form input{min-width:0;min-height:54px;border:1px solid rgba(255,255,255,.1);border-radius:999px;padding:0 18px;background:#1b1b1b;color:#f8f8f5;outline:0}.login-form input::placeholder{color:#77766f}.login-form input:focus{border-color:#a5f0bf}.login-form button{min-height:54px;margin-top:4px;background:#a5f0bf;color:#111}.form-message{margin:0;color:#f4b4a8;font-weight:700}.error-banner{display:flex;align-items:center;gap:8px;margin-bottom:14px;padding:14px 16px;color:#7b2119}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:1050px){.metrics-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.toolbar{grid-template-columns:1fr}.segmented-control{overflow-x:auto}}@media(max-width:640px){.app-shell{width:min(100% - 20px,1480px);padding-top:10px}.topbar{align-items:flex-start;flex-direction:column;border-radius:26px;padding:24px}h1{font-size:1.75rem}.metrics-grid{grid-template-columns:1fr}.upload-panel{align-items:stretch;flex-direction:column}.upload-button{width:100%}.login-form{grid-template-columns:1fr}.header-login{width:100%;max-width:none}}
