@font-face {
  font-family: "fat-frank";
  src:
    url("../fonts/fatfrank-free.eot#iefix") format("embedded-opentype"),
    url("../fonts/fatfrank-free.woff") format("woff"),
    url("../fonts/fatfrank-free.ttf") format("truetype"),
    url("../fonts/fatfrank-free.svg#FontName") format("svg");
  font-style: normal;
  font-weight: normal;
}

html,
body {
  width: 100%;
  height: 100%;
}
body {
  background-color: #101e34;
  overflow: hidden;
}

*:not(a) {
  -webkit-user-select: none;
  -webkit-touch-callout: none;
}

.gradient-bg {
  width: 150%;
  min-width: 100%;
  height: 130%;
  left: 50%;
  top: 0;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  -o-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  position: fixed;
  background-color: #1a1a2a;
  -webkit-background-image:
    radial-gradient(
      ellipse farthest-corner at center,
      transparent 0%,
      #0a0b13 100%
    ),
    url(../v1/noise-160.png);
  background-image:
    radial-gradient(
      ellipse farthest-corner at center,
      transparent 0%,
      #0a0b13 100%
    ),
    url(../v1/noise-160.png);
  background-repeat: repeat;
  -webkit-background-size: auto;
  background-size: auto;
  background-position: center;
  z-index: 0;
}

/*@media screen and (max-width: 1024px){
  .gradient-bg{
    width: 130vh;
    height: 130vh;
  }
}*/

.text {
  position: fixed;
  width: 100%;
  text-align: center;
  z-index: 3;
  font-size: 130px;
  line-height: 1;
  font-family: fat-frank, arial;
  text-transform: uppercase;
  font-weight: 800;
  color: #fff;
  top: 65px;
  margin: 0;
  -webkit-transform: translateY(-300%);
  -ms-transform: translateY(-300%);
  -o-transform: translateY(-300%);
  transform: translateY(-300%);
}
.text .blue {
  color: #46aeff;
}
.text .red {
  color: #ff4646;
}

/*svg {
  position: absolute;
  width: 100%;
  height: 100%;
}

svg{
  position: fixed;
  width: 1300px;
  text-align: center;
  font-size: 60px;
  line-height: 1;
  font-family: fat-frank, arial;
  text-transform: uppercase;
  font-weight: 800;
  color: #fff;
  top: 65px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -o-transform: translateX(-50%);
  transform: translateX(-50%);
}

@media screen and (min-width: 1530px){
  svg{
    width: 1510px;
  }
}

@media screen and (max-width: 1300px){
  svg{
    width: 1220px;
  }
}

@media screen and (max-width: 1250px){
  .text{
    display: block;
  }
  svg{
    display: none;
  }
}


svg tspan{
  stroke: #101e34;
  /*stroke-width: 0.8;*/
/*stroke-location: outside;
}

svg tspan:nth-child(1){
  fill: #46aeff
}

svg tspan:nth-child(2){
  fill: #ff4646;
}

svg tspan:nth-child(3){
  fill: #fff;
}

.colortext .anim-shape:nth-child(1) {
  fill: #101e34;
}*/

#can {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  backface-visibility: hidden;
  z-index: 9998;
}
.trumpet {
  display: none; /* ponytail: trumpet hidden for now — remove to restore */
  width: 840px;
  height: 840px;
  /*width: 77.777778vh;
  height: 77.777778vh;*/
  height: 77.777778%;
  position: fixed;
  top: 50%;
  left: 100%;
  -webkit-transform-origin: 0 0;
  -moz-transform-origin: 0 0;
  -ms-transform-origin: 0 0;
  -o-transform-origin: 0 0;
  transform-origin: 0 0;
  -webkit-transition:
    top 0.5s,
    left 0.5s;
  -o-transition:
    top 0.5s,
    left 0.5s;
  transition:
    top 0.5s,
    left 0.5s;
  -webkit-transform: rotate(-45deg) translate(150%, 150%);
  -ms-transform: rotate(-45deg) translate(150%, 150%);
  -o-transform: rotate(-45deg) translate(150%, 150%);
  transform: rotate(-45deg) translate(150%, 150%);
  z-index: 3000;
}

@media screen and (max-width: 767px) {
  .trumpet {
    width: 800px;
    height: 800px;
    /*width: 74.074074vh;
    height: 74.074074vh;*/
    height: 74.074074%;
    -webkit-transform: rotate(-90deg) translate(150%, 150%);
    -ms-transform: rotate(-90deg) translate(150%, 150%);
    -o-transform: rotate(-90deg) translate(150%, 150%);
    transform: rotate(-90deg) translate(150%, 150%);
  }
}

.trumpet .trumpet-inner-wrapper {
  width: 100%;
  height: 100%;
  position: relative;
}
.trumpet .trumpet-inner-wrapper .trumpet-inner {
  position: absolute;
  width: 700px;
  height: 700px;
  /*width: 64.814814vh;
  height: 64.814814vh;*/
  width: 83.333333%;
  height: 83.333333%;
  -webkit-transform: rotate(-90deg);
  -moz-transform: rotate(-90deg);
  -ms-transform: rotate(-90deg);
  -o-transform: rotate(-90deg);
  transform: rotate(-90deg);
  bottom: 0;
  right: 0;
}
@media screen and (max-width: 767) {
  .trumpet .trumpet-inner-wrapper .trumpet-inner {
    width: 87.5%;
    height: 87.5%;
  }
}
.trumpet.flipped .trumpet-inner-wrapper .trumpet-inner {
  -webkit-transform: scaleX(-1);
  -ms-transform: scaleX(-1);
  -o-transform: scaleX(-1);
  transform: scaleX(-1);
}
.trump {
  width: 1009.8px; /*1122*/
  /*width: 103.888889vh;*/
  /*height: 100%; */
  height: 724.5px; /*805*/
  /*height: 74.537037vh;*/
  height: 74.537037%;
  position: fixed;
  left: 50%;
  /*position: relative; 1 */
  /*margin: 0 auto;*/
  bottom: 0;
  z-index: 2;
}

@media screen and (max-width: 768px) {
  .trump {
    /*width: 88.305555vh;
    height: 63.35648145vh;*/
    width: 100%;
    height: 63.356481%;
  }
}

.trump .trump-inner {
  position: relative;
  width: 100%;
  height: 100%;
  margin-left: -50%;
  -webkit-transform: translateY(200%);
  -ms-transform: translateY(200%);
  -o-transform: translateY(200%);
  transform: translateY(200%);
}

/*.trump .body{
  position: absolute;
  width: 100%;
  height: 100%;
  bottom: 0;
  background-image: url(assets/trumps.png);
  background-repeat: no-repeat;
  -webkit-background-size: contain;
  background-size: 200% 100%;
  background-position: 100% 0;
}
.trump .body.blown{
  background-position: 0 0;
}*/

.trump .body-cont {
  position: absolute;
  bottom: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  margin-left: -5%;
}
.trump .body {
  width: 200%;
  height: 100%;
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -o-transform: translateX(-50%);
  transform: translateX(-50%);
  background-image: url(../v1/img-0.75/trumps.png);
  background-repeat: no-repeat;
  -webkit-background-size: contain;
  background-size: 100% 100%;
  background-position: 100% 0;
}

.trump .eyes {
  position: absolute;
  width: 18.8%;
  height: 6%;
  bottom: 68%;
  left: 41%;
}
.trump .eyes .eye {
  position: absolute;
  width: 30%;
  height: 100%;
  background-repeat: no-repeat;
  -webkit-background-size: contain;
  background-size: contain;
  background-position: center center;
}
.trump .eyes .eye.left-eye {
}
.trump .eyes .eye.right-eye {
  right: -1%;
  top: 8%;
}
.iris {
  width: 90px;
  height: 90px;
  /*width: 9vh;
  height: 9vh;*/
  position: relative;
  top: 50%;
  left: 50%;
  margin-top: -45px;
  margin-left: -45px;
  /*margin-top: -4.5vh;
  margin-left: -4.5vh;*/
  background-image: url(../v1/img-0.75/eye.png);
  background-repeat: no-repeat;
  -webkit-background-size: contain;
  background-size: contain;
  background-position: center;
}
.reflection {
  width: 100%;
  height: 100%;
  margin-left: -50%;
  margin-top: -50%;
  position: absolute;
  top: 65%;
  left: 50%;
  background-image: url(../v1/img-0.75/reflection.png);
  background-repeat: no-repeat;
  -webkit-background-size: contain;
  background-size: contain;
  background-position: center;
}

.trump .hair {
  position: absolute;
  -webkit-transform: translateZ(0);
  -ms-transform: translateZ(0);
  -o-transform: translateZ(0);
  transform: translateZ(0);
  bottom: 41%;
  left: 4%;
  width: 89.126559%;
  height: 93.167701%;
  overflow: hidden;
}
.trump .hair .angle-cont,
.trump .hair .angle-cont-can,
.trump .hair .idle-cont {
  width: 101%;
  height: 101%;
  margin-left: -0.5%;
  margin-top: -0.5%;
  position: absolute;
  overflow: hidden;
  top: 0;
  -webkit-transform: translateY(-10000px) translateZ(0);
  -ms-transform: translateY(-10000px) translateZ(0);
  -o-transform: translateY(-10000px) translateZ(0);
  transform: translateY(-10000px) translateZ(0);
}

.trump .hair .idle-cont .hair-sprite {
  position: absolute;
  width: 100%;
  height: 100%;
  /*will-change: transform;*/
}

.trump .hair .angle-cont .hair-sprite {
  position: absolute;
  width: 400%;
  height: 600%;
}

/*Counter*/

.bottom-bar {
  position: fixed;
  bottom: 20px;
  left: 20px;
  right: 20px;
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  gap: 12px;
  pointer-events: none;
  z-index: 9999;
}

.counter-cont {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 14px 18px;
  background: rgba(20, 26, 33, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 10px;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  font-family: fat-frank;
  font-size: 2.15rem;
  text-transform: uppercase;
  pointer-events: none;
  -webkit-transform: translateY(500%);
  -ms-transform: translateY(500%);
  -o-transform: translateY(500%);
  transform: translateY(500%);
}

@media screen and (max-width: 767px) {
  .counter-cont .counter-numbers,
  .counter-cont .counter-text {
    font-size: 1.333333rem;
  }
}

.counter-cont .counter-numbers {
  color: #fff;
  line-height: 1;
}

.counter-cont .counter-text {
  color: #494855;
}

.counter-cont .counter-based {
  font-family: "Open Sans";
  font-size: 9px;
  color: #494855;
}

.counter-cont .counter-based .ref-link {
  color: #494855;
  pointer-events: auto;
}

.counter-cont .counter-based .ref-link:hover {
  color: #fff;
}

.bottom-right-cont {
  position: relative;
  display: flex;
  align-items: stretch;
  justify-content: flex-end;
  gap: 12px;
  -webkit-transform: translateY(500%);
  -ms-transform: translateY(500%);
  -o-transform: translateY(500%);
  transform: translateY(500%);
}

.fart-toast {
  position: absolute;
  bottom: calc(100% + 10px);
  right: 0;
  width: 96px;
  box-sizing: border-box;
  padding: 10px;
  background: rgba(20, 26, 33, 0.85);
  border: 2px solid rgba(230, 60, 60, 0.85);
  border-radius: 10px;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  font-family: "Open Sans";
  font-size: 13px;
  color: #fff;
  text-align: center;
  opacity: 0;
  transform: translateY(8px);
  transition:
    opacity 0.3s ease,
    transform 0.3s ease;
  pointer-events: none;
  z-index: 10000;
}
.fart-toast.show {
  opacity: 1;
  transform: translateY(0);
  animation: toast-glow 1.4s ease-in-out infinite;
}
@keyframes toast-glow {
  0%,
  100% {
    box-shadow: 0 0 4px rgba(230, 60, 60, 0.5);
  }
  50% {
    box-shadow: 0 0 16px rgba(230, 60, 60, 0.95);
  }
}

.days-cont {
  padding: 14px 18px;
  background: rgba(20, 26, 33, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 10px;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  text-align: center;
  font-family: "Open Sans";
  z-index: 9999;
}

.days-cont .days-numbers {
  font-family: fat-frank;
  font-size: 2.15rem;
  line-height: 1;
  color: #fff;
}

.days-cont .days-text {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: #9b9aa5;
  margin-top: 4px;
}

.days-cont .days-meter {
  width: 160px;
  height: 8px;
  margin-top: 10px;
  background: rgba(255, 255, 255, 0.12);
  border-radius: 4px;
  overflow: hidden;
}

.days-cont .days-meter-fill {
  height: 100%;
  width: 0;
  background: linear-gradient(90deg, #ee3e3e, #f6a623);
  border-radius: 4px;
  transition: width 0.6s ease;
}

.bottom-right-cont .flush-btn {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  width: 96px;
  flex: 0 0 96px;
  box-sizing: border-box;
  padding: 7px;
  font-family: "Open Sans";
  font-size: 12px;
  letter-spacing: 1px;
  color: #fff;
  background: rgba(20, 26, 33, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 10px;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  cursor: pointer;
  pointer-events: auto;
  transition: background 0.2s ease;
  animation: flush-glow 2s ease-in-out infinite;
}

.bottom-right-cont .flush-btn:hover {
  background: rgba(20, 26, 33, 0.75);
}

@keyframes flush-glow {
  0%,
  100% {
    box-shadow: 0 0 6px 0 rgba(246, 166, 35, 0.4);
  }
  50% {
    box-shadow: 0 0 18px 4px rgba(246, 166, 35, 0.8);
  }
}

.bottom-right-cont .flush-icon {
  width: 36px;
  height: 36px;
  color: #f6a623;
}

.bottom-right-cont .flush-btn.flushing {
  animation: flush-shake 0.6s ease;
}

.bottom-right-cont .flush-btn.flushing .flush-icon {
  animation: flush-spin 0.6s ease;
  transform-origin: 50% 60%;
}

@keyframes flush-shake {
  0%,
  100% {
    transform: translateX(0) rotate(0);
  }
  20% {
    transform: translateX(-3px) rotate(-2deg);
  }
  40% {
    transform: translateX(3px) rotate(2deg);
  }
  60% {
    transform: translateX(-2px) rotate(-1deg);
  }
  80% {
    transform: translateX(2px) rotate(1deg);
  }
}

@keyframes flush-spin {
  0% {
    transform: rotate(0) scale(1);
  }
  50% {
    transform: rotate(180deg) scale(0.7);
  }
  100% {
    transform: rotate(360deg) scale(1);
  }
}

@media screen and (max-width: 767px) {
  .bottom-bar {
    left: 10px;
    right: 10px;
    bottom: 10px;
    gap: 8px;
  }
  .counter-cont,
  .days-cont {
    padding: 10px 12px;
  }
  .counter-cont .counter-based {
    display: none;
  }
  .bottom-right-cont {
    gap: 8px;
  }
  .days-cont .days-numbers {
    font-size: 1.333333rem;
  }
  .days-cont .days-meter {
    width: 100%;
    min-width: 80px;
  }
  /* equal box heights, bottoms aligned on small screens */
  .counter-cont,
  .days-cont {
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  .days-cont .days-meter {
    margin-top: auto;
  }
}

/*Simplified loader*/
.row1 .left,
.row1 .right {
  animation-delay: -0s;
  /*Obviously not needed*/
}
.row2 .left,
.row2 .right {
  animation-delay: -0.5s;
}
.row3 .left,
.row3 .right {
  animation-delay: -1s;
}
.row4 .left,
.row4 .right {
  animation-delay: -1.5s;
}
/**/

.loader {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  -o-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  width: 120px;
  height: 84px;
}
.left,
.right {
  height: 8px;
  width: 10px;
  background-color: #000;
  border-radius: 4px;
  position: absolute;
}
.left {
  left: 0px;
  animation: left 2s infinite;
}
.right {
  right: 0px;
  animation: right 2s infinite;
}

.row1,
.row2,
.row3,
.row4 {
  position: relative;
}
.row1 {
  top: 0px;
}
.row1 .left,
.row1 .right {
  background-color: #46aeff;
}
.row2 {
  top: 13px;
}
.row2 .left,
.row2 .right {
  background-color: #ff4646;
}
.row3 {
  top: 26px;
}
.row3 .left,
.row3 .right {
  background-color: #fff;
}
.row4 {
  top: 78px;
}

@keyframes left {
  0%,
  50%,
  100% {
    width: 50px;
  }
  25% {
    width: 80px;
  }
  75% {
    width: 20px;
  }
}
@keyframes right {
  0%,
  50%,
  100% {
    width: 50px;
  }
  25% {
    width: 20px;
  }
  75% {
    width: 80px;
  }
}

.loader-text {
  text-align: center;
  /*position: relative;
  top: 40px;*/
}

.loader-text p {
  color: #fff;
  display: block;
  text-align: center;
  font-size: 30px;
  line-height: 1;
  font-family: "fat-frank";
  margin: 0;
  text-transform: uppercase;
  animation: loader-text 2s infinite;
}

.loader-text p:first-child {
  color: #46aeff;
  animation-delay: 0;
}

.loader-text p:nth-child(2) {
  color: #ff4646;
  animation-delay: 0.5s;
}

.loader-text p:nth-child(3) {
  animation-delay: 1s;
}

@keyframes loader-text {
  0%,
  50%,
  100% {
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    -o-transform: translateX(0);
    transform: translateX(0);
  }
  25% {
    -webkit-transform: translateX(-10%);
    -ms-transform: translateX(-10%);
    -o-transform: translateX(-10%);
    transform: translateX(-10%);
  }
  75% {
    -webkit-transform: translateX(10%);
    -ms-transform: translateX(10%);
    -o-transform: translateX(10%);
    transform: translateX(10%);
  }
}
/*
@media screen and (min-width: 1921px){
  .text{
    font-size: 150px;
  }
}*/

@media screen and (min-width: 1530px) {
  .text {
    font-size: 150px;
  }
}

@media screen and (max-width: 1300px) {
  .text {
    font-size: 120px;
  }
}

@media screen and (max-width: 1250px) {
  .text {
    text-align: left;
    line-height: 0.8;
    padding-left: 30px;
    font-size: 84px;
  }
  .text span {
    display: block;
    margin-left: 35px;
  }
}

@media screen and (max-width: 1024px) {
  .text {
    font-size: 84px;
    text-align: left;
    line-height: 0.8;
    padding-left: 0.25em;
    top: 0.5em;
  }
  .text span {
    display: block;
    margin-left: 0.25em;
  }
}

@media screen and (max-width: 767px) {
  .text {
    font-size: 66px;
  }
}

/*Crios fix*/

/*@media screen and (max-width: 1024px){
  .crios .gradient-bg{
    width: 200%;
    height: 100%;
  }
}

.crios .trumpet{
  width: 840px;
  height: 77.777778%;
}

@media screen and (max-width: 767px){
  .crios .trumpet{
    width: 800px;
    height: 74.074074%;
  }
}

.crios .trumpet .trumpet-inner-wrapper .trumpet-inner {
  width: 83.333333%;
  height: 83.333333%;
}

@media screen and (max-width: 767px){
  .crios .trumpet .trumpet-inner-wrapper .trumpet-inner {
    width: 87.5%;
    height: 87.5%;
  }
}*/

.crios .trump {
  width: 1009.8px; /*1122*/
  height: 74.537037%; /*805*/
}

/*@media screen and (max-width: 768px){
  .crios .trump{
    width: 100%;
    height: 63.356481%;
  }
}

.crios .iris{
  width: 90px;
  height: 90px;
  margin-top: -45px;
  margin-left: -45px;
}*/

html,
.crios {
  /*height: 110% !important;*/
  margin: 0 !important;
  position: relative;
  top: 0;
  background-color: #0c0c16;
}

.crios > * {
  display: none;
}

.crios .crios-cont {
  display: block;
  position: relative;
  width: 100%;
  height: auto;
}

.crios-cont .text-cont {
  position: absolute;
  width: 100%;
}

.crios-top {
  top: 90px;
  left: 40px;
  text-align: left;
}

.crios-bottom {
  right: 30px;
  bottom: 30px;
  text-align: right;
}

.crios-text,
.crios-logo {
  font-family: "fat-frank";
  text-transform: uppercase;
  color: #fff;
}

h1.crios-text {
  margin: 0;
  line-height: 1;
}

h1.crios-text .star {
  font-family: arial;
  margin-left: -14px;
  margin-right: 2px;
}

.crios-text span {
  color: #46aeff;
}

.crios-cont .crios-bottom {
  display: none;
}

body:not(.crios) .crios-cont {
  display: none;
}

/*
     FILE ARCHIVED ON 21:39:03 Feb 18, 2016 AND RETRIEVED FROM THE
     INTERNET ARCHIVE ON 13:10:22 May 23, 2019.
     JAVASCRIPT APPENDED BY WAYBACK MACHINE, COPYRIGHT INTERNET ARCHIVE.

     ALL OTHER CONTENT MAY ALSO BE PROTECTED BY COPYRIGHT (17 U.S.C.
     SECTION 108(a)(3)).
*/
/*
playback timings (ms):
  LoadShardBlock: 84.059 (3)
  esindex: 0.009
  captures_list: 102.051
  CDXLines.iter: 11.9 (3)
  PetaboxLoader3.datanode: 92.032 (5)
  exclusion.robots: 0.325
  exclusion.robots.policy: 0.312
  RedisCDXSource: 0.921
  PetaboxLoader3.resolve: 64.609 (3)
  load_resource: 79.308
*/

/* animated flies orbiting the person */
.flies {
  position: absolute;
  top: 0;
  left: 50%;
  width: 0;
  height: 0;
  pointer-events: none;
  z-index: 5;
}
/* flies + clouds are created dynamically by JS; per-element randomness is
   passed in as CSS custom properties so one keyframe drives every instance */
.fly {
  position: absolute;
  width: 10px;
  height: 7px;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 35%, #444 0%, #111 70%, #000 100%);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0.6);
  animation: fly-drift var(--dur, 8s) linear infinite var(--delay, 0s);
}
.fly::before,
.fly::after {
  content: "";
  position: absolute;
  top: -2px;
  width: 6px;
  height: 9px;
  border-radius: 50%;
  background: rgba(200, 200, 210, 0.35);
}
.fly::before {
  left: -3px;
  transform: rotate(-25deg);
}
.fly::after {
  right: -3px;
  transform: rotate(25deg);
}
@keyframes fly-drift {
  0%,
  100% {
    transform: translate(var(--x0), var(--y0)) rotate(0deg);
  }
  25% {
    transform: translate(var(--x1), var(--y1)) rotate(15deg);
  }
  50% {
    transform: translate(var(--x2), var(--y2)) rotate(-12deg);
  }
  75% {
    transform: translate(var(--x3), var(--y3)) rotate(10deg);
  }
}
@media (prefers-reduced-motion: reduce) {
  .fly {
    animation: none;
  }
}

/* green stink clouds rising from behind the shoulders, beside the head */
.stink {
  position: absolute;
  top: 0;
  left: 50%;
  width: 0;
  height: 0;
  pointer-events: none;
  z-index: 6; /* above body-cont -> renders in front of the image */
}
.cloud {
  position: absolute;
  width: 140px;
  height: 140px;
  border-radius: 50%;
  background:
    radial-gradient(
      circle at 35% 30%,
      rgba(170, 230, 90, 0.35) 0%,
      rgba(170, 230, 90, 0) 55%
    ),
    radial-gradient(
      circle at 65% 55%,
      rgba(120, 190, 50, 0.3) 0%,
      rgba(120, 190, 50, 0) 60%
    ),
    radial-gradient(
      circle at 50% 70%,
      rgba(90, 150, 30, 0.28) 0%,
      rgba(90, 150, 30, 0) 65%
    ),
    radial-gradient(
      circle at 50% 50%,
      rgba(110, 180, 40, 0.22) 0%,
      rgba(80, 140, 20, 0) 70%
    );
  filter: blur(14px);
  opacity: 0;
  will-change: transform, opacity;
  animation: cloud-drift var(--dur, 7s) ease-in-out infinite var(--delay, 0s);
}
@keyframes cloud-drift {
  0% {
    transform: translate(var(--cx0), var(--cy0)) scale(0.35) rotate(0deg);
    opacity: 0;
  }
  20% {
    opacity: 0.8;
  }
  55% {
    transform: translate(var(--cx1), var(--cy1)) scale(0.95) rotate(12deg);
    opacity: 0.65;
  }
  80% {
    opacity: 0.28;
  }
  100% {
    transform: translate(var(--cx2), var(--cy2)) scale(1.5) rotate(24deg);
    opacity: 0;
  }
}
@media (prefers-reduced-motion: reduce) {
  .cloud {
    animation: none;
  }
}

/* Falling toilet-paper rolls (right 30%) and diapers (left 30%). Each item is
   placed at its resting spot near the bottom and dropped in via the same
   keyframe; scatter at the bottom reads as a pile. Containers sit behind the
   Trump image (z-index 1 < .trump z-index 2). */
.fall-zone {
  position: fixed;
  top: 0;
  bottom: 0;
  width: 30%;
  pointer-events: none;
  overflow: hidden;
  z-index: 1;
}
.fall-zone.tp {
  right: 0;
}
.fall-zone.diaper {
  left: 0;
}
.fall-item {
  position: absolute;
  bottom: var(--rest, 0px);
  left: var(--lane, 50%);
  width: 64px;
  height: auto;
  transform: rotate(var(--rot, 0deg));
  animation: fall-drop var(--dur, 2.2s) cubic-bezier(0.5, 0, 0.9, 0.4)
    var(--delay, 0s) both;
}
@keyframes fall-drop {
  from {
    transform: translateY(-120vh) rotate(0deg);
  }
  to {
    transform: translateY(0) rotate(var(--rot, 0deg));
  }
}
@media (prefers-reduced-motion: reduce) {
  .fall-item {
    animation: none;
  }
}

/* Cleanup button: hidden until 30 clicks, then revealed with a pulsing green
   border. Sends in Vance to sweep the mess away. */
.cleanup-btn {
  position: absolute;
  bottom: calc(100% + 10px);
  right: 0;
  width: 96px;
  box-sizing: border-box;
  display: none;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 10px;
  background: rgba(20, 26, 33, 0.85);
  border: 2px solid rgba(80, 220, 120, 0.9);
  border-radius: 10px;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  font-family: "Open Sans";
  font-size: 13px;
  color: #fff;
  text-align: center;
  cursor: pointer;
  pointer-events: auto;
  z-index: 10001;
  animation: cleanup-glow 1.4s ease-in-out infinite;
}
.cleanup-btn.show {
  display: inline-flex;
}
.cleanup-icon {
  font-size: 22px;
}
@keyframes cleanup-glow {
  0%,
  100% {
    box-shadow: 0 0 4px rgba(80, 220, 120, 0.5);
  }
  50% {
    box-shadow: 0 0 16px rgba(80, 220, 120, 0.95);
  }
}

/* Vance sweeps right -> left across the screen, clearing the mess (~3s). */
.vance-sweep {
  position: fixed;
  bottom: 0;
  left: 0;
  height: 74.537037%; /* matches .trump image height */
  width: auto;
  pointer-events: none;
  z-index: 9997;
  animation: vance-sweep 10s linear forwards;
}
@media screen and (max-width: 768px) {
  .vance-sweep {
    height: 63.356481%; /* matches .trump mobile height */
    animation-duration: 5s;
  }
}
@keyframes vance-sweep {
  from {
    transform: translateX(110vw);
  }
  to {
    transform: translateX(-120vw);
  }
}
/* Fades a mess item out while its movement animation keeps running. */
@keyframes mess-fade {
  to {
    opacity: 0;
  }
}
