*{margin:0;padding:0;box-sizing:border-box}:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg-primary: #0d1b0f;--bg-secondary: #1a2e1d;--bg-tertiary: #264229;--text-primary: #e8f4ea;--text-secondary: #b8d4bb;--text-muted: #7a9b7d;--border-color: #2d4a31;--accent-primary: #2d5f3a;--accent-hover: #1f4428;--success: #4caf50;--success-hover: #45a049;--danger: #f44336;--danger-hover: #da190b;--warning: #ff9800;--budgens-green: #00643c;--budgens-green-dark: #004428;--budgens-green-light: #007f4a}body{margin:0;min-width:320px;min-height:100vh;background:var(--bg-primary);color:var(--text-primary)}#root{width:100%}h1,h2,h3,h4,h5,h6{font-weight:600;color:var(--text-primary)}button{font-family:inherit}a{color:var(--accent-primary);text-decoration:none}a:hover{text-decoration:underline}.app{min-height:100vh;padding:.75rem .75rem 2rem}.app-header{text-align:center;margin-bottom:1rem;padding:1.25rem;background:linear-gradient(135deg,var(--budgens-green) 0%,var(--budgens-green-dark) 100%);border-radius:12px;color:#fff;box-shadow:0 4px 12px #00643c66}.app-header h1{margin:0 0 .5rem;font-size:1.5rem}.subtitle{margin:0;opacity:.95;font-size:.9rem}.app-main{max-width:100%;margin:0 auto}.scanner-section{background:var(--bg-secondary);border-radius:12px;padding:1rem;margin-bottom:1rem;box-shadow:0 2px 8px #0000004d;border:1px solid var(--border-color)}.barcode-scanner{margin-bottom:1.25rem}.scanner-controls{text-align:center;margin-bottom:1rem}.scanner-viewport{position:relative;width:100%;height:300px;margin:0 auto;border:2px solid var(--budgens-green);border-radius:8px;overflow:hidden;background:#000;transition:border-color .3s,box-shadow .3s}.scanner-viewport:before{content:"";position:absolute;top:50%;left:10%;right:10%;height:2px;background:linear-gradient(90deg,transparent 0%,#ff0000 20%,#ff0000 80%,transparent 100%);box-shadow:0 0 10px #f00c,0 0 20px #f006;transform:translateY(-50%);z-index:10;pointer-events:none;animation:laserScan 2s ease-in-out infinite}@keyframes laserScan{0%,to{opacity:.6}50%{opacity:1}}.scanner-viewport.scan-success{border-color:var(--success);box-shadow:0 0 20px #2ed57380;animation:scanPulse .5s ease-out}.scanner-viewport.scan-duplicate{border-color:var(--danger);box-shadow:0 0 20px #eb4d4b80;animation:scanPulse .5s ease-out}@keyframes scanPulse{0%{transform:scale(1)}50%{transform:scale(1.02)}to{transform:scale(1)}}.scanner-viewport canvas{width:100%;height:100%;object-fit:cover}.manual-entry{text-align:center;padding:1rem;background:var(--bg-tertiary);border-radius:8px;border:1px solid var(--border-color)}.manual-entry p{margin:0 0 .75rem;color:var(--text-secondary);font-size:.9rem}.input-group{display:flex;flex-direction:column;gap:.75rem;width:100%}.input-field{width:100%;padding:.875rem;border:2px solid var(--border-color);border-radius:8px;font-size:1rem;transition:border-color .2s;background:var(--bg-primary);color:var(--text-primary)}.input-field:focus{outline:none;border-color:var(--budgens-green)}.btn{padding:.875rem 1.25rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;text-transform:uppercase;letter-spacing:.5px;width:100%;touch-action:manipulation}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--budgens-green);color:#fff}.btn-primary:hover:not(:disabled){background:var(--budgens-green-dark)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:2px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--border-color)}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:var(--success-hover)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:var(--danger-hover)}.btn-sm{padding:.625rem 1rem;font-size:.875rem;width:auto}.btn-outline{background:transparent;border:2px solid var(--budgens-green);color:var(--budgens-green-light)}.btn-outline:hover{background:var(--budgens-green);color:#fff}.loading{text-align:center;padding:1.5rem;font-size:1rem;color:var(--budgens-green-light)}.export-section{text-align:center;margin-bottom:1rem}.modal-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #00000080}.modal-content h2{margin-top:0;color:var(--text-primary);font-size:1.25rem}.product-info{margin:1.25rem 0}.product-info p{margin:.5rem 0;color:var(--text-secondary)}.product-info strong{color:var(--text-primary)}.manual-entry-section{margin:1.25rem 0}.warning{color:var(--warning);font-weight:600;margin-bottom:1rem;font-size:.95rem}.success{color:var(--success);font-weight:600;margin-bottom:1rem;font-size:.95rem}.product-found{padding:1rem;background:var(--bg-tertiary);border-radius:8px;border:1px solid var(--border-color)}.product-image{max-width:100%;height:auto;border-radius:8px;margin-top:1rem}.button-group{display:flex;flex-direction:column;gap:.75rem;margin-top:1.25rem}.button-group .btn{width:100%}.product-list{background:var(--bg-secondary);border-radius:12px;padding:1rem;box-shadow:0 2px 8px #0000004d;border:1px solid var(--border-color)}.section-header{display:flex;flex-direction:column;align-items:stretch;gap:.75rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:2px solid var(--border-color)}.section-header h2{margin:0;color:var(--text-primary);font-size:1.25rem}.empty-state{text-align:center;padding:2rem 1rem;color:var(--text-muted);font-size:1rem}.products-grid{display:flex;flex-direction:column;gap:.75rem}.product-card{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;padding:1rem;transition:transform .2s,box-shadow .2s}.product-card:active{transform:scale(.98)}.product-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:.75rem;gap:.75rem}.product-header h3{margin:0;color:var(--text-primary);font-size:1.05rem;flex:1;word-break:break-word}.btn-delete{background:var(--danger);color:#fff;border:none;border-radius:50%;width:36px;height:36px;min-width:36px;font-size:1.5rem;line-height:1;cursor:pointer;transition:background .2s;flex-shrink:0;display:flex;align-items:center;justify-content:center}.btn-delete:active{background:var(--danger-hover);transform:scale(.95)}.product-details p{margin:.4rem 0;color:var(--text-secondary);font-size:.9rem}.product-details strong{color:var(--text-primary)}.product-date{color:var(--text-muted);font-size:.85rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-color)}@media(min-width:768px){.app{padding:1.5rem}.app-header h1{font-size:2rem}.subtitle{font-size:1rem}.app-main{max-width:1200px}.scanner-section{padding:2rem}.scanner-viewport{height:400px;max-width:640px}.input-group{flex-direction:row;max-width:500px;margin:0 auto}.btn{width:auto}.button-group{flex-direction:row}.button-group .btn{flex:1}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.section-header{flex-direction:row;align-items:center;justify-content:space-between}.product-list{padding:2rem}}
