*{box-sizing:border-box}
body{margin:0;background:#eef3f8;color:#102a43;font-family:Arial,Helvetica,sans-serif;font-size:16px}
.appShell{display:grid;grid-template-columns:270px 1fr;min-height:100vh}
.sidebar{background:#0b2b45;color:white;padding:18px;position:sticky;top:0;height:100vh}
.logoBox{display:flex;gap:12px;align-items:center;margin-bottom:26px}
.logo{width:52px;height:52px;border-radius:16px;background:#dc2626;display:flex;align-items:center;justify-content:center;font-weight:900}
.logoBox h1{font-size:22px;margin:0}.logoBox p{margin:3px 0;color:#c9d6e2}
.nav{display:block;width:100%;margin:8px 0;padding:13px;border:0;border-radius:12px;background:#153b5c;color:#dbeafe;text-align:left;font-size:16px;cursor:pointer}
.nav.active{background:white;color:#0b2b45;font-weight:900}
.content{padding:22px;min-width:0}
.topbar{display:flex;justify-content:space-between;align-items:center;background:white;border-radius:18px;padding:18px 22px;box-shadow:0 8px 26px #0b2b4512;margin-bottom:18px}
.topbar h2{margin:0;font-size:28px}.topbar p{margin:4px 0;color:#64748b}
button{border:0;border-radius:10px;padding:12px 16px;font-size:16px;background:#d9e2ec;cursor:pointer;font-weight:700}
.primary{background:#087f3e;color:white}.danger{background:#dc2626;color:white}.full{width:100%;margin-top:14px}
input,select{width:100%;padding:13px;border:2px solid #bcccdc;border-radius:10px;font-size:17px;background:white}
label{display:block;margin-top:12px;font-weight:800}
.page{display:none}.page.active{display:block}
.loginCard,.card{background:white;border-radius:18px;padding:20px;box-shadow:0 8px 26px #0b2b4512;border:1px solid #d9e2ec}
.loginCard{max-width:520px;margin:40px auto}
.note{background:#fff3cd;color:#664d03;border-radius:12px;padding:12px}
.statsGrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
.stat{background:white;border-radius:18px;padding:20px;box-shadow:0 8px 26px #0b2b4512;border-left:7px solid #087f3e}
.stat.red{border-left-color:#dc2626}.stat b{display:block;font-size:36px}.stat span{color:#64748b;font-weight:700}
.grid2{display:grid;grid-template-columns:1fr 340px;gap:18px}
.itemsGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin:14px 0}
.itemBox{background:#f8fafc;border:1px solid #d9e2ec;border-radius:12px;padding:10px}
.row{display:grid;grid-template-columns:1fr 120px 160px;gap:10px;margin-bottom:14px}
.listRow{display:grid;grid-template-columns:1fr 110px 90px;gap:8px;align-items:center;border-bottom:1px solid #e2e8f0;padding:9px 0}
.productRow{grid-template-columns:1fr 90px 80px 90px 90px 90px}
.productRow button{padding:10px 8px;font-size:14px}
.customerRow{display:grid;grid-template-columns:1fr 150px 90px;gap:8px;align-items:center;border-bottom:1px solid #e2e8f0;padding:9px 0}
.toolbar{display:grid;grid-template-columns:1fr 140px 150px;gap:10px;margin-bottom:14px}
.groupCard{background:white;border-radius:18px;margin-bottom:18px;overflow:hidden;box-shadow:0 8px 26px #0b2b4512;border:1px solid #d9e2ec}
.groupHead{display:flex;justify-content:space-between;align-items:center;background:#f8fafc;padding:14px 16px;border-bottom:1px solid #d9e2ec}
.groupHead h3{margin:0;font-size:24px;color:#087f3e}
.badge{padding:7px 12px;border-radius:999px;font-weight:900}.badge.open{background:#ffe8cc;color:#d9480f}.badge.done{background:#d3f9d8;color:#087f3e}.badge.problem{background:#ffe3e3;color:#c92a2a}
.palletGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:12px;padding:16px}
.pallet{border:3px solid #ff6b6b;background:#fff1f1;color:#dc0000;border-radius:16px;padding:16px;text-align:center;cursor:pointer;font-weight:900;transition:.15s}
.pallet:hover{transform:scale(1.03);background:#ffd6d6}
.pallet.ok{background:#d3f9d8!important;color:#087f3e!important;border-color:#087f3e!important}
.pallet.bad{background:#ffe3e3!important;color:#c92a2a!important;border-color:#c92a2a!important;text-decoration:line-through}
.pallet .name{font-size:18px}.pallet .qty{font-size:32px;margin-top:8px}
.groupDetails{padding:0 16px 16px}
.excel{width:100%;border-collapse:collapse;font-size:14px}.excel th,.excel td{border:1px solid #cbd5e1;padding:7px;text-align:center}.excel th{background:#cbd7ef;color:#003b88}.excel td.customer{text-align:left;font-weight:800;color:#087f5b}
.archiveOrder{border:1px solid #d9e2ec;border-radius:14px;padding:14px;margin:12px 0;background:#f8fafc}
.productTotals{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.totalCard{background:#f8fafc;border:1px solid #d9e2ec;border-radius:14px;padding:14px}.totalCard b{font-size:26px;color:#087f3e}
@media(max-width:1000px){.appShell{grid-template-columns:1fr}.sidebar{height:auto;position:static}.grid2{grid-template-columns:1fr}.statsGrid{grid-template-columns:1fr 1fr}.toolbar,.row{grid-template-columns:1fr}.content{padding:12px}.excel{font-size:12px}}
@media print{.sidebar,.topbar,.toolbar,.groupHead button{display:none}.appShell{display:block}.content{padding:0}.card,.groupCard{box-shadow:none;border:0}.pallet{border-width:1px}}
.weightInput{width:70px;padding:7px;border:1px solid #cbd5e1;border-radius:8px;text-align:center;font-weight:700;font-size:15px;background:#fff}
#groupsList .listRow{justify-content:space-between}

.totalCard.clickable{cursor:pointer;transition:.15s}
.totalCard.clickable:hover{transform:scale(1.02);border-color:#087f3e;background:#eefbf3}
.totalCard.selected{border:3px solid #087f3e;background:#d3f9d8}
.dashboardDetails{margin-top:18px}
.prepBox{background:#fff;border:2px solid #087f3e;border-radius:16px;padding:16px}
.prepHead{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}
.prepHead h3{margin:0;color:#087f3e;font-size:26px}
.prepList{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:10px}
.prepRow{display:grid;grid-template-columns:100px 1fr 90px;gap:8px;align-items:center;border:1px solid #d9e2ec;border-radius:12px;padding:12px;background:#f8fafc;font-weight:800}
.prepQty{font-size:22px;color:#0b2b45;font-weight:900}
.prepTotal{margin-top:14px;padding:12px;background:#fff3cd;border-radius:12px;text-align:right;font-size:24px;font-weight:900;color:#0b2b45}
@media print{.statsGrid,.productTotals .totalCard:not(.selected),.note{display:none}.prepBox{border:0}.prepHead button{display:none}}

/* Mitarbeiter-Modus: nur Dashboard + Kontrolle sichtbar */
.workerMode #newDayBtn{display:none!important}
.workerMode #statDoneOrders{opacity:.65}
.workerMode .sidebar .nav[hidden]{display:none!important}


/* V10 Security UI: before login hide whole app navigation/content */
.loggedOut .sidebar{display:none!important}
.loggedOut .appShell{display:block;min-height:100vh}
.loggedOut .content{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.loggedOut .topbar{display:none!important}
.loggedOut #appPage{display:none!important}
.loggedOut .loginCard{margin:0;width:100%;max-width:520px}
.loggedIn .sidebar{display:block}


/* V13: Gesamtübersicht aller offenen Bestellungen */
.cardHead{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}
.cardHead h3{margin:0}
.secondary{background:#e2e8f0;color:#0b2b45}
.allOrdersBox{margin-top:18px}
.allOrdersCard{background:#fff;border:2px solid #0b2b45;border-radius:16px;padding:16px}
.tableScroll{overflow:auto;max-width:100%}
.allOrdersTable{min-width:1200px;font-size:15px}
.allOrdersTable .groupTitle td{background:#e6f0ff;color:#003b88;font-size:18px;font-weight:900;text-align:left}
.allOrdersTable .groupCell{font-weight:800;color:#0b2b45;background:#f8fafc;white-space:nowrap}
.allOrdersTable .num{font-weight:800;text-align:center}
.allOrdersTable .subtotal td{color:#dc0000;font-weight:900;background:#f8fafc}
.allOrdersTable .grandTotal td{color:#dc0000;font-weight:900;background:#fff3cd;font-size:17px}
@media(max-width:1000px){.cardHead{align-items:stretch;flex-direction:column}.allOrdersTable{font-size:13px}}
@media print{.allOrdersCard{border:0;padding:0}.allOrdersTable{font-size:11px;min-width:0}.allOrdersBox[hidden]{display:none!important}}


/* V16: one-page report + Excel export */
.reportButtons{display:flex;gap:10px;align-items:center;justify-content:flex-end}
.reportButtons button:first-child{background:#087f3e;color:#fff}
@media print{
  @page{size:landscape;margin:7mm}
  body.printAllOrdersOnly .sidebar,
  body.printAllOrdersOnly .topbar,
  body.printAllOrdersOnly .statsGrid,
  body.printAllOrdersOnly .productTotals,
  body.printAllOrdersOnly .dashboardDetails,
  body.printAllOrdersOnly .cardHead,
  body.printAllOrdersOnly .reportButtons,
  body.printAllOrdersOnly .note{display:none!important}
  body.printAllOrdersOnly .appShell{display:block!important}
  body.printAllOrdersOnly .content{padding:0!important}
  body.printAllOrdersOnly .card{box-shadow:none!important;border:0!important;padding:0!important}
  body.printAllOrdersOnly .allOrdersBox{display:block!important;margin:0!important}
  body.printAllOrdersOnly .allOrdersCard{border:0!important;padding:0!important;box-shadow:none!important}
  body.printAllOrdersOnly .tableScroll{overflow:visible!important}
  body.printAllOrdersOnly .allOrdersTable{width:100%!important;min-width:0!important;font-size:10px!important}
  body.printAllOrdersOnly .allOrdersTable th,
  body.printAllOrdersOnly .allOrdersTable td{padding:3px!important}
  body.printAllOrdersOnly .prepTotal{font-size:16px!important;margin-top:6px!important}
}


/* V17: Excel/Druck buttons always visible and clean one-page print */
.topReportButtons{margin-left:auto;display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.topReportButtons button{white-space:nowrap}
@media(max-width:900px){.topReportButtons{width:100%;justify-content:flex-start}.topReportButtons button{flex:1}}
@media print{
  body.printAllOrdersOnly .allOrdersTable{table-layout:fixed!important;width:100%!important;font-size:8px!important;line-height:1.05!important}
  body.printAllOrdersOnly .allOrdersTable th,
  body.printAllOrdersOnly .allOrdersTable td{padding:2px!important;word-break:break-word!important}
  body.printAllOrdersOnly .allOrdersTable .groupTitle td{font-size:10px!important}
}

.archiveTools{display:flex;gap:10px;align-items:center;flex-wrap:wrap;background:#fff3cd;border:1px solid #ffe69c;border-radius:12px;padding:12px;margin-bottom:14px}
.archiveTools button,.archiveHead button{border:0;border-radius:10px;padding:9px 12px;font-weight:800;background:#e9f2ff;color:#0b3f78;cursor:pointer}
.archiveHead{display:flex;align-items:center;justify-content:space-between;gap:10px}
