/* ============================================================
   Shopomat — "Frischmarkt": warm paper, market green, tomato.
   Mobile-first. Eingeben = Mutter, zuhause, ruhig & groß.
   Einkaufen = Shopper, im Laden, schnell & glanceable.
   ============================================================ */

:root {
  --paper:#FBF6EC;
  --paper-2:#F4ECDB;
  --card:#FFFFFF;
  --ink:#221C14;
  --ink-soft:#7A6F5B;
  --line:#EBE2CC;
  --green:#1E6B45;
  --green-deep:#134B30;
  --green-soft:#E6F0E7;
  --tomato:#D6492B;
  --tomato-soft:#FBE7DF;
  --amber:#E0962A;
  --done:#AEA48F;
  --r:20px;
  --r-sm:13px;
  --r-pill:999px;
  --sh:0 1px 2px rgba(34,28,20,.04), 0 10px 28px -12px rgba(34,28,20,.18);
  --sh-soft:0 1px 0 var(--line);
  --tap:56px;
  --font-d:"Fraunces",Georgia,serif;
  --font-b:"Hanken Grotesk",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}

* { box-sizing:border-box; -webkit-tap-highlight-color:transparent; }
html,body { margin:0; padding:0; }

body {
  font-family:var(--font-b);
  color:var(--ink);
  background-color:var(--paper);
  background-image:
    radial-gradient(1200px 600px at 80% -10%, rgba(224,150,42,.10), transparent 60%),
    radial-gradient(900px 500px at -10% 0%, rgba(30,107,69,.08), transparent 55%);
  background-attachment:fixed;
  min-height:100dvh;
  padding-bottom:calc(86px + env(safe-area-inset-bottom));
  line-height:1.45;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

/* faint paper grain */
body::before {
  content:""; position:fixed; inset:0; pointer-events:none; z-index:0; opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='120' height='120' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
}

/* ---------- App bar ---------- */
.appbar {
  position:sticky; top:0; z-index:20;
  padding:calc(env(safe-area-inset-top) + 14px) 20px 12px;
  background:linear-gradient(var(--paper) 68%, rgba(251,246,236,0));
}
.brand { display:flex; align-items:center; gap:11px; max-width:560px; margin:0 auto; }
.brand .mark {
  font-size:22px; width:42px; height:42px; display:grid; place-items:center;
  background:var(--green); color:#fff; border-radius:14px;
  box-shadow:0 6px 16px -6px rgba(30,107,69,.6); transform:rotate(-4deg);
}
.wordmark {
  font-family:var(--font-d); font-weight:700; font-size:23px; letter-spacing:-.02em;
  color:var(--green-deep); display:flex; flex-direction:column; line-height:1;
}
.wordmark small {
  font-family:var(--font-b); font-weight:600; font-size:11px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--ink-soft); margin-top:4px;
}

/* ---------- Layout ---------- */
main#app {
  position:relative; z-index:1;
  max-width:560px; margin:0 auto; padding:6px 16px 24px;
  animation:rise .4s cubic-bezier(.2,.7,.3,1) both;
}
@keyframes rise { from{opacity:0; transform:translateY(8px);} to{opacity:1; transform:none;} }

.card {
  background:var(--card); border:1px solid var(--line); border-radius:var(--r);
  box-shadow:var(--sh); padding:18px; margin-bottom:16px;
}

/* ---------- Section headings (Mutter context) ---------- */
.eyebrow {
  font-family:var(--font-b); font-weight:700; font-size:11px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--ink-soft); margin:22px 4px 10px;
}
.eyebrow:first-child { margin-top:4px; }

/* ---------- Search field ---------- */
.search { position:relative; }
.search::before {
  content:"🔍"; position:absolute; left:18px; top:50%; transform:translateY(-50%);
  font-size:18px; opacity:.5;
}
.search input {
  width:100%; height:62px; padding:0 18px 0 50px;
  font-family:var(--font-b); font-size:18px; font-weight:500; color:var(--ink);
  background:var(--card); border:1.5px solid var(--line); border-radius:var(--r);
  box-shadow:var(--sh); outline:none; transition:border-color .15s, box-shadow .15s;
}
.search input::placeholder { color:var(--ink-soft); font-weight:500; }
.search input:focus {
  border-color:var(--green);
  box-shadow:0 0 0 4px var(--green-soft), var(--sh);
}

/* ---------- Suggestions ---------- */
.suggest { margin-top:10px; background:var(--card); border:1px solid var(--line);
  border-radius:var(--r); box-shadow:var(--sh); overflow:hidden; }
.suggest:empty { display:none; }
.suggestion {
  display:flex; align-items:center; gap:13px; min-height:var(--tap);
  padding:12px 16px; cursor:pointer; border-bottom:1px solid var(--line);
  font-size:17px; font-weight:500;
  animation:fadein .18s ease both;
}
.suggestion:last-child { border-bottom:0; }
.suggestion:active { background:var(--paper-2); }
.suggestion::before {
  content:"🛒"; flex:none; width:38px; height:38px; border-radius:11px;
  background:var(--green-soft); display:grid; place-items:center; font-size:17px;
}
.suggestion[data-new]{ color:var(--tomato); font-weight:700; }
.suggestion[data-new]::before { content:"＋"; background:var(--tomato-soft); color:var(--tomato); font-weight:700; }
@keyframes fadein { from{opacity:0; transform:translateY(-3px);} to{opacity:1;transform:none;} }

/* ---------- New-item sheet ---------- */
#newform {
  margin-top:12px; padding-top:16px; border-top:1px dashed var(--line);
  display:grid; grid-template-columns:1fr; gap:10px;
  animation:rise .25s ease both;
}
#newform .row2 { display:flex; gap:10px; }
select, #newform input, #qty {
  height:54px; padding:0 14px; font-family:var(--font-b); font-size:16px; font-weight:500;
  color:var(--ink); background:var(--card); border:1.5px solid var(--line);
  border-radius:var(--r-sm); outline:none; width:100%;
}
select:focus, #newform input:focus { border-color:var(--green); }
#qty { width:84px; text-align:center; flex:none; }
#newform input[id="note"] { flex:1; }

/* ---------- Buttons ---------- */
button {
  font-family:var(--font-b); cursor:pointer; border:0; color:inherit;
  background:none; transition:transform .08s ease, background .15s, opacity .15s;
}
button:active { transform:scale(.97); }

.btn-primary, #add, #finish, #addstore {
  display:flex; align-items:center; justify-content:center; gap:8px;
  width:100%; min-height:var(--tap); padding:0 20px;
  background:var(--green); color:#fff; font-size:17px; font-weight:700;
  border-radius:var(--r); box-shadow:0 8px 20px -8px rgba(30,107,69,.55);
}
.btn-primary:active, #add:active, #finish:active, #addstore:active { background:var(--green-deep); }
#finish { margin-top:18px; font-size:18px; letter-spacing:.01em; }

/* ---------- Backlog (Mutter sees what's already requested) ---------- */
.group { padding:0; overflow:hidden; }
.group-head {
  display:flex; align-items:center; gap:10px; padding:15px 18px;
  background:var(--green-soft); border-bottom:1px solid var(--line);
}
.group-head .store {
  font-family:var(--font-d); font-weight:600; font-size:18px; color:var(--green-deep);
  letter-spacing:-.01em;
}
.count {
  margin-left:auto; font-size:13px; font-weight:700; color:var(--green-deep);
  background:#fff; border:1px solid var(--line); padding:3px 11px; border-radius:var(--r-pill);
}
.row {
  display:flex; align-items:center; gap:12px; padding:14px 18px;
  border-bottom:1px solid var(--line); font-size:17px;
}
.row:last-child { border-bottom:0; }
.row .name { font-weight:600; }
.row .note { color:var(--ink-soft); font-size:14px; font-weight:500; }
.qty {
  flex:none; min-width:34px; text-align:center; font-weight:700; font-size:14px;
  color:var(--amber); background:#FCEFD6; border-radius:var(--r-pill); padding:3px 9px;
}
.del {
  margin-left:auto; flex:none; width:38px; height:38px; border-radius:11px;
  display:grid; place-items:center; font-size:16px; color:var(--tomato);
  background:var(--tomato-soft);
}

/* ---------- Einkaufen: store chips ---------- */
.chips { display:flex; flex-wrap:wrap; gap:10px; }
.chip {
  min-height:50px; padding:0 20px; border-radius:var(--r-pill);
  background:var(--card); border:1.5px solid var(--line); box-shadow:var(--sh-soft);
  font-size:16px; font-weight:700; color:var(--green-deep);
}
.chip:active { background:var(--green); color:#fff; border-color:var(--green); }

/* ---------- Einkaufen: round list ---------- */
.round-head {
  font-family:var(--font-d); font-weight:600; font-size:20px; color:var(--green-deep);
  margin-bottom:6px;
}
.dept {
  font-family:var(--font-b); font-weight:700; font-size:12px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--ink-soft);
  display:flex; align-items:center; gap:12px; margin:20px 0 8px;
}
.dept::after { content:""; flex:1; height:1px; background:var(--line); }

.check {
  display:flex; align-items:center; gap:14px; padding:14px 4px;
  border-bottom:1px solid var(--line); font-size:18px; cursor:pointer;
}
.check:last-child { border-bottom:0; }
.check input { position:absolute; opacity:0; width:0; height:0; }
.box {
  flex:none; width:30px; height:30px; border-radius:9px;
  border:2.5px solid var(--green); background:#fff;
  display:grid; place-items:center; transition:transform .12s, background .12s;
}
.box::after {
  content:"✓"; color:#fff; font-size:18px; font-weight:800;
  transform:scale(0); transition:transform .15s cubic-bezier(.3,1.5,.5,1);
}
.check input:checked + .box { background:var(--green); animation:pop .25s; }
.check input:checked + .box::after { transform:scale(1); }
@keyframes pop { 50%{ transform:scale(1.18);} }
.check .label { font-weight:600; flex:1; }
.check.done { color:var(--done); }
.check.done .label { text-decoration:line-through; }
.check.done .box { border-color:var(--done); }
.check select {
  flex:none; width:auto; min-width:120px; height:42px; font-size:14px;
  border-radius:var(--r-pill); padding:0 12px;
}

/* ---------- Historie: receipt cards ---------- */
.receipt { position:relative; padding-top:22px; }
.receipt::before {
  content:""; position:absolute; left:0; right:0; top:0; height:10px;
  background:
    radial-gradient(circle at 6px 10px, transparent 6px, var(--card) 7px) repeat-x;
  background-size:14px 12px;
}
.receipt .rh {
  display:flex; align-items:baseline; gap:10px; flex-wrap:wrap;
  padding-bottom:12px; margin-bottom:6px; border-bottom:1.5px dashed var(--line);
}
.receipt .rh .store { font-family:var(--font-d); font-weight:600; font-size:19px; color:var(--green-deep); }
.receipt .rh .date { color:var(--ink-soft); font-size:14px; }
.receipt .total {
  margin-left:auto; font-weight:800; font-size:16px; color:#fff;
  background:var(--green); padding:4px 12px; border-radius:var(--r-pill);
}
.receipt .li {
  display:flex; justify-content:space-between; gap:12px;
  padding:7px 0; font-size:15px; color:var(--ink);
}
.receipt .li .q { color:var(--ink-soft); font-variant-numeric:tabular-nums; }

/* ---------- Setup ---------- */
.setup-add { display:flex; gap:10px; }
.setup-add input { flex:1; }
.setup-add button { flex:none; width:auto; padding:0 18px; }
.dep-pill {
  display:inline-block; margin:4px 6px 0 0; padding:6px 14px;
  background:var(--green-soft); color:var(--green-deep); font-weight:600;
  font-size:14px; border-radius:var(--r-pill);
}

/* ---------- Empty state ---------- */
.empty {
  text-align:center; padding:50px 24px; color:var(--ink-soft);
}
.empty .big { font-size:46px; display:block; margin-bottom:12px; }
.empty p { font-size:16px; font-weight:500; margin:0; }

/* ---------- Bottom tab bar (thumb reach) ---------- */
.tabbar {
  position:fixed; left:0; right:0; bottom:0; z-index:30;
  display:flex; padding:8px 8px calc(8px + env(safe-area-inset-bottom));
  background:rgba(251,246,236,.92); backdrop-filter:saturate(1.4) blur(12px);
  border-top:1px solid var(--line);
}
.tabbar button {
  flex:1; display:flex; flex-direction:column; align-items:center; gap:3px;
  padding:7px 2px; border-radius:14px; color:var(--ink-soft);
}
.tabbar .ic {
  font-size:19px; width:40px; height:32px; display:grid; place-items:center;
  border-radius:var(--r-pill); transition:background .18s, color .18s, transform .18s;
}
.tabbar .lb { font-size:11px; font-weight:700; letter-spacing:.01em; }
.tabbar button.active { color:var(--green-deep); }
.tabbar button.active .ic {
  background:var(--green); color:#fff; transform:translateY(-1px);
  box-shadow:0 6px 14px -6px rgba(30,107,69,.6);
}

/* ---------- Toast (inline, no popups) ---------- */
#toast {
  position:fixed; left:50%; bottom:calc(94px + env(safe-area-inset-bottom));
  transform:translate(-50%,14px); z-index:40;
  background:var(--tomato); color:#fff; font-weight:600; font-size:15px;
  padding:13px 22px; border-radius:var(--r-pill); max-width:88vw;
  box-shadow:0 12px 30px -8px rgba(214,73,43,.6);
  opacity:0; pointer-events:none; transition:opacity .25s, transform .25s;
}
#toast.show { opacity:1; transform:translate(-50%,0); }

/* ---------- Add panel + quantity stepper (Mutter) ---------- */
.addpanel {
  margin-top:12px; background:var(--card); border:1px solid var(--line);
  border-radius:var(--r); box-shadow:var(--sh); padding:18px;
  animation:rise .22s ease both;
}
.addpanel .pick {
  font-family:var(--font-d); font-weight:600; font-size:21px; color:var(--green-deep);
  letter-spacing:-.01em; margin-bottom:6px;
}
.addpanel .sub { color:var(--ink-soft); font-size:14px; font-weight:500; }
.flabel {
  font-size:12px; font-weight:700; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink-soft); margin:18px 2px 8px;
}
.addpanel input, .addpanel select {
  width:100%; height:54px; padding:0 16px; font-family:var(--font-b);
  font-size:16px; font-weight:500; color:var(--ink); background:var(--card);
  border:1.5px solid var(--line); border-radius:var(--r-sm); outline:none;
}
.addpanel input:focus, .addpanel select:focus { border-color:var(--green); }
.stepper { display:flex; align-items:center; gap:18px; }
.stepper button {
  width:60px; height:60px; flex:none; border-radius:18px;
  background:var(--green-soft); color:var(--green-deep);
  font-size:30px; font-weight:700; line-height:1;
  display:grid; place-items:center; border:1.5px solid var(--line);
}
.stepper button:active { background:var(--green); color:#fff; }
.stepper output {
  font-family:var(--font-d); font-weight:700; font-size:30px;
  min-width:54px; text-align:center; font-variant-numeric:tabular-nums;
}
.addpanel .go { margin-top:22px; }
.btn-secondary {
  width:100%; min-height:50px; margin-top:10px;
  background:var(--paper-2); color:var(--ink-soft); font-weight:700;
  font-size:15px; border-radius:var(--r);
}
.btn-secondary:active { background:var(--line); }

@media (min-width:600px){
  .tabbar { max-width:560px; left:50%; transform:translateX(-50%);
    border:1px solid var(--line); border-radius:var(--r) var(--r) 0 0; }
}
