@charset "UTF-8";
@font-face {
  font-family: "Neutral Face";
  font-weight: 400;
  font-style: normal;
  src: url("../fonts/NeutralFace.woff") format("woff");
}
@font-face {
  font-family: "Neutral Face";
  font-weight: 600;
  font-style: bold;
  src: url("../fonts/NeutralFaceBold.woff") format("woff");
}
@font-face {
  font-family: "Galvji";
  font-weight: 400;
  font-style: normal;
  src: url("../fonts/Galvji.woff") format("woff");
}
@font-face {
  font-family: "Galvji";
  font-weight: 600;
  font-style: bold;
  src: url("../fonts/GalvjiBold.woff") format("woff");
}
@font-face {
  font-family: "Roboto";
  font-weight: 400;
  font-style: normal;
  src: url("../fonts/Roboto.woff") format("woff");
}
@font-face {
  font-family: "Roboto";
  font-weight: 600;
  font-style: bold;
  src: url("../fonts/RobotoBold.woff") format("woff");
}
* {
  box-sizing: border-box;
  font-size: calc(14px + 10 * (100vw - 300px) / 1300);
  scroll-behavior: smooth;
}

body {
  margin: 0;
  background: #ffffff;
  color: #000000;
  font-family: "Roboto", sans-serif;
  letter-spacing: 0.3px;
}
body.purple {
  --color: #8132f6;
}
body.green {
  --color: #007355;
}
body.brown {
  --color: #9e7c55;
}
body.red {
  --color: #f41a42;
}
body.blue {
  --color: #5c96d6;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: "Neutral Face";
  font-weight: 400;
  margin-top: 1.2em;
  margin-bottom: 1em;
  overflow-wrap: anywhere;
}

h1 {
  font-size: 2rem;
}

h2 {
  font-size: 2rem;
}
@media screen and (min-width: 1536px) {
  h2 {
    font-size: 2.2rem;
  }
}

h3 {
  font-size: 1.6rem;
}

h4 {
  font-size: 1.4rem;
}

h5 {
  font-size: 1.2rem;
}

h6 {
  font-size: 0.9rem;
}

p,
a,
li,
strong,
em {
  font-size: 1rem;
}
@media screen and (min-width: 1536px) {
  p,
  a,
  li,
  strong,
  em {
    font-size: 1.1rem;
  }
}

br {
  line-height: 1em;
}

header {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  z-index: 1;
  pointer-events: none;
}
header .header-container {
  position: sticky;
  height: 40vh;
  top: calc(60vh - 45px);
  pointer-events: none;
}
@media screen and (min-width: 768px) {
  header .header-container {
    top: 60vh;
  }
}
header nav {
  display: none;
  pointer-events: all;
  padding: 1.6rem;
  position: absolute;
  bottom: 0;
  right: 10%;
  text-align: right;
  transition: 0.2s;
}
header nav ul {
  margin: unset;
}
header nav li {
  list-style: none;
}
header nav a {
  text-decoration: none;
  font-size: 1.1em;
  line-height: 1em;
  text-transform: uppercase;
  color: black;
}
header nav a:hover {
  color: var(--color);
}
@media screen and (min-width: 640px) {
  header nav {
    display: flex;
    align-items: center;
  }
}
@media screen and (min-width: 1024px) {
  header nav {
    right: 20%;
  }
}
header .nav-big {
  bottom: 30vh;
}
header .nav-big a {
  font-size: 1.6em;
}
header .main-logo {
  position: absolute;
  bottom: 0;
  width: 62%;
  padding: 1rem;
  transform-origin: 0% 100%;
  transition: 0.2s;
  pointer-events: all;
}
header .main-logo.main-logo-big {
  /*transform: scale(1.6);*/
  width: 100%;
}
@media screen and (min-width: 420px) {
  header .main-logo.main-logo-big {
    /*width: 50%;*/
  }
}
@media screen and (min-width: 640px) {
  header .main-logo.main-logo-big {
    width: 65%;
  }
}
@media screen and (min-width: 768px) {
  header .main-logo.main-logo-big {
    width: 55%;
  }
}
@media screen and (min-width: 1024px) {
  header .main-logo.main-logo-big {
    width: 45%;
  }
}
@media screen and (min-width: 1536px) {
  header .main-logo.main-logo-big {
    width: 36%;
  }
}
@media screen and (min-width: 420px) {
  header .main-logo {
    /*width: 50%;*/
  }
}
@media screen and (min-width: 640px) {
  header .main-logo {
    width: 50%;
  }
}
@media screen and (min-width: 768px) {
  header .main-logo {
    width: 36%;
  }
}
@media screen and (min-width: 1024px) {
  header .main-logo {
    width: 30%;
  }
}
@media screen and (min-width: 1536px) {
  header .main-logo {
    width: 25%;
  }
}

.section-background {
  position: fixed;
  z-index: -1;
}
.section-background svg {
  position: absolute;
  top: -117%;
  height: 379%;
  transition: 0.3s;
  fill: white;
  stroke: var(--color);
  stroke-width: 2px;
}
.section-background svg.outlined-color {
  fill: white;
  stroke: var(--color);
}
.section-background svg.filled-color {
  fill: var(--color);
  stroke: white;
}
.section-background svg.outlined-black {
  fill: white;
  stroke: black;
}
.section-background svg:first-child {
  animation: scroll-banner 800s infinite linear;
}
.section-background svg:last-child {
  animation: scroll-banner1 800s infinite linear;
  animation-delay: -800s;
}

.section-wrapper {
  position: relative;
  width: 100%;
}

section {
  position: relative;
  width: 100%;
  min-height: 100vh;
}

.section-about,
.section-work,
.section-contact {
  padding: 1rem;
}

.section-about {
  /*margin-top: 100vh;*/
  padding-top: 25vh;
  top: 100vh;
  padding-bottom: 100vh;
}

.section-work {
  pointer-events: all;
}
.section-work h2 {
  margin-top: 2rem;
  margin-bottom: 4rem;
  padding-top: 1rem;
}
.section-work h6 {
  margin-top: 4rem;
  margin-bottom: 2rem;
}
.section-work a {
  text-decoration: none;
  color: black;
}
.section-work a:hover {
  color: var(--color);
}

.section-contact {
  height: 100vh;
}

.main-sound-player {
  position: absolute;
  right: 10rem;
  top: 12%;
  cursor: pointer;
}
.main-sound-player svg {
  width: 7vw;
  min-width: 80px;
  height: auto;
  stroke: var(--color);
  stroke-width: 2px;
  fill: transparent;
  transition: 0.2s;
}
.main-sound-player svg:hover {
  fill: var(--color);
}
@media screen and (min-width: 1024px) {
  .main-sound-player {
    right: 6rem;
    top: 6rem;
  }
}

.element-title-description {
  width: 100%;
  padding: 1rem;
  visibility: hidden;
  transition: 0.2s;
}
.element-title-description p {
  margin: 0;
  font-family: "Neutral Face";
  line-height: 1.1em;
  font-size: 2.5vw;
  transition: 0.2s;
  white-space: nowrap;
}
.element-title-description.sticky {
  visibility: visible;
  position: sticky;
  top: 0;
  z-index: 1;
}
.element-title-description.sticky p {
  font-size: 4.7vw;
}
@media screen and (min-width: 420px) {
  .element-title-description.small p {
    font-size: 3.8vw;
  }
}
@media screen and (min-width: 1024px) {
  .element-title-description {
    width: 75%;
  }
  .element-title-description.sticky p {
    font-size: 3.8vw;
  }
  .element-title-description.small {
    width: 50%;
  }
  .element-title-description.small p {
    font-size: 2.5vw;
  }
}

section.absolute {
  position: absolute;
}
section.absolute:nth-child(1) {
  background: #119da4;
}
section.absolute:nth-child(2) {
  background: #6d9dc5;
}

.div-sticky {
  width: 80%;
  height: 20vh;
  position: sticky;
  top: 0;
  background: var(--color);
}

.animation-test-wrapper {
  position: relative;
  height: calc(90vw + 2rem);
}

.animation-test-container {
  position: absolute;
  left: 0;
  top: 0;
}

.animation-test {
  display: flex;
  flex-direction: row;
  gap: 1rem;
  padding: 1rem;
  offset-path: polygon(0% 0%, calc(-100% + 100vw) 100%);
  offset-anchor: 0 0;
  offset-rotate: 0deg;
  offset-distance: 0%;
  /*animation: move 3000ms infinite alternate ease-in-out;*/
}

.animation-test-element {
  width: calc(20vw - 1rem);
  height: 45vw;
  background: aqua;
}

@keyframes move {
  0% {
    offset-distance: 0%;
  }
  100% {
    offset-distance: 50%;
  }
}
.about-container {
  width: 100%;
}
@media screen and (min-width: 768px) {
  .about-container {
    width: 50%;
  }
}

.profiles-wrapper {
  display: flex;
  flex-direction: column;
  gap: 0rem;
}
@media screen and (min-width: 640px) {
  .profiles-wrapper {
    flex-direction: row;
    gap: 2rem;
  }
}

.profile-container {
  flex-basis: 100%;
}
@media screen and (min-width: 640px) {
  .profile-container {
    flex-basis: 50%;
  }
}
.profile-container a {
  color: inherit !important;
}
.profile-container img {
  width: 100%;
  padding-right: 3em;
  box-sizing: border-box;
}

.contact-wrapper {
  position: relative;
  top: 50%;
  width: 100%;
  display: flex;
  gap: 4rem;
}
.contact-wrapper:first-child {
  margin-left: 1rem;
}
@media screen and (min-width: 640px) {
  .contact-wrapper {
    top: 45%;
    width: 100%;
    gap: 2rem;
    flex-direction: row;
    justify-content: flex-end;
  }
  .contact-wrapper:first-child {
    margin-left: unset;
  }
}

.contact-container {
  display: flex;
  flex-direction: column;
}
.contact-container a {
  color: var(--color);
  text-decoration: none;
}
.contact-container a:hover {
  color: black;
}
.contact-container svg {
  width: 5vw;
  min-width: 50px;
  height: auto;
  stroke: var(--color);
  stroke-width: 2px;
  fill: transparent;
  margin-bottom: 1rem;
  transition: 0.2s;
}
.contact-container svg:hover {
  fill: var(--color);
}
@media screen and (min-width: 1536px) {
  .contact-container svg {
    margin-bottom: 2rem;
  }
}
@media screen and (min-width: 640px) {
  .contact-container {
    flex-basis: 40%;
    flex-grow: 0;
  }
}
@media screen and (min-width: 768px) {
  .contact-container {
    flex-basis: 30%;
    flex-grow: 0;
  }
}

footer {
  width: calc(100% - 2rem);
  position: absolute;
  bottom: 0;
  display: flex;
  align-items: end;
  justify-content: space-between;
}
footer div {
  display: flex;
}
footer h6:nth-child(2) {
  display: none;
}
@media screen and (min-width: 768px) {
  footer h6:nth-child(2) {
    display: block;
  }
}

.work-container {
  position: relative;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  align-items: end;
}
@media screen and (min-width: 768px) {
  .work-container {
    flex-direction: row;
  }
}

.work-element {
  position: relative;
  height: 15vh;
  width: 100%;
  /*display: flex;
  flex-direction: column;
  justify-content: space-between;*/
  text-decoration: none;
  color: black;
}
.work-element h3 {
  padding-right: 2rem;
  margin: 0;
  position: absolute;
  bottom: 0;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .work-element {
    height: 60vh;
    flex-basis: 20%;
    width: unset;
  }
}
.work-element:nth-child(1) {
  stroke: #8132f6;
}
.work-element:nth-child(2) {
  stroke: #007355;
}
.work-element:nth-child(3) {
  stroke: #9e7c55;
}
.work-element:nth-child(4) {
  stroke: #f41a42;
}
.work-element:nth-child(5) {
  stroke: #5c96d6;
}
.work-element:hover {
  color: #8132f6;
}
.work-element:hover:nth-child(1) svg {
  fill: #8132f6;
}
.work-element:hover:nth-child(2) svg {
  fill: #007355;
}
.work-element:hover:nth-child(3) svg {
  fill: #9e7c55;
}
.work-element:hover:nth-child(4) svg {
  fill: #f41a42;
}
.work-element:hover:nth-child(5) svg {
  fill: #5c96d6;
}

.work-element-background {
  position: relative;
  width: 100%;
  height: 80%;
  overflow: hidden;
}
.work-element-background svg {
  width: auto;
  height: 350%;
  margin: 0;
  white-space: nowrap;
  position: absolute;
  top: -70%;
  stroke-width: 2px;
  transition: 0.3s;
}
.work-element-background svg:first-child {
  animation: scroll-banner 200s infinite linear;
}
.work-element-background svg:last-child {
  animation: scroll-banner1 200s infinite linear;
  animation-delay: -200s;
}
@media screen and (min-width: 768px) {
  .work-element-background svg {
    height: 230%;
    top: -50%;
  }
}

.to-full-list-button {
  cursor: pointer;
  margin-top: 4rem;
  color: var(--color);
}
.to-full-list-button.list-visible::before {
  content: "–";
}
.to-full-list-button::before {
  content: "+";
}

.full-works-list {
  width: calc(80% - 1rem);
  margin-left: 1rem;
  display: block;
}
.full-works-list h3 {
  margin: 0.5em 0;
}
.full-works-list a:hover:nth-child(1n+1) {
  color: #8132f6;
}
.full-works-list a:hover:nth-child(2n+2) {
  color: #007355;
}
.full-works-list a:hover:nth-child(3n+3) {
  color: #9e7c55;
}
.full-works-list a:hover:nth-child(4n+4) {
  color: #f41a42;
}
.full-works-list a:hover:nth-child(5n+5) {
  color: #5c96d6;
}
.full-works-list.hidden {
  display: none;
}

@keyframes scroll-banner {
  0% {
    transform: translate(0, 0%);
  }
  100% {
    transform: translate(-100%, 0%);
  }
}
@keyframes scroll-banner1 {
  0% {
    transform: translate(100%, 0%);
  }
  100% {
    transform: translate(0%, 0%);
  }
}
.project-container {
  max-width: 800px;
  margin: auto;
  margin-top: 1rem;
  margin-bottom: 4rem;
  padding: 1rem;
}
@media screen and (min-width: 1024px) {
  .project-container {
    margin-top: 6rem;
    padding: unset;
    max-width: 900px;
  }
}
@media screen and (min-width: 1280px) {
  .project-container {
    max-width: 1100px;
  }
}
@media screen and (min-width: 1536px) {
  .project-container {
    max-width: 1500px;
  }
}
@media screen and (min-width: 2800px) {
  .project-container {
    max-width: 1500px;
  }
}
.project-container img {
  position: relative;
  width: 100%;
}

.project-back-button {
  position: absolute;
  top: 2rem;
  text-decoration: none;
  color: var(--color);
  display: flex;
  font-size: 0.9rem;
  gap: 0.2rem;
}
.project-back-button span {
  font-size: 1rem;
  transform: rotate(180deg);
}

.project-description {
  min-height: unset;
  display: flex;
  flex-direction: column;
  gap: 2rem;
}
.project-description .project-title {
  flex-basis: 40%;
}
.project-description .project-title h1 {
  margin: 0;
}
.project-description .project-extras * {
  font-size: 0.8rem;
}
.project-description article {
  flex-basis: 60%;
  padding-bottom: 2rem;
}
.project-description article .related-tags {
  color: var(--color);
  text-transform: uppercase;
}
.project-description article .related-tags p {
  font-size: 0.8em;
}
.project-description article p:first-child {
  margin-top: 0;
}
@media screen and (min-width: 768px) {
  .project-description {
    flex-direction: row;
  }
  .project-description article {
    padding-bottom: 4rem;
  }
}

.project-media {
  min-height: unset;
  padding-bottom: 3rem;
  z-index: 1;
}
.project-media .project-video {
  display: flex;
  justify-content: center;
  margin-bottom: 0.3rem;
}
.project-media iframe {
  aspect-ratio: 16/9;
  width: 100% !important;
}

.project-related-nav {
  width: 100%;
  min-height: unset;
  display: flex;
  justify-content: space-between;
  padding-top: 8rem;
  padding-bottom: 8rem;
}
.project-related-nav .related-nav-element {
  width: 50%;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}
.project-related-nav .related-nav-element h4,
.project-related-nav .related-nav-element h6 {
  margin: 0;
}
.project-related-nav .related-nav-element h6 {
  color: var(--color);
}
.project-related-nav .related-nav-element h4 {
  color: black;
}
.project-related-nav .related-nav-element h4:hover {
  color: var(--color);
}
.project-related-nav .related-nav-element a {
  text-decoration: none;
}
.project-related-nav .related-previous {
  text-align: left;
  align-items: flex-start;
}
.project-related-nav .related-previous h6 {
  padding-left: 1.5rem;
}
.project-related-nav .related-next {
  text-align: right;
  align-items: flex-end;
}
.project-related-nav .related-next h6 {
  padding-right: 1.5rem;
}

.project-player-overlay-wrapper {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  pointer-events: none;
}

.project-player-overlay {
  margin: 0 auto;
  height: 100%;
}

.project-player-overlay-fixed {
  position: fixed;
}

.player-progress-bar-container {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  pointer-events: all;
  opacity: 1;
  transition: 0.2s;
  cursor: pointer;
}
.player-progress-bar-container .player-progress-bar {
  width: 0;
  height: 1rem;
  background: var(--color);
}

@keyframes jump {
  0%, 100% {
    transform: translateY(0);
  }
  20% {
    transform: translateY(-10px);
  }
  40% {
    transform: translateY(0);
  }
  60% {
    transform: translateY(-5px);
  }
  80% {
    transform: translateY(0);
  }
}
.player-controls {
  position: relative;
  width: 4rem;
  padding-left: 1rem;
  pointer-events: all;
  margin-top: 40vh;
  cursor: pointer;
  animation: jump 1s ease-out 3; /* Apply the jump animation */
}
.player-controls svg {
  width: 100%;
  overflow: visible;
  stroke: var(--color);
  stroke-width: 2px;
}
.player-controls:hover svg {
  fill: var(--color);
}
@media screen and (min-width: 768px) {
  .player-controls {
    width: 5rem;
  }
}

.player-title {
  position: relative;
  height: 1.75rem;
  width: 100vw;
  left: calc((100% - 100vw) / 2);
  margin-top: 2rem;
  opacity: 1;
  transition: 0.2s;
}
.player-title p:nth-of-type(1) {
  animation: scroll-banner 5s infinite linear;
}
.player-title p:nth-of-type(2) {
  animation: scroll-banner1 5s infinite linear;
  animation-delay: -5s;
}
.player-title p {
  min-width: 100%;
  font-size: 3.8rem;
  position: absolute;
  margin: 0;
  line-height: 1em;
  white-space: nowrap;
  padding-right: 1rem;
  color: var(--color);
}

.player-progress-num {
  position: relative;
  padding-left: 1rem;
  opacity: 1;
  transition: 0.2s;
}
.player-progress-num p,
.player-progress-num span {
  font-size: 2.3rem;
  color: var(--color);
}

.player-hidden {
  visibility: hidden;
  opacity: 0;
}

.controls-hidden {
  display: none;
}

/*# sourceMappingURL=main.css.map */