:root{
--cream:#FBF7EF;--cream-2:#F3ECDF;--paper:#fff;
--ink:#2A2118;--ink-soft:#6B5F50;
--espresso:#2A231B;--espresso-2:#19130E;
--sage:#88A294;--sage-deep:#46634F;--forest:#3D5445;
--sand:#C9A05C;--sand-deep:#A87C3E;--line:#E7DCC9;
--head:'Fraunces',Georgia,serif;--body:'Mulish',system-ui,sans-serif;--tabh:64px;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:var(--body);background:var(--espresso-2);color:var(--ink);-webkit-font-smoothing:antialiased}
.app{max-width:480px;margin:0 auto;min-height:100dvh;background:var(--cream);display:flex;flex-direction:column;position:relative;box-shadow:0 0 40px rgba(0,0,0,.28)}
.appbar{position:sticky;top:0;z-index:20;background:var(--cream);display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--line)}
.appbar img{height:30px;width:auto}
.ab-greet{font-family:var(--head);font-size:1rem;color:var(--ink)}
.views{flex:1;overflow-y:auto;padding:18px 18px calc(var(--tabh) + 26px)}
.view{display:none;animation:fade .25s ease}
.view.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
h2.vh{font-family:var(--head);font-size:1.5rem;font-weight:700;margin-bottom:4px;color:var(--ink)}
.vsub{color:var(--ink-soft);font-size:.92rem;margin-bottom:18px}
.card{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:0 8px 24px rgba(40,30,20,.05);margin-bottom:16px}
.card.dark{background:linear-gradient(160deg,var(--espresso),var(--espresso-2));color:#fff;border:none}
.card.dark .vsub,.card.dark p{color:rgba(255,255,255,.82)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--body);font-weight:800;font-size:.95rem;padding:13px 18px;border-radius:12px;border:none;cursor:pointer;text-decoration:none;transition:.18s;color:#fff}
.btn:active{transform:scale(.98)}
.btn-primary{background:var(--forest)}
.btn-gold{background:var(--sand)}
.btn-ghost{background:transparent;border:1.5px solid var(--line);color:var(--ink)}
.btn-block{width:100%}
.tiles{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.tile{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:16px;text-align:left;cursor:pointer;display:flex;flex-direction:column;gap:5px;transition:.18s;font-family:var(--body)}
.tile:active{transform:scale(.98)}
.tile .ti{font-size:1.5rem}
.tile b{font-family:var(--head);font-weight:600;font-size:1.02rem;color:var(--ink)}
.tile span{font-size:.8rem;color:var(--ink-soft)}
.tile.soon{opacity:.7;cursor:default}
.tile.soon .badge{font-size:.64rem;font-weight:800;text-transform:uppercase;color:var(--sand-deep);letter-spacing:.05em}
.loy-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:14px}
.loy-count{font-family:var(--head);font-size:2rem;font-weight:700;color:#fff}
.loy-count small{font-size:1rem;color:rgba(255,255,255,.7)}
.stamps{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin:6px 0 4px}
.stamp{aspect-ratio:1;border-radius:50%;border:2px dashed rgba(255,255,255,.32);display:grid;place-items:center;color:rgba(255,255,255,.5);font-weight:700;font-size:.85rem}
.stamp.filled{background:var(--sand);border:2px solid var(--sand);color:#fff;font-size:1rem}
.loy-reward{margin-top:14px;background:rgba(255,255,255,.1);border-radius:12px;padding:13px 15px;font-size:.9rem;color:rgba(255,255,255,.92);display:flex;flex-direction:column;gap:6px}
.loy-reward.unlocked{background:var(--sand);color:#fff}
.loy-reward b{font-family:var(--head);font-size:1.05rem}
.qr-card{text-align:center}
.qr-box{display:inline-block;background:#fff;padding:12px;border-radius:14px;border:1px solid var(--line);margin:8px 0}
.qr-box img,.qr-box canvas{display:block}
.qr-token{font-family:ui-monospace,monospace;font-size:.82rem;color:var(--ink-soft);letter-spacing:.03em;word-break:break-all}
.field{margin-bottom:12px}
.field label{display:block;font-size:.82rem;font-weight:700;color:var(--ink-soft);margin-bottom:5px}
.field input{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:12px;font-family:var(--body);font-size:1rem;background:var(--cream)}
.field input:focus{outline:none;border-color:var(--sage)}
.login-err{color:#b3402f;font-size:.86rem;margin-bottom:8px;min-height:1em}
.acct-row{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.acct-av{width:48px;height:48px;border-radius:50%;background:var(--sage);color:#fff;display:grid;place-items:center;font-family:var(--head);font-size:1.3rem;font-weight:700;flex:none}
.acct-row b{font-family:var(--head);font-size:1.1rem;color:var(--ink)}
.acct-row span{display:block;font-size:.84rem;color:var(--ink-soft)}
.muted-link{display:block;text-align:center;margin-top:12px;font-size:.88rem;color:var(--sage-deep);font-weight:700;text-decoration:none}
.tabbar{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:480px;height:var(--tabh);background:rgba(251,247,239,.96);backdrop-filter:blur(10px);border-top:1px solid var(--line);display:flex;z-index:30}
.tab{flex:1;border:none;background:none;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--ink-soft);font-family:var(--body);font-size:.7rem;font-weight:700}
.tab .tic{font-size:1.25rem;line-height:1}
.tab.active{color:var(--forest)}
.install{background:var(--espresso);color:#fff;padding:10px 14px;font-size:.86rem;display:none;align-items:center;justify-content:space-between;gap:10px}
.install.show{display:flex}
.install button{background:var(--sand);border:none;color:#fff;font-weight:800;padding:7px 12px;border-radius:9px;font-size:.82rem;cursor:pointer}
.install .x{background:none;color:rgba(255,255,255,.7);padding:4px 8px;font-size:1.1rem}
.toast{position:fixed;bottom:calc(var(--tabh) + 16px);left:50%;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;padding:11px 18px;border-radius:30px;font-size:.88rem;font-weight:600;opacity:0;transition:.3s;z-index:40;pointer-events:none;max-width:88%;text-align:center}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
/* Scanner */
.scan-stage{position:relative;background:#000;border-radius:14px;overflow:hidden;aspect-ratio:4/3;display:grid;place-items:center}
.scan-stage video{width:100%;height:100%;object-fit:cover}
.scan-frame{position:absolute;inset:18% 12%;border:3px solid rgba(255,255,255,.9);border-radius:12px;box-shadow:0 0 0 9999px rgba(0,0,0,.22)}
.scan-msg{font-size:.84rem;color:var(--ink-soft);text-align:center;margin-top:10px}
.scan-manual{display:flex;gap:8px;margin-top:12px}
.scan-manual input{flex:1;padding:11px 13px;border:1.5px solid var(--line);border-radius:10px;font-size:1rem;background:var(--cream)}
.scan-manual .btn{flex:none}
#scanResult{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:0 8px 24px rgba(40,30,20,.05)}
.scan-prod{font-family:var(--head);font-size:1.1rem;font-weight:700;margin-bottom:10px;color:var(--ink)}
.scan-prod span{display:block;font-family:var(--body);font-size:.8rem;font-weight:500;color:var(--ink-soft);margin-top:2px}
.ampel{border-radius:12px;padding:14px 16px;color:#fff;display:flex;flex-direction:column;gap:3px;margin-bottom:12px}
.ampel b{font-size:1.1rem;font-family:var(--head)}
.ampel span{font-size:.88rem;opacity:.93}
.ampel.gruen{background:#3f7d52}
.ampel.rot{background:#b3402f}
.ampel.gelb{background:#c08a2e}
.scan-disc{font-size:.78rem;color:var(--ink-soft);background:var(--cream-2);border-radius:10px;padding:11px 13px;line-height:1.45;margin:0}

/* Phase 3: Zoeliakie-Tipps */
.help-card{display:flex;align-items:center;gap:14px;width:100%;background:var(--cream-2);border:1px solid var(--line);border-radius:16px;padding:16px;margin-top:14px;cursor:pointer;text-align:left;font-family:var(--body);transition:.18s}
.help-card:active{transform:scale(.98)}
.help-ic{font-size:1.6rem;flex:none}
.help-tx{flex:1;display:flex;flex-direction:column;gap:2px}
.help-tx b{font-family:var(--head);font-size:1rem;color:var(--ink)}
.help-tx span{font-size:.8rem;color:var(--ink-soft)}
.help-arrow{color:var(--sage-deep);font-weight:800;flex:none}
.tip-card{display:flex;gap:14px;align-items:flex-start;background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:16px;box-shadow:0 8px 24px rgba(40,30,20,.05);margin-bottom:12px}
.tip-ic{font-size:1.5rem;flex:none}
.tip-card b{font-family:var(--head);font-size:1.05rem;color:var(--ink);display:block;margin-bottom:3px}
.tip-card p{font-size:.9rem;color:var(--ink-soft);line-height:1.5;margin:0}
.tip-disc{font-size:.8rem;color:var(--ink-soft);background:var(--cream-2);border-radius:10px;padding:12px 14px;line-height:1.45;margin-top:4px}
/* Konto: Bestellungen */
.ord{border-top:1px solid var(--line);padding:12px 0}
.ord-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}
.ord-date{font-weight:700;color:var(--ink);font-size:.9rem}
.ord-badge{font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;padding:3px 9px;border-radius:999px}
.ord-badge.ord-paid{background:#e3efe6;color:#3f7d52}
.ord-badge.ord-open{background:#f3ecdf;color:#a87c3e}
.ord-items{font-size:.86rem;color:var(--ink-soft);margin-bottom:3px}
.ord-total{font-family:var(--head);font-weight:700;color:var(--ink)}
/* Angebote */
.offer-card{display:flex;gap:14px;align-items:flex-start;background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:16px;box-shadow:0 8px 24px rgba(40,30,20,.05);margin-bottom:12px}
.offer-ic{font-size:1.6rem;flex:none}
.offer-tx{flex:1;display:flex;flex-direction:column;gap:4px}
.offer-tx b{font-family:var(--head);font-size:1.05rem;color:var(--ink)}
.offer-tx span{font-size:.88rem;color:var(--ink-soft);line-height:1.45}
.offer-code{align-self:flex-start;margin-top:4px;background:var(--cream-2);border:1px dashed var(--sand);color:var(--sand-deep);font-family:ui-monospace,monospace;font-weight:700;font-size:.85rem;padding:7px 12px;border-radius:9px;cursor:pointer}
.offer-code:active{transform:scale(.97)}
.offer-badge{display:inline-block;align-self:flex-start;background:#e9f3ec;color:#3f7d52;font-size:.72rem;font-weight:800;padding:2px 9px;border-radius:7px;margin:1px 0 2px}
.notif-card{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:18px;margin-top:16px;box-shadow:0 8px 24px rgba(40,30,20,.05)}
.notif-h{display:flex;align-items:center;gap:8px;font-family:var(--head);font-size:1.05rem;color:var(--ink)}
.notif-ic{font-size:1.2rem}
.notif-tx{font-size:.86rem;color:var(--ink-soft);line-height:1.5;margin:8px 0 14px}
.notif-btn{width:100%;background:var(--ink);color:var(--paper);border:0;border-radius:12px;padding:13px;font-weight:800;font-size:.95rem;cursor:pointer;font-family:var(--body)}
.notif-btn.on{background:var(--cream-2);color:var(--ink);border:1.5px solid var(--line)}
.notif-btn:active{transform:scale(.98)}
.notif-state{font-size:.8rem;color:var(--ink-soft);margin-top:10px;text-align:center;line-height:1.4}
.job-hero{background:linear-gradient(135deg,#3a2a1e,#5a4334);color:#fff;border-radius:18px;padding:22px;display:flex;flex-direction:column;gap:6px;margin-bottom:18px}
.job-hero-ic{font-size:1.8rem}
.job-hero b{font-family:var(--head);font-size:1.25rem}
.job-hero span{color:#e8ddd0;font-size:.9rem;line-height:1.45}
.job-h3{font-family:var(--head);font-size:1.05rem;color:var(--ink);margin:18px 0 10px}
.job-perks{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:9px}
.job-perks li{display:flex;align-items:center;gap:10px;font-size:.92rem;color:var(--ink);background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:11px 14px}
.job-perks li span{font-size:1.15rem}
.job-roles{display:flex;flex-direction:column;gap:9px}
.job-role{text-align:left;background:var(--paper);border:1.5px solid var(--line);border-radius:13px;padding:13px 15px;cursor:pointer;display:flex;flex-direction:column;gap:2px;font-family:var(--body)}
.job-role b{color:var(--ink);font-size:.98rem}
.job-role span{color:var(--ink-soft);font-size:.82rem}
.job-role:active{transform:scale(.99);border-color:var(--ink)}
.job-form{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:18px;display:flex;flex-direction:column;gap:10px;margin-top:4px}
.job-form input,.job-form textarea{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:11px;font-family:var(--body);font-size:.95rem;background:#fff;box-sizing:border-box}
.job-form textarea{resize:vertical}
.job-apply-btn{width:100%;background:var(--ink);color:var(--paper);border:0;border-radius:12px;padding:14px;font-weight:800;font-size:.98rem;cursor:pointer;font-family:var(--body)}
.job-apply-btn:active{transform:scale(.98)}
.job-form-msg{font-size:.88rem;font-weight:700;text-align:center;margin:2px 0 0;min-height:1em}
.job-consent{font-size:.74rem;color:var(--ink-soft);line-height:1.45;margin:4px 0 0}
.job-share{width:100%;margin-top:14px;background:var(--cream-2);color:var(--ink);border:1.5px solid var(--line);border-radius:12px;padding:13px;font-weight:700;font-size:.92rem;cursor:pointer;font-family:var(--body)}
.job-share:active{transform:scale(.98)}
.notif-tags{display:flex;flex-direction:column;gap:9px;margin:0 0 14px}
.notif-tags label{display:flex;align-items:center;gap:9px;font-size:.88rem;color:var(--ink);cursor:pointer}
.notif-tags input{width:18px;height:18px;accent-color:var(--ink)}
.treue-nudge{display:flex;align-items:center;gap:12px;background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:14px 16px;margin-top:14px}
.tn-ic{font-size:1.5rem}
.tn-tx{flex:1;display:flex;flex-direction:column;gap:2px}
.tn-tx b{font-size:.95rem;color:var(--ink)}
.tn-tx span{font-size:.8rem;color:var(--ink-soft);line-height:1.4}
.tn-btn{flex:none;background:var(--ink);color:var(--paper);border:0;border-radius:10px;padding:10px 16px;font-weight:800;font-size:.86rem;cursor:pointer;font-family:var(--body)}
.tn-btn:active{transform:scale(.97)}
.job-cv-label{display:block;font-size:.82rem;color:var(--ink-soft);font-weight:700;margin-top:2px}
.job-cv-input{width:100%;font-size:.85rem;color:var(--ink-soft);padding:6px 0}

/* ===== In-App-Shop ===== */
.lh-cart-ov,.lh-cart-drawer{display:none!important}
.shop-bar{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px}
.shop-cartbtn{position:relative;border:1.5px solid var(--line);background:#fff;border-radius:999px;padding:8px 14px;font:800 .82rem/1 inherit;color:var(--ink);cursor:pointer}
.cart-badge{display:inline-block;min-width:18px;height:18px;line-height:18px;text-align:center;background:var(--sage-deep,#5a6b50);color:#fff;border-radius:9px;font-size:.7rem;margin-left:5px;padding:0 5px}
.shop-cats{display:flex;gap:8px;overflow-x:auto;padding:2px 0 12px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.shop-cats::-webkit-scrollbar{display:none}
.shop-cat{flex:none;border:1.5px solid var(--line);background:#fff;border-radius:999px;padding:7px 14px;font:700 .8rem/1 inherit;color:var(--ink);cursor:pointer;white-space:nowrap}
.shop-cat.active{background:var(--sage-deep,#5a6b50);color:#fff;border-color:var(--sage-deep,#5a6b50)}
.shop-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.sp-card{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;display:flex;flex-direction:column}
.sp-card>img{width:100%;aspect-ratio:1/1;object-fit:cover;background:var(--cream-2,#f3ede4)}
.sp-b{padding:10px 11px 12px;display:flex;flex-direction:column;gap:6px;flex:1}
.sp-n{font:700 .92rem/1.2 inherit;color:var(--ink)}
.sp-p{font-weight:800;color:var(--sage-deep,#5a6b50);font-size:.85rem}
.sp-var{display:flex;flex-wrap:wrap;gap:5px}
.sp-var button{border:1.4px solid var(--line);background:#fff;border-radius:8px;padding:4px 8px;font:700 .72rem/1 inherit;color:var(--ink);cursor:pointer}
.sp-var button.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.sp-add{margin-top:auto;border:0;background:var(--sage-deep,#5a6b50);color:#fff;border-radius:10px;padding:9px;font:800 .82rem/1 inherit;cursor:pointer}
.sp-add:active{transform:scale(.98)}
.cart-line{display:flex;gap:12px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:14px;padding:10px;margin-bottom:10px}
.cart-line img{width:62px;height:62px;object-fit:cover;border-radius:10px;flex:none;background:var(--cream-2,#f3ede4)}
.cart-line .ci{flex:1;min-width:0}
.cart-line .ci b{font-size:.9rem;display:block}
.cart-line .ci span{font-size:.78rem;color:var(--ink-soft)}
.cart-qty{display:inline-flex;align-items:center;border:1.5px solid var(--line);border-radius:999px;overflow:hidden}
.cart-qty button{border:0;background:#fff;width:30px;height:30px;font-size:1.1rem;cursor:pointer;color:var(--ink)}
.cart-qty span{min-width:26px;text-align:center;font-weight:700;font-size:.85rem}
.cart-rm{border:0;background:none;color:var(--ink-soft);cursor:pointer;font-size:1.2rem;padding:2px 6px;line-height:1}
.mode-opt{display:flex;align-items:center;gap:9px;border:1.5px solid var(--line);border-radius:12px;padding:10px 13px;cursor:pointer;font-weight:600;font-size:.88rem;margin-bottom:8px}
.mode-opt.active{border-color:var(--sage-deep,#5a6b50);background:#f6faf6}
.cart-sum{display:flex;justify-content:space-between;font-size:.9rem;padding:3px 0;color:var(--ink-soft)}
.cart-sum.total{font-weight:800;color:var(--ink);font-size:1.05rem;border-top:1px solid var(--line);margin-top:6px;padding-top:8px}
.cart-code{display:flex;gap:8px;margin:10px 0}
.cart-code input{flex:1;padding:9px 12px;border:1.5px solid var(--line);border-radius:10px;font-family:inherit;font-size:.85rem;text-transform:uppercase}
.lh-toast{display:none!important}

/* tabbar-clearance: letzter Inhalt nie unter der Tab-Bar */
.view{padding-bottom:110px}
