.media {
  display: grid;
  gap: 12px;
}

.media-input {
  display: none;
}

.media-drop {
  border: 1px dashed rgba(96, 100, 108, 0.35);
  border-radius: var(--r);
  padding: 14px 12px;
  color: var(--admin-muted);
  font-weight: 650;
  background: #fff;
  width: 100%;
  text-align: left;
  cursor: pointer;
}

.media-drop.is-dragover {
  border-color: var(--admin-accent-weak-border);
  background: var(--admin-accent-weak);
  color: var(--admin-text);
}

.media-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 6px;
}

.media-grid:empty {
  display: none;
}

.media-item {
  position: relative;
  aspect-ratio: 1 / 1;
  border-radius: var(--r);
  border: 1px solid var(--admin-border);
  background: linear-gradient(180deg, #fafafa, #f1f1f6);
  overflow: hidden;
  cursor: default;
}

.media-item.media-item--button {
  cursor: pointer;
}

.media-item[draggable="true"] {
  cursor: grab;
}

.media-item.is-dragging {
  opacity: 0.6;
  cursor: grabbing;
}

.media-item.is-dragover {
  border-color: var(--admin-accent-weak-border);
  box-shadow: 0 0 0 1px var(--admin-accent-weak);
}

.media-item.is-selected {
  border-color: var(--admin-accent-weak-border);
  box-shadow: 0 0 0 1px var(--admin-accent-weak);
}

.media-preview {
  width: 100%;
  height: 100%;
}

.media-item img,
.media-item video,
.media-preview img,
.media-preview video {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.media-add-card {
  display: grid;
  place-items: center;
  aspect-ratio: 1 / 1;
  border: 1px dashed rgba(96, 100, 108, 0.35);
  border-radius: var(--r);
  background: #fff;
  color: var(--admin-muted);
  font-size: 12px;
  font-weight: 650;
  line-height: 1.35;
  text-align: center;
  cursor: pointer;
  padding: 10px;
}

.media-add-card.is-dragover {
  border-color: var(--admin-accent-weak-border);
  background: var(--admin-accent-weak);
  color: var(--admin-text);
}

.media-remove {
  position: absolute;
  top: 8px;
  right: 8px;
  z-index: 2;
  width: 26px;
  height: 26px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(55, 53, 47, 0.12);
  border-radius: 999px;
  background: #fff;
  color: rgba(55, 53, 47, 0.78);
  cursor: pointer;
  font-size: 16px;
  line-height: 1;
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.08);
  font: inherit;
}

.media-remove:hover {
  background: #f8f8f8;
  color: #37352f;
}

.media-shell {
  border: 1px solid var(--admin-border);
  border-radius: var(--r);
  background: #fff;
  padding: 12px;
}

@media (max-width: 980px) {
  .media-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
