:root{--sidebar-width:240px;--control-height:34px;--control-height-sm:28px;--radius:6px;--radius-sm:4px;--bg:#f0f0f0;--surface:#fff;--surface2:#e8e8e8;--surface3:#ddd;--text:#1a1a1a;--text-muted:#555;--control-bg:#1a1a1a;--control-text:#fff;--border:#bbb;--border-light:#ddd;--border-mid:#999;--success:#0d7d0d;--success-bg:#e8f5e8;--danger:#b91c1c;--danger-bg:#fef2f2}*{box-sizing:border-box}html{font-size:14px;-webkit-text-size-adjust:100%}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:.875rem;line-height:1.4;background:var(--bg);color:var(--text);min-height:100vh;min-height:100dvh;padding-bottom:env(safe-area-inset-bottom)}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100%;height:100dvh;background:var(--surface);border-right:1px solid var(--border-light);z-index:100;transform:translateX(-100%);transition:transform .25s ease,box-shadow .25s ease;padding:max(env(safe-area-inset-top),10px) 0 10px;overflow-y:auto;font-size:.8125rem}.sidebar.open{transform:translateX(0);box-shadow:4px 0 20px rgba(0,0,0,.15)}.nav{display:flex;flex-direction:column;gap:2px}.nav-link{padding:8px 14px;color:var(--text);text-decoration:none;font-weight:500;font-size:.8125rem;transition:background .15s;border-radius:var(--radius-sm);margin:0 6px}.nav-link:focus,.nav-link:hover{background:var(--surface2);color:var(--text)}.sidebar-toggle{position:fixed;top:max(env(safe-area-inset-top),6px);left:10px;z-index:101;width:36px;height:36px;background:var(--control-bg);border:none;border-radius:var(--radius);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;box-shadow:0 1px 3px rgba(0,0,0,.15);transition:background .2s}.sidebar-toggle span{width:16px;height:1.5px;background:var(--control-text);border-radius:1px}.sidebar-toggle:hover{background:#333}.overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:99;opacity:0;pointer-events:none;transition:opacity .25s}.overlay.visible{opacity:1;pointer-events:auto}.main{min-height:100vh;min-height:100dvh;padding:max(env(safe-area-inset-top),10px) 14px 20px 54px;max-width:1200px;margin:0 auto;font-size:.875rem}.main-fullwidth{padding-left:16px;max-width:none}@media (min-width:768px){.sidebar{transform:translateX(0);box-shadow:none}.sidebar-toggle{display:none}.main{margin-left:var(--sidebar-width);padding-left:20px}}.page-title{font-size:1.15rem;font-weight:600;margin:0 0 .75rem;letter-spacing:-.01em}.card{background:var(--surface);border-radius:var(--radius);padding:12px 14px;margin-bottom:12px;border:1px solid var(--border-light);box-shadow:0 1px 2px rgba(0,0,0,.04)}.card h2{font-size:.9rem;font-weight:600;margin:0 0 10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:var(--control-height);padding:0 12px;border-radius:var(--radius);font-weight:500;font-size:.8125rem;border:1px solid transparent;cursor:pointer;text-decoration:none;transition:background .15s,border-color .15s,transform .1s;box-sizing:border-box}.btn:active{transform:scale(.98)}.btn-primary{background:var(--control-bg);color:var(--control-text);border-color:var(--control-bg)}.btn-primary:hover{background:#333;border-color:#333}.btn-secondary{background:var(--surface);color:var(--text);border-color:var(--border)}.btn-secondary:hover{background:var(--surface2);border-color:var(--border-mid)}.btn-danger{background:var(--danger);color:#fff;border:1px solid var(--danger)}.btn-danger:hover{background:#a00;border-color:#a00}.btn-success{background:var(--success);color:#fff;border:1px solid var(--success)}.btn-success:hover{background:#0a6b0a;border-color:#0a6b0a}.btn-sm{min-height:var(--control-height-sm);padding:0 8px;font-size:.75rem}.form-group{margin-bottom:10px}.form-group label{display:block;margin-bottom:3px;font-weight:500;font-size:.75rem;color:var(--text-muted)}.form-row{display:flex;flex-wrap:wrap;gap:12px}.form-row,.form-row-align-end{align-items:flex-end}.form-group-inline{margin-bottom:0}.form-group-inline label{margin-bottom:4px}.form-control-w140{min-width:120px}.form-control-w160{min-width:140px}.form-control-w180{min-width:160px}.form-control-select{min-width:100px}input[type=email],input[type=number],input[type=password],input[type=search],input[type=text],select,textarea{min-height:var(--control-height);padding:0 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-size:.8125rem;font-family:inherit;box-sizing:border-box;transition:border-color .15s,box-shadow .15s}textarea{min-height:80px;padding:8px 10px;font-size:.8125rem}select{cursor:pointer;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto;min-width:90px}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--border-mid);box-shadow:0 0 0 2px rgba(0,0,0,.06)}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}table{width:100%;border-collapse:collapse}td,th{padding:8px 10px;text-align:left;border-bottom:1px solid var(--border-light);font-size:.8125rem}tbody tr:nth-child(2n){background:rgba(0,0,0,.02)}tbody tr:hover,th{background:var(--surface2)}th{font-weight:600;color:var(--text-muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.03em;border-bottom:1px solid var(--border-mid)}.badge{display:inline-block;padding:2px 6px;border-radius:var(--radius-sm);font-size:.7rem;font-weight:500}.badge-warning{background:var(--surface3);color:var(--text);border:1px solid var(--border-mid)}.badge-ok{background:var(--surface2);color:var(--text-muted);border:1px solid var(--border-light)}.flash{padding:8px 12px;border-radius:var(--radius);margin-bottom:12px;font-size:.8125rem}.flash-error{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger)}.flash-success{background:var(--success-bg);color:var(--success);border:1px solid var(--success)}.article-thumb{width:44px;height:44px;object-fit:cover;border-radius:var(--radius-sm);background:var(--surface2);border:1px solid var(--border-light)}.stock-controls{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}.stock-controls input[type=number],.stock-controls input[type=text]{min-height:var(--control-height-sm);width:64px;text-align:center;padding:0 8px}.stock-controls input[type=text]{width:90px;text-align:left}.stock-controls .btn{min-height:var(--control-height-sm)}td .btn+.btn,td .stock-controls+.btn{margin-left:6px;vertical-align:middle}.shop-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border-light);font-size:.8125rem}.shop-item:last-child{border-bottom:none}.shop-item.checked .shop-item-name{text-decoration:line-through;color:var(--text-muted)}.shop-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--control-bg)}.empty-state{text-align:center;padding:1.5rem 1rem;color:var(--text-muted);font-size:.8125rem}.empty-state p{margin:0 0 .75rem}.scanner-modal{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:16px;visibility:hidden;opacity:0;transition:visibility .2s,opacity .2s}.scanner-modal.scanner-modal-open{visibility:visible;opacity:1}.scanner-modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.75)}.scanner-modal-box{position:relative;background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);padding:14px;width:100%;max-width:380px;max-height:90vh;overflow:auto;box-shadow:0 4px 20px rgba(0,0,0,.12);font-size:.8125rem}.scanner-modal-title{margin:0 0 8px;font-size:1rem;font-weight:600}.scanner-reader{width:100%;min-height:180px;border-radius:var(--radius);overflow:hidden;background:#000}.scanner-reader video{width:100%;display:block}.scanner-modal-hint{margin:8px 0;font-size:.8125rem;color:var(--text-muted)}.scanner-modal-cancel{width:100%;margin-top:8px}.ean-booking-card .form-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.ean-booking-card .ean-input-wrap{flex:1 1;min-width:140px}.ean-booking-result{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-light)}.ean-booking-result .article-info{display:flex;align-items:center;gap:10px;margin-bottom:10px;font-size:.8125rem}.history-table td{font-size:.8125rem}.protocol-layout{display:flex;flex-direction:column;height:calc(100vh - 2rem);height:calc(100dvh - 2rem);max-height:900px;margin:-.5rem -.5rem 0}.protocol-header{flex-shrink:0;background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius) var(--radius) 0 0;padding:10px 12px}.protocol-header-inner{display:flex;align-items:center;flex-wrap:wrap;gap:6px}.protocol-title{margin:0;font-size:1rem;font-weight:600}.protocol-meta{color:var(--text-muted);font-size:.8125rem}.protocol-body{display:grid;grid-template-columns:260px 1fr;flex:1 1;min-height:0;border:1px solid var(--border-light);border-top:none;border-radius:0 0 var(--radius) var(--radius);background:var(--surface)}@media (max-width:768px){.protocol-body{grid-template-columns:1fr}}.protocol-sidebar{border-right:1px solid var(--border-light);display:flex;flex-direction:column;min-height:0;overflow:hidden}.protocol-sidebar-caption{margin:0 10px 6px;padding:6px 8px;font-size:.7rem;color:var(--text-muted);background:var(--surface2);border-radius:var(--radius-sm);border:1px solid var(--border-light);line-height:1.35}.protocol-sidebar-toolbar{display:flex;gap:6px;padding:8px 10px;border-bottom:1px solid var(--border-light)}.protocol-search{flex:1 1;min-width:0;padding:6px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-size:.8125rem}.protocol-new-category{display:flex;gap:6px;padding:6px 10px;border-bottom:1px solid var(--border-light);flex-wrap:wrap}.protocol-new-category input{flex:1 1;min-width:100px;padding:6px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-size:.8125rem}.protocol-tree{flex:1 1;overflow-y:auto;padding:8px 0}.protocol-category{margin-bottom:8px}.protocol-category-header{display:flex;align-items:center;gap:4px;padding:6px 10px;font-size:.8125rem;flex-wrap:wrap}.protocol-category-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);width:100%;margin-bottom:1px}.protocol-category-num{color:var(--text-muted);min-width:1.4em;flex-shrink:0}.protocol-category-title.protocol-title-btn{flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;text-align:left;background:none;border:1px solid transparent;border-radius:var(--radius-sm);padding:3px 5px;cursor:pointer;font-weight:600;font-size:.8125rem;color:var(--text)}.protocol-category-title.protocol-title-btn:hover{background:var(--surface2);border-color:var(--border-light)}.protocol-category-actions{display:flex;align-items:center;gap:4px;margin-left:auto}.protocol-btn-icon{white-space:nowrap}.protocol-inline-edit{flex:1 1;min-width:0;padding:3px 6px;font-size:.8125rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text)}.protocol-inline-edit:focus{outline:none;border-color:var(--border);box-shadow:0 0 0 2px rgba(0,0,0,.1)}.protocol-new-topic{display:flex;gap:6px;padding:4px 12px 8px 36px}.protocol-new-topic input{flex:1 1;padding:4px 6px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-size:.8125rem}.protocol-topics{list-style:none;margin:0;padding:0 0 0 12px}.protocol-topics li{margin:0}.protocol-topic-li{display:flex;align-items:center;gap:6px;padding:2px 0}.protocol-topic-li .protocol-topic-num{flex-shrink:0;font-size:.75rem;color:var(--text-muted);min-width:2em}.protocol-topic-btn{flex:1 1;min-width:0;display:flex;align-items:center;padding:4px 8px;border:none;border-radius:var(--radius-sm);background:none;color:var(--text);font:inherit;font-size:.8125rem;text-align:left;cursor:pointer;transition:background .15s}.protocol-topic-btn:hover{background:var(--surface2)}.protocol-topic-btn.active{background:var(--surface2);font-weight:500;border:1px solid var(--border-light)}.protocol-topic-title-text{overflow:hidden;text-overflow:ellipsis}.protocol-topic-edit{flex:1 1;min-width:0;font-size:.9rem}.protocol-topic-delete-btn,.protocol-topic-edit-btn{flex-shrink:0;width:24px;height:24px;padding:0;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);font-size:.75rem;cursor:pointer;transition:background .15s,color .15s}.protocol-topic-delete-btn:hover,.protocol-topic-edit-btn:hover{background:var(--surface2);color:var(--text)}.protocol-topic-delete-btn:hover{background:var(--danger-bg);color:var(--danger)}.protocol-topic-delete-btn.btn-danger{background:var(--danger);color:#fff;min-height:auto}.protocol-topic-delete-btn.btn-danger:hover{background:#a00;color:#fff}.btn-icon{min-height:auto;padding:0;width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;font-size:.75rem}.protocol-anlagen{flex-shrink:0;padding:8px 12px;border-bottom:1px solid var(--border-light);background:var(--surface2)}.protocol-anlagen-title{font-size:.75rem;font-weight:600;color:var(--text-muted);margin:0 0 6px;text-transform:uppercase;letter-spacing:.03em}.protocol-drop-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:10px 12px;text-align:center;color:var(--text-muted);font-size:.8125rem;background:var(--surface);transition:border-color .2s,background .2s;cursor:pointer}.protocol-drop-zone.drag-over,.protocol-drop-zone:hover{border-color:var(--border);background:var(--surface2)}.protocol-drop-zone input[type=file]{display:none}.protocol-anlagen-list{margin-top:10px;list-style:none;padding:0;margin-bottom:0}.protocol-anlagen-list li{display:flex;align-items:center;gap:6px;padding:4px 0;border-bottom:1px solid var(--border-light);font-size:.8125rem}.protocol-anlagen-list li:last-child{border-bottom:none}.protocol-anlagen-list a{color:var(--text);text-decoration:none;flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis}.protocol-anlagen-list a:hover{text-decoration:underline}.protocol-anlagen-list .btn-danger.btn-icon{flex-shrink:0;width:24px;height:24px;padding:0;display:inline-flex;align-items:center;justify-content:center;font-size:.75rem}.protocol-editor.contenteditable table{width:100%;border-collapse:collapse;margin:8px 0;font-size:.8125rem}.protocol-editor.contenteditable table td,.protocol-editor.contenteditable table th{border:1px solid var(--border-light);padding:6px 8px;text-align:left;font-size:.8125rem}.protocol-editor.contenteditable table th{background:var(--surface2);font-weight:600}.protocol-topic-num{color:var(--text-muted);font-size:.85rem;min-width:2em}.protocol-main{display:flex;flex-direction:column;min-height:0;overflow:hidden}.protocol-editor-header{flex-shrink:0;padding:8px 12px;border-bottom:1px solid var(--border-light);display:flex;align-items:baseline;gap:6px}.protocol-editor-label{font-size:.75rem;color:var(--text-muted);font-weight:500}.protocol-editor-title{margin:0;font-size:.9375rem;font-weight:600}.protocol-toolbar{flex-shrink:0;display:flex;align-items:center;gap:2px;padding:6px 12px;border-bottom:1px solid var(--border-light);flex-wrap:wrap}.protocol-editor-wrap{flex:1 1;min-height:0;padding:10px 12px}.protocol-editor.contenteditable{width:100%;height:100%;min-height:160px;padding:10px;border:1px solid var(--border-light);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font:inherit;font-size:.8125rem;line-height:1.45;overflow-y:auto}.protocol-editor.contenteditable:empty:before{content:attr(data-placeholder);color:var(--text-muted)}.protocol-editor.contenteditable:focus{outline:none;border-color:var(--border);box-shadow:0 0 0 2px rgba(0,0,0,.08)}.protocol-empty{display:flex;align-items:center;justify-content:center;flex:1 1;padding:2rem}.protocol-loading{padding:2rem}