.scene-database-panel-body {
  display: grid;
  gap: 8px;
}

.scene-database-products-list {
  display: grid;
  gap: 8px;
}

.scene-database-product-thumb {
  align-self: start;
  height: 52px;
  min-height: 52px;
}

.scene-database-product-item .plugin-filter-item-fields {
  gap: 3px;
}

.scene-database-product-item .scene-database-product-binding {
  color: rgba(0, 122, 255, 0.86);
}

#sceneDatabaseProductModal.modal-backdrop {
  z-index: 90;
  background: rgba(6, 10, 16, 0.64);
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
}

#sceneDatabaseProductModal .scene-database-product-modal {
  position: relative;
  display: grid;
  width: min(940px, calc(100vw - 36px));
  max-height: calc(100dvh - 48px);
  padding: 0;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 16px;
  background: linear-gradient(180deg, rgb(15, 15, 15), rgb(10, 10, 10));
  box-shadow: 0 28px 80px rgba(0, 0, 0, 0.52);
  color: rgb(255, 255, 255);
  -webkit-backdrop-filter: none;
  backdrop-filter: none;
}

#sceneDatabaseProductModal .scene-database-product-modal.has-image {
  grid-template-columns: 1fr;
}

.scene-database-product-modal-close {
  position: absolute;
  z-index: 2;
  top: 12px;
  right: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: rgba(24, 24, 24, 0.88);
  color: rgb(255, 255, 255);
}

.scene-database-product-modal-close:hover,
.scene-database-product-modal-close:focus-visible {
  background: rgba(36, 36, 36, 0.96);
  outline: none;
}

.scene-database-product-modal-image {
  min-width: 0;
  padding: 18px 18px 0;
  background: transparent;
}

.scene-database-product-modal-images {
  display: flex;
  gap: 12px;
  min-width: 0;
  overflow-x: auto;
  overscroll-behavior-x: contain;
  padding: 0 48px 4px 0;
  scroll-snap-type: x proximity;
}

.scene-database-product-modal-image-frame {
  display: block;
  flex: 0 0 min(360px, 72vw);
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 12px;
  background: rgb(8, 8, 8);
  box-shadow: 0 16px 36px rgba(0, 0, 0, 0.28);
  scroll-snap-align: start;
}

.scene-database-product-modal-image-frame img {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
}

.scene-database-product-modal-body {
  display: flex;
  flex-direction: column;
  align-content: start;
  gap: 12px;
  min-width: 0;
  min-height: 230px;
  padding: 28px 36px 32px;
}

.scene-database-product-modal-body > span {
  color: rgba(255, 255, 255, 0.48);
  font-size: 0.72rem;
  font-weight: 750;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.scene-database-product-modal-body h3 {
  margin: 0;
  padding-right: 34px;
  color: rgba(255, 255, 255, 0.96);
  font-size: 1.55rem;
  font-weight: 760;
  line-height: 1.18;
}

.scene-database-product-modal-body p {
  margin: 0;
  color: rgba(255, 255, 255, 0.66);
  font-size: 0.95rem;
  font-weight: 550;
  line-height: 1.45;
}

.scene-database-product-modal-badges {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
  margin-top: auto;
  order: 3;
}

.scene-database-product-modal-badges span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 34px;
  padding: 0 12px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.07);
  color: rgb(255, 255, 255);
}

.scene-database-product-modal-badges small {
  color: rgba(255, 255, 255, 0.48);
  font-size: 0.66rem;
  font-weight: 780;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.scene-database-product-modal-badges strong {
  color: rgba(255, 255, 255, 0.92);
  font-size: 0.82rem;
  font-weight: 760;
  line-height: 1;
}

.scene-database-product-modal-fields {
  display: grid;
  gap: 8px;
  margin: 6px 0 0;
  order: 2;
}

.scene-database-product-modal-fields div {
  display: grid;
  grid-template-columns: 96px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  min-height: 38px;
  padding: 10px 12px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 8px;
  background: rgb(18, 18, 18);
}

.scene-database-product-modal-fields dt,
.scene-database-product-modal-fields dd {
  min-width: 0;
  margin: 0;
}

.scene-database-product-modal-fields dt {
  color: rgba(255, 255, 255, 0.48);
  font-size: 0.7rem;
  font-weight: 780;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.scene-database-product-modal-fields dd {
  overflow-wrap: anywhere;
  color: rgba(255, 255, 255, 0.86);
  font-size: 0.82rem;
  font-weight: 650;
  line-height: 1.3;
}

#sceneDatabaseModal.modal-backdrop {
  background: rgba(6, 10, 16, 0.62);
  -webkit-backdrop-filter: blur(5px);
  backdrop-filter: blur(5px);
}

#sceneDatabaseModal .scene-database-modal {
  display: flex;
  flex-direction: column;
  width: min(1240px, calc(100vw - 32px));
  min-height: 420px;
  max-height: calc(100dvh - 48px);
  padding: 0;
  overflow: hidden;
  background: rgb(12, 12, 12);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.46);
  color: rgb(255, 255, 255);
  -webkit-backdrop-filter: none;
  backdrop-filter: none;
}

#sceneDatabaseModal .modal-header {
  flex: 0 0 auto;
  margin: 0;
  padding: 16px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

#sceneDatabaseModal .modal-header h3 {
  margin: 0;
  color: rgb(255, 255, 255);
  font-size: 1rem;
  font-weight: 650;
  line-height: 1.2;
}

#sceneDatabaseModal .modal-close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 32px;
  width: 32px;
  height: 32px;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: rgb(30, 30, 30);
  color: rgb(255, 255, 255);
  line-height: 0;
}

#sceneDatabaseModal .modal-close:hover,
#sceneDatabaseModal .modal-close:focus-visible {
  background: rgb(38, 38, 38);
  outline: none;
}

.scene-database-modal-body {
  display: grid;
  align-items: stretch;
  flex: 1 1 auto;
  min-height: 0;
  padding: 18px;
  overflow: auto;
  background: rgb(12, 12, 12);
}

.scene-database-empty-state {
  display: grid;
  justify-items: center;
  gap: 8px;
  max-width: 460px;
  margin: 0 auto;
  padding: 32px 24px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.035);
  text-align: center;
}

.scene-database-empty-state span {
  color: rgba(255, 255, 255, 0.48);
  font-size: 0.72rem;
  font-weight: 750;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.scene-database-empty-state strong {
  color: rgba(255, 255, 255, 0.94);
  font-size: 1.08rem;
  font-weight: 750;
  line-height: 1.2;
}

.scene-database-empty-state p {
  max-width: 42ch;
  margin: 0;
  color: rgba(255, 255, 255, 0.58);
  font-size: 0.84rem;
  font-weight: 500;
  line-height: 1.45;
}

.scene-database-empty-state small {
  color: rgba(255, 255, 255, 0.42);
  font-size: 0.74rem;
  font-weight: 600;
}

.scene-database-loading-state {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 220px;
  width: 100%;
}

.scene-database-loading-state img {
  width: 38px;
  height: 38px;
}

.scene-database-primary-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  margin-top: 8px;
  padding: 0 16px;
  border: 0;
  border-radius: 999px;
  background: #007aff;
  color: rgb(255, 255, 255);
  font-size: 0.84rem;
  font-weight: 750;
  cursor: pointer;
}

.scene-database-primary-action:hover,
.scene-database-primary-action:focus-visible {
  background: #1687ff;
  outline: none;
}

.scene-database-workspace {
  display: grid;
  align-self: start;
  gap: 14px;
  width: 100%;
}

.scene-database-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 16px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.035);
}

.scene-database-summary div {
  display: grid;
  gap: 4px;
}

.scene-database-summary span,
.scene-database-table-card span {
  color: rgba(255, 255, 255, 0.48);
  font-size: 0.72rem;
  font-weight: 750;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.scene-database-summary strong,
.scene-database-table-card strong {
  color: rgba(255, 255, 255, 0.94);
  font-size: 0.95rem;
  font-weight: 750;
}

.scene-database-summary small,
.scene-database-table-card small {
  color: rgba(255, 255, 255, 0.52);
  font-size: 0.78rem;
  font-weight: 650;
  white-space: nowrap;
}

.scene-database-table-list {
  display: grid;
  gap: 8px;
}

.scene-database-table-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  min-height: 64px;
  padding: 12px 14px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 10px;
  background: rgb(18, 18, 18);
}

.scene-database-table-card div {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.scene-database-table-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.scene-database-table-tabs button,
.scene-database-row-actions button,
.scene-database-field-row button,
.scene-database-binding-row button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 0 12px;
  border: 0;
  border-radius: 999px;
  background: rgb(30, 30, 30);
  color: rgb(255, 255, 255);
  font-size: 0.78rem;
  font-weight: 750;
  cursor: pointer;
}

.scene-database-table-tabs button.active,
.scene-database-row-actions button[type="submit"],
.scene-database-field-row button[type="submit"] {
  background: #007aff;
}

.scene-database-table-tabs button:hover,
.scene-database-table-tabs button:focus-visible,
.scene-database-row-actions button:hover,
.scene-database-row-actions button:focus-visible,
.scene-database-field-row button:hover,
.scene-database-field-row button:focus-visible,
.scene-database-binding-row button:hover,
.scene-database-binding-row button:focus-visible {
  background: rgb(42, 42, 42);
  outline: none;
}

.scene-database-table-tabs button.active:hover,
.scene-database-table-tabs button.active:focus-visible,
.scene-database-row-actions button[type="submit"]:hover,
.scene-database-row-actions button[type="submit"]:focus-visible,
.scene-database-field-row button[type="submit"]:hover,
.scene-database-field-row button[type="submit"]:focus-visible {
  background: #1687ff;
}

.scene-database-row-actions button:disabled,
.scene-database-field-row button:disabled,
.scene-database-table-tabs button:disabled {
  cursor: not-allowed;
  opacity: 0.72;
}

.scene-database-table-tabs button:disabled.active {
  cursor: default;
  opacity: 1;
}

.scene-database-message {
  margin: 0;
  padding: 10px 12px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.035);
  color: rgba(255, 255, 255, 0.66);
  font-size: 0.8rem;
  font-weight: 650;
}

.scene-database-message.is-success {
  border-color: rgba(0, 122, 255, 0.36);
  color: rgba(215, 234, 255, 0.92);
}

.scene-database-message.is-error {
  border-color: rgba(255, 79, 79, 0.36);
  color: rgba(255, 210, 210, 0.95);
}

.scene-database-editor-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  align-items: start;
}

.scene-database-editor-card {
  display: grid;
  gap: 12px;
  min-width: 0;
  padding: 0;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 10px;
  background: rgb(18, 18, 18);
}

.scene-database-editor-card:nth-child(2) {
  grid-row: auto;
}

.scene-database-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: 58px;
  padding: 12px 14px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.scene-database-card-header div {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.scene-database-card-header span,
.scene-database-binding-row span,
.scene-database-target-strip span,
.scene-database-cell span {
  color: rgba(255, 255, 255, 0.48);
  font-size: 0.68rem;
  font-weight: 750;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.scene-database-card-header strong,
.scene-database-binding-row strong,
.scene-database-target-strip strong {
  color: rgba(255, 255, 255, 0.92);
  font-size: 0.9rem;
  font-weight: 750;
}

.scene-database-card-header small {
  color: rgba(255, 255, 255, 0.52);
  font-size: 0.76rem;
  font-weight: 650;
  white-space: nowrap;
}

.scene-database-field-list,
.scene-database-row-list,
.scene-database-binding-list {
  display: grid;
  gap: 10px;
  padding: 0 14px;
}

.scene-database-row-list {
  gap: 14px;
  padding-bottom: 14px;
}

.scene-database-binding-list {
  padding-bottom: 12px;
}

.scene-database-field-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(120px, 0.5fr) 104px 86px 92px;
  gap: 10px;
  align-items: center;
}

.scene-database-field-row.is-new {
  margin: 0 14px 14px;
}

.scene-database-field-row input[type="text"],
.scene-database-field-row select,
.scene-database-target-select,
.scene-database-cell input,
.scene-database-cell textarea {
  width: 100%;
  min-width: 0;
  min-height: 36px;
  padding: 0 10px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 8px;
  background: rgb(12, 12, 12);
  color: rgb(255, 255, 255);
  font-size: 0.82rem;
  font-weight: 600;
}

.scene-database-cell textarea {
  min-height: 118px;
  padding-top: 10px;
  padding-bottom: 10px;
  line-height: 1.4;
  resize: vertical;
}

.scene-database-field-row button {
  width: 100%;
}

.scene-database-field-row select,
.scene-database-target-select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  padding-right: 34px;
  background-image: url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%23FFFFFF' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  background-size: 12px 8px;
}

.scene-database-required-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: rgba(255, 255, 255, 0.62);
  font-size: 0.74rem;
  font-weight: 700;
  white-space: nowrap;
}

.scene-database-row-card {
  display: grid;
  gap: 0;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 10px;
}

.scene-database-row-card.is-new {
  margin: 0 12px 12px;
}

.scene-database-row-fields {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.scene-database-row-card > .scene-database-row-fields {
  padding: 12px;
}

.scene-database-row-fields.has-image {
  grid-template-columns: minmax(180px, 0.9fr) minmax(220px, 1.1fr) minmax(180px, 0.8fr);
  align-items: stretch;
  gap: 12px;
}

.scene-database-row-field-stack,
.scene-database-row-description-stack,
.scene-database-row-image-stack {
  display: grid;
  align-content: start;
  gap: 10px;
  min-width: 0;
  padding: 10px;
}

.scene-database-cell {
  display: grid;
  gap: 5px;
  min-width: 0;
}

.scene-database-cell.is-image {
  align-content: start;
}

.scene-database-cell.is-image-preview-panel {
  display: grid;
  align-content: start;
  gap: 10px;
}

.scene-database-image-preview {
  width: 100%;
  overflow: hidden;
  border-radius: 8px;
  background: rgb(12, 12, 12);
}

.scene-database-image-preview img {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

.scene-database-image-preview-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.scene-database-image-thumb {
  position: relative;
  display: block;
  min-width: 0;
  margin: 0;
  overflow: hidden;
  border-radius: 8px;
  background: rgb(8, 8, 8);
}

.scene-database-image-thumb img {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
}

.scene-database-image-thumb.is-empty {
  display: flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 4 / 3;
  border: 1px dashed rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.025);
  color: rgba(255, 255, 255, 0.34);
  font-size: 0.72rem;
  font-weight: 750;
}

.scene-database-image-thumb button {
  position: absolute;
  right: 6px;
  bottom: 6px;
  min-height: 24px;
  padding: 0 8px;
  border: 0;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.68);
  color: rgb(255, 255, 255);
  font-size: 0.66rem;
  font-weight: 750;
}

.scene-database-image-thumb button:hover,
.scene-database-image-thumb button:focus-visible {
  background: rgba(28, 28, 28, 0.92);
  outline: none;
}

.scene-database-row-description-stack .scene-database-cell textarea {
  height: 100%;
  min-height: 134px;
}

.scene-database-row-description-stack,
.scene-database-row-description-stack .scene-database-cell,
.scene-database-row-description-stack .scene-database-cell textarea {
  align-self: stretch;
}

.scene-database-row-description-stack {
  grid-template-rows: 1fr;
}

.scene-database-row-description-stack .scene-database-cell {
  display: grid;
  grid-template-rows: 1fr;
  height: 100%;
  min-height: 0;
}

.scene-database-row-image-stack .scene-database-image-preview img,
.scene-database-row-image-stack .scene-database-image-thumb img {
  aspect-ratio: 4 / 3;
}

.scene-database-image-preview.is-empty {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 132px;
  border: 1px dashed rgba(255, 255, 255, 0.12);
  color: rgba(255, 255, 255, 0.42);
  font-size: 0.74rem;
  font-weight: 700;
}

.scene-database-cell.is-checkbox {
  align-content: end;
}

.scene-database-cell.is-checkbox input {
  width: 18px;
  min-height: 18px;
}

.scene-database-row-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
  min-height: 58px;
  padding: 11px 12px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.scene-database-target-strip {
  display: grid;
  gap: 8px;
  margin: 0 12px;
  padding: 10px 12px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 10px;
  background: rgb(12, 12, 12);
}

.scene-database-binding-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 10px;
  align-items: center;
  padding: 10px 12px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 10px;
  background: rgb(12, 12, 12);
}

.scene-database-binding-row div {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.scene-database-binding-row small {
  color: rgba(255, 255, 255, 0.56);
  font-size: 0.76rem;
  font-weight: 650;
  white-space: nowrap;
}

.scene-database-muted {
  margin: 0;
  color: rgba(255, 255, 255, 0.5);
  font-size: 0.8rem;
  font-weight: 600;
  line-height: 1.4;
}

@media (max-width: 1100px) {
  .scene-database-field-row {
    grid-template-columns: minmax(0, 1fr) minmax(120px, 0.5fr) 104px 86px 92px;
  }
}

@media (max-width: 760px) {
  .scene-database-field-row {
    grid-template-columns: 1fr;
  }

  .scene-database-row-fields {
    grid-template-columns: 1fr;
  }

  .scene-database-row-fields.has-image {
    grid-template-columns: 1fr;
  }

  .scene-database-row-field-stack,
  .scene-database-row-description-stack,
  .scene-database-row-image-stack {
    padding: 0;
    border: 0;
    background: transparent;
  }

  .scene-database-product-modal-image {
    padding: 14px 14px 0;
  }

  .scene-database-product-modal-image-frame {
    flex-basis: min(280px, 78vw);
  }

  .scene-database-product-modal-body {
    min-height: 0;
    padding: 24px 20px 22px;
  }

  .scene-database-product-modal-body h3 {
    font-size: 1.28rem;
  }

  .scene-database-product-modal-badges {
    justify-content: flex-start;
  }

  .scene-database-product-modal-fields div {
    grid-template-columns: 1fr;
    gap: 4px;
  }

  .scene-database-binding-row {
    grid-template-columns: 1fr;
  }
}

#sceneDatabaseModal .modal-actions {
  flex: 0 0 auto;
  margin: 0;
  gap: 10px;
  padding: 14px 16px 16px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

#sceneDatabaseModal .modal-actions button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  min-width: 104px;
  min-height: 40px;
  padding: 0 18px;
  border: 0;
  border-radius: 999px;
  background: rgb(30, 30, 30);
  color: rgb(255, 255, 255);
  font-size: 0.9rem;
  font-weight: 700;
  box-shadow: none;
}

#sceneDatabaseModal .modal-actions button:hover,
#sceneDatabaseModal .modal-actions button:focus-visible {
  background: rgb(38, 38, 38);
  outline: none;
}
