.app{max-width:480px;margin:0 auto;min-height:100vh;background:#0f172a;position:relative}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:#0f172a}.header{display:flex;align-items:center;gap:12px;padding:20px 20px 12px;border-bottom:1px solid #1E293B;background:#0f172a;position:sticky;top:0;z-index:100}.back-btn{background:#1e293b;border:none;color:#94a3b8;border-radius:10px;padding:8px;cursor:pointer;display:flex;align-items:center}.title{margin:0;font-size:22px;font-weight:700;color:#f8fafc;letter-spacing:-.5px}.subtitle{font-size:13px;color:#64748b}.content{padding:16px 20px 100px}.search-wrap{display:flex;align-items:center;gap:10px;background:#1e293b;border-radius:12px;padding:10px 14px;margin-bottom:16px;color:#64748b}.search-input{flex:1;background:none;border:none;outline:none;color:#e2e8f0;font-size:15px}.clear-btn{background:none;border:none;color:#64748b;cursor:pointer;font-size:14px;padding:4px}.action-row{display:flex;gap:10px;margin-bottom:20px}.btn-primary{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;background:#3b82f6;color:#fff;border:none;border-radius:12px;padding:12px 16px;font-size:15px;font-weight:600;cursor:pointer}.btn-outline{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;background:#1e293b;color:#3b82f6;border:1.5px solid #334155;border-radius:12px;padding:12px 16px;font-size:15px;font-weight:600;cursor:pointer}.btn-cancel{flex:1;background:#0f172a;color:#94a3b8;border:1.5px solid #334155;border-radius:12px;padding:12px 16px;font-size:15px;cursor:pointer}.btn-ghost{background:none;color:#94a3b8;border:none;padding:8px 10px;font-size:13px;cursor:pointer;display:flex;align-items:center;gap:4px;white-space:nowrap}.btn-small-primary{background:#3b82f6;color:#fff;border:none;border-radius:8px;padding:8px 14px;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap}.card{background:#1e293b;border-radius:14px;padding:20px}.section-title{font-size:13px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:1px;margin-bottom:12px}.muted{font-size:14px;color:#64748b}.hint{font-size:12px;color:#475569}.badge{font-size:13px;font-weight:600;color:#94a3b8;background:#0f172a;padding:2px 10px;border-radius:20px}.badge.lg{font-size:16px;padding:4px 12px}.color-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.list-card{display:flex;align-items:center;gap:12px;background:#1e293b;border-radius:12px;padding:12px 14px;margin-bottom:8px;cursor:pointer}.card-name{font-size:15px;font-weight:600;color:#f1f5f9}.card-loc{font-size:12px;color:#64748b}.match-items{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.match-chip{font-size:11px;color:#f59e0b;background:#f59e0b1a;padding:2px 8px;border-radius:6px;display:flex;align-items:center;gap:4px}.empty-state{text-align:center;padding:40px 20px}.empty-title{font-size:17px;font-weight:600;color:#94a3b8;margin-bottom:4px}.box-list{display:flex;flex-direction:column;gap:10px}.box-card{background:#1e293b;border-radius:14px;overflow:hidden;cursor:pointer;display:flex;transition:transform .1s}.box-card:active{transform:scale(.98)}.box-stripe{width:5px;flex-shrink:0}.box-body{flex:1;padding:14px 16px}.box-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.box-name{font-size:16px;font-weight:600;color:#f1f5f9}.box-loc{font-size:13px;color:#64748b;margin-bottom:6px}.box-preview{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.qr-mini{display:inline-flex;align-items:center;gap:3px;font-size:10px;color:#3b82f6;background:#3b82f61a;padding:2px 7px;border-radius:6px;font-weight:600}.preview-thumb{width:28px;height:28px;border-radius:6px;object-fit:cover}.preview-chip{font-size:11px;color:#94a3b8;background:#0f172a;padding:2px 8px;border-radius:20px}.preview-more{font-size:11px;color:#64748b}.form-group{margin-bottom:18px}.label{display:block;font-size:13px;font-weight:600;color:#94a3b8;margin-bottom:6px}.input{width:100%;background:#0f172a;border:1.5px solid #334155;border-radius:10px;padding:10px 14px;color:#e2e8f0;font-size:15px;outline:none;box-sizing:border-box;margin-bottom:8px;transition:border-color .15s}.input:focus{border-color:#3b82f6}.form-actions{display:flex;gap:10px;margin-top:8px}.box-info{margin-bottom:16px}.box-info-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.box-info-name{font-size:18px;font-weight:700;color:#f1f5f9}.box-info-loc{font-size:13px;color:#64748b;margin-top:2px}.qr-section{border-top:1px solid #334155;padding-top:14px}.qr-toggle{display:flex;align-items:center;gap:8px;background:none;border:none;color:#3b82f6;font-size:14px;font-weight:600;cursor:pointer;padding:0}.qr-container{cursor:pointer;display:inline-block;background:#0f172a;border-radius:16px;padding:16px;border:1px solid #334155}.qr-actions{margin-top:10px;display:flex;gap:8px;justify-content:center}.qr-action-btn{display:flex;align-items:center;gap:4px;background:#334155;border:none;color:#cbd5e1;border-radius:8px;padding:6px 12px;font-size:12px;font-weight:600;cursor:pointer}.add-item-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;background:none;color:#3b82f6;border:1.5px dashed #334155;border-radius:12px;padding:12px;font-size:15px;font-weight:600;cursor:pointer;margin-bottom:16px}.add-item-card{margin-bottom:16px}.input-row{display:flex;gap:8px;margin-bottom:8px}.flex-1{flex:1;margin-bottom:0!important}.qty-input{width:60px;margin-bottom:0!important;text-align:center}.add-item-actions{display:flex;justify-content:flex-end;gap:8px}.view-toggle{display:flex;gap:4px;margin-bottom:14px;background:#1e293b;border-radius:10px;padding:3px}.toggle-btn{flex:1;background:none;border:none;color:#64748b;border-radius:8px;padding:6px 12px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.toggle-btn.active{background:#334155;color:#e2e8f0}.item-list{display:flex;flex-direction:column;gap:6px}.item-row{display:flex;align-items:center;gap:12px;background:#1e293b;border-radius:12px;padding:12px 14px;animation:fadeIn .2s ease}.item-idx{width:28px;height:28px;border-radius:50%;background:#0f172a;color:#64748b;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0}.item-thumb{width:44px;height:44px;border-radius:10px;object-fit:cover;flex-shrink:0;cursor:pointer;border:1px solid #334155}.item-name{font-size:15px;font-weight:500;color:#e2e8f0;display:flex;align-items:center;gap:6px}.qty{font-size:12px;color:#f59e0b;font-weight:600}.item-note{font-size:12px;color:#64748b;margin-top:2px}.del-btn{background:none;border:none;color:#475569;cursor:pointer;padding:6px;border-radius:6px;display:flex;transition:color .15s}.del-btn:hover{color:#ef4444}.photo-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.photo-grid-item{background:#1e293b;border-radius:12px;overflow:hidden;position:relative;animation:fadeIn .2s ease}.photo-grid-img{width:100%;height:130px;object-fit:cover;display:block;cursor:pointer}.photo-grid-placeholder{width:100%;height:130px;display:flex;align-items:center;justify-content:center;background:#0f172a;color:#334155}.photo-grid-label{padding:8px 10px;display:flex;align-items:center;gap:4px}.photo-grid-name{font-size:13px;font-weight:600;color:#cbd5e1}.photo-grid-del{position:absolute;top:6px;right:6px;background:#0f172ab3;border:none;color:#94a3b8;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer}.photo-grid-del:hover{color:#ef4444}.photo-preview{position:relative;margin-bottom:10px;border-radius:12px;overflow:hidden;background:#0f172a}.photo-preview img{width:100%;max-height:200px;object-fit:cover;display:block;border-radius:12px}.photo-remove{position:absolute;top:8px;right:8px;background:#0f172acc;border:none;color:#ef4444;border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.photo-capture-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;background:#3b82f614;border:1.5px dashed #334155;border-radius:12px;padding:16px;color:#3b82f6;font-size:14px;font-weight:600;cursor:pointer}.danger-zone{margin-top:32px;padding-top:20px;border-top:1px solid #1E293B}.danger-btn{width:100%;background:none;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:10px;padding:10px;font-size:14px;cursor:pointer}.danger-confirm{background:#ef4444;color:#fff;border:none;border-radius:8px;padding:8px 14px;font-size:13px;font-weight:600;cursor:pointer}.confirm-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.lightbox-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000eb;z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px}.lightbox-overlay img{max-width:100%;max-height:85vh;border-radius:12px;object-fit:contain}.lightbox-close{position:absolute;top:16px;right:16px;background:#ffffff26;border:none;color:#fff;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer}.scanner-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;z-index:1500;display:flex;flex-direction:column}.scanner-header{display:flex;align-items:center;gap:12px;padding:16px 20px;background:#0009;z-index:10}.scanner-body{flex:1;position:relative;display:flex;align-items:center;justify-content:center}.scanner-frame-wrap{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.scanner-frame{width:220px;height:220px;border:3px solid rgba(59,130,246,.8);border-radius:20px;box-shadow:0 0 0 9999px #00000080,0 0 30px #3b82f64d;position:relative}.corner{position:absolute;width:30px;height:30px}.corner.tl{top:-2px;left:-2px;border-top:4px solid #3B82F6;border-left:4px solid #3B82F6;border-radius:8px 0 0}.corner.tr{top:-2px;right:-2px;border-top:4px solid #3B82F6;border-right:4px solid #3B82F6;border-radius:0 8px 0 0}.corner.bl{bottom:-2px;left:-2px;border-bottom:4px solid #3B82F6;border-left:4px solid #3B82F6;border-radius:0 0 0 8px}.corner.br{bottom:-2px;right:-2px;border-bottom:4px solid #3B82F6;border-right:4px solid #3B82F6;border-radius:0 0 8px}.scan-line{position:absolute;left:10px;right:10px;height:2px;background:linear-gradient(90deg,transparent,#3B82F6,transparent);animation:scanLine 2s ease-in-out infinite}.scanner-msg{position:absolute;color:#94a3b8;text-align:center;padding:30px}.scanner-bottom-msg{position:absolute;bottom:0;left:0;right:0;background:#000c;padding:20px;text-align:center}.scanner-footer{padding:16px 20px;background:#0009;text-align:center}.toast{position:fixed;top:16px;left:50%;transform:translate(-50%);padding:10px 20px;border-radius:10px;color:#fff;font-weight:600;font-size:14px;z-index:3000;animation:slideDown .3s ease;white-space:nowrap}.sync-bar{position:fixed;top:0;left:50%;transform:translate(-50%);background:#3b82f6;color:#fff;font-size:12px;font-weight:600;padding:4px 16px;border-radius:0 0 8px 8px;z-index:200;animation:fadeIn .2s ease}.auth-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;z-index:2500;display:flex;align-items:center;justify-content:center;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.auth-modal{background:#1e293b;border-radius:18px;padding:28px 24px;width:100%;max-width:340px;text-align:center;animation:fadeIn .2s ease}.auth-icon{font-size:36px;margin-bottom:10px}.auth-title{font-size:18px;font-weight:700;color:#f1f5f9;margin:0 0 6px}.auth-desc{font-size:14px;color:#94a3b8;margin:0 0 18px}.auth-input{text-align:center;font-size:18px!important;letter-spacing:4px;margin-bottom:4px!important}.auth-input.auth-error{border-color:#ef4444!important;animation:shake .3s ease}.auth-error-text{color:#ef4444;font-size:13px;margin:4px 0 8px}.auth-actions{display:flex;justify-content:center;gap:10px;margin-top:14px}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}.qty-control{display:flex;align-items:center;gap:2px;background:#0f172a;border-radius:8px;padding:2px;flex-shrink:0}.qty-control.sm{gap:1px;padding:1px}.qty-btn{width:28px;height:28px;border:none;background:#334155;color:#cbd5e1;border-radius:6px;font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .1s;line-height:1}.qty-btn.sm{width:22px;height:22px;font-size:13px;border-radius:5px}.qty-btn:hover:not(:disabled){background:#3b82f6;color:#fff}.qty-btn:disabled{opacity:.3;cursor:default}.qty-value{min-width:28px;text-align:center;font-size:14px;font-weight:700;color:#f59e0b}.readonly-badge{display:inline-block;font-size:13px;color:#94a3b8;background:#1e293b;padding:4px 12px;border-radius:20px;border:1px solid #334155}.qty-readonly{min-width:28px;text-align:center;font-size:14px;font-weight:700;color:#f59e0b;background:#0f172a;padding:4px 10px;border-radius:8px;flex-shrink:0}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%;background:#0f172a;font-family:Noto Sans TC,SF Pro Display,-apple-system,BlinkMacSystemFont,sans-serif;color:#e2e8f0;-webkit-font-smoothing:antialiased}input,button,select,textarea{font-family:inherit}input::placeholder{color:#475569}input:focus{border-color:#3b82f6!important}button:active{transform:scale(.97)}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#334155;border-radius:4px}@keyframes scanLine{0%,to{top:10px;opacity:.5}50%{top:calc(100% - 12px);opacity:1}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translate(-50%,-20px)}to{opacity:1;transform:translate(-50%)}}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.7}}
