/* public/css/app.css — Kerwe-Kasse */
:root{
  --paper:#F4F1E8; --ink:#22271F; --zelt:#2E6B3F; --zelt-dark:#1F4A2B;
  --rot:#C0392B; --gelb:#F2B705; --blau:#2D7DA8; --card:#FFF; --muted:#7A7E72;
  --radius:18px;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--paper);color:var(--ink);
  display:flex;flex-direction:column;max-width:560px;margin:0 auto;
  min-height:100dvh;user-select:none;
}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select{font:inherit}
.hidden{display:none!important}

/* ---------- Header ---------- */
header{padding:12px 16px 8px;display:flex;align-items:center;justify-content:space-between;gap:8px}
header h1{font-size:1.15rem;font-weight:800;letter-spacing:-.02em}
header h1 .sub{display:block;font-size:.68rem;font-weight:700;color:var(--muted);letter-spacing:.08em;text-transform:uppercase}
.chip{font-size:.7rem;font-weight:700;padding:4px 10px;border-radius:99px;background:#E3EDE5;color:var(--zelt);border:1px solid #C6D8CB;white-space:nowrap}
.chip.offline{background:#F7E2DE;color:var(--rot);border-color:#E8C2BC}
.chip.queue{background:#FBF0D3;color:#8A6A00;border-color:#EBD89A}
.iconbtn{font-size:1.25rem;padding:6px 8px;border-radius:12px;background:#E9E5D8}

/* ---------- Tabs ---------- */
nav.tabs{display:flex;gap:8px;overflow-x:auto;padding:4px 16px 10px;scrollbar-width:none}
nav.tabs::-webkit-scrollbar{display:none}
.tab{flex:0 0 auto;background:#E9E5D8;font-weight:700;font-size:.95rem;padding:10px 18px;border-radius:99px}
.tab.active{background:var(--ink);color:var(--paper)}

/* ---------- Grid ---------- */
main{flex:1;overflow-y:auto;padding:0 12px 150px}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
@media (max-width:370px){.grid{grid-template-columns:repeat(2,1fr)}}
.tile{
  position:relative;background:var(--card);border-radius:var(--radius);
  padding:12px 8px 10px;display:flex;flex-direction:column;align-items:center;gap:5px;
  box-shadow:0 1px 3px rgba(34,39,31,.10);min-height:118px;
  transition:transform .06s;overflow:hidden;
}
.tile:active{transform:scale(.96)}
.tile .bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.35}
.tile>*{position:relative}
.tile .emoji{font-size:1.9rem;line-height:1}
.tile .name{font-size:.8rem;font-weight:700;text-align:center;line-height:1.15;text-shadow:0 0 6px var(--paper)}
.tile .price{font-size:.76rem;font-weight:800;padding:3px 9px;border-radius:99px;color:#fff;background:var(--zelt)}
.tile .hint{font-size:.64rem;color:var(--muted);font-weight:700;text-shadow:0 0 6px var(--paper)}
.tile .badge{
  position:absolute;top:4px;right:4px;background:var(--rot);color:#fff;
  min-width:22px;height:22px;border-radius:99px;font-size:.75rem;font-weight:800;
  display:flex;align-items:center;justify-content:center;padding:0 6px;z-index:2;
}
.tile.soldout{opacity:.4;pointer-events:none}
.tile.soldout .price::after{content:" · AUS"}
.tile.pfandtile .price{background:var(--blau)}
.tile.pfandback .price{background:var(--rot)}

/* ---------- Kassen-Leiste ---------- */
.checkout{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:560px;
  padding:10px 12px calc(12px + env(safe-area-inset-bottom));
  background:linear-gradient(to top,var(--paper) 75%,transparent)}
.checkout-inner{background:var(--zelt-dark);border-radius:22px;padding:10px 12px;
  display:flex;align-items:center;gap:10px;box-shadow:0 6px 24px rgba(31,74,43,.4)}
.total-display{flex:1;background:#10240F;border-radius:14px;padding:7px 14px;
  font-family:"SF Mono",ui-monospace,Menlo,monospace;color:#8CE99A;font-size:1.4rem;
  font-weight:700;letter-spacing:.05em;text-align:right;text-shadow:0 0 8px rgba(140,233,154,.5)}
.total-display.neg{color:#FF9C8A;text-shadow:0 0 8px rgba(255,156,138,.5)}
.total-display .items{display:block;font-size:.6rem;color:#5BA86A;letter-spacing:.12em;text-align:left}
.pay-btn{background:var(--gelb);color:var(--ink);border-radius:14px;font-size:1rem;font-weight:800;padding:14px 18px}
.pay-btn:disabled{opacity:.35}
.cart-btn{color:#CFE3D2;font-size:1.4rem;padding:6px}

/* ---------- Sheets ---------- */
.backdrop{position:fixed;inset:0;background:rgba(20,25,18,.45);opacity:0;pointer-events:none;transition:opacity .2s;z-index:40}
.backdrop.open{opacity:1;pointer-events:auto}
.sheet{position:fixed;bottom:0;left:50%;transform:translate(-50%,105%);width:100%;max-width:560px;
  background:var(--card);border-radius:24px 24px 0 0;
  padding:18px 18px calc(24px + env(safe-area-inset-bottom));
  transition:transform .25s cubic-bezier(.3,1.1,.4,1);z-index:50;
  box-shadow:0 -8px 40px rgba(0,0,0,.2);max-height:85dvh;overflow-y:auto}
.sheet.open{transform:translate(-50%,0)}
.sheet h2{font-size:1.05rem;font-weight:800;margin-bottom:12px}
.row-btn{display:flex;justify-content:space-between;align-items:center;width:100%;
  background:#F4F1E8;border-radius:14px;padding:15px;margin-bottom:8px;font-size:1rem;font-weight:700;text-align:left}
.row-btn.sel{outline:3px solid var(--zelt);background:#E8F1EA}
.row-btn .p{color:var(--zelt);font-weight:800}
.grouplabel{font-size:.78rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin:10px 0 6px}
.qty-line{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.qty-btn{width:44px;height:44px;border-radius:12px;background:#F4F1E8;font-size:1.4rem;font-weight:800}
.qty-val{min-width:40px;text-align:center;font-size:1.3rem;font-weight:800}
.primary{display:block;width:100%;background:var(--ink);color:var(--paper);border-radius:14px;
  font-size:1.05rem;font-weight:800;padding:16px;margin-top:12px}
.primary.green{background:var(--zelt)}
.primary.yellow{background:var(--gelb);color:var(--ink)}
.primary:disabled{opacity:.4}
.toggle-line{display:flex;align-items:center;gap:10px;padding:12px 4px;font-weight:700}
.toggle-line input{width:22px;height:22px;accent-color:var(--zelt)}

/* Warenkorb */
.cart-row{display:flex;align-items:center;gap:8px;padding:9px 0;border-bottom:1px solid #EEE9DC;font-size:.92rem}
.cart-row .n{flex:1;font-weight:600}
.cart-row .n small{display:block;color:var(--muted);font-weight:500}
.cart-row .q{min-width:20px;text-align:center;font-weight:800}
.cart-row .p{min-width:62px;text-align:right;font-weight:700;font-variant-numeric:tabular-nums}
.cart-row .p.neg{color:var(--rot)}
.cart-row.sub{padding-left:18px;color:var(--muted);border-bottom:none;margin-top:-6px;font-size:.85rem}
.cart-row .qty-btn{width:34px;height:34px;font-size:1.1rem}
.sum-line{display:flex;justify-content:space-between;font-size:1.15rem;font-weight:800;padding:14px 0 4px}
.linkbtn{color:var(--rot);font-weight:700;font-size:.85rem;padding:10px 0}

/* ---------- Bezahlen / Numpad ---------- */
.paychoice{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:8px}
.paychoice button{border-radius:16px;padding:22px 10px;font-size:1.1rem;font-weight:800}
.paychoice .karte{background:var(--ink);color:#fff}
.paychoice .bar{background:var(--zelt);color:#fff}
.paychoice button:disabled{opacity:.35}
.amount-line{display:flex;justify-content:space-between;font-size:1.05rem;font-weight:700;padding:8px 2px}
.amount-line .v{font-variant-numeric:tabular-nums;font-weight:800}
.amount-line.change .v{font-size:1.5rem;color:var(--zelt)}
.amount-line.change.neg .v{color:var(--rot)}
.numpad{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:10px}
.numpad button{background:#F4F1E8;border-radius:14px;font-size:1.5rem;font-weight:700;padding:14px 0}
.quick{display:flex;gap:8px;margin-top:10px}
.quick button{flex:1;background:#E8F1EA;color:var(--zelt-dark);border-radius:12px;font-weight:800;padding:12px 0}

/* ---------- Overlays ---------- */
.overlay{position:fixed;inset:0;z-index:100;background:var(--ink);color:#fff;display:flex;
  flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:30px;gap:16px}
.overlay .amount{font-family:ui-monospace,Menlo,monospace;font-size:2.4rem;font-weight:700;color:#8CE99A}
.overlay .big{font-size:3.4rem}
.overlay .step{font-size:.95rem;color:#B8BDB0;max-width:300px;line-height:1.5}
.overlay .change-big{font-size:1.2rem;color:#B8BDB0}
.overlay .change-big b{display:block;font-size:2.2rem;color:#FFD75E}
.spinner{width:46px;height:46px;border-radius:50%;border:4px solid #3A4136;border-top-color:#8CE99A;animation:spin .9s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.overlay .done-btn{background:var(--gelb);color:var(--ink);border-radius:14px;font-size:1.05rem;font-weight:800;padding:15px 30px;margin-top:6px}
.overlay .ghost-btn{color:#B8BDB0;font-weight:700;padding:10px}

/* ---------- Login ---------- */
.login-wrap{margin:auto;width:100%;max-width:380px;padding:24px}
.login-wrap h1{font-size:1.5rem;font-weight:800;margin-bottom:4px}
.login-wrap .sub{color:var(--muted);font-weight:600;margin-bottom:22px}
.field{margin-bottom:14px}
.field label{display:block;font-size:.78rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.field input,.field select{width:100%;padding:14px;border-radius:14px;border:1.5px solid #D9D4C5;background:#fff;font-size:1rem}
.error-msg{color:var(--rot);font-weight:700;font-size:.9rem;min-height:1.4em;margin:6px 0}

/* ---------- Admin ---------- */
.admin main{padding-bottom:40px}
table.data{width:100%;border-collapse:collapse;font-size:.88rem;margin:8px 0}
table.data th{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);text-align:left;padding:6px 8px;border-bottom:2px solid #E0DCCE}
table.data td{padding:7px 8px;border-bottom:1px solid #ECE8DB;font-variant-numeric:tabular-nums}
table.data td.r,table.data th.r{text-align:right}
.card{background:#fff;border-radius:16px;padding:14px;margin:10px 0;box-shadow:0 1px 3px rgba(34,39,31,.08)}
.card h3{font-size:.95rem;font-weight:800;margin-bottom:8px}
.bar-row{display:flex;align-items:center;gap:8px;font-size:.8rem;margin:3px 0}
.bar-row .lbl{width:88px;color:var(--muted);font-weight:700}
.bar-row .bar{height:16px;background:var(--zelt);border-radius:4px;min-width:2px}
.bar-row .val{font-weight:700;font-variant-numeric:tabular-nums}
.inline-edit{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.inline-edit input[type=text]{flex:1;min-width:110px;padding:8px;border-radius:10px;border:1px solid #D9D4C5}
.inline-edit input[type=number]{width:84px;padding:8px;border-radius:10px;border:1px solid #D9D4C5}
.minibtn{background:#E9E5D8;border-radius:10px;padding:8px 10px;font-weight:700;font-size:.82rem}
.minibtn.danger{background:#F7E2DE;color:var(--rot)}
.minibtn.on{background:var(--zelt);color:#fff}
.art-row{border-bottom:1px solid #ECE8DB;padding:10px 0}
.art-row .head{display:flex;align-items:center;gap:8px;font-weight:700}
.art-row .head .nm{flex:1}
@media (prefers-reduced-motion:reduce){.sheet{transition:none}.spinner{animation-duration:2s}}
