#reactions{
    position:fixed;
    bottom:0px;
    left:0px;
    height:50%;
    width:100vw;
    background: rgb(27,12,28);
    background: linear-gradient(0deg, rgba(0,0,0,0.4) 15%, rgba(0,0,0,0) 97%);
    overflow-x:hidden;
}

:root{
    --reac-item-size: 64px;
}

#reactions td{
    text-align:center;
    padding:0px;
    width:100vw;
    overflow-x:hidden;
}

.reactions-switcher{
    display:flex;
    flex-direction:column;
    align-items:center;
    position:relative;
    width:500px;
    max-width:100%;
    margin:0 auto;
}

.reactions-switcher.is-photo-mode.is-showing-tutorial::before{
    content:"";
    position:fixed;
    inset:0;
    background:rgba(0, 0, 0, 0.62);
    backdrop-filter:blur(3px);
    -webkit-backdrop-filter:blur(3px);
    z-index:999;
    pointer-events:none;
}

.reactions-slides{
    width:100%;
    max-width:100%;
    position:relative;
    overflow:visible;
    min-height:118px;
    margin:0 auto;
}

.reactions-slide{
    display:none;
    width:100%;
    justify-content:center;
}

.reactions-slide.is-active{
    display:flex;
}

.reactions-pager{
    position:absolute;
    left:50%;
    bottom:12px;
    transform:translateX(-50%);
    z-index:4;
    display:inline-flex;
    align-items:center;
    gap:10px;
    padding:0;
    border-radius:0;
    background:transparent;
    border:0;
    box-shadow:none;
}

.reactions-pager__dot{
    width:10px;
    height:10px;
    border-radius:50%;
    border:0;
    padding:0;
    background:rgba(255, 255, 255, 0.28);
    cursor:pointer;
}

.reactions-pager__dot.is-active{
    background:#ffffff;
}

.shared-page--reac .shared-header{
    z-index:30;
}

.reactions-tutorial{
    --tutorial-arrow-size:64px;
    --tutorial-arrow-left:calc(50vw - (var(--tutorial-arrow-size) / 2));
    --tutorial-arrow-top:50vh;
    --tutorial-bubble-left:calc(50vw - 210px);
    --tutorial-bubble-top:96px;
    --tutorial-bubble-width:min(420px, calc(100vw - 24px));
    position:fixed;
    inset:0;
    width:100vw;
    height:100vh;
    height:100dvh;
    z-index:1000;
    display:none;
    pointer-events:none;
    overflow:visible;
}

.reactions-switcher.is-photo-mode.is-showing-tutorial .reactions-tutorial{
    display:block;
}

.reactions-tutorial__arrow{
    position:absolute;
    top:var(--tutorial-arrow-top);
    left:var(--tutorial-arrow-left);
    z-index:1001;
    display:flex;
    align-items:center;
    justify-content:center;
    width:var(--tutorial-arrow-size);
    height:var(--tutorial-arrow-size);
    border-radius:999px;
    color:#ffffff;
    background:rgba(19, 28, 43, 0.96);
    border:1px solid rgba(255,255,255,0.18);
    box-shadow:
      0 12px 28px rgba(0,0,0,0.24),
      0 0 22px rgba(115, 165, 255, 0.22);
    animation: reactionsTutorialBob 1.2s ease-in-out infinite;
    font-size:1.8rem;
}

.reactions-tutorial__bubble{
    position:absolute;
    top:var(--tutorial-bubble-top);
    left:var(--tutorial-bubble-left);
    z-index:1001;
    width:var(--tutorial-bubble-width);
    max-width:calc(100vw - 24px);
    text-align:center;
    color: rgba(255, 255, 255, 0.92);
    font-size: 0.92rem;
    line-height: 1.28;
    text-shadow: 0 0 20px black;
    padding:12px 16px;
    border-radius:18px;
    background:rgba(5, 8, 14, 0.72);
    border:1px solid rgba(255,255,255,0.1);
    box-shadow:0 14px 34px rgba(0,0,0,0.34);
}

.reactions-tutorial__text{
    display:block;
}

.reactions-tutorial__privacy{
    margin-top:10px;
    color:rgba(255,255,255,0.64);
    font-size:0.72rem;
    line-height:1.35;
}

.reactions-tutorial__privacy a{
    color:rgba(255,255,255,0.9);
    text-decoration:underline;
    text-underline-offset:2px;
    pointer-events:auto;
}

.photo-slot.is-tutorial-target{
    position:relative;
    z-index:1002;
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.08),
      inset 0 0 0 2px rgba(255,255,255,0.26),
      0 0 0 6px rgba(255,255,255,0.08),
      0 0 30px rgba(113, 169, 255, 0.3),
      0 14px 28px rgba(0, 0, 0, 0.32);
}

.reactions-switcher.is-photo-mode.is-showing-tutorial .container_emoji--photos{
    position:relative;
    z-index:auto;
}

@keyframes reactionsTutorialBob {
    0%,
    100% {
        transform:translateY(0);
    }
    50% {
        transform:translateY(4px);
    }
}

.container_emoji{
    background-color:rgba(0,0,0,0.5);
    border-radius:50px;
    width:min(720px, calc(100vw - 28px));
    display:grid;
    grid-template-columns:repeat(4, minmax(0, 1fr));
    align-items:center;
    justify-items:center;
    position:relative;
    padding:10px 18px 24px;
    column-gap:8px;
    row-gap:0;
    overflow:visible;
    min-height:86px;
    max-width:100%;
    margin:0px;
    margin:0 auto;
    -ms-overflow-style: none; 
    scrollbar-width: none;
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.container_emoji--reactions{
    display:flex;
    align-items:center;
    justify-content:center;
    width:min(720px, calc(100vw - 28px));
    min-height:94px;
    padding:12px 22px 24px;
    gap:0;
}

.reaction-cell{
    --cooldown-progress:0;
    flex:0 0 25%;
    max-width:25%;
    display:flex;
    align-items:center;
    justify-content:center;
    height:var(--reac-item-size);
    position:relative;
    overflow:visible;
}

.reaction-cell::before,
.reaction-cell::after{
    left:50%;
    top:50%;
    width:var(--reac-item-size);
    height:var(--reac-item-size);
    transform:translate(-50%, -50%);
    border-radius:50%;
}

.reaction-cell > .emoji,
.reaction-cell > button.emoji{
    flex:0 0 auto;
}

.photo-slot-card{
    --cooldown-progress:0;
    position:relative;
    width:var(--reac-item-size);
    height:var(--reac-item-size);
    display:flex;
    align-items:center;
    justify-content:center;
    overflow:visible;
    z-index:998;
}

.photo-slot-card:has(.photo-slot.is-tutorial-target){
    z-index:1002;
}

.photo-slot-card .emoji{
    margin:0;
}

.photo-slot-card.is-blocked::after{
    content:"\f023";
    font-family:"Font Awesome 6 Free";
    font-weight:900;
    position:absolute;
    inset:0;
    display:flex;
    align-items:center;
    justify-content:center;
    color:#ffffff;
    font-size:1rem;
    z-index:4;
    text-shadow:0 2px 12px rgba(0,0,0,0.5);
    pointer-events:none;
}

.photo-slot.is-blocked{
    filter:blur(0px);
}

.photo-slot.is-cooling-down{
    filter:grayscale(1) brightness(0.72);
    cursor:default;
}

.photo-slot.is-blocked::before{
    content:"";
    position:absolute;
    inset:0;
    border-radius:inherit;
    backdrop-filter:blur(5px);
    -webkit-backdrop-filter:blur(5px);
    background:rgba(7, 11, 19, 0.28);
    z-index:2;
}

.photo-slot.is-cooling-down::before{
    content:"";
    position:absolute;
    inset:0;
    border-radius:inherit;
    background:rgba(7, 11, 19, 0.18);
    z-index:2;
}

.photo-slot.is-blocked .emoji__camera-icon{
    opacity:0;
}

.photo-slot-card.is-cooling-down::before{
    content:"";
    position:absolute;
    inset:-4px;
    border-radius:999px;
    background:
        radial-gradient(circle at center, rgba(7, 11, 19, 0.88) 0 64%, transparent 65%),
        conic-gradient(
            from 0deg,
            rgba(255,255,255,0.08) 0deg,
            rgba(255,255,255,0.08) calc((1 - var(--cooldown-progress)) * 360deg),
            rgba(255,255,255,0.92) calc((1 - var(--cooldown-progress)) * 360deg),
            rgba(255,255,255,0.08) 360deg
        );
    -webkit-mask: radial-gradient(farthest-side, transparent calc(100% - 5px), #000 calc(100% - 4px));
    mask: radial-gradient(farthest-side, transparent calc(100% - 5px), #000 calc(100% - 4px));
    z-index:4;
    pointer-events:none;
}

.photo-slot-card.is-cooling-down::after{
    content:attr(data-cooldown-seconds) "s";
    position:absolute;
    inset:0;
    display:flex;
    align-items:center;
    justify-content:center;
    color:#ffffff;
    font-size:0.8rem;
    font-weight:800;
    text-shadow:0 2px 10px rgba(0,0,0,0.5);
    z-index:5;
    pointer-events:none;
}

.photo-slot-delete{
    position:absolute;
    top:-2px;
    right:-2px;
    width:28px;
    height:28px;
    border:0;
    border-radius:999px;
    display:none;
    align-items:center;
    justify-content:center;
    padding:0;
    cursor:pointer;
    color:#ffffff;
    background:rgba(12, 15, 22, 0.92);
    border:1px solid rgba(255,255,255,0.14);
    box-shadow:0 8px 18px rgba(0,0,0,0.32);
    z-index:3;
}

.photo-slot-card.has-photo .photo-slot-delete{
    display:flex;
}

.photo-slot-card.is-blocked .photo-slot-delete{
    display:none !important;
}

.photo-slot-card.is-cooling-down .photo-slot-delete{
    display:none !important;
}

.photo-slot-delete i{
    font-size:0.95rem;
    line-height:1;
}

.emoji {
    width: 120px;
    height: 120px;
    background: rgb(255,131,0);
    background: linear-gradient(0deg, rgba(255,131,0,1) 0%, rgba(255,239,0,1) 100%);
    display: inline-flex;
    border-radius: 50%;
    position: relative;
    margin: 0;
    transition: transform 0.2s ease;
  }

  .container_emoji--reactions .emoji{
    width:120px;
    height:120px;
    transform:scale(0.52);
    transform-origin:center center;
    margin:0;
  }

  .container_emoji--reactions .emoji--mode-toggle,
  .container_emoji--reactions .emoji--mode-toggle-back{
    width:var(--reac-item-size);
    height:var(--reac-item-size);
    min-width:var(--reac-item-size);
    min-height:var(--reac-item-size);
    max-width:var(--reac-item-size);
    max-height:var(--reac-item-size);
    transform:none;
  }

  button.emoji {
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border: 0;
    padding: 0;
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
    overflow:visible;
  }

  .selfie-input {
    display: none;
  }

  .emoji--camera,
  .emoji--mode-toggle,
  .emoji--selfie {
    width:var(--reac-item-size);
    height:var(--reac-item-size);
    min-width:var(--reac-item-size);
    min-height:var(--reac-item-size);
    max-width:var(--reac-item-size);
    max-height:var(--reac-item-size);
    aspect-ratio:1 / 1;
    background: linear-gradient(180deg, #1e2430 0%, #0a0f16 100%);
    border: 1px solid rgba(255, 255, 255, 0.16);
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.08),
      0 10px 24px rgba(0, 0, 0, 0.28);
  }

  .emoji--camera .emoji__camera-icon {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    font-size: 2rem;
    text-shadow:0 8px 18px rgba(0,0,0,0.34);
  }

  .emoji--camera .emoji__camera-icon i,
  .emoji--mode-toggle .emoji__camera-icon i{
    color:#fbfdff !important;
    filter:drop-shadow(0 4px 10px rgba(0,0,0,0.28));
  }

  .emoji--mode-toggle .emoji__camera-icon i{
    transform:translateX(2px);
  }

  .emoji--mode-toggle-back .emoji__camera-icon i{
    transform:translateX(-2px);
  }

  .emoji--mode-toggle{
    background: linear-gradient(180deg, #1d2740 0%, #0e1830 100%);
    box-shadow:
      inset 0 1px 0 rgba(255,255,255,0.1),
      0 10px 24px rgba(0,0,0,0.28);
  }

.emoji--mode-toggle .emoji__camera-icon{
    font-size:2.2rem;
    transform:none;
  }

  .emoji--camera,
  .photo-slot.emoji--camera{
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.08),
      inset 0 0 0 1px rgba(255,255,255,0.04),
      0 10px 24px rgba(0, 0, 0, 0.28);
  }

  .emoji--camera.is-uploading {
    opacity: 0.72;
  }

  .emoji--selfie {
    background-color: #11161f;
    background-size: cover !important;
    background-position: center center !important;
    background-repeat: no-repeat !important;
  }

  .emoji--selfie-ready .emoji__camera-icon,
  .emoji--selfie-ready .emoji__camera-icon::before {
    opacity: 0 !important;
    display: none !important;
  }

  .photo-slot{
    position:relative;
    background:
      radial-gradient(circle at 50% 38%, rgba(255,255,255,0.08), transparent 30%),
      linear-gradient(180deg, #1f293c 0%, #0b1321 100%);
  }

  .photo-slot .emoji__camera-icon{
    opacity:1;
    transform:translateY(-2px);
  }

  .photo-slot.emoji--selfie-ready{
    background-size: cover !important;
    background-position: center center !important;
    background-repeat: no-repeat !important;
  }

  .photo-slot.emoji--selfie-ready::after{
    content:"";
    position:absolute;
    inset:0;
    border-radius:50%;
    box-shadow:
      inset 0 0 0 1px rgba(255,255,255,0.08),
      0 10px 24px rgba(0,0,0,0.22);
  }

  .emoji--photo-reaction {
    border-color: rgba(255, 255, 255, 0.24);
  }

  .emoji.gif {
    background-color:transparent !important;
    border-radius:0% !important;
    width:120px;
    height:120px;
    background-size:110%;
    background-repeat:no-repeat;
    margin:0;
    background-position:center;
  }

  .container_emoji--reactions .emoji.gif{
    width:120px;
    height:120px;
    transform:scale(0.7);
    margin:0;
    margin-top:-6px;
    background-size:100%;
  }

  @media only screen and (max-width: 800px) {
    :root{
      --reac-mobile-side-gap: 16px;
      --reac-item-size: 64px;
    }

    #reactions{
      width:100vw;
      left:0;
      overflow-x:hidden;
    }

    #reactions td{
      width:100vw;
      overflow-x:hidden;
    }

    .reactions-switcher{
      width:500px;
      max-width:calc(100vw - var(--reac-mobile-side-gap));
      padding:0;
      margin:0 auto;
      overflow-x:hidden;
    }

    .reactions-slides{
      width:100%;
      max-width:100%;
      min-height:110px;
      overflow:hidden;
    }

    .reactions-slide{
      width:100%;
    }

    .container_emoji{
      width:calc(100vw - var(--reac-mobile-side-gap));
      max-width:calc(100vw - var(--reac-mobile-side-gap));
      min-width:0;
      min-height:82px;
      padding:8px 12px 22px;
      align-items:center;
      justify-items:center;
      column-gap:4px;
      overflow:hidden;
      margin:0 auto;
    }

    .container_emoji--reactions{
      min-height:82px;
      width:calc(100vw - var(--reac-mobile-side-gap));
      max-width:calc(100vw - var(--reac-mobile-side-gap));
      padding:8px 14px 22px;
    }

    .reactions-tutorial{
      --tutorial-bubble-width:min(320px, calc(100vw - 20px));
    }

    .reactions-tutorial__bubble{
      font-size:0.86rem;
      line-height:1.22;
      padding:10px 12px;
    }

    .reactions-tutorial__arrow{
      font-size:1.8rem;
    }

    .emoji{
      width:64px;
      height:64px;
    }

    .container_emoji--reactions .emoji{
      width:120px;
      height:120px;
      transform:scale(0.52);
    }

    .container_emoji--reactions .emoji--mode-toggle,
    .container_emoji--reactions .emoji--mode-toggle-back{
      width:var(--reac-item-size);
      height:var(--reac-item-size);
      min-width:var(--reac-item-size);
      min-height:var(--reac-item-size);
      max-width:var(--reac-item-size);
      max-height:var(--reac-item-size);
      transform:none;
    }

    .container_emoji--reactions .emoji.gif{
      width:120px;
      height:120px;
      background-size:100%;
    }

    .emoji--mode-toggle .emoji__camera-icon,
    .emoji--mode-toggle-back .emoji__camera-icon{
      transform:none;
    }

    .emoji--mode-toggle .emoji__camera-icon i{
      transform:translateX(1px);
    }

    .emoji--mode-toggle-back .emoji__camera-icon i{
      transform:translateX(-1px);
    }

    .photo-slot-card{
      width:var(--reac-item-size);
      height:var(--reac-item-size);
    }

    .photo-slot-delete{
      top:-4px;
      right:-1px;
      width:26px;
      height:26px;
    }

    .reactions-pager{
      bottom:12px;
      gap:8px;
    }

    .reactions-pager__dot{
      width:9px;
      height:9px;
    }
  }

  .emoji.gif.surprise {
    background-image:url("../pictures/emojis/surprise.gif");
  }

  .emoji.gif.fire {
    background-image:url("../pictures/emojis/fire.gif");
  }
  
.emoji.clicked {
    animation: none;
  }

  .reaction-cell.is-bouncing,
  .photo-slot-card.is-bouncing{
    animation: bounceUnified 0.5s cubic-bezier(0.25, 1, 0.5, 1);
    transform-origin:center center;
  }

  .reaction-cell.is-cooling-down{
    pointer-events:none;
  }

  .reaction-cell.is-cooling-down > .emoji{
    filter:grayscale(1) brightness(0.72);
  }

  .reaction-cell.is-cooling-down > .emoji > *{
    opacity:0.32;
  }

  .reaction-cell.is-cooling-down::before{
    content:"";
    position:absolute;
    width:calc(var(--reac-item-size) + 8px);
    height:calc(var(--reac-item-size) + 8px);
    background:
      radial-gradient(circle at center, rgba(7, 11, 19, 0.88) 0 64%, transparent 65%),
      conic-gradient(
        from 0deg,
        rgba(255,255,255,0.08) 0deg,
        rgba(255,255,255,0.08) calc((1 - var(--cooldown-progress)) * 360deg),
        rgba(255,255,255,0.92) calc((1 - var(--cooldown-progress)) * 360deg),
        rgba(255,255,255,0.08) 360deg
      );
    -webkit-mask: radial-gradient(farthest-side, transparent calc(100% - 5px), #000 calc(100% - 4px));
    mask: radial-gradient(farthest-side, transparent calc(100% - 5px), #000 calc(100% - 4px));
    z-index:3;
    pointer-events:none;
  }

  .reaction-cell.is-cooling-down::after{
    content:attr(data-cooldown-seconds) "s";
    position:absolute;
    width:var(--reac-item-size);
    height:var(--reac-item-size);
    display:flex;
    align-items:center;
    justify-content:center;
    color:#fff;
    font-size:0.8rem;
    font-weight:800;
    text-shadow:0 2px 10px rgba(0,0,0,0.5);
    z-index:4;
    pointer-events:none;
  }

  @keyframes bounceUnified {
    0%, 20%, 50%, 80%, 100% {
      transform: translateY(0) scale(1);
    }
    40% {
      transform: translateY(-20px) scale(1.09);
    }
    60% {
      transform: translateY(-10px) scale(1.04);
    }
  }

  .emoji__face,
  .emoji__eyebrows,
  .emoji__eyes,
  .emoji__mouth,
  .emoji__tongue,
  .emoji__heart,
  .emoji__hand,
  .emoji__thumb {
    position: absolute;
  }
  .emoji__face:before, .emoji__face:after,
  .emoji__eyebrows:before,
  .emoji__eyebrows:after,
  .emoji__eyes:before,
  .emoji__eyes:after,
  .emoji__mouth:before,
  .emoji__mouth:after,
  .emoji__tongue:before,
  .emoji__tongue:after,
  .emoji__heart:before,
  .emoji__heart:after,
  .emoji__hand:before,
  .emoji__hand:after,
  .emoji__thumb:before,
  .emoji__thumb:after {
    position: absolute;
    content: "";
  }
  
  .emoji__face {
    width: inherit;
    height: inherit;
  }
  
  .emoji--like {
    background: #548dff;
  }
  .emoji--like .emoji__hand {
    left: 25px;
    bottom: 30px;
    width: 20px;
    height: 40px;
    background: #ffffff;
    border-radius: 5px;
    z-index: 0;
    -webkit-animation: hands-up 2s linear infinite;
            animation: hands-up 2s linear infinite;
  }
  .emoji--like .emoji__hand:before {
    left: 25px;
    bottom: 5px;
    width: 40px;
    background: inherit;
    height: 10px;
    border-radius: 2px 10px 10px 2px;
    box-shadow: 1px -9px 0 1px #ffffff, 2px -19px 0 2px #ffffff, 3px -29px 0 3px #ffffff;
  }
  .emoji--like .emoji__thumb {
    border-bottom: 20px solid #ffffff;
    border-left: 20px solid transparent;
    top: -25px;
    right: -25px;
    z-index: 2;
    transform: rotate(5deg);
    transform-origin: 0% 100%;
    -webkit-animation: thumbs-up 2s linear infinite;
            animation: thumbs-up 2s linear infinite;
  }
  .emoji--like .emoji__thumb:before {
    border-radius: 50% 50% 0 0;
    background: #ffffff;
    width: 10px;
    height: 12px;
    left: -10px;
    top: -8px;
    transform: rotate(-15deg);
    transform-origin: 100% 100%;
    box-shadow: -1px 4px 0 -1px #ffffff;
  }
  
  .emoji--love {
    background: #f55064;
    background: linear-gradient(0deg, darkred 0%, #f55064 100%);
  }
  .emoji--love .emoji__heart {
    left: calc(50% - 40px);
    top: calc(50% - 40px);
    width: 80px;
    height: 80px;
    -webkit-animation: heart-beat 1s linear infinite alternate;
            animation: heart-beat 1s linear infinite alternate;
  }
  .emoji--love .emoji__heart:before, .emoji--love .emoji__heart:after {
    left: calc(50% - 20px);
    top: calc(50% - 32px);
    width: 40px;
    height: 64px;
    background: #ffffff;
    border-radius: 20px 20px 0 0;
  }
  .emoji--love .emoji__heart:before {
    transform: translate(20px) rotate(-45deg);
    transform-origin: 0 100%;
  }
  .emoji--love .emoji__heart:after {
    transform: translate(-20px) rotate(45deg);
    transform-origin: 100% 100%;
  }
  
  .emoji--haha .emoji__face {
    -webkit-animation: haha-face 2s linear infinite;
            animation: haha-face 2s linear infinite;
  }
  .emoji--haha .emoji__eyes {
    width: 26px;
    height: 6px;
    border-radius: 2px;
    left: calc(50% - 13px);
    top: 35px;
    transform: rotate(20deg);
    background: transparent;
    box-shadow: -25px 5px 0 0 #000000, 25px -5px 0 0 #000000;
  }
  .emoji--haha .emoji__eyes:after {
    left: 0;
    top: 0;
    width: 26px;
    height: 6px;
    border-radius: 2px;
    transform: rotate(-40deg);
    background: transparent;
    box-shadow: -25px -5px 0 0 #000000, 25px 5px 0 0 #000000;
  }
  .emoji--haha .emoji__mouth {
    width: 80px;
    height: 40px;
    left: calc(50% - 40px);
    top: 50%;
    background: #000000;
    border-radius: 0 0 40px 40px;
    overflow: hidden;
    z-index: 1;
    -webkit-animation: haha-mouth 2s linear infinite;
            animation: haha-mouth 2s linear infinite;
  }
  .emoji--haha .emoji__tongue {
    width: 70px;
    height: 30px;
    background: #f55064;
    left: calc(50% - 35px);
    bottom: -10px;
    border-radius: 50%;
  }
  
  .emoji--yay .emoji__face {
    -webkit-animation: yay 1s linear infinite alternate;
            animation: yay 1s linear infinite alternate;
  }
  .emoji--yay .emoji__eyebrows {
    left: calc(50% - 3px);
    top: 30px;
    height: 6px;
    width: 6px;
    border-radius: 50%;
    background: transparent;
    box-shadow: -6px 0 0 0 #000000, -36px 0 0 0px #000000, 6px 0 0 0 #000000, 36px 0 0 0px #000000;
  }
  .emoji--yay .emoji__eyebrows:before, .emoji--yay .emoji__eyebrows:after {
    width: 36px;
    height: 18px;
    border-radius: 60px 60px 0 0;
    background: transparent;
    border: 6px solid black;
    box-sizing: border-box;
    border-bottom: 0;
    bottom: 3px;
    left: calc(50% - 18px);
  }
  .emoji--yay .emoji__eyebrows:before {
    margin-left: -21px;
  }
  .emoji--yay .emoji__eyebrows:after {
    margin-left: 21px;
  }
  .emoji--yay .emoji__mouth {
    top: 60px;
    background: transparent;
    left: 50%;
  }
  .emoji--yay .emoji__mouth:after {
    width: 80px;
    height: 80px;
    left: calc(50% - 40px);
    top: -75px;
    border-radius: 50%;
    background: transparent;
    border: 6px solid #000000;
    box-sizing: border-box;
    border-top-color: transparent;
    border-left-color: transparent;
    border-right-color: transparent;
    z-index: 1;
  }
  .emoji--yay .emoji__mouth:before {
    width: 6px;
    height: 6px;
    background: transparent;
    border-radius: 50%;
    bottom: 5px;
    left: calc(50% - 3px);
    box-shadow: -25px 0 0 0 #000000, 25px 0 0 0 #000000, -35px -2px 30px 10px #d5234c, 35px -2px 30px 10px #d5234c;
  }
  
  .emoji--wow .emoji__face {
    -webkit-animation: wow-face 3s linear infinite;
            animation: wow-face 3s linear infinite;
  }
  .emoji--wow .emoji__eyebrows {
    left: calc(50% - 3px);
    height: 6px;
    width: 6px;
    border-radius: 50%;
    background: transparent;
    box-shadow: -18px 0 0 0 #000000, -33px 0 0 0 #000000, 18px 0 0 0 #000000, 33px 0 0 0 #000000;
    -webkit-animation: wow-brow 3s linear infinite;
            animation: wow-brow 3s linear infinite;
  }
  .emoji--wow .emoji__eyebrows:before, .emoji--wow .emoji__eyebrows:after {
    width: 24px;
    height: 20px;
    border: 6px solid #000000;
    box-sizing: border-box;
    border-radius: 50%;
    border-bottom-color: transparent;
    border-left-color: transparent;
    border-right-color: transparent;
    top: -3px;
    left: calc(50% - 12px);
  }
  .emoji--wow .emoji__eyebrows:before {
    margin-left: -25px;
  }
  .emoji--wow .emoji__eyebrows:after {
    margin-left: 25px;
  }
  .emoji--wow .emoji__eyes {
    width: 16px;
    height: 24px;
    left: calc(50% - 8px);
    top: 35px;
    border-radius: 50%;
    background: transparent;
    box-shadow: 25px 0 0 0 #000000, -25px 0 0 0 #000000;
  }
  .emoji--wow .emoji__mouth {
    width: 30px;
    height: 45px;
    left: calc(50% - 15px);
    top: 50%;
    border-radius: 50%;
    background: #000000;
    -webkit-animation: wow-mouth 3s linear infinite;
            animation: wow-mouth 3s linear infinite;
  }
  
  .emoji--sad .emoji__face {
    -webkit-animation: sad-face 2s ease-in infinite;
            animation: sad-face 2s ease-in infinite;
  }
  .emoji--sad .emoji__eyebrows {
    left: calc(50% - 3px);
    top: 35px;
    height: 6px;
    width: 6px;
    border-radius: 50%;
    background: transparent;
    box-shadow: -40px 9px 0 0 #000000, -25px 0 0 0 #000000, 25px 0 0 0 #000000, 40px 9px 0 0 #000000;
  }
  .emoji--sad .emoji__eyebrows:before, .emoji--sad .emoji__eyebrows:after {
    width: 30px;
    height: 20px;
    border: 6px solid #000000;
    box-sizing: border-box;
    border-radius: 50%;
    border-bottom-color: transparent;
    border-left-color: transparent;
    border-right-color: transparent;
    top: 2px;
    left: calc(50% - 15px);
  }
  .emoji--sad .emoji__eyebrows:before {
    margin-left: -30px;
    transform: rotate(-30deg);
  }
  .emoji--sad .emoji__eyebrows:after {
    margin-left: 30px;
    transform: rotate(30deg);
  }
  .emoji--sad .emoji__eyes {
    width: 14px;
    height: 16px;
    left: calc(50% - 7px);
    top: 50px;
    border-radius: 50%;
    background: transparent;
    box-shadow: 25px 0 0 0 #000000, -25px 0 0 0 #000000;
  }
  .emoji--sad .emoji__eyes:after {
    background: #548dff;
    width: 12px;
    height: 12px;
    margin-left: 6px;
    border-radius: 0 100% 40% 50%/0 50% 40% 100%;
    transform-origin: 0% 0%;
    -webkit-animation: tear-drop 2s ease-in infinite;
            animation: tear-drop 2s ease-in infinite;
  }
  .emoji--sad .emoji__mouth {
    width: 60px;
    height: 80px;
    left: calc(50% - 30px);
    top: 80px;
    box-sizing: border-box;
    border: 6px solid #000000;
    border-radius: 50%;
    border-bottom-color: transparent;
    border-left-color: transparent;
    border-right-color: transparent;
    background: transparent;
    -webkit-animation: sad-mouth 2s ease-in infinite;
            animation: sad-mouth 2s ease-in infinite;
  }
  .emoji--sad .emoji__mouth:after {
    width: 6px;
    height: 6px;
    background: transparent;
    border-radius: 50%;
    top: 4px;
    left: calc(50% - 3px);
    box-shadow: -18px 0 0 0 #000000, 18px 0 0 0 #000000;
  }
  
  .emoji--angry {
    background: linear-gradient(#d5234c -10%, #ffda6a);
    background-size: 100%;
    -webkit-animation: angry-color 2s ease-in infinite;
            animation: angry-color 2s ease-in infinite;
  }

  .emoji--angry .emoji__face {
    -webkit-animation: angry-face 2s ease-in infinite;
            animation: angry-face 2s ease-in infinite;
  }
  .emoji--angry .emoji__eyebrows {
    left: calc(50% - 3px);
    top: 55px;
    height: 6px;
    width: 6px;
    border-radius: 50%;
    background: transparent;
    box-shadow: -44px 5px 0 0 #000000, -7px 16px 0 0 #000000, 7px 16px 0 0 #000000, 44px 5px 0 0 #000000;
  }
  .emoji--angry .emoji__eyebrows:before, .emoji--angry .emoji__eyebrows:after {
    width: 50px;
    height: 20px;
    border: 6px solid #000000;
    box-sizing: border-box;
    border-radius: 50%;
    border-top-color: transparent;
    border-left-color: transparent;
    border-right-color: transparent;
    top: 0;
    left: calc(50% - 25px);
  }
  .emoji--angry .emoji__eyebrows:before {
    margin-left: -25px;
    transform: rotate(15deg);
  }
  .emoji--angry .emoji__eyebrows:after {
    margin-left: 25px;
    transform: rotate(-15deg);
  }
  .emoji--angry .emoji__eyes {
    width: 12px;
    height: 12px;
    left: calc(50% - 6px);
    top: 70px;
    border-radius: 50%;
    background: transparent;
    box-shadow: 25px 0 0 0 #000000, -25px 0 0 0 #000000;
  }
  .emoji--angry .emoji__mouth {
    width: 36px;
    height: 18px;
    left: calc(50% - 18px);
    bottom: 15px;
    background: #000000;
    border-radius: 50%;
    -webkit-animation: angry-mouth 2s ease-in infinite;
            animation: angry-mouth 2s ease-in infinite;
  }
  
  @-webkit-keyframes heart-beat {
    25% {
      transform: scale(1.1);
    }
    75% {
      transform: scale(0.6);
    }
  }
  
  @keyframes heart-beat {
    25% {
      transform: scale(1.1);
    }
    75% {
      transform: scale(0.6);
    }
  }
  @-webkit-keyframes haha-face {
    10% {
      transform: translateY(25px);
    }
    20% {
      transform: translateY(15px);
    }
    30% {
      transform: translateY(25px);
    }
    40% {
      transform: translateY(15px);
    }
    50% {
      transform: translateY(25px);
    }
    60% {
      transform: translateY(0);
    }
    70% {
      transform: translateY(-10px);
    }
    80% {
      transform: translateY(0);
    }
    90% {
      transform: translateY(-10px);
    }
  }
  @keyframes haha-face {
    10% {
      transform: translateY(25px);
    }
    20% {
      transform: translateY(15px);
    }
    30% {
      transform: translateY(25px);
    }
    40% {
      transform: translateY(15px);
    }
    50% {
      transform: translateY(25px);
    }
    60% {
      transform: translateY(0);
    }
    70% {
      transform: translateY(-10px);
    }
    80% {
      transform: translateY(0);
    }
    90% {
      transform: translateY(-10px);
    }
  }
  @-webkit-keyframes haha-mouth {
    10% {
      transform: scale(0.6);
      top: 45%;
    }
    20% {
      transform: scale(0.8);
      top: 45%;
    }
    30% {
      transform: scale(0.6);
      top: 45%;
    }
    40% {
      transform: scale(0.8);
      top: 45%;
    }
    50% {
      transform: scale(0.6);
      top: 45%;
    }
    60% {
      transform: scale(1);
      top: 50%;
    }
    70% {
      transform: scale(1.2);
      top: 50%;
    }
    80% {
      transform: scale(1);
      top: 50%;
    }
    90% {
      transform: scale(1.1);
      top: 50%;
    }
  }
  @keyframes haha-mouth {
    10% {
      transform: scale(0.6);
      top: 45%;
    }
    20% {
      transform: scale(0.8);
      top: 45%;
    }
    30% {
      transform: scale(0.6);
      top: 45%;
    }
    40% {
      transform: scale(0.8);
      top: 45%;
    }
    50% {
      transform: scale(0.6);
      top: 45%;
    }
    60% {
      transform: scale(1);
      top: 50%;
    }
    70% {
      transform: scale(1.2);
      top: 50%;
    }
    80% {
      transform: scale(1);
      top: 50%;
    }
    90% {
      transform: scale(1.1);
      top: 50%;
    }
  }
  @-webkit-keyframes yay {
    25% {
      transform: rotate(-15deg);
    }
    75% {
      transform: rotate(15deg);
    }
  }
  @keyframes yay {
    25% {
      transform: rotate(-15deg);
    }
    75% {
      transform: rotate(15deg);
    }
  }
  @-webkit-keyframes wow-face {
    15%, 25% {
      transform: rotate(20deg) translateX(-25px);
    }
    45%, 65% {
      transform: rotate(-20deg) translateX(25px);
    }
    75%, 100% {
      transform: rotate(0deg) translateX(0);
    }
  }
  @keyframes wow-face {
    15%, 25% {
      transform: rotate(20deg) translateX(-25px);
    }
    45%, 65% {
      transform: rotate(-20deg) translateX(25px);
    }
    75%, 100% {
      transform: rotate(0deg) translateX(0);
    }
  }
  @-webkit-keyframes wow-brow {
    15%, 65% {
      top: 25px;
    }
    75%, 100%, 0% {
      top: 15px;
    }
  }
  @keyframes wow-brow {
    15%, 65% {
      top: 25px;
    }
    75%, 100%, 0% {
      top: 15px;
    }
  }
  @-webkit-keyframes wow-mouth {
    10%, 30% {
      width: 20px;
      height: 20px;
      left: calc(50% - 10px);
    }
    50%, 70% {
      width: 30px;
      height: 40px;
      left: calc(50% - 15px);
    }
    75%, 100% {
      height: 50px;
    }
  }
  @keyframes wow-mouth {
    10%, 30% {
      width: 20px;
      height: 20px;
      left: calc(50% - 10px);
    }
    50%, 70% {
      width: 30px;
      height: 40px;
      left: calc(50% - 15px);
    }
    75%, 100% {
      height: 50px;
    }
  }
  @-webkit-keyframes sad-face {
    25%, 35% {
      top: -15px;
    }
    55%, 95% {
      top: 10px;
    }
    100%, 0% {
      top: 0;
    }
  }
  @keyframes sad-face {
    25%, 35% {
      top: -15px;
    }
    55%, 95% {
      top: 10px;
    }
    100%, 0% {
      top: 0;
    }
  }
  @-webkit-keyframes sad-mouth {
    25%, 35% {
      transform: scale(0.85);
      top: 70px;
    }
    55%, 100%, 0% {
      transform: scale(1);
      top: 80px;
    }
  }
  @keyframes sad-mouth {
    25%, 35% {
      transform: scale(0.85);
      top: 70px;
    }
    55%, 100%, 0% {
      transform: scale(1);
      top: 80px;
    }
  }
  @-webkit-keyframes tear-drop {
    0%, 100% {
      display: block;
      left: 35px;
      top: 15px;
      transform: rotate(45deg) scale(0);
    }
    25% {
      display: block;
      left: 35px;
      transform: rotate(45deg) scale(2);
    }
    49.9% {
      display: block;
      left: 35px;
      top: 65px;
      transform: rotate(45deg) scale(0);
    }
    50% {
      display: block;
      left: -35px;
      top: 15px;
      transform: rotate(45deg) scale(0);
    }
    75% {
      display: block;
      left: -35px;
      transform: rotate(45deg) scale(2);
    }
    99.9% {
      display: block;
      left: -35px;
      top: 65px;
      transform: rotate(45deg) scale(0);
    }
  }
  @keyframes tear-drop {
    0%, 100% {
      display: block;
      left: 35px;
      top: 15px;
      transform: rotate(45deg) scale(0);
    }
    25% {
      display: block;
      left: 35px;
      transform: rotate(45deg) scale(2);
    }
    49.9% {
      display: block;
      left: 35px;
      top: 65px;
      transform: rotate(45deg) scale(0);
    }
    50% {
      display: block;
      left: -35px;
      top: 15px;
      transform: rotate(45deg) scale(0);
    }
    75% {
      display: block;
      left: -35px;
      transform: rotate(45deg) scale(2);
    }
    99.9% {
      display: block;
      left: -35px;
      top: 65px;
      transform: rotate(45deg) scale(0);
    }
  }
  @-webkit-keyframes hands-up {
    25% {
      transform: rotate(15deg);
    }
    50% {
      transform: rotate(-15deg) translateY(-10px);
    }
    75%, 100% {
      transform: rotate(0deg);
    }
  }
  @keyframes hands-up {
    25% {
      transform: rotate(15deg);
    }
    50% {
      transform: rotate(-15deg) translateY(-10px);
    }
    75%, 100% {
      transform: rotate(0deg);
    }
  }
  @-webkit-keyframes thumbs-up {
    25% {
      transform: rotate(20deg);
    }
    50%, 100% {
      transform: rotate(5deg);
    }
  }
  @keyframes thumbs-up {
    25% {
      transform: rotate(20deg);
    }
    50%, 100% {
      transform: rotate(5deg);
    }
  }
  @-webkit-keyframes angry-color {
    45%, 60% {
      background-size: 250%;
    }
    85%, 100%, 0% {
      background-size: 100%;
    }
  }
  @keyframes angry-color {
    45%, 60% {
      background-size: 250%;
    }
    85%, 100%, 0% {
      background-size: 100%;
    }
  }
  @-webkit-keyframes angry-face {
    35%, 60% {
      transform: translateX(0) translateY(10px) scale(0.9);
    }
    40% {
      transform: translateX(-5px) translateY(10px) scale(0.9);
    }
    45% {
      transform: translateX(5px) translateY(10px) scale(0.9);
    }
    50% {
      transform: translateX(-5px) translateY(10px) scale(0.9);
    }
    55% {
      transform: translateX(5px) translateY(10px) scale(0.9);
    }
  }
  @keyframes angry-face {
    35%, 60% {
      transform: translateX(0) translateY(10px) scale(0.9);
    }
    40% {
      transform: translateX(-5px) translateY(10px) scale(0.9);
    }
    45% {
      transform: translateX(5px) translateY(10px) scale(0.9);
    }
    50% {
      transform: translateX(-5px) translateY(10px) scale(0.9);
    }
    55% {
      transform: translateX(5px) translateY(10px) scale(0.9);
    }
  }
  @-webkit-keyframes angry-mouth {
    25%, 50% {
      height: 6px;
      bottom: 25px;
    }
  }
  @keyframes angry-mouth {
    25%, 50% {
      height: 6px;
      bottom: 25px;
    }
  }
