@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600;700&family=DM+Sans:wght@300;400;500&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--cream:#faf7f2;--warm:#f5efe6;--bark:#2d1f14;--bark-mid:#5c3d2e;--bark-light:#8b6355;--sage:#7c9a6e;--terra:#c4674a;--terra-light:#e8a090;--gold:#d4a853;--text:#2d1f14;--soft:#7a6256;--border:#e8ddd4;--shadow:rgba(45,31,20,.12);--r:16px;--rs:10px}body{background:var(--cream);font-family:DM Sans,sans-serif;color:var(--text);min-height:100vh}h1,h2,h3{font-family:Playfair Display,serif}.app{display:flex;flex-direction:column;min-height:100vh}.nav{background:var(--bark);padding:0 24px;display:flex;align-items:center;gap:8px;height:64px;position:sticky;top:0;z-index:100;box-shadow:0 2px 20px #00000040}.brand{font-family:Playfair Display,serif;color:var(--gold);font-size:22px;font-weight:700;margin-right:auto}.brand span{color:var(--terra-light)}.sync-pill{font-size:11px;padding:3px 10px;border-radius:20px;font-weight:500}.sync-pill.cloud{background:#7c9a6e4d;color:#a8c49a}.sync-pill.local{background:#d4a85333;color:var(--gold)}.nav-tabs{display:flex;gap:4px}.ntab{background:none;border:none;color:#ffffff8c;font-family:DM Sans,sans-serif;font-size:13.5px;font-weight:500;padding:8px 14px;border-radius:8px;cursor:pointer;transition:all .2s;white-space:nowrap}.ntab:hover{background:#ffffff1a;color:#fff}.ntab.active{background:var(--terra);color:#fff}.main{flex:1;padding:28px 24px;max-width:1280px;margin:0 auto;width:100%}.sh{margin-bottom:24px}.sh h2{font-size:28px;color:var(--bark)}.sh p{color:var(--soft);margin-top:4px;font-size:14px}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.card{background:#fff;border-radius:var(--r);overflow:hidden;box-shadow:0 2px 12px var(--shadow);transition:transform .2s,box-shadow .2s;cursor:pointer;border:2px solid transparent;position:relative}.card:hover{transform:translateY(-3px);box-shadow:0 8px 28px var(--shadow)}.card.sel{border-color:var(--sage)}.card.rec{border-color:var(--gold)}.card-img{width:100%;height:180px;object-fit:cover;display:block;background:var(--warm)}.card-body{padding:14px 16px}.card-title{font-size:16px;font-weight:600;color:var(--bark);margin-bottom:6px;font-family:Playfair Display,serif}.card-meta{display:flex;gap:10px;font-size:12px;color:var(--soft);margin-bottom:10px;flex-wrap:wrap}.tags{display:flex;flex-wrap:wrap;gap:4px}.tag{background:var(--warm);color:var(--bark-light);font-size:11px;padding:2px 8px;border-radius:20px;font-weight:500}.badge{position:absolute;top:10px;right:10px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600}.badge-sel{background:var(--sage);color:#fff}.badge-rec{background:var(--gold);color:#fff}.card-actions{display:flex;gap:8px;margin-top:12px}.btn{border:none;border-radius:var(--rs);padding:8px 14px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:500;cursor:pointer;transition:all .18s;display:flex;align-items:center;gap:5px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-p{background:var(--terra);color:#fff;flex:1;justify-content:center}.btn-p:hover:not(:disabled){background:#b05a3f}.btn-s{background:var(--warm);color:var(--bark-mid);border:1px solid var(--border)}.btn-s:hover{background:var(--border)}.btn-g{background:transparent;color:var(--soft);border:1px solid var(--border)}.btn-g:hover{background:var(--warm)}.btn-sage{background:var(--sage);color:#fff;flex:1;justify-content:center}.btn-sage:hover{background:#6a8860}.btn-del{background:#fee2e2;color:#b91c1c;border:1px solid #fca5a5}.btn-del:hover{background:#fecaca}.btn-sm{padding:5px 10px;font-size:12px}.filters{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap;align-items:center}.chip{padding:6px 14px;border-radius:20px;border:1.5px solid var(--border);background:#fff;font-size:13px;cursor:pointer;transition:all .15s;color:var(--soft);font-family:DM Sans,sans-serif}.chip:hover{border-color:var(--bark-light);color:var(--bark)}.chip.on{background:var(--bark);color:#fff;border-color:var(--bark)}.sinput{padding:8px 16px;border-radius:20px;border:1.5px solid var(--border);font-family:DM Sans,sans-serif;font-size:13px;outline:none;background:#fff;color:var(--text);width:200px;transition:border-color .15s}.sinput:focus{border-color:var(--terra)}.selbar{background:var(--bark);border-radius:var(--r);padding:16px 20px;margin-bottom:24px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}.selbar p{color:#ffffffb3;font-size:14px}.selbar strong{color:var(--gold)}.schips{display:flex;gap:8px;flex-wrap:wrap;flex:1}.schip{background:#ffffff1f;color:#fff;padding:4px 12px;border-radius:20px;font-size:13px;display:flex;align-items:center;gap:6px}.schip button{background:none;border:none;color:#fff9;cursor:pointer;font-size:16px;line-height:1}.rec-sec{margin-bottom:32px}.rec-head{display:flex;align-items:center;gap:10px;margin-bottom:16px;padding:12px 16px;background:linear-gradient(135deg,#fff9ee,#fff);border-radius:var(--rs);border:1.5px solid #f0d99a}.rec-head h3{font-size:18px;color:var(--bark)}.rec-head p{font-size:13px;color:var(--soft)}.pulse{display:flex;align-items:center;gap:10px;color:var(--soft);font-size:14px;padding:12px 0}.pd{width:8px;height:8px;border-radius:50%;background:var(--gold);animation:pulse 1.2s ease-in-out infinite}.pd:nth-child(2){animation-delay:.2s}.pd:nth-child(3){animation-delay:.4s}@keyframes pulse{0%,to{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1)}}.ibar{display:flex;gap:8px;margin-bottom:12px}.iinput{flex:1;padding:10px 16px;border-radius:var(--rs);border:1.5px solid var(--border);font-family:DM Sans,sans-serif;font-size:14px;outline:none;background:#fff}.iinput:focus{border-color:var(--terra)}.psteps{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px}.pstep{display:flex;align-items:center;gap:5px;font-size:12px;padding:4px 10px;border-radius:20px}.pstep.done{background:#dcfce7;color:#15803d}.pstep.active{background:#fff9ee;color:var(--bark-mid)}.pstep.pending{background:var(--warm);color:var(--soft)}.pstep.error{background:#fee2e2;color:#b91c1c}.spin{animation:spin 1s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.pzone{border:2px dashed var(--border);border-radius:var(--rs);padding:20px;text-align:center;cursor:pointer;transition:all .2s;background:var(--warm);min-height:120px;display:flex;flex-direction:column;align-items:center;justify-content:center}.pzone:hover,.pzone.over{border-color:var(--terra);background:#fdf3ef}.pzone img{width:100%;height:160px;object-fit:cover;border-radius:8px;margin-bottom:8px}.pzone p{font-size:13px;color:var(--soft)}.pzone .picon{font-size:32px;margin-bottom:8px}.calgrid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;margin-bottom:24px}.calday{background:#fff;border-radius:var(--rs);padding:10px;min-height:160px;box-shadow:0 1px 8px var(--shadow);border:1.5px solid var(--border);transition:border-color .15s}.calday.today{border-color:var(--terra)}.cddl{font-size:11px;color:var(--soft);font-weight:500;margin-bottom:2px}.cddn{font-size:18px;font-family:Playfair Display,serif;color:var(--bark);font-weight:600;margin-bottom:8px}.calday.today .cddn{color:var(--terra)}.cmeal{background:var(--warm);border-radius:6px;padding:4px 6px;margin-bottom:4px;display:flex;align-items:flex-start;gap:4px;font-size:11px;color:var(--bark-mid)}.cmeal-img{width:36px;height:36px;border-radius:6px;object-fit:cover;flex-shrink:0}.cmeal-t{flex:1;overflow:hidden;font-weight:500;word-break:break-word;white-space:normal;line-height:1.3;font-size:10px}.cmeal-rm{background:none;border:none;color:var(--bark-light);cursor:pointer;font-size:14px;flex-shrink:0;opacity:0;transition:opacity .15s}.cmeal:hover .cmeal-rm{opacity:1}.cadd{width:100%;background:none;border:1.5px dashed var(--border);border-radius:6px;padding:4px;font-size:11px;color:var(--soft);cursor:pointer;transition:all .15s}.cadd:hover{border-color:var(--sage);color:var(--sage);background:#f0f7ee}.wnav{display:flex;align-items:center;gap:12px;margin-bottom:16px}.wnav h3{font-size:20px;color:var(--bark);flex:1}.wnav button{background:var(--warm);border:1.5px solid var(--border);border-radius:8px;padding:6px 12px;cursor:pointer;font-size:18px;color:var(--bark-mid);transition:all .15s}.wnav button:hover{background:var(--border)}.sctl{display:flex;align-items:center;gap:12px;background:#fff;border:1.5px solid var(--border);border-radius:var(--rs);padding:10px 16px;margin-bottom:20px}.sctl label{font-size:14px;color:var(--soft);flex:1}.sctl strong{font-size:16px;color:var(--bark);min-width:28px;text-align:center}.sbtn{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--border);background:var(--warm);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;color:var(--bark-mid);transition:all .15s;flex-shrink:0}.sbtn:hover:not(:disabled){background:var(--terra);color:#fff;border-color:var(--terra)}.sbtn:disabled{opacity:.3;cursor:not-allowed}.scaled{font-size:12px;color:var(--terra);margin-left:8px}.shoprow{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fff;border-radius:var(--rs);border:1.5px solid var(--border);margin-bottom:8px;transition:all .2s;cursor:pointer}.shoprow.chk{opacity:.5;background:var(--warm)}.shoprow.chk .iname{text-decoration:line-through}.cbox{width:22px;height:22px;border-radius:6px;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s;background:#fff}.shoprow.chk .cbox{background:var(--sage);border-color:var(--sage);color:#fff}.idot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.iname{flex:1;font-size:14px;color:var(--text);font-weight:500}.iqty{font-size:13px;color:var(--soft);white-space:nowrap}.dinfo{font-size:11px;padding:2px 8px;border-radius:20px;white-space:nowrap}.dok{background:#dcfce7;color:#15803d}.dwarn{background:#fef9c3;color:#a16207}.durgent{background:#fee2e2;color:#b91c1c}.cattitle{font-size:13px;font-weight:600;color:var(--soft);text-transform:uppercase;letter-spacing:.5px;margin:16px 0 8px;display:flex;align-items:center;gap:8px}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--cream);border-radius:var(--r);padding:24px;max-width:560px;width:100%;max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal h3{font-size:22px;margin-bottom:6px;color:var(--bark)}.mpara{color:var(--soft);font-size:13px;margin-bottom:16px}.mlist{display:flex;flex-direction:column;gap:8px;max-height:380px;overflow-y:auto}.mitem{display:flex;align-items:center;gap:10px;background:#fff;border-radius:var(--rs);padding:10px 12px;border:1.5px solid var(--border);cursor:pointer;transition:all .15s}.mitem:hover{border-color:var(--sage);background:#f6fbf4}.mitem img{width:44px;height:44px;border-radius:8px;object-fit:cover}.mitem strong{font-size:14px;color:var(--bark);display:block}.mitem span{font-size:12px;color:var(--soft)}.mfoot{display:flex;gap:8px;margin-top:16px;justify-content:flex-end}.detail{max-width:800px;margin:0 auto}.dimg{width:100%;height:320px;object-fit:cover;border-radius:var(--r);margin-bottom:24px;box-shadow:0 4px 24px var(--shadow)}.detail h2{font-size:32px;color:var(--bark);margin-bottom:8px}.dmeta{display:flex;gap:20px;margin-bottom:24px;flex-wrap:wrap}.dmi{display:flex;flex-direction:column;align-items:center;background:#fff;border-radius:var(--rs);padding:10px 16px;border:1px solid var(--border);min-width:80px}.dmi span:first-child{font-size:20px}.dmi span:last-child{font-size:12px;color:var(--soft);margin-top:2px}.dsec{margin-bottom:24px}.dsec h3{font-size:20px;color:var(--bark);margin-bottom:12px;border-bottom:2px solid var(--border);padding-bottom:6px;display:flex;align-items:center;gap:10px}.ingrow{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border)}.ingrow:last-child{border-bottom:none}.ingname{font-size:14px;color:var(--text)}.ingr{display:flex;align-items:center;gap:8px}.ingqty{font-size:14px;color:var(--bark-mid);font-weight:500}.mstep{display:flex;gap:12px;margin-bottom:12px;align-items:flex-start}.snum{width:28px;height:28px;border-radius:50%;background:var(--terra);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;flex-shrink:0;margin-top:1px}.stxt{font-size:14px;color:var(--text);line-height:1.6;padding-top:3px}.empty{text-align:center;padding:48px 24px;color:var(--soft)}.empty h3{font-size:22px;color:var(--bark);margin-bottom:8px}.ei{font-size:56px;margin-bottom:16px}.toasts{position:fixed;bottom:80px;right:20px;z-index:300;display:flex;flex-direction:column;gap:8px}.toast{background:var(--bark);color:#fff;padding:10px 16px;border-radius:var(--rs);font-size:13px;box-shadow:0 4px 20px #0000004d;animation:tslide .3s ease;max-width:300px}.toast.success{border-left:4px solid var(--sage)}.toast.error{border-left:4px solid #f87171}.toast.info{border-left:4px solid var(--gold)}@keyframes tslide{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.fgrp{margin-bottom:14px}.flabel{font-size:12px;font-weight:600;color:var(--soft);text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px;display:block}.finput{width:100%;padding:8px 12px;border-radius:8px;border:1.5px solid var(--border);font-family:DM Sans,sans-serif;font-size:14px;outline:none;background:#fff}.finput:focus{border-color:var(--terra)}.ftarea{width:100%;padding:8px 12px;border-radius:8px;border:1.5px solid var(--border);font-family:DM Sans,sans-serif;font-size:14px;outline:none;background:#fff;resize:vertical;min-height:80px}.ftarea:focus{border-color:var(--terra)}.ingrow-edit{display:grid;grid-template-columns:1fr 70px 70px 90px 100px 28px;gap:5px;margin-bottom:6px;align-items:center}.ingi{padding:6px 8px;border-radius:6px;border:1.5px solid var(--border);font-family:DM Sans,sans-serif;font-size:13px;outline:none;width:100%}.ingi:focus{border-color:var(--sage)}.ingdel{background:#fee2e2;border:none;border-radius:6px;color:#b91c1c;cursor:pointer;font-size:16px;width:28px;height:28px;display:flex;align-items:center;justify-content:center}.sbanner{background:linear-gradient(135deg,#fff9ee,#fff);border:1.5px solid #f0d99a;border-radius:var(--r);padding:18px 20px;margin-bottom:24px}.sbanner h4{font-size:15px;color:var(--bark);margin-bottom:6px}.sbanner p{font-size:13px;color:var(--soft);margin-bottom:10px;line-height:1.5}.sbanner code{background:var(--warm);padding:1px 5px;border-radius:4px;font-size:12px}.srow{display:flex;gap:8px;flex-wrap:wrap}.si{flex:1;min-width:180px;padding:8px 12px;border-radius:8px;border:1.5px solid var(--border);font-family:DM Sans,sans-serif;font-size:13px;outline:none}.si:focus{border-color:var(--gold)}.statgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.statcard{background:#fff;border:1.5px solid var(--border);border-radius:var(--rs);padding:14px 16px;text-align:center}.statcard .stn{font-size:28px;margin-bottom:4px}.statcard .stv{font-size:26px;font-family:Playfair Display,serif;color:var(--bark);font-weight:700}.statcard .stl{font-size:12px;color:var(--soft)}pre{background:var(--bark);color:#a8c49a;padding:16px 20px;border-radius:var(--rs);font-size:12px;overflow-x:auto;line-height:1.6}.prog-wrap{margin-bottom:16px}.prog-labels{display:flex;justify-content:space-between;font-size:13px;color:var(--soft);margin-bottom:6px}.prog-bar{height:6px;background:var(--border);border-radius:4px;overflow:hidden}.prog-fill{height:100%;background:var(--sage);border-radius:4px;transition:width .3s ease}.mobnav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--bark);padding:8px;gap:4px;z-index:100;box-shadow:0 -2px 20px #0003}@media (max-width:768px){.calgrid{grid-template-columns:repeat(3,1fr)}.nav-tabs{display:none}.mobnav{display:flex}.main{padding-bottom:80px}.grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.toasts{bottom:90px;right:12px;left:12px}.ingrow-edit{grid-template-columns:1fr 1fr}}.mtab{flex:1;background:none;border:none;color:#ffffff80;padding:6px 4px;border-radius:8px;cursor:pointer;font-size:10px;display:flex;flex-direction:column;align-items:center;gap:2px;transition:all .15s;font-family:DM Sans,sans-serif}.mtab.active{color:#fff;background:#ffffff1f}.micon{font-size:20px}
