@font-face {
  font-family: "moderat";
  src: url("./fonts/Moderat-Regular.woff2") format("woff2"), url("./fonts/Moderat-Regular.woff") format("woff");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "moderat-light";
  src: url("./fonts/Moderat-Light.woff2") format("woff2"), url("./fonts/Moderat-Light.woff") format("woff");
  font-weight: normal;
  font-style: normal;
}
html,
body {
  font-family: moderat, sans-serif;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  overflow-x: hidden;
}

body {
  background-color: #f0f5e9;
}

.pin-spacer {
  pointer-events: none;
}

.bg {
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 0;
}

section {
  height: 100vh;
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 6;
}
section .text-wrapper {
  max-width: min(76%, 1300px);
  margin-bottom: 3%;
  z-index: 6;
  pointer-events: none;
}
@media (max-width: 1024px) {
  section .text-wrapper {
    max-width: min(86%, 1300px);
  }
}
@media (max-width: 767px) {
  section .text-wrapper {
    max-width: calc(100% - 1.2rem);
    padding-inline: 1.6rem;
  }
}
section h1,
section h2 {
  margin: 0;
  font-family: moderat-light, sans-serif;
  font-weight: normal;
  line-height: 1;
  pointer-events: none;
  user-select: none;
}
section h1 {
  font-size: min(10vh, 6vw);
}
@media (max-width: 1024px) {
  section h1 {
    font-size: min(13vh, 8vw);
  }
}
@media (max-width: 767px) {
  section h1 {
    font-size: min(16vh, 10vw);
  }
}
section h2 {
  font-size: min(6vh, 3vw);
}
@media (max-width: 1024px) {
  section h2 {
    font-size: min(10vh, 5.5vw);
  }
}
@media (max-width: 767px) {
  section h2 {
    font-size: min(14vh, 8vw);
  }
}
section p {
  font-family: moderat-light, sans-serif;
  font-size: min(5vh, 3vw);
}
@media (max-width: 1024px) {
  section p {
    font-size: min(7.5vh, 4.5vw);
  }
}
@media (max-width: 767px) {
  section p {
    font-size: min(10vh, 6vw);
  }
}
section p.body-text {
  font-size: min(4vh, 2vw);
}
@media (max-width: 1024px) {
  section p.body-text {
    font-size: 1.8rem;
  }
}
@media (max-width: 767px) {
  section p.body-text {
    font-size: 1rem;
  }
}
section p.multi-column {
  column-count: 2;
}
section h1 + p {
  margin-top: 0.5rem;
}

.wrapper {
  position: fixed;
  top: 0;
  left: 0;
}
.wrapper .circle {
  position: fixed;
  top: -9999px;
  left: -9999px;
  visibility: hidden;
  width: 18vw;
  height: 18vw;
  border-radius: 50%;
}
@media (orientation: portrait) {
  .wrapper .circle {
    width: 28vh;
    height: 28vh;
  }
}
.wrapper h2 {
  width: max-content;
  position: absolute;
  transform: translate(-50%, calc(5.4vw - 2rem));
  text-transform: uppercase;
  font-size: 1.8vw;
  font-family: moderat-light, sans-serif;
  font-weight: 400;
  line-height: 1.1;
  padding-top: 2rem;
  cursor: pointer;
  visibility: hidden;
}
@media (max-width: 1024px) {
  .wrapper h2 {
    transform: translate(-50%, 3rem);
    font-size: 1.6rem;
  }
}
@media (max-width: 767px) {
  .wrapper h2 {
    transform: translate(-50%, 1.6rem);
    font-size: 1.2rem;
  }
}
.wrapper .circular-wrapper {
  opacity: 0;
  position: absolute;
  width: 160px;
  height: 160px;
  display: flex;
  justify-content: center;
  transform: translate(-50%, -50%);
}
.wrapper .circular-wrapper .circular {
  position: absolute;
  margin: 0;
  font-size: 1vw;
}
@media (max-width: 1024px) {
  .wrapper .circular-wrapper .circular {
    font-size: 0.9rem;
  }
}
@media (max-width: 767px) {
  .wrapper .circular-wrapper .circular {
    font-size: 0.6rem;
  }
}
.wrapper#roadtrip {
  z-index: 2;
}
.wrapper#roadtrip h2 span {
  color: #4A94FF;
}
.wrapper#workbook {
  z-index: 4;
}
.wrapper#workbook .circle {
  background: #F99D27;
  border-radius: 0;
  height: 21.6vw;
  width: 14.4vw;
}
.wrapper#workbook h2 span {
  color: #F99D27;
}
.wrapper#toolbox {
  z-index: 1;
}
.wrapper#toolbox .circle {
  background: #A85868;
  border-radius: 0;
  height: 27vw;
  width: 14.4vw;
}
.wrapper#toolbox h2 span {
  color: #A85868;
}
.wrapper#camp {
  z-index: 5;
}
.wrapper#camp .circle {
  background: #22FFAA;
  border-radius: 0;
  clip-path: polygon(0 0, 0% 100%, 100% 100%);
}
.wrapper#camp h2 span {
  color: #22FFAA;
}

.wrapper {
  width: 0;
  height: 0;
}
.wrapper svg {
  width: 32vw !important;
  height: auto !important;
}
@media (max-width: 1024px) {
  .wrapper svg {
    width: 56vw !important;
  }
}
@media (max-width: 767px) {
  .wrapper svg {
    width: 76vw !important;
  }
}

#car,
#tires {
  cursor: pointer;
}

#camp svg,
#workbook svg,
#toolbox svg {
  pointer-events: none;
}
#camp svg > g > g,
#workbook svg > g > g,
#toolbox svg > g > g {
  pointer-events: initial;
  cursor: pointer;
}

#roadtrip svg {
  pointer-events: none;
}
#roadtrip svg > g > g > g {
  pointer-events: initial;
  cursor: pointer;
}

nav.icons {
  display: flex;
  gap: 1rem;
  position: fixed;
  top: 1.4rem;
  right: 2rem;
}
nav.icons img {
  height: 3rem;
}
@media (max-width: 767px) {
  nav.icons img {
    height: 1.6rem;
  }
}
@media (max-width: 767px) {
  nav.icons {
    top: 0.6rem;
    right: 0.6rem;
    gap: 0.6rem;
  }
}

.subpage section {
  visibility: hidden;
}
.subpage section:nth-child(even) {
  background: rgba(0, 0, 0, 0.05);
}

header,
footer {
  padding: 2rem;
  padding-bottom: 1.4rem;
  padding-top: 1.4rem;
}
@media (max-width: 767px) {
  header,
  footer {
    padding: 0.6rem;
    padding-bottom: 0.6rem;
    padding-top: 0.6rem;
  }
}

header {
  position: fixed;
  top: 0;
  right: 0;
}

footer {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  box-sizing: border-box;
  display: flex;
  z-index: 8;
  align-items: flex-end;
}
footer.reverse {
  flex-direction: row-reverse;
}
@media (max-width: 767px) {
  footer.reverse {
    flex-direction: column-reverse;
    align-items: flex-start;
  }
  footer.reverse #logo {
    margin-bottom: 1rem;
  }
}
footer #logo {
  width: 200px;
  overflow: visible;
}
@media (max-width: 1024px) {
  footer #logo {
    height: 4rem;
    width: auto;
  }
}
@media (max-width: 767px) {
  footer #logo {
    height: 2rem;
    width: auto;
  }
}
footer nav.bottom {
  bottom: 2rem;
  width: 100%;
  display: flex;
  justify-content: center;
  gap: 1rem;
}
@media (max-width: 767px) {
  footer nav.bottom {
    flex-direction: column;
    align-items: flex-end;
    flex-wrap: wrap;
    gap: 0.2rem;
    max-height: 60px;
    font-size: 0.8rem;
  }
}
footer nav.bottom a {
  color: black;
  visibility: hidden;
}

.sayhi-wrapper {
  opacity: 0;
  font-size: 1vw;
  color: black;
}
@media (max-width: 1024px) {
  .sayhi-wrapper {
    font-size: 0.9rem;
  }
}
@media (max-width: 767px) {
  .sayhi-wrapper {
    font-size: 0.6rem;
  }
}

#ipsum p {
  display: none;
}

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