:root{--color-primary:#2563eb;--color-secondary:#64748b;--color-background:#fff;--color-surface:#f8fafc;--color-text:#1f2937;--color-textSecondary:#6b7280;--color-border:#e5e7eb;--color-success:#10b981;--color-warning:#f59e0b;--color-error:#ef4444;--color-info:#3b82f6}.theme-dark{--color-primary:#3b82f6;--color-secondary:#94a3b8;--color-background:#0f172a;--color-surface:#1e293b;--color-text:#f1f5f9;--color-textSecondary:#cbd5e1;--color-border:#334155;--color-success:#22c55e;--color-warning:#fbbf24;--color-error:#f87171;--color-info:#60a5fa}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;background-color:var(--color-background);color:#1f2937;color:var(--color-text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0;transition:background-color .3s ease,color .3s ease}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}a{color:#2563eb;color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}button{background:none;border:none;cursor:pointer;font-family:inherit;margin:0;padding:0}button:focus{outline:2px solid #2563eb;outline:2px solid var(--color-primary);outline-offset:2px}input,select,textarea{background-color:#f8fafc;background-color:var(--color-surface);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:4px;color:#1f2937;color:var(--color-text);font-family:inherit;padding:8px 12px;transition:border-color .2s ease}input:focus,select:focus,textarea:focus{border-color:#2563eb;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a;outline:none}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#f8fafc;background:var(--color-surface)}::-webkit-scrollbar-thumb{background:#e5e7eb;background:var(--color-border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#6b7280;background:var(--color-textSecondary)}::selection{background-color:#2563eb;background-color:var(--color-primary);color:#fff}::placeholder{color:#6b7280;color:var(--color-textSecondary);opacity:1}:disabled{cursor:not-allowed;opacity:.6}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-in{animation:fadeIn .3s ease-in-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.slide-in{animation:slideIn .3s ease-out}.container{max-width:1200px;padding:0 16px}@media (max-width:640px){.container{padding:0 12px}}.text-primary{color:#2563eb;color:var(--color-primary)}.text-secondary{color:#6b7280;color:var(--color-textSecondary)}.text-success{color:#10b981;color:var(--color-success)}.text-warning{color:#f59e0b;color:var(--color-warning)}.text-error{color:#ef4444;color:var(--color-error)}.text-left{text-align:left}.text-right{text-align:right}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mt-5{margin-top:20px}.mb-1{margin-bottom:4px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.mb-5{margin-bottom:20px}.p-1{padding:4px}.p-2{padding:8px}.p-3{padding:12px}.p-4{padding:16px}.p-5{padding:20px}.visible{display:block}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (prefers-contrast:high){:root{--color-border:#000;--color-textSecondary:#000}.theme-dark{--color-border:#fff;--color-textSecondary:#fff}}:root{--off-white:#faf9f6;--taupe-gray:#4a4a4a;--sage-green:#8a9a5b;--sage-green-dark:#7a8a4b;--sage-green-light:#e8f5e8;--warm-orange:#e89f65;--brick-red:#cb4154;--subtle-gray:#d3d3d3}*{box-sizing:border-box;margin:0;padding:0}body{background-color:#faf9f6;background-color:var(--off-white);color:#2c2c2c;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6}.container{margin:0 auto;max-width:800px;padding:20px}.card{background:#fff;border:1px solid #0000000d;border-radius:12px;box-shadow:0 4px 16px #00000014;margin-bottom:20px;padding:20px}.btn{background:#8a9a5b;background:var(--sage-green);border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-block;font-size:16px;padding:12px 24px;text-decoration:none;transition:background-color .3s}.btn:hover{background:#7a8a4b;background:var(--sage-green-dark)}.btn-secondary{background:#e89f65;background:var(--warm-orange)}.btn-secondary:hover{background:#d89f55}.btn-danger{background:#cb4154;background:var(--brick-red)}.btn-danger:hover{background:#b03144}.form-group{margin-bottom:15px}.form-group label{color:#2c2c2c;display:block;font-weight:600;margin-bottom:5px}.form-group input,.form-group select,.form-group textarea{border:2px solid #d3d3d3;border:2px solid var(--subtle-gray);border-radius:8px;font-size:16px;padding:12px;transition:border-color .3s;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#8a9a5b;border-color:var(--sage-green);outline:none}.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:#cb4154;border-color:var(--brick-red)}.error-message{color:#cb4154;color:var(--brick-red);display:block;font-size:.85rem;margin-top:5px}.tags-container{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));margin-top:10px}.tag-checkbox{align-items:center;background:#f5f5f5;border-radius:6px;cursor:pointer;display:flex;font-size:14px;gap:5px;padding:8px 12px;transition:background-color .3s}.tag-checkbox:hover{background:#e8f5e8;background:var(--sage-green-light)}.tag-checkbox input[type=checkbox]{margin:0}.selected-tags{gap:5px;margin-top:10px}.selected-tag{background:#8a9a5b;background:var(--sage-green);border-radius:4px;color:#fff;font-size:12px}.items-list{margin-top:20px}.item{background:#fff;border-left:4px solid #8a9a5b;border-left:4px solid var(--sage-green);border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:16px;padding:20px;position:relative;transition:all .2s ease}.item:hover{box-shadow:0 4px 16px #0000001f;transform:translateY(-2px)}.item.expiring-soon{background:linear-gradient(135deg,#fff,#fff8f0);border-left-color:#e89f65;border-left-color:var(--warm-orange)}.item.expired{background:linear-gradient(135deg,#fff,#fff5f5);border-left-color:#cb4154;border-left-color:var(--brick-red)}.item.selected{background:#e8f5e8;background:var(--sage-green-light);border:2px solid #8a9a5b;border:2px solid var(--sage-green);box-shadow:0 4px 16px #8a9a5b33}.item-header{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;margin-bottom:12px;padding-bottom:8px}.item-name{color:#1a1a1a;flex:1 1;font-size:1.2rem;font-weight:700;line-height:1.3;margin-right:16px}.item-category{background:#e8f5e8;background:var(--sage-green-light);border-radius:20px;color:#8a9a5b;color:var(--sage-green);font-size:.85rem;font-weight:600;letter-spacing:.5px;padding:6px 12px;text-transform:uppercase;white-space:nowrap}.item-details{color:#666;font-size:.95rem;font-weight:400;line-height:1.5;margin-bottom:8px}.item-details .primary-info{color:#333;font-size:1rem;font-weight:500}.item-details .secondary-info{color:#666;font-size:.9rem;font-weight:400}.item-details .tertiary-info{color:#999;font-size:.85rem;font-weight:400}.expiry-warning{background:#ffc1071a;color:#e89f65;color:var(--warm-orange)}.expiry-danger,.expiry-warning{border-radius:6px;display:inline-block;font-size:.95rem;font-weight:600;padding:4px 8px}.expiry-danger{background:#dc35451a;color:#cb4154;color:var(--brick-red)}.quantity-editable{background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;color:#495057;font-weight:600;padding:4px 8px;transition:all .2s ease}.quantity-editable:hover{background:#e9ecef;border-color:#8a9a5b;color:#8a9a5b}.item-notes{background:#f8f9fa;border-left:3px solid #dee2e6;border-radius:6px;color:#6c757d;font-size:.9rem;font-style:italic;margin-top:8px;padding:8px 12px}.selected-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.selected-tag{background:#e3f2fd;border:1px solid #bbdefb;border-radius:12px;color:#1976d2;font-size:.8rem;font-weight:500;padding:4px 8px}.item-actions{border-top:1px solid #f0f0f0;display:flex;gap:8px;justify-content:flex-end;margin-top:12px;padding-top:8px}.item-actions .btn{border-radius:6px;font-size:.85rem;font-weight:500;padding:6px 12px;transition:all .2s ease}.item-actions .btn:hover{box-shadow:0 2px 8px #00000026;transform:translateY(-1px)}.stats{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:30px}.stat-card{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;padding:20px;text-align:center}.stat-number{color:#8a9a5b;color:var(--sage-green);font-size:2rem;font-weight:700}.stat-label{color:#2c2c2c;font-size:.9rem;font-weight:500;margin-top:5px}.core-stats{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(3,1fr);margin-bottom:20px}.core-stat{color:inherit;cursor:pointer;text-decoration:none;transition:all .3s ease}.core-stat:hover{box-shadow:0 4px 20px #00000026;transform:translateY(-2px)}.core-stat:active{transform:translateY(0)}.category-stats{margin-bottom:20px}.category-scroll{-ms-overflow-style:none;display:flex;gap:12px;overflow-x:auto;padding:5px 0;scrollbar-width:none}.category-scroll::-webkit-scrollbar{display:none}.category-card{background:#fff;border:none;border-radius:12px;box-shadow:0 2px 8px #00000014;color:inherit;cursor:pointer;flex:0 0 auto;min-width:80px;padding:16px 12px;text-align:center;text-decoration:none;transition:all .3s ease}.category-card:hover{background:#e8f5e8;background:var(--sage-green-light);box-shadow:0 4px 16px #0000001f;transform:translateY(-2px)}.category-card.active{background:#8a9a5b;background:var(--sage-green);box-shadow:0 4px 16px #8a9a5b4d;color:#fff;transform:translateY(-2px)}.category-card.active .category-count,.category-card.active .category-icon,.category-card.active .category-name{color:#fff}.category-card:active{transform:translateY(0)}.category-icon{color:#8a9a5b;color:var(--sage-green);display:flex;justify-content:center;margin-bottom:8px}.category-name{color:#2c2c2c;font-size:.8rem;font-weight:500;margin-bottom:4px}.category-count{color:#8a9a5b;color:var(--sage-green);font-size:1.2rem;font-weight:700}.quick-actions{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(2,1fr);margin-bottom:30px}.quick-action{align-items:center;background:#fff;border:1px solid #0000000d;border-radius:12px;box-shadow:0 2px 10px #0000001a;color:inherit;display:flex;flex-direction:column;gap:8px;padding:20px;text-align:center;text-decoration:none;transition:all .3s ease}.quick-action:hover{background:#e8f5e8;background:var(--sage-green-light);box-shadow:0 4px 20px #00000026;transform:translateY(-2px)}.quick-action:active{transform:translateY(0)}.quick-action span{color:#2c2c2c;font-size:.9rem;font-weight:500}.quick-action svg{color:#8a9a5b;color:var(--sage-green)}@media (max-width:768px){.stats{gap:10px;grid-template-columns:repeat(3,1fr);margin-bottom:20px}.stat-card{padding:15px 10px}.stat-number{font-size:1.5rem}.stat-label{font-size:.8rem}.core-stats{gap:10px;margin-bottom:15px}.core-stat{padding:15px 10px}.core-stat .stat-number{font-size:1.8rem}.core-stat .stat-label{font-size:.85rem}.category-scroll{gap:8px}.category-card{min-width:70px;padding:12px 8px}.category-icon svg{height:18px;width:18px}.category-name{font-size:.75rem}.category-count{font-size:1.1rem}.quick-actions{gap:12px;margin-bottom:25px}.quick-action{padding:16px 12px}.quick-action span{font-size:.85rem}.quick-action svg{height:20px;width:20px}}@media (max-width:480px){.stats{grid-template-columns:repeat(2,1fr)}.stat-card{padding:12px 8px}.stat-number{font-size:1.3rem}.stat-label{font-size:.75rem}.core-stats{gap:8px}.core-stat{padding:12px 8px}.core-stat .stat-number{font-size:1.6rem}.core-stat .stat-label{font-size:.8rem}.category-card{min-width:60px;padding:10px 6px}.category-icon svg{height:16px;width:16px}.category-name{font-size:.7rem}.category-count{font-size:1rem}.quick-actions{gap:10px}.quick-action{padding:14px 10px}.quick-action span{font-size:.8rem}.quick-action svg{height:18px;width:18px}}@media (max-width:768px){.stats:has(.stat-card:nth-child(5)){gap:8px;grid-template-columns:repeat(5,1fr)}.stats:has(.stat-card:nth-child(5)) .stat-card{padding:10px 6px}.stats:has(.stat-card:nth-child(5)) .stat-number{font-size:1.2rem}.stats:has(.stat-card:nth-child(5)) .stat-label{font-size:.7rem}}@media (max-width:480px){.stats:has(.stat-card:nth-child(5)){grid-template-columns:repeat(3,1fr)}}.tabs{border-bottom:2px solid #d3d3d3;border-bottom:2px solid var(--subtle-gray);display:flex;margin-bottom:20px}.tab{border-bottom:2px solid #0000;cursor:pointer;padding:12px 20px;transition:all .3s}.tab.active{border-bottom-color:#8a9a5b;border-bottom-color:var(--sage-green);color:#8a9a5b;color:var(--sage-green);font-weight:500}.tab:hover{background:#f5f5f5}.tab-content{display:none}.tab-content.active{display:block}@media (max-width:768px){.container{padding:15px}.tags-container{grid-template-columns:repeat(auto-fit,minmax(80px,1fr))}.tabs{flex-direction:column}.tab{text-align:center}.btn{font-size:16px;min-height:44px;min-width:44px;padding:12px 20px}.card{margin-bottom:15px;padding:15px}}.navbar{background:#fff;box-shadow:0 2px 10px #0000001a;margin-bottom:20px;padding:15px 20px}.navbar-header{margin-bottom:15px;text-align:center}.navbar-title{color:#8a9a5b;color:var(--sage-green);font-size:1.8rem;font-weight:700;margin:0}.navbar-subtitle{color:#666;font-size:.9rem;font-weight:400;margin:5px 0 0}.navbar-tabs{display:flex;gap:10px;justify-content:space-around}.navbar-tab{align-items:center;background:#0000;border:none;border-radius:8px;color:#666;cursor:pointer;display:flex;flex:1 1;flex-direction:column;font-size:.8rem;font-weight:500;gap:4px;justify-content:center;min-height:60px;padding:12px 8px;text-decoration:none;transition:all .3s ease}.navbar-tab:hover{background:#e8f5e8;background:var(--sage-green-light);box-shadow:0 2px 8px #0000001a;color:#8a9a5b;color:var(--sage-green);transform:translateY(-1px)}.navbar-tab.active{background:#8a9a5b;background:var(--sage-green);box-shadow:0 4px 12px #8a9a5b4d;color:#fff;transform:translateY(-2px)}.navbar-tab:active{transform:translateY(0);transition:transform .1s ease}.navbar-tab span{font-size:.75rem;font-weight:500;margin-top:2px}@media (max-width:768px){.navbar-tabs{gap:8px}.navbar-tab{min-width:60px;padding:8px 12px}.navbar-tab span{font-size:12px}}body[style*="font-size: 18px"] .navbar-tab{font-size:18px!important;padding:12px 16px!important}body[style*="font-size: 18px"] .navbar-tab span{font-size:18px!important}body[style*="font-size: 18px"] .navbar-title{font-size:24px!important}body[style*="font-size: 18px"] .navbar-subtitle{font-size:18px!important}.fab{align-items:center;background:#8a9a5b;background:var(--sage-green);border:none;border-radius:50%;bottom:20px;box-shadow:0 4px 12px #00000026;color:#fff;cursor:pointer;display:flex;height:56px;justify-content:center;position:fixed;right:20px;transition:all .3s;width:56px;z-index:1000}.fab:hover{background:#7a8a4b;background:var(--sage-green-dark);box-shadow:0 6px 16px #0003;transform:scale(1.05)}.fab:active{transform:scale(.95)}.hidden{display:none}.text-center{text-align:center}.mt-10{margin-top:10px}.mb-10{margin-bottom:10px}.mt-20{margin-top:20px}.mb-20{margin-bottom:20px}.barcode-scanner{background:#000000e6;bottom:0;display:flex;flex-direction:column;left:0;position:fixed;right:0;top:0;z-index:1000}.scanner-header{align-items:center;background:#fff;color:#333;display:flex;justify-content:space-between;padding:20px}.scanner-header h3{font-size:1.2rem;font-weight:600;margin:0}.close-btn{background:none;border:none;border-radius:50%;cursor:pointer;padding:8px;transition:background-color .3s}.close-btn:hover{background:#f5f5f5}.scanner-content{align-items:center;display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:20px}.video-container{background:#000;border-radius:12px;height:300px;max-width:400px;overflow:hidden;position:relative;width:100%}.scan-overlay{align-items:center;bottom:0;display:flex;flex-direction:column;justify-content:center;left:0;pointer-events:none;position:absolute;right:0;top:0}.scan-frame{border:2px solid #8a9a5b;border:2px solid var(--sage-green);border-radius:8px;height:100px;position:relative;width:200px}.scan-frame:after,.scan-frame:before{border:3px solid #8a9a5b;border:3px solid var(--sage-green);content:"";height:20px;position:absolute;width:20px}.scan-frame:before{border-bottom:none;border-right:none;left:-3px;top:-3px}.scan-frame:after{border-left:none;border-top:none;bottom:-3px;right:-3px}.scan-tip{background:#000000b3;border-radius:20px;color:#fff;font-size:.9rem;margin-top:20px;padding:8px 16px;text-align:center}.scanner-controls{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:20px}.scanner-error{color:#fff;padding:20px;text-align:center}.scanner-error p{font-size:1rem;margin-bottom:15px}.scan-result{background:#fff;padding:20px;text-align:center}.scan-result h4{color:#333;margin:0 0 10px}.barcode-result{background:#f8f9fa;border-radius:8px;color:#8a9a5b;color:var(--sage-green);font-family:monospace;font-size:1.1rem;font-weight:600;margin:10px 0;padding:12px}@media (max-width:768px){.scanner-header{padding:15px}.scanner-header h3{font-size:1.1rem}.video-container{height:250px}.scan-frame{height:80px;width:180px}.scanner-controls{align-items:center;flex-direction:column}.scanner-controls .btn{max-width:300px;width:100%}}@media (max-width:480px){.video-container{height:200px}.scan-frame{height:70px;width:150px}.scan-tip{font-size:.8rem}}.animate-spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.viewport{height:300px;overflow:hidden;position:relative;width:100%}.viewport video{height:100%;object-fit:cover;width:100%}.viewport canvas{height:100%;left:0;position:absolute;top:0;width:100%}.scanner-loading{align-items:center;background:#f5f5f5;border-radius:8px;display:flex;flex-direction:column;gap:16px;height:300px;justify-content:center}.navbar-settings-btn,.scanner-loading p{color:#666;font-size:14px}.navbar-settings-btn{align-items:center;background:none;border:none;border-radius:8px;cursor:pointer;display:flex;font-weight:500;gap:8px;padding:12px 16px;transition:all .2s}.navbar-settings-btn:hover{background:#8a9a5b1a;color:#7a8a4b;color:var(--sage-green-dark)}.navbar-settings-btn:active{transform:scale(.95)}.navbar-settings-btn span{font-size:14px;font-weight:500;margin-left:8px}@media (max-width:768px){.navbar-settings-btn{padding:8px 12px}.navbar-settings-btn span{font-size:12px}}body[style*="font-size: 18px"] .navbar-settings-btn{font-size:18px!important;padding:12px 16px!important}body[style*="font-size: 18px"] .navbar-settings-btn span{font-size:18px!important}.mobile-bottom-nav{align-items:center;background:#fff;border-top:1px solid #e5e7eb;bottom:0;box-shadow:0 -2px 10px #0000001a;display:flex;justify-content:space-around;left:0;padding:8px 0;position:fixed;right:0;z-index:1000}.mobile-nav-tab{align-items:center;background:none;border:none;border-radius:8px;color:#6b7280;cursor:pointer;display:flex;flex-direction:column;font-size:.75rem;font-weight:500;gap:4px;min-width:60px;padding:8px 12px;text-decoration:none;transition:all .2s ease}.mobile-nav-tab:hover{background:#f9fafb;color:#8a9a5b}.mobile-nav-tab.active{background:#f0f4f0;color:#8a9a5b}.mobile-nav-tab svg{height:20px;width:20px}@media (max-width:768px){.App{padding-bottom:80px}.container{margin-bottom:20px}}.status-indicator,.status-indicators,.statusIndicator,.statusIndicators,[class*=status-indicator],[class*=statusIndicator]{display:none!important}button:contains("信息"),button:contains("成功"),button:contains("警告"),button:contains("过期提醒"),button:contains("错误"),div:contains("信息"),div:contains("成功"),div:contains("警告"),div:contains("过期提醒"),div:contains("错误"){display:none!important}[style*="position: fixed"][style*=top][style*=right],[style*="position:fixed"][style*=top][style*=right]{display:none!important}
/*# sourceMappingURL=main.899ecc9c.css.map*/