/* ============================================================
   Glafia Dex — Box UI (creature-box homage)
   Charcoal command bars · green swoosh · houndstooth cream
============================================================ */
:root{
  --cream:#f3ead3; --cream2:#efe4c9; --hound:#e7d9b8;
  --green:#a6d23f; --green-d:#8cbb2c; --green-l:#bbe05a;
  --char:#3c3c3e; --char2:#313133; --char-l:#4d4d50;
  --panel:#ffffff; --ink:#33302b; --ink2:#8a8275;
  --rowg:#eae7df; --rowg2:#f4f1ea;
  --sel:#ffd23e; --heart:#e8453f;

  --t-asian:#2f9fd0; --t-cosy:#e8896b; --t-quick:#f0b41f;
  --t-vegan:#6cbf4a; --t-veg:#7cc24a; --t-pantry:#bf9243; --t-feeds:#a877c8;

  --mv-blue:#9fb7e2; --mv-gray:#dcd8cd; --mv-red:#eca6a6; --mv-yellow:#f3df9a; --mv-green:#bcdb95; --mv-purple:#cab2e3;
  --good:#67bb4b; --warn:#f0b41f; --miss:#e09a9a;

  --soft:0 2px 7px rgba(60,52,38,.16);
  --soft2:0 4px 14px rgba(60,52,38,.18);
  --fd:'Fredoka',sans-serif; --bd:'Nunito',sans-serif; --px:'Pixelify Sans',sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{font-family:var(--bd);color:var(--ink);background:var(--char);-webkit-font-smoothing:antialiased;overflow:hidden}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input{font-family:inherit}
.fd{font-family:var(--fd)} .px{font-family:var(--px)}

/* ---------- frame ---------- */
#root{height:100%}
.gameframe{height:100%;display:flex;flex-direction:column;background:var(--char);max-width:1340px;margin:0 auto;position:relative}

/* command bars */
.cmdbar{background:var(--char);color:#fff;display:flex;align-items:center;gap:14px;padding:9px 16px;flex:none;z-index:30}
.cmdbar.top{border-bottom:1px solid #2a2a2c}
.cmdbar.bottom{border-top:1px solid #2a2a2c;font-size:13px;gap:8px;flex-wrap:wrap}
.cmdgroup{display:flex;align-items:center;gap:9px}
.cmdgroup.right{margin-left:auto}
.glyph{width:24px;height:24px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;color:#fff;flex:none;font-family:var(--bd)}
.glyph.a{background:#5bbf63}.glyph.b{background:#e8615a}.glyph.x{background:#4a90d6}.glyph.y{background:#e6b333}.glyph.plus{background:#7a7a7d}
.cmdbtn{display:inline-flex;align-items:center;gap:7px;font-weight:700;font-size:14px;color:#eceae6;padding:5px 10px;border-radius:9px}
.cmdbtn:hover{background:rgba(255,255,255,.1)}
.cmdbtn .lab{white-space:nowrap}
.brandlogo{display:flex;align-items:center;gap:9px;font-family:var(--fd);font-weight:700;font-size:19px;color:#fff;white-space:nowrap}
.brandlogo .ball{width:24px;height:24px;border-radius:50%;background:conic-gradient(from 0deg,#e8615a 0 50%,#fff 50% 100%);border:2.5px solid #1f1f20;position:relative}
.brandlogo .ball::after{content:"";position:absolute;inset:0;margin:auto;width:7px;height:7px;background:#fff;border:2px solid #1f1f20;border-radius:50%}
.bidot{opacity:.4}

/* ---------- background board ---------- */
.board{
  flex:1;min-height:0;position:relative;overflow:hidden;
  background:
    repeating-linear-gradient(45deg, transparent 0 9px, rgba(190,165,110,.10) 9px 10px),
    repeating-linear-gradient(-45deg, transparent 0 9px, rgba(190,165,110,.08) 9px 10px),
    var(--cream);
}
.swoosh{position:absolute;top:0;left:0;right:0;height:236px;background:var(--green);z-index:0;clip-path:polygon(0 0,100% 0,100% 56%,0 100%);filter:drop-shadow(0 5px 0 var(--green-d))}
.swoosh.two{position:absolute;top:0;left:0;right:0;height:300px;background:var(--green-l);opacity:.5;z-index:0;clip-path:polygon(0 80%,100% 45%,100% 51%,0 86%);filter:none}

.boxlayout{position:relative;z-index:1;height:100%;display:grid;grid-template-columns:248px 1fr 366px;gap:0;min-height:0}
@media(max-width:1080px){.boxlayout{grid-template-columns:210px 1fr 320px}}
@media(max-width:880px){.boxlayout{grid-template-columns:1fr;overflow-y:auto}}

/* ================= LEFT — party (favourites) ================= */
.party{padding:16px 14px;display:flex;flex-direction:column;gap:10px;min-height:0;overflow-y:auto}
.partytab{
  align-self:flex-start;background:#fff;border-radius:22px;padding:8px 26px;font-family:var(--fd);font-weight:600;font-size:18px;
  box-shadow:var(--soft);margin-bottom:2px;display:flex;align-items:center;gap:8px;
}
.pcard{
  background:#fff;border-radius:20px;padding:8px 14px 8px 8px;display:flex;align-items:center;gap:11px;
  box-shadow:var(--soft);cursor:pointer;transition:transform .1s, box-shadow .1s;border:2.5px solid transparent;
}
.pcard:hover{transform:translateY(-1px)}
.pcard.sel{border-color:var(--sel);box-shadow:0 4px 12px rgba(240,180,30,.35)}
.pcard .pcc{width:46px;height:46px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;font-size:25px;box-shadow:inset 0 0 0 2px rgba(0,0,0,.06)}
.pcard .pci{flex:1;min-width:0;display:flex;flex-direction:column}
.pcard .pci .nm{font-family:var(--fd);font-weight:600;font-size:16px;line-height:1.05;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pcard .pci .lv{font-weight:800;font-size:12.5px;color:var(--ink2);margin-top:1px}
.party .hearttip{color:var(--ink2);font-weight:700;font-size:13px;padding:10px 8px;line-height:1.4}
.party .heartstar{color:#e8b53f}

/* ================= MIDDLE — box ================= */
.boxmid{display:flex;flex-direction:column;min-height:0;padding:14px 10px 12px}
.pager{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:12px}
.pagerbtn{width:36px;height:36px;border-radius:50%;background:#fff;box-shadow:var(--soft);font-size:16px;color:var(--ink);display:flex;align-items:center;justify-content:center;flex:none}
.pagerbtn:active{transform:scale(.94)}
.pagername{
  background:#fff;border-radius:24px;box-shadow:var(--soft);padding:7px 20px;min-width:230px;text-align:center;
  display:flex;align-items:center;justify-content:center;gap:9px;position:relative;
}
.pagername .pn-em{font-size:17px}
.pagername .pn-txt{font-family:var(--fd);font-weight:600;font-size:19px;color:var(--ink);border:none;outline:none;background:transparent;text-align:center;max-width:190px}
.pagername .pn-edit{position:absolute;right:12px;font-size:13px;color:var(--ink2);opacity:.6}
.pagername:hover .pn-edit{opacity:1}
.boxcount{text-align:center;font-weight:800;font-size:12px;color:var(--ink2);margin:-6px 0 12px}

.boxgridwrap{flex:1;min-height:0;overflow-y:auto;display:flex;align-items:flex-start;justify-content:center}
.boxgrid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;width:100%;max-width:430px}
.cell{aspect-ratio:1;border-radius:16px;position:relative;display:flex;align-items:center;justify-content:center}
.cell.empty{background:rgba(255,255,255,.4);box-shadow:inset 0 0 0 2px rgba(150,130,90,.10)}
.cell.full{cursor:pointer;transition:transform .1s}
.cell.full:hover{transform:translateY(-2px)}
.cell .tile{width:100%;height:100%;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:34px;box-shadow:var(--soft);position:relative;overflow:hidden}
.cell .tile .tdots{position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.45) 1.4px,transparent 1.4px);background-size:11px 11px;opacity:.5}
.cell.sel .tile{box-shadow:0 0 0 3px var(--sel), var(--soft2)}
.cell .heart{position:absolute;top:-13px;left:50%;transform:translateX(-50%);color:var(--heart);font-size:20px;filter:drop-shadow(0 1px 1px rgba(0,0,0,.25));z-index:2}
.cell .minifav{position:absolute;top:-5px;right:-5px;font-size:13px;z-index:2}

.boxactions{display:flex;gap:12px;justify-content:center;margin-top:12px}
.boxbtn{background:#fff;border-radius:22px;box-shadow:var(--soft);padding:9px 22px;font-weight:800;font-size:14px;display:flex;align-items:center;gap:9px;color:var(--ink);white-space:nowrap}
.boxbtn:active{transform:translateY(1px)}
.boxbtn .bi{font-size:15px}

/* ================= RIGHT — detail panel ================= */
.detail{padding:14px 14px 14px 6px;min-height:0;display:flex}
.dpanel{background:#fff;border-radius:18px;box-shadow:var(--soft2);flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}
.dempty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;height:100%;color:var(--ink2);font-weight:700;text-align:center;padding:30px}
.dscroll{overflow-y:auto;min-height:0;flex:1}
.dhead{display:flex;align-items:center;gap:10px;padding:14px 16px 4px}
.dhead .dball{width:26px;height:26px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;font-size:15px;box-shadow:inset 0 0 0 2px rgba(0,0,0,.08)}
.dhead .dname{font-family:var(--fd);font-weight:700;font-size:22px;flex:1;line-height:1.05}
.dhead .dlv{font-weight:800;font-size:14px;color:var(--ink2);white-space:nowrap}
.dspecies{padding:0 16px;color:var(--ink2);font-weight:700;font-size:13.5px;margin-top:2px}

.dtypes{display:flex;flex-wrap:wrap;gap:7px;padding:11px 16px 12px;align-items:center}
.typebadge{
  display:inline-flex;align-items:center;gap:6px;padding:5px 12px 5px 8px;border-radius:8px;color:#fff;font-weight:800;
  font-size:12px;letter-spacing:.4px;text-transform:uppercase;box-shadow:inset 0 -2px 0 rgba(0,0,0,.18), 0 1px 2px rgba(0,0,0,.15);
  position:relative;white-space:nowrap;
}
.typebadge .tb-ic{width:16px;height:16px;border-radius:50%;background:rgba(255,255,255,.85);display:flex;align-items:center;justify-content:center;font-size:10px}
.typebadge .tb-x{margin-left:3px;width:15px;height:15px;border-radius:50%;background:rgba(0,0,0,.22);display:inline-flex;align-items:center;justify-content:center;font-size:10px}
.addtag{border:2px dashed #cdc4b0;color:var(--ink2);background:#fff;border-radius:8px;padding:4px 10px;font-weight:800;font-size:12px}

/* stat table */
.stattable{margin:2px 0}
.strow{display:grid;grid-template-columns:96px 1fr;align-items:center;font-size:14px}
.strow:nth-child(odd){background:var(--rowg2)}
.strow:nth-child(even){background:#fff}
.strow .stk{padding:7px 16px;font-weight:800;color:#6a6256;background:var(--rowg);height:100%;display:flex;align-items:center}
.strow .stv{padding:7px 14px;font-weight:800;color:var(--ink);display:flex;align-items:center;gap:10px}
.strow .stv .seg{display:inline-flex;gap:3px}
.strow .stv .seg i{width:11px;height:13px;border-radius:2px;background:#e3ddcf;box-shadow:inset 0 0 0 1px rgba(0,0,0,.06)}
.strow .stv .seg i.on{background:var(--good)}
.strow .stv .seg i.spice.on{background:var(--t-cosy)}

/* moves (steps) */
.dmoves{padding:12px 14px 6px}
.dmoves .ml{font-weight:800;font-size:12px;color:var(--ink2);letter-spacing:.5px;padding:0 2px 8px}
.move{display:flex;align-items:center;gap:10px;border-radius:11px;padding:9px 12px;margin-bottom:7px;font-weight:700;font-size:13.5px;color:#3a342c;line-height:1.3}
.move .ic{width:22px;height:22px;border-radius:50%;background:rgba(255,255,255,.7);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:12px;flex:none;color:#5a5247}
.move.m0{background:var(--mv-blue)}.move.m1{background:var(--mv-gray)}.move.m2{background:var(--mv-red)}.move.m3{background:var(--mv-yellow)}.move.m4{background:var(--mv-green)}.move.m5{background:var(--mv-purple)}
.dmoves .more{color:var(--ink2);font-weight:800;font-size:12.5px;padding:2px 4px}

.markings{display:flex;gap:9px;justify-content:center;padding:10px;color:#cfc7b5;font-size:13px}
.dfoot{padding:10px 14px 14px;display:flex;gap:9px}
.openbtn{flex:1;background:var(--green);color:#26330a;font-family:var(--fd);font-weight:600;font-size:16px;border-radius:13px;padding:11px;box-shadow:0 3px 0 var(--green-d);display:flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap}
.openbtn:active{transform:translateY(2px);box-shadow:0 1px 0 var(--green-d)}
.iconbtn{background:#fff;box-shadow:var(--soft);border-radius:13px;padding:11px 14px;font-size:16px;color:var(--ink)}
.iconbtn.on{background:var(--sel)}

/* ================= FULL RECIPE view ================= */
.rfull{position:relative;z-index:1;height:100%;overflow-y:auto;padding:18px 22px 40px}
.rfback{display:inline-flex;align-items:center;gap:8px;background:#fff;border-radius:22px;box-shadow:var(--soft);padding:8px 16px;font-weight:800;font-size:14px;margin-bottom:14px;white-space:nowrap}
.rfgrid{display:grid;grid-template-columns:320px 1fr;gap:20px;max-width:1000px;margin:0 auto}
@media(max-width:820px){.rfgrid{grid-template-columns:1fr}}
.rfcard{background:#fff;border-radius:18px;box-shadow:var(--soft2);overflow:hidden}
.rfportrait{aspect-ratio:1.1;display:flex;align-items:center;justify-content:center;font-size:120px;position:relative}
.rfportrait .tdots{position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.4) 1.6px,transparent 1.6px);background-size:15px 15px;opacity:.5}
.rfcard .rfst{padding:6px 0 10px}
.rfright{display:flex;flex-direction:column;gap:16px;min-width:0}
.rftitle{display:flex;align-items:flex-start;gap:14px;flex-wrap:wrap}
.rftitle h1{font-family:var(--fd);font-weight:700;font-size:32px;margin:0;line-height:1.04}
.rftitle .blurb{color:var(--ink2);font-weight:700;font-size:14.5px;margin:3px 0 0}
.panelw{background:#fff;border-radius:16px;box-shadow:var(--soft);padding:15px 17px}
.panelw h3{font-family:var(--fd);font-weight:600;font-size:18px;line-height:1.3;margin:0 0 3px}
.panelw .hint{color:var(--ink2);font-weight:700;font-size:12.5px;margin:0 0 11px}
.scaler{display:inline-flex;align-items:center;gap:5px;background:#fff;border-radius:26px;box-shadow:var(--soft);padding:5px;border:2px solid var(--cream2)}
.scaler button{width:32px;height:32px;border-radius:50%;background:var(--green);color:#26330a;font-size:19px;font-weight:800;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 0 var(--green-d)}
.scaler button:active{transform:translateY(2px);box-shadow:none}
.scaler button:disabled{background:#e3ddcf;color:#fff;box-shadow:none;cursor:not-allowed}
.scaler .val{min-width:78px;text-align:center}
.scaler .val b{font-family:var(--fd);font-size:19px;display:block;line-height:1}
.scaler .val small{color:var(--ink2);font-size:11px;font-weight:800}
.ing{display:flex;align-items:center;gap:11px;padding:8px 2px;border-bottom:1.5px dashed var(--cream2)}
.ing:last-child{border-bottom:none}
.ing .box{width:20px;height:20px;border-radius:6px;flex:none;background:var(--rowg);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:inset 0 0 0 2px rgba(0,0,0,.06)}
.ing.on .box{background:var(--good)}
.ing.on .nm{text-decoration:line-through;color:var(--ink2)}
.ing .nm{flex:1;font-weight:700;font-size:14.5px}
.ing .qty{font-family:var(--px);font-size:14px;background:var(--rowg2);padding:3px 11px;border-radius:11px;white-space:nowrap}

/* tag editor */
.tagedit{display:flex;flex-wrap:wrap;gap:7px;align-items:center}
.tagpop{position:absolute;z-index:50;background:#fff;border-radius:14px;box-shadow:var(--soft2);padding:12px;width:230px;margin-top:6px}
.tagpop .ti{display:flex;gap:7px;margin-bottom:9px}
.tagpop input{flex:1;border:2px solid var(--cream2);border-radius:10px;padding:7px 11px;font-weight:700;outline:none}
.tagpop .opts{display:flex;flex-wrap:wrap;gap:6px}
.tagpop .opt{font-weight:800;font-size:12px;color:#fff;padding:4px 10px;border-radius:8px;text-transform:uppercase;letter-spacing:.3px}

/* ================= SEARCH / pantry ================= */
.searchscreen{position:relative;z-index:1;height:100%;overflow-y:auto;padding:18px 22px 40px}
.searchhead{display:flex;align-items:center;gap:12px;margin-bottom:6px;flex-wrap:wrap}
.searchhead h2{font-family:var(--fd);font-weight:600;font-size:24px;margin:0;line-height:1.3;white-space:nowrap}
.searchgrid{display:grid;grid-template-columns:1.5fr 1fr;gap:20px;align-items:start;max-width:1080px}
@media(max-width:900px){.searchgrid{grid-template-columns:1fr}}
.pantrycard{background:#fff;border-radius:18px;box-shadow:var(--soft);padding:16px 18px}
.pantrycard .hint{color:var(--ink2);font-weight:700;font-size:13px;margin:2px 0 12px}
.catlbl{font-weight:800;font-size:11.5px;color:var(--ink2);letter-spacing:.5px;margin:14px 0 8px}
.jargrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(98px,1fr));gap:9px}
.jar{background:#fff;border-radius:14px;box-shadow:var(--soft);padding:8px 6px;display:flex;flex-direction:column;align-items:center;gap:5px;font-weight:800;font-size:12px;text-align:center;line-height:1.1;border:2.5px solid transparent;transition:transform .08s}
.jar:active{transform:scale(.96)}
.jar .av{width:34px;height:34px;border-radius:10px;background:var(--rowg2);display:flex;align-items:center;justify-content:center;font-size:19px}
.jar .av .lt{font-family:var(--fd);font-weight:700;color:var(--ink2);font-size:15px}
.jar.have{background:#eef7e3;border-color:var(--good)}
.jar.have .av{background:#d8eecb}
.resultscard{background:#fff;border-radius:18px;box-shadow:var(--soft);padding:16px;position:sticky;top:0}
.resultscard h3{font-family:var(--fd);font-weight:600;font-size:19px;line-height:1.3;margin:0 0 2px}
.resultscard .meta{color:var(--ink2);font-weight:700;font-size:12.5px;margin:0 0 12px}
.result{display:flex;align-items:center;gap:11px;padding:9px;border-radius:14px;box-shadow:var(--soft);cursor:pointer;margin-bottom:9px;transition:transform .08s}
.result:hover{transform:translateY(-2px)}
.result .mini{width:46px;height:46px;border-radius:12px;flex:none;display:flex;align-items:center;justify-content:center;font-size:24px}
.result .info{flex:1;min-width:0}
.result .info .nm{font-family:var(--fd);font-weight:600;font-size:15px;line-height:1.05}
.result .mb{height:9px;background:var(--rowg);border-radius:6px;overflow:hidden;margin:5px 0 3px}
.result .mb i{display:block;height:100%}
.result .st{font-weight:800;font-size:11.5px;color:var(--ink2)}
.result .ready{color:var(--good)}
.result .cook{background:var(--good);color:#fff;font-weight:800;font-size:10.5px;padding:2px 9px;border-radius:11px;white-space:nowrap}
.emptyhint{text-align:center;color:var(--ink2);font-weight:700;padding:24px 10px;font-size:14px}
.emptyhint .big{font-size:38px;display:block;margin-bottom:8px}

/* ================= MODAL (box list manager) ================= */
.modalwrap{position:fixed;inset:0;background:rgba(40,36,28,.45);display:flex;align-items:center;justify-content:center;z-index:200;padding:20px}
.modalcard{background:var(--cream);border-radius:20px;box-shadow:0 18px 50px rgba(0,0,0,.4);width:420px;max-width:100%;max-height:86vh;overflow:hidden;display:flex;flex-direction:column}
.modalhead{background:var(--char);color:#fff;padding:13px 18px;display:flex;align-items:center;gap:10px;font-family:var(--fd);font-weight:600;font-size:19px}
.modalhead .mx{margin-left:auto;width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;font-weight:800}
.modalbody{padding:14px 16px;overflow-y:auto}
.boxrow{display:flex;align-items:center;gap:10px;background:#fff;border-radius:14px;box-shadow:var(--soft);padding:9px 12px;margin-bottom:9px}
.boxrow .bem{font-size:18px}
.boxrow input{flex:1;border:none;outline:none;font-family:var(--fd);font-weight:600;font-size:16px;background:transparent;color:var(--ink);min-width:0}
.boxrow .bcount{font-weight:800;font-size:12px;color:var(--ink2)}
.boxrow .bdel{width:26px;height:26px;border-radius:50%;background:#f6e1df;color:var(--heart);font-weight:800;display:flex;align-items:center;justify-content:center;flex:none}
.boxrow.locked{opacity:.7}
.addbox{display:flex;gap:8px;margin-top:4px}
.addbox input{flex:1;border:2px solid #d8cfb8;border-radius:12px;padding:9px 13px;font-weight:700;outline:none;background:#fff}
.addbox button{background:var(--green);color:#26330a;font-weight:800;border-radius:12px;padding:9px 16px;box-shadow:0 2px 0 var(--green-d)}
.modalnote{color:var(--ink2);font-weight:700;font-size:12px;text-align:center;padding:6px 14px 14px}

/* in-box add/remove toggle inside modal recipe assign */
.assignrow{display:flex;align-items:center;gap:9px;padding:7px 4px;border-bottom:1.5px dashed var(--cream2)}
.assignrow:last-child{border-bottom:none}
.assignrow .an{flex:1;font-weight:700;font-size:14px}
.assignrow .atog{width:24px;height:24px;border-radius:7px;background:var(--rowg);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;flex:none}
.assignrow.in .atog{background:var(--good)}

/* fadein */
.fadein{animation:fade .26s ease both}
@keyframes fade{from{transform:translateY(7px)}to{transform:none}}
@media(prefers-reduced-motion:reduce){.fadein{animation:none}}

/* ================= NEDI mascot ================= */
.nedi-root{position:fixed;left:18px;bottom:62px;z-index:1000;display:flex;flex-direction:column;align-items:flex-start;gap:10px}
.nedi-fab{width:72px;height:72px;border-radius:50%;background:#fff;border:3px solid var(--char);box-shadow:var(--soft2);display:flex;align-items:center;justify-content:center;padding:0;animation:nbob 3.5s ease-in-out infinite}
.nedi-fab:hover{transform:translateY(-3px) rotate(-4deg)}
.nedi-fab:active{transform:translateY(1px)}
@keyframes nbob{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
@media(prefers-reduced-motion:reduce){.nedi-fab{animation:none}}
.teaser{background:var(--char);color:#fff;font-weight:800;font-size:13px;padding:9px 13px;border-radius:15px 15px 15px 4px;max-width:210px;cursor:pointer;box-shadow:var(--soft2);position:relative}
.teaser::after{content:"";position:absolute;left:22px;bottom:-8px;width:12px;height:12px;background:var(--char);transform:rotate(45deg)}
.chatpanel{width:336px;max-width:calc(100vw - 32px);height:450px;max-height:calc(100vh - 150px);background:var(--cream);border:3px solid var(--char);border-radius:20px;box-shadow:0 16px 40px rgba(0,0,0,.4);display:flex;flex-direction:column;overflow:hidden}
.chathead{display:flex;align-items:center;gap:11px;padding:11px 14px;background:var(--char);color:#fff}
.chathead .ch-cat{background:#fff;border-radius:50%;width:46px;height:46px;display:flex;align-items:center;justify-content:center;flex:none;border:2px solid #1f1f20}
.chathead .ch-id{flex:1;line-height:1.1}
.chathead .ch-id b{font-family:var(--fd);font-weight:600;font-size:19px;display:block}
.chathead .ch-id small{font-weight:700;font-size:11.5px;opacity:.85}
.chathead .ch-close{width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.18);color:#fff;font-weight:800}
.chatbody{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:9px}
.bubble{max-width:86%;padding:9px 13px;border-radius:15px;font-weight:600;font-size:14px;line-height:1.4}
.bubble.nedi{align-self:flex-start;background:#fff;box-shadow:var(--soft);border-bottom-left-radius:5px}
.bubble.me{align-self:flex-end;background:var(--green);color:#26330a;border-bottom-right-radius:5px}
.bubble.typing{display:flex;gap:5px;padding:13px}
.bubble.typing span{width:8px;height:8px;border-radius:50%;background:var(--ink2);animation:td 1s infinite}
.bubble.typing span:nth-child(2){animation-delay:.18s}.bubble.typing span:nth-child(3){animation-delay:.36s}
@keyframes td{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}
.chips{display:flex;flex-wrap:wrap;gap:6px;padding:0 12px 8px}
.chipbtn{background:#fff;border-radius:13px;box-shadow:var(--soft);padding:5px 10px;font-weight:800;font-size:11.5px;white-space:nowrap}
.chatinput{display:flex;gap:8px;padding:10px 12px;background:var(--cream2)}
.chatinput input{flex:1;border:none;border-radius:18px;padding:9px 14px;font-weight:600;font-size:14px;outline:none;background:#fff;box-shadow:var(--soft)}
.sendbtn{width:40px;height:40px;border-radius:50%;background:var(--green);color:#26330a;font-size:15px;box-shadow:0 2px 0 var(--green-d);flex:none}
.sendbtn:active{transform:translateY(2px);box-shadow:none}

::-webkit-scrollbar{width:11px;height:11px}
::-webkit-scrollbar-thumb{background:rgba(150,135,95,.35);border-radius:8px;border:3px solid transparent;background-clip:padding-box}

/* ================= v2 additions ================= */
.cmdbtn.act{background:rgba(255,255,255,.16)}

/* box count row + view toggle */
.boxcount{display:flex;align-items:center;justify-content:center;gap:10px}
.viewtoggle{background:#fff;border-radius:14px;box-shadow:var(--soft);padding:4px 11px;font-weight:800;font-size:11.5px;color:var(--ink)}
.viewtoggle:active{transform:translateY(1px)}

/* list view */
.boxlist{width:100%;max-width:460px;display:flex;flex-direction:column;gap:9px}
.lrow{display:flex;align-items:center;gap:11px;background:#fff;border-radius:15px;box-shadow:var(--soft);padding:8px 10px;cursor:pointer;border:2.5px solid transparent;transition:transform .08s}
.lrow:hover{transform:translateY(-1px)}
.lrow.sel{border-color:var(--sel)}
.lrow .lmini{width:42px;height:42px;border-radius:11px;flex:none;display:flex;align-items:center;justify-content:center;font-size:23px}
.lrow .linfo{flex:1;min-width:0;display:flex;flex-direction:column}
.lrow .ln{font-family:var(--fd);font-weight:600;font-size:16px;line-height:1.05;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lrow .lstar{color:#e8b53f}
.lrow .lmeta{font-weight:700;font-size:12px;color:var(--ink2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lrow .lopen{background:var(--green);color:#26330a;border-radius:11px;box-shadow:0 2px 0 var(--green-d);padding:6px 12px;font-weight:800;font-size:12px;flex:none}
.lrow .lopen:active{transform:translateY(2px);box-shadow:none}

/* source link */
.srclink{display:flex;align-items:center;gap:6px;flex-wrap:wrap;background:#fff;border-radius:13px;box-shadow:var(--soft);padding:9px 13px;margin-top:12px;font-weight:800;font-size:13.5px;color:var(--t-asian);text-decoration:none}
.srclink .srcdom{color:var(--ink2);font-weight:700;font-size:12px}
.editlink{margin-top:12px;width:100%;background:#fff;border-radius:13px;box-shadow:var(--soft);padding:10px;font-weight:800;font-size:14px;color:var(--ink)}
.editlink:active{transform:translateY(1px)}

/* search: box filter */
.boxfilter{display:flex;align-items:center;gap:8px;flex-wrap:wrap;max-width:1080px;margin:2px 0 14px}
.bflbl{font-weight:800;font-size:13px;color:var(--ink2)}
.bfchip{background:#fff;border-radius:16px;box-shadow:var(--soft);padding:6px 13px;font-weight:800;font-size:13px;color:var(--ink)}
.bfchip:active{transform:translateY(1px)}
.bfclear{font-weight:800;font-size:12.5px;color:var(--ink2);padding:6px 8px}

/* search: pantry edit */
.pantrytop{display:flex;align-items:flex-start;gap:12px;justify-content:space-between;margin-bottom:6px}
.editpantry{background:#fff;border-radius:14px;box-shadow:var(--soft);padding:6px 13px;font-weight:800;font-size:13px;color:var(--ink);flex:none}
.editpantry.on{background:var(--sel)}
.jar.editing{cursor:default;gap:4px;padding:7px 5px}
.jar.editing .emojinp{width:38px;text-align:center;border:2px solid var(--cream2);border-radius:9px;padding:4px;font-size:16px;outline:none}
.jar.editing .namenp{width:100%;border:2px solid var(--cream2);border-radius:9px;padding:4px 6px;font-weight:700;font-size:11.5px;text-align:center;outline:none}
.jar.editing .jardel{position:absolute;top:-7px;right:-7px;width:22px;height:22px;border-radius:50%;background:#f6e1df;color:var(--heart);font-weight:800;font-size:12px;box-shadow:var(--soft)}
.jar{position:relative}
.addjar{display:flex}
.addjar input{width:100%;border:2.5px dashed #cdc4b0;border-radius:14px;padding:8px 10px;font-weight:700;font-size:12px;outline:none;background:rgba(255,255,255,.6);text-align:center}
.addjar input:focus{border-color:var(--green);background:#fff}
.customhint{color:var(--ink2);font-weight:700;font-size:12px;margin:8px 2px 0;line-height:1.4}

/* ================= EDIT screen ================= */
.editwrap{max-width:900px;margin:0 auto}
.edithead{margin-bottom:14px}
.edithead h1{font-family:var(--fd);font-weight:700;font-size:30px;margin:0;line-height:1.05}
.edithead p{color:var(--ink2);font-weight:700;font-size:14.5px;margin:3px 0 0}
.editgrid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
@media(max-width:760px){.editgrid{grid-template-columns:1fr}}
.editwrap .panelw{margin-bottom:16px}
.flbl{display:block;font-weight:800;font-size:12.5px;color:var(--ink2);margin:12px 2px 5px}
.flbl:first-of-type{margin-top:4px}
.finp{width:100%;border:2.5px solid var(--cream2);border-radius:12px;padding:10px 13px;font-weight:700;font-size:14.5px;outline:none;background:#fff;color:var(--ink)}
.finp:focus{border-color:var(--green)}
.emojipick{display:flex;gap:10px;align-items:center}
.emojibig{width:58px;text-align:center;font-size:26px;padding:6px}
.emojiopts{display:flex;flex-wrap:wrap;gap:5px;flex:1}
.eopt{width:34px;height:34px;border-radius:10px;background:var(--rowg2);font-size:18px;display:flex;align-items:center;justify-content:center}
.eopt:hover{background:var(--cream2)}
.statedit{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px;min-height:36px}
.statedit .flbl{margin:0;white-space:nowrap}
.numstep{display:inline-flex;align-items:center;gap:4px;background:#fff;border-radius:22px;border:2px solid var(--cream2);padding:3px}
.numstep button{width:30px;height:30px;border-radius:50%;background:var(--green);color:#26330a;font-size:17px;font-weight:800;box-shadow:0 2px 0 var(--green-d)}
.numstep button:active{transform:translateY(2px);box-shadow:none}
.numstep b{min-width:42px;text-align:center;font-family:var(--fd);font-size:17px}
.segpick{display:inline-flex;align-items:center;gap:9px}
.segpick .seg i{width:15px;height:17px;cursor:pointer}
.segpick small{font-weight:800;color:var(--ink2);font-size:13px;min-width:56px}

/* ingredient + step editors */
.ingedit{display:grid;grid-template-columns:62px 92px 1fr 32px;gap:7px;align-items:center;margin-bottom:7px}
.ingedit input,.ingedit select{border:2px solid var(--cream2);border-radius:10px;padding:8px 9px;font-weight:700;font-size:13.5px;outline:none;background:#fff;min-width:0}
.ingedit input:focus,.ingedit select:focus{border-color:var(--green)}
.ingedit .qy{text-align:center}
.stepedit{display:grid;grid-template-columns:26px 1fr 32px;gap:9px;align-items:start;margin-bottom:8px}
.stepedit .sn{width:26px;height:26px;border-radius:50%;background:var(--ink);color:var(--cream);font-family:var(--px);font-weight:800;font-size:13px;display:flex;align-items:center;justify-content:center;margin-top:5px}
.stepedit textarea{border:2px solid var(--cream2);border-radius:11px;padding:8px 11px;font-family:var(--bd);font-weight:600;font-size:14px;outline:none;resize:vertical;background:#fff;line-height:1.35}
.stepedit textarea:focus{border-color:var(--green)}
.rmrow{width:30px;height:30px;border-radius:50%;background:#f6e1df;color:var(--heart);font-weight:800;font-size:13px;display:flex;align-items:center;justify-content:center;margin-top:3px}
.addrow{margin-top:6px;background:var(--rowg2);border-radius:12px;padding:9px 15px;font-weight:800;font-size:13.5px;color:var(--ink);box-shadow:var(--soft)}
.addrow:active{transform:translateY(1px)}

/* paste box */
.pastebox textarea{width:100%;min-height:150px;border:2.5px solid var(--cream2);border-radius:13px;padding:12px 14px;font-family:var(--bd);font-weight:600;font-size:14px;outline:none;resize:vertical;background:#fff;line-height:1.45}
.pastebox textarea:focus{border-color:var(--green)}
.pasterow{display:flex;gap:10px;margin-top:11px;flex-wrap:wrap}
.gbtn{background:var(--green);color:#26330a;border-radius:13px;padding:10px 18px;font-family:var(--fd);font-weight:600;font-size:15px;box-shadow:0 3px 0 var(--green-d);white-space:nowrap}
.gbtn:active{transform:translateY(2px);box-shadow:0 1px 0 var(--green-d)}
.gbtn:disabled{background:#d8d2c2;color:#fff;box-shadow:none;cursor:not-allowed}
.gbtn.big{padding:12px 26px;font-size:17px}
.lbtn{background:#fff;border-radius:13px;padding:10px 16px;font-weight:800;font-size:14px;color:var(--ink);box-shadow:var(--soft);white-space:nowrap}
.lbtn:active{transform:translateY(1px)}
.delbtn{background:#f6e1df;color:var(--heart);border-radius:13px;padding:10px 16px;font-weight:800;font-size:14px;box-shadow:var(--soft)}
.editfoot{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:4px 0 20px}

/* help + toast + dpad */
.dpad .dpadic{font-size:15px}
.helpcard{position:fixed;right:16px;bottom:66px;background:var(--char);color:#fff;border-radius:14px;box-shadow:0 10px 30px rgba(0,0,0,.4);padding:12px 15px;z-index:1200;display:flex;flex-direction:column;gap:7px;font-weight:700;font-size:13px}
.helpcard b{font-family:var(--fd);font-weight:600;font-size:15px;margin-bottom:2px}
.helpcard span{display:flex;align-items:center;gap:7px}
kbd{background:#54545a;border-radius:6px;border:1px solid #6a6a70;box-shadow:0 2px 0 #2a2a2c;padding:1px 7px;font-family:var(--px);font-size:12px;min-width:20px;text-align:center}
.toast{position:fixed;left:50%;bottom:72px;transform:translateX(-50%);background:#3c3c3e;color:#fff;font-weight:800;font-size:14px;padding:11px 18px;border-radius:14px;box-shadow:0 8px 24px rgba(0,0,0,.35);z-index:1500}

/* ================= v3 additions ================= */
/* per-step ingredient quantities */
.move .movebody{display:flex;flex-direction:column;gap:6px;flex:1;min-width:0}
.move .movetx{font-weight:700}
.stepings{display:flex;flex-wrap:wrap;gap:6px;margin-top:1px}
.steping{background:rgba(255,255,255,.7);border-radius:9px;padding:2px 9px;font-weight:800;font-size:11.5px;color:#5a5247}
.steping b{font-family:var(--px);font-weight:400;color:var(--ink)}

/* numbered effort/spice pips */
.segpick{display:inline-flex;align-items:center;gap:9px}
.pips{display:inline-flex;gap:4px}
.pip{width:26px;height:26px;border-radius:8px;background:var(--rowg);color:var(--ink2);font-weight:800;font-size:13px;border:2px solid transparent;box-shadow:inset 0 0 0 1px rgba(0,0,0,.05)}
.pip:hover{background:var(--cream2)}
.pip.on{background:var(--good);color:#fff}
.pip.spiceon{background:var(--t-cosy);color:#fff}
.segpick small{font-weight:800;color:var(--ink2);font-size:13px;min-width:56px}

/* cover picker */
.coverpick{display:flex;gap:12px;align-items:center;margin-bottom:8px}
.coverprev{width:64px;height:64px;border-radius:14px;border:2.5px solid var(--cream2);display:flex;align-items:center;justify-content:center;font-size:34px;flex:none;overflow:hidden}
.covertabs{display:flex;gap:7px}
.ctab{display:inline-flex;align-items:center;gap:5px;white-space:nowrap;background:var(--rowg2);border-radius:11px;padding:7px 13px;font-weight:800;font-size:13px;color:var(--ink);box-shadow:var(--soft)}
.ctab.on{background:var(--ink);color:var(--cream)}
.imagepick{display:flex;flex-direction:column;gap:8px}
.imagerow{display:flex;gap:8px;align-items:center}
.uploadbtn{background:var(--green);color:#26330a;border-radius:12px;padding:9px 15px;font-weight:800;font-size:13.5px;box-shadow:0 2px 0 var(--green-d);cursor:pointer;display:inline-block;white-space:nowrap}
.uploadbtn:active{transform:translateY(2px);box-shadow:none}

/* ingredients optional toggle */
.ingedithead{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.ingedithead h3{margin:0}
.optoggle{display:inline-flex;align-items:center;gap:7px;font-weight:800;font-size:13px;color:var(--ink2);cursor:pointer;user-select:none;white-space:nowrap;flex:none}
.optoggle input{width:17px;height:17px;accent-color:var(--green);cursor:pointer}

/* editable box emoji in modal */
.boxrow input.bememoji{width:44px;flex:none;text-align:center;font-size:18px;border:2px solid var(--cream2);border-radius:9px;padding:5px 2px;outline:none;min-width:0}

/* ================= collapsible favourites + mobile ================= */
.partytab{cursor:pointer;justify-content:flex-start}
.ptcount{background:var(--rowg);border-radius:12px;padding:1px 9px;font-size:13px;font-weight:800;color:var(--ink2)}
.ptchev{margin-left:auto;font-size:13px;color:var(--ink2)}

@media(max-width:880px){
  .boxlayout.mobile{display:flex;flex-direction:column;overflow-y:auto}
  .boxlayout.mobile .party{padding:12px 12px 4px;overflow:visible;flex:none}
  .boxlayout.mobile .partytab{align-self:stretch;width:100%}
  .boxlayout.mobile .party.collapsed{padding-bottom:0}
  .boxlayout.mobile .boxmid{padding:6px 12px 16px;flex:none}
  .boxlayout.mobile .boxgridwrap{overflow:visible}
  .boxgrid{max-width:none}
  .helpcard{display:none}
  .nedi-root{bottom:68px}
}
@media(max-width:560px){
  .cmdbar .cmdbtn .lab{display:none}
  .brandlogo{font-size:17px}
  .brandlogo small{display:none}
  .cmdbar.bottom{justify-content:space-around;padding:9px 10px}
  .cmdbar.top{gap:8px;padding:9px 12px}
  .dpad{display:none}
}

/* ================= sync ================= */
.synced-dot{width:11px;height:11px;border-radius:50%;display:inline-block;flex:none;box-shadow:0 0 0 2px rgba(0,0,0,.18)}
.synced-dot.s-off{background:#9a9a9d}
.synced-dot.s-idle{background:#9a9a9d}
.synced-dot.s-syncing{background:#f0b41f;animation:pulse 1s infinite}
.synced-dot.s-synced{background:#67bb4b}
.synced-dot.s-error{background:#e8615a}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.synctext{font-weight:700;font-size:13.5px;color:var(--ink2);line-height:1.45;margin:0 0 12px}
.syncfield{display:flex;gap:8px;margin-bottom:12px}
.syncfield input{flex:1;border:2.5px solid var(--cream2);border-radius:12px;padding:9px 13px;font-weight:700;font-size:14.5px;outline:none;background:#fff;min-width:0}
.syncfield input:focus{border-color:var(--green)}
.syncstatus{display:flex;align-items:center;gap:8px;font-weight:800;font-size:13px;color:var(--ink2);margin-bottom:14px}
.syncbtns{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.syncnote{font-weight:700;font-size:12px;color:var(--ink2);line-height:1.45;margin:0;padding-top:10px;border-top:1.5px dashed var(--cream2)}
