/* ===== Council Foods — white glassmorphism ===== */
@font-face{font-family:'FixelD';src:url('assets/fonts/FixelDisplay-Black.woff2') format('woff2');font-weight:900;font-display:swap}
@font-face{font-family:'FixelD';src:url('assets/fonts/FixelDisplay-Bold.woff2') format('woff2');font-weight:700;font-display:swap}
@font-face{font-family:'Fixel';src:url('assets/fonts/FixelText-SemiBold.woff2') format('woff2');font-weight:600;font-display:swap}
@font-face{font-family:'Fixel';src:url('assets/fonts/FixelText-Medium.woff2') format('woff2');font-weight:500;font-display:swap}
@font-face{font-family:'Fixel';src:url('assets/fonts/FixelText-Regular.woff2') format('woff2');font-weight:400;font-display:swap}

:root{
  --text:#221B20; --muted:rgba(34,27,32,.56); --line:rgba(34,27,32,.09);
  --mint:#15C9BA;          /* readable teal accent (text/numbers) */
  --mintfill:#36ECDE;      /* bright fill on buttons */
  --coral:#FC3E57;
  --glass:rgba(255,255,255,.52);
  --glass2:rgba(255,255,255,.72);
  --glassbd:rgba(255,255,255,.72);
  --shadow:0 14px 38px rgba(28,32,40,.16);
  --r:26px;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%;overflow:hidden}
body{
  background:#E9F0EE; color:var(--text);
  font-family:'Fixel',-apple-system,"Segoe UI",Roboto,sans-serif;font-weight:500;
  display:flex;flex-direction:column;height:100dvh;
  padding:env(safe-area-inset-top) 0 0;
  -webkit-font-smoothing:antialiased;position:relative;
}
/* color blobs the frosted glass refracts */
body::before{content:"";position:fixed;inset:-20%;z-index:-1;
  background:
    radial-gradient(38% 32% at 16% 14%, rgba(54,236,222,.55), transparent 60%),
    radial-gradient(42% 36% at 86% 10%, rgba(252,62,87,.34), transparent 62%),
    radial-gradient(48% 40% at 78% 88%, rgba(54,236,222,.40), transparent 60%),
    radial-gradient(46% 42% at 10% 92%, rgba(255,196,120,.40), transparent 62%);
  filter:saturate(1.1)}

/* ---------- header ---------- */
.top{padding:14px 22px 6px}
.brand{font-family:'FixelD';font-weight:900;letter-spacing:.4px;font-size:20px;line-height:1;color:var(--text)}
.brand span{color:var(--mint);margin-left:6px}
.brand-sub{color:var(--muted);font-size:11.5px;font-weight:500;letter-spacing:.3px;margin-top:5px}

/* ---------- filters ---------- */
.filters{display:flex;gap:8px;overflow-x:auto;padding:12px 22px 14px;scrollbar-width:none;flex:0 0 auto}
.filters::-webkit-scrollbar{display:none}
.chip{flex:0 0 auto;background:var(--glass);border:1px solid var(--glassbd);color:var(--text);
  padding:8px 15px;border-radius:999px;font-size:13px;font-weight:600;white-space:nowrap;cursor:pointer;
  transition:all .18s;backdrop-filter:blur(12px);box-shadow:0 4px 14px rgba(28,32,40,.07)}
.chip.on{background:var(--mintfill);border-color:rgba(255,255,255,.7);color:#073a36;box-shadow:0 6px 18px rgba(54,236,222,.4)}

/* ---------- views ---------- */
.view{flex:1;min-height:0}
.view[hidden]{display:none}

/* ---------- deck (swipe) ---------- */
.deck{position:relative;margin:2px 18px 0}
.card{position:absolute;inset:0;border-radius:var(--r);overflow:hidden;background:#fff;
  box-shadow:0 24px 54px rgba(24,28,36,.28);will-change:transform}
.card .img{position:absolute;inset:0;background-size:cover;background-position:center}
.card .badge{position:absolute;top:16px;left:16px;background:var(--glass2);backdrop-filter:blur(12px);
  border:1px solid var(--glassbd);color:#0a6b63;font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:1px;padding:6px 13px;border-radius:999px;z-index:2;box-shadow:0 4px 12px rgba(0,0,0,.12)}
.card .stamp{position:absolute;top:26px;font-family:'FixelD';font-size:30px;font-weight:900;letter-spacing:1px;
  border:4px solid;padding:5px 15px;border-radius:14px;opacity:0;transform:rotate(-13deg);z-index:4;
  background:rgba(255,255,255,.5);backdrop-filter:blur(4px)}
.card .stamp.like{right:20px;color:#0a8f84;border-color:#15C9BA}
.card .stamp.nope{left:20px;color:var(--coral);border-color:var(--coral)}
/* frosted glass info panel refracting the food image */
.card .meta{position:absolute;left:13px;right:13px;bottom:13px;z-index:3;
  background:rgba(255,255,255,.55);backdrop-filter:blur(26px) saturate(1.5);
  border:1px solid rgba(255,255,255,.65);border-radius:20px;padding:15px 17px 16px;
  box-shadow:0 12px 30px rgba(20,24,32,.22)}
.card h2{font-family:'FixelD';font-weight:900;margin:0 0 9px;font-size:23px;line-height:1.08;letter-spacing:-.5px;color:#1a141a}
.card .author{font-size:13px;color:var(--muted);margin-bottom:12px;font-weight:500}
.card .stats{display:flex;gap:7px;flex-wrap:wrap}
.card .stats .st{display:flex;align-items:center;gap:5px;background:rgba(255,255,255,.55);border:1px solid var(--line);
  padding:6px 11px;border-radius:999px;font-size:12px;font-weight:600;color:#41383f}
.card .stats .st b{font-family:'FixelD';font-weight:900;color:var(--mint)}
.card .tags{display:flex;gap:7px;margin-top:11px;flex-wrap:wrap}
.tag{font-size:11px;font-weight:700;padding:5px 11px;border-radius:8px;background:rgba(21,201,186,.16);color:#0a8076}
.tag.k{background:rgba(252,62,87,.14);color:#d3324a}

/* empty state */
.empty{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:14px;color:var(--muted);text-align:center;padding:34px}
.empty .big{font-family:'FixelD';font-weight:900;font-size:30px;color:var(--text);letter-spacing:-.5px}
.empty .erow{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-top:4px}
.empty button{background:var(--mintfill);border:0;color:#073a36;font-weight:700;padding:12px 22px;border-radius:999px;
  cursor:pointer;font-size:14px;font-family:'Fixel';box-shadow:0 8px 20px rgba(54,236,222,.35)}
.empty .ghost{background:var(--glass2);color:var(--text);border:1px solid var(--glassbd);box-shadow:var(--shadow)}

/* ---------- catalog ---------- */
.catalog{overflow-y:auto;padding:0 18px 18px;-webkit-overflow-scrolling:touch}
.searchbar{position:relative;margin-bottom:14px}
.searchbar .si{position:absolute;left:15px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:17px}
.search{width:100%;background:var(--glass2);border:1px solid var(--glassbd);color:var(--text);
  border-radius:15px;padding:13px 16px 13px 40px;font-size:15px;font-family:'Fixel';outline:none;
  backdrop-filter:blur(12px);box-shadow:0 6px 18px rgba(28,32,40,.08)}
.search::placeholder{color:var(--muted)}
.grid{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.gcard{background:var(--glass);border-radius:18px;overflow:hidden;cursor:pointer;border:1px solid var(--glassbd);
  backdrop-filter:blur(16px);box-shadow:0 10px 26px rgba(28,32,40,.12);transition:transform .15s}
.gcard:active{transform:scale(.97)}
.gwrap{position:relative;aspect-ratio:1/1;overflow:hidden}
.gwrap img{width:100%;height:100%;object-fit:cover;display:block;background:#dfe7e5}
.gbadge{position:absolute;bottom:9px;left:9px;z-index:2;background:var(--glass2);backdrop-filter:blur(10px);
  border:1px solid var(--glassbd);color:#0a6b63;font-size:9.5px;font-weight:700;text-transform:uppercase;
  letter-spacing:.6px;padding:3px 8px;border-radius:999px}
.gheart{position:absolute;top:9px;right:9px;z-index:2;width:26px;height:26px;border-radius:50%;
  background:var(--coral);color:#fff;font-size:13px;display:flex;align-items:center;justify-content:center;
  box-shadow:0 3px 10px rgba(0,0,0,.25)}
.gmeta{padding:10px 12px 13px}
.gmeta b{display:block;font-size:13px;line-height:1.25;font-weight:600;color:#1f1820;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:33px}
.gmeta small{display:flex;align-items:center;gap:5px;color:var(--muted);font-size:11.5px;margin-top:4px}
.gmeta small b{font-family:'FixelD';font-weight:900;color:var(--mint);display:inline}

/* ---------- plan ---------- */
.plan{overflow-y:auto;padding:6px 20px 18px}
.plan-head{display:flex;align-items:center;justify-content:space-between;margin:8px 0 14px}
.plan-head h2{font-family:'FixelD';font-weight:900;margin:0;font-size:24px;letter-spacing:-.5px;color:var(--text)}
.plan-head h2 span{color:var(--mint)}
.mini{background:var(--mintfill);border:0;color:#073a36;font-weight:700;font-size:13px;padding:10px 15px;border-radius:12px;
  cursor:pointer;font-family:'Fixel';box-shadow:0 6px 16px rgba(54,236,222,.35)}
.plan-item{display:flex;gap:13px;padding:11px;margin-bottom:9px;align-items:center;
  background:var(--glass);border:1px solid var(--glassbd);border-radius:16px;backdrop-filter:blur(14px);box-shadow:0 8px 20px rgba(28,32,40,.08)}
.plan-item .pi{width:58px;height:58px;border-radius:13px;object-fit:cover;flex:0 0 auto;background:#dfe7e5}
.plan-item .pt{flex:1;min-width:0;cursor:pointer}
.plan-item .pt b{display:block;font-size:14px;font-weight:600;line-height:1.2;color:#1f1820;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.plan-item .pt small{color:var(--muted);font-size:12px}
.plan-item .rm{background:rgba(252,62,87,.13);border:0;color:var(--coral);font-size:15px;
  width:32px;height:32px;border-radius:50%;flex:0 0 auto;cursor:pointer}

/* ---------- action buttons ---------- */
.actions{display:flex;justify-content:center;align-items:center;gap:20px;padding:16px 0 14px;flex:0 0 auto}
.act{border-radius:50%;border:0;cursor:pointer;display:flex;align-items:center;justify-content:center;
  box-shadow:0 12px 28px rgba(24,28,36,.22);transition:transform .12s}
.act:active{transform:scale(.88)}
.act.skip{width:62px;height:62px;font-size:25px;background:var(--glass2);backdrop-filter:blur(14px);color:var(--coral);border:1px solid var(--glassbd)}
.act.info{width:50px;height:50px;font-size:20px;background:var(--glass2);backdrop-filter:blur(14px);color:var(--text);border:1px solid var(--glassbd)}
.act.like{width:62px;height:62px;font-size:26px;background:var(--mintfill);color:#073a36;box-shadow:0 12px 28px rgba(54,236,222,.4)}

/* ---------- bottom nav ---------- */
.tabbar{display:flex;gap:6px;margin:0 16px 0;padding:8px 6px calc(8px + env(safe-area-inset-bottom));
  background:rgba(255,255,255,.6);backdrop-filter:blur(22px) saturate(1.4);border:1px solid var(--glassbd);
  border-bottom:0;border-radius:24px 24px 0 0;flex:0 0 auto;box-shadow:0 -8px 30px rgba(28,32,40,.1)}
.tab{flex:1;background:none;border:0;color:var(--muted);font-size:10px;font-weight:600;font-family:'Fixel';
  padding:8px 0 6px;display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;position:relative;
  border-radius:15px;transition:color .15s}
.tab .ti{font-size:17px;line-height:1}
.tab.on{color:#0a8f84}
.tab.on .ti{filter:drop-shadow(0 2px 8px rgba(21,201,186,.5))}
.tab .dot{position:absolute;top:3px;right:50%;margin-right:-24px;background:var(--coral);color:#fff;
  font-size:10px;font-weight:700;min-width:17px;height:17px;border-radius:999px;display:inline-flex;
  align-items:center;justify-content:center;padding:0 4px}

/* ---------- detail sheet ---------- */
.sheet-wrap{position:fixed;inset:0;z-index:50;background:rgba(20,24,30,.42);display:flex;align-items:flex-end}
.sheet-wrap[hidden]{display:none}
.sheet{background:rgba(255,255,255,.86);backdrop-filter:blur(30px) saturate(1.4);width:100%;max-height:90dvh;
  overflow-y:auto;border-radius:28px 28px 0 0;padding:8px 22px 32px;animation:up .3s cubic-bezier(.2,.8,.2,1);
  border-top:1px solid rgba(255,255,255,.8)}
@keyframes up{from{transform:translateY(100%)}to{transform:translateY(0)}}
.grab{width:44px;height:5px;background:rgba(34,27,32,.18);border-radius:99px;margin:8px auto 18px}
.sheet h2{font-family:'FixelD';font-weight:900;margin:0 0 6px;font-size:24px;line-height:1.18;letter-spacing:-.5px;color:#1a141a}
.sheet .author{color:var(--muted);font-size:13px;margin-bottom:16px}
.sheet .recipe{white-space:pre-wrap;line-height:1.6;font-size:14.5px;color:#2c2530;font-weight:400;
  background:rgba(255,255,255,.5);border:1px solid var(--line);border-radius:16px;padding:16px;margin:14px 0}
.sheet .row{display:flex;gap:10px;margin-top:9px}
.btn{flex:1;border:0;border-radius:14px;padding:14px;font-weight:700;font-size:14.5px;cursor:pointer;font-family:'Fixel'}
.btn.tt{background:var(--coral);color:#fff}
.btn.cp{background:var(--mintfill);color:#073a36}
.btn.gh{background:rgba(255,255,255,.6);color:var(--text);border:1px solid var(--glassbd)}
.toast{position:fixed;bottom:110px;left:50%;transform:translateX(-50%);background:#073a36;color:#36ECDE;
  font-weight:700;padding:11px 20px;border-radius:999px;z-index:99;opacity:0;transition:opacity .2s;font-size:13px;
  box-shadow:0 8px 24px rgba(0,0,0,.3)}
.toast.show{opacity:1}

/* ---------- health score chip ---------- */
.score{display:inline-flex;align-items:baseline;gap:3px;font-family:'FixelD';font-weight:900;font-size:15px;
  line-height:1;padding:6px 10px 5px;border-radius:11px;color:#fff;letter-spacing:-.3px}
.score i{font-family:'Fixel';font-weight:700;font-style:normal;font-size:8px;text-transform:uppercase;letter-spacing:.6px;opacity:.92}
.score.good{background:linear-gradient(135deg,#15C9BA,#0a9e92)}
.score.mid{background:linear-gradient(135deg,#FFB020,#F59000)}
.score.low{background:linear-gradient(135deg,#FC3E57,#d62942)}
/* on deck card image — top right, floating glass-edged */
.card .img .score{position:absolute;top:16px;right:16px;z-index:2;box-shadow:0 6px 16px rgba(20,24,32,.28);border:1px solid rgba(255,255,255,.35)}
/* on catalog tile */
.gwrap .score{position:absolute;top:8px;left:8px;z-index:2;font-size:13px;padding:4px 8px 3px;box-shadow:0 4px 12px rgba(20,24,32,.25)}
.gwrap .score i{font-size:7px}
/* in detail sheet */
.macros{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin:2px 0 14px}
.score.big{font-size:22px;padding:9px 14px 8px}.score.big i{font-size:9px}
.macro{background:rgba(255,255,255,.55);border:1px solid var(--line);border-radius:11px;padding:8px 12px;
  font-size:13px;font-weight:600;color:#41383f}
.macro b{font-family:'FixelD';font-weight:900;color:var(--mint);font-size:16px}
.estnote{font-size:11px;font-weight:600;color:var(--muted);margin-left:auto}
.estnote.ok{color:#0a9e92}

/* ingredient list in sheet */
.ing{background:rgba(255,255,255,.5);border:1px solid var(--line);border-radius:16px;padding:6px 16px 10px;margin:6px 0 4px}
.ing h3{font-family:'FixelD';font-weight:900;font-size:15px;margin:12px 0 8px;color:#1a141a;letter-spacing:-.3px}
.ing h3 small{font-family:'Fixel';font-weight:600;color:var(--mint);font-size:13px}
.ingrow{display:flex;justify-content:space-between;gap:10px;padding:7px 0;border-bottom:1px solid var(--line);font-size:14px;color:#2c2530}
.ingrow:last-child{border-bottom:0}
.ingrow .iq{color:var(--muted);font-weight:600;white-space:nowrap}

/* ---------- shopping list (in sheet) ---------- */
.shop{margin:14px 0 4px;background:rgba(255,255,255,.5);border:1px solid var(--line);border-radius:16px;padding:4px 16px}
.shi{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--line);cursor:pointer}
.shi:last-child{border-bottom:0}
.shi input{width:21px;height:21px;accent-color:#15C9BA;flex:0 0 auto;cursor:pointer}
.shi .shn{flex:1;font-size:14.5px;font-weight:500;color:#2c2530}
.shi .shq{color:var(--muted);font-weight:600;font-size:13px;white-space:nowrap}
.shi.done .shn{text-decoration:line-through;color:var(--muted)}
.shi.done .shq{opacity:.5}

/* ---------- pantry ---------- */
.pantry-view{overflow-y:auto;padding:6px 20px 18px}
.pantry-head h2{font-family:'FixelD';font-weight:900;margin:8px 0 4px;font-size:24px;letter-spacing:-.5px;color:var(--text)}
.psub{color:var(--muted);font-size:13px;margin:0 0 12px;line-height:1.4}
.psel{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:11px;min-height:8px}
.ptag{background:var(--mintfill);border:0;color:#073a36;font-weight:700;font-size:13px;padding:8px 13px;
  border-radius:999px;cursor:pointer;font-family:'Fixel';box-shadow:0 4px 12px rgba(54,236,222,.3)}
.pempty{color:var(--muted);font-size:13px;font-style:italic}
.pin{margin-bottom:12px}
.pcommon{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:6px}
.pchip{background:var(--glass);border:1px solid var(--glassbd);color:#41383f;font-weight:600;font-size:12.5px;
  padding:7px 12px;border-radius:999px;cursor:pointer;font-family:'Fixel';backdrop-filter:blur(10px)}
.pmhead{font-family:'FixelD';font-weight:900;font-size:14px;color:var(--mint);margin:16px 0 11px;letter-spacing:-.2px}
.pmatches{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.pmatches .pmhead,.pmatches .empty{grid-column:1/-1}
.pmatches .empty{position:static;padding:40px 20px}
.pmpct{position:absolute;top:8px;left:8px;z-index:2;font-family:'FixelD';font-weight:900;font-size:13px;
  padding:4px 9px;border-radius:10px;color:#fff;box-shadow:0 4px 12px rgba(20,24,32,.25)}
.pmpct.good{background:linear-gradient(135deg,#15C9BA,#0a9e92)}
.pmpct.mid{background:linear-gradient(135deg,#FFB020,#F59000)}
.pmpct.low{background:rgba(34,27,32,.55)}

/* plan action buttons */
.plan-acts{display:flex;gap:8px}
.mini.solid{background:var(--coral);color:#fff;box-shadow:0 6px 16px rgba(252,62,87,.32)}
.mini:not(.solid){background:var(--glass2);color:var(--text);border:1px solid var(--glassbd)}
