:root{font-family:Inter,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}.loading-container{display:flex;justify-content:center;align-items:center;height:100vh;width:100%}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{--primary-color: #646cff;--primary-hover: #535bf2;--secondary-color: #747bff;--success-color: #4caf50;--error-color: #f44336;--warning-color: #ff9800;--text-color: #213547;--text-light: #666;--border-color: #e0e0e0;--bg-light: #f8f9fa;--bg-white: #ffffff;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--border-radius: 8px;--transition: all .3s ease}*{box-sizing:border-box;margin:0;padding:0}.container{width:100%;max-width:none;margin:0 auto;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;box-sizing:border-box;background:var(--bg-light)}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding:20px;border-bottom:2px solid var(--border-color);background:var(--bg-white);border-radius:var(--border-radius);box-shadow:var(--shadow-sm);width:100%;box-sizing:border-box}.header h1{margin:0;font-size:2em;color:var(--primary-color);font-weight:600}.user-info{display:flex;align-items:center;gap:20px}.user-info span{font-size:16px;color:var(--text-color);font-weight:500}.logout-btn{padding:10px 20px;background-color:var(--error-color);color:#fff;border:none;border-radius:var(--border-radius);cursor:pointer;font-size:14px;font-weight:500;transition:var(--transition);box-shadow:var(--shadow-sm)}.logout-btn:hover{background-color:#d32f2f;transform:translateY(-1px);box-shadow:var(--shadow-md)}.success-message{background-color:#e8f5e8;color:var(--success-color);padding:12px 20px;margin:20px 0;border-radius:var(--border-radius);border-left:4px solid var(--success-color);box-shadow:var(--shadow-sm);font-weight:500}.error-message{background-color:#ffebee;color:var(--error-color);padding:12px 20px;margin:20px 0;border-radius:var(--border-radius);border-left:4px solid var(--error-color);box-shadow:var(--shadow-sm);font-weight:500}.tab-container{background:var(--bg-white);border-radius:var(--border-radius);box-shadow:var(--shadow-md);overflow:hidden;width:100%;box-sizing:border-box}.tab-navigation{display:flex;background-color:var(--bg-light);border-bottom:2px solid var(--border-color)}.tab-btn{flex:1;padding:16px 24px;background:transparent;border:none;color:var(--text-light);font-size:16px;font-weight:500;cursor:pointer;transition:var(--transition);border-bottom:3px solid transparent}.tab-btn:hover{color:var(--primary-color);background-color:#646cff0d}.tab-btn.active{color:var(--primary-color);background-color:var(--bg-white);border-bottom-color:var(--primary-color);box-shadow:0 -2px 0 var(--primary-color) inset}.tab-content{padding:30px;max-width:100%;box-sizing:border-box}.upload-section{background:var(--bg-white)}.upload-form{display:flex;flex-direction:column;gap:19px;max-width:640px;background:var(--bg-white);padding:24px;border-radius:var(--border-radius);box-shadow:var(--shadow-md);border:1px solid var(--border-color)}.form-row{display:flex;gap:20px;flex-wrap:wrap}.form-group{display:flex;flex-direction:column;gap:8px;flex:1;min-width:250px}.flex-1{flex:1}.form-group label{font-weight:600;color:var(--text-color);font-size:14px;display:block;margin-bottom:8px}.form-input{width:100%;padding:11px 13px;border:2px solid var(--border-color);border-radius:var(--border-radius);font-size:14px;color:var(--text-color);transition:var(--transition);background:var(--bg-white);font-family:inherit}.form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #646cff1a}.form-input:disabled{background-color:var(--bg-light);cursor:not-allowed;opacity:.7}.file-input{width:100%;padding:16px;border:2px dashed var(--border-color);border-radius:var(--border-radius);background:var(--bg-light);cursor:pointer;transition:var(--transition);font-size:12px;text-align:center;color:var(--text-light)}.file-input:hover{border-color:var(--primary-color);background:#646cff0d;color:var(--primary-color)}.file-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #646cff1a}.file-preview{margin-top:12px;padding:12px 16px;background:var(--bg-light);border-radius:var(--border-radius);display:flex;align-items:center;gap:12px;border:1px solid var(--border-color);transition:var(--transition)}.image-preview-container{flex-shrink:0;width:60px;height:60px;border-radius:var(--border-radius);overflow:hidden;border:1px solid var(--border-color);background-color:#fff;display:flex;align-items:center;justify-content:center}.image-preview{width:100%;height:100%;object-fit:cover;transition:var(--transition)}.file-preview:hover .image-preview{transform:scale(1.05)}.file-preview:hover{background-color:#646cff0d;border-color:var(--primary-color)}.file-name{font-weight:600;color:var(--text-color);font-size:14px;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size{font-size:12px;color:var(--text-light)}.files-preview{margin-top:16px;padding:16px;background:var(--bg-light);border-radius:var(--border-radius);border:1px solid var(--border-color)}.files-preview h4{margin:0 0 12px;font-size:16px;color:var(--text-color);font-weight:600}.files-list{display:flex;flex-direction:column;gap:8px;max-height:200px;overflow-y:auto}.files-list .file-preview{margin-top:0;border:1px solid transparent}.primary-btn{padding:11px 26px;background-color:var(--primary-color);color:#fff;border:none;border-radius:var(--border-radius);cursor:pointer;font-size:14px;font-weight:600;transition:var(--transition);box-shadow:var(--shadow-sm);min-width:120px;display:inline-flex;align-items:center;justify-content:center;gap:6px}.primary-btn:hover{background-color:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.primary-btn:disabled{background-color:var(--border-color);cursor:not-allowed;transform:none;box-shadow:none;opacity:.7}.upload-btn{padding:11px 26px;background-color:var(--primary-color);color:#fff;border:none;border-radius:var(--border-radius);cursor:pointer;font-size:14px;font-weight:600;transition:var(--transition);box-shadow:var(--shadow-sm);min-width:120px;display:inline-flex;align-items:center;justify-content:center;gap:6px}.upload-btn:hover{background-color:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.upload-btn:disabled{background-color:var(--border-color);cursor:not-allowed;transform:none;box-shadow:none;opacity:.7}.form-actions{display:flex;gap:16px;justify-content:flex-start;align-items:center;margin-top:8px;padding-top:20px;border-top:1px solid var(--border-color)}@media (max-width: 768px){.upload-form{padding:20px;gap:20px}.form-row{flex-direction:column;gap:20px}.form-group{min-width:auto}.form-actions{justify-content:stretch}.primary-btn,.upload-btn{flex:1;min-width:auto}}.list-section{background:var(--bg-white)}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:15px}.list-header .header-left{display:flex;align-items:center;gap:15px;flex-shrink:0}.list-header .filter-group{display:flex;align-items:center;gap:12px;flex-wrap:nowrap}.list-header h2{margin:0;font-size:20px;color:var(--text-color);font-weight:600}.filter-select-wrapper{position:relative;display:inline-block}.factory-filter-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding:10px 40px 10px 16px;border:2px solid var(--border-color);border-radius:var(--border-radius);font-size:14px;color:var(--text-color);background-color:var(--card-bg);cursor:pointer;transition:var(--transition);min-width:150px}.factory-filter-select:hover{border-color:var(--primary-color)}.factory-filter-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #1891ff1a}.filter-icon{position:absolute;right:14px;top:50%;transform:translateY(-50%);pointer-events:none;color:var(--text-secondary);font-size:10px}.filter-section{display:flex;gap:15px;align-items:center;flex-wrap:wrap}.date-filter{display:flex;align-items:center;gap:10px}.date-input{padding:10px 16px;border:2px solid var(--border-color);border-radius:var(--border-radius);font-size:14px;color:var(--text-color);background-color:var(--card-bg);cursor:pointer;transition:var(--transition)}.date-input:hover{border-color:var(--primary-color)}.date-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #1891ff1a}.date-separator{color:var(--text-secondary);font-size:14px}.export-btn{padding:10px 20px;background-color:var(--primary-color);color:#fff;border:none;border-radius:var(--border-radius);font-size:14px;cursor:pointer;transition:var(--transition)}.export-btn:hover{background-color:#40a9ff}.export-btn:disabled{background-color:#ccc;cursor:not-allowed}.filter-select{padding:10px 16px;border:2px solid var(--border-color);border-radius:var(--border-radius);font-size:14px;color:var(--text-color);transition:var(--transition);background:var(--bg-white);min-width:150px}.filter-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #646cff1a}.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px;margin-top:20px}.image-card{background:var(--bg-white);border:1px solid var(--border-color);border-radius:var(--border-radius);overflow:hidden;transition:var(--transition);box-shadow:var(--shadow-sm);display:flex;flex-direction:column}.image-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--primary-color)}.image-wrapper{width:100%;padding-bottom:100%;position:relative;overflow:hidden;background:var(--bg-light);display:flex;align-items:center;justify-content:center}.image-wrapper img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:contain;transition:var(--transition);background:#fff}.image-card:hover .image-wrapper img{transform:scale(1.05)}.so-image-indicator{position:absolute;top:8px;right:8px;z-index:10}.so-badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 8px;background:linear-gradient(135deg,#ff6b6b,#ee5a5a);color:#fff;font-size:11px;font-weight:700;border-radius:4px;box-shadow:0 2px 8px #ee5a5a66;letter-spacing:.5px}.image-info{padding:16px;flex:1;display:flex;flex-direction:column}.image-info h3{margin:0 0 8px;font-size:16px;color:var(--text-color);font-weight:600;line-height:1.4;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.pattern-code{font-size:13px;color:var(--text-light);margin:0 0 12px;font-family:Courier New,monospace}.image-actions{display:flex;gap:10px;margin-top:auto}.delete-btn{flex:1;padding:10px;background-color:var(--error-color);color:#fff;border:none;border-radius:var(--border-radius);cursor:pointer;font-size:14px;font-weight:500;transition:var(--transition);box-shadow:var(--shadow-sm)}.delete-btn:hover{background-color:#d32f2f;transform:translateY(-1px);box-shadow:var(--shadow-md)}.delete-btn:disabled{background-color:var(--border-color);cursor:not-allowed;transform:none;box-shadow:none}.empty-state{text-align:center;padding:60px 20px;color:var(--text-light);font-size:18px;background:var(--bg-light);border-radius:var(--border-radius);border:2px dashed var(--border-color);margin-top:20px}.loading{text-align:center;padding:60px 20px;color:var(--text-color);font-size:18px;font-weight:600;margin-top:20px}.orders-section{background:var(--bg-white);padding:20px;border-radius:var(--border-radius);box-shadow:var(--shadow-sm)}.orders-table-container{margin-top:20px;overflow-x:auto;background:var(--bg-white);border-radius:var(--border-radius);box-shadow:var(--shadow-sm)}.orders-table{width:100%;border-collapse:collapse;font-size:14px}.orders-table th,.orders-table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border-color)}.orders-table th{background-color:var(--bg-light);font-weight:600;color:var(--text-color);position:sticky;top:0;z-index:10}.orders-table tr:last-child td{border-bottom:none}.order-row{transition:background-color .2s}.order-row:hover{background-color:#646cff0d}.order-status{display:inline-block;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:capitalize}.order-status.draft{background-color:#fff3cd;color:#856404;border:1px solid #ffeeba}.order-status.submitted{background-color:#d1ecf1;color:#0c5460;border:1px solid #bee5eb}.order-status.processed{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.view-details-btn{padding:6px 12px;background-color:var(--primary-color);color:#fff;border:none;border-radius:var(--border-radius);cursor:pointer;font-size:12px;font-weight:500;transition:var(--transition);box-shadow:var(--shadow-sm)}.view-details-btn:hover{background-color:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;overflow-y:auto}.modal-content{background:var(--bg-white);border-radius:var(--border-radius);box-shadow:0 10px 25px #00000026;width:100%;max-width:700px;max-height:85vh;overflow-y:auto;position:relative;animation:modalFadeIn .3s ease-out}@keyframes modalFadeIn{0%{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-color);background:var(--bg-light);position:sticky;top:0;z-index:10}.modal-header h3{margin:0;font-size:18px;color:var(--text-color);font-weight:600}.close-btn{background:none;border:none;font-size:22px;color:var(--text-light);cursor:pointer;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.close-btn:hover{background-color:#0000000d;color:var(--text-color)}.modal-body{padding:20px}.message-modal{max-width:400px}.message-modal .modal-body{padding:20px;text-align:center}.success-message-content{color:#10b981;font-size:16px;margin-bottom:10px}.error-message-content{color:#ef4444;font-size:16px;margin-bottom:10px}.confirm-message-content{color:var(--text-color);font-size:16px;line-height:1.5;margin-bottom:10px;text-align:left}.modal-footer{padding:16px 20px;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:10px}.modal-content .form-group{margin-bottom:16px}.modal-content .form-group label{margin-bottom:6px}.modal-content .form-input{padding:10px 12px}.modal-content .form-actions{margin-top:20px}.order-details-info{background:var(--bg-light);padding:20px;border-radius:var(--border-radius);margin-bottom:24px}.detail-row{display:flex;margin-bottom:12px;align-items:center;flex-wrap:wrap}.detail-row:last-child{margin-bottom:0}.detail-label{font-weight:600;color:var(--text-color);min-width:120px;margin-right:12px}.detail-value{color:var(--text-color);flex:1}.order-items-section{margin-top:24px}.order-items-section h4{margin:0 0 16px;font-size:16px;color:var(--text-color);font-weight:600}.order-items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}.order-item-card{background:var(--bg-white);border:1px solid var(--border-color);border-radius:var(--border-radius);overflow:hidden;transition:var(--transition);box-shadow:var(--shadow-sm)}.order-item-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--primary-color)}.item-image{width:100%;height:150px;background:var(--bg-light);display:flex;align-items:center;justify-content:center;overflow:hidden}.item-image img{width:100%;height:100%;object-fit:contain;background:#fff}.item-info{padding:12px}.item-name{margin:0 0 4px;font-size:14px;font-weight:600;color:var(--text-color);line-height:1.4;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.item-code{margin:0 0 4px;font-size:12px;color:var(--text-light);font-family:Courier New,monospace}.item-category{margin:0;font-size:12px;color:var(--text-light)}.empty-state.small{padding:30px 20px;font-size:16px}.modal-tabs{display:flex;background-color:var(--bg-light);border-bottom:1px solid var(--border-color)}.modal-tab-btn{padding:12px 24px;background:transparent;border:none;color:var(--text-light);font-size:14px;font-weight:500;cursor:pointer;transition:var(--transition);border-bottom:2px solid transparent}.modal-tab-btn:hover{color:var(--primary-color);background-color:#646cff0d}.modal-tab-btn.active{color:var(--primary-color);background-color:var(--bg-white);border-bottom-color:var(--primary-color)}.operation-logs-section{background:var(--bg-white);padding:20px;border-radius:var(--border-radius)}.operation-logs-section h4{margin:0 0 16px;font-size:16px;color:var(--text-color);font-weight:600}.logs-table-container{overflow-x:auto;background:var(--bg-white);border-radius:var(--border-radius);box-shadow:var(--shadow-sm)}.logs-table{width:100%;border-collapse:collapse;font-size:14px}.logs-table th,.logs-table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border-color)}.logs-table th{background-color:var(--bg-light);font-weight:600;color:var(--text-color);position:sticky;top:0;z-index:10}.logs-table tr:last-child td{border-bottom:none}.log-row{transition:background-color .2s}.log-row:hover{background-color:#646cff0d}.log-type{display:inline-block;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;background-color:var(--bg-light);color:var(--text-color);text-transform:capitalize}@media (max-width: 768px){.logs-table{font-size:12px}.logs-table th,.logs-table td{padding:8px 12px}.log-type{padding:2px 8px;font-size:10px}.logs-table th:nth-child(5),.logs-table td:nth-child(5){display:none}}@media (max-width: 480px){.logs-table th:nth-child(3),.logs-table td:nth-child(3){display:none}}@media (max-width: 768px){.orders-table{font-size:12px}.orders-table th,.orders-table td{padding:8px 12px}.order-status{padding:2px 8px;font-size:10px}.modal-overlay{padding:10px}.modal-header,.modal-body{padding:16px}.detail-row{flex-direction:column;align-items:flex-start;gap:4px}.detail-label{min-width:auto;margin-right:0}.order-items-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.item-image{height:120px}}@media (max-width: 480px){.orders-table th:nth-child(6),.orders-table td:nth-child(6){display:none}.order-items-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px}}.login-container{max-width:420px;margin:60px auto;padding:40px;background-color:var(--bg-white);box-shadow:var(--shadow-lg);border-radius:var(--border-radius);text-align:center;width:100%}.login-container h1{color:var(--primary-color);margin-bottom:30px;font-size:28px;font-weight:700}.login-form{display:flex;flex-direction:column;gap:20px;margin-top:20px;align-items:stretch}.login-form .form-group{display:flex;flex-direction:column;text-align:left;align-items:stretch;gap:8px}.login-form label{font-weight:600;color:var(--text-color);font-size:14px}.login-form input{padding:14px 16px;border:2px solid var(--border-color);border-radius:var(--border-radius);font-size:16px;color:var(--text-color);transition:var(--transition);background:var(--bg-white)}.login-form input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #646cff1a}.login-btn{padding:14px;background-color:var(--primary-color);color:#fff;border:none;border-radius:var(--border-radius);cursor:pointer;font-size:16px;font-weight:600;transition:var(--transition);box-shadow:var(--shadow-sm);margin-top:10px}.login-btn:hover{background-color:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.login-hint{margin-top:24px;padding:20px;background-color:var(--bg-light);border-radius:var(--border-radius);font-size:14px;color:var(--text-light);text-align:left;border-left:4px solid var(--secondary-color)}.login-hint p{margin:8px 0;line-height:1.6}html,body{margin:0;padding:0;width:100%;height:100%;overflow-x:hidden}body{display:flex;flex-direction:column;min-width:320px;min-height:100vh;background-color:var(--bg-light);color:var(--text-color);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;box-sizing:border-box}#root{display:flex;flex-direction:column;width:100%;height:100%;margin:0;padding:0;box-sizing:border-box;flex:1}*{box-sizing:border-box}.categories-section{background:var(--bg-white);padding:20px;border-radius:var(--border-radius);box-shadow:var(--shadow-sm)}.categories-list{display:flex;flex-direction:column;gap:24px;margin-top:20px}.category-card{background:var(--bg-white);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:24px;box-shadow:var(--shadow-sm);transition:var(--transition)}.category-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--primary-color)}.category-header{margin-bottom:20px}.category-header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.category-actions{display:flex;gap:8px}.category-actions .edit-btn,.category-actions .delete-btn{padding:8px 16px;font-size:14px;font-weight:500;border-radius:6px;min-width:auto;flex:none;box-shadow:var(--shadow-sm)}.category-actions .edit-btn{background-color:var(--primary-color);color:#fff;border:none}.category-actions .edit-btn:hover{background-color:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.category-actions .delete-btn{background-color:var(--error-color);color:#fff;border:none}.category-actions .delete-btn:hover{background-color:#d32f2f;transform:translateY(-1px);box-shadow:var(--shadow-md)}.category-header h3{margin:0;font-size:20px;color:var(--text-color);font-weight:600}.category-prefix{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;background-color:var(--primary-color);color:#fff;font-size:18px;font-weight:700;border-radius:50%;box-shadow:var(--shadow-sm)}.category-description{margin:0;color:var(--text-light);font-size:14px;line-height:1.5}.subcategories-list{margin-top:20px;padding-top:20px;border-top:1px solid var(--border-color)}.subcategories-list h4{margin:0 0 16px;font-size:16px;color:var(--text-color);font-weight:600}.subcategory-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}.subcategory-card{background:var(--bg-white);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:20px;transition:var(--transition);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:12px}.subcategory-card:hover{border-color:var(--primary-color);box-shadow:var(--shadow-md);transform:translateY(-2px)}.subcategory-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.subcategory-name{font-weight:600;color:var(--text-color);font-size:16px;flex:1;margin-right:12px;line-height:1.4}.subcategory-description{margin:0;color:var(--text-light);font-size:14px;line-height:1.5;flex:1}.subcategory-actions{display:flex;gap:8px;flex-shrink:0}.subcategory-actions .edit-btn,.subcategory-actions .delete-btn{padding:6px 12px;font-size:12px;font-weight:500;border-radius:6px;min-width:auto;flex:none;box-shadow:var(--shadow-sm)}.subcategory-actions .edit-btn{background-color:var(--primary-color);color:#fff;border:none}.subcategory-actions .edit-btn:hover{background-color:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.subcategory-actions .delete-btn{background-color:var(--error-color);color:#fff;border:none}.subcategory-actions .delete-btn:hover{background-color:#d32f2f;transform:translateY(-1px);box-shadow:var(--shadow-md)}.button-group{display:flex;gap:12px;flex-wrap:wrap}.add-btn{padding:10px 20px;background-color:var(--primary-color);color:#fff;border:none;border-radius:var(--border-radius);cursor:pointer;font-size:14px;font-weight:500;transition:var(--transition);box-shadow:var(--shadow-sm)}.add-btn:hover{background-color:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.add-category-form,.add-subcategory-form{display:flex;flex-direction:column;gap:20px}.form-group textarea{padding:12px 16px;border:2px solid var(--border-color);border-radius:var(--border-radius);font-size:16px;color:var(--text-color);transition:var(--transition);resize:vertical;min-height:80px;font-family:inherit}.form-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #646cff1a}.form-hint{font-size:12px;color:var(--text-light);margin-top:4px;margin-bottom:0}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:10px}.cancel-btn{padding:10px 20px;background-color:var(--bg-light);color:var(--text-color);border:1px solid var(--border-color);border-radius:var(--border-radius);cursor:pointer;font-size:14px;font-weight:500;transition:var(--transition)}.cancel-btn:hover{background-color:var(--border-color)}.save-btn{padding:10px 20px;background-color:var(--primary-color);color:#fff;border:none;border-radius:var(--border-radius);cursor:pointer;font-size:14px;font-weight:500;transition:var(--transition);box-shadow:var(--shadow-sm)}.save-btn:hover{background-color:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.save-btn:disabled{background-color:var(--border-color);cursor:not-allowed;transform:none;box-shadow:none}.edit-btn{flex:1;padding:10px;background-color:var(--primary-color);color:#fff;border:none;border-radius:var(--border-radius);cursor:pointer;font-size:14px;font-weight:500;transition:var(--transition);box-shadow:var(--shadow-sm)}.edit-btn:hover{background-color:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.edit-btn:disabled{background-color:var(--border-color);cursor:not-allowed;transform:none;box-shadow:none}@media (max-width: 768px){.container{padding:15px}.header{flex-direction:column;gap:15px;text-align:center}.tab-btn{padding:12px 16px;font-size:14px}.tab-content{padding:20px}.list-header,.filter-section{flex-direction:column;align-items:stretch}.filter-select{min-width:auto}.image-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.upload-btn{align-self:stretch}.login-container{margin:30px auto;padding:25px}.category-header-top{flex-direction:column;align-items:flex-start;gap:12px}.subcategory-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.button-group{justify-content:stretch}.add-btn{flex:1}}@media (max-width: 480px){.image-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.tab-content{padding:15px}.header h1{font-size:1.5em}.category-card{padding:16px}.subcategory-grid{grid-template-columns:1fr}.form-actions{flex-direction:column}.cancel-btn,.save-btn{width:100%}}.factory-card{background:linear-gradient(135deg,#f8f9fa,#fff);border:2px solid #e3e8ee;border-radius:16px;padding:24px;margin-bottom:24px;box-shadow:0 4px 12px #00000014;transition:all .3s ease;position:relative;overflow:hidden}.factory-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary-color),var(--secondary-color))}.factory-card:hover{box-shadow:0 8px 24px #0000001f;border-color:var(--primary-color)}.factory-header{margin-bottom:20px}.factory-header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.factory-header h3{margin:0;font-size:22px;color:var(--text-color);font-weight:700;display:flex;align-items:center;gap:10px}.factory-header h3:before{content:"🏭";font-size:24px}.factory-actions{display:flex;gap:8px}.factory-actions .edit-btn,.factory-actions .delete-btn{padding:8px 16px;font-size:13px;font-weight:500;border-radius:8px;min-width:auto;flex:none;box-shadow:var(--shadow-sm)}.factory-actions .edit-btn{background-color:#4a90d9;color:#fff;border:none}.factory-actions .edit-btn:hover{background-color:#357abd;transform:translateY(-1px);box-shadow:var(--shadow-md)}.factory-actions .delete-btn{background-color:#e74c3c;color:#fff;border:none}.factory-actions .delete-btn:hover{background-color:#c0392b;transform:translateY(-1px);box-shadow:var(--shadow-md)}.factory-description{color:#666;font-size:14px;margin:0;padding-left:34px}.categories-under-factory{margin-top:20px;padding-top:16px;border-top:1px dashed #e0e0e0}.categories-under-factory h4{margin:0 0 16px;font-size:15px;color:#888;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.category-item-card{background:#fff;border:1px solid #e8ecf1;border-radius:12px;padding:16px;box-shadow:0 2px 8px #0000000f;transition:all .2s ease;position:relative}.category-item-card:before{content:"";position:absolute;left:0;top:12px;bottom:12px;width:4px;background:var(--primary-color);border-radius:0 4px 4px 0}.category-item-card:hover{box-shadow:0 4px 16px #0000001a;border-color:var(--primary-color);transform:translateY(-2px)}.category-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;padding-left:12px}.category-item-name{font-size:16px;font-weight:600;color:var(--text-color)}.category-item-actions{display:flex;gap:6px}.category-item-actions .edit-btn,.category-item-actions .delete-btn{padding:6px 12px;font-size:12px;font-weight:500;border-radius:6px;min-width:auto;flex:none}.category-item-actions .edit-btn{background-color:#f0f4f8;color:#4a90d9;border:1px solid #d0dae6}.category-item-actions .edit-btn:hover{background-color:#4a90d9;color:#fff;border-color:#4a90d9}.category-item-actions .delete-btn{background-color:#fef2f2;color:#e74c3c;border:1px solid #fecaca}.category-item-actions .delete-btn:hover{background-color:#e74c3c;color:#fff;border-color:#e74c3c}.category-item-description{font-size:13px;color:#888;margin:0;padding-left:12px;line-height:1.4}.empty-state{text-align:center;padding:40px 20px;color:#888}.empty-state p{margin:0;font-size:16px}.pagination-container{display:flex;flex-direction:column;align-items:center;gap:12px;margin-top:24px;padding:20px;background:#f8f9fa;border-radius:12px}.pagination-info{font-size:14px;color:#666}.pagination-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:center}.pagination-btn{padding:8px 16px;border:1px solid #e0e0e0;background:#fff;color:#333;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s ease}.pagination-btn:hover:not(:disabled){background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.page-numbers{display:flex;gap:4px}.page-number{min-width:36px;height:36px;border:1px solid #e0e0e0;background:#fff;color:#333;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s ease}.page-number:hover{background:#f0f0f0}.page-number.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.page-size-select{padding:8px 12px;border:1px solid #e0e0e0;background:#fff;color:#333;border-radius:6px;cursor:pointer;font-size:14px;margin-left:8px}.page-size-select:focus{outline:none;border-color:var(--primary-color)}@media (max-width: 768px){.pagination-controls{gap:6px}.pagination-btn{padding:6px 12px;font-size:13px}.page-number{min-width:32px;height:32px;font-size:13px}}
