*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #1a6b3c;--primary-light: #f0f7f3;--primary-mid: #6dab8b;--primary-dark: #145530;--warning: #f0a500;--warning-light: #fff3cd;--danger: #e53935;--text-primary: #1a1a1a;--text-secondary: #555;--text-muted: #888;--bg: #f0f7f3;--card-bg: #fff;--border: #e0ece7;--radius: 16px;--radius-sm: 8px;--shadow: 0 2px 12px rgba(26,107,60,.08);--shadow-sm: 0 1px 6px rgba(26,107,60,.06);font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Noto Sans TC,Microsoft JhengHei,sans-serif;font-size:16px;line-height:1.5;color:var(--text-primary);background:var(--bg)}html,body,#root{min-height:100vh}#root{max-width:480px;margin:0 auto;background:var(--bg);min-height:100vh}button{cursor:pointer;border:none;font-family:inherit;font-size:1rem;transition:opacity .15s,background .15s}button:disabled{opacity:.55;cursor:not-allowed}input{font-family:inherit;font-size:1rem;outline:none}a{color:var(--primary);text-decoration:none}.page{min-height:100vh;background:var(--bg);padding-bottom:40px}.nav-bar{position:sticky;top:0;z-index:100;background:var(--primary);color:#fff;padding:14px 16px;display:flex;align-items:center;gap:12px;box-shadow:0 2px 8px #00000026}.nav-bar__title{font-size:1.1rem;font-weight:700;flex:1}.nav-bar__back{background:transparent;color:#fff;font-size:1.2rem;padding:4px 8px}.state-view{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 32px;gap:16px}.state-text{font-size:.95rem;color:var(--text-muted)}.state-error{font-size:.9rem;color:var(--danger);text-align:center;line-height:1.6}.retry-btn{background:var(--primary);color:#fff;border-radius:var(--radius-sm);padding:10px 28px;font-size:.9rem}.card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px 16px}.badge{display:inline-block;border-radius:6px;padding:2px 10px;font-size:.8rem;font-weight:600}.badge--pending{background:#fff3cd;color:#856404}.badge--active{background:#d4edda;color:#155724}.badge--done{background:#d1ecf1;color:#0c5460}.badge--cancelled{background:#f8d7da;color:#721c24}.btn-primary{width:100%;padding:16px;border-radius:var(--radius);background:var(--primary);color:#fff;font-size:1rem;font-weight:700}.btn-warning{width:100%;padding:16px;border-radius:var(--radius);background:var(--warning);color:#fff;font-size:1rem;font-weight:700}.btn-outline{width:100%;padding:14px;border-radius:var(--radius);background:transparent;border:2px solid var(--primary);color:var(--primary);font-size:1rem;font-weight:600}.search-bar{display:flex;align-items:center;background:#fff;border-radius:12px;padding:10px 14px;gap:8px;border:1px solid var(--border)}.search-bar__icon{color:var(--text-muted);font-size:1rem}.search-bar__input{flex:1;border:none;background:transparent;color:var(--text-primary);font-size:.95rem}.search-bar__input::placeholder{color:var(--text-muted)}.filter-tabs{display:flex;gap:8px;padding:0 16px}.filter-tab{flex:1;padding:8px 4px;border-radius:10px;background:#fff;color:var(--text-secondary);font-size:.88rem;font-weight:500;border:1px solid var(--border)}.filter-tab--active{background:var(--primary);color:#fff;border-color:var(--primary)}.toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000bf;color:#fff;padding:14px 24px;border-radius:12px;display:flex;align-items:center;gap:8px;max-width:72vw;z-index:9999;font-size:.95rem;animation:toast-in .2s ease;pointer-events:none}.toast--success{background:#1a6b3ce0}.toast--error{background:#c83232e0}.toast__icon{font-size:1.1rem;font-weight:700}.toast__message{text-align:center;line-height:1.4}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,-45%)}to{opacity:1;transform:translate(-50%,-50%)}}.login-page{min-height:100vh;background:linear-gradient(160deg,#1a6b3c,#145530 60%,#0d3d23);display:flex;align-items:center;justify-content:center;padding:24px}.login-card{background:#fff;border-radius:24px;padding:40px 28px 32px;width:100%;max-width:360px;box-shadow:0 8px 40px #00000040}.login-logo{font-size:3rem;text-align:center;margin-bottom:12px}.login-title{font-size:1.4rem;font-weight:700;text-align:center;color:#1a1a1a;margin-bottom:4px}.login-subtitle{font-size:.8rem;text-align:center;color:#aaa;letter-spacing:2px;margin-bottom:32px}.login-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:.88rem;color:#555;font-weight:500}.form-input{width:100%;padding:12px 14px;border:1.5px solid #ddd;border-radius:12px;font-size:1rem;color:#1a1a1a;transition:border-color .15s}.form-input:focus{border-color:#1a6b3c}.form-error{color:#e53935;font-size:.88rem;padding:8px 12px;background:#fdecea;border-radius:8px}.login-btn{width:100%;padding:14px;background:#1a6b3c;color:#fff;border-radius:14px;font-size:1.05rem;font-weight:700;margin-top:4px;transition:background .15s}.login-btn:hover:not(:disabled){background:#145530}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px;animation:overlay-in .15s ease}.modal-box{background:#fff;border-radius:16px;width:100%;max-width:300px;overflow:hidden;animation:box-in .15s ease}.modal-title{padding:20px 20px 8px;font-size:1.05rem;font-weight:700;text-align:center;color:#1a1a1a}.modal-content{padding:8px 20px 20px;font-size:.9rem;color:#555;text-align:center;line-height:1.6}.modal-actions{display:flex;border-top:1px solid #eee}.modal-btn{flex:1;padding:14px;font-size:1rem;background:transparent;border:none}.modal-btn--cancel{color:#888;border-right:1px solid #eee}.modal-btn--confirm{color:#1a6b3c;font-weight:700}.modal-btn:active{background:#f5f5f5}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}@keyframes box-in{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.home-page{min-height:100vh;background:var(--bg);padding:0 0 40px}.home-page:before{content:"";display:block;height:180px;background:linear-gradient(160deg,#1a6b3c,#27a05a);border-radius:0 0 32px 32px}.user-card{margin:-100px 20px 0;background:#fff;border-radius:20px;padding:20px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 4px 20px #1a6b3c26}.user-info .user-name{font-size:1.15rem;font-weight:700;color:#1a1a1a}.user-info .user-code{font-size:.85rem;color:var(--text-muted);margin-top:2px}.logout-btn{background:#fff0f0;color:#e53935;border-radius:10px;padding:8px 14px;font-size:.88rem;font-weight:600}.module-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:24px 20px 0}.module-btn{background:#fff;border-radius:20px;padding:28px 16px;display:flex;flex-direction:column;align-items:center;gap:8px;box-shadow:var(--shadow);transition:transform .1s,box-shadow .1s}.module-btn:active{transform:scale(.97);box-shadow:0 1px 6px #1a6b3c1a}.module-icon{font-size:2.2rem;margin-bottom:4px}.module-label{font-size:1.1rem;font-weight:700;color:#1a1a1a}.module-sub{font-size:.78rem;color:var(--text-muted)}.nav-switch-btn{background:#fff3;color:#fff;border-radius:8px;padding:6px 12px;font-size:.82rem;font-weight:600}.clear-btn{background:transparent;color:var(--text-muted);padding:0 4px;font-size:1rem}.task-list{padding:12px 16px;display:flex;flex-direction:column;gap:12px}.task-card{background:var(--card-bg);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm);cursor:pointer;transition:box-shadow .15s}.task-card:active{box-shadow:none;background:#f7fdf8}.task-card__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.task-id{font-size:1rem;font-weight:700;color:#1a1a1a;font-family:monospace}.task-meta{display:flex;gap:16px;font-size:.85rem;color:var(--text-muted)}.task-remark{margin-top:6px;font-size:.82rem;color:var(--text-secondary);padding:4px 8px;background:var(--primary-light);border-radius:6px}.order-card{margin:16px 16px 0;background:var(--card-bg);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}.order-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--primary-light)}.order-row:last-child{border-bottom:none}.order-label{font-size:.85rem;color:var(--text-muted);min-width:80px}.order-value{font-size:.95rem;color:var(--text-primary);text-align:right;flex:1}.order-id{font-weight:700;font-family:monospace}.order-remark{color:var(--text-secondary);font-style:italic}.section-title{margin:16px 16px 8px;font-size:.95rem;font-weight:700;color:var(--primary)}.lines-list{padding:0 16px;display:flex;flex-direction:column;gap:12px}.line-card{background:var(--card-bg);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow-sm)}.line-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:8px}.line-name{font-size:.98rem;font-weight:700;color:#1a1a1a}.line-code{font-size:.8rem;color:var(--text-muted)}.line-row{display:flex;align-items:center;gap:8px;margin-bottom:10px}.line-label{font-size:.82rem;color:var(--text-muted)}.line-expected{font-weight:700;color:var(--primary);font-size:1rem;margin-right:12px}.line-location{font-weight:600;color:var(--primary);font-family:monospace;font-size:.9rem}.form-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}.form-field-label{font-size:.82rem;color:var(--text-secondary);min-width:72px}.form-field-input{flex:1;padding:8px 10px;border:1.5px solid var(--border);border-radius:8px;font-size:.92rem;color:var(--text-primary)}.form-field-input:focus{border-color:var(--primary)}.form-field-input:disabled{background:#f5f5f5;color:#aaa}.photo-section{margin:8px 16px 0}.photo-placeholder-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;width:100%;min-height:120px;background:var(--card-bg, #fff);border:2px dashed var(--border, #d9d9d9);border-radius:var(--radius, 12px);color:var(--text-muted, #aaa);font-size:.9rem;cursor:pointer;transition:border-color .2s}.photo-placeholder-btn:active{border-color:var(--primary, #1677ff);color:var(--primary, #1677ff)}.photo-placeholder-icon{font-size:2rem}.photo-preview-wrap{position:relative;width:100%;border-radius:var(--radius, 12px);overflow:hidden}.photo-preview-img{display:block;width:100%;height:200px;object-fit:cover;border-radius:var(--radius, 12px)}.photo-remove-btn{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;background:#0000008c;color:#fff;border:none;font-size:1rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}.photo-uploading{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000073;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.95rem;border-radius:var(--radius, 12px)}.action-bar{padding:20px 16px 0}.shelving-card{cursor:default}.shelving-actions{display:flex;gap:8px;margin-top:12px}.shelving-action-btn{flex:1;padding:8px 0;border-radius:10px;font-size:.88rem;font-weight:600}.shelving-action-btn--detail{background:var(--primary-light);color:var(--primary);border:1px solid var(--primary)}.shelving-action-btn--start{background:var(--warning);color:#fff}.shelving-action-btn--complete{background:var(--primary);color:#fff}.picking-card{cursor:pointer}.picking-card:active{opacity:.85}.task-remark{font-size:.82rem;color:var(--text-muted);margin-top:6px;padding-top:6px;border-top:1px solid var(--border)}.nav-bar--outbound{background:linear-gradient(135deg,#1a5fa8,#2480e4)}.line-batch--unassigned{color:var(--text-muted);font-style:italic}.badge--done{background:#e6f4ea;color:#1a7a3c;border:1px solid #b2deba}.badge--cancelled{background:#fce8e8;color:#c0392b;border:1px solid #f4b8b8}.readonly-notice{text-align:center;padding:20px;color:var(--text-muted);font-size:.9rem}.nav-bar--stocktaking{background:linear-gradient(135deg,#5b6abf,#7c3aed)}.nav-bar__action{background:#fff3;color:#fff;border-radius:8px;padding:6px 12px;font-size:.95rem;font-weight:600}.badge--complete{background:#dcfce7;color:#166534;border-radius:12px;padding:2px 10px;font-size:.8rem;font-weight:600}.stocktaking-card--complete{border-left:4px solid #22c55e}.stocktaking-progress-bar{height:6px;background:var(--border);border-radius:3px;overflow:hidden;margin:8px 0 4px}.stocktaking-progress-bar__fill{height:100%;background:#7c3aed;border-radius:3px;transition:width .3s ease}.stocktaking-progress-bar__fill--complete{background:#22c55e}.detail-header{margin:12px 16px 0;background:var(--card-bg);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow-sm)}.detail-header__no{font-size:1.05rem;font-weight:700;color:#1a1a1a;font-family:monospace;margin-bottom:4px}.detail-header__progress{font-size:.95rem;font-weight:600;color:#7c3aed;margin-bottom:4px}.detail-header__date{font-size:.82rem;color:var(--text-muted)}.detail-header__remark{margin-top:6px;font-size:.82rem;color:var(--text-secondary);padding:4px 8px;background:#f5f0ff;border-radius:6px}.submitted-banner{margin:10px 16px 0;background:#dcfce7;border:1px solid #86efac;border-radius:var(--radius);padding:10px 16px;font-size:.9rem;color:#166534;font-weight:600}.filter-bar{padding:10px 16px 4px;display:flex;gap:8px}.filter-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;font-size:.85rem;font-weight:500;background:var(--card-bg);color:var(--text-secondary);border:1px solid var(--border);transition:all .15s}.filter-btn--active{background:#7c3aed;color:#fff;border-color:#7c3aed}.filter-btn__badge{display:inline-flex;align-items:center;justify-content:center;background:#ef4444;color:#fff;border-radius:10px;padding:0 6px;font-size:.78rem;font-weight:700;min-width:18px;height:18px;line-height:18px}.lines-list{padding:8px 16px 80px;display:flex;flex-direction:column;gap:10px}.line-item{background:var(--card-bg);border-radius:var(--radius);padding:12px 14px;box-shadow:var(--shadow-sm);position:relative;transition:border-color .15s;border-left:3px solid transparent}.line-item--checked{border-left-color:#22c55e;background:#f0fdf4}.line-item--error{border-left-color:#ef4444}.line-item__head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:6px;gap:8px}.line-item__product-name{font-size:.95rem;font-weight:600;color:#1a1a1a;flex:1}.line-item__code{font-size:.78rem;color:var(--text-muted);font-family:monospace;flex-shrink:0}.line-item__body{display:flex;flex-direction:column;gap:4px}.line-item__meta{display:flex;flex-wrap:wrap;gap:8px;font-size:.8rem;color:var(--text-muted)}.line-item__qty{display:flex;align-items:center;gap:10px;margin-top:6px;flex-wrap:wrap}.line-item__book-qty{font-size:.85rem;color:var(--text-secondary)}.line-item__actual-label{font-size:.85rem;color:var(--text-secondary);white-space:nowrap}.line-item__actual-input{width:80px;padding:5px 8px;border:1px solid var(--border);border-radius:8px;font-size:.95rem;text-align:right;background:var(--input-bg, #fff);color:var(--text-primary);transition:border-color .15s}.line-item__actual-input:focus{outline:none;border-color:#7c3aed;box-shadow:0 0 0 2px #7c3aed26}.line-item__actual-input:disabled{background:var(--disabled-bg, #f3f4f6);color:var(--text-muted);cursor:not-allowed}.line-item__actual-input.input--error{border-color:#ef4444}.save-status{font-size:.75rem;margin-top:4px;font-weight:500}.save-status--saving{color:#6b7280}.save-status--saved{color:#22c55e}.save-status--error{color:#ef4444}.line-item__checked-badge{position:absolute;top:10px;right:14px;font-size:1rem;color:#22c55e;font-weight:700}.submit-bar{position:fixed;bottom:0;left:0;right:0;padding:12px 16px;background:linear-gradient(to top,#fff 80%,#fff0);z-index:100}.submit-btn{width:100%;padding:14px;background:linear-gradient(135deg,#7c3aed,#5b6abf);color:#fff;border-radius:12px;font-size:1rem;font-weight:700;letter-spacing:.04em;transition:opacity .15s,transform .1s;box-shadow:0 4px 12px #7c3aed4d}.submit-btn:active{transform:scale(.98);opacity:.9}.submit-btn:disabled{background:var(--border);color:var(--text-muted);box-shadow:none;cursor:not-allowed}
