:root{--bg: #f4f3f0;--surface: #ffffff;--border: #e2ddd5;--text: #2c2c2c;--muted: #7c766c;--primary: #3f4a54;--primary-dark: #303942;--accent: #8a6f3e;--danger: #a8412f;--ok: #3c6b4f;--radius: 10px;--shadow: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}h1{font-size:1.5rem;margin:0;font-weight:600}h3{font-size:1rem;margin:0 0 .75rem;font-weight:600}.muted{color:var(--muted)}.small{font-size:.82rem}.num{text-align:right;font-variant-numeric:tabular-nums}.strong{font-weight:600}.center{text-align:center;padding:2rem}.app-shell{min-height:100%;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;gap:1.5rem;background:var(--primary);color:#fff;padding:0 1.25rem;height:56px;position:sticky;top:0;z-index:20}.brand{display:flex;align-items:center;gap:.6rem;font-weight:600;font-size:1.05rem}.nav{display:flex;gap:.4rem;flex:1}.nav a{color:#d9dde1;padding:.4rem .8rem;border-radius:6px}.nav a:hover{color:#fff;text-decoration:none;background:#ffffff14}.nav a.active{color:#fff;background:#ffffff26}.user-box{display:flex;align-items:center;gap:.75rem}.user-box .muted{color:#c8cdd2}.content{flex:1;width:100%;max-width:1180px;margin:0 auto;padding:1.5rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.1rem 1.25rem;margin-bottom:1.25rem}.page-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:1rem}.toolbar{margin-bottom:1rem}.table{width:100%;border-collapse:collapse}.table th{text-align:left;font-weight:600;color:var(--muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.03em;padding:.5rem .6rem;border-bottom:2px solid var(--border)}.table td{padding:.55rem .6rem;border-bottom:1px solid var(--border)}.table tbody tr:hover{background:#faf9f6}.row-link a{display:block}.cat-head{color:var(--accent);border-bottom:1px solid var(--border);padding-bottom:.4rem}.inactive-row{opacity:.5}.field{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.7rem}.field.inline{flex-direction:row;align-items:center;gap:.5rem}.field>span{font-size:.8rem;color:var(--muted);font-weight:500}input,select,textarea{font:inherit;color:var(--text);background:#fff;border:1px solid var(--border);border-radius:7px;padding:.45rem .55rem;outline:none}input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #3f4a541f}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:0 1rem}.grid-cols{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}.form-section h3{color:var(--accent);border-bottom:1px solid var(--border);padding-bottom:.4rem}.btn{font:inherit;font-weight:500;border:1px solid transparent;border-radius:7px;padding:.5rem .95rem;cursor:pointer;transition:background .12s}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:#efece6;color:var(--text);border-color:var(--border)}.btn-secondary:hover{background:#e6e2da}.btn-ghost{background:transparent;color:inherit;border-color:#ffffff4d}.topbar .btn-ghost{color:#fff}.btn-ghost:hover{background:#ffffff1a}.btn:disabled{opacity:.5;cursor:not-allowed}.icon-btn{background:transparent;border:none;cursor:pointer;font-size:.95rem;color:var(--muted);padding:.2rem .35rem;border-radius:5px}.icon-btn:hover{background:#f0ede7;color:var(--danger)}.badge{display:inline-block;padding:.15rem .5rem;border-radius:20px;font-size:.75rem;font-weight:600;background:#ece8e1;color:var(--muted)}.status-ANGELEGT{background:#e7edf2;color:#3f4a54}.status-IN_BEARBEITUNG{background:#f3ecd9;color:#8a6f3e}.status-ABGESCHLOSSEN{background:#e0ede4;color:var(--ok)}.status-ARCHIVIERT{background:#eceae6;color:#877f72}.mwst-MWST_19{background:#e7edf2;color:#3f4a54}.mwst-MWST_7{background:#e0ede4;color:var(--ok)}.mwst-DURCHLAUFEND{background:#f3ecd9;color:#8a6f3e}.login-wrap{min-height:100vh;display:grid;place-items:center;background:linear-gradient(160deg,#3f4a54,#2c343b);padding:1rem}.login-card{width:340px;max-width:100%}.login-brand{text-align:center;margin-bottom:1.25rem}.login-brand h1{font-size:1.2rem;margin:.5rem 0 .1rem}.alert{padding:.6rem .8rem;border-radius:7px;margin-bottom:.8rem;font-size:.88rem}.alert-error{background:#f7e4e0;color:var(--danger)}.btn-primary[type=submit]{width:100%;margin-top:.5rem}.search{width:100%;max-width:420px}.tabs{display:flex;gap:.25rem;border-bottom:1px solid var(--border);margin-bottom:1.25rem}.tab{background:none;border:none;border-bottom:2px solid transparent;padding:.6rem 1rem;cursor:pointer;font:inherit;color:var(--muted);margin-bottom:-1px}.tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.breadcrumb{margin-bottom:.5rem;font-size:.85rem}.detail-actions{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.pdf-menu{display:flex;gap:.4rem}.pdf-menu .btn{padding:.45rem .7rem}.add-termin-row{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap}.termin-card{border-left:3px solid var(--accent)}.termin-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:.6rem}.termin-art{font-weight:600;color:var(--primary);font-size:1rem;border-color:transparent;background:#f6f4f0}.auftrag-card{border-left:3px solid var(--primary)}.auftrag-name{font-weight:600;font-size:1.02rem}.auftrag-gruppe{margin-top:.6rem;padding-top:.4rem;border-top:1px solid var(--border)}.auftrag-gruppe h4{margin:0 0 .5rem;font-size:.9rem;color:var(--accent)}.field.span-2{grid-column:1 / -1}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:1.25rem}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.1rem 1.25rem;display:flex;flex-direction:column;gap:.25rem;text-decoration:none;color:inherit;border-left:4px solid var(--border)}a.stat-card:hover{background:#faf9f6;text-decoration:none}.stat-card.status-ANGELEGT{border-left-color:#6b8299}.stat-card.status-IN_BEARBEITUNG{border-left-color:#c79a4e}.stat-card.status-ABGESCHLOSSEN{border-left-color:#3c6b4f}.stat-card.status-ARCHIVIERT{border-left-color:#9b9385}.stat-card.accent{border-left-color:var(--accent)}.stat-num{font-size:1.7rem;font-weight:700;color:var(--primary);font-variant-numeric:tabular-nums}.stat-label{font-size:.82rem;color:var(--muted)}.vorlage-card{border-left:3px solid var(--accent)}.vorlage-name{font-size:1.15rem;font-weight:600;color:var(--primary)}.vorlage-besch{margin-bottom:.6rem}.btn-xs{padding:.2rem .5rem;font-size:.8rem}.mahnung-row{grid-template-columns:1fr auto auto}.mahn-badge{background:#f3ecd9;color:#8a6f3e}.logo-box{display:flex;gap:1.25rem;align-items:center;flex-wrap:wrap}.logo-preview{width:200px;height:90px;border:1px dashed var(--border);border-radius:8px;display:grid;place-items:center;background:#fff;overflow:hidden}.logo-preview img{max-width:100%;max-height:100%;object-fit:contain}.logo-actions{display:flex;gap:.6rem;align-items:center}.positions-table .mini-input{width:80px;padding:.3rem .4rem}.mini-input{width:80px}.pos-name{font-weight:500}.pos-desc{font-size:.8rem}.positionen-foot{display:grid;grid-template-columns:1fr 360px;gap:1.25rem;align-items:start}.add-position{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.add-position select{flex:1;min-width:200px}.vorlage-row{display:flex;gap:.5rem;align-items:center;margin-top:.9rem;padding-top:.9rem;border-top:1px solid var(--border)}.summe-box h3{color:var(--accent)}.summe-row{display:flex;justify-content:space-between;padding:.3rem 0}.summe-row.sub{font-size:.82rem;color:var(--muted);padding:.1rem 0 .3rem}.summe-row.total{font-size:1.1rem;font-weight:700;color:var(--primary)}.summe-divider{border-top:2px solid var(--border);margin:.5rem 0}.sticky-actions{position:sticky;bottom:0;display:flex;justify-content:flex-end;align-items:center;gap:1rem;padding:.8rem 0;background:linear-gradient(transparent,var(--bg) 40%)}.saved-hint{color:var(--ok);font-weight:500}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:grid;place-items:center;z-index:50}.modal{width:460px;max-width:92vw;margin:0}.modal-actions{display:flex;justify-content:flex-end;gap:.6rem;margin-top:1rem}.ghost-input{border:1px solid transparent;background:transparent;width:100%;padding:.3rem .4rem}.ghost-input:hover{border-color:var(--border)}.ghost-input.small{font-size:.8rem}.new-leistung-row,.bank-row{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;margin-bottom:.5rem}.new-leistung-row>input:first-child{flex:1;min-width:160px}.bank-row>input{flex:1}.rg-status{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.7rem 1rem;border-radius:var(--radius);margin-bottom:1rem;flex-wrap:wrap}.rg-ENTWURF{background:#f3ecd9;color:#8a6f3e}.rg-FINALISIERT{background:#e0ede4;color:var(--ok)}.rg-STORNIERT{background:#f7e4e0;color:var(--danger)}.rg-actions{display:flex;gap:.5rem}.btn-ghost-danger{background:transparent;border:1px solid var(--danger);color:var(--danger)}.btn-ghost-danger:hover{background:var(--danger);color:#fff}.subtotal-row td{background:#faf8f4;border-top:1px solid var(--border)}.summe-row.endbetrag{font-size:1.25rem;color:var(--accent);border-top:2px solid var(--accent);margin-top:.3rem;padding-top:.5rem}.zahlung-row{display:grid;grid-template-columns:1fr auto auto;gap:.6rem;align-items:center;padding:.35rem 0;border-bottom:1px solid var(--border)}.add-zahlung{display:flex;gap:.5rem;align-items:center;margin-top:.7rem;flex-wrap:wrap}.add-zahlung input.num{width:110px}.add-zahlung input{flex:1;min-width:120px}@media (max-width: 860px){.grid-cols,.grid-2,.positionen-foot{grid-template-columns:1fr}.nav{display:none}}
