@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Manrope:ital,wght@0,400;1,400&display=swap");
:root {
  --blinds-spacing: 1vh;
}

body {
  font-family: "Manrope", sans-serif;
}

#page {
  overflow-y: scroll;
  overflow-x: hidden;
  height: 100vh;
  background-color: #f4f3ee;
}

.blind-container {
  margin-top: 80vh;
  min-height: calc(var(--blinds-spacing) * 20 + 100vh);
}

.blind {
  text-align: left;
  position: sticky;
  top: 20px;
  margin-left: 20px;
  margin-bottom: var(--blinds-spacing);
  font-size: 3rem;
  line-height: 4rem;
  display: block;
}
.blind:nth-of-type(1) {
  clip-path: inset(0% 0 75% 0);
}
.blind:nth-of-type(2) {
  clip-path: inset(25% 0 50% 0);
}
.blind:nth-of-type(3) {
  clip-path: inset(50% 0 25% 0);
}
.blind:nth-of-type(4) {
  clip-path: inset(75% 0 0% 0);
}
.blind:nth-of-type(5) {
  clip-path: inset(100% 0 -25% 0);
}
.blind:nth-of-type(6) {
  clip-path: inset(125% 0 -50% 0);
}
.blind:nth-of-type(7) {
  clip-path: inset(150% 0 -75% 0);
}
.blind:nth-of-type(8) {
  clip-path: inset(175% 0 -100% 0);
}
.blind:nth-of-type(9) {
  clip-path: inset(200% 0 -125% 0);
}
.blind:nth-of-type(10) {
  clip-path: inset(225% 0 -150% 0);
}

.blind2 {
  text-align: left;
  position: sticky;
  top: 20px;
  margin-left: 20px;
  margin-bottom: var(--blinds-spacing);
  font-size: 3rem;
  line-height: 4rem;
  display: block;
}
.blind2:nth-of-type(1) {
  clip-path: inset(0% 0 87.5% 0);
}
.blind2:nth-of-type(2) {
  clip-path: inset(12.5% 0 75% 0);
}
.blind2:nth-of-type(3) {
  clip-path: inset(25% 0 62.5% 0);
}
.blind2:nth-of-type(4) {
  clip-path: inset(37.5% 0 50% 0);
}
.blind2:nth-of-type(5) {
  clip-path: inset(50% 0 37.5% 0);
}
.blind2:nth-of-type(6) {
  clip-path: inset(62.5% 0 25% 0);
}
.blind2:nth-of-type(7) {
  clip-path: inset(75% 0 12.5% 0);
}
.blind2:nth-of-type(8) {
  clip-path: inset(87.5% 0 0% 0);
}
.blind2:nth-of-type(9) {
  clip-path: inset(100% 0 -12.5% 0);
}
.blind2:nth-of-type(10) {
  clip-path: inset(112.5% 0 -25% 0);
}

.sticky-permanent {
  position: sticky;
  top: 0px;
  margin-left: 20px;
  height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: top;
  align-items: left;
  z-index: 0;
}
.sticky-permanent h2 {
  font-size: 3rem;
  margin-top: 1rem;
  margin-bottom: 1rem;
}

.hidden {
  visibility: hidden;
  display: inline-block;
  overflow: hidden;
}

em {
  font-style: italic !important;
}

.blind,
.blind2,
.sticky-permanent h2 {
  font-size: clamp(0.6rem, 4vw, 3rem);
  line-height: clamp(1.2rem, 5vw, 4rem);
  white-space: nowrap;
  /* evita saltos de línea */
  overflow: hidden;
  /* previene desbordes */
  text-overflow: ellipsis;
  /* opcional */
}

.sticky-permanent p {
  font-size: clamp(0.1rem, 3vw, 1rem);
  line-height: clamp(0.3rem, 5vw, 1rem);
  white-space: nowrap;
  /* evita saltos de línea */
  overflow: hidden;
  /* previene desbordes */
  text-overflow: ellipsis;
  /* opcional */
}

.blind-img {
  position: sticky;
  top: 20px;
  margin-left: auto;
  margin-right: 20px;
  margin-bottom: var(--blinds-spacing);
  display: block;
  max-width: clamp(150px, 30vw, 400px);
  height: auto;
}
.blind-img:nth-of-type(1) {
  clip-path: inset(0% 0 75% 0);
}
.blind-img:nth-of-type(2) {
  clip-path: inset(25% 0 50% 0);
}
.blind-img:nth-of-type(3) {
  clip-path: inset(50% 0 25% 0);
}
.blind-img:nth-of-type(4) {
  clip-path: inset(75% 0 0% 0);
}
.blind-img:nth-of-type(5) {
  clip-path: inset(100% 0 -25% 0);
}
.blind-img:nth-of-type(6) {
  clip-path: inset(125% 0 -50% 0);
}
.blind-img:nth-of-type(7) {
  clip-path: inset(150% 0 -75% 0);
}
.blind-img:nth-of-type(8) {
  clip-path: inset(175% 0 -100% 0);
}
.blind-img:nth-of-type(9) {
  clip-path: inset(200% 0 -125% 0);
}
.blind-img:nth-of-type(10) {
  clip-path: inset(225% 0 -150% 0);
}

@media (max-width: 600px) {
  .blind-img {
    top: calc(20px + 10vh);
  }
}
.gradient {
  background: linear-gradient(var(--g-ang, to bottom), transparent 0%, var(--g-col, #00000033) 40%, var(--g-col, #00000033) 66%, transparent 100%);
}

.pixel {
  image-rendering: pixelated;
  image-rendering: crisp-edges;
  /* fallback */
  transform: scale(3);
  transform-origin: top right;
  /* keeps position consistent */
}

.progress-circle-container {
  position: fixed;
  bottom: 60px;
  right: 30px;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
}

.progress-circle {
  width: 80px;
  height: 80px;
  transform: rotate(-90deg);
}

.progress-circle-bar {
  fill: none;
  stroke: black;
  stroke-width: 5;
  stroke-dasharray: 283;
  stroke-dashoffset: 0;
  transform-origin: center;
  transition: stroke-dashoffset 0.3s ease;
}

.progress-text {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-weight: bold;
  font-size: 1.2rem;
  color: #000;
  z-index: 9997;
  /* Below the scroll-to-top button */
  pointer-events: none;
}

.progress-background {
  fill: transparent;
  stroke: #ededed;
  stroke-width: 5;
  stroke-dasharray: none;
}

.scroll-to-top {
  position: absolute;
  height: 100%;
  width: 100%;
  background-color: black;
  border-radius: 50%;
  cursor: pointer;
  transition: opacity 0.3s ease;
  z-index: 9998;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
}

.scroll-to-top svg {
  display: block;
  width: 20px;
  height: 20px;
  stroke: white;
  transition: all 0.1s ease;
}

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

.mouse {
  background: #4e5559 linear-gradient(transparent 0%, transparent 50%, #d2d1ce 50%, #d2d1ce 100%);
  position: relative;
  width: 52px;
  height: 88px;
  border-radius: 100px;
  background-size: 100% 200%;
  animation: colorSlide 6s linear infinite, nudgeMouse 6s ease-out infinite;
}
.mouse:before, .mouse:after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
}
.mouse:before {
  width: 46px;
  height: 82px;
  background-color: #f4f3ee;
  border-radius: 100px;
}
.mouse:after {
  background-color: #4e5559;
  width: 10px;
  height: 10px;
  border-radius: 100%;
  animation: trackBallSlide 6s linear infinite;
}

@keyframes colorSlide {
  0% {
    background-position: 0% 100%;
  }
  20% {
    background-position: 0% 0%;
  }
  21% {
    background-color: #4e5559;
  }
  29.99% {
    background-color: #d2d1ce;
    background-position: 0% 0%;
  }
  30% {
    background-color: #4e5559;
    background-position: 0% 100%;
  }
  50% {
    background-position: 0% 0%;
  }
  51% {
    background-color: #4e5559;
  }
  59% {
    background-color: #d2d1ce;
    background-position: 0% 0%;
  }
  60% {
    background-color: #4e5559;
    background-position: 0% 100%;
  }
  80% {
    background-position: 0% 0%;
  }
  81% {
    background-color: #4e5559;
  }
  90%, 100% {
    background-color: #d2d1ce;
  }
}
@keyframes trackBallSlide {
  0% {
    opacity: 1;
    transform: scale(1) translateY(-20px);
  }
  6% {
    opacity: 1;
    transform: scale(0.9) translateY(5px);
  }
  14% {
    opacity: 0;
    transform: scale(0.4) translateY(40px);
  }
  15%, 19% {
    opacity: 0;
    transform: scale(0.4) translateY(-20px);
  }
  28%, 29.99% {
    opacity: 1;
    transform: scale(1) translateY(-20px);
  }
  30% {
    opacity: 1;
    transform: scale(1) translateY(-20px);
  }
  36% {
    opacity: 1;
    transform: scale(0.9) translateY(5px);
  }
  44% {
    opacity: 0;
    transform: scale(0.4) translateY(40px);
  }
  45%, 49% {
    opacity: 0;
    transform: scale(0.4) translateY(-20px);
  }
  58%, 59.99% {
    opacity: 1;
    transform: scale(1) translateY(-20px);
  }
  60% {
    opacity: 1;
    transform: scale(1) translateY(-20px);
  }
  66% {
    opacity: 1;
    transform: scale(0.9) translateY(5px);
  }
  74% {
    opacity: 0;
    transform: scale(0.4) translateY(40px);
  }
  75%, 79% {
    opacity: 0;
    transform: scale(0.4) translateY(-20px);
  }
  88%, 100% {
    opacity: 1;
    transform: scale(1) translateY(-20px);
  }
}
@keyframes nudgeMouse {
  0% {
    transform: translateY(0);
  }
  20% {
    transform: translateY(8px);
  }
  30% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(8px);
  }
  60% {
    transform: translateY(0);
  }
  80% {
    transform: translateY(8px);
  }
  90% {
    transform: translateY(0);
  }
}
.blind-container {
  margin-top: 0 !important;
  position: relative;
}

.blind,
.blind2,
.blind-img {
  will-change: transform;
}