*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{touch-action:manipulation}body,html{margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:#16181d;background:#f2f5f3;min-height:100dvh;overscroll-behavior:contain;-webkit-font-smoothing:antialiased}:root{--brand:#17a558;--brand-dark:#0e7d41;--ink:#16181d;--muted:#6b7280;--line:#e6e8ec;--card:#fff;--danger:#e04646;--pill-w:128px;--safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px)}button{font:inherit;cursor:pointer;border:none;background:none}input,select{font-size:16px;font-family:inherit}a{color:inherit}.app{min-height:100dvh;display:flex;flex-direction:column}.header{position:-webkit-sticky;position:sticky;top:0;z-index:400;background:#fff;padding:calc(var(--safe-top) + 12px) var(--pill-w) 12px 18px;border-bottom:1px solid var(--line)}.brand{display:flex;align-items:center;gap:10px}.brand svg{flex:0 0 auto;border-radius:11px;box-shadow:0 2px 6px rgba(13,90,52,.16)}.header h1{margin:0;font-size:19px;font-weight:700;letter-spacing:-.2px}.header .sub{margin:2px 0 0;font-size:12.5px;color:var(--muted)}.content{flex:1 1;padding:16px;padding-bottom:calc(var(--safe-bottom) + 24px)}.btn{height:48px;padding:0 18px;border-radius:13px;background:var(--brand);color:#fff;font-weight:650;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:transform .06s ease,background .15s ease}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5}.btn.block{width:100%}.btn.ghost{background:#eaf2ed;color:var(--ink)}.btn.sm{height:38px;padding:0 14px;font-size:13.5px;border-radius:11px}.input{width:100%;height:48px;padding:0 14px;border:1.5px solid var(--line);border-radius:13px;background:#fff;outline:none}.input:focus{border-color:var(--brand)}.tabs{display:flex;gap:8px;margin-bottom:14px}.tabs .seg{flex:1 1;display:inline-flex;background:#e7efe9;border-radius:12px;padding:3px}.tabs .seg button{flex:1 1;padding:9px 10px;border-radius:9px;font-size:14px;font-weight:600;color:var(--muted)}.tabs .seg button.on{background:#fff;color:var(--ink);box-shadow:0 1px 3px rgba(0,0,0,.12)}.row2{display:flex;gap:8px;margin-bottom:16px}.row2 .btn{flex:1 1}.cardList{flex-direction:column}.cardList,.lcard{display:flex;gap:12px}.lcard{width:100%;text-align:left;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:16px;align-items:center;transition:transform .06s ease}.lcard:active{transform:scale(.99)}.lcard .ic{width:44px;min-width:44px;height:44px;border-radius:12px;background:#eaf7f0;color:var(--brand);display:flex;align-items:center;justify-content:center;font-size:22px}.lcard .body{flex:1 1;min-width:0}.lcard .name{font-weight:680;font-size:16px;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lcard .meta{margin:3px 0 0;font-size:12.5px;color:var(--muted)}.lcard .chev{color:#c3c8cf;font-size:20px}.badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:650}.badge.shared{background:#e7f6ee;color:var(--brand-dark)}.empty{text-align:center;color:var(--muted);padding:40px 16px;font-size:14px}.empty .big{font-size:40px}.dhead{display:flex;align-items:center;gap:10px;margin-bottom:6px}.dhead .btn.ghost{height:38px;padding:0 12px}.dtitle{flex:1 1;min-width:0;font-size:19px;font-weight:720;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dmeta{font-size:12.5px;color:var(--muted);margin:0 0 14px;display:flex;flex-wrap:wrap;gap:6px 12px;align-items:center}.codepill{background:#eaf7f0;color:var(--brand-dark);font-weight:700;letter-spacing:1px;padding:3px 10px;border-radius:999px;font-size:13px}.items{display:flex;flex-direction:column;gap:8px}.item{gap:12px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:12px 14px}.check,.item{display:flex;align-items:center}.check{width:26px;min-width:26px;height:26px;border-radius:8px;border:2px solid #cdd5ce;justify-content:center;color:#fff;font-size:15px}.check.on{background:var(--brand);border-color:var(--brand)}.item .txt{flex:1 1;min-width:0}.item .nm{font-size:15px;font-weight:550}.item.done .nm{text-decoration:line-through;color:var(--muted)}.item .qty{font-size:12.5px;color:var(--muted)}.item .by{font-size:11px;color:#a2a8b0}.item .del{color:#c3c8cf;font-size:18px;padding:4px}.addbar{position:-webkit-sticky;position:sticky;bottom:0;display:flex;gap:8px;padding:12px 0 calc(var(--safe-bottom) + 8px);background:linear-gradient(0deg,#f2f5f3 70%,transparent)}.addbar .input{flex:1 1}.sectionTitle{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin:18px 2px 8px}.sheetBackdrop{position:fixed;inset:0;background:rgba(10,12,16,.45);z-index:900;animation:fade .18s ease}.sheet{position:fixed;left:0;right:0;bottom:0;z-index:1000;background:#fff;border-radius:22px 22px 0 0;padding:10px 18px calc(var(--safe-bottom) + 20px);max-height:88dvh;overflow-y:auto;animation:slideUp .24s cubic-bezier(.2,.8,.2,1);box-shadow:0 -8px 40px rgba(0,0,0,.2)}.grip{width:40px;height:4px;background:#d7dbe0;border-radius:999px;margin:6px auto 12px}.sheet h2{margin:0 0 4px;font-size:20px}.sheet .sub{color:var(--muted);font-size:13px;margin:0 0 12px}.field{display:flex;flex-direction:column;gap:6px;margin-top:12px}.field label{font-size:12px;font-weight:600;color:var(--muted)}.chk{display:flex;align-items:center;gap:10px;margin-top:14px;font-size:14px}.chk input{width:20px;height:20px}.rlist{display:flex;flex-direction:column;gap:10px;margin-top:8px}.rcard{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:10px;text-align:left;width:100%}.rcard:active{transform:scale(.99)}.rthumb{width:54px;min-width:54px;height:54px;border-radius:10px;object-fit:cover;background:#eee}.rcard .rn{font-weight:650;font-size:14.5px}.rcard .rs{font-size:12px;color:var(--muted)}.spinner{width:28px;height:28px;border:3px solid #dfe3e8;border-top:3px solid var(--brand);border-radius:999px;margin:20px auto;animation:spin .8s linear infinite}.toast{position:fixed;left:50%;bottom:calc(var(--safe-bottom) + 20px);transform:translateX(-50%);background:#16181d;color:#fff;padding:10px 16px;border-radius:12px;font-size:13.5px;z-index:1200;animation:fade .2s ease}.linkBtn{color:var(--brand-dark);font-weight:650;font-size:14px;text-decoration:underline}@keyframes spin{to{transform:rotate(1turn)}}@keyframes fade{0%{opacity:0}}@keyframes slideUp{0%{transform:translateY(100%)}}