﻿/* ANIMATIONS */
.transition-fade {
  transition: opacity 1s ease-in-out;
}

.transition-slowfade {
  transition: opacity 4s ease-in-out;
}

.transition-flip[data-state=active] {
  animation: flip-active 2s forwards;
}

.transition-flip[data-state=inactive] {
  animation: fade-inactive 2s forwards;
}

.transition-slide[data-state=active] {
  animation: slide-active 2s forwards;
}

.transition-slide[data-state=inactive] {
  animation: slide-inactive 2s forwards;
}

.transition-slide-fade[data-state=active] {
  animation: slide-active 2s forwards;
}

.transition-slide-fade[data-state=inactive] {
  animation: fade-inactive 2s forwards;
}

@keyframes slide-active {
  from {
    opacity: 0;
    transform: translateX(100%);
  }
  to {
    transform: translateX(0%);
    opacity: 1;
  }
}
@keyframes slide-inactive {
  from {
    opacity: 1;
    transform: translateX(0%);
  }
  to {
    transform: translateX(-100%);
    opacity: 0;
  }
}
@keyframes fade-inactive {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
@keyframes flip-active {
  from {
    opacity: 0;
    transform: rotateX(180deg);
  }
  to {
    transform: rotateX(0deg);
    opacity: 1;
  }
}
/* TV settings */
.transition-retro-tv figcaption {
  content: "AV-1";
  color: #00FF00;
  position: absolute;
  top: 8px;
  left: 24px;
  font-size: 32px;
  visibility: hidden;
  pointer-events: none;
}

.transition-retro-tv[data-state=active] {
  background: #121010;
}
.transition-retro-tv[data-state=active]::after {
  content: " ";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  background: rgba(18, 16, 16, 0.1);
  opacity: 0;
  z-index: 2;
  pointer-events: none;
}
.transition-retro-tv[data-state=active]::before {
  content: " ";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  background: linear-gradient(rgba(18, 16, 16, 0) 50%, rgba(0, 0, 0, 0.25) 50%), linear-gradient(90deg, rgba(255, 0, 0, 0.06), rgba(0, 255, 0, 0.02), rgba(0, 0, 255, 0.06));
  z-index: 2;
  background-size: 100% 2px, 3px 100%;
  pointer-events: none;
}

.transition-retro-tv[data-state=active]::after {
  animation: tv-flicker 0.15s infinite;
}

.transition-retro-tv[data-state=inactive] {
  animation: tv-off 0.55s cubic-bezier(0.23, 1, 0.32, 1);
  animation-fill-mode: forwards;
}

.transition-retro-tv[data-state=active] {
  animation: tv-on 4s linear;
  animation-fill-mode: forwards;
}

.transition-retro-tv[data-state=active] figcaption {
  animation: tv-overlay-anim 5s linear;
  animation-fill-mode: forwards;
}

@keyframes tv-on {
  0% {
    transform: scale(1, 0.8) translate3d(0, 0, 0);
    filter: brightness(30);
    opacity: 1;
  }
  3.5% {
    transform: scale(1, 0.8) translate3d(0, 100%, 0);
  }
  3.6% {
    transform: scale(1, 0.8) translate3d(0, -100%, 0);
    opacity: 1;
  }
  9% {
    transform: scale(1.3, 0.6) translate3d(0, 100%, 0);
    filter: brightness(30);
    opacity: 0;
  }
  11% {
    transform: scale(1, 1) translate3d(0, 0, 0);
    filter: contrast(0) brightness(0);
    opacity: 0;
  }
  100% {
    transform: scale(1, 1) translate3d(0, 0, 0);
    filter: contrast(1) brightness(1.2) saturate(1.3);
    opacity: 1;
  }
}
@keyframes tv-off {
  0% {
    transform: scale(1, 1.3) translate3d(0, 0, 0);
    filter: brightness(1);
    opacity: 1;
  }
  60% {
    transform: scale(1.3, 0.001) translate3d(0, 0, 0);
    filter: brightness(10);
  }
  100% {
    animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    transform: scale(0, 0.0001) translate3d(0, 0, 0);
    filter: brightness(50);
  }
}
@keyframes tv-flicker {
  0% {
    opacity: 0.7624651997;
  }
  5% {
    opacity: 0.2423547805;
  }
  10% {
    opacity: 0.1866694479;
  }
  15% {
    opacity: 0.5570656803;
  }
  20% {
    opacity: 0.165353959;
  }
  25% {
    opacity: 0.9832441059;
  }
  30% {
    opacity: 0.4031866448;
  }
  35% {
    opacity: 0.5471501428;
  }
  40% {
    opacity: 0.3846313401;
  }
  45% {
    opacity: 0.7770198772;
  }
  50% {
    opacity: 0.086556041;
  }
  55% {
    opacity: 0.9842266046;
  }
  60% {
    opacity: 0.5079387947;
  }
  65% {
    opacity: 0.9132956938;
  }
  70% {
    opacity: 0.265698336;
  }
  75% {
    opacity: 0.2676638259;
  }
  80% {
    opacity: 0.6934766402;
  }
  85% {
    opacity: 0.7690351242;
  }
  90% {
    opacity: 0.5154367642;
  }
  95% {
    opacity: 0.8097453753;
  }
  100% {
    opacity: 0.4928924081;
  }
}
@keyframes tv-overlay-anim {
  0% {
    visibility: hidden;
  }
  20% {
    visibility: hidden;
  }
  21% {
    visibility: visible;
  }
  100% {
    visibility: hidden;
  }
}
