.component-figure {
  margin: 0;
  width: 100%;
  height: 100%;
}

.component-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: var(--focal-point-x) var(--focal-point-y);
}

/* textblock: responsive font-size and text-align via CSS custom properties */
.text-bloc-container .blocks-container .block-container .title {
  font-size: var(--pd-fs-desk, inherit);
}
.text-bloc-container .blocks-container .block-container .text-element {
  font-size: var(--pd-fs-desk, inherit);
  text-align: var(--pd-align-desk, inherit);
}
@media only screen and (max-width: 1023px) {
  .text-bloc-container .blocks-container .block-container .title {
    font-size: var(--pd-fs-mb, inherit);
  }
  .text-bloc-container .blocks-container .block-container .text-element {
    font-size: var(--pd-fs-mb, inherit);
    text-align: var(--pd-align-mb, inherit);
  }
}
