@import url('https://fonts.googleapis.com/css2?family=IM+Fell+English&display=swap');

*, *::before, *::after {
  padding: 0;
  margin: 0;
  box-sizing: border-box;
}

body {
  font-family: 'IM Fell English', serif;
  background-image: repeating-linear-gradient(60deg, #000 0px, #222 2px, #000 4px);
  color: #fff;
  min-height: 100vh;
  display: grid;
  place-items: center;
  overflow: hidden;
}

.container {
  position: relative;
}

button {
  position: absolute;
  left: 50%; top: -0.5em;
  font: inherit;
  font-size: 4em;
  color: #444;
  background: none;
  border: none;
  translate: -50% -50%;
  opacity: 0.5;
  -webkit-animation: restart 1s 16s forwards;
          animation: restart 1s 16s forwards;
  transition: color 0.3s;
  display: none;
  
  &:hover {
    color: #aaa;
  }
  
  &:active {
    opacity: 1;
    color: #fff;
    
    &, & ~ .typing::before, & ~ .typing::after {
      -webkit-animation: none;
              animation: none;
    }
  }
}

@-webkit-keyframes restart {
  to { color: #fff; }
}

@keyframes restart {
  to { color: #fff; }
}

.typing {
  font-size: 48px;
  text-align: center;
  
  &::before {
    content: '';
    -webkit-animation: text 14.5s 1s step-end forwards;
            animation: text 14.5s 1s step-end forwards;
  }

  &::after {
    content: '';
    display: inline-block;
    width: 0;
    translate: -0.2em;
    -webkit-animation: chars 5s 0.5s step-end 3;
            animation: chars 5s 0.5s step-end 3;
  }
}

@-webkit-keyframes text {
  0%  { content: 'W'; }
  2%  { content: 'We'; }
  4%  { content: 'Web'; }
  6%  { content: 'Webb'; }
  8%  { content: 'Webbp'; }
  10%  { content: 'Webbpl'; }
  12%  { content: 'Webbpla'; }
  14%  { content: 'Webbplat'; }
  16%  { content: 'Webbplats'; }
  18%  { content: 'Webbplatse'; }
  20%  { content: 'Webbplatsen'; }
  22%  { content: 'Webbplatsen '; }
  24%  { content: 'Webbplatsen '; }
  26%  { content: 'Webbplatsen ä'; }
  28%  { content: 'Webbplatsen är'; }
  30%  { content: 'Webbplatsen är '; }
  32%  { content: 'Webbplatsen är u'; }
  34%  { content: 'Webbplatsen är un'; }
  36%  { content: 'Webbplatsen är und'; }
  38%  { content: 'Webbplatsen är unde'; }
  40%  { content: 'Webbplatsen är under'; }
  42%  { content: 'Webbplatsen är under '; }
  44%  { content: 'Webbplatsen är under u'; }
  46%  { content: 'Webbplatsen är under up'; }
  48%  { content: 'Webbplatsen är under upp'; }
  50%  { content: 'Webbplatsen är under uppb'; }
  52%  { content: 'Webbplatsen är under uppby'; }
  54%  { content: 'Webbplatsen är under uppbyg'; }
  56%  { content: 'Webbplatsen är under uppbygg'; }
  58%  { content: 'Webbplatsen är under uppbyggn'; }
  60%  { content: 'Webbplatsen är under uppbyggna'; }
  62%  { content: 'Webbplatsen är under uppbyggnad'; }
  64%  { content: 'Webbplatsen är under uppbyggnad.'; }
  66%  { content: 'Webbplatsen är under uppbyggnad. '; }
  68%  { content: 'Webbplatsen är under uppbyggnad. V'; }
  70%  { content: 'Webbplatsen är under uppbyggnad. Vä'; }
  72%  { content: 'Webbplatsen är under uppbyggnad. Vän'; }
  74%  { content: 'Webbplatsen är under uppbyggnad. Vänl'; }
  76%  { content: 'Webbplatsen är under uppbyggnad. Vänli'; }
  78%  { content: 'Webbplatsen är under uppbyggnad. Vänlig'; }
  80%  { content: 'Webbplatsen är under uppbyggnad. Vänlige'; }
  82%  { content: 'Webbplatsen är under uppbyggnad. Vänligen'; }
  84%  { content: 'Webbplatsen är under uppbyggnad. Vänligen '; }
  86%  { content: 'Webbplatsen är under uppbyggnad. Vänligen å'; }
  88%  { content: 'Webbplatsen är under uppbyggnad. Vänligen åt'; }
  90%  { content: 'Webbplatsen är under uppbyggnad. Vänligen åte'; }
  92%  { content: 'Webbplatsen är under uppbyggnad. Vänligen åter'; }
  94%  { content: 'Webbplatsen är under uppbyggnad. Vänligen återk'; }
  96%  { content: 'Webbplatsen är under uppbyggnad. Vänligen återko'; }
  98%  { content: 'Webbplatsen är under uppbyggnad. Vänligen återkom'; }
  100%  { content: 'Webbplatsen är under uppbyggnad. Vänligen återkom.'; }
}

@keyframes text {
  0%  { content: 'W'; }
  2%  { content: 'We'; }
  4%  { content: 'Web'; }
  6%  { content: 'Webb'; }
  8%  { content: 'Webbp'; }
  10%  { content: 'Webbpl'; }
  12%  { content: 'Webbpla'; }
  14%  { content: 'Webbplat'; }
  16%  { content: 'Webbplats'; }
  18%  { content: 'Webbplatse'; }
  20%  { content: 'Webbplatsen'; }
  22%  { content: 'Webbplatsen '; }
  24%  { content: 'Webbplatsen '; }
  26%  { content: 'Webbplatsen ä'; }
  28%  { content: 'Webbplatsen är'; }
  30%  { content: 'Webbplatsen är '; }
  32%  { content: 'Webbplatsen är u'; }
  34%  { content: 'Webbplatsen är un'; }
  36%  { content: 'Webbplatsen är und'; }
  38%  { content: 'Webbplatsen är unde'; }
  40%  { content: 'Webbplatsen är under'; }
  42%  { content: 'Webbplatsen är under '; }
  44%  { content: 'Webbplatsen är under u'; }
  46%  { content: 'Webbplatsen är under up'; }
  48%  { content: 'Webbplatsen är under upp'; }
  50%  { content: 'Webbplatsen är under uppb'; }
  52%  { content: 'Webbplatsen är under uppby'; }
  54%  { content: 'Webbplatsen är under uppbyg'; }
  56%  { content: 'Webbplatsen är under uppbygg'; }
  58%  { content: 'Webbplatsen är under uppbyggn'; }
  60%  { content: 'Webbplatsen är under uppbyggna'; }
  62%  { content: 'Webbplatsen är under uppbyggnad'; }
  64%  { content: 'Webbplatsen är under uppbyggnad.'; }
  66%  { content: 'Webbplatsen är under uppbyggnad. '; }
  68%  { content: 'Webbplatsen är under uppbyggnad. V'; }
  70%  { content: 'Webbplatsen är under uppbyggnad. Vä'; }
  72%  { content: 'Webbplatsen är under uppbyggnad. Vän'; }
  74%  { content: 'Webbplatsen är under uppbyggnad. Vänl'; }
  76%  { content: 'Webbplatsen är under uppbyggnad. Vänli'; }
  78%  { content: 'Webbplatsen är under uppbyggnad. Vänlig'; }
  80%  { content: 'Webbplatsen är under uppbyggnad. Vänlige'; }
  82%  { content: 'Webbplatsen är under uppbyggnad. Vänligen'; }
  84%  { content: 'Webbplatsen är under uppbyggnad. Vänligen '; }
  86%  { content: 'Webbplatsen är under uppbyggnad. Vänligen å'; }
  88%  { content: 'Webbplatsen är under uppbyggnad. Vänligen åt'; }
  90%  { content: 'Webbplatsen är under uppbyggnad. Vänligen åte'; }
  92%  { content: 'Webbplatsen är under uppbyggnad. Vänligen åter'; }
  94%  { content: 'Webbplatsen är under uppbyggnad. Vänligen återk'; }
  96%  { content: 'Webbplatsen är under uppbyggnad. Vänligen återko'; }
  98%  { content: 'Webbplatsen är under uppbyggnad. Vänligen återkom'; }
  100%  { content: 'Webbplatsen är under uppbyggnad. Vänligen återkom.'; }
}

@-webkit-keyframes chars {
  0%  { content: 'a'; }
  2%  { content: 'M'; }
  4%  { content: 'b'; }
  6%  { content: 'N'; }
  8%  { content: 'c'; }
  10%  { content: 'O'; }
  12%  { content: 'd'; }
  14%  { content: 'P'; }
  16%  { content: 'e'; }
  18%  { content: 'Q'; }
  20%  { content: 'f'; }
  22%  { content: 'R'; }
  24%  { content: 'g'; }.
  26%  { content: 'S'; }
  28%  { content: 'h'; }
  30%  { content: 'T'; }
  32%  { content: 'i'; }
  34%  { content: 'U'; }
  36%  { content: 'j'; }
  38%  { content: 'V'; }
  40%  { content: 'k'; }
  42%  { content: 'W'; }
  44%  { content: 'l'; }
  46%  { content: 'X'; }
  48%  { content: 'm'; }
  50%  { content: 'Y'; }
  52%  { content: 'n'; }
  54%  { content: 'Z'; }
  56%  { content: 'o'; }
  58%  { content: 'A'; }
  60%  { content: 'p'; }
  62%  { content: 'B'; }
  64%  { content: 'q'; }
  66%  { content: 'C'; }
  68%  { content: 'r'; }
  70%  { content: 'D'; }
  72%  { content: 's'; }
  74%  { content: 'E'; }
  76%  { content: 't'; }
  78%  { content: 'F'; }
  80%  { content: 'u'; }
  82%  { content: 'G'; }
  84%  { content: 'v'; }
  86%  { content: 'H'; }
  88%  { content: 'w'; }
  90%  { content: 'I'; }
  92%  { content: 'x'; }
  94%  { content: 'J'; }
  96%  { content: 'y'; }
  98%  { content: 'K'; }
}

@keyframes chars {
  0%  { content: 'a'; }
  2%  { content: 'M'; }
  4%  { content: 'b'; }
  6%  { content: 'N'; }
  8%  { content: 'c'; }
  10%  { content: 'O'; }
  12%  { content: 'd'; }
  14%  { content: 'P'; }
  16%  { content: 'e'; }
  18%  { content: 'Q'; }
  20%  { content: 'f'; }
  22%  { content: 'R'; }
  24%  { content: 'g'; }.
  26%  { content: 'S'; }
  28%  { content: 'h'; }
  30%  { content: 'T'; }
  32%  { content: 'i'; }
  34%  { content: 'U'; }
  36%  { content: 'j'; }
  38%  { content: 'V'; }
  40%  { content: 'k'; }
  42%  { content: 'W'; }
  44%  { content: 'l'; }
  46%  { content: 'X'; }
  48%  { content: 'm'; }
  50%  { content: 'Y'; }
  52%  { content: 'n'; }
  54%  { content: 'Z'; }
  56%  { content: 'o'; }
  58%  { content: 'A'; }
  60%  { content: 'p'; }
  62%  { content: 'B'; }
  64%  { content: 'q'; }
  66%  { content: 'C'; }
  68%  { content: 'r'; }
  70%  { content: 'D'; }
  72%  { content: 's'; }
  74%  { content: 'E'; }
  76%  { content: 't'; }
  78%  { content: 'F'; }
  80%  { content: 'u'; }
  82%  { content: 'G'; }
  84%  { content: 'v'; }
  86%  { content: 'H'; }
  88%  { content: 'w'; }
  90%  { content: 'I'; }
  92%  { content: 'x'; }
  94%  { content: 'J'; }
  96%  { content: 'y'; }
  98%  { content: 'K'; }
}