html,
body {
  height: 100%;
  margin: 0;
}

body {
  background: #000;
  overflow: hidden;
  font-family: var(--font-inter);
}

html.cutout-overlay-active,
body.cutout-overlay-active {
  background: transparent;
}

.video-section {
  position: relative;
  width: 100%;
  height: 100vh;
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  --scroll-fade: 0;
}

.section-video {
  width: 100%;
  height: auto;
  display: block;
  align-self: flex-start;
  transition: none;
}

.video-poster {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  opacity: 0;
  pointer-events: none;
  transition: none;
  z-index: 1;
}

.video-section.is-finished .video-poster {
  opacity: 1;
  pointer-events: none;
}

.video-section.is-finished .section-video {
  opacity: 0;
  pointer-events: none;
}

.video-section.is-finished .zoom-lens {
  opacity: 0;
  pointer-events: none;
}

.poster-spacer {
  display: block;
  width: 100%;
  height: auto;
  opacity: 0;
  pointer-events: none;
}

.video-section.cutout-overlay-active .poster-slice {
  opacity: 0;
}

.video-section.cutout-overlay-active .video-controls-wrap,
.video-section.cutout-overlay-active .video-progress {
  opacity: 0;
  pointer-events: none;
}

.poster-foreground {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  pointer-events: none;
}

.poster-base {
  z-index: 1;
}

.video-section.is-finished .poster-base {
  filter: blur(calc(var(--scroll-fade, 0) * 32px));
  opacity: calc(1 - var(--scroll-fade, 0));
  transition: filter 0.2s linear, opacity 0.2s linear;
}

.video-section.is-finished .poster-foreground {
  -webkit-clip-path: polygon(
    0 20%,
    100% 20%,
    100% 47%,
    75% 47%,
    75% 100%,
    65% 100%,
    65% 40%,
    40% 40%,
    40% 100%,
    30% 100%,
    30% 50%,
    0 40%
  );
  clip-path: polygon(
    0 20%,
    100% 20%,
    100% 47%,
    75% 47%,
    75% 100%,
    65% 100%,
    65% 40%,
    40% 40%,
    40% 100%,
    30% 100%,
    30% 50%,
    0 40%
  );
}

.video-section.is-finished:not(.cutout-overlay-active) .poster-slice {
  opacity: calc(1 - var(--scroll-fade, 0));
  transition: opacity 0.2s linear;
}

.poster-slice {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  pointer-events: none;
  z-index: 2;
}

.poster-slice-top {
  clip-path: inset(0 0 80% 0);
}

.poster-slice-bottom {
  clip-path: polygon(0 40%, 30% 50%, 30% 100%, 0 100%);
}

.poster-slice-house {
  clip-path: inset(42% 30% 15% 40%);
}

.video-section.is-finished .poster-slice-house {
  transform: translateY(calc(var(--scroll-fade, 0) * -24px));
  transition: transform 0.2s linear;
}

.poster-slice-bill {
  clip-path: inset(50% 0% 0% 75%);
}

.zoom-lens {
  position: absolute;
  left: 0;
  top: 0;
  width: 40vw;
  height: 40vw;
  border-radius: 50%;
  overflow: hidden;
  pointer-events: none;
  opacity: 0;
  transform: translate(-50%, -50%) scale(0.98);
  transition: opacity 0.2s ease, transform 0.2s ease;
  z-index: 1;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.35);
}

.zoom-lens.is-active {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.zoom-video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform-origin: top left;
  object-fit: cover;
  will-change: transform;
}

.video-ui {
  position: absolute;
  inset: 0;
  padding: 0 2rem;
  pointer-events: auto;
  z-index: 2;
  --ui-gap: 1.6rem;
}

.video-controls-wrap {
  position: absolute;
  right: var(--ui-gap);
  left: var(--ui-gap)*2;
  bottom: var(--ui-gap);
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.35rem;
  pointer-events: auto;
}

.video-controls-row {
  display: flex;
  align-items: center;
  gap: 0.65rem;
}

.speed-readout {
  width: 100%;
  text-align: center;
  color: #E6FD53;
  font-size: 0.65rem;
  letter-spacing: 0.28em;
  text-transform: uppercase;
}

.video-controls {
  position: relative;
  display: flex;
  align-items: stretch;
  gap: 0;
  padding: 0;
  border-radius: 999px;
  background: #1f3ff7;
  overflow: hidden;
}

.video-controls::before {
  content: "";
  position: absolute;
  top: 0.25rem;
  bottom: 0.25rem;
  left: 0.25rem;
  width: calc(50% - 0.25rem);
  border-radius: 999px;
  background: #E6FD53;
  transition: transform 0.25s ease;
  pointer-events: none;
}

.video-controls.is-pause::before {
  transform: translateX(100%);
}

.video-control {
  position: relative;
  z-index: 1;
  flex: 1 1 0;
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.65rem 1.9rem;
  background: transparent;
  color: #fff;
  font-size: 0.7rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  cursor: pointer;
  transition: color 0.2s ease;
}

.video-controls:not(.is-pause) .video-control:first-child,
.video-controls:not(.is-pause) .video-control:first-child:hover {
  color: #1B263F;
}

.video-controls.is-pause .video-control:last-child,
.video-controls.is-pause .video-control:last-child:hover {
  color: #1B263F;
}

.video-control:hover {
  color: #fff;
}

.speed-control {
  border: 2px solid #E6FD53;
  background: #1f3ff7;
  color: #fff;
  padding: 0.4rem 0.75rem;
  border-radius: 999px;
  font-size: 0.7rem;
  letter-spacing: 0.1em;
  cursor: pointer;
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.speed-control:hover {
  transform: translateY(-1px);
}

.speed-control:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  transform: none;
}

.speed-up-wrap {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.zoom-toggle {
  position: absolute;
  bottom: calc(100% + 0.2rem);
  left: 50%;
  transform: translateX(-50%);
  width: 2.9rem;
  height: 2.9rem;
  border: none;
  background: transparent;
  padding: 0;
  cursor: pointer;
  display: grid;
  place-items: center;
}

.zoom-icon {
  width: 100%;
  height: 100%;
}

.zoom-icon circle,
.zoom-icon line {
  stroke: #ee4703;
  stroke-width: 3.1;
  stroke-linecap: round;
  fill: none;
}

.zoom-check {
  stroke: #000;
  stroke-width: 2.4;
  stroke-linecap: round;
  stroke-linejoin: round;
  fill: none;
  opacity: 0;
  transition: opacity 0.2s ease;
}

.speed-up-wrap.is-checked .zoom-check {
  opacity: 1;
}

.zoom-toggle {
  transition: transform 0.2s ease;
}

.zoom-toggle:hover {
  transform: translateX(-50%) scale(1.12);
}

.replay-control {
  position: absolute;
  left: calc(var(--ui-gap) * 2);
  bottom: var(--ui-gap);
  display: flex;
  align-items: center;
  gap: 0.8rem;
  border: none;
  background: transparent;
  color: #f5f5f5;
  padding: 0;
  border-radius: 999px;
  cursor: pointer;
  pointer-events: auto;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 0.3s ease, transform 0.3s ease;
}

.replay-control.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.video-section.is-finished .replay-control.is-visible {
  opacity: calc(1 - var(--scroll-fade, 0));
  transform: translateX(calc(var(--scroll-fade, 0) * -560px));
}

.replay-control:disabled {
  opacity: 0;
  pointer-events: none;
}

.replay-icon {
  display: block;
  width: 3.4rem;
  height: 3.4rem;
}

.replay-ring {
  fill: none;
  stroke: #1f3ff7;
  stroke-width: 3;
}

.replay-core {
  fill: #E6FD53;
  opacity: 0.6;
  transform-origin: center;
  transform-box: fill-box;
  animation: replayBlink 1.1s ease-in-out infinite;
  animation-play-state: paused;
}

.replay-control.is-visible .replay-core {
  animation-play-state: running;
}

.replay-text {
  font-size: 1.25rem;
  letter-spacing: 0.35em;
  text-transform: uppercase;
}

@keyframes replayBlink {
  0%,
  100% {
    opacity: 0.45;
    transform: scale(0.96);
  }
  50% {
    opacity: 1;
    transform: scale(1);
  }
}

.video-progress {
  position: absolute;
  top: var(--ui-gap);
  right: var(--ui-gap);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.4rem;
  color: #f5f5f5;
  pointer-events: none;
}

.progress-circle {
  position: relative;
  width: 4.4rem;
  height: 4.4rem;
  display: grid;
  place-items: center;
}

.progress-svg {
  width: 100%;
  height: 100%;
  transform: rotate(-90deg);
}

.progress-track {
  fill: none;
  stroke: rgba(255, 255, 255, 0.25);
  stroke-width: 8;
}

.progress-bar {
  fill: none;
  stroke: #1f3ff7;
  stroke-width: 8;
  stroke-linecap: round;
  stroke-dasharray: 326.7;
  stroke-dashoffset: 326.7;
  transition: stroke-dashoffset 0.2s linear;
}

.progress-value {
  position: absolute;
  font-size: 0.85rem;
  letter-spacing: 0.12em;
}

.progress-step {
  font-size: 0.7rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
}

.video-ui .scroll-indicator {
  position: absolute;
  left: 50%;
  bottom: var(--scroll-indicator-bottom, clamp(1.6rem, 4vh, 2.8rem));
  width: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.35rem;
  opacity: 0;
  transform: translate(-50%, 8px) scale(var(--scroll-indicator-scale, 1));
  transition: opacity 350ms ease, transform 350ms ease;
  pointer-events: none;
}

.video-ui .scroll-indicator.revealed {
  opacity: 1;
  transform: translate(-50%, 0) scale(var(--scroll-indicator-scale, 1));
  pointer-events: auto;
  cursor: pointer;
}

.video-section.is-finished .video-ui .scroll-indicator.revealed {
  opacity: calc(1 - var(--scroll-fade, 0));
  transform: translate(-50%, calc(var(--scroll-fade, 0) * 540px));
}

@media (max-width: 900px) {
  .video-section {
    align-items: center;
    justify-content: center;
  }

  .section-video,
  .poster-foreground,
  .poster-slice,
  .poster-spacer {
    height: 100%;
    object-fit: cover;
  }

  .zoom-lens {
    display: none;
  }

  .zoom-toggle {
    display: none;
  }

  .speed-readout {
    display: block;
    width: 100%;
    text-align: center;
    font-size: 0.55rem;
    letter-spacing: 0.22em;
  }

  .video-ui {
    padding: 0 1rem;
    --ui-gap: 1rem;
  }

  .video-controls-wrap {
    left: var(--ui-gap);
    right: var(--ui-gap);
    align-items: stretch;
  }

  .video-controls-row {
    width: 100%;
    flex-wrap: nowrap;
    justify-content: space-between;
    gap: 0.5rem;
  }

  .video-controls {
    flex: 1 1 auto;
    justify-content: center;
  }

  .speed-up-wrap {
    gap: 0.4rem;
  }

  .zoom-toggle {
    position: static;
    transform: none;
    width: 2.4rem;
    height: 2.4rem;
  }

  .video-progress {
    top: var(--ui-gap);
    bottom: auto;
    left: var(--ui-gap);
    right: var(--ui-gap);
  }

  .replay-control {
    right: var(--ui-gap);
    bottom: calc(var(--ui-gap) + 6.5rem);
  }
}

@media (max-width: 600px) {
  .video-control {
    padding: 0.45rem 1.2rem;
    letter-spacing: 0.22em;
  }

  .speed-control {
    padding: 0.35rem 0.6rem;
  }

  .speed-readout {
    letter-spacing: 0.2em;
  }

  .video-controls-row {
    flex-direction: row;
    gap: 0.5rem;
    width: 100%;
  }

  .video-controls {
    width: 100%;
    justify-content: space-between;
  }

  .speed-up-wrap {
    gap: 0.4rem;
  }
}

@media (hover: none) {
  .speed-control:hover {
    transform: none;
  }
}

@media (max-width: 900px) and (orientation: landscape) {
  .video-section {
    align-items: stretch;
  }

  .section-video,
  .video-poster,
  .poster-foreground,
  .poster-base,
  .poster-slice,
  .poster-spacer {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .poster-spacer {
    display: none;
  }
}
