:root{
  --plum-950:#1a0836; --plum-900:#241046; --plum-800:#2e1065; --plum-700:#3b1580;
  --violet:#7c3aed; --violet-2:#8b5cf6; --violet-soft:#a78bfa; --violet-glow:#c4b5fd;
  --ink:#f4f0ff; --ink-dim:#c9bfe6; --ink-faint:#9a8fc0;
  --glass:rgba(124,58,237,.10); --glass-2:rgba(167,139,250,.07);
  --stroke:rgba(167,139,250,.22); --stroke-2:rgba(196,181,253,.12);
  --green:#34d399; --lime:#a3e635; --amber:#fbbf24; --red:#f87171;
  --shadow:0 18px 50px -20px rgba(0,0,0,.7);
  --r:20px; --r-sm:14px;
  --nav-h:74px;
  --sans:'Instrument Sans',system-ui,sans-serif;
  --disp:'Bricolage Grotesque',system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0}
body{
  font-family:var(--sans); color:var(--ink); background:var(--plum-950);
  min-height:100dvh; overflow-x:hidden;
  padding-bottom:calc(var(--nav-h) + env(safe-area-inset-bottom));
  -webkit-font-smoothing:antialiased;
}

/* ---------- Skylrk-ish soft glossy background ---------- */
.bg{position:fixed;inset:0;z-index:-2;background:
  radial-gradient(120% 90% at 50% -10%, var(--plum-700), var(--plum-950) 60%);overflow:hidden}
.bg span{position:absolute;border-radius:50%;filter:blur(60px);opacity:.55;mix-blend-mode:screen}
.bg span:nth-child(1){width:70vw;height:70vw;left:-15vw;top:-10vw;
  background:radial-gradient(circle,#7c3aed,transparent 70%);animation:drift1 22s ease-in-out infinite}
.bg span:nth-child(2){width:55vw;height:55vw;right:-12vw;top:22vh;
  background:radial-gradient(circle,#a78bfa,transparent 70%);animation:drift2 27s ease-in-out infinite}
.bg span:nth-child(3){width:60vw;height:60vw;left:10vw;bottom:-20vh;
  background:radial-gradient(circle,#5b21b6,transparent 70%);animation:drift3 30s ease-in-out infinite}
@keyframes drift1{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(6vw,4vh) scale(1.08)}}
@keyframes drift2{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-5vw,5vh) scale(1.12)}}
@keyframes drift3{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(4vw,-4vh) scale(1.06)}}
.grain{position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ---------- Header ---------- */
.app-header{position:sticky;top:0;z-index:20;padding:calc(env(safe-area-inset-top) + 14px) 18px 12px;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  background:linear-gradient(180deg,rgba(26,8,54,.82),rgba(26,8,54,.35) 70%,transparent);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}
.brand{display:flex;align-items:center;gap:11px}
.brand .logo{width:42px;height:42px;border-radius:12px;box-shadow:0 6px 18px -6px var(--violet)}
.brand h1{font-family:var(--disp);font-weight:800;font-size:1.42rem;margin:0;letter-spacing:-.02em;line-height:1}
.brand .tag{margin:3px 0 0;font-size:.72rem;color:var(--ink-faint);letter-spacing:.01em}
.header-right{display:flex;align-items:center;gap:8px}
.sync-btn{width:34px;height:34px;flex:none;border-radius:11px;border:1px solid var(--stroke);background:var(--glass);
  display:grid;place-items:center;cursor:pointer}
.sync-btn:active{transform:scale(.94)}
.sync-dot{width:11px;height:11px;border-radius:50%;background:var(--ink-faint);transition:.2s;
  box-shadow:0 0 0 0 rgba(0,0,0,0)}
.sync-dot.ok{background:var(--green);box-shadow:0 0 8px var(--green)}
.sync-dot.err{background:var(--red);box-shadow:0 0 8px var(--red)}
.sync-dot.sync{background:var(--amber);animation:pulse 1s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.4;transform:scale(.85)}50%{opacity:1;transform:scale(1.15)}}
.header-stats{display:flex;gap:8px;text-align:right}
.header-stats .stat{background:var(--glass);border:1px solid var(--stroke);border-radius:12px;padding:6px 10px;min-width:52px}
.header-stats .stat b{font-family:var(--mono);font-size:.95rem;display:block;line-height:1.1}
.header-stats .stat small{font-size:.6rem;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.06em}

/* ---------- Views ---------- */
main{max-width:640px;margin:0 auto;padding:14px 16px 40px}
.view{display:none;animation:fade .35s ease}
.view.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ---------- Today card ---------- */
.today-card{background:linear-gradient(135deg,rgba(124,58,237,.22),rgba(167,139,250,.06));
  border:1px solid var(--stroke);border-radius:var(--r);padding:15px 16px;margin-bottom:16px;
  box-shadow:var(--shadow);position:relative;overflow:hidden}
.today-card::before{content:"";position:absolute;top:-40%;right:-10%;width:180px;height:180px;
  background:radial-gradient(circle,rgba(196,181,253,.35),transparent 70%);filter:blur(6px)}
.today-card .tc-top{display:flex;justify-content:space-between;align-items:baseline;position:relative}
.today-card h2{font-family:var(--disp);font-weight:700;font-size:.82rem;text-transform:uppercase;
  letter-spacing:.08em;color:var(--violet-glow);margin:0}
.today-card .cal{font-family:var(--mono);font-size:1.7rem;font-weight:700;letter-spacing:-.02em}
.today-card .cal small{font-size:.8rem;color:var(--ink-faint);font-weight:500}
.macros{display:flex;gap:16px;margin-top:8px;position:relative}
.macros div{font-size:.78rem;color:var(--ink-dim)}
.macros div b{font-family:var(--mono);color:var(--ink);font-size:.95rem;display:block}

/* ---------- Toolbar ---------- */
.toolbar{display:flex;gap:9px;margin-bottom:12px}
.search{flex:1;display:flex;align-items:center;gap:8px;background:var(--glass);border:1px solid var(--stroke);
  border-radius:var(--r-sm);padding:0 12px}
.search .ic{width:17px;height:17px;stroke:var(--ink-faint);fill:none;stroke-width:2;flex:none}
.search input{flex:1;background:none;border:0;outline:0;color:var(--ink);font-family:var(--sans);font-size:.95rem;padding:11px 0}
.search input::placeholder{color:var(--ink-faint)}
select#sortSel{background:var(--glass);color:var(--ink);border:1px solid var(--stroke);border-radius:var(--r-sm);
  padding:0 10px;font-family:var(--sans);font-size:.85rem;outline:0;appearance:none}
select#sortSel option{background:var(--plum-900);color:var(--ink)}

/* ---------- Chips ---------- */
.chips{display:flex;gap:8px;overflow-x:auto;padding-bottom:12px;margin:0 -16px 4px;padding-left:16px;padding-right:16px;
  scrollbar-width:none}
.chips::-webkit-scrollbar{display:none}
.chip{flex:none;background:var(--glass);border:1px solid var(--stroke);color:var(--ink-dim);
  border-radius:999px;padding:7px 13px;font-size:.8rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:.18s}
.chip.active{background:var(--violet);border-color:var(--violet-2);color:#fff;box-shadow:0 6px 16px -6px var(--violet)}
.chip .n{font-family:var(--mono);opacity:.7;margin-left:4px;font-size:.72rem}

/* ---------- Pantry grid ---------- */
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
@media(min-width:560px){.grid{grid-template-columns:repeat(3,1fr)}}
.card{background:var(--glass-2);border:1px solid var(--stroke-2);border-radius:var(--r-sm);overflow:hidden;
  position:relative;display:flex;flex-direction:column;box-shadow:0 10px 24px -18px #000;transition:.2s}
.card:active{transform:scale(.98)}
.card .thumb{aspect-ratio:1.35;background:linear-gradient(135deg,var(--plum-700),var(--plum-900));
  display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.card .thumb img{width:100%;height:100%;object-fit:contain;padding:8px;background:#fff}
.card .thumb .noimg{font-family:var(--disp);font-weight:800;font-size:1.6rem;color:var(--violet-soft);opacity:.55}
.card .grade{position:absolute;top:7px;left:7px;width:26px;height:26px;border-radius:8px;display:grid;place-items:center;
  font-family:var(--mono);font-weight:700;font-size:.72rem;color:#0b0616;box-shadow:0 3px 8px rgba(0,0,0,.4)}
.card .body{padding:10px 11px 12px;flex:1;display:flex;flex-direction:column;gap:6px}
.card .name{font-weight:600;font-size:.9rem;line-height:1.2;letter-spacing:-.01em}
.card .brand{font-size:.7rem;color:var(--ink-faint);margin-top:-3px}
.card .meta{display:flex;flex-wrap:wrap;gap:5px;margin-top:auto}
.badge{font-size:.64rem;padding:3px 7px;border-radius:6px;font-weight:600;white-space:nowrap;
  background:var(--glass);border:1px solid var(--stroke);color:var(--ink-dim)}
.badge.cat{color:var(--violet-glow)}
.exp-ok{background:rgba(52,211,153,.14);border-color:rgba(52,211,153,.3);color:#6ee7b7}
.exp-warn{background:rgba(163,230,53,.14);border-color:rgba(163,230,53,.3);color:#bef264}
.exp-soon{background:rgba(251,191,36,.16);border-color:rgba(251,191,36,.35);color:#fcd34d}
.exp-exp{background:rgba(248,113,113,.18);border-color:rgba(248,113,113,.4);color:#fca5a5}
.price{font-family:var(--mono);font-size:.72rem;color:var(--ink-dim)}
.qtybar{display:flex;align-items:center;justify-content:space-between;gap:6px;margin-top:4px;
  background:var(--plum-900);border:1px solid var(--stroke-2);border-radius:10px;padding:4px}
.qtybar button{width:28px;height:28px;border-radius:7px;border:0;background:var(--glass);color:var(--ink);
  font-size:1.1rem;line-height:1;cursor:pointer;display:grid;place-items:center}
.qtybar button:active{background:var(--violet)}
.qtybar .q{font-family:var(--mono);font-weight:700;font-size:.9rem}
.qtybar .q small{color:var(--ink-faint);font-weight:500;font-size:.66rem}
.card .row2{display:flex;gap:6px;margin-top:6px}
.card .row2 button{flex:1;border:1px solid var(--stroke);background:var(--glass);color:var(--ink-dim);
  border-radius:9px;padding:7px 0;font-size:.72rem;font-weight:600;cursor:pointer;transition:.15s}
.card .row2 button.eat:active{background:var(--green);color:#04120b;border-color:var(--green)}
.card .row2 button.list:active{background:var(--violet);color:#fff}
.card .row2 button.more{flex:none;width:34px}

/* ---------- Empty ---------- */
.empty{grid-column:1/-1;text-align:center;padding:44px 20px;color:var(--ink-faint)}
.empty .big{font-family:var(--disp);font-size:1.15rem;color:var(--ink-dim);margin-bottom:6px}
.empty p{font-size:.85rem;margin:0 0 16px}

/* ---------- FAB ---------- */
.fab{position:fixed;right:18px;bottom:calc(var(--nav-h) + 16px + env(safe-area-inset-bottom));z-index:30;
  width:56px;height:56px;border-radius:18px;border:0;font-size:1.9rem;line-height:1;color:#fff;cursor:pointer;
  background:linear-gradient(135deg,var(--violet),var(--violet-2));box-shadow:0 14px 30px -8px var(--violet)}
.fab:active{transform:scale(.94)}

/* ---------- Buttons ---------- */
.btn{background:var(--glass);border:1px solid var(--stroke);color:var(--ink);border-radius:var(--r-sm);
  padding:12px 16px;font-family:var(--sans);font-size:.92rem;font-weight:600;cursor:pointer;transition:.15s}
.btn:active{transform:scale(.97)}
.btn.primary{background:linear-gradient(135deg,var(--violet),var(--violet-2));border-color:transparent;
  box-shadow:0 12px 26px -12px var(--violet)}
.btn.block{width:100%;display:block}
.btn.ghost{background:transparent}
.link{background:none;border:0;color:var(--violet-soft);font-size:.76rem;cursor:pointer;font-weight:600}

/* ---------- Scanner ---------- */
.scanner-wrap{position:relative;aspect-ratio:1.05;border-radius:var(--r);overflow:hidden;background:#0b0616;
  border:1px solid var(--stroke);box-shadow:var(--shadow);margin-bottom:14px}
#video{width:100%;height:100%;object-fit:cover;display:block}
.scan-frame{position:absolute;inset:0;display:grid;place-items:center;pointer-events:none}
.scan-frame span{width:70%;height:38%;border-radius:16px;border:2px solid rgba(196,181,253,.85);
  box-shadow:0 0 0 100vmax rgba(11,6,22,.45);position:relative}
.scan-frame span::after{content:"";position:absolute;left:6%;right:6%;top:50%;height:2px;
  background:linear-gradient(90deg,transparent,var(--violet-glow),transparent);animation:scanline 2.1s ease-in-out infinite}
@keyframes scanline{0%,100%{top:12%}50%{top:88%}}
.scan-hint{position:absolute;left:0;right:0;bottom:12px;text-align:center;font-size:.78rem;color:var(--ink-dim);
  text-shadow:0 1px 6px #000}
.scan-controls{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}
.manual-barcode{display:flex;gap:8px}
.manual-barcode input{flex:1;background:var(--glass);border:1px solid var(--stroke);color:var(--ink);
  border-radius:var(--r-sm);padding:12px 14px;font-family:var(--mono);font-size:.95rem;outline:0}
.manual-barcode input::placeholder{color:var(--ink-faint);font-family:var(--sans)}

/* ---------- Scan result card ---------- */
.scan-card{background:var(--glass);border:1px solid var(--stroke);border-radius:var(--r);padding:16px;
  box-shadow:var(--shadow);animation:fade .3s ease}
.scan-card .sc-head{display:flex;gap:13px}
.scan-card .sc-img{width:74px;height:74px;border-radius:12px;background:#fff;flex:none;object-fit:contain;padding:5px}
.scan-card .sc-img.ph{background:var(--plum-700);display:grid;place-items:center;font-family:var(--disp);
  font-size:1.5rem;color:var(--violet-soft)}
.scan-card h3{margin:0 0 2px;font-family:var(--disp);font-weight:700;font-size:1.05rem;line-height:1.15}
.scan-card .sc-brand{color:var(--ink-faint);font-size:.78rem}
.gradebig{display:flex;align-items:center;gap:12px;margin:14px 0;padding:12px;border-radius:14px;
  background:var(--plum-900);border:1px solid var(--stroke-2)}
.gradebig .ring{width:52px;height:52px;border-radius:50%;display:grid;place-items:center;flex:none;
  font-family:var(--mono);font-weight:700;font-size:1.15rem;color:#0b0616}
.gradebig .gtxt b{font-family:var(--disp);font-size:1.05rem;display:block}
.gradebig .gtxt span{font-size:.74rem;color:var(--ink-faint)}
.macro-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:12px 0}
.macro-grid div{background:var(--plum-900);border:1px solid var(--stroke-2);border-radius:11px;padding:9px 6px;text-align:center}
.macro-grid b{font-family:var(--mono);font-size:.95rem;display:block}
.macro-grid small{font-size:.62rem;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.04em}
.additives{margin:10px 0}
.additives .a-tag{display:inline-block;font-size:.68rem;padding:3px 8px;border-radius:7px;margin:0 5px 5px 0;
  background:var(--glass);border:1px solid var(--stroke)}
.additives .a-tag.risk{background:rgba(248,113,113,.15);border-color:rgba(248,113,113,.4);color:#fca5a5}
.tip{font-size:.78rem;color:var(--amber);background:rgba(251,191,36,.1);border:1px solid rgba(251,191,36,.28);
  border-radius:11px;padding:9px 12px;margin:10px 0}

/* ---------- Lista ---------- */
.lista-add{display:flex;gap:8px;margin-bottom:18px}
.lista-add input{flex:1;background:var(--glass);border:1px solid var(--stroke);color:var(--ink);
  border-radius:var(--r-sm);padding:13px 15px;font-size:.95rem;outline:0}
.lista-add input::placeholder{color:var(--ink-faint)}
.section-h{font-family:var(--disp);font-weight:700;font-size:.95rem;margin:22px 2px 10px;display:flex;
  align-items:center;justify-content:space-between}
.section-h .hint{font-family:var(--sans);font-weight:400;font-size:.7rem;color:var(--ink-faint)}
.lista-block{display:flex;flex-direction:column;gap:8px}
.li{display:flex;align-items:center;gap:12px;background:var(--glass-2);border:1px solid var(--stroke-2);
  border-radius:var(--r-sm);padding:12px 14px}
.li .cb{width:22px;height:22px;border-radius:7px;border:2px solid var(--stroke);flex:none;cursor:pointer;
  display:grid;place-items:center;transition:.15s}
.li .cb.on{background:var(--green);border-color:var(--green)}
.li .cb.on::after{content:"✓";color:#04120b;font-size:.8rem;font-weight:700}
.li .txt{flex:1;font-size:.92rem}
.li.done .txt{text-decoration:line-through;color:var(--ink-faint)}
.li .sub{font-size:.7rem;color:var(--ink-faint)}
.li .x{background:none;border:0;color:var(--ink-faint);font-size:1.1rem;cursor:pointer;padding:2px 4px}
.li .restock{background:var(--glass);border:1px solid var(--stroke);color:var(--violet-soft);border-radius:9px;
  padding:6px 11px;font-size:.74rem;font-weight:600;cursor:pointer}
.li.empty-li{justify-content:center;color:var(--ink-faint);font-size:.85rem;border-style:dashed}

/* ---------- Recetas ---------- */
.recetas-actions{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}
#suggestBox:not(:empty){margin-bottom:18px}
.suggest{background:var(--glass);border:1px solid var(--stroke);border-radius:var(--r);padding:15px}
.suggest p{margin:0 0 10px;font-size:.84rem;color:var(--ink-dim)}
.suggest textarea{width:100%;min-height:120px;background:var(--plum-900);border:1px solid var(--stroke-2);
  color:var(--ink);border-radius:12px;padding:12px;font-size:.82rem;font-family:var(--mono);resize:vertical;outline:0}
.rec{background:var(--glass-2);border:1px solid var(--stroke-2);border-radius:var(--r-sm);padding:14px;margin-bottom:10px}
.rec.can{border-color:rgba(52,211,153,.35);background:rgba(52,211,153,.06)}
.rec .rhead{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.rec h4{font-family:var(--disp);font-weight:700;font-size:1rem;margin:0}
.rec .can-badge{font-size:.68rem;font-weight:700;color:#6ee7b7;background:rgba(52,211,153,.14);
  border:1px solid rgba(52,211,153,.3);border-radius:7px;padding:3px 8px;white-space:nowrap}
.rec .miss-badge{font-size:.68rem;color:var(--amber);white-space:nowrap}
.rec .ings{display:flex;flex-wrap:wrap;gap:5px;margin:9px 0 4px}
.rec .ing{font-size:.7rem;padding:3px 8px;border-radius:7px;background:var(--glass);border:1px solid var(--stroke-2);color:var(--ink-faint)}
.rec .ing.have{color:#6ee7b7;border-color:rgba(52,211,153,.3)}
.rec .notes{font-size:.8rem;color:var(--ink-dim);margin-top:8px;white-space:pre-wrap}
.rec .del{background:none;border:0;color:var(--ink-faint);font-size:.72rem;cursor:pointer;margin-top:6px}

/* ---------- Bottom nav ---------- */
.bottom-nav{position:fixed;left:0;right:0;bottom:0;z-index:40;height:calc(var(--nav-h) + env(safe-area-inset-bottom));
  padding-bottom:env(safe-area-inset-bottom);display:flex;
  background:linear-gradient(0deg,rgba(20,7,42,.96),rgba(20,7,42,.8));backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);border-top:1px solid var(--stroke)}
.nav-btn{flex:1;background:none;border:0;color:var(--ink-faint);display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:4px;cursor:pointer;font-family:var(--sans);transition:.15s}
.nav-btn svg{width:23px;height:23px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.nav-btn span{font-size:.66rem;font-weight:600}
.nav-btn.active{color:var(--violet-glow)}
.nav-btn.active svg{filter:drop-shadow(0 0 8px var(--violet))}

/* ---------- Modal ---------- */
.modal-back{position:fixed;inset:0;z-index:50;background:rgba(11,6,22,.72);backdrop-filter:blur(6px);
  display:flex;align-items:flex-end;justify-content:center;animation:fade .2s}
.modal{width:100%;max-width:560px;max-height:92dvh;overflow-y:auto;background:var(--plum-900);
  border:1px solid var(--stroke);border-radius:24px 24px 0 0;padding:20px 18px calc(28px + env(safe-area-inset-bottom));
  box-shadow:0 -20px 60px rgba(0,0,0,.6);animation:slideup .3s cubic-bezier(.2,.9,.3,1)}
@media(min-width:560px){.modal-back{align-items:center}.modal{border-radius:24px}}
@keyframes slideup{from{transform:translateY(100%)}to{transform:none}}
.modal .grab{width:40px;height:4px;border-radius:2px;background:var(--stroke);margin:0 auto 16px}
.modal h2{font-family:var(--disp);font-weight:800;font-size:1.3rem;margin:0 0 4px}
.modal .sub{color:var(--ink-faint);font-size:.8rem;margin:0 0 16px}
.field{margin-bottom:13px}
.field label{display:block;font-size:.74rem;color:var(--ink-dim);margin-bottom:5px;font-weight:600;letter-spacing:.01em}
.field input,.field select,.field textarea{width:100%;background:var(--glass);border:1px solid var(--stroke);
  color:var(--ink);border-radius:12px;padding:12px 13px;font-family:var(--sans);font-size:.95rem;outline:0}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--violet-2)}
.field select option{background:var(--plum-900)}
.field textarea{min-height:90px;resize:vertical}
.frow{display:flex;gap:10px}.frow .field{flex:1}
.modal-actions{display:flex;gap:10px;margin-top:18px}
.modal-actions .btn{flex:1}

/* ---------- Toast ---------- */
.toast{position:fixed;left:50%;bottom:calc(var(--nav-h) + 20px + env(safe-area-inset-bottom));transform:translateX(-50%) translateY(20px);
  z-index:80;background:var(--violet);color:#fff;padding:11px 18px;border-radius:12px;font-size:.85rem;font-weight:600;
  box-shadow:0 14px 30px -8px rgba(0,0,0,.6);opacity:0;pointer-events:none;transition:.28s;max-width:88vw;text-align:center}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
