* {

	box-sizing: border-box;
	padding: 0;
	margin: 0;
}

.flower-coin {

  position: relative;
  top: 2px;
  border-radius: 100%;
}

body {

	background-color: #fff;
}

.group-project {

  background-color: #011f23;
}

.back-page {

    position: absolute;
    left: 10px;
    top: 10px;
    display: flex;
    align-items: center;
    gap: 5px;
    color: #fff;
    text-decoration: none;
}

body {

	transform-origin: center center; /* Define o ponto de zoom */
	transform: scale(1) translate(0, 0);
	transition: transform 2s ease-in-out;
}

body.single-criptomoedas {

  overflow: hidden;
  background-color: #011f23;
}

body.zoom {
	transform: scale(10) translate(0, -50px); /* Ajusta o zoom e posicionamento */
}

.timeline {

	display: flex;
	overflow-x: scroll;
	gap: 90px;
	padding: 20px;
	align-items: self-start;
	height: 641px;
	position: relative;
}

.timeline:after {

	background: url(../src/images/floor.png);
    height: 134px;
    width: 1165px;
    position: absolute;
    bottom: -42px;
    left: 0;
    content: "";
    background-size: cover;
    background-position: center top;
}

.event {

	background: url("../src/images/quadro.png") no-repeat center center;
	width: 204px;
	height: 323px;
	background-size: 100%;
}

.number {

	background: url(../src/images/number.png) no-repeat center center;
    width: 92px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}

.number.first:before {

	display: none;
}

.number.last:after {

	display: none;
}

.number:after {

    content: "";
    position: absolute;
    left: 90px;
    top: 9px;
    width: 129px;
    height: 2px;
    background-color: #fff;
}

.number:before {

    content: "";
    position: absolute;
    right: 90px;
    top: 9px;
    width: 63px;
    height: 2px;
    background-color: #fff;
}

.number span {

	font-weight: bold;
	position: relative;
	top: -2px;
}

.timeline-item {

	width: 204px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	justify-content: start;
	align-items: center;
	position: relative;
	height: 450px;
}


.timeline-item.timeline-item-door {

	height: 529px;
	margin-left: 20px;
  margin-right: 20px;
}

.coin-aaa {

    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    margin-top: 25px;
    gap: 10px;
    text-decoration: none;
}

.group-coin-aaa {

  font-family: "Inter", sans-serif;
  text-align: center;
  margin-top: 10px;
}

.content-page {

  padding: 20px;
}

.content-page p {

  padding-bottom: 10px;
}

.content-page ol,
.content-page ul {

  padding-left: 20px;
  padding-bottom: 20px;
}

.content-page ol li,
.content-page ul li {

  font-family: "Inter", sans-serif;
  font-size: 12px;
}

body.home {

  background-color: #1C3738;
}

.welcome {

  justify-content: center;
  align-items: center;
  flex-direction: column;
  height: 100vh;
  display: flex;
}

.welcome a {

  color: #fff;
  font-family: "Inter", sans-serif;
  text-decoration: none;
}

.welcome a:hover {

  color: #FBA301;
}

.content-page h1,
.content-page h2,
.content-page h3,
.content-page h4,
.content-page h5,
.content-page h6 {

  font-family: "Inter", sans-serif;
}

.content-page h2 {

  font-size: 21px;
}

.group-coin-aaa h1 {

  font-size: 21px;
  color: #fff;
  margin-bottom: 10px;
}

.group-coin-aaa strong {

  font-size: 16px;
  color: #9b9b9b;
}

.coin-aaa span,
.coin-aaa strong {

  color: #fff;
  font-family: "Inter", sans-serif;
}

body.single-post {

  background-color: #000;
  overflow: auto;
}

.room-current {

  position: absolute;
  left: 0;
  top: -12px;
  color: #fff;
  background-color: #000;
  padding: 2px 20px;
  font-family: "Inter", sans-serif;
  border-radius: 5px;
  font-size: 13px;
}

.timeline-item.timeline-item-featured:after {

	  position: absolute;
    right: -42px;
    content: "";
    background: url(../src/images/featured.png) no-repeat center center;
    width: 270px;
    height: 89%;
    background-size: 100%;
    bottom: -141px;
}

.timeline-item.timeline-item-featured .description {

	padding-left: 10px;
	padding-right: 10px;
}

.timeline-item .image {

	position: relative;
  margin-bottom: 20px;
}

.timeline-item .image img {

  padding: 38px 28px;
}

.timeline-item .image:after {

    content: "";
    left: 0;
    right: 0;
    margin: 0 auto;
    position: absolute;
    width: 37px;
    height: 62px;
    background: url(../src/images/light.png) no-repeat center center;
    border-radius: 0px 0px 50px 50px;
}

.light-top {

	width: 132px;
    height: 291px;
    background: url(../src/images/light-2.png) no-repeat center center;
    position: fixed;
    left: 20px;
    top: 0;
    content: "";
    z-index: 10;
}

.light-top.light-top-2 {

	left: inherit;
	right: 15px;
}

/*.timeline-item .image:before {

    content: "";
    left: 31px;
    position: absolute;
    width: 133px;
    height: 231px;
    background: url(../src/images/shadow.png) no-repeat center center;
    top: 39px;
}*/

.description {

}

.description p {

	color: #fff;
  font-size: 14px;
}

p, span {

	font-family: "Inter", sans-serif;
	font-optical-sizing: auto;
	font-style: normal;
	font-size: 12px;
}


.container {

	position: relative;
	min-height: 100vh;
	transform-style: preserve-3d;
	perspective: 1000px;
}

.group-project {

	overflow: hidden;
}

.surface {

	position: fixed;
	bottom: 0;
	display: grid;
	grid-template-rows: repeat(10, 300px);
	grid-template-columns: repeat(99, 300px);
	transform-origin: bottom;
	transform-origin: bottom;
	transform: rotateX(70deg) translateX(-5%);
	animation: animate 50s linear infinite;
}

.surface div:nth-child(odd) {
	background-color: #424b5c;
}

.surface div:nth-child(even) {
	background-color: #fff;
}

.door-frame {
	width: 200px;
	height: 100%;
	background-color: #000;
	border: 15px solid #ff0;
	border-radius: 2px;
	position: relative;
	perspective: 800px; /* Adding perspective for 3D effect */
	cursor: pointer;
	z-index: 9;
transition: transform 2s ease-in-out, width 2s ease-in-out, height 2s ease-in-out, border-radius 2s ease-in-out;
}

		.door-frame.zoom {
			width: 100vw;
			height: 100vh;
			transform: scale(1.5);
			border: 15px solid #000;
			z-index: 2;
		}

.door-1 {
	width: 100%;
	height: 100%;
	background-color: #8b4513; /* Brown door */
	position: absolute;
	left: 0;
	top: 0;
	transform-origin: right; /* Pivot the door from the right side */
	transform: rotateY(0deg);
	transition: transform 2s ease-in-out;
}

.door-1.open {
	transform: rotateY(120deg); /* Swing open to 120 degrees */
}

.door-1::before {
	content: "";
	position: absolute;
	width: 15px;
	height: 40px;
	background-color: #222;
	border-radius: 20%;
	left: 20px; /* Adjust handle to the left side */
	top: 50%;
	transform: translateY(-50%);
}

.choices {

    position: fixed;
    left: 20px;
    top: calc(100% - 70px);
    display: grid;
    justify-content: space-between;
    right: 20px;
    margin: 0 auto;
    grid-template-columns: 1fr 1fr;
    gap: 15px;
    z-index: 22;
}

.modal .choices {

	position: static;
	display: flex;
    flex-direction: column;
    width: 200px;
    justify-content: center;
    align-items: start;
    gap: 5px;
}

.modal .choices li a {

	text-align: left;
	justify-content: space-between;

}

.modal .choices li.active .status {

	background: url("../src/images/icon-check.svg");
	background-size: 100%;
}

.modal .group {

	display: flex;
    gap: 10px;
}

.modal .choices li .status {

	width: 25px;
    height: 25px;

}

.modal .choice-title {

	font-family: "Inter", sans-serif;
	color: #fff;
	font-size: 15px;
}

.modal .choices li a {

	border-top: 6px solid transparent;
	border-bottom: 6px solid #b6b6b6;
}

.modal .choices li.active a {

	background-color: #fff;
	border-top: 6px solid transparent;
	border-bottom: 6px solid #8BC34A;
}

.modal .choices li {

	width: 100%;
}

.choices li .descr span,
.choices li .descr strong {

	font-family: "Inter", sans-serif;

}

.choices li .descr strong {

	color: #000;
}

.choices li a .descr span,
.choices li .descr span  {

	font-weight: bold;
	color: #9e9e9e;
}

.choices li img {

	width: 35px;
}

.choices li.coin-choice {

	background-color: #fff;
	padding: 10px;
	display: flex;
    gap: 10px;
    box-shadow: 1px 1px 8px #333;
}

.choices li .descr {

	display: flex;
	flex-direction: column;
}

.choices li {

	list-style: none;
}

.choices li a {

    display: flex;
    align-items: center;
    gap: 10px;
    justify-content: center;
    height: 55px;
    background-color: #fff;
    padding: 10px 20px;
    text-decoration: none;
}

.icon-featured {

	position: absolute;
    left: 22px;
    width: 27px;
    top: 16px;
}

.door-coin {

    position: relative;
    display: flex;
    gap: 10px;
    justify-content: start;
    width: 200px;
}

.step {

    padding: 5px 30px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.step span {

	color: #fff;
	font-size: 20px;
	font-family: "Lilita One", sans-serif;
	font-weight: 400;
	font-style: normal;
}

    .modal {

    height: 100dvh;
    width: 100%;
    z-index: 99999999;
    position: fixed;
    top: 0;
    left: 0;
    display: none;

}

.modal.active {

    display: flex;
    align-items: center;
    justify-content: center;
}

.buttons-modal {

    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    width: 100%;
}

.bg-modal {

    background-color: rgba(0, 0, 0, 0.9);
    height: 100%;
    width: 100%;
    position: fixed;
    left: 0;
    top: 0;
    z-index: 9999999;
    display: none;
}

.wrapper-modal {

    padding: 15px;
    position: relative;
    z-index: 99999999;
    width: 100%;
    display: flex;
    gap: 10px;
    justify-content: center;
    align-items: center;
    flex-direction: column;

}

.close-modal {

    position: fixed;
    right: 20px;
    top: 20px;
    width: 20px;
    height: 20px;
    z-index: 999999999;
}

.logoutButton {
    --figure-duration: 100ms;
    --transform-figure: none;
    --walking-duration: 100ms;
    --transform-arm1: none;
    --transform-wrist1: none;
    --transform-arm2: none;
    --transform-wrist2: none;
    --transform-leg1: none;
    --transform-calf1: none;
    --transform-leg2: none;
    --transform-calf2: none;
    background: none;
    border: 0;
    color: #f4f7ff;
    cursor: pointer;
    display: block;
    font-family: "Quicksand", sans-serif;
    font-size: 16px;
    font-weight: 500;
    height: 40px;
    outline: none;
    padding: 0 0 0 10px;
    perspective: 100px;
    position: relative;
    text-align: left;
    width: 100%;
    -webkit-tap-highlight-color: transparent;
    text-transform: uppercase;
    overflow: hidden;
}
.logoutButton.current {

  filter: grayscale(1);
  pointer-events: none;
}
.logoutButton:hover .door {
  transform: rotateY(20deg);
}
.logoutButton:active::before {
  transform: scale(0.96);
}
.logoutButton:active .door {
  transform: rotateY(28deg);
}
.logoutButton.clicked::before {
  transform: none;
}
.logoutButton.clicked .door {
  transform: rotateY(35deg);
}
.logoutButton.door-slammed .door {
  transform: none;
  transition: transform 100ms ease-in 250ms;
}
.logoutButton.falling {
  animation: shake 200ms linear;
}
.logoutButton.falling .bang {
  animation: flash 300ms linear;
}
.logoutButton.falling .figure {
  animation: spin 1000ms infinite linear;
  bottom: -1080px;
  opacity: 0;
  right: 1px;
  transition: transform calc(var(--figure-duration) * 1ms) linear, bottom calc(var(--figure-duration) * 1ms) cubic-bezier(0.7, 0.1, 1, 1) 100ms, opacity calc(var(--figure-duration) * 0.25ms) linear calc(var(--figure-duration) * 0.75ms);
  z-index: 1;
}
.logoutButton--light::before {
  background-color: #f4f7ff;
}
.logoutButton--light .button-text {
  color: #1f2335;
}
.logoutButton--light .door,
.logoutButton--light .doorway {
  fill: #1f2335;
}

.button-text {
  color: #f4f7ff;
  font-weight: bold;
  position: relative;
  z-index: 10;
  font-size: 11px;
}

button svg {
  display: block;
  position: absolute;
}

.figure {
  bottom: 5px;
  fill: #fff;
  right: 18px;
  transform: var(--transform-figure);
  transition: transform calc(var(--figure-duration) * 1ms) cubic-bezier(0.2, 0.1, 0.8, 0.9);
  width: 30px;
  z-index: 4;
}

.door,
.doorway {
  bottom: 4px;
  fill: #000;
  right: 12px;
  width: 32px;
}

.door {
  transform: rotateY(20deg);
  transform-origin: 100% 50%;
  transform-style: preserve-3d;
  transition: transform 200ms ease;
  z-index: 5;
}
.door path {
    fill: #fff;
    stroke: #000;
    stroke-width: 4;
}

.doorway {
  z-index: 3;
}

.bang {
  opacity: 0;
}

.arm1, .wrist1, .arm2, .wrist2, .leg1, .calf1, .leg2, .calf2 {
  transition: transform calc(var(--walking-duration) * 1ms) ease-in-out;
}

.arm1 {
  transform: var(--transform-arm1);
  transform-origin: 52% 45%;
}

.wrist1 {
  transform: var(--transform-wrist1);
  transform-origin: 59% 55%;
}

.arm2 {
  transform: var(--transform-arm2);
  transform-origin: 47% 43%;
}

.wrist2 {
  transform: var(--transform-wrist2);
  transform-origin: 35% 47%;
}

.leg1 {
  transform: var(--transform-leg1);
  transform-origin: 47% 64.5%;
}

.calf1 {
  transform: var(--transform-calf1);
  transform-origin: 55.5% 71.5%;
}

.leg2 {
  transform: var(--transform-leg2);
  transform-origin: 43% 63%;
}

.calf2 {
  transform: var(--transform-calf2);
  transform-origin: 41.5% 73%;
}

@keyframes spin {
  from {
    transform: rotate(0deg) scale(0.94);
  }
  to {
    transform: rotate(359deg) scale(0.94);
  }
}
@keyframes shake {
  0% {
    transform: rotate(-1deg);
  }
  50% {
    transform: rotate(2deg);
  }
  100% {
    transform: rotate(-1deg);
  }
}
@keyframes flash {
  0% {
    opacity: 0.4;
  }
  100% {
    opacity: 0;
  }
}


body .background {
  align-items: center;
  display: flex;
  height: 100%;
  justify-content: center;
  width: 50%;
}
body .background--light {
  background: #f4f7ff;
}
body .background--dark {
  background: #1f2335;
}

.wallet {

    position: absolute;
    z-index: 9;
    width: 60px;
    display: flex;
    flex-direction: column;
    bottom: -10px;
    right: -70px;
}

.wallet.open {

	z-index: 1;
}


.icon {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: #0066ff;
  color: #fff;
  position: relative;
  z-index: 101;
}

.coin {
  position: absolute;
  top: var(--coin-from-x, 24px);
  left: var(--coin-from-y, 24px);
  z-index: 100;
  opacity: 0;
}

.coin::after {
  content: "$";
  display: flex;
  align-items: center;
  justify-content: center;
  width: 12px;
  height: 12px;
  font-size: 10px;
  color: rgb(237, 196, 107);
  background: rgb(227, 162, 23);
  border: 2px solid rgb(237, 196, 107);
  border-radius: 50%;
  opacity: 0;
}

.coin--animated,
.coin--animated::after {
  animation-delay: var(--coin-delay, 0s);
  animation-duration: var(--coin-duration, 1.5s);
  animation-direction: normal;
  animation-fill-mode: both;
  animation-play-state: running;
  animation-iteration-count: infinite;
}

.coin--animated {
  animation-name: coin-x-axis;
  animation-timing-function: ease-in;
}

.coin--animated::after {
  animation-name: coin-y-axis-and-flip;
  animation-timing-function: ease-out;
}

@keyframes coin-x-axis {
  30% {
    opacity: 1;
  }
  70% {
    opacity: 1;
  }
  to {
    left: calc(var(--coin-to-x) * 1.5);
  }
}

@keyframes coin-y-axis-and-flip {
  30% {
    opacity: 1;
  }
  70% {
    opacity: 1;
  }
  to {
    transform: translateY(calc(var(--coin-to-y) * 1.5)) rotate3d(1, 1, 1, 1080deg);
  }
}

.touchon-hand-fill {
  fill: #ffffff;
  filter: drop-shadow(0px 6px 10px rgba(0, 0, 0, 0.5));
}

.touchon-hand-stroke {
  stroke: #000;
  stroke-width: 12;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.touchon-hand-fill, .touchon-hand-stroke {
  animation: 2.2s linear 0.6s infinite handTouch;
  transform-origin: 50% 50%;
}

.hand-touch-1, .hand-touch-2, .hand-touch-3 {
  stroke: #fff;
  filter: drop-shadow(0px 6px 10px rgba(0, 0, 0, 0.4));
}

.hand-touch-1 {
  animation: 2.2s linear 0s infinite touch-1;
}

.hand-touch-2 {
  animation: 2.2s linear 0s infinite touch-2;
  opacity: 0;
}

.hand-touch-3 {
  animation: 2.2s linear 0s infinite touch-3;
  opacity: 0;
}

@keyframes touch-1 {
  0% {
    r: 0;
  }
  70% {
    r: 0;
  }
  80% {
    r: 50;
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes touch-2 {
  0% {
    r: 0;
  }
  50% {
    r: 0;
  }
  80% {
    r: 110;
    opacity: 0.8;
  }
  95% {
    opacity: 0;
  }
}
@keyframes touch-3 {
  30% {
    r: 0;
    opacity: 0;
  }
  80% {
    r: 160;
    opacity: 0.7;
  }
  90% {
    opacity: 0;
  }
}
@keyframes handTouch {
  0% {
    transform: scale(1, 1);
  }
  10% {
    transform: scale(0.7, 0.7);
  }
  20% {
    transform: scale(1, 1);
  }
}

.hand {

	position: absolute;
    z-index: 22;
    top: 285px;
    transform: rotate(-25deg);
    right: 110px;
}