*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f0f1a;--surface: #1c1c2e;--surface2: #252540;--border: #35355a;--accent: #7c6af7;--accent2: #a78bfa;--text: #e2e2f0;--text-dim: #8888aa;--danger: #ef4444;--success: #22c55e;--warning: #f59e0b;--radius: 10px;--shadow: 0 2px 12px rgba(0,0,0,.4)}html{font-size:16px}body{background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,sans-serif;line-height:1.5;min-height:100dvh}a{color:var(--accent2);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;border:none;border-radius:var(--radius);padding:.5rem 1rem;font-size:.9rem;font-weight:600;transition:opacity .15s,transform .1s}button:active{transform:scale(.97)}button:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border)}.btn-danger{background:var(--danger);color:#fff}.btn-sm{padding:.3rem .7rem;font-size:.8rem}input,textarea,select{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:.5rem .75rem;font-size:1rem;width:100%;outline:none;transition:border-color .15s}input:focus,textarea:focus,select:focus{border-color:var(--accent)}textarea{resize:vertical;min-height:80px}label{display:block;font-size:.8rem;color:var(--text-dim);margin-bottom:.25rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.form-group{margin-bottom:1rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem;box-shadow:var(--shadow)}.tag{display:inline-block;padding:.15rem .5rem;border-radius:99px;font-size:.75rem;font-weight:600}.tag-erstverkauf{background:#1e3a5f;color:#60b0ff}.tag-weiterverkauf{background:#1e4d30;color:#4ade80}.tag-haendler{background:#3d2b00;color:#fbbf24}.tag-unbekannt{background:#2a2a3a;color:var(--text-dim)}.confidence-hoch{color:var(--success)}.confidence-mittel{color:var(--warning)}.confidence-niedrig{color:var(--danger)}.spinner{width:24px;height:24px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;margin:1rem auto}@keyframes spin{to{transform:rotate(360deg)}}.error-msg{background:#2a1010;border:1px solid var(--danger);border-radius:var(--radius);padding:.75rem 1rem;color:#f88;margin:.5rem 0}.app-layout{display:flex;flex-direction:column;min-height:100dvh}.topbar{background:var(--surface);border-bottom:1px solid var(--border);padding:.75rem 1rem;display:flex;align-items:center;gap:1rem;position:sticky;top:0;z-index:100}.topbar-logo{font-size:1.1rem;font-weight:700;color:var(--accent2);white-space:nowrap}.topbar nav{display:flex;gap:.5rem;flex-wrap:wrap}.topbar nav a{padding:.3rem .7rem;border-radius:6px;font-size:.85rem;color:var(--text-dim);transition:background .15s,color .15s}.topbar nav a:hover,.topbar nav a.active{background:var(--surface2);color:var(--text);text-decoration:none}.page{padding:1rem;max-width:900px;margin:0 auto;width:100%}.page-title{font-size:1.4rem;font-weight:700;margin-bottom:1rem}.search-bar{display:flex;gap:.5rem;margin-bottom:1rem}.search-bar input{flex:1}.instrument-list{display:flex;flex-direction:column;gap:.5rem}.instrument-card{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color .15s,background .15s;text-decoration:none;color:inherit}.instrument-card:hover{border-color:var(--accent);background:var(--surface2);text-decoration:none}.instrument-nummer{font-size:1rem;font-weight:700;color:var(--accent2);min-width:80px}.instrument-info{min-width:0}.instrument-besitzer{font-size:.9rem;color:var(--text)}.instrument-meta{font-size:.8rem;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}@media (max-width: 600px){.detail-grid{grid-template-columns:1fr}}.history-timeline{margin-top:.5rem}.history-item{display:grid;grid-template-columns:100px 1fr auto;gap:.75rem;align-items:start;padding:.75rem 0;border-bottom:1px solid var(--border)}.history-item:last-child{border-bottom:none}.history-date{font-size:.85rem;color:var(--text-dim)}.foto-grid{display:flex;gap:1rem;flex-wrap:wrap;margin-top:.5rem}.foto-thumb{width:120px;height:120px;object-fit:cover;border-radius:8px;border:1px solid var(--border);cursor:pointer}.analyze-result{display:flex;flex-direction:column;gap:.5rem}.analyze-field{display:grid;grid-template-columns:130px 1fr auto;gap:.5rem;align-items:center;padding:.5rem;background:var(--surface2);border-radius:6px}.analyze-label{font-size:.8rem;color:var(--text-dim);font-weight:600}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;width:100%;max-width:520px;max-height:90dvh;overflow-y:auto}.modal-title{font-size:1.1rem;font-weight:700;margin-bottom:1rem}.modal-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.section-title{font-size:1rem;font-weight:700;color:var(--accent2)}.rechnung-row{display:grid;grid-template-columns:1fr 1fr 80px auto;gap:.75rem;align-items:center;padding:.6rem .75rem;background:var(--surface);border:1px solid var(--border);border-radius:8px;margin-bottom:.5rem}@media (max-width: 600px){.rechnung-row{grid-template-columns:1fr auto}}
