/* src/_includes/components/media/media.css */
.sp-post-page-content > :not(.sp-media):not(.sp-divider):not(hr):not(.sp-case):not(.sp-case-view) {
  max-width: 75%;
}
.sp-post-page-content > .sp-media,
.sp-post-page-content > .sp-divider,
.sp-post-page-content > hr,
.sp-post-page-content > .sp-case,
.sp-post-page-content > .sp-case-view {
  width: 100%;
  max-width: 100%;
}
.sp-case > :not(.sp-media):not(.sp-divider):not(hr) {
  max-width: 75%;
}
.sp-case > .sp-media,
.sp-case > .sp-divider,
.sp-case > hr {
  width: 100%;
  max-width: 100%;
}
.sp-media {
  margin: 3rem 0;
}
.sp-media--content {
  max-width: 75%;
}
.sp-media--full {
  position: relative;
  overflow: visible;
}
.sp-media--full .sp-media__img,
.sp-media--full .sp-video {
  width: calc(100% + var(--sp-sidebar-width) - var(--sp-layout-padding));
  margin-left: calc((var(--sp-sidebar-width) - var(--sp-layout-padding)) * -1);
  position: relative;
  z-index: 5;
}
.sp-media__img,
.sp-video__el {
  width: 100%;
  display: block;
  border-radius: var(--sp-border-radius-S);
}
.sp-media__caption {
  margin-top: 0.75rem;
  max-width: 75%;
  width: 100%;
  font-size: var(--sp-font-tertiary-text);
  line-height: var(--sp-line-height-tertiary-text);
  letter-spacing: var(--sp-letter-spacing-tertiary-text);
  color: var(--sp-text-color-secondary);
}
.sp-video {
  position: relative;
}
.sp-video__control {
  position: absolute;
  right: 1rem;
  width: 4.3rem;
  bottom: 1rem;
  background: #ffffff10;
  color: var(--sp-text-color);
  border: 1px solid var(--sp-divider);
  border-radius: 999px;
  padding: 0.4rem 0.9rem;
  backdrop-filter: blur(32px);
  cursor: pointer;
  font-size: var(--sp-font-tertiary-text);
  line-height: var(--sp-line-height-tertiary-text);
  letter-spacing: var(--sp-letter-spacing-tertiary-text);
}
.sp-video-embed iframe {
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  border-radius: 8px;
  margin: 3rem 0;
}
.sp-post-page-content img:not(.sp-media__img) {
  border-radius: var(--sp-border-radius-S);
  width: 100%;
}
@media (max-width: 900px) {
  .sp-media--full .sp-media__img,
  .sp-media--full .sp-video {
    width: 100%;
    margin-left: 0;
  }
  .sp-media--full {
    padding-left: 0;
  }
  .sp-post-page-content > :not(.sp-media):not(.sp-divider):not(hr):not(.sp-case):not(.sp-case-view) {
    max-width: 100%;
  }
  .sp-media__caption {
    max-width: 100%;
  }
  .sp-case > :not(.sp-media):not(.sp-divider):not(hr) {
    max-width: 100%;
  }
}

/* src/_includes/components/divider/divider.css */
.sp-aside .sp-divider {
  width: 100%;
}
.sp-scrolled .sp-aside .sp-divider {
  width: calc(100% - 2rem);
}
.sp-divider {
  --sp-divider-space-block: 2rem;
  position: relative;
  display: block;
  border: none;
  margin: 0;
  padding: 0;
  min-height: calc((var(--sp-divider-space-block) * 2) + 1px);
  background: transparent;
  transition: width 0.2s ease;
}
.sp-divider::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: var(--sp-divider-space-block);
  height: 1px;
  background: var(--sp-divider);
}
.sp-divider--space::after {
  content: none;
}
.sp-divider--tight {
  --sp-divider-space-block: 1rem;
}
.sp-divider--roomy {
  --sp-divider-space-block: 2rem;
}
.sp-divider--loose {
  --sp-divider-space-block: 5rem;
}
@media (max-width: 900px) {
  .sp-divider--loose {
    display: none;
  }
}

/* src/_includes/components/note-card/note-card.css */
.note-card {
  display: flex;
  flex-wrap: nowrap;
  align-items: flex-start;
  gap: var(--sp-space-M4);
  padding: var(--sp-space-M5) 0;
  border-bottom: 1px solid var(--sp-divider);
  text-decoration: none;
  color: inherit;
}
.note-card--media {
  gap: var(--sp-space-M4);
}
.note-card:last-child {
  border-bottom: none;
}
.note-card__content {
  flex: 7;
  display: grid;
  gap: var(--sp-space-S6);
}
.note-card__aside {
  flex: 3;
  display: flex;
  justify-content: flex-end;
  align-items: flex-start;
  gap: var(--sp-space-M2);
}
.note-card__media {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-space-M4);
  justify-content: flex-end;
}
.note-card__cover {
  width: 5.7rem;
  aspect-ratio: 2 / 3;
  border-radius: var(--sp-border-radius-S);
  overflow: hidden;
  flex-shrink: 0;
}
.note-card__cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.note-card__cover video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.note-card__badge {
  width: 3rem;
  display: flex;
}
.note-card__badge img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}
.note-card__date {
  font-family:
    "Cossette",
    "Graphik",
    sans-serif;
  font-size: var(--sp-font-h1);
  line-height: var(--sp-line-height-h1);
  letter-spacing: var(--sp-letter-spacing-h1);
  color: var(--sp-text-color-secondary);
  text-align: right;
}
.note-card__title {
  margin: 0;
}
.note-card__description {
  margin: 0;
  font-size: var(--sp-font-post-text);
  line-height: var(--sp-line-height-post-text);
  letter-spacing: var(--sp-letter-spacing-post-text);
  color: var(--sp-text-color-secondary);
}
.note-card:hover .note-card__title {
  color: var(--sp-accent);
}
.note-card:hover .note-card__description {
  color: var(--sp-text-color);
}
@media (max-width: 900px) {
  .note-card,
  .note-card--media {
    flex-direction: column;
    gap: var(--sp-space-M2);
  }
  .note-card__media {
    display: flex;
    align-items: flex-start;
    gap: var(--sp-space-M3);
    justify-content: flex-start;
  }
  .note-card__cover {
    width: 20%;
  }
  .note-card__badge {
    order: 2;
  }
  .note-card__cover {
    order: 1;
  }
  .note-card__aside {
    width: 100%;
    justify-content: flex-start;
  }
  .note-card__aside--no-cover {
    display: none;
  }
  .note-card__date {
    display: none;
  }
}

/* src/_includes/components/project-card/project-card.css */
.sp-project-card {
  display: inline-block;
  width: 100%;
  text-decoration: none;
  cursor: pointer;
  break-inside: avoid;
  margin-bottom: var(--sp-space-M5);
}
.sp-project-card__image {
  width: 100%;
  aspect-ratio: 2 / 3;
  background: var(--sp-back-plate);
  border-radius: var(--sp-border-radius-S);
  overflow: hidden;
  margin-bottom: var(--sp-space-M1);
  transition: opacity 0.2s ease-out;
}
.sp-project-card__image--small {
  aspect-ratio: 1 / 1;
}
.sp-project-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.15s ease-out;
}
.sp-project-card__image video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.15s ease-out;
}
.sp-project-card:hover .sp-project-card__image img {
  transform: scale(1.02);
}
.sp-project-card:hover .sp-project-card__image video {
  transform: scale(1.02);
}
.sp-project-card--dimmed .sp-project-card__image {
  opacity: 0.5;
}
.sp-project-card__content {
  display: flex;
  flex-direction: row;
}
.sp-project-card__header {
  display: flex;
  align-items: baseline;
  gap: var(--sp-space-S4);
  flex-wrap: wrap;
}
.sp-project-card__title {
  margin: 0;
  transition: color 0.15s ease-out;
}
.sp-project-card:hover .sp-project-card__title {
  color: var(--sp-accent);
}
.sp-project-card__company {
  font-size: var(--sp-font-tertiary-text);
  line-height: var(--sp-line-height-110);
  letter-spacing: var(--sp-letter-spacing-tertiary-text);
  color: var(--sp-text-color-secondary);
}
.sp-project-card__description {
  margin: 0;
  color: var(--sp-text-color-secondary);
  opacity: 0;
  transform: translateY(2px);
  transition:
    opacity 0.2s ease-out,
    transform 0.2s ease-out,
    color 0.2s ease-out;
}
.sp-project-card__meta {
  display: inline-grid;
  align-items: start;
  margin: 0;
  line-height: var(--sp-line-height-primary-text);
}
.sp-project-card__date {
  grid-area: 1 / 1;
  margin: 0;
  color: var(--sp-text-color-tertiary);
  transition: opacity 0.2s ease-out, transform 0.2s ease-out;
}
@media (hover: hover) and (pointer: fine) {
  .sp-project-card__date,
  .sp-project-card__description {
    grid-area: 1 / 1;
    white-space: nowrap;
  }
  .sp-project-card:hover .sp-project-card__date {
    opacity: 0;
    transform: translateY(-2px);
  }
  .sp-project-card:hover .sp-project-card__description {
    opacity: 1;
    transform: translateY(0);
  }
}
.sp-project-card:hover .sp-project-card__description {
  color: var(--sp-text-color);
}
@media (max-width: 900px) {
  .sp-project-card__description {
    display: none;
    opacity: 0;
    transform: none;
  }
}

/* src/_includes/components/service-card/service-card.css */
.sp-service-card {
  min-height: 17.583rem;
  border: 1px solid var(--sp-divider);
  border-radius: var(--sp-border-radius-S);
  padding: var(--sp-space-M2);
  background: var(--sp-back);
  display: grid;
  grid-template-rows: auto 1fr;
}
.sp-service-card__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--sp-space-S4);
}
.sp-service-card__title {
  margin: 0;
  font-size: var(--sp-font-h1);
  line-height: var(--sp-line-height-h1);
  letter-spacing: var(--sp-letter-spacing-h1);
}
.sp-service-card__number {
  font-family:
    "Cossette",
    "Graphik",
    sans-serif;
  font-size: var(--sp-font-h1);
  line-height: var(--sp-line-height-h1);
  letter-spacing: var(--sp-letter-spacing-h1);
  color: var(--sp-text-color-tertiary);
}
.sp-service-card__list {
  margin: auto 0 0;
  list-style: none;
  padding: 0;
}
.sp-service-card__list li {
  margin: 0;
  color: var(--sp-text-color-secondary);
  font-size: var(--sp-font-primary-text);
  line-height: var(--sp-line-height-primary-text);
  letter-spacing: var(--sp-letter-spacing-primary-text);
}

/* src/_includes/components/service-tag/service-tag.css */
.sp-service-tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.5rem;
  padding: 0 var(--sp-space-M2);
  border: 0.0625rem solid var(--sp-text-color);
  border-radius: var(--sp-border-radius-S);
  color: var(--sp-text-color);
  font-size: var(--sp-font-primary-text);
  line-height: var(--sp-line-height-primary-text);
  letter-spacing: var(--sp-letter-spacing-primary-text);
  white-space: nowrap;
}

/* src/_includes/components/case-view/case-view.css */
.sp-case-view {
  --sp-case-columns: 12;
  --sp-case-rows: 3;
  --sp-case-media-row-height: 13.625rem;
  background: var(--sp-back-plate);
  border-radius: var(--sp-border-radius-M);
  padding: var(--sp-space-M5);
  overflow: hidden;
}
.sp-case-view--no-full-link {
  padding: var(--sp-space-M5) var(--sp-space-M5) var(--sp-space-M9);
}
.sp-post-page-content > .sp-case-view {
  width: calc(100% + var(--sp-sidebar-width) - var(--sp-layout-padding));
  max-width: none;
  margin-left: calc((var(--sp-sidebar-width) - var(--sp-layout-padding)) * -1);
  position: relative;
  z-index: 5;
}
.sp-case-view__media-grid {
  display: grid;
  grid-template-columns: repeat(var(--sp-case-columns), minmax(0, 1fr));
  grid-template-rows: repeat(var(--sp-case-rows), auto);
  gap: var(--sp-space-M1);
}
.sp-case-view__media-item {
  grid-column: var(--sp-case-col-start) / var(--sp-case-col-end);
  grid-row: var(--sp-case-row-start) / var(--sp-case-row-end);
  z-index: var(--sp-case-z);
  border: none;
  background: transparent;
  padding: 0;
  cursor: pointer;
  border-radius: var(--sp-border-radius-S);
  overflow: hidden;
  transition: opacity 0.2s ease-out;
}
.sp-case-view__media-item--dimmed {
  opacity: 0.5;
}
.sp-case-view__media-image,
.sp-case-view__media-video {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: var(--sp-border-radius-S);
}
.sp-case-view__media-image,
.sp-case-view__media-video {
  transform: scale(1);
  transition: transform 0.3s ease-out;
  transform-origin: center;
}
.sp-case-view__media-item:active .sp-case-view__media-image,
.sp-case-view__media-item:active .sp-case-view__media-video {
  transform: scale(1);
}
@media (hover: hover) and (pointer: fine) {
  .sp-case-view__media-item:hover .sp-case-view__media-image,
  .sp-case-view__media-item:hover .sp-case-view__media-video {
    transform: scale(1.02);
  }
}
.sp-case-view__tags {
  margin-top: var(--sp-space-M5);
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-space-S6);
}
.sp-case-view__content {
  margin-top: var(--sp-space-M9);
  display: grid;
  grid-template-columns: repeat(var(--sp-case-columns), minmax(0, 1fr));
  gap: var(--sp-space-M1);
}
.sp-case-view__project {
  grid-column: 1 / span 4;
  min-width: 0;
  display: flex;
  flex-direction: column;
  align-self: stretch;
}
.sp-case-view__project-title {
  margin: 0;
  font-size: var(--sp-font-h1);
  line-height: var(--sp-line-height-h1);
  letter-spacing: var(--sp-letter-spacing-h1);
  padding-right: var(--sp-space-M7);
}
.sp-case-view__project-date {
  margin-top: var(--sp-space-S1);
  margin-bottom: 0;
  color: var(--sp-text-color-secondary);
  font-size: var(--sp-font-h1);
  line-height: var(--sp-line-height-h1);
  letter-spacing: var(--sp-letter-spacing-h1);
  font-family:
    "Cossette",
    "Graphik",
    sans-serif;
}
.sp-case-view__metrics {
  margin-top: auto;
  padding-top: var(--sp-space-M5);
  display: grid;
  gap: var(--sp-space-M2);
}
.sp-case-view__metric {
  display: grid;
  gap: var(--sp-space-S2);
}
.sp-case-view__metric-value {
  margin: 0;
  color: var(--sp-text-color-accent);
  font-size: 3rem;
  line-height: var(--sp-line-height-h1);
  letter-spacing: var(--sp-letter-spacing-h1-numbers);
  font-family:
    "Cossette",
    "Graphik",
    sans-serif;
}
.sp-case-view__metric-label {
  margin: 0;
  color: var(--sp-text-color-accent);
  font-size: var(--sp-font-h1);
  line-height: var(--sp-line-height-h1);
  letter-spacing: var(--sp-letter-spacing-h1);
  font-family:
    "Cossette",
    "Graphik",
    sans-serif;
}
.sp-case-view__blocks {
  grid-column: 5 / span 8;
  min-width: 0;
  display: grid;
  grid-template-columns: repeat(8, minmax(0, 1fr));
  row-gap: var(--sp-space-M5);
}
.sp-case-view__block {
  grid-column: var(--sp-case-block-start) / span 5;
  min-width: 0;
  position: relative;
}
.sp-case-view__block-title {
  margin: 0;
  font-size: var(--sp-font-h1);
  line-height: var(--sp-line-height-h1);
  letter-spacing: var(--sp-letter-spacing-h1);
}
.sp-case-view__block-text {
  margin: var(--sp-space-S4) 0 0;
}
.sp-case-view__block-line {
  --sp-case-block-step: calc( (100% - (4 * var(--sp-space-M1))) / 5 + var(--sp-space-M1) );
  position: absolute;
  top: 0.25rem;
  left: calc(-1 * var(--sp-case-block-step));
  width: calc(var(--sp-case-block-step) - var(--sp-space-M1));
  height: 0.875rem;
  border-left: 0.0625rem solid var(--sp-divider);
  border-bottom: 0.0625rem solid var(--sp-divider);
}
.sp-case-view__full-link {
  margin-top: var(--sp-space-M8);
  padding-top: var(--sp-space-M5);
  border-top: 0.0625rem solid var(--sp-divider);
  width: 100%;
  min-height: 7rem;
  border-radius: var(--sp-border-radius-S);
  text-decoration: none;
  color: var(--sp-text-color);
  background-color: transparent;
  font-size: var(--sp-font-h1);
  line-height: var(--sp-line-height-h1);
  letter-spacing: var(--sp-letter-spacing-h1);
  font-family:
    "Cossette",
    "Graphik",
    sans-serif;
  display: grid;
  grid-template-columns: repeat(var(--sp-case-columns), minmax(0, 1fr));
  align-items: center;
  transition-property: background-color, color;
  transition-duration: 0.2s;
  transition-timing-function: ease-out;
}
.sp-case-view__full-link-label {
  grid-column: 5 / span 8;
  justify-self: start;
}
.sp-case-view__full-link:hover {
  background-color: var(--sp-accent);
  color: var(--sp-back);
  transition-duration: 0.1s;
}
.sp-case-view-gallery {
  position: fixed;
  inset: 0;
  z-index: 60;
  background: rgba(0, 0, 0, 0.9);
  padding: var(--sp-space-M5);
  display: none;
  align-items: center;
  justify-content: center;
}
.sp-case-view-gallery.is-active {
  display: flex;
}
.sp-case-view-gallery__backdrop {
  position: absolute;
  inset: 0;
  border: none;
  background: transparent;
  cursor: pointer;
}
.sp-case-view-gallery__viewport {
  position: relative;
  z-index: 1;
  width: min(90vw, 80rem);
  max-height: calc(100dvh - (2 * var(--sp-space-M5)));
  display: flex;
  align-items: center;
  justify-content: center;
}
.sp-case-view-gallery__image,
.sp-case-view-gallery__video {
  width: 100%;
  max-height: calc(100dvh - (2 * var(--sp-space-L1)));
  object-fit: contain;
  border-radius: var(--sp-border-radius-S);
}
.sp-case-view-gallery__video {
  background: #000;
}
.sp-case-view-gallery__control {
  position: absolute;
  z-index: 2;
  border: 0.0625rem solid var(--sp-divider);
  background: rgba(23, 24, 28, 0.8);
  color: var(--sp-text-color);
  border-radius: 999px;
  min-width: 2.75rem;
  min-height: 2.75rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: var(--sp-font-h2);
  line-height: var(--sp-line-height-h2);
  letter-spacing: var(--sp-letter-spacing-h2);
}
.sp-case-view-gallery__control--close {
  top: var(--sp-space-M5);
  right: var(--sp-space-M5);
  font-size: var(--sp-font-h1);
}
.sp-case-view-gallery__control--prev {
  left: var(--sp-space-M5);
}
.sp-case-view-gallery__control--next {
  right: var(--sp-space-M5);
}
@media (max-width: 900px) {
  .sp-post-page-content > .sp-case-view {
    width: 100%;
    max-width: 100%;
    margin-left: 0;
  }
  .sp-case-view {
    padding: var(--sp-space-M2);
  }
  .sp-case-view__tags {
    display: none;
  }
  .sp-case-view__media-grid {
    grid-template-columns: 1fr;
    grid-template-rows: none;
    grid-auto-rows: minmax(12rem, auto);
  }
  .sp-case-view__media-item {
    grid-column: auto;
    grid-row: auto;
    z-index: auto;
    aspect-ratio: 16 / 10;
  }
  .sp-case-view__content {
    grid-template-columns: 1fr;
    gap: 0;
    margin-top: var(--sp-space-M5);
  }
  .sp-case-view__project,
  .sp-case-view__blocks,
  .sp-case-view__metrics {
    grid-column: auto;
  }
  .sp-case-view__project {
    display: contents;
  }
  .sp-case-view__project-title,
  .sp-case-view__project-date {
    order: 1;
  }
  .sp-case-view__blocks {
    order: 2;
  }
  .sp-case-view__metrics {
    order: 3;
    margin-top: 0;
    padding-top: 0;
  }
  .sp-case-view__blocks {
    grid-template-columns: 1fr;
    row-gap: var(--sp-space-M3);
    margin: var(--sp-space-M5) 0;
  }
  .sp-case-view__block {
    grid-column: auto;
  }
  .sp-case-view__block-line {
    display: none;
  }
  .sp-case-view__block-text {
    margin: var(--sp-space-S2) 0 0;
  }
  .sp-case-view__metric-value {
    font-size: var(--sp-font-size-32);
  }
  .sp-case-view__full-link-label {
    grid-column: 1 / -1;
    justify-self: center;
  }
  .sp-case-view__full-link {
    padding-top: var(--sp-space-M2);
    margin-top: var(--sp-space-M6);
  }
  .sp-case-view--no-full-link {
    padding: var(--sp-space-M2) var(--sp-space-M2) var(--sp-space-M9) var(--sp-space-M2);
  }
  .sp-case-view-gallery {
    padding: var(--sp-space-M2);
  }
  .sp-case-view-gallery__viewport {
    width: 100%;
    max-height: calc(100dvh - (2 * var(--sp-space-M2)));
  }
  .sp-case-view-gallery__control--close {
    top: var(--sp-space-M2);
    right: var(--sp-space-M2);
  }
  .sp-case-view-gallery__control--prev {
    left: var(--sp-space-M2);
  }
  .sp-case-view-gallery__control--next {
    right: var(--sp-space-M2);
  }
}

/* src/_includes/components/work-index-item/work-index-item.css */
.sp-list__desc {
  font-size: var(--sp-font-tertiary-text);
  line-height: var(--sp-line-height-tertiary-text);
  letter-spacing: var(--sp-letter-spacing-tertiary-text);
  color: var(--sp-text-color-secondary);
}

/* src/_includes/components/masonry-list/masonry-list.css */
.sp-list--masonry {
  display: block;
  column-count: 2;
  column-gap: 1.5rem;
}
.sp-list--masonry > li {
  break-inside: avoid;
  margin-bottom: 1.5rem;
}
@media (max-width: 900px) {
  .sp-list--masonry {
    column-count: 1;
  }
}

/* src/_includes/components/render-items/render-items.css */

/* src/assets/css/components.entry.css */
/*# sourceMappingURL=components.bundle.css.map */
