:root{--canvas: #ece7da;--paper: #f7f3ea;--paper-2: #fbf9f2;--ink: #21261e;--ink-soft: #5c6356;--ink-faint: #8b9082;--line: #dcd4c2;--line-soft: #e7e0d1;--pine: #2b543e;--pine-deep: #1e3b2c;--amber: #d8862a;--amber-soft: #f4e3c8;--amber-ink: #9a5b14;--clay: #bb4733;--clay-soft: #f2d9d1;--moss: #e6eddd;--r: 18px;--font: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--mono: ui-monospace, "SF Mono", "Cascadia Mono", Menlo, Consolas, monospace;--maxw: 480px}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;font-family:var(--font);color:var(--ink);background:var(--pine-deep);-webkit-font-smoothing:antialiased}button,input,textarea,select{font-family:var(--font)}a{color:inherit;text-decoration:none}#root{min-height:100dvh;display:flex;justify-content:center}.app{width:100%;max-width:var(--maxw);min-height:100dvh;background:var(--canvas);display:flex;flex-direction:column;position:relative;box-shadow:0 0 60px -10px #00000080}.appbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:12px;padding:max(12px,env(safe-area-inset-top)) 18px 12px;background:var(--canvas);border-bottom:1px solid var(--line-soft)}.appbar .back{width:36px;height:36px;flex:none;border-radius:11px;border:1px solid var(--line);background:var(--paper-2);display:grid;place-items:center;font-size:20px;color:var(--ink);cursor:pointer;line-height:1}.appbar .ttl{font-weight:750;font-size:20px;letter-spacing:-.01em}.appbar .sub{font-size:12px;color:var(--ink-soft);font-family:var(--mono)}.appbar .greet{font-size:13px;color:var(--ink-soft)}.appbar .greet b{display:block;font-size:21px;color:var(--ink);font-weight:800;letter-spacing:-.02em;margin-top:2px}.appbar .spacer{flex:1}.appbar .avatar{width:34px;height:34px;border-radius:50%;flex:none;background:var(--pine);color:#fff;display:grid;place-items:center;font-size:13px;font-weight:700;cursor:pointer;border:none}.body{flex:1;overflow-y:auto;padding:16px 16px 96px;display:flex;flex-direction:column;gap:12px}.tabbar{position:fixed;bottom:0;width:100%;max-width:var(--maxw);display:flex;background:var(--paper-2);border-top:1px solid var(--line);padding:8px 6px max(10px,env(safe-area-inset-bottom));z-index:30}.tabbar a{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10px;color:var(--ink-faint);padding:2px}.tabbar a.on{color:var(--pine);font-weight:600}.tabbar a .ic{font-size:20px;line-height:1}.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:14px}.label{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint)}.muted{color:var(--ink-soft);font-size:13px}.center-empty{text-align:center;color:var(--ink-faint);padding:40px 16px;font-size:14px}.row-between{display:flex;align-items:center;justify-content:space-between;gap:10px}h2.sec{font-size:14px;margin:6px 2px 0;color:var(--ink)}.chip{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:3px 9px;border-radius:999px;font-family:var(--mono);letter-spacing:.02em;white-space:nowrap}.chip.box{background:#e7ede4;color:var(--pine)}.chip.cons{background:var(--amber-soft);color:var(--amber-ink)}.chip.manual{background:var(--line-soft);color:var(--ink-soft)}.chip.miss{background:var(--clay-soft);color:var(--clay)}.chip.done{background:var(--moss);color:var(--pine)}.chip.priv{background:var(--line-soft);color:var(--ink-soft)}.chip.pub{background:var(--moss);color:var(--pine)}.scan-cta{display:flex;align-items:center;gap:14px;width:100%;text-align:left;background:var(--pine);color:#fff;border-radius:var(--r);padding:16px;box-shadow:0 12px 24px -12px #2b543ee6;border:none;cursor:pointer}.scan-cta .qr{width:46px;height:46px;border-radius:12px;background:#ffffff24;display:grid;place-items:center;font-size:24px;flex:none}.scan-cta .t b{display:block;font-size:16px;font-weight:700}.scan-cta .t span{font-size:12px;color:#c7d7c4}.quad{display:grid;grid-template-columns:1fr 1fr;gap:10px}.tile{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:13px;display:flex;flex-direction:column;gap:8px;cursor:pointer;text-align:left}.tile .ic{font-size:22px}.tile .nm{font-size:14px;font-weight:650;color:var(--ink)}.tile .mt{font-size:11px;color:var(--ink-soft);font-family:var(--mono)}.tile .badge{align-self:flex-start;background:var(--clay);color:#fff;font-size:10px;font-weight:700;padding:1px 7px;border-radius:999px;font-family:var(--mono)}.feed{display:flex;flex-direction:column;gap:9px}.feed .ev{display:flex;gap:10px;align-items:flex-start;font-size:13px}.feed .dot{width:8px;height:8px;border-radius:50%;margin-top:5px;flex:none}.feed .ev small{color:var(--ink-faint);font-family:var(--mono);font-size:10.5px}.item{display:flex;gap:11px;align-items:flex-start;padding:11px 12px;background:var(--paper);border:1px solid var(--line);border-radius:14px;cursor:pointer;transition:background .15s,border-color .15s;width:100%;text-align:left}.item:hover{border-color:var(--pine)}.box-check{width:23px;height:23px;border-radius:7px;border:2px solid var(--ink-faint);flex:none;display:grid;place-items:center;color:#fff;font-size:14px;margin-top:1px;transition:.15s;background:transparent}.item .meta{flex:1;min-width:0}.item .nm{font-size:14px;font-weight:600;line-height:1.25}.item .rmk{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--ink-soft);margin-top:4px;font-style:italic}.item .rmk.empty{color:var(--ink-faint)}.item .qty{font-family:var(--mono);font-size:11px;color:var(--ink-faint);margin-top:2px}.item.done{background:var(--moss);border-color:#cfe0c4}.item.done .box-check{background:var(--pine);border-color:var(--pine)}.item.done .nm{color:var(--pine)}.item.missing{background:var(--clay-soft);border-color:#e8c7bd}.item.missing .box-check{border-color:var(--clay);color:var(--clay)}.banner{display:flex;align-items:center;gap:9px;padding:10px 13px;border-radius:13px;font-size:13px;font-weight:600}.banner.warn{background:var(--clay-soft);color:var(--clay)}.banner.ok{background:var(--moss);color:var(--pine)}.banner.info{background:var(--amber-soft);color:var(--amber-ink)}.seg{display:flex;gap:4px;background:var(--line-soft);padding:4px;border-radius:13px}.seg button{flex:1;border:none;background:transparent;font-size:12.5px;font-weight:650;padding:8px 4px;border-radius:9px;color:var(--ink-soft);cursor:pointer}.seg button.on{background:var(--paper-2);color:var(--ink);box-shadow:0 2px 6px -2px #0003}.seg button .ct{font-family:var(--mono);font-size:10px;opacity:.8}.progress{height:8px;background:var(--line-soft);border-radius:999px;overflow:hidden}.progress i{display:block;height:100%;background:var(--pine);border-radius:999px;transition:width .3s}.btn{border:none;background:var(--pine);color:#fff;font-weight:700;font-size:14px;padding:13px;border-radius:14px;cursor:pointer;width:100%}.btn:disabled{opacity:.5;cursor:default}.btn.amber{background:var(--amber)}.btn-row{display:flex;gap:10px}.ghostbtn{border:1px dashed var(--line);background:transparent;color:var(--ink-soft);font-size:13px;padding:11px;border-radius:13px;width:100%;cursor:pointer}.linkbtn{border:none;background:transparent;color:var(--pine);font-weight:600;font-size:13px;cursor:pointer;padding:4px}.act{border:1px solid var(--pine);color:var(--pine);background:transparent;font-size:12px;font-weight:700;padding:6px 12px;border-radius:999px;cursor:pointer;white-space:nowrap}.act.amber{border-color:var(--amber);color:var(--amber-ink)}.act.ghost{border-color:var(--line);color:var(--ink-soft)}.shop{display:flex;gap:10px;align-items:center;padding:11px 12px;background:var(--paper);border:1px solid var(--line);border-radius:14px}.shop .nm{flex:1;font-size:14px;font-weight:600;min-width:0}.shop .nm small{display:block;font-weight:400;font-size:11.5px;color:var(--ink-soft);font-style:italic}.shop.bought{background:var(--amber-soft);border-color:#e8d3ae}.trip{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:13px;display:flex;flex-direction:column;gap:8px}.trip .top{display:flex;justify-content:space-between;align-items:baseline;gap:8px}.trip .dest{font-size:15px;font-weight:700}.trip .km{font-family:var(--mono);font-size:15px;font-weight:700;color:var(--pine);white-space:nowrap}.trip .who{font-size:12px;color:var(--ink-soft);font-family:var(--mono)}.trip .note{font-size:13px;color:var(--ink-soft);border-top:1px dashed var(--line);padding-top:8px;display:flex;gap:7px;align-items:flex-start}.trip .note.ok{color:var(--pine)}.trip .note.urgent{color:var(--clay);font-weight:600}.field{display:flex;flex-direction:column;gap:6px}.field>label{font-size:12.5px;font-weight:650;color:var(--ink-soft)}.input,.textarea,.select{border:1px solid var(--line);background:var(--paper-2);border-radius:12px;padding:11px 12px;font-size:14px;color:var(--ink);width:100%}.textarea{resize:vertical;min-height:64px}.input:focus,.textarea:focus,.select:focus{outline:2px solid var(--pine);outline-offset:1px;border-color:var(--pine)}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:10px}.opt{display:flex;gap:11px;align-items:center;padding:12px;border:1px solid var(--line);border-radius:14px;cursor:pointer;background:var(--paper);width:100%;text-align:left}.opt .rd{width:20px;height:20px;border-radius:50%;border:2px solid var(--ink-faint);flex:none;display:grid;place-items:center}.opt.on{border-color:var(--pine);background:var(--moss)}.opt.on .rd{border-color:var(--pine)}.opt.on .rd:after{content:"";width:10px;height:10px;border-radius:50%;background:var(--pine)}.opt .ic{font-size:18px}.opt .tx b{display:block;font-size:13.5px;font-weight:650}.opt .tx span{font-size:11.5px;color:var(--ink-soft)}.qr-wrap{display:flex;flex-direction:column;align-items:center;gap:12px;padding:8px}.qr-wrap img,.qr-wrap canvas{width:200px;height:200px;background:#fff;border-radius:12px;padding:10px;border:1px solid var(--line)}#qr-reader{width:100%;border-radius:14px;overflow:hidden;border:1px solid var(--line)}#qr-reader img[alt="Info icon"]{display:none}.person{display:flex;gap:11px;align-items:center;padding:10px 12px;background:var(--paper);border:1px solid var(--line);border-radius:14px}.person .av{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:12px;font-weight:700;flex:none}.person .nm{flex:1;font-size:14px;font-weight:600}.person .role{font-size:11.5px;color:var(--ink-soft)}.list{display:flex;flex-direction:column;gap:10px}.divider{height:1px;background:var(--line-soft);margin:4px 0}.photo-thumb{width:42px;height:42px;border-radius:10px;object-fit:cover;border:1px solid var(--line);flex:none;cursor:pointer}.photo-wide{width:100%;max-height:200px;object-fit:cover;border-radius:var(--r);border:1px solid var(--line);cursor:pointer;display:block}.hero-img{width:100%;aspect-ratio:21 / 10;object-fit:cover;border-radius:var(--r);display:block;border:1px solid var(--line)}.print-sheet{display:grid;grid-template-columns:1fr 1fr;gap:10px}.label-card{border:1.5px dashed var(--ink-faint);border-radius:10px;padding:12px 8px;display:flex;flex-direction:column;align-items:center;gap:2px;background:#fff;text-align:center}.label-card img{width:108px;height:108px}.label-code{font-family:var(--mono);font-weight:700;font-size:14px;letter-spacing:.05em}.label-name{font-size:13px;font-weight:600}.label-loc{font-size:11px;color:var(--ink-soft)}@media print{body{background:#fff!important}.app{max-width:none!important;box-shadow:none!important;background:#fff!important}.no-print,.tabbar{display:none!important}.body{padding:0!important;overflow:visible!important}.print-sheet{grid-template-columns:repeat(3,1fr);gap:6mm}.label-card{break-inside:avoid}}@media (prefers-reduced-motion: reduce){*{transition:none!important}}
