:root{--font-display:"Rubik",system-ui,sans-serif;--font-body:"IBM Plex Sans",system-ui,sans-serif;--font-mono:"JetBrains Mono",monospace;--font-table:"Rubik",system-ui,sans-serif;--weight-light:200;--weight-regular:300;--weight-medium:500;--weight-bold:700;--weight-heavy:800;--text-xs:0.75rem;--text-sm:0.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:2rem;--text-4xl:2.5rem;--space-xs:0.5rem;--space-sm:1rem;--space-md:1.5rem;--space-lg:2rem;--space-xl:3rem;--space-2xl:4rem;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-full:9999px;--transition-fast:0.15s ease;--transition-base:0.2s ease;--transition-slow:0.3s ease;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px #00000012;--shadow-lg:0 10px 15px #0000001a;--shadow-xl:0 20px 25px #00000026;--color-slate-blue:#5b7a8e;--color-sage-green:#8baa92;--color-deep-navy:#0d1b3e;--color-golden-yellow:#f4b942;--color-warm-gray:#f5f5f5;--color-success:#10b981;--color-error:#ef4444;--color-warning:#f59e0b;--color-custom-highlight:#f4b942;--color-standard-highlight:#10b981}:root,:root[data-theme=light]{--bg-primary:#fff;--bg-secondary:#f5f5f5;--bg-tertiary:#e5e7eb;--bg-surface:#fff;--bg-input:#fff;--bg-overlay:#0d1b3e99;--text-primary:#0d1b3e;--text-secondary:#4b5563;--text-tertiary:#6b7280;--text-muted:#9ca3af;--text-inverse:#fff;--border-light:#e5e7eb;--border-default:#d1d5db;--border-strong:#9ca3af;--focus-ring:#5b7a8e66;--hover-overlay:#0000000a}@media (prefers-color-scheme:dark){:root:not([data-theme=light]){--bg-primary:#373636;--bg-secondary:#2b2b2b;--bg-tertiary:#4a4a4a;--bg-surface:#403f3f;--bg-input:#2b2b2b;--bg-overlay:#000000d9;--text-primary:#fff;--text-secondary:#b0b0b0;--text-tertiary:#909090;--text-muted:#707070;--text-inverse:#373636;--border-light:#4a4a4a;--border-default:#555;--border-strong:#666;--focus-ring:#f4b94266;--hover-overlay:#ffffff0d;--shadow-sm:0 1px 2px #0003;--shadow-md:0 4px 6px #0000004d;--shadow-lg:0 10px 15px #0006;--shadow-xl:0 20px 25px #00000080}}:root[data-theme=dark]{--bg-primary:#373636;--bg-secondary:#2b2b2b;--bg-tertiary:#4a4a4a;--bg-surface:#403f3f;--bg-input:#2b2b2b;--bg-overlay:#000000d9;--text-primary:#fff;--text-secondary:#b0b0b0;--text-tertiary:#909090;--text-muted:#707070;--text-inverse:#373636;--border-light:#4a4a4a;--border-default:#555;--border-strong:#666;--focus-ring:#f4b94266;--hover-overlay:#ffffff0d;--shadow-sm:0 1px 2px #0003;--shadow-md:0 4px 6px #0000004d;--shadow-lg:0 10px 15px #0006;--shadow-xl:0 20px 25px #00000080}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{background-color:#fff;background-color:var(--bg-primary);color:#0d1b3e;color:var(--text-primary);font-family:IBM Plex Sans,system-ui,sans-serif;font-family:var(--font-body);font-size:1rem;font-size:var(--text-base);font-weight:300;font-weight:var(--weight-regular);line-height:1.6;min-height:100vh;transition:background-color .3s ease,color .3s ease;transition:background-color var(--transition-slow),color var(--transition-slow)}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#f5f5f5;background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:#9ca3af;background:var(--border-strong);border-radius:9999px;border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:#5b7a8e;background:var(--color-slate-blue)}h1,h2,h3,h4,h5,h6{color:#0d1b3e;color:var(--text-primary);font-family:Rubik,system-ui,sans-serif;font-family:var(--font-display);font-weight:500;font-weight:var(--weight-medium);line-height:1.2}h1{font-size:2.5rem;font-size:var(--text-4xl)}h2{font-size:1.5rem;font-size:var(--text-2xl)}h3{font-size:1.25rem;font-size:var(--text-xl)}h4{font-size:1.125rem;font-size:var(--text-lg)}p{color:#4b5563;color:var(--text-secondary);font-weight:200;font-weight:var(--weight-light)}.minimalist-card{background-color:#fff;background-color:var(--bg-surface);border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:8px;border-radius:var(--radius-md);box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm);padding:1.5rem;padding:var(--space-md);transition:box-shadow .2s ease,border-color .2s ease;transition:box-shadow var(--transition-base),border-color var(--transition-base)}.minimalist-card:hover{box-shadow:0 4px 6px #00000012;box-shadow:var(--shadow-md)}.minimalist-card h2{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-light);font-size:1.125rem;font-size:var(--text-lg);font-weight:700;font-weight:var(--weight-bold);margin-bottom:1rem;margin-bottom:var(--space-sm);padding-bottom:.5rem;padding-bottom:var(--space-xs)}.minimalist-card h2,.minimalist-input{color:#0d1b3e;color:var(--text-primary)}.minimalist-input{background-color:#fff;background-color:var(--bg-input);border:1px solid #d1d5db;border:1px solid var(--border-default);border-radius:4px;border-radius:var(--radius-sm);font-family:IBM Plex Sans,system-ui,sans-serif;font-family:var(--font-body);font-size:1rem;font-size:var(--text-base);font-weight:300;font-weight:var(--weight-regular);padding:.625rem .875rem;transition:border-color .15s ease,box-shadow .15s ease,background-color .15s ease;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast);width:100%}.minimalist-input:hover:not(:disabled):not(:focus){border-color:#9ca3af;border-color:var(--border-strong)}.minimalist-input:focus{border-color:#5b7a8e;border-color:var(--color-slate-blue);box-shadow:0 0 0 3px #5b7a8e66;box-shadow:0 0 0 3px var(--focus-ring);outline:none}.minimalist-input:disabled,.minimalist-input[readonly]{background-color:#f5f5f5;background-color:var(--bg-secondary);cursor:default;opacity:.7}.minimalist-input::placeholder{color:#9ca3af;color:var(--text-muted);font-weight:200;font-weight:var(--weight-light)}select.minimalist-input{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;background-size:16px;cursor:pointer;padding-right:36px}@media (prefers-color-scheme:dark){:root:not([data-theme=light]) select.minimalist-input{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23CBD5E1' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")}}:root[data-theme=dark] select.minimalist-input{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23CBD5E1' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")}.minimalist-button{align-items:center;background-color:#5b7a8e;background-color:var(--color-slate-blue);border:none;border-radius:4px;border-radius:var(--radius-sm);color:#fff;color:var(--text-inverse);cursor:pointer;display:inline-flex;font-family:IBM Plex Sans,system-ui,sans-serif;font-family:var(--font-body);font-size:.875rem;font-size:var(--text-sm);font-weight:500;font-weight:var(--weight-medium);gap:.5rem;justify-content:center;padding:.625rem 1.25rem;text-decoration:none;transition:all .2s ease;transition:all var(--transition-base)}.minimalist-button:hover:not(:disabled){box-shadow:0 4px 6px #00000012;box-shadow:var(--shadow-md);filter:brightness(110%);transform:translateY(-2px)}.minimalist-button:active:not(:disabled){transform:translateY(0)}.minimalist-button:disabled{cursor:not-allowed;opacity:.5;transform:none}.minimalist-button:focus-visible{outline:3px solid #f4b942;outline:3px solid var(--color-golden-yellow);outline-offset:2px}.btn-primary,.new-formula-btn,.save-formula-btn{background-color:#f4b942!important;background-color:var(--color-golden-yellow)!important;color:#0d1b3e!important;color:var(--color-deep-navy)!important;font-weight:700;font-weight:var(--weight-bold)}.btn-primary:hover:not(:disabled),.new-formula-btn:hover:not(:disabled),.save-formula-btn:hover:not(:disabled){box-shadow:0 8px 16px #f4b9424d}.btn-secondary{background-color:initial;border:2px solid #5b7a8e;border:2px solid var(--color-slate-blue);color:#5b7a8e;color:var(--color-slate-blue)}.btn-secondary:hover:not(:disabled){background-color:#5b7a8e;background-color:var(--color-slate-blue);color:#fff;color:var(--text-inverse)}.btn-danger,.confirm-delete-btn,.delete-btn{background-color:#ef4444!important;background-color:var(--color-error)!important;color:#fff!important}.btn-danger:hover:not(:disabled),.confirm-delete-btn:hover:not(:disabled),.delete-btn:hover:not(:disabled){box-shadow:0 8px 16px #ef44444d}.btn-success{background-color:#10b981!important;background-color:var(--color-success)!important;color:#fff!important}.btn-ghost{background-color:initial;border:none;color:#0d1b3e;color:var(--text-primary);text-decoration:underline;text-underline-offset:4px}.btn-ghost:hover:not(:disabled){box-shadow:none;color:#5b7a8e;color:var(--color-slate-blue);transform:none}.tint-btn-custom{background-color:#f4b942!important;background-color:var(--color-custom-highlight)!important;border:none;color:#0d1b3e!important;color:var(--color-deep-navy)!important;font-weight:700;font-weight:var(--weight-bold);min-width:100px}.tint-btn-custom:hover:not(:disabled){box-shadow:0 4px 12px #f4b94266}.tint-btn-standard{background-color:#10b981!important;background-color:var(--color-standard-highlight)!important;border:none;color:#fff!important;font-weight:700;font-weight:var(--weight-bold);min-width:100px}.tint-btn-standard:hover:not(:disabled){box-shadow:0 4px 12px #10b98166}.table-minimalist{border-collapse:collapse;font-family:Rubik,system-ui,sans-serif;font-family:var(--font-table);font-size:1.125rem;font-size:var(--text-lg);width:100%}.table-minimalist thead{background-color:initial;border-bottom:1px solid #d1d5db;border-bottom:1px solid var(--border-default)}.table-minimalist th{color:#6b7280;color:var(--text-tertiary);font-family:IBM Plex Sans,system-ui,sans-serif;font-family:var(--font-body);font-size:.75rem;font-size:var(--text-xs);font-weight:500;font-weight:var(--weight-medium);letter-spacing:.05em;text-align:left;text-transform:uppercase}.table-minimalist td,.table-minimalist th{padding:1rem;padding:var(--space-sm) var(--space-sm)}.table-minimalist td{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-light);color:#0d1b3e;color:var(--text-primary);vertical-align:middle}.table-minimalist tbody tr{transition:background-color .15s ease;transition:background-color var(--transition-fast)}.table-minimalist tbody tr:hover{background-color:#0000000a;background-color:var(--hover-overlay)}.table-minimalist tbody tr:last-child td{border-bottom:none}.table-minimalist input,.table-minimalist select{background:#0000;border:1px solid #0000;border-radius:4px;border-radius:var(--radius-sm);color:#0d1b3e;color:var(--text-primary);font-family:Rubik,system-ui,sans-serif;font-family:var(--font-table);font-size:1.125rem;font-size:var(--text-lg);padding:.375rem .5rem;transition:border-color .15s ease,background-color .15s ease;transition:border-color var(--transition-fast),background-color var(--transition-fast);width:100%}.table-minimalist select{word-wrap:break-word;overflow-wrap:break-word;text-overflow:ellipsis;white-space:normal}.table-minimalist input:hover:not(:disabled):not(:focus),.table-minimalist select:hover:not(:disabled):not(:focus){border-color:#d1d5db;border-color:var(--border-default)}.table-minimalist input:focus,.table-minimalist select:focus{background-color:#fff;background-color:var(--bg-input);border-color:#5b7a8e;border-color:var(--color-slate-blue);outline:none}.library-table td strong,.library-table td.strong,.table-minimalist td strong,.table-minimalist td.strong{font-weight:500;font-weight:var(--weight-medium)}.section-header td{background-color:#f5f5f5;background-color:var(--bg-secondary);border-left:3px solid #f4b942;border-left:3px solid var(--color-golden-yellow);color:#4b5563;color:var(--text-secondary);font-size:.75rem;font-size:var(--text-xs);letter-spacing:.1em;padding:.5rem 1rem;padding:var(--space-xs) var(--space-sm);text-transform:uppercase}.grand-total td,.section-header td{font-family:Rubik,system-ui,sans-serif;font-family:var(--font-display);font-weight:700;font-weight:var(--weight-bold)}.grand-total td{border-top:2px solid #d1d5db;border-top:2px solid var(--border-default);color:#0d1b3e;color:var(--text-primary);font-size:1.125rem;font-size:var(--text-lg);padding-top:1.5rem;padding-top:var(--space-md)}.library-table{background-color:#fff;background-color:var(--bg-surface);border:1px solid #e5e7eb;border:1px solid var(--border-light);border-collapse:collapse;border-radius:8px;border-radius:var(--radius-md);overflow:hidden;width:100%}.library-table thead{background-color:#f5f5f5;background-color:var(--bg-secondary)}.library-table th{border-bottom:1px solid #d1d5db;border-bottom:1px solid var(--border-default);color:#6b7280;color:var(--text-tertiary);font-family:IBM Plex Sans,system-ui,sans-serif;font-family:var(--font-body);font-size:.75rem;font-size:var(--text-xs);font-weight:500;font-weight:var(--weight-medium);letter-spacing:.05em;text-align:left;text-transform:uppercase}.library-table td,.library-table th{padding:1rem;padding:var(--space-sm)}.library-table td{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-light);color:#0d1b3e;color:var(--text-primary);font-family:Rubik,system-ui,sans-serif;font-family:var(--font-table);font-size:.875rem;font-size:var(--text-sm)}.library-table tbody tr{transition:background-color .15s ease;transition:background-color var(--transition-fast)}.library-table tbody tr:hover{background-color:#0000000a;background-color:var(--hover-overlay)}.library-table input[type=text]{background-color:#fff;background-color:var(--bg-input);border:1px solid #d1d5db;border:1px solid var(--border-default);border-radius:4px;border-radius:var(--radius-sm);color:#0d1b3e;color:var(--text-primary);font-family:Rubik,system-ui,sans-serif;font-family:var(--font-table);font-size:.875rem;font-size:var(--text-sm);padding:.375rem .5rem;width:100%}.library-table input[type=text]:focus{border-color:#5b7a8e;border-color:var(--color-slate-blue);box-shadow:0 0 0 2px #5b7a8e66;box-shadow:0 0 0 2px var(--focus-ring);outline:none}.library-table input[type=checkbox]{accent-color:#5b7a8e;accent-color:var(--color-slate-blue);cursor:pointer;height:18px;width:18px}.formula-composition-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:0}.formula-composition-header h2{margin-bottom:0}.consolidate-btn{background:#5b7a8e;background:var(--color-slate-blue);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:6px 14px;text-transform:uppercase;transition:all .2s ease}.consolidate-btn:hover{background:#0d1b3e;background:var(--color-deep-navy);transform:translateY(-1px)}.formula-header-buttons{display:flex;gap:8px}.refactor-btn{background:#5b7a8e;background:var(--color-slate-blue);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:6px 14px;text-transform:uppercase;transition:all .2s ease}.refactor-btn:hover{background:#0d1b3e;background:var(--color-deep-navy);transform:translateY(-1px)}.refactor-popup{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0d1b3e99;background-color:var(--bg-overlay);display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.refactor-popup-content{animation:popupFadeIn .2s ease-out;background-color:#fff;background-color:var(--bg-surface);border:1px solid #d1d5db;border:1px solid var(--border-default);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 20px 25px #00000026;box-shadow:var(--shadow-xl);max-width:550px;min-width:450px;padding:2rem;padding:var(--space-lg)}.refactor-popup-content h2{color:#0d1b3e;color:var(--text-primary);margin-bottom:1.5rem;margin-bottom:var(--space-md);text-align:center}.refactor-steps{justify-content:center;margin-bottom:2rem;margin-bottom:var(--space-lg);padding:1rem 0;padding:var(--space-sm) 0}.refactor-step,.refactor-steps{align-items:center;display:flex}.refactor-step{flex-direction:column;gap:4px}.refactor-step .step-number{align-items:center;background:var(--bg-muted);border-radius:50%;color:#9ca3af;color:var(--text-muted);display:flex;font-size:.9rem;font-weight:600;height:32px;justify-content:center;transition:all .2s ease;width:32px}.refactor-step .step-label{color:#9ca3af;color:var(--text-muted);font-size:.7rem;letter-spacing:.5px;text-transform:uppercase}.refactor-step.active .step-number{background:#5b7a8e;background:var(--color-slate-blue);color:#fff}.refactor-step.active .step-label{color:#5b7a8e;color:var(--color-slate-blue)}.refactor-step.completed .step-number{background:#10b981;background:var(--color-success);color:#fff}.step-connector{background:#d1d5db;background:var(--border-default);height:2px;margin:0 8px 16px;width:40px}.refactor-step-content{align-items:center;display:flex;flex-direction:column;min-height:180px;padding:1.5rem 0;padding:var(--space-md) 0;text-align:center}.refactor-icon{font-size:2.5rem}.refactor-icon,.refactor-step-content h3{margin-bottom:1rem;margin-bottom:var(--space-sm)}.refactor-step-content h3{color:#0d1b3e;color:var(--text-primary)}.refactor-step-content p{color:#4b5563;color:var(--text-secondary);margin-bottom:.5rem;margin-bottom:var(--space-xs);max-width:380px}.refactor-note{color:#9ca3af;color:var(--text-muted);font-size:.85rem;font-style:italic}.refactor-scale-controls{align-items:center;background-color:#f5f5f5;background-color:var(--bg-secondary);border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:8px;border-radius:var(--radius-md);display:flex;gap:1rem;gap:var(--space-sm);justify-content:center;margin-top:1.5rem;margin-top:var(--space-md);padding:1rem;padding:var(--space-sm)}.refactor-scale-btn{background-color:#fff;background-color:var(--bg-surface);border:1px solid #d1d5db;border:1px solid var(--border-default);border-radius:4px;border-radius:var(--radius-sm);color:#0d1b3e;color:var(--text-primary);cursor:pointer;font-family:IBM Plex Sans,system-ui,sans-serif;font-family:var(--font-body);font-size:1rem;font-weight:500;font-weight:var(--weight-medium);padding:.5rem 1.5rem;padding:var(--space-xs) var(--space-md);transition:all .2s ease;transition:all var(--transition-base)}.refactor-scale-btn:hover{background-color:#e5e7eb;background-color:var(--bg-tertiary);border-color:#9ca3af;border-color:var(--border-strong)}.refactor-scale-btn.connected{background-color:#5b7a8e;background-color:var(--color-slate-blue);border-color:#5b7a8e;border-color:var(--color-slate-blue);color:#fff}.refactor-scale-btn.connected:hover{background-color:#5a6b8c}.refactor-tare-btn{background-color:#f4b942;background-color:var(--color-golden-yellow);border-color:#f4b942;border-color:var(--color-golden-yellow);color:#0d1b3e;color:var(--color-deep-navy)}.refactor-tare-btn:hover{background-color:#e5a830;border-color:#e5a830}.refactor-live-weight{background-color:#fff;background-color:var(--bg-surface);border:2px solid #10b981;border:2px solid var(--color-success);border-radius:4px;border-radius:var(--radius-sm);color:#10b981;color:var(--color-success);font-family:JetBrains Mono,monospace;font-family:var(--font-mono);font-size:1.25rem;font-weight:700;font-weight:var(--weight-bold);min-width:80px;padding:.5rem 1rem;padding:var(--space-xs) var(--space-sm);text-align:center}.refactor-weight-input{margin:1.5rem 0;margin:var(--space-md) 0;max-width:300px;text-align:left;width:100%}.refactor-weight-input label{color:#0d1b3e;color:var(--text-primary);display:block;font-size:.85rem;font-weight:500;margin-bottom:.5rem;margin-bottom:var(--space-xs)}.weight-input-row{display:flex;gap:8px}.weight-input-row input{background:#fff;background:var(--bg-surface);border:1px solid #d1d5db;border:1px solid var(--border-default);border-radius:8px;border-radius:var(--radius-md);color:#0d1b3e;color:var(--text-primary);flex:1 1;font-size:1rem;padding:10px 12px}.weight-input-row input:focus{border-color:#5b7a8e;border-color:var(--color-slate-blue);outline:none}.scale-capture-btn{background:#f59e0b;background:var(--color-warning);border:none;border-radius:8px;border-radius:var(--radius-md);color:#0d1b3e;color:var(--color-deep-navy);cursor:pointer;font-weight:600;padding:10px 14px;transition:all .2s ease;white-space:nowrap}.scale-capture-btn:hover{background:#e6a700;transform:translateY(-1px)}.refactor-comparison{font-size:.9rem;margin-top:1.5rem;margin-top:var(--space-md)}.refactor-summary-table{margin-top:1.5rem;margin-top:var(--space-md);max-height:200px;overflow-y:auto;width:100%}.refactor-summary-table table{border-collapse:collapse;font-size:.9rem;width:100%}.refactor-summary-table td,.refactor-summary-table th{border-bottom:1px solid #d1d5db;border-bottom:1px solid var(--border-default);padding:8px 12px;text-align:left}.refactor-summary-table th{background:var(--bg-muted);color:#0d1b3e;color:var(--text-primary);font-weight:600}.refactor-summary-table td{color:#4b5563;color:var(--text-secondary)}.refactor-summary-table td:last-child{color:#0d1b3e;color:var(--text-primary);font-family:Rubik,system-ui,sans-serif;font-family:var(--font-table);text-align:right}.refactor-buttons{border-top:1px solid #d1d5db;border-top:1px solid var(--border-default);display:flex;gap:1rem;gap:var(--space-sm);justify-content:center;margin-top:2rem;margin-top:var(--space-lg);padding-top:1.5rem;padding-top:var(--space-md)}.formulation-table{table-layout:fixed}.formulation-table td:first-child,.formulation-table th:first-child{min-width:200px;width:35%}.formulation-table td:nth-child(2),.formulation-table td:nth-child(3),.formulation-table td:nth-child(4),.formulation-table td:nth-child(5),.formulation-table th:nth-child(2),.formulation-table th:nth-child(3),.formulation-table th:nth-child(4),.formulation-table th:nth-child(5){width:11%}.formulation-table td:nth-child(6),.formulation-table td:nth-child(7),.formulation-table th:nth-child(6),.formulation-table th:nth-child(7){width:10%}.production-data-table td:first-child,.production-data-table th:first-child{width:50%}.production-data-table td:nth-child(2),.production-data-table td:nth-child(3),.production-data-table th:nth-child(2),.production-data-table th:nth-child(3){text-align:right;width:25%}.ingredient-name{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.formulator-layout-grid{grid-gap:1.5rem;grid-gap:var(--space-md);align-items:stretch;display:grid;gap:1.5rem;gap:var(--space-md);grid-template-columns:280px minmax(500px,1fr) 320px;margin:0 auto;max-width:1800px;padding:1.5rem;padding:var(--space-md)}@media (max-width:1200px){.formulator-layout-grid{grid-template-columns:1fr;grid-template-rows:auto auto auto}.layout-column-center,.layout-column-left,.layout-column-right{width:100%}}.formulator-action-buttons{flex-wrap:wrap;gap:.5rem;gap:var(--space-xs)}.action-container,.formulator-action-buttons{background-color:#f5f5f5;background-color:var(--bg-secondary);border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:8px;border-radius:var(--radius-md);display:flex;margin-bottom:1.5rem;margin-bottom:var(--space-md);padding:1rem;padding:var(--space-sm)}.action-container{align-items:center;justify-content:space-between}.production-controls,.production-table.minimalist-card{padding:1rem;padding:var(--space-sm)}.production-controls{background-color:#f5f5f5;background-color:var(--bg-secondary);border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:8px;border-radius:var(--radius-md);display:flex;flex-direction:column;gap:1rem;gap:var(--space-sm);margin-bottom:1.5rem;margin-bottom:var(--space-md)}.production-control-row{grid-gap:1rem;grid-gap:var(--space-sm);align-items:center;display:grid;gap:1rem;gap:var(--space-sm);grid-template-columns:120px 1fr}.production-control-row label{font-size:.875rem;font-size:var(--text-sm);font-weight:500;font-weight:var(--weight-medium)}.control-input-group{align-items:center;display:flex;gap:.5rem;gap:var(--space-xs)}.control-input-group .unit{color:#9ca3af;color:var(--text-muted);font-family:JetBrains Mono,monospace;font-family:var(--font-mono);font-size:.875rem;font-size:var(--text-sm)}.switch{display:inline-block;height:26px;position:relative;width:48px}.switch input{height:0;opacity:0;width:0}.slider{background-color:#d1d5db;background-color:var(--border-default);border-radius:9999px;border-radius:var(--radius-full);cursor:pointer;inset:0}.slider,.slider:before{position:absolute;transition:.2s ease;transition:var(--transition-base)}.slider:before{background-color:#fff;border-radius:50%;bottom:3px;box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm);content:"";height:20px;left:3px;width:20px}input:checked+.slider{background-color:#5b7a8e;background-color:var(--color-slate-blue)}input:checked+.slider:before{transform:translateX(22px)}input:focus-visible+.slider{box-shadow:0 0 0 3px #5b7a8e66;box-shadow:0 0 0 3px var(--focus-ring)}.input-group{display:flex;flex-direction:column;gap:.25rem}.input-group label{color:#6b7280;color:var(--text-tertiary);font-size:.75rem;font-size:var(--text-xs);font-weight:500;font-weight:var(--weight-medium);letter-spacing:.05em;text-transform:uppercase}.overlay{z-index:999}.confirm-popup,.delete-popup,.details-popup,.feedback-popup,.image-popup,.overlay,.save-popup,.webcam-popup{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0d1b3e99;background-color:var(--bg-overlay);inset:0;position:fixed}.confirm-popup,.delete-popup,.details-popup,.feedback-popup,.image-popup,.save-popup,.webcam-popup{align-items:center;display:flex;justify-content:center;z-index:1000}.confirm-popup-content,.delete-popup-content,.details-popup-content,.feedback-popup-content,.image-popup-content,.save-popup-content,.webcam-popup-content{animation:popupFadeIn .2s ease-out;background-color:#fff;background-color:var(--bg-surface);border:1px solid #d1d5db;border:1px solid var(--border-default);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 20px 25px #00000026;box-shadow:var(--shadow-xl);color:#0d1b3e;color:var(--text-primary);max-height:90vh;max-width:90vw;overflow-y:auto;padding:2rem;padding:var(--space-lg)}@keyframes popupFadeIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.confirm-popup-content h2,.delete-popup-content h2,.details-popup-content h2,.feedback-popup-content h2,.image-popup-content h2,.save-popup-content h2,.webcam-popup-content h2{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-light);font-family:Rubik,system-ui,sans-serif;font-family:var(--font-display);font-size:1.25rem;font-size:var(--text-xl);font-weight:700;font-weight:var(--weight-bold);margin-bottom:1.5rem;margin-bottom:var(--space-md);padding-bottom:1rem;padding-bottom:var(--space-sm)}.feedback-popup-content{width:450px}.confirm-popup-content{min-width:320px;text-align:center}.confirm-popup-content p{color:#0d1b3e;color:var(--text-primary);font-size:1.125rem;font-size:var(--text-lg);font-weight:300;font-weight:var(--weight-regular);margin-bottom:1.5rem;margin-bottom:var(--space-md)}.confirm-popup-content button,.delete-popup-content button{margin:0 .5rem;margin:0 var(--space-xs);padding:.5rem 1.5rem;padding:var(--space-xs) var(--space-md)}.header-logo{display:block;height:auto;margin:1.5rem auto;margin:var(--space-md) auto;max-width:400px}.notes-textarea{font-family:IBM Plex Sans,system-ui,sans-serif;font-family:var(--font-body);font-size:1rem;font-size:var(--text-base);font-weight:200;font-weight:var(--weight-light);line-height:1.6;min-height:120px;resize:vertical}.thumbnail-grid{grid-gap:1.5rem;grid-gap:var(--space-md);display:grid;gap:1.5rem;gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.thumbnail-card{background-color:#fff;background-color:var(--bg-surface);border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:8px;border-radius:var(--radius-md);cursor:pointer;padding:1rem;padding:var(--space-sm);position:relative;text-align:center;transition:all .2s ease;transition:all var(--transition-base)}.thumbnail-card:hover{border-color:#5b7a8e;border-color:var(--color-slate-blue);box-shadow:0 10px 15px #0000001a;box-shadow:var(--shadow-lg);transform:translateY(-4px)}.thumbnail-card img{border-radius:4px;border-radius:var(--radius-sm);height:160px;margin-bottom:.5rem;margin-bottom:var(--space-xs);object-fit:cover;width:100%}.thumbnail-card p{color:#0d1b3e;color:var(--text-primary);font-family:Rubik,system-ui,sans-serif;font-family:var(--font-display);font-size:.875rem;font-size:var(--text-sm);font-weight:700;font-weight:var(--weight-bold);margin-top:.5rem;margin-top:var(--space-xs)}.thumbnail-card input[type=checkbox]{accent-color:#5b7a8e;accent-color:var(--color-slate-blue);height:20px;left:1rem;left:var(--space-sm);position:absolute;top:1rem;top:var(--space-sm);width:20px}.filters-container{background-color:#f5f5f5;background-color:var(--bg-secondary);border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:8px;border-radius:var(--radius-md);display:flex;flex-wrap:wrap;gap:1rem;gap:var(--space-sm);margin-bottom:1.5rem;margin-bottom:var(--space-md);padding:1rem;padding:var(--space-sm)}.filters-container input{background-color:#fff;background-color:var(--bg-input);border:1px solid #d1d5db;border:1px solid var(--border-default);border-radius:4px;border-radius:var(--radius-sm);color:#0d1b3e;color:var(--text-primary);flex:1 1;font-family:IBM Plex Sans,system-ui,sans-serif;font-family:var(--font-body);font-size:.875rem;font-size:var(--text-sm);min-width:150px;padding:.5rem 1rem;padding:var(--space-xs) var(--space-sm)}.filters-container input:focus{border-color:#5b7a8e;border-color:var(--color-slate-blue);box-shadow:0 0 0 2px #5b7a8e66;box-shadow:0 0 0 2px var(--focus-ring);outline:none}.clear-filters-btn{background-color:#e5e7eb;background-color:var(--bg-tertiary);border:1px solid #d1d5db;border:1px solid var(--border-default);border-radius:4px;border-radius:var(--radius-sm);color:#4b5563;color:var(--text-secondary);cursor:pointer;font-size:.875rem;font-size:var(--text-sm);padding:.5rem 1rem;padding:var(--space-xs) var(--space-sm);transition:all .15s ease;transition:all var(--transition-fast)}.clear-filters-btn:hover{background-color:#d1d5db;background-color:var(--border-default);color:#0d1b3e;color:var(--text-primary)}.binder-load-green,.status-positive{color:#10b981!important;color:var(--color-success)!important}.binder-load-red,.status-negative{color:#ef4444!important;color:var(--color-error)!important}.view-image-button{background:#0000;border:none;color:#5b7a8e;color:var(--color-slate-blue);cursor:pointer;font-size:.875rem;font-size:var(--text-sm);font-weight:500;font-weight:var(--weight-medium);padding:0;text-decoration:underline;text-underline-offset:4px;transition:color .15s ease;transition:color var(--transition-fast)}.view-image-button:hover{color:#f4b942;color:var(--color-golden-yellow)}@media (max-width:768px){body{font-size:14px}.formulator-action-buttons{flex-direction:column}.formulator-action-buttons .minimalist-button{width:100%}.action-container{flex-direction:column;gap:1rem;gap:var(--space-sm)}.library-table{display:block;overflow-x:auto}.thumbnail-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.feedback-popup-content,.image-popup-content,.popup-content,.save-popup-content,.webcam-popup-content{padding:1.5rem;padding:var(--space-md);width:95vw}}:focus-visible{outline:3px solid #f4b942;outline:3px solid var(--color-golden-yellow);outline-offset:2px}:focus:not(:focus-visible){outline:none}.shot-input-wrapper{align-items:center;display:flex;gap:4px;position:relative}.shot-input-wrapper input{flex:1 1;min-width:0}.scale-save-btn{align-items:center;background-color:#10b981;background-color:var(--color-success);border:none;border-radius:4px;border-radius:var(--radius-sm);color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:20px;height:28px;justify-content:center;line-height:1;padding:0;transition:all .15s ease;transition:all var(--transition-fast);width:28px}.scale-save-btn:hover{background-color:#059669;box-shadow:0 4px 6px #00000012;box-shadow:var(--shadow-md);transform:scale(1.1)}.scale-save-btn:active{transform:scale(.95)}.scale-status{align-items:center;background-color:#f5f5f5;background-color:var(--bg-secondary);border:1px solid #d1d5db;border:1px solid var(--border-default);border-radius:4px;border-radius:var(--radius-sm);display:flex;font-family:Rubik,system-ui,sans-serif;font-family:var(--font-table);font-size:.875rem;font-size:var(--text-sm);gap:.5rem;gap:var(--space-xs);padding:.375rem .75rem}.scale-status-dot{border-radius:50%;flex-shrink:0;height:10px;width:10px}.scale-status-dot.connected{background-color:#10b981;background-color:var(--color-success);box-shadow:0 0 8px #10b981;box-shadow:0 0 8px var(--color-success)}.scale-status-dot.partial{background-color:#f59e0b;background-color:var(--color-warning);box-shadow:0 0 8px #f59e0b;box-shadow:0 0 8px var(--color-warning)}.scale-status-dot.disconnected{background-color:#ef4444;background-color:var(--color-error)}.scale-weight-display{color:#10b981;color:var(--color-success);font-weight:700;font-weight:var(--weight-bold);margin-left:.5rem;margin-left:var(--space-xs)}.weight-overlay{animation:overlayFadeIn .15s ease-out;background-color:#fff;background-color:var(--bg-surface);border:2px solid #f4b942;border:2px solid var(--color-golden-yellow);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 20px 25px #00000026;box-shadow:var(--shadow-xl);min-width:180px;padding:1.5rem;padding:var(--space-md);position:fixed;text-align:center;z-index:1000}@keyframes overlayFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.weight-overlay-value{color:#10b981;color:var(--color-success);font-family:Rubik,system-ui,sans-serif;font-family:var(--font-table);font-size:2.5rem;font-size:var(--text-4xl);font-weight:800;font-weight:var(--weight-heavy);line-height:1;margin-bottom:.5rem;margin-bottom:var(--space-xs)}.weight-overlay-unit{color:#4b5563;color:var(--text-secondary);font-size:1.125rem;font-size:var(--text-lg);margin-bottom:1rem;margin-bottom:var(--space-sm)}.weight-overlay-save-btn{background-color:#f4b942;background-color:var(--color-golden-yellow);border:none;border-radius:4px;border-radius:var(--radius-sm);color:#0d1b3e;color:var(--color-deep-navy);cursor:pointer;font-size:1rem;font-size:var(--text-base);font-weight:700;font-weight:var(--weight-bold);padding:.5rem 1.5rem;padding:var(--space-xs) var(--space-md);transition:all .15s ease;transition:all var(--transition-fast);width:100%}.weight-overlay-save-btn:hover{box-shadow:0 4px 6px #00000012;box-shadow:var(--shadow-md);transform:translateY(-2px)}.weight-overlay-save-btn:active{transform:translateY(0)}.scale-btn{align-items:center;display:inline-flex;gap:.375rem}.scale-btn-icon{font-size:1.1em}
/*# sourceMappingURL=main.7eefd7e4.css.map*/