/**
 * TODO: move the following to a work-section css file due to the creation of work page.
 * TODO: unbind `work-label-items` from GSAP when a transition is triggered
 * in order to avoid inline element and needing the !important overwrites.
 * `#cs-container video[data-video-label='...']` are duplicate rules of
 * `case-study-image-container-1`, see how to reuse instead of rewriting these.
 */

html {
  /* Prevents items from shifting horizontally when scroll bar is removed
  while transitioning between pages. */
  overflow-y: scroll !important;
}

.work {
  color: var(--color-light);
  min-height: 100vh;
  /* padding-bottom: calc(50 * 100vw / var(--page-width)); */
  padding-top: calc(50 * 100vw / var(--page-width));
  position: relative;
}

@media only screen and (min-width: 768px) {
  .work {
    padding-top: 0;
  }
}

/**
 * Work label
 */

.work-label-spacer {
  height: 100vh;
  margin-top: -100vh;
}

@media only screen and (min-width: 768px) {
  .work-label-spacer {
    height: 100vh;
  }
}

.work-label {
  align-items: flex-start;
  display: flex;
  height: 100vh;
  justify-content: center;
  left: 0;
  opacity: 0.8;
  pointer-events: none;
  position: sticky;
  top: 0;
  z-index: 2;
}

@media only screen and (min-width: 768px) {
  .work-label {
    align-items: center;
    height: 100vh;
    transition: opacity 1s;
  }
}

/* this is work_label */
.work-label-item {
  display: flex;
  font-size: calc(64 * 100vw / var(--page-width));
  gap: calc(47 * 100vw / var(--page-width));
  line-height: 0.72;
  margin: 0 auto;
  opacity: var(--o-work-label);
  padding-top: calc(34 * 100vw / var(--page-width));
  pointer-events: none;
  width: calc(315 * 100vw / var(--page-width));
}

@media only screen and (min-width: 768px) {
  .work-label-item {
    filter: blur(5px);
    font-size: calc(140 * 100vw / var(--page-width));
    gap: calc(160 * 100vw / var(--page-width));
    padding-top: 0;
    width: calc(860 * 100vw / var(--page-width));
  }
}

.work-label span:nth-child(even) {
  margin-top: calc(34 * 100vw / var(--page-width));
}

@media only screen and (min-width: 768px) {
  .work-label span:nth-child(even) {
    margin-top: 0;
  }
}

@media only screen and (min-width: 768px) {
  :root {
    --label-translate: 392;
  }

  .work-label span {
    margin-top: 0;
  }

  .work-label span span {
    display: block;
    transition: transform 1s;
  }

  .work-label-in .work_label_1 span {
    transform: translate(
      calc(-142 * 100vw / var(--page-width)),
      calc(-1 * var(--label-translate) * 100vw / var(--page-width))
    );
  }

  .work-label-in .work_label_2 span {
    transform: translate(
      calc(-110 * 100vw / var(--page-width)),
      calc(var(--label-translate) * 100vw / var(--page-width))
    );
  }

  .work-label-in .work_label_3 span {
    transform: translate(
      calc(135 * 100vw / var(--page-width)),
      calc(-1 * var(--label-translate) * 100vw / var(--page-width))
    );
  }

  .work-label-in .work_label_4 span {
    transform: translate(
      calc(196 * 100vw / var(--page-width)),
      calc(var(--label-translate) * 100vw / var(--page-width))
    );
  }
}

/* Counters */

.case-study-counters {
  height: 100vh;
  left: 0;
  margin-top: -100vh;
  opacity: 0;
  pointer-events: none;
  position: sticky;
  top: 0;
  transition: opacity 0.5s;
  width: 100%;
  z-index: 2;
}

.case-study-counters.in-step {
  opacity: 1;
  transition-duration: 1s;
}

.case-study-count {
  color: var(--color-light);
  left: calc(16 * 100vw / var(--page-width));
  position: absolute;
  top: calc(136 * 100vw / var(--page-width));
  z-index: 1;
}

@media only screen and (min-width: 768px) {
  .case-study-count {
    left: calc(190 * 100vw / var(--page-width));
    top: 50vh;
    transform: translate(0, calc(-290 * 100vw / var(--page-width)));
  }
}

.case-study-count + .case-study-count {
  bottom: calc(81 * 100vw / var(--page-width));
  left: auto;
  right: calc(16 * 100vw / var(--page-width));
  top: auto;
}

@media only screen and (min-width: 768px) {
  .case-study-count + .case-study-count {
    bottom: auto;
    left: auto;
    right: calc(190 * 100vw / var(--page-width));
    top: 50vh;
    transform: translate(0, calc(240 * 100vw / var(--page-width)));
  }
}

/**
 * Case Study Block
 *
 * Styles for case studies within the work section.
 */

.case-studies {
  --cs-count: 5;
  min-height: calc(var(--cs-count) * 100vh);
}

[data-cs-marker] {
  height: 100vh;
}

[data-cs-marker='1'] {
  /* Fill inner-wrapper space (sticky element) */
  margin-top: -100vh;
}

/**
 * Case Studies Group
 */

.case-studies-group {
  height: 100vh;
  left: 0;
  top: 0;
  position: sticky;
}

/* End: Case Studies Group */

/**
 * Case Study
 */

[data-cs] {
  align-items: center;
  bottom: 0;
  display: flex;
  height: 100vh;
  justify-content: center;
  left: 0;
  overflow: hidden;
  position: absolute;
  right: 0;
  top: 0;
}

.work-case-study-headline {
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -16%);
  width: calc(295 * 100vw / var(--page-width));
  z-index: 2;
}

@media only screen and (min-width: 768px) {
  .work-case-study-headline {
    transform: translate(-50%, -50%);
    width: calc(670 * 100vw / var(--page-width));
  }
}

.work-case-study-headline .label,
.work-case-study-headline .title,
.work-case-study-headline .subheadline {
  opacity: 0;
  transition-duration: 0.5s;
  transition-property: opacity;
  transition-timing-function: ease-in;
}

/* NOTE: Required for opacity to work on Safari */
.work-case-study-headline .title {
  display: block;
}

[data-cs='5'] .work-case-study-headline .title {
  margin-bottom: 0;
}

.work-case-study-headline .title span {
  display: block;
  /* Using event delegation to detect click. Adding point-events to this
  element avoids the need to add extra logic on detecting click on anchor. */
  pointer-events: none;
}

@media only screen and (min-width: 768px) {
  .work-case-study-headline .title span {
    display: inline-block;
  }

  /* Extra helper to align headline with label */
  [data-cs].h-align .title span::first-letter {
    margin-left: calc(-7 * 100vw / var(--page-width));
  }
}

.work-case-study-headline a {
  color: inherit;
  text-decoration: none;
}

@media (hover: hover) {
  .work-case-study-headline a:hover {
    color: var(--color-accent-sun);
  }
}

[data-cs='4'] .work-case-study-headline {
  width: calc(340 * 100vw / var(--page-width));
}

@media only screen and (min-width: 768px) {
  [data-cs='4'] .work-case-study-headline {
    left: 55%;
    width: calc(852 * 100vw / var(--page-width));
  }
}

[data-cs='4'] .headline-1 {
  margin-left: calc(20 * 100vw / var(--page-width));
}

@media only screen and (min-width: 768px) {
  [data-cs='4'] .headline-1 {
    margin-left: 0;
  }
}

[data-cs='4'] .headline-3 {
  margin-left: calc(130 * 100vw / var(--page-width));
}

@media only screen and (min-width: 768px) {
  [data-cs='4'] .headline-3 {
    margin-left: 0;
  }
}

[data-cs='4'] .subheadline {
  margin-left: calc(254 * 100vw / var(--page-width));
}

@media only screen and (min-width: 768px) {
  [data-cs='4'] .subheadline {
    margin-left: 0;
  }
}

/* Headlines are stack so z-index positions elements on top when "active" */
.work-case-study-headline .label {
  margin-bottom: calc(20 * 100vw / var(--page-width));
}

@media only screen and (min-width: 768px) {
  .work-case-study-headline .label {
    margin-bottom: calc(25 * 100vw / var(--page-width));
  }
}

.work-case-study-headline .headline {
  transition: color 0.25s ease-in-out;
}

[data-cs] .headline-2 {
  text-align: right;
}

@media only screen and (min-width: 768px) {
  [data-cs='1'] .headline-2 {
    transform: translate(calc(284 * 100vw / var(--page-width)), 0);
  }

  [data-cs='2'] .headline-2 {
    transform: translate(calc(193 * 100vw / var(--page-width)), 0);
  }

  [data-cs='3'] .headline-2 {
    transform: translate(calc(248 * 100vw / var(--page-width)), 0);
  }

  [data-cs='4'] .headline-1 {
    transform: translate(calc(78 * 100vw / var(--page-width)), 0);
  }

  [data-cs='4'] .headline-3 {
    transform: translate(calc(346 * 100vw / var(--page-width)), 0);
  }

  [data-cs='5'] .headline-2 {
    transform: translate(calc(232 * 100vw / var(--page-width)), 0);
  }
}

.subheadline {
  display: inline-block;
  font-size: calc(18 * 100vw / var(--page-width));
  margin: calc(26 * 100vw / var(--page-width)) 0 0
    calc(228 * 100vw / var(--page-width));
  text-align: left;
  line-height: 1;
}

@media only screen and (min-width: 768px) {
  .subheadline {
    /* display: inline-block; */
    font-size: calc(20 * 100vw / var(--page-width));
    margin: calc(18 * 100vw / var(--page-width)) 0 0;
    transform: translate(calc(520 * 100vw / var(--page-width)), 0);
  }

  [data-cs='1'] .subheadline {
    transform: translate(calc(454 * 100vw / var(--page-width)), 0);
  }

  [data-cs='4'] .subheadline {
    transform: translate(calc(604 * 100vw / var(--page-width)), 0);
  }

  [data-cs='5'] .subheadline {
    transform: translate(calc(607 * 100vw / var(--page-width)), 0);
  }
}

/**
 * Case study assets.
 * `case-study-background`: static asset, no interactions.
 * `.work *-asset`: scopes transition to work section, prevents transitions on
 * clone section.
 */

.case-study-background,
.case-study-asset {
  display: block;
  height: 100%;
  width: auto;
}

@media only screen and (min-width: 768px) {
  .case-study-background,
  .case-study-asset {
    height: auto;
    width: 100%;
  }
}

.work .case-study-asset {
  transition: transform 0.35s linear;
}

/* End: Case study assets */

.case-study-image-container {
  height: calc(220 * 100vw / var(--page-width));
  position: absolute;
  top: 50vh;
  width: calc(270 * 100vw / var(--page-width));
}

@media only screen and (min-width: 768px) {
  .case-study-image-container {
    background-color: transparent;
    height: 100%;
    width: 100%;
  }
}

.case-study-image-container-1 {
  /* Above secondary assets */
  z-index: 2;
}

.case-study-image-container-1 video {
  object-fit: cover;
  height: 100%;
  width: 100%;
}

@media only screen and (min-width: 768px) {
  .case-study-image-container-1 video:first-child {
    display: none;
    visibility: hidden;
  }

  .case-study-image-container-1 video:last-child {
    display: block;
    visibility: visible;
  }
}

/* Animations and transitions (case studies) */
/* Use the states `previous`, `next` and `current` */

[data-status] {
  pointer-events: none;
}

[data-status='current'] {
  pointer-events: visible;
}

[data-status='current'] .label {
  opacity: 1;
  transition-delay: 0.5s;
}

[data-status='current'] .title {
  opacity: 1;
  transition-delay: 0.7s;
}

[data-status='current'] .subheadline {
  opacity: 1;
  transition-delay: 0.9s;
}

[data-enter] [data-status='next'] .case-study-image-container {
  transition: none !important;
}

/* Using `.work` to differentiate between elements in work section and cloned
elements used on page transitions. */
/* TODO: update to `work-*` */
.work .case-study-image-container {
  opacity: 0;
  visibility: hidden;
  transition:
    transform 1.5s,
    opacity 1.5s,
    visibility 0s 1.5s;
}

[data-status='current'] .case-study-image-container {
  opacity: 1;
  transition:
    transform 1.5s,
    opacity 1.5s;
  visibility: visible;
}

:root {
  --sm-first-img-0: translate(0, calc(330 * 100vw / var(--page-width)));
  --sm-second-img-0: translate(0, calc(340 * 100vw / var(--page-width)));
  --sm-first-img-50: translate(0, calc(-204 * 100vw / var(--page-width)));
  --sm-second-img-50: translate(0, calc(38 * 100vw / var(--page-width)));
  --sm-first-img-100: translate(0, calc(-410 * 100vw / var(--page-width)));
  --sm-second-img-100: translate(0, calc(-300 * 100vw / var(--page-width)));
}

/* Active 1 */

[data-cs='1'] .case-study-image-container-bg {
  height: 100%;
  transform: translate(-15%, 0%);
  width: auto;
  top: 0%;
}

@media only screen and (min-width: 768px) {
  [data-cs='1'] .case-study-image-container-bg {
    height: calc(900 * 100vw / var(--page-width));
    left: calc(180 * 100vw / var(--page-width));
    top: 50%;
    transform: translate(0, -50%);
    width: calc(1200 * 100vw / var(--page-width));
  }
}

[data-cs='1'] .case-study-image-container-1 {
  left: 0;
  /* Custom position for first element, all others use the same var. */
  transform: translate(0, calc(100 * 100vw / var(--page-width)));
}

@media only screen and (min-width: 768px) {
  [data-cs='1'] .case-study-image-container-1 {
    height: calc(398 * 100vw / var(--page-width));
    left: calc(101 * 100vw / var(--page-width));
    transform: translate(0, calc(70 * 100vw / var(--page-width)));
    width: calc(620 * 100vw / var(--page-width));
  }
}

[data-cs='1'] .case-study-image-container-2 {
  display: none;
}

@media only screen and (min-width: 768px) {
  [data-cs='1'] .case-study-image-container-2 {
    display: block;
    height: calc(360 * 100vw / var(--page-width));
    left: calc(594 * 100vw / var(--page-width));
    transform: translate(0, calc(160 * 100vw / var(--page-width)));
    width: calc(582 * 100vw / var(--page-width));
  }
}

[data-cs='1'] .case-study-image-container-3 {
  left: calc(106 * 100vw / var(--page-width));
  /* Custom position for first element, all others use the same var. */
  transform: translate(0, calc(200 * 100vw / var(--page-width)));
}

@media only screen and (min-width: 768px) {
  [data-cs='1'] .case-study-image-container-3 {
    display: block;
    height: calc(272 * 100vw / var(--page-width));
    left: calc(1090 * 100vw / var(--page-width));
    transform: translate(0, calc(133 * 100vw / var(--page-width)));
    width: calc(483 * 100vw / var(--page-width));
  }
}

[data-cs='1'][data-status='current'] .case-study-image-container-1 {
  transform: var(--sm-first-img-50);
}

@media only screen and (min-width: 768px) {
  [data-cs='1'][data-status='current'] .case-study-image-container-1 {
    transform: translate(0, calc(-168 * 100vw / var(--page-width)));
  }

  [data-cs='1'][data-status='current'] .case-study-image-container-2 {
    transform: translate(0, calc(-20 * 100vw / var(--page-width)));
  }
}

[data-cs='1'][data-status='current'] .case-study-image-container-3 {
  transform: var(--sm-second-img-50);
}

@media only screen and (min-width: 768px) {
  [data-cs='1'][data-status='current'] .case-study-image-container-3 {
    transform: translate(0, calc(-205 * 100vw / var(--page-width)));
  }
}

[data-status='previous'][data-cs='1'] .case-study-image-container-1 {
  transform: var(--sm-first-img-100);
}

@media only screen and (min-width: 768px) {
  [data-status='previous'][data-cs='1'] .case-study-image-container-1 {
    transform: translate(0, calc(-940 * 100vw / var(--page-width)));
  }
}

@media only screen and (min-width: 768px) {
  [data-status='previous'][data-cs='1'] .case-study-image-container-2 {
    transform: translate(0, calc(-915 * 100vw / var(--page-width)));
  }
}

[data-status='previous'][data-cs='1'] .case-study-image-container-3 {
  transform: var(--sm-second-img-100);
}

@media only screen and (min-width: 768px) {
  [data-status='previous'][data-cs='1'] .case-study-image-container-3 {
    transform: translate(0, calc(-887 * 100vw / var(--page-width)));
  }
}

/* Active 2 */

[data-cs='2'] .case-study-image-container-1 {
  left: calc(106 * 100vw / var(--page-width));
  transform: var(--sm-first-img-0);
}

@media only screen and (min-width: 768px) {
  [data-cs='2'] .case-study-image-container-1 {
    height: calc(378 * 100vw / var(--page-width));
    left: calc(140 * 100vw / var(--page-width));
    transform: translate(0, calc(565 * 100vw / var(--page-width)));
    width: calc(567 * 100vw / var(--page-width));
    z-index: 2;
  }
}

[data-cs='2'] .case-study-image-container-2 {
  display: none;
}

@media only screen and (min-width: 768px) {
  [data-cs='2'] .case-study-image-container-2 {
    display: block;
    height: calc(559 * 100vw / var(--page-width));
    left: calc(616 * 100vw / var(--page-width));
    transform: translate(0, calc(620 * 100vw / var(--page-width)));
    width: calc(420 * 100vw / var(--page-width));
  }
}

[data-cs='2'] .case-study-image-container-3 {
  display: none;
}

@media only screen and (min-width: 768px) {
  [data-cs='2'] .case-study-image-container-3 {
    display: block;
    height: calc(357 * 100vw / var(--page-width));
    left: calc(1020 * 100vw / var(--page-width));
    transform: translate(0, calc(531 * 100vw / var(--page-width)));
    width: calc(458 * 100vw / var(--page-width));
  }
}

[data-cs='2'] .case-study-image-container-4 {
  left: 0;
  transform: var(--sm-second-img-0);
}

@media only screen and (min-width: 768px) {
  [data-cs='2'] .case-study-image-container-4 {
    height: calc(292 * 100vw / var(--page-width));
    left: calc(1249 * 100vw / var(--page-width));
    transform: translate(0, calc(546 * 100vw / var(--page-width)));
    width: calc(194 * 100vw / var(--page-width));
  }
}

[data-cs='2'] .case-study-image-container-5 {
  display: none;
}

@media only screen and (min-width: 768px) {
  [data-cs='2'] .case-study-image-container-5 {
    display: block;
    height: calc(66 * 100vw / var(--page-width));
    left: calc(296 * 100vw / var(--page-width));
    transform: translate(0, calc(595 * 100vw / var(--page-width)));
    width: calc(149 * 100vw / var(--page-width));
  }
}

[data-cs='2'][data-status='current'] .case-study-image-container-1 {
  transform: var(--sm-first-img-50);
}

@media only screen and (min-width: 768px) {
  [data-cs='2'][data-status='current'] .case-study-image-container-1 {
    transform: translate(0, calc(-25 * 100vw / var(--page-width)));
  }

  [data-cs='2'][data-status='current'] .case-study-image-container-2 {
    transform: translate(0, calc(-330 * 100vw / var(--page-width)));
  }
}

[data-cs='2'][data-status='current'] .case-study-image-container-3 {
  transform: translate(0, calc(-231 * 100vw / var(--page-width)));
}

[data-cs='2'][data-status='current'] .case-study-image-container-4 {
  transform: var(--sm-second-img-50);
}

@media only screen and (min-width: 768px) {
  [data-cs='2'][data-status='current'] .case-study-image-container-4 {
    transform: translate(0, calc(46 * 100vw / var(--page-width)));
  }
}

@media only screen and (min-width: 768px) {
  [data-cs='2'][data-status='current'] .case-study-image-container-5 {
    transform: translate(0, calc(-204 * 100vw / var(--page-width)));
  }
}

[data-cs='2'][data-status='previous'] .case-study-image-container-1 {
  transform: var(--sm-first-img-100);
}

@media only screen and (min-width: 768px) {
  [data-cs='2'][data-status='previous'] .case-study-image-container-1 {
    transform: translate(0, calc(-965 * 100vw / var(--page-width)));
  }

  [data-cs='2'][data-status='previous'] .case-study-image-container-2 {
    transform: translate(0, calc(-1170 * 100vw / var(--page-width)));
  }

  [data-cs='2'][data-status='previous'] .case-study-image-container-3 {
    transform: translate(0, calc(-911 * 100vw / var(--page-width)));
  }
}

[data-cs='2'][data-status='previous'] .case-study-image-container-4 {
  transform: var(--sm-second-img-100);
}

@media only screen and (min-width: 768px) {
  [data-cs='2'][data-status='previous'] .case-study-image-container-4 {
    transform: translate(0, calc(-916 * 100vw / var(--page-width)));
  }

  [data-cs='2'][data-status='previous'] .case-study-image-container-5 {
    transform: translate(0, calc(-755 * 100vw / var(--page-width)));
  }
}

/* Active 3 */

[data-cs='3'] .case-study-image-container-1 {
  left: 0;
  transform: var(--sm-first-img-0);
}

@media only screen and (min-width: 768px) {
  [data-cs='3'] .case-study-image-container-1 {
    height: calc(560 * 100vw / var(--page-width));
    left: calc(140 * 100vw / var(--page-width));
    transform: translate(0, calc(549 * 100vw / var(--page-width)));
    width: calc(293 * 100vw / var(--page-width));
  }
}

[data-cs='3'] .case-study-image-container-2 {
  display: none;
}

@media only screen and (min-width: 768px) {
  [data-cs='3'] .case-study-image-container-2 {
    display: block;
    height: calc(560 * 100vw / var(--page-width));
    left: calc(503 * 100vw / var(--page-width));
    transform: translate(0, calc(580 * 100vw / var(--page-width)));
    width: calc(293 * 100vw / var(--page-width));
  }
}

[data-cs='3'] .case-study-image-container-3 {
  display: none;
}

@media only screen and (min-width: 768px) {
  [data-cs='3'] .case-study-image-container-3 {
    display: block;
    height: calc(560 * 100vw / var(--page-width));
    left: calc(873 * 100vw / var(--page-width));
    transform: translate(0, calc(598 * 100vw / var(--page-width)));
    width: calc(293 * 100vw / var(--page-width));
  }
}

[data-cs='3'] .case-study-image-container-4 {
  left: calc(106 * 100vw / var(--page-width));
  transform: var(--sm-second-img-0);
}

@media only screen and (min-width: 768px) {
  [data-cs='3'] .case-study-image-container-4 {
    height: calc(560 * 100vw / var(--page-width));
    left: calc(1247 * 100vw / var(--page-width));
    transform: translate(0, calc(551 * 100vw / var(--page-width)));
    width: calc(293 * 100vw / var(--page-width));
  }
}

[data-cs='3'][data-status='current'] .case-study-image-container-1 {
  transform: var(--sm-first-img-50);
}

@media only screen and (min-width: 768px) {
  [data-cs='3'][data-status='current'] .case-study-image-container-1 {
    transform: translate(0, calc(-179 * 100vw / var(--page-width)));
  }

  [data-cs='3'][data-status='current'] .case-study-image-container-2 {
    transform: translate(0, calc(-320 * 100vw / var(--page-width)));
  }

  [data-cs='3'][data-status='current'] .case-study-image-container-3 {
    transform: translate(0, calc(-128 * 100vw / var(--page-width)));
  }
}

[data-cs='3'][data-status='current'] .case-study-image-container-4 {
  transform: var(--sm-second-img-50);
}

@media only screen and (min-width: 768px) {
  [data-cs='3'][data-status='current'] .case-study-image-container-4 {
    transform: translate(0, calc(-351 * 100vw / var(--page-width)));
  }
}

[data-cs='3'] .case-study-image-container-bg {
  height: 100%;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: auto;
}

@media only screen and (min-width: 768px) {
  [data-cs='3'] .case-study-image-container-bg {
    height: auto;
    left: calc(-420 * 100vw / var(--page-width));
    transform: translate(0, -50%);
    width: 100%;
  }
}

[data-cs='3'][data-status='previous'] .case-study-image-container-1 {
  transform: var(--sm-first-img-100);
}

@media only screen and (min-width: 768px) {
  [data-cs='3'][data-status='previous'] .case-study-image-container-1 {
    transform: translate(0, calc(-1109 * 100vw / var(--page-width)));
  }

  [data-cs='3'][data-status='previous'] .case-study-image-container-2 {
    transform: translate(0, calc(-1140 * 100vw / var(--page-width)));
  }

  [data-cs='3'][data-status='previous'] .case-study-image-container-3 {
    transform: translate(0, calc(-1161 * 100vw / var(--page-width)));
  }
}

[data-cs='3'][data-status='previous'] .case-study-image-container-4 {
  transform: var(--sm-second-img-100);
}

@media only screen and (min-width: 768px) {
  [data-cs='3'][data-status='previous'] .case-study-image-container-4 {
    transform: translate(0, calc(-1111 * 100vw / var(--page-width)));
  }
}

/* Active 4 */

[data-cs='4'] .case-study-image-container-1 {
  left: calc(106 * 100vw / var(--page-width));
  transform: var(--sm-first-img-0);
}

@media only screen and (min-width: 768px) {
  [data-cs='4'] .case-study-image-container-1 {
    height: calc(342 * 100vw / var(--page-width));
    left: calc(209 * 100vw / var(--page-width));
    transform: translate(0, calc(593 * 100vw / var(--page-width)));
    width: calc(455 * 100vw / var(--page-width));
  }
}

[data-cs='4'] .case-study-image-container-2 {
  display: none;
}

@media only screen and (min-width: 768px) {
  [data-cs='4'] .case-study-image-container-2 {
    display: block;
    height: calc(223 * 100vw / var(--page-width));
    left: calc(421 * 100vw / var(--page-width));
    transform: translate(0, calc(1016 * 100vw / var(--page-width)));
    width: calc(265 * 100vw / var(--page-width));
  }
}

[data-cs='4'] .case-study-image-container-3 {
  left: 0;
  transform: var(--sm-second-img-0);
}

@media only screen and (min-width: 768px) {
  [data-cs='4'] .case-study-image-container-3 {
    height: calc(577 * 100vw / var(--page-width));
    left: calc(1100 * 100vw / var(--page-width));
    transform: translate(0, calc(626 * 100vw / var(--page-width)));
    width: calc(455 * 100vw / var(--page-width));
  }
}

[data-cs='4'][data-status='current'] .case-study-image-container-1 {
  transform: var(--sm-first-img-50);
}

@media only screen and (min-width: 768px) {
  [data-cs='4'][data-status='current'] .case-study-image-container-1 {
    transform: translate(0, calc(-383 * 100vw / var(--page-width)));
  }

  [data-cs='4'][data-status='current'] .case-study-image-container-2 {
    transform: translate(0, calc(146 * 100vw / var(--page-width)));
  }
}

[data-cs='4'][data-status='current'] .case-study-image-container-3 {
  transform: var(--sm-second-img-50);
}

@media only screen and (min-width: 768px) {
  [data-cs='4'][data-status='current'] .case-study-image-container-3 {
    transform: translate(0, calc(-286 * 100vw / var(--page-width)));
  }
}

[data-cs='4'][data-status='previous'] .case-study-image-container-1 {
  transform: var(--sm-first-img-100);
}

@media only screen and (min-width: 768px) {
  [data-cs='4'][data-status='previous'] .case-study-image-container-1 {
    transform: translate(0, calc(-1493 * 100vw / var(--page-width)));
  }

  [data-cs='4'][data-status='previous'] .case-study-image-container-2 {
    transform: translate(0, calc(-756 * 100vw / var(--page-width)));
  }
}

[data-cs='4'][data-status='previous'] .case-study-image-container-3 {
  transform: var(--sm-second-img-100);
}

@media only screen and (min-width: 768px) {
  [data-cs='4'][data-status='previous'] .case-study-image-container-3 {
    transform: translate(0, calc(-1006 * 100vw / var(--page-width)));
  }
}

/* Active 5 */

[data-cs='5'] .case-study-image-container-1 {
  left: calc(106 * 100vw / var(--page-width));
  transform: var(--sm-second-img-0);
}

@media only screen and (min-width: 768px) {
  [data-cs='5'] .case-study-image-container-1 {
    height: calc(320 * 100vw / var(--page-width));
    left: calc(140 * 100vw / var(--page-width));
    transform: translate(0, calc(511 * 100vw / var(--page-width)));
    width: calc(266 * 100vw / var(--page-width));
  }
}

[data-cs='5'] .case-study-image-container-2 {
  left: 0;
  transform: var(--sm-first-img-0);
}

@media only screen and (min-width: 768px) {
  [data-cs='5'] .case-study-image-container-2 {
    height: calc(167 * 100vw / var(--page-width));
    left: calc(460 * 100vw / var(--page-width));
    transform: translate(0, calc(448 * 100vw / var(--page-width)));
    width: calc(167 * 100vw / var(--page-width));
  }
}

[data-cs='5'] .case-study-image-container-3 {
  display: none;
}

@media only screen and (min-width: 768px) {
  [data-cs='5'] .case-study-image-container-3 {
    display: block;
    height: calc(167 * 100vw / var(--page-width));
    left: calc(1003 * 100vw / var(--page-width));
    transform: translate(0, calc(347 * 100vw / var(--page-width)));
    width: calc(167 * 100vw / var(--page-width));
  }
}

[data-cs='5'] .case-study-image-container-4 {
  display: none;
}

@media only screen and (min-width: 768px) {
  [data-cs='5'] .case-study-image-container-4 {
    display: block;
    height: calc(405 * 100vw / var(--page-width));
    left: calc(1234 * 100vw / var(--page-width));
    transform: translate(0, calc(384 * 100vw / var(--page-width)));
    width: calc(300 * 100vw / var(--page-width));
  }
}

[data-cs='5'][data-status='current'] .case-study-image-container-1 {
  transform: var(--sm-second-img-50);
}

@media only screen and (min-width: 768px) {
  [data-cs='5'][data-status='current'] .case-study-image-container-1 {
    transform: translate(0, calc(61 * 100vw / var(--page-width)));
  }
}

[data-cs='5'][data-status='current'] .case-study-image-container-2 {
  transform: var(--sm-first-img-50);
}

@media only screen and (min-width: 768px) {
  [data-cs='5'][data-status='current'] .case-study-image-container-2 {
    transform: translate(0, calc(158 * 100vw / var(--page-width)));
  }

  [data-cs='5'][data-status='current'] .case-study-image-container-3 {
    transform: translate(0, calc(-243 * 100vw / var(--page-width)));
  }

  [data-cs='5'][data-status='current'] .case-study-image-container-4 {
    transform: translate(0, calc(-324 * 100vw / var(--page-width)));
  }
}

/* For transition to case study we are copying these videos instead of cloning
to avoid loading cause due to cloning. By copying the video does not re-load
preventing a visual flicker while it is displayed. */
[data-case-study-video] {
  display: none;
}
