/* Typography. */

@font-face {
  font-family: 'ThinSkinned';
  src: url("../fonts/ThinSkinned.eot");
  src: url("../fonts/ThinSkinned.eot?#iefix")format("embedded-opentype"),
		 url("../fonts/ThinSkinned.woff")format("woff"),
		 url("../fonts/ThinSkinned.ttf")format("truetype");
  font-style: normal;
  font-weight: 400;
  font-display: swap;
}

/* Typography. */

/* Null. */

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  color: var(--color);
}

html {
  display: block;
}

body {
  overflow: hidden;
  margin: 0;
  padding: 0;
  height: 100vh;
  color: var(--color);
  font-size: var(--body);
  font-weight: 400;
  font-style: normal;
  line-height: 1.1;
  font-family: 'ThinSkinned', sans-serif;
  background-color: var(--bg);
}

img,
svg {
  display: block;
  width: 100%;
  height: auto;
}

a {
  text-decoration: none;
}

li {
  list-style-type: none;
}

input,
button,
textarea {
  display: block;
  font-family: var(--family);
  background-color: transparent;
  border: 0 none;
  box-shadow: none;
  appearance: none;
  outline: none;
  resize: none;
}

input::placeholder,
textarea::placeholder {
  color: var(--color);
  font-family: var(--family);
}

/* Null. */

/* Modal. */

.modal {
  --color: #fff;
  --modal_w: 320px;
  --modal_inner: 20px;
  --modal_close: 20px;
  --hide: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 99999;
  transition: opacity .43s;
}

.modal_viel {
  position: absolute !important;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: black;
  opacity: 0.8;
  z-index: -1;
  transition: opacity .83s;
}

.modal:not(.active) {
  pointer-events: none;
  opacity: 0;
}

.modal_wrapper {
  overflow: hidden;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: min(var(--modal_w), 280px);
  background: var(--white);
  border-radius: 15px;
  background: radial-gradient(80.69% 80.69% at 50% 69.63%, #109514 0%, #39B54A 100%);
}

.modal_scroll {
  overflow-y: scroll;
  position: relative;
  width: calc(100% + var(--hide));
  max-height: calc(100vh - 40px);
  margin-right: calc(var(--hide) * -1);
  padding: 40px calc(var(--hide) - var(--scroll) + var(--modal_inner)) 32px var(--modal_inner);
}

.modal_close {
  --size: var(--modal_close);
  top: 16px;
  right: 16px;
}

.modal_title {
  font-size: 26px;
  text-align: center;
  line-height: 1.2;
}

.modal_subtitle {
  margin-top: 32px;
  font-size: 32px;
  text-align: center;
  line-height: 1.2;
}

.modal_text {
  margin-top: 24px;
  font-size: 16px;
  text-align: center;
  line-height: 1.4;
}

/* Modal. */

/* Close. */

._close {
  --color: #fff;
  position: absolute;
  width: var(--size);
  height: var(--size);
  border-radius: 50%;
  cursor: pointer;
  z-index: 1;
  transform: rotate(50grad);
  transition: opacity .43s;
}

._close:before,
._close:after {
  content: '';
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  height: 3px;
  margin-top: -1px;
  background-color: var(--color);
  border-radius: 2px;
  transition: background-color .43s;
}

._close:after {
  transform: rotate(100grad);
}

._close:hover {
  --color: #D2D7DC;
}

/* Close. */

.wrapper {
  overflow: hidden;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: radial-gradient(80.69% 80.69% at 50% 69.63%, #109514 0%, #39B54A 100%);
}

.con {
  pointer-events: none;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}

.text {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: absolute;
  top: 70px;
  left: 50%;
  color: #fff;
  font-size: min(109px, 5.7vw);
  text-transform: uppercase;
  white-space: nowrap;
  text-align: center;
  transform: translate3d(-50%, 0px, 0px);
}

.text span {
  display: block;
  font-size: min(45px, 2.4vw);
  transform: rotate(-1deg);
}

.ribbon {
  --size: max(120%, 1000px);
  position: absolute;
  left: calc(50% - var(--size) / 2);
  bottom: 40px;
  width: var(--size);
}

.ribbon:after {
  content: '';
  display: block;
  padding-bottom: 27.5%;
}

.ribbon img {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  object-fit: contain;
  object-position: center;
}

.cart {
  --size: min(948px, 50vw);
  position: absolute;
  left: calc(50% - var(--size) / 2);
  bottom: -5%;
  width: var(--size);
  margin-bottom: -8%;
  margin-left: 9%;
}

.cart:after {
  content: '';
  display: block;
  padding-bottom: 108%;
}

.cart img {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  object-fit: contain;
  object-position: center;
  /* animation: cart infinite alternate 3s linear; */
}

.cart2 button {
  pointer-events: auto;
  position: absolute;
  top: 14%;
  left: 7%;
  width: calc(var(--size) * .6);
  height: calc(108% * .52);
  z-index: 1;
}

@keyframes cart {
  from {
    transform: rotate(11deg);
  }

  to {
    transform: rotate(-1deg);
  }
}

@keyframes top {
  from {
    transform: translate3d(0, -5%, 0px);
  }

  to {
    transform: translate3d(0, 5%, 0px);
  }
}

@keyframes left {
  from {
    transform: translate3d(-5%, 0, 0px);
  }

  to {
    transform: translate3d(5%, 0, 0px);
  }
}

.flower {
  pointer-events: none;
  --size: min(114px, 11vw);
  position: absolute;
  top: 2%;
  right: 1%;
  width: var(--size);
}

.flower:after {
  content: '';
  display: block;
  padding-bottom: 153%;
}

.flower img {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  object-fit: contain;
  object-position: center;
}

.eggs_wrapper {
  pointer-events: none;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 2;
}

.eggs_left .egg {
  animation: top infinite alternate 4s ease-in-out;
}

.eggs_right .egg {
  animation: left infinite alternate 4s ease-in-out;
}

.eggs_left .egg.animate {
  animation-play-state: paused;
}

.egg.animate, .cart.animate img {
  animation: open 2s linear !important;
}

@keyframes open {
  0% {
    transform: scale(1);
  }

  25% {
    transform: scale(.7);
  }

  50% {
    transform: scale(1);
  }

  75% {
    transform: scale(.7);
  }

  100% {
    transform: scale(0);
  }
}

.egg {
  pointer-events: none;
  position: absolute;
  width: var(--size);
}

.egg:after {
  content: '';
  display: block;
  padding-bottom: var(--pb);
}

.egg img {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  object-fit: contain;
  object-position: center;
}

.egg button {
  pointer-events: auto;
  position: absolute;
  top: var(--t);
  left: var(--l);
  right: var(--r);
  bottom: var(--b);
  width: var(--w);
  height: var(--h);
  z-index: 1;  
    cursor: pointer;
}

.egg._e1 {
  --size: min(266px, 14vw);
  --pb: 112%;
  --t: 0;
  --l: 0;
  --w: calc(var(--size) * .6);
  --h: calc(var(--pb) * .52);
  top: 50px;
  left: 5%;
}

.egg._e2 {
  --size: min(295px, 15.5vw);
  --pb: 109%;
  --t: 0;
  --l: 2%;
  --w: calc(var(--size) * .62);
  --h: calc(var(--pb) * .52);
  top: 30%;
  left: 25%;
}

.egg._e3 {
  --size: min(300px, 16vw);
  --pb: 124%;
  --t: 25%;
  --l: 2%;
  --w: calc(var(--size) * .6);
  --h: calc(var(--pb) * .4);
  top: 30%;
  left: 10%;
}

.egg._e4 {
  --size: min(337px, 18vw);
  --pb: 100%;
  --t: 4%;
  --l: 10%;
  --w: calc(var(--size) * .51);
  --h: calc(var(--pb) * .52);
  top: 64%;
  left: 20%;
}

.egg._e5 {
  --size: min(303px, 16vw);
  --pb: 108%;
  --t: 7%;
  --l: 2%;
  --w: calc(var(--size) * .51);
  --h: calc(var(--pb) * .52);
  top: 70%;
  left: 5%;
}

.egg._e6 {
  --size: min(326px, 17vw);
  --pb: 84%;
  --t: 20%;
  --l: 0%;
  --w: calc(var(--size) * .57);
  --h: calc(var(--pb) * .70);
  top: 24%;
  left: 46%;
}

.egg._e7 {
  --size: min(256px, 13vw);
  --pb: 135%;
  --t: 8%;
  --l: 18%;
  --w: calc(var(--size) * .57);
  --h: calc(var(--pb) * .40);
  top: 5%;
  right: 10%;
}

.egg._e8 {
  --size: min(354px, 20vw);
  --pb: 70%;
  --t: 12%;
  --l: 0;
  --w: calc(var(--size) * .50);
  --h: calc(var(--pb) * .94);
  top: 20%;
  right: -7%;
}

.egg._e9 {
  --size: min(302px, 16vw);
  --pb: 103%;
  --t: 4%;
  --l: 0;
  --w: calc(var(--size) * .50);
  --h: calc(var(--pb) * .6);
  top: 37%;
  right: 3%;
}

.egg._e10 {
  --size: min(294px, 16vw);
  --pb: 96%;
  --t: 4%;
  --l: 0;
  --w: calc(var(--size) * .56);
  --h: calc(var(--pb) * .65);
  top: 70%;
  right: 10%;
}

.egg._e11 {
  --size: min(267px, 14vw);
  --pb: 120%;
  --t: 0;
  --l: 0;
  --w: calc(var(--size) * .58);
  --h: calc(var(--pb) * .50);
  top: 60%;
  right: -3%;
}

@media only screen and (max-height: 800px) and (min-width: 1000px) {
  .con {
    bottom: -80px;
  }
}

@media only screen and (max-height: 1000px) and (min-width: 1600px) {
  .con {
    bottom: -100px;
  }
}

@media only screen and (max-width: 600px) {
  .text {
    font-size: 7.8vw;
  }

  .text span {
    margin-top: 8px;
    font-size: 4vw;
  }

  .cart {
    --size: 85vw;
  }

  .egg._e1 {
    --size: 25vw;
    top: 10%;
  }

  .egg._e2 {
    --size: 26vw;
  }

  .egg._e3 {
    --size: 26vw;
    top: 40%;
    left: 5%;
  }

  .egg._e4 {
    --size: 32vw;
    top: 55%;
  }

  .egg._e5 {
    --size: 26vw;
  }

  .egg._e6 {
    --size: 29vw;
    top: 41%;
  }

  .egg._e7 {
    --size: 23vw;
    top: 6%;
    right: 0;
  }

  .egg._e8 {
    --size: 30vw;
    right: 0;
  }

  .egg._e9 {
    --size: 26vw;
    right: 0;
  }

  .egg._e10 {
    --size: 26vw;
    right: -5%;
  }

  .egg._e11 {
    --size: 24vw;
    top: 52%;
  }
}