:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}#root{max-width:1280px;margin:0 auto;padding:2rem}.login-page{display:flex;justify-content:center;align-items:center;min-height:80vh}.login-form-container{width:100%;max-width:400px}.login-form{background:#1a1a1a;padding:2rem;border-radius:8px;box-shadow:0 4px 6px #0000004d}.login-form h2{margin:0 0 .5rem;text-align:center;color:#fff}.login-subtitle{text-align:center;color:#888;margin-bottom:1.5rem}.login-error{background:#f44;color:#fff;padding:.75rem;border-radius:4px;margin-bottom:1rem;text-align:center}.form-field{margin-bottom:1rem}.form-field label{display:block;margin-bottom:.5rem;color:#ccc;text-align:left}.form-field input{width:100%;padding:.75rem;border:1px solid #333;border-radius:4px;background:#2a2a2a;color:#fff;font-size:1rem;box-sizing:border-box}.form-field input:focus{outline:none;border-color:#646cff}.form-field input:disabled{opacity:.6;cursor:not-allowed}.login-button{width:100%;padding:.75rem;background:#646cff;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:background .2s}.login-button:hover:not(:disabled){background:#535bf2}.login-button:disabled{opacity:.6;cursor:not-allowed}.auth-loading{display:flex;justify-content:center;align-items:center;min-height:80vh;color:#888}.permission-error{text-align:center;padding:2rem;max-width:500px;margin:4rem auto}.permission-error h2{color:#f44;margin-bottom:1rem}.permission-error p{color:#888;margin-bottom:.5rem}.product-entry-page{text-align:left}.page-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;border-bottom:1px solid #333;margin-bottom:2rem}.page-header h1{margin:0}.user-info{display:flex;align-items:center;gap:1rem}.user-info span{color:#888}.logout-button{padding:.5rem 1rem;background:transparent;color:#888;border:1px solid #333;border-radius:4px;cursor:pointer;transition:all .2s}.logout-button:hover{background:#333;color:#fff}.page-content{padding:1rem 0}.product-entry-form{max-width:800px}.form-section{background:#1a1a1a;padding:1.5rem;border-radius:8px;margin-bottom:1.5rem}.form-section h2{margin:0 0 1rem;font-size:1.25rem;color:#fff;border-bottom:1px solid #333;padding-bottom:.5rem}.section-placeholder{color:#666;font-style:italic}.form-field-with-retention{margin-bottom:1rem}.field-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.field-header label{color:#ccc;font-weight:500}.retention-checkbox{display:flex;align-items:center;gap:.25rem;font-size:.85rem;color:#888;cursor:pointer}.retention-checkbox input[type=checkbox]{width:16px;height:16px;cursor:pointer}.retention-label{font-weight:400}.form-field-with-retention input[type=text],.form-field-with-retention input[type=url],.form-field-with-retention input[type=number],.form-field-with-retention textarea,.form-field-with-retention select{width:100%;padding:.75rem;border:1px solid #333;border-radius:4px;background:#2a2a2a;color:#fff;font-size:1rem;box-sizing:border-box;font-family:inherit}.form-field-with-retention textarea{resize:vertical;min-height:60px}.form-field-with-retention input:focus,.form-field-with-retention textarea:focus,.form-field-with-retention select:focus{outline:none;border-color:#646cff}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media(max-width:600px){.form-row{grid-template-columns:1fr}}.form-error{background:#f44;color:#fff;padding:.75rem 1rem;border-radius:4px;margin-bottom:1rem}.form-success{background:#4b4;color:#fff;padding:.75rem 1rem;border-radius:4px;margin-bottom:1rem}.form-actions{display:flex;gap:1rem;flex-wrap:wrap;padding-top:1rem}.btn{padding:.75rem 1.5rem;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;border:none}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:#646cff;color:#fff}.btn-primary:hover:not(:disabled){background:#535bf2}.btn-secondary{background:#3a3a3a;color:#fff;border:1px solid #555}.btn-secondary:hover:not(:disabled){background:#4a4a4a}.btn-tertiary{background:transparent;color:#888;border:1px solid #444}.btn-tertiary:hover:not(:disabled){background:#2a2a2a;color:#fff}@media(max-width:600px){.form-actions{flex-direction:column}.btn{width:100%}}.image-capture{margin-top:1rem}.image-capture-actions{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:1rem}.btn-camera,.btn-gallery,.btn-upload{padding:.75rem 1.25rem;border-radius:4px;font-size:.95rem;cursor:pointer;transition:all .2s;border:1px solid #444;background:#2a2a2a;color:#fff}.btn-camera:hover:not(:disabled),.btn-gallery:hover:not(:disabled),.btn-upload:hover:not(:disabled){background:#3a3a3a;border-color:#555}.btn-upload{background:#2a5a2a;border-color:#3a7a3a}.btn-upload:hover:not(:disabled){background:#3a7a3a}.btn-camera:disabled,.btn-gallery:disabled,.btn-upload:disabled{opacity:.5;cursor:not-allowed}.compression-progress{margin-bottom:1rem}.compression-item{display:flex;align-items:center;gap:.75rem;padding:.5rem;background:#2a2a2a;border-radius:4px;margin-bottom:.5rem}.compression-item span{color:#888;font-size:.9rem}.compression-item progress{flex:1;height:8px;border-radius:4px}.image-thumbnails{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.75rem;margin-bottom:1rem}.image-thumbnail{position:relative;aspect-ratio:1;border-radius:8px;overflow:hidden;background:#2a2a2a;border:2px solid #333}.image-thumbnail.has-error{border-color:#f44}.thumbnail-image{width:100%;height:100%;object-fit:cover}.thumbnail-remove{position:absolute;top:4px;right:4px;width:24px;height:24px;border-radius:50%;background:#000000b3;color:#fff;border:none;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:background .2s}.thumbnail-remove:hover:not(:disabled){background:#f44}.thumbnail-remove:disabled{opacity:.5;cursor:not-allowed}.thumbnail-uploaded{position:absolute;bottom:4px;right:4px;width:24px;height:24px;border-radius:50%;background:#4b4;color:#fff;font-size:14px;display:flex;align-items:center;justify-content:center}.thumbnail-upload-progress{position:absolute;inset:0;background:#000000b3;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem}.thumbnail-upload-progress progress{width:80%;height:6px;border-radius:3px}.upload-percent{color:#fff;font-size:.85rem;font-weight:500}.thumbnail-error{position:absolute;bottom:4px;left:4px;right:32px;display:flex;align-items:center;gap:4px}.error-message{font-size:16px}.btn-retry{width:24px;height:24px;border-radius:50%;background:#ff4444e6;color:#fff;border:none;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;transition:background .2s}.btn-retry:hover{background:#f66}.upload-errors{background:#ff44441a;border:1px solid #ff4444;border-radius:4px;padding:.75rem;margin-bottom:1rem}.error-summary{color:#f66;margin:0;font-size:.9rem}.image-count{color:#888;font-size:.9rem}.uploaded-count{color:#4b4}.capture-preview-modal{position:fixed;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.capture-preview-content{max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;gap:1rem}.capture-preview-image{max-width:100%;max-height:70vh;border-radius:8px}.capture-preview-actions{display:flex;gap:1rem}@media(max-width:600px){.image-thumbnails{grid-template-columns:repeat(3,1fr)}.image-capture-actions{flex-direction:column}.btn-camera,.btn-gallery,.btn-upload{width:100%}}.form-error,.form-success{display:flex;align-items:center;gap:.5rem;animation:slideIn .3s ease-out}.success-icon,.error-icon{font-size:1.25rem}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.upload-progress{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#2a3a5a;border:1px solid #3a5a8a;border-radius:4px;margin-bottom:1rem;color:#8ab4f8}.upload-progress progress{flex:1;height:8px;border-radius:4px;background:#1a2a4a}.upload-progress progress::-webkit-progress-bar{background:#1a2a4a;border-radius:4px}.upload-progress progress::-webkit-progress-value{background:#4a8af4;border-radius:4px}.upload-progress progress::-moz-progress-bar{background:#4a8af4;border-radius:4px}.input-error{border-color:#f44!important;background:#ff44441a!important}.input-error:focus{border-color:#f66!important;box-shadow:0 0 0 2px #f443}.field-error{display:block;color:#f66;font-size:.85rem;margin-top:.25rem}.section-errors{margin-top:.5rem;padding:.5rem;background:#ff44441a;border-radius:4px}.section-errors .field-error{display:block;margin-bottom:.25rem}.section-errors .field-error:last-child{margin-bottom:0}.ymm-entry-list{margin-top:0}.ymm-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid #333}.ymm-header h3{margin:0;font-size:1.25rem;color:#fff}.ymm-add-btn{padding:.5rem 1rem;background:#2a5a2a;color:#fff;border:1px solid #3a7a3a;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s}.ymm-add-btn:hover{background:#3a7a3a}.ymm-empty-message{color:#666;font-style:italic;text-align:center;padding:1rem}.ymm-entries{display:flex;flex-direction:column;gap:.75rem}.ymm-entry-row{display:grid;grid-template-columns:1fr 1fr 100px 100px auto auto;gap:.5rem;align-items:end;padding:.75rem;background:#2a2a2a;border-radius:4px}.ymm-entry-row .field-group{display:flex;flex-direction:column;gap:.25rem}.ymm-entry-row label{font-size:.8rem;color:#888}.ymm-entry-row input{padding:.5rem;border:1px solid #333;border-radius:4px;background:#1a1a1a;color:#fff;font-size:.9rem}.ymm-entry-row input:focus{outline:none;border-color:#646cff}.ymm-remove-btn{padding:.5rem;background:transparent;color:#f66;border:1px solid #ff4444;border-radius:4px;cursor:pointer;font-size:1rem;transition:all .2s;height:fit-content}.ymm-remove-btn:hover{background:#f44;color:#fff}@media(max-width:768px){.ymm-entry-row{grid-template-columns:1fr 1fr}.ymm-remove-btn{grid-column:span 2;justify-self:end}}.category-selector{position:relative}.category-selector--loading,.category-selector--error{padding:.75rem;background:#2a2a2a;border-radius:4px}.loading-text{color:#888}.error-text{color:#f66}.category-checkbox-list{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;background:#2a2a2a;border-radius:4px;max-height:200px;overflow-y:auto}.category-checkbox-item{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem;color:#fff}.category-checkbox-item input[type=checkbox]{width:16px;height:16px;cursor:pointer}.category-parent-indicator{color:#666;font-size:.85rem}.category-selector__no-results{padding:.75rem;color:#666;text-align:center}.brand-selector{position:relative}.brand-selector--loading,.brand-selector--error{padding:.75rem;background:#2a2a2a;border-radius:4px}.brand-radio-list{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;background:#2a2a2a;border-radius:4px;max-height:200px;overflow-y:auto}.brand-radio-item{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem;color:#fff}.brand-radio-item input[type=radio]{width:16px;height:16px;cursor:pointer}.brand-selector__no-results{padding:.75rem;color:#666;text-align:center}.attribute-list{margin-top:0}.attribute-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid #333}.attribute-header h2{margin:0;font-size:1.25rem;color:#fff}.attribute-add-btn{padding:.5rem 1rem;background:#2a5a2a;color:#fff;border:1px solid #3a7a3a;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s}.attribute-add-btn:hover{background:#3a7a3a}.attribute-empty-message{color:#666;font-style:italic;text-align:center;padding:1rem}.attribute-entries{display:flex;flex-direction:column;gap:.75rem}.attribute-row{display:grid;grid-template-columns:1fr 1fr auto auto auto;gap:.5rem;align-items:end;padding:.75rem;background:#2a2a2a;border-radius:4px}.attribute-row .field-group{display:flex;flex-direction:column;gap:.25rem}.attribute-row label{font-size:.8rem;color:#888}.attribute-row select,.attribute-row input{padding:.5rem;border:1px solid #333;border-radius:4px;background:#1a1a1a;color:#fff;font-size:.9rem}.attribute-row select:focus,.attribute-row input:focus{outline:none;border-color:#646cff}.visibility-toggle{display:flex;align-items:center;gap:.25rem;padding:.5rem;cursor:pointer}.visibility-toggle input[type=checkbox]{width:16px;height:16px}.attribute-remove-btn{padding:.5rem;background:transparent;color:#f66;border:1px solid #ff4444;border-radius:4px;cursor:pointer;font-size:1rem;transition:all .2s;height:fit-content}.attribute-remove-btn:hover{background:#f44;color:#fff}@media(max-width:768px){.attribute-row{grid-template-columns:1fr 1fr}.visibility-toggle,.attribute-remove-btn{grid-column:span 1}}.sku-generator{display:flex;flex-direction:column;gap:1rem}.sku-generator-error{background:#ff44441a;border:1px solid #ff4444;color:#f66;padding:.5rem .75rem;border-radius:4px;font-size:.9rem}.sku-generator-selectors{display:flex;gap:.75rem;align-items:flex-end;flex-wrap:wrap}.sku-generator-field{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:120px}.sku-generator-field label{font-size:.8rem;color:#888}.sku-generator-field select{padding:.5rem;border:1px solid #333;border-radius:4px;background:#2a2a2a;color:#fff;font-size:.9rem}.sku-generator-field select:focus{outline:none;border-color:#646cff}.sku-generate-btn{margin-top:.25rem}.sku-generator-result{display:flex;flex-direction:column;gap:.25rem}.sku-generator-result label{font-size:.8rem;color:#888;display:flex;align-items:center;gap:.5rem}.manual-override-badge{font-size:.75rem;color:#646cff;font-style:italic}.sku-generator-result input{padding:.75rem;border:1px solid #333;border-radius:4px;background:#2a2a2a;color:#fff;font-size:1rem}.sku-generator-result input:focus{outline:none;border-color:#646cff}.sku-help-text{margin:0;font-size:.8rem;color:#666}@media(max-width:600px){.sku-generator-selectors{flex-direction:column}.sku-generator-field,.sku-generate-btn{width:100%}}.ymm-retain-checkbox,.attribute-retain-checkbox{display:flex;align-items:center;gap:.25rem;font-size:.85rem;color:#888;cursor:pointer;white-space:nowrap}.ymm-retain-checkbox input[type=checkbox],.attribute-retain-checkbox input[type=checkbox]{width:16px;height:16px;cursor:pointer}.ymm-retain-checkbox span,.attribute-retain-checkbox span{font-weight:400}
