.d9-container { max-width: 1200px; margin: auto; padding: 20px; }
.d9-toolbar { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 15px; background: #f8f9fa; padding: 20px; border-radius: 12px; margin-bottom: 25px; }
.tool-group { display: flex; gap: 10px; }

.d9-btn { padding: 8px 18px; border-radius: 6px; border: none; font-weight: 600; cursor: pointer; transition: 0.3s; }
.primary { background: #007bff; color: white; }
.secondary { background: #28a745; color: white; }
.outline { background: white; border: 1px solid #dee2e6; color: #444; }
.active { border: 2px solid #007bff !important; }

#main-product-table { width: 100%; border-collapse: collapse; background: white; }
#main-product-table th { background: #f1f3f5; padding: 12px; border-bottom: 2px solid #ddd; }
#main-product-table td { padding: 12px; border-bottom: 1px solid #eee; vertical-align: middle; }

.d9-zoom-wrapper { width: 60px; height: 60px; border: 1px solid #eee; overflow: hidden; border-radius: 6px; cursor: pointer; }
.d9-thumb { width: 100%; height: 100%; object-fit: contain; background: #fff; }

.stock-badge { background: #e3f2fd; color: #0d47a1; padding: 4px 10px; border-radius: 20px; font-size: 11px; font-weight: bold; }
.d9-price-input { padding: 6px; width: 100px; border: 1px solid #ccc; border-radius: 4px; text-align: right; }

.d9-pagination { display: flex; justify-content: center; gap: 8px; margin-top: 30px; }
.d9-modal { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.7); display: none; align-items: center; justify-content: center; z-index: 9999; }
.d9-modal-content { background: #fff; padding: 30px; border-radius: 12px; width: 350px; text-align: center; }