/**
 * @file
 * Visual styles for nodes.
 */

.node--unpublished {
  background-color: #fff4f4;
}

/* Service (full) hero: make rendered media image fill the grid column. */
.node--service-full .field-media-service-hero,
.node--service-full .field-media-service-hero *,
.node--project-full .field-media-project-hero,
.node--project-full .field-media-project-hero * {
  box-sizing: border-box;
}

.node--service-full .field-media-service-hero__inner,
.node--service-full .field-media-service-hero__inner .field--name-field-media,
.node--service-full .field-media-service-hero__inner .field__item,
.node--project-full .field-media-project-hero__inner,
.node--project-full .field-media-project-hero__inner .field--name-field-media,
.node--project-full .field-media-project-hero__inner .field__item {
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  min-height: 0;
  width: 100%;
}

.node--service-full .field-media-service-hero__inner .field,
.node--service-full .field-media-service-hero__inner .field__item,
.node--service-full .field-media-service-hero__inner .media--type-image,
.node--service-full .field-media-service-hero__inner .contextual-region,
.node--project-full .field-media-project-hero__inner .field,
.node--project-full .field-media-project-hero__inner .field__item,
.node--project-full .field-media-project-hero__inner .media--type-image,
.node--project-full .field-media-project-hero__inner .contextual-region {
  margin: 0;
}

.node--service-full .field-media-service-hero__inner .media--type-image {
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  min-height: 0;
  width: 100%;
}

.node--project-full .field-media-project-hero__inner .media--type-image {
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  min-height: 0;
  width: 100%;
}

.node--service-full .field-media-service-hero__inner .field--name-field-media-image,
.node--service-full .field-media-service-hero__inner .field--name-field-media-image .field__item,
.node--project-full .field-media-project-hero__inner .field--name-field-media-image,
.node--project-full .field-media-project-hero__inner .field--name-field-media-image .field__item {
  display: block;
  flex: 1 1 auto;
  min-height: 0;
  width: 100%;
}

.node--service-full .field-media-service-hero__inner a {
  display: block;
  height: 100%;
  width: 100%;
}

.node--project-full .field-media-project-hero__inner a {
  display: block;
  height: 100%;
  width: 100%;
}

.node--service-full .field-media-service-hero__inner picture {
  display: block;
  height: 100%;
  width: 100%;
}

.node--project-full .field-media-project-hero__inner picture {
  display: block;
  height: 100%;
  width: 100%;
}

.node--service-full .field-media-service-hero__inner img {
  display: block;
  max-width: none;
  min-height: 260px;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.page-node-type-service .node--service-full .field-media-service-hero__inner img {
  max-height: 500px;
}

.node--project-full .field-media-project-hero__inner img {
  display: block;
  max-width: none;
  min-height: 260px;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media (min-width: 40rem) {
  .node--service-full .field-media-service-hero__inner img,
  .node--project-full .field-media-project-hero__inner img {
    min-height: 320px;
  }
}

/* Project full: fullscreen gallery slides from field_media. */
.node--project-full figure .field,
.node--project-full figure .field__item,
.node--project-full figure .media--type-image,
.node--project-full figure .field--name-field-media-image,
.node--project-full figure .field--name-field-media-image .field__item,
.node--project-full figure .contextual-region {
  height: 100%;
  width: 100%;
  margin: 0;
}

.node--project-full figure a,
.node--project-full figure picture,
.node--project-full figure img {
  display: block;
  height: 100%;
  width: 100%;
}

.node--project-full figure img {
  object-fit: cover;
  object-position: center;
}

.node--project-full .project-media-slider .swiper-slide .field,
.node--project-full .project-media-slider .swiper-slide .field__item,
.node--project-full .project-media-slider .swiper-slide .media--type-image,
.node--project-full .project-media-slider .swiper-slide .field--name-field-media-image,
.node--project-full .project-media-slider .swiper-slide .field--name-field-media-image .field__item,
.node--project-full .project-media-slider .swiper-slide .contextual-region {
  height: 100%;
  width: 100%;
  margin: 0;
}

.node--project-full .project-media-slider .swiper-slide picture,
.node--project-full .project-media-slider .swiper-slide img {
  display: block;
  height: 100%;
  width: 100%;
}

.node--project-full .project-media-slider .swiper-button-prev,
.node--project-full .project-media-slider .swiper-button-next {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 2.125rem;
  width: 2.125rem;
  border-radius: 9999px;
  border: 1px solid rgb(255 255 255 / 0.5);
  background-color: rgb(255 255 255 / 0.2);
  color: #fff;
  z-index: 30;
  pointer-events: auto;
  backdrop-filter: blur(2px);
  transition: background-color 200ms ease, border-color 200ms ease, transform 200ms ease;
}

.node--project-full .project-media-slider .swiper-button-prev {
  left: 1rem;
}

.node--project-full .project-media-slider .swiper-button-next {
  right: 1rem;
}

.node--project-full .project-media-slider .swiper-button-prev:hover,
.node--project-full .project-media-slider .swiper-button-next:hover,
.node--project-full .project-media-slider .swiper-button-prev:focus-visible,
.node--project-full .project-media-slider .swiper-button-next:focus-visible {
  border-color: rgb(255 255 255 / 0.85);
  background-color: rgb(255 255 255 / 0.3);
  transform: scale(1.04);
}

.node--project-full .project-media-slider .swiper-button-prev svg,
.node--project-full .project-media-slider .swiper-button-next svg {
  height: 0.875rem;
  width: 0.875rem;
}

.node--project-full .project-media-slider .swiper-button-prev::after,
.node--project-full .project-media-slider .swiper-button-next::after {
  content: none;
}

.node--project-full .project-media-slider .swiper-pagination-bullet {
  background: rgb(255 255 255 / 0.75);
}

.node--project-full .project-media-slider .swiper-pagination-bullet-active {
  background: #fff;
}

/* Service teaser: fixed-height slot (matches .h-56); img respects image style / max-width. */
.node--service-teaser__media,
.node--service-teaser__media * {
  box-sizing: border-box;
}

.node--service-teaser__media .field,
.node--service-teaser__media .field__item {
  margin: 0;
  max-width: 100%;
}

.node--service-teaser__media .field--name-field-media,
.node--service-teaser__media .contextual-region {
  display: block;
  max-width: 100%;
}

.node--service-teaser__media img {
  display: block;
  width: 100%;
  max-width: 100%;
  height: 14rem;
  object-fit: cover;
  object-position: center;
  transform: scale(1);
  transition: transform 500ms cubic-bezier(0.4, 0, 0.2, 1);
}

/* Match card image zoom on home / other sections (group on parent <a>). */
.node--service-teaser a.group:hover .node--service-teaser__media img,
.node--service-teaser a.group:focus-visible .node--service-teaser__media img,
.node--project-teaser a.group:hover .node--service-teaser__media img,
.node--project-teaser a.group:focus-visible .node--service-teaser__media img {
  transform: scale(1.05);
}
