/* ===== LEKKERLAND BESTELLAPP – shared.css ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --blue:#E31837;--blue2:#c0112b;--green:#00a651;--red:#e03535;
  --orange:#f59e0b;--bg:#f7f0f1;--card:#fff;--text:#111827;
  --muted:#6b7280;--border:#e5e7eb;--r:13px;
}
html{height:100%}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  background:var(--bg);color:var(--text);min-height:100%}

/* HEADER – single row */
.hdr{background:var(--blue);color:#fff;display:flex;align-items:center;
  gap:8px;padding:8px 12px 7px;position:sticky;top:0;z-index:200;
  box-shadow:0 2px 8px rgba(0,0,0,.28)}
/* .hdr-top: legacy compat wrapper, transparent to layout */
.hdr-top{display:contents;flex-shrink:0}
.hdr-logo{font-size:1.25rem;flex-shrink:0}
.hdr-titles{flex:1;min-width:0}
.hdr-title{font-size:.88rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hdr-sub{font-size:.62rem;opacity:.72;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hdr-badge{background:var(--orange);color:#fff;border-radius:20px;
  padding:2px 8px;font-size:.7rem;font-weight:700;display:none;flex-shrink:0}
/* NAV TABS – inline icon pills like the gear button */
.topnav{display:flex;gap:5px;flex-shrink:0}
.topnav a{background:rgba(255,255,255,.13);border:1.5px solid rgba(255,255,255,.28);
  color:rgba(255,255,255,.75);border-radius:9px;padding:5px 11px 5px;
  text-decoration:none;cursor:pointer;display:flex;flex-direction:column;
  align-items:center;gap:2px;
  position:relative;transition:background .12s,border-color .12s,color .12s;flex-shrink:0}
.topnav a .ni{font-size:1.15rem;line-height:1.1}
.topnav a span:not(.ni):not(.ndot){font-size:.56rem;font-weight:700;letter-spacing:.02em;
  line-height:1;white-space:nowrap}
.topnav a.active{background:rgba(255,255,255,.28);border-color:rgba(255,255,255,.75);color:#fff}
.topnav a:hover:not(.active){background:rgba(255,255,255,.22);color:#fff}
.topnav .ndot{position:absolute;top:-4px;right:-4px;background:var(--orange);
  color:#fff;border-radius:10px;min-width:14px;height:14px;font-size:.55rem;
  font-weight:700;display:none;align-items:center;justify-content:center;padding:0 2px;
  border:1.5px solid var(--blue)}
/* Einstellungen-Button – gleiche Größe wie Nav-Tabs */
.hdr-gear{background:rgba(255,255,255,.13);border:1.5px solid rgba(255,255,255,.28);
  color:#fff;border-radius:9px;padding:5px 11px;font-size:1.15rem;cursor:pointer;
  flex-shrink:0;transition:background .15s;text-decoration:none;display:flex;
  align-items:center;line-height:1;margin-left:2px}
.hdr-gear:hover{background:rgba(255,255,255,.28)}
.hdr-gear:active{opacity:.8}
/* Kamera-Button im Suchfeld */
.cam-btn{position:absolute;left:7px;top:50%;transform:translateY(-50%);
  background:none;border:none;font-size:1.2rem;cursor:pointer;padding:3px 4px;
  border-radius:7px;line-height:1;z-index:1;transition:background .12s,color .12s}
.cam-btn:hover{background:rgba(0,0,0,.07)}
.cam-btn.on{color:var(--red)}

/* BOTTOM NAV – hidden (replaced by top nav inside header) */
.bnav{display:none!important}

/* PAGE */
.page{padding:12px}

/* CARD */
.card{background:var(--card);border-radius:var(--r);padding:14px;margin-bottom:11px;
  box-shadow:0 1px 4px rgba(0,0,0,.07)}
.card-title{font-size:.9rem;font-weight:700;margin-bottom:10px;display:flex;
  align-items:center;gap:6px}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:5px;
  padding:11px 16px;border:none;border-radius:10px;font-size:.87rem;font-weight:600;
  cursor:pointer;transition:opacity .15s,transform .1s;width:100%}
.btn:active{transform:scale(.98);opacity:.88}
.btn:disabled{opacity:.35;cursor:not-allowed}
.btn-primary{background:var(--blue);color:#fff}
.btn-success{background:var(--green);color:#fff}
.btn-danger{background:var(--red);color:#fff}
.btn-outline{background:transparent;border:1.5px solid var(--blue);color:var(--blue)}
.btn-sm{padding:7px 12px;font-size:.78rem;width:auto;border-radius:8px}
.row{display:flex;gap:8px}.row .btn{flex:1}
.gap-8{display:flex;flex-direction:column;gap:8px}

/* INPUTS */
.inp{width:100%;padding:10px 13px;border:1.5px solid var(--border);border-radius:10px;
  font-size:.93rem;background:#fff;color:var(--text);transition:border-color .15s}
.inp:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(227,24,55,.12)}
.iw{position:relative;margin-bottom:8px}
.iw .ii{position:absolute;left:11px;top:50%;transform:translateY(-50%);
  font-size:.95rem;pointer-events:none}
.iw .inp{padding-left:34px}

/* SELECT */
select{width:100%;padding:9px 12px;border:1.5px solid var(--border);border-radius:10px;
  font-size:.88rem;background:#fff;color:var(--text);-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24'%3E%3Cpath fill='%23888' d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 10px center;margin-bottom:8px}
select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(227,24,55,.12)}

/* RESULT CARDS */
.res-ok{background:#ecfdf5;border:1.5px solid #6ee7b7;border-radius:var(--r);padding:13px;margin-bottom:10px}
.res-ok .rn{font-size:.92rem;font-weight:700;color:#065f46}
.res-ok .rm{font-size:.75rem;margin-top:2px}
.res-ok .ra{font-size:.78rem;color:#047857;margin-top:5px;font-weight:600}
.res-no{background:#fff7ed;border:1.5px solid #fed7aa;border-radius:var(--r);padding:13px;margin-bottom:10px}
.res-no .rn{font-size:.92rem;font-weight:700;color:#92400e}
.res-no .rm{color:#b45309;font-size:.75rem;margin-top:2px}

/* SEARCH DROPDOWN */
.sdrop{background:#fff;border:1.5px solid var(--border);border-radius:10px;
  overflow:hidden;max-height:220px;overflow-y:auto;margin-top:-4px}
.si{padding:9px 13px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .1s}
.si:last-child{border-bottom:none}
.si:active{background:#fdf0f2}
.si-name{font-weight:600;font-size:.85rem}
.si-meta{color:var(--muted);font-size:.72rem;margin-top:1px}

/* BADGES */
.bdg{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;
  border-radius:6px;font-size:.68rem;font-weight:700}
.bdg-plu{background:#dbeafe;color:#1d4ed8}
.bdg-ean{background:#d1fae5;color:#065f46}
.bdg-ll {background:#ede9fe;color:#5b21b6}
.bdg-wg {background:#fef3c7;color:#92400e}
.bdg-ekw{background:#fce7f3;color:#9d174d}

/* CHIPS */
.chip{display:inline-flex;align-items:center;gap:3px;padding:3px 9px;
  border-radius:20px;font-size:.72rem;font-weight:600}
.chip-g{background:#d1fae5;color:#065f46}
.chip-o{background:#fef3c7;color:#92400e}
.chip-b{background:#dbeafe;color:#1e40af}

/* PRODUCT LIST (REGALE) */
.prod-item{display:flex;align-items:center;gap:10px;padding:9px 0;
  border-bottom:1px solid var(--border)}
.prod-item:last-child{border-bottom:none}
.pi-info{flex:1;min-width:0}
.pi-name{font-weight:600;font-size:.87rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pi-meta{font-size:.7rem;color:var(--muted);margin-top:2px;display:flex;flex-wrap:wrap;gap:3px}
.pi-add{width:34px;height:34px;border-radius:50%;border:none;background:var(--blue);
  color:#fff;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;
  justify-content:center;flex-shrink:0;transition:opacity .15s}
.pi-add:active{opacity:.7}
.pi-qty{font-size:.8rem;font-weight:700;color:var(--blue);min-width:20px;text-align:center}

/* ORDER LIST */
.oi{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--border)}
.oi:last-child{border-bottom:none}
.oi-info{flex:1;min-width:0}
.oi-name{font-weight:600;font-size:.87rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.oi-plu{font-size:.7rem;color:var(--muted);margin-top:1px;display:flex;flex-wrap:wrap;gap:3px}
.qrow{display:flex;align-items:center;gap:5px}
.qb{width:29px;height:29px;border-radius:50%;border:none;background:var(--blue);
  color:#fff;font-size:1rem;cursor:pointer;display:flex;align-items:center;
  justify-content:center;flex-shrink:0}
.qb:active{opacity:.7}
.qv{min-width:28px;text-align:center;font-weight:700;font-size:.92rem;
  cursor:pointer;border-radius:5px;padding:2px 5px;transition:background .1s;
  border:1.5px solid transparent}
.qv:hover{background:#f0f0f0;border-color:var(--border)}
.qv-inp{width:48px;text-align:center;font-weight:700;font-size:.92rem;
  border:1.5px solid var(--blue);border-radius:6px;padding:3px 5px;
  outline:none;background:#fff;-webkit-appearance:none;appearance:none;
  box-shadow:0 0 0 3px rgba(227,24,55,.12)}

/* IMPORT MODE MENU */
.imp-wrap{position:relative;display:inline-block}
.imp-menu{position:absolute;top:calc(100% + 5px);left:0;background:#fff;
  border:1.5px solid var(--border);border-radius:11px;
  box-shadow:0 6px 20px rgba(0,0,0,.13);z-index:350;min-width:220px;overflow:hidden}
.imp-opt{padding:11px 14px;cursor:pointer;font-size:.84rem;display:flex;
  align-items:flex-start;gap:9px;border-bottom:1px solid var(--border);transition:background .1s}
.imp-opt:last-child{border-bottom:none}
.imp-opt:hover{background:#fdf0f2}
.imp-opt .io-icon{font-size:1.1rem;flex-shrink:0;margin-top:1px}
.imp-opt .io-label{font-weight:700;display:block}
.imp-opt .io-sub{font-size:.72rem;color:var(--muted);display:block;margin-top:2px;font-weight:400}
.db-btn{background:none;border:none;color:var(--red);font-size:1.05rem;cursor:pointer;padding:3px;opacity:.7}
.db-btn:active{opacity:1}

/* TABLE */
.tw{overflow-x:auto;border-radius:10px;margin-top:6px}
table{width:100%;border-collapse:collapse;font-size:.75rem}
th{background:var(--blue);color:#fff;padding:7px 9px;text-align:left;font-weight:600}
td{padding:6px 9px;border-bottom:1px solid var(--border)}
tr:last-child td{border-bottom:none}
tr:nth-child(even) td{background:#fdf8f8}

/* UPLOAD ZONE */
.upz{border:2px dashed var(--border);border-radius:var(--r);padding:24px 14px;
  text-align:center;cursor:pointer;transition:border-color .2s,background .2s;display:block}
.upz:hover,.upz.drag{border-color:var(--blue);background:#fdf0f2}
.upz input{display:none}
.upz .ui{font-size:2.2rem;margin-bottom:6px}
.upz .ut{font-weight:700;font-size:.92rem;margin-bottom:3px}
.upz .us{font-size:.75rem;color:var(--muted)}

/* ENCODING BUTTONS */
.encrow{display:flex;gap:6px;align-items:center;margin-bottom:8px;flex-wrap:wrap}
.eb{padding:4px 11px;border:1.5px solid var(--border);border-radius:8px;
  background:#fff;font-size:.75rem;cursor:pointer;font-weight:600;transition:all .15s}
.eb.on{border-color:var(--blue);background:#fce4e8;color:var(--blue)}

/* CSV PREVIEW */
.cpre{background:#1e1e2e;color:#cdd6f4;padding:13px;border-radius:10px;
  font-family:'Courier New',monospace;font-size:.75rem;overflow-x:auto;
  white-space:pre;max-height:180px;overflow-y:auto;line-height:1.6}

/* EMPTY STATE */
.empty{text-align:center;padding:32px 18px;color:var(--muted)}
.empty .ei{font-size:2.8rem;margin-bottom:10px}
.empty p{font-size:.85rem;line-height:1.5}

/* SCANNER */
#reader-box{background:#000;border-radius:var(--r);overflow:hidden;margin-bottom:10px;min-height:56px;position:relative}
#reader{width:100%}
#reader video{border-radius:var(--r)}

/* SECTION LABEL */
.slabel{font-size:.72rem;font-weight:700;color:var(--muted);text-transform:uppercase;
  letter-spacing:.05em;margin-bottom:5px}

/* TOAST */
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%) translateY(16px);
  background:#1f2937;color:#fff;padding:9px 18px;border-radius:22px;font-size:.82rem;
  font-weight:500;z-index:500;opacity:0;transition:opacity .25s,transform .25s;
  pointer-events:none;white-space:nowrap;max-width:90vw;overflow:hidden;text-overflow:ellipsis}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* EDIT BUTTON on product items */
.pi-edit{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--border);
  background:#fff;color:var(--muted);font-size:.85rem;cursor:pointer;display:flex;
  align-items:center;justify-content:center;flex-shrink:0;transition:background .12s,color .12s}
.pi-edit:active{background:#f0f4ff;color:var(--blue)}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.52);z-index:400;
  display:none;align-items:flex-end;animation:fadeInBg .18s}
.modal-overlay.open{display:flex}
@keyframes fadeInBg{from{background:rgba(0,0,0,0)}to{background:rgba(0,0,0,.52)}}
.modal-box{background:#fff;border-radius:var(--r) var(--r) 0 0;width:100%;
  max-height:92vh;overflow-y:auto;animation:slideUp .22s ease-out;
  padding-bottom:env(safe-area-inset-bottom,10px)}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.modal-hdr{display:flex;align-items:center;justify-content:space-between;
  padding:14px 14px 10px;border-bottom:1px solid var(--border);
  position:sticky;top:0;background:#fff;z-index:1}
.modal-title{font-weight:700;font-size:.97rem}
.modal-cls{background:none;border:none;font-size:1.35rem;cursor:pointer;
  color:var(--muted);line-height:1;padding:2px 6px;border-radius:6px}
.modal-cls:hover{background:#f3f4f6}
.modal-body{padding:14px}
.mf-label{font-size:.72rem;font-weight:700;color:var(--muted);text-transform:uppercase;
  letter-spacing:.05em;margin-bottom:4px;margin-top:11px;display:block}
.mf-label:first-child{margin-top:0}
.mf-req{color:var(--red)}
.mf-hint{font-size:.7rem;color:var(--muted);margin-top:3px;font-weight:400;text-transform:none;letter-spacing:0}

/* ADD NEW link inside res-no / search-drop */
.add-link{display:inline-flex;align-items:center;gap:5px;margin-top:9px;
  padding:8px 14px;border-radius:9px;background:var(--blue);color:#fff;
  font-size:.82rem;font-weight:600;text-decoration:none;cursor:pointer;border:none}
.add-link:active{opacity:.8}

/* CLICKABLE ARTICLE NAME (scanner / order) */
.oi-name-link{color:inherit;text-decoration:none;cursor:pointer;display:block}
.oi-name-link:visited{color:inherit}
.oi-name-link:hover{color:inherit;text-decoration:none}
.oi-name-link:active{opacity:.7}

/* MODAL LOCK BUTTON */
.modal-lock-btn{background:none;border:1.5px solid rgba(255,255,255,.4);border-radius:8px;
  padding:3px 9px;font-size:1rem;cursor:pointer;color:#fff;margin-left:auto;
  margin-right:6px;transition:background .12s;flex-shrink:0;line-height:1.2}
.modal-lock-btn:hover{background:rgba(255,255,255,.2)}
.modal-lock-btn.unlocked{border-color:rgba(255,255,255,.8);background:rgba(255,255,255,.2)}

/* LOCKED INPUT STATE */
.inp.locked{background:#f5f5f5 !important;color:var(--muted);cursor:default;
  border-color:var(--border) !important;box-shadow:none !important}

/* CODE128 BARCODE AREA */
.bc-wrap{border:1.5px solid var(--border);border-radius:9px;padding:5px 4px 3px;
  background:#fafafa;cursor:pointer;height:68px;min-height:68px;max-height:68px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  overflow:hidden;transition:border-color .12s,background .12s;position:relative}
.bc-wrap:hover{border-color:var(--blue);background:#fdf0f2}
.bc-wrap:active{opacity:.85}
.bc-pill{display:inline-block;background:#fce4e8;color:var(--blue);border-radius:4px;
  padding:1px 6px;font-size:.62rem;font-weight:700;margin-left:4px;letter-spacing:.02em}
.bc-empty{font-size:.73rem;color:var(--muted);text-align:center;padding:8px 0}
/* UTILS */
.mt8{margin-top:8px}.mt12{margin-top:12px}
.txt-m{color:var(--muted);font-size:.8rem}
.divider{height:1px;background:var(--border);margin:10px 0}

/* SETTINGS / LEGAL PAGES */
.set-section{margin-bottom:6px}
.set-section .card-title{margin-bottom:6px}
.set-link{display:flex;align-items:center;gap:10px;padding:11px 14px;
  background:#fff;border-radius:10px;border:1.5px solid var(--border);
  text-decoration:none;color:var(--text);font-size:.88rem;font-weight:600;
  margin-bottom:8px;transition:background .12s,border-color .12s}
.set-link:hover{background:#fdf0f2;border-color:var(--blue)}
.set-link .sl-icon{font-size:1.2rem;flex-shrink:0}
.set-link .sl-text{flex:1}
.set-link .sl-sub{font-size:.72rem;color:var(--muted);font-weight:400;display:block;margin-top:1px}
.set-link .sl-arr{color:var(--muted);font-size:.9rem}
.legal-page h1{font-size:1.05rem;font-weight:700;margin-bottom:6px;color:var(--text)}
.legal-page h2{font-size:.9rem;font-weight:700;margin:14px 0 4px;color:var(--text)}
.legal-page p{font-size:.82rem;color:var(--text);line-height:1.55;margin-bottom:7px}
.legal-page a{color:var(--blue)}
.back-link{display:inline-flex;align-items:center;gap:6px;color:var(--blue);
  font-size:.85rem;font-weight:600;text-decoration:none;padding:8px 0;margin-bottom:4px}
.back-link:active{opacity:.7}

/* UNIVERSAL ARTICLE PREVIEW POPUP */
.apt-overlay{}  /* inherits .modal-overlay */
.apt-box{max-width:420px;margin:0 auto}
.apt-hdr{display:flex;align-items:center;gap:8px;padding:12px 14px 10px;
  border-bottom:1px solid var(--border)}
.apt-hdr-info{flex:1;min-width:0}
.apt-name{font-size:.95rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.apt-meta{font-size:.7rem;color:var(--muted);margin-top:2px;white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis}
.apt-counter{font-size:.72rem;font-weight:700;color:var(--muted);white-space:nowrap;
  background:#f3f4f6;border-radius:20px;padding:2px 9px;flex-shrink:0}
.apt-bc-row{display:flex;align-items:center;gap:6px;padding:12px 10px}
.apt-nav{background:#f3f4f6;border:1.5px solid var(--border);border-radius:10px;
  font-size:2rem;padding:6px 13px;cursor:pointer;flex-shrink:0;color:var(--text);
  transition:background .1s,border-color .1s;line-height:1;font-weight:300}
.apt-nav:hover{background:#e8edff;border-color:var(--blue)}
.apt-nav:active{opacity:.7}
.apt-bc-inner{flex:1;background:#fff;border-radius:8px;border:1.5px solid var(--border);
  padding:8px 6px;min-height:84px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.apt-actions{display:flex;gap:7px;padding:0 14px 14px}
.apt-action-btn{flex:1}

/* FAVOURITE STAR COLUMN */
.th-fav{width:26px!important;min-width:26px!important;cursor:default!important;
  text-align:center!important;padding:5px 3px!important}
.td-fav{width:26px;min-width:26px;padding:2px 3px!important;text-align:center;
  cursor:pointer;user-select:none;vertical-align:middle}
.fav-star{font-size:.95rem;line-height:1;display:inline-block;
  transition:transform .12s;user-select:none}
.td-fav:active .fav-star{transform:scale(.75)}

/* BARCODE POPUP */
.bc-popup-box{max-width:340px;margin:0 auto}
.bc-popup-box .modal-hdr{background:var(--blue)}
.bc-popup-svg-wrap{display:flex;justify-content:center;margin:4px 0 10px;
  background:#fff;border-radius:8px;border:1px solid var(--border);
  padding:8px;min-height:80px;align-items:center;justify-content:center}
.bc-popup-actions{display:flex;gap:8px;margin-top:4px}
.bc-popup-actions .btn{flex:1}
