/* Full-Width Grid */
.col1 {
  width: 8.3333333333vw;
}

.col2 {
  width: 16.6666666667vw;
}

.col3 {
  width: 25vw;
}

.col4 {
  width: 33.3333333333vw;
}

.col5 {
  width: 41.6666666667vw;
}

.col6 {
  width: 50vw;
}

.col7 {
  width: 58.3333333333vw;
}

.col8 {
  width: 66.6666666667vw;
}

.col9 {
  width: 75vw;
}

.col10 {
  width: 83.3333333333vw;
}

.col11 {
  width: 91.6666666667vw;
}

.col12 {
  width: 100vw;
}

/* Full-Width Offsets */
.off1 {
  margin-left: 8.3333333333vw;
}

.off2 {
  margin-left: 16.6666666667vw;
}

.off3 {
  margin-left: 25vw;
}

.off4 {
  margin-left: 33.3333333333vw;
}

.off5 {
  margin-left: 41.6666666667vw;
}

.off6 {
  margin-left: 50vw;
}

.off7 {
  margin-left: 58.3333333333vw;
}

.off8 {
  margin-left: 66.6666666667vw;
}

.off9 {
  margin-left: 75vw;
}

.off10 {
  margin-left: 83.3333333333vw;
}

.off11 {
  margin-left: 91.6666666667vw;
}

/* Relative Width Grid */
.w1 {
  width: 8.3333333333%;
}

.w2 {
  width: 16.6666666667%;
}

.w3 {
  width: 25%;
}

.w4 {
  width: 33.3333333333%;
}

.w5 {
  width: 41.6666666667%;
}

.w6 {
  width: 50%;
}

.w7 {
  width: 58.3333333333%;
}

.w8 {
  width: 66.6666666667%;
}

.w9 {
  width: 75%;
}

.w10 {
  width: 83.3333333333%;
}

.w11 {
  width: 91.6666666667%;
}

.full-width {
  width: 100%;
}

a {
  color: #003AFF;
  text-decoration: underline;
}
a:hover {
  color: #000000;
}
a.svg-art {
  fill: #000000;
  text-decoration: none;
}
a.svg-art:hover {
  fill: #003AFF;
}

u {
  text-decoration: none;
  position: relative;
}
u::after {
  content: "";
  border-bottom: 2px solid #000000;
  position: absolute;
  bottom: 10%;
  left: 0;
  width: 100%;
}

p {
  margin-top: 0;
  margin-bottom: 1rem;
  font-family: "Helvetica Neue", "Roboto", sans-serif;
  font-size: 1.5rem;
  color: #000000;
  font-weight: 300;
  line-height: 1.15;
}

h1, h2, h3, h4, h5, h6 {
  margin: 0;
}

.section-header {
  font-family: "Helvetica Neue", "Roboto", sans-serif;
  font-size: 1rem;
  color: #000000;
  line-height: 1;
  font-size: 0.85rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  position: relative;
  z-index: 5;
}
@media (min-width: 768px) {
  .section-header {
    font-size: 1.125rem;
  }
}
@media (min-width: 768px) {
  .section-header {
    font-size: 0.85rem;
  }
}

figure {
  margin: 0;
  padding: 0;
}

img {
  width: 100%;
  height: 100%;
}

.flex {
  display: flex;
}

.flex-column {
  display: flex;
  flex-direction: column;
}

.flex-row {
  display: flex;
  flex-direction: row;
}

.sr-only, .slick-sr-only {
  position: absolute;
  left: -10000px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

main {
  min-height: 3.5rem;
}
main .mobile-spacer {
  height: 3rem;
}
@media (min-width: 768px) {
  main .mobile-spacer {
    display: none;
  }
}

.nothing-to-see-here {
  height: 100vh;
  display: flex;
  flex-direction: column;
}
.nothing-to-see-here main {
  height: 100vh;
}

.filler {
  padding: 10rem 3rem;
}
.filler h1 {
  font-family: "Hedvig Letters Serif", sans-serif;
  font-size: 1.8rem;
  color: #000000;
  font-weight: normal;
  line-height: 1.3;
  font-size: 5rem;
}
@media (min-width: 768px) {
  .filler h1 {
    font-size: 2rem;
  }
}

.carousel-nav {
  display: grid;
  column-gap: 1rem;
  font-family: "Hedvig Letters Serif", sans-serif;
  font-size: 2.45rem;
  color: #000000;
  font-weight: normal;
  line-height: 0.8;
}

.slick-arrow {
  display: grid;
  column-gap: 0.5rem;
}
.slick-arrow > * {
  font-family: "Hedvig Letters Serif", sans-serif;
  font-size: 2.45rem;
  color: #000000;
  font-weight: normal;
  line-height: 0.8;
}
.slick-arrow button {
  background: none;
  border: none;
}
.slick-arrow button:hover {
  color: #003AFF;
}
.slick-arrow button:visited {
  color: #000000;
  background-color: unset;
}

.custom-prev-container {
  grid-area: prev;
  text-align: right;
  grid-template-areas: "number arrow";
  grid-template-columns: 1fr max-content;
}
.custom-prev-container .featured-slide-number {
  grid-area: number;
  text-align: left;
}
.custom-prev-container .slick-prev {
  font-family: "Hedvig Letters Serif", sans-serif;
  font-size: 2.45rem;
  color: #000000;
  font-weight: normal;
  line-height: 0.8;
  padding: 0;
  grid-area: arrow;
}

.custom-next-container {
  grid-area: next;
  grid-template-areas: "arrow number";
  grid-template-columns: max-content 1fr;
}
.custom-next-container .featured-slide-number {
  grid-area: number;
  text-align: left;
}
.custom-next-container .slick-next {
  font-family: "Hedvig Letters Serif", sans-serif;
  font-size: 2.45rem;
  color: #000000;
  font-weight: normal;
  line-height: 0.8;
  padding: 0;
  grid-area: arrow;
}

.featured-prev-container,
.family-prev-container {
  grid-area: prev;
  text-align: right;
}
.featured-prev-container button,
.family-prev-container button {
  display: grid;
  grid-template-areas: "number arrow";
  grid-template-columns: 1fr max-content;
  padding: 0;
  column-gap: 0.5rem;
}
.featured-prev-container button .featured-slide-number,
.family-prev-container button .featured-slide-number {
  grid-area: number;
  text-align: left;
}
.featured-prev-container button .slick-prev,
.family-prev-container button .slick-prev {
  font-family: "Hedvig Letters Serif", sans-serif;
  font-size: 2.45rem;
  color: #000000;
  font-weight: normal;
  line-height: 0.8;
  padding: 0;
  grid-area: arrow;
}

.featured-next-container,
.family-next-container {
  grid-area: next;
}
.featured-next-container button,
.family-next-container button {
  display: grid;
  grid-template-areas: "arrow number";
  grid-template-columns: max-content 1fr;
  padding: 0;
  column-gap: 0.5rem;
}
.featured-next-container button .featured-slide-number,
.family-next-container button .featured-slide-number {
  grid-area: number;
  text-align: left;
}
.featured-next-container button .slick-next,
.family-next-container button .slick-next {
  font-family: "Hedvig Letters Serif", sans-serif;
  font-size: 2.45rem;
  color: #000000;
  font-weight: normal;
  line-height: 0.8;
  padding: 0;
  grid-area: arrow;
}

body {
  background-color: #F6F6F1;
  margin: 0;
  padding: 0;
  /* Mobile Menu Styles */
  /* Hide the checkbox but keep it accessible */
  /* Screen reader only text */
  /* Header container for flexbox layout */
  /* Mobile hamburger button */
  /* Desktop navigation - visible by default */
  /* Mobile navigation overlay */
  /* Show mobile nav when checkbox is checked */
  /* Logo visibility controls */
  /* Mobile logo: show on all pages, all screen sizes */
  /* Desktop logo: hide by default */
  /* Desktop breakpoint */
  /* Close button styles */
  /* Show close button when menu is open */
  /* Mobile styles */
}
body.template-home {
  padding-top: 0;
}
@media (min-width: 768px) {
  body.template-home {
    padding-top: 0;
  }
}
body .mobile-menu-checkbox {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
body .sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
body .header-container {
  display: flex;
  justify-content: flex-end;
  align-items: center;
}
body.template-home .header-container {
  justify-content: space-between;
}
body .mobile-menu-button {
  display: none;
  flex-direction: column;
  padding: 0.5rem 1rem 0.5rem 0;
  z-index: 1001;
  position: relative;
  transition: border-color 0.2s ease;
}
body .mobile-menu-button:focus {
  outline: 2px solid #005fcc;
  outline-offset: 2px;
}
body .mobile-menu-button svg {
  width: 2rem;
  height: 2rem;
  fill: #000000;
}
body .desktop-nav {
  display: block;
}
body .mobile-nav {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: auto;
  background-color: rgba(245, 245, 245, 0.9);
  z-index: 1000;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease;
  transform: translateY(-100%);
}
body .mobile-menu-checkbox:checked ~ .mobile-nav {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
body .mobile-logo {
  display: block;
}
body .desktop-logo {
  display: none;
}
@media (min-width: 768px) {
  body {
    /* Hide mobile logo on desktop */
    /* Show desktop logo only on homepage */
    /* Desktop logo stays hidden on non-homepage */
  }
  body .mobile-logo {
    display: none; /* test */
  }
  body.template-home .desktop-logo {
    display: block;
    height: 2rem;
  }
}
body .mobile-nav-content {
  padding: 3rem 2rem;
  height: 100%;
  overflow-y: auto;
}
body .mobile-nav-content .footer-nav {
  list-style: none;
  margin: 0;
  padding: 0;
}
body .mobile-nav-content .footer-nav li {
  font-family: "Helvetica Neue", "Roboto", sans-serif;
  font-size: 1rem;
  color: #000000;
  font-weight: 700;
  line-height: 1.1;
  text-transform: uppercase;
  text-decoration: none;
}
@media (min-width: 768px) {
  body .mobile-nav-content .footer-nav li {
    font-size: 1rem;
  }
}
body .mobile-nav-content .footer-nav li a {
  color: #000000;
  text-decoration: none;
}
body .mobile-nav-content .footer-nav li a:hover {
  color: #003AFF;
}
body .mobile-close-button {
  display: none;
  position: absolute;
  top: 0.1rem;
  right: 1.6rem;
  font-size: 2.5rem;
  line-height: 1;
  background: none;
}
body .mobile-close-button:focus {
  outline: 2px solid #005fcc;
  outline-offset: 2px;
}
body .mobile-close-button:hover {
  color: #003AFF;
}
body .mobile-menu-checkbox:checked ~ .mobile-nav .mobile-close-button {
  display: block;
}
@media (max-width: 768px) {
  body .mobile-menu-button {
    display: flex;
  }
  body .desktop-nav {
    display: none;
  }
  body .mobile-nav {
    display: block;
  }
  body .mobile-nav .main-nav {
    flex-direction: column;
    align-items: flex-start;
    height: auto;
  }
  body .mobile-nav .main-nav a {
    display: block;
    margin-right: 0;
    margin-bottom: 0.2rem;
    width: 100%;
  }
  body .mobile-nav .main-nav a:hover {
    color: #003AFF;
    text-decoration: underline;
  }
}
body .fury-header {
  position: fixed;
  width: 100%;
  height: 3rem;
  top: 0;
  left: 0;
  z-index: 5;
}
body .fury-header .site-logo {
  position: relative;
  width: 100%;
  text-align: center;
  padding-left: 3.1rem;
}
body .fury-header .site-logo svg, body .fury-header .site-logo img {
  height: 2rem;
}
body .fury-header h1 {
  font-family: "Hedvig Letters Serif", sans-serif;
  font-size: 2.5rem;
  color: #000000;
  font-weight: normal;
  line-height: 1.1;
  font-size: 3rem;
  text-decoration: none;
  font-weight: 700;
}
body .fury-header h1 > a:hover {
  color: #003AFF;
}
body .fury-header .desktop-nav .main-nav {
  justify-content: end;
  align-items: center;
  height: 2rem;
}
body .fury-header .desktop-nav .main-nav a {
  font-family: "Helvetica Neue", "Roboto", sans-serif;
  font-size: 1rem;
  color: #000000;
  font-weight: 700;
  line-height: 1.1;
  text-transform: uppercase;
  text-decoration: none;
  margin-right: 1rem;
}
@media (min-width: 768px) {
  body .fury-header .desktop-nav .main-nav a {
    font-size: 1rem;
  }
}
body .fury-header .desktop-nav .main-nav a:hover {
  color: #003AFF;
  text-decoration: underline;
}
body .fury-header .desktop-nav .main-nav a > * {
  height: 1.5rem;
  filter: drop-shadow(0 0 0.05rem #F6F6F1);
}
body .fury-header .desktop-nav .main-nav a.fury-icon:not(:last-child) {
  margin-right: 1rem;
}
body .fury-header .desktop-nav .main-nav a.fury-icon > * {
  height: 1.9rem;
  margin-top: -0.25rem;
}
body .fury-header .desktop-nav .main-nav a > svg:hover {
  fill: #003AFF;
  filter: drop-shadow(0 0 0.005rem #F6F6F1);
}
body .fury-header .desktop-nav .main-nav a:last-child {
  margin-right: 0;
}
@media (min-width: 768px) {
  body .fury-header {
    overflow: visible;
    position: absolute;
    top: 0;
    left: 0;
    height: unset;
    z-index: 5;
    padding: 2.5rem 2.5rem 0;
    width: calc(100% - 5rem);
  }
  body .fury-header .site-logo {
    z-index: 10;
    position: relative;
    padding-left: 0;
  }
  body .fury-header .site-logo svg, body .fury-header .site-logo img {
    position: absolute;
    height: 15rem;
    left: 1rem;
    top: -2.5rem;
    filter: drop-shadow(0 0 0.05rem #F6F6F1);
  }
  body .fury-header h1 {
    font-family: "Hedvig Letters Serif", sans-serif;
    font-size: 2.5rem;
    color: #000000;
    font-weight: normal;
    line-height: 1.1;
    filter: drop-shadow(0 0 0.05rem #F6F6F1);
    font-size: 5rem;
    text-decoration: none;
    font-weight: 700;
  }
  body .fury-header h1 > a:hover {
    color: #003AFF;
  }
  body .fury-header .main-nav a {
    margin-right: 1.2rem;
  }
  body .fury-header .main-nav a > * {
    height: 1.7rem;
  }
  body .fury-header .main-nav a.fury-icon {
    margin-left: -0.3rem;
  }
  body .fury-header .main-nav a.fury-icon:not(:last-child) {
    margin-right: 0.9rem;
  }
  body .fury-header .main-nav a.fury-icon > * {
    height: 2.1rem;
    margin-top: -0.25rem;
  }
}
body section.featured {
  position: relative;
}
body section.featured .featured-caro .featured-project-wrap .featured-project .featured-art.home-hero .carousel-art {
  height: 50vh;
}
body section.featured .featured-caro .featured-project-wrap .featured-project .featured-art.home-hero .carousel-art picture > * {
  object-fit: cover;
}
body section.featured .featured-caro .featured-project-wrap .featured-project .featured-art.home-hero .desktop.has-mobile-preview {
  display: none;
}
body section.featured .featured-caro .featured-project-wrap .featured-project .featured-content {
  margin-right: 2rem;
  margin-left: 2rem;
  margin-top: 4.3rem;
  margin-bottom: 2.5rem;
}
@media (min-width: 768px) {
  body section.featured .featured-caro .featured-project-wrap .featured-project .featured-content {
    margin-right: 3rem;
  }
}
@media (min-width: 768px) {
  body section.featured .featured-caro .featured-project-wrap .featured-project .featured-content {
    margin-left: 3rem;
  }
}
body section.featured .featured-caro .featured-project-wrap .featured-project .featured-content .featured-header {
  font-family: "Helvetica Neue", "Roboto", sans-serif;
  font-size: 1.5rem;
  color: #000000;
  font-weight: 300;
  line-height: 1.15;
  margin-bottom: 0.35rem;
}
body section.featured .featured-caro .featured-project-wrap .featured-project .featured-content .featured-text > *:last-child {
  margin-bottom: 0;
}
body section.featured .featured-nav {
  position: absolute;
  top: 50vh;
  left: 0;
  z-index: 2;
  padding-top: 1rem;
  padding-bottom: 1rem;
  padding-left: 1.875rem;
  grid-template-areas: "prev next";
}
@media (min-width: 768px) {
  body section.featured .featured-caro .featured-project-wrap .featured-project .featured-art.home-hero .carousel-art {
    height: 70vh;
  }
  body section.featured .featured-nav {
    top: 70vh;
    padding-left: 2.875rem;
  }
}
@media (min-width: 1024px) {
  body section.featured .featured-caro .featured-project-wrap .featured-project {
    display: grid;
    grid-template-areas: "art art art art" "spacer nav content afterspacer" "collabs collabs collabs collabs";
    grid-template-columns: 3rem calc(16.6666666667vw + 3rem) 1fr 3rem;
    row-gap: 1rem;
    grid-template-rows: auto 1fr auto;
  }
  body section.featured .featured-caro .featured-project-wrap .featured-project .featured-art {
    grid-area: art;
  }
  body section.featured .featured-caro .featured-project-wrap .featured-project .featured-art.home-hero .carousel-art {
    height: calc(100vh - 2rem - 2.3rem);
  }
  body section.featured .featured-caro .featured-project-wrap .featured-project .featured-art.home-hero .mobile {
    display: none;
  }
  body section.featured .featured-caro .featured-project-wrap .featured-project .featured-art.home-hero .desktop.has-mobile-preview {
    display: block;
  }
  body section.featured .featured-caro .featured-project-wrap .featured-project .featured-content {
    grid-area: content;
    display: grid;
    grid-template-areas: "name stuff";
    grid-template-columns: calc(25% - 2rem + (100% - 4 * (25% - 2rem)) / 3) 1fr;
    margin: 0 0 3rem;
  }
  body section.featured .featured-caro .featured-project-wrap .featured-project .featured-content .featured-header {
    grid-area: name;
    line-height: 1.05;
    margin-bottom: 0;
  }
  body section.featured .featured-caro .featured-project-wrap .featured-project .featured-content .featuered-text {
    grid-area: stuff;
  }
  body section.featured .featured-caro .featured-project-wrap .featured-project .project-credits {
    grid-area: collabs;
  }
  body section.featured .featured-nav {
    margin: 0;
    top: calc(100vh - 2rem - 2.3rem);
    padding-left: 2.875rem;
    width: calc(16.6666666667vw + 3rem);
    background-color: #F6F6F1;
    grid-template-columns: max-content max-content 1fr;
    grid-template-areas: "prev next spacer";
  }
}
body section.big-type {
  margin-right: 2rem;
  margin-left: 2rem;
  margin-bottom: 2.5rem;
  padding-top: 0.5rem;
  border-top: 1px solid #000000;
}
@media (min-width: 768px) {
  body section.big-type {
    margin-right: 3rem;
  }
}
@media (min-width: 768px) {
  body section.big-type {
    margin-left: 3rem;
  }
}
body section.big-type h2 {
  margin-bottom: 2rem;
}
body section.big-type .main-text p {
  font-family: "Hedvig Letters Serif", sans-serif;
  font-size: 1.8rem;
  color: #000000;
  font-weight: normal;
  line-height: 1.3;
}
@media (min-width: 768px) {
  body section.big-type .main-text p {
    font-size: 2rem;
  }
}
@media (min-width: 768px) {
  body section.big-type {
    padding-bottom: 0;
  }
  body section.big-type .main-text p {
    padding-left: calc(8.3333333333vw - 3rem);
    padding-right: calc(8.3333333333vw - 3rem);
  }
}
body section.about {
  padding-bottom: 0;
  margin-bottom: 2.5rem;
}
body section.about h1, body section.about h2 {
  margin-bottom: 2rem;
}
body section.about .fury-doodle.mobile-doodle {
  padding: 2rem 2rem 0;
}
body section.about .fury-doodle.desktop-doodle {
  display: none;
}
@media (min-width: 768px) {
  body section.about {
    margin-bottom: -5.25rem;
  }
  body section.about .fury-doodle {
    display: flex;
    justify-content: end;
  }
  body section.about .fury-doodle figure {
    position: relative;
    width: fit-content;
  }
  body section.about .fury-doodle figure > * {
    position: relative;
    height: 23rem;
    width: auto;
    padding-bottom: 0.5rem;
    z-index: 3;
  }
  body section.about .fury-doodle figure::after {
    content: "";
    position: absolute;
    background-color: #F6F6F1;
    width: 72.35%;
    bottom: 0;
    right: 0;
    height: 3rem;
    z-index: 2;
  }
  body section.about .fury-doodle.mobile-doodle {
    display: none;
  }
  body section.about .fury-doodle.desktop-doodle {
    display: flex;
  }
}
body section.graphic {
  margin-right: 2rem;
  margin-left: 2rem;
  margin-top: 2rem;
  margin-bottom: 2.5rem;
  padding-top: 0.5rem;
  border-top: 1px solid #000000;
}
@media (min-width: 768px) {
  body section.graphic {
    margin-right: 3rem;
  }
}
@media (min-width: 768px) {
  body section.graphic {
    margin-left: 3rem;
  }
}
@media (min-width: 768px) {
  body section.graphic {
    margin-top: 3rem;
  }
}
body section.graphic h2 {
  margin-bottom: 2rem;
}
body section.graphic .process-caro-wrap .process-caro {
  --gutterpad: 2rem;
  --gutter: calc(var(--gutterpad) * 2);
  --carowidth: calc(100% + var(--gutter));
  margin-left: calc(var(--gutterpad) * -1);
  margin-right: calc(var(--gutterpad) * -1);
  width: var(--carowidth);
  display: grid;
  grid-template-areas: "prev next" "image image";
  grid-template-columns: calc(50% + 1rem) calc(50% - 1rem);
}
body section.graphic .process-caro-wrap .process-caro .slick-list {
  grid-area: image;
}
body section.graphic .process-caro-wrap .process-caro .slick-list .slick-track {
  background-image: var(--lineart);
  background-repeat: no-repeat;
  background-size: var(--mobile-full-lineart-width) auto;
  background-position-x: calc(var(--mobile-step-width) - var(--mobile-step-width) * var(--item));
}
body section.graphic .process-caro-wrap .process-caro .slick-arrow > * {
  font-family: "Helvetica Neue", "Roboto", sans-serif;
  font-size: 1.25rem;
  color: #000000;
  line-height: 1.1;
  font-weight: 300;
  text-transform: uppercase;
}
body section.graphic .process-caro-wrap .process-caro .slick-arrow > *.slide-total {
  display: none;
}
body section.graphic .process-caro-wrap .process-caro .slick-arrow button {
  padding-bottom: 0.25rem;
}
body section.graphic .process-caro-wrap .process-caro .slick-arrow.slick-disabled button, body section.graphic .process-caro-wrap .process-caro .slick-arrow.slick-disabled button:hover, body section.graphic .process-caro-wrap .process-caro .slick-arrow.slick-disabled button:visited {
  color: #F6F6F1;
  background-color: unset;
}
body section.graphic .process-caro-wrap .process-caro .custom-prev-container {
  display: grid;
  grid-template-areas: "arrow number";
  gap: 0;
  align-items: center;
  grid-template-columns: 1fr 2rem;
}
body section.graphic .process-caro-wrap .process-caro .custom-prev-container button {
  text-align: right;
}
body section.graphic .process-caro-wrap .process-caro .custom-prev-container .slide-number {
  text-align: center;
}
body section.graphic .process-caro-wrap .process-caro .custom-next-container {
  display: block;
}
body section.graphic .process-caro-wrap .process-caro .step-wrap {
  --artDepth: calc(85% * var(--steps) / var(--ratio));
}
body section.graphic .process-caro-wrap .process-caro .step-wrap .step-header {
  padding-left: var(--gutterpad);
  padding-right: var(--gutterpad);
}
body section.graphic .process-caro-wrap .process-caro .step-wrap .step-header .step-number {
  font-family: "Helvetica Neue", "Roboto", sans-serif;
  font-size: 1.25rem;
  color: #000000;
  line-height: 1.1;
  font-weight: 300;
  text-transform: uppercase;
  text-align: center;
}
body section.graphic .process-caro-wrap .process-caro .step-wrap .step-header .step-label {
  font-family: "Helvetica Neue", "Roboto", sans-serif;
  font-size: 1.25rem;
  color: #000000;
  line-height: 1.1;
  font-weight: 300;
  text-transform: uppercase;
  text-align: center;
}
body section.graphic .process-caro-wrap .process-caro .step-wrap .step-description {
  --mobile-step-width: 100vw;
  --mobile-full-lineart-width: calc(100vw * var(--steps));
  padding-left: var(--gutterpad);
  padding-right: var(--gutterpad);
  padding-top: var(--artDepth);
}
body section.graphic .process-caro-wrap .process-caro .step-wrap .step-description > *:last-child {
  margin-bottom: 0;
}
body section.graphic .process-caro-wrap .process-caro .step-wrap .step-description > * {
  font-family: "Helvetica Neue", "Roboto", sans-serif;
  font-size: 1.25rem;
  color: #000000;
  line-height: 1.29;
  font-weight: 300;
}
@media (min-width: 768px) {
  body section.graphic .process-caro-wrap .process-caro .step-wrap .step-description > * {
    font-size: 1rem;
  }
}
@media (min-width: 768px) {
  body section.graphic {
    margin-bottom: 4rem;
  }
  body section.graphic .process-caro-wrap {
    margin-left: -3rem;
    margin-right: -3rem;
    background-image: var(--lineart);
    background-repeat: no-repeat;
    background-position-y: 1rem;
    padding-left: 3rem;
    padding-right: 3rem;
  }
  body section.graphic .process-caro-wrap .process-caro {
    display: flex;
    gap: 0;
  }
  body section.graphic .process-caro-wrap .process-caro .step-wrap {
    width: calc(100% / var(--steps));
    display: flex;
    flex-direction: column;
  }
  body section.graphic .process-caro-wrap .process-caro .step-wrap .step-header {
    height: 3.5rem;
    margin-right: 0.4rem;
  }
  body section.graphic .process-caro-wrap .process-caro .step-wrap .step-description {
    border-right: 1px solid #000000;
    background-image: none;
    padding-left: calc(var(--gutterpad) / 2);
    padding-right: calc(var(--gutterpad) / 2);
    flex: 1;
  }
  body section.graphic .process-caro-wrap .process-caro .step-wrap:last-child .step-description {
    border: none;
  }
}
@media (min-width: 1024px) {
  body section.graphic .process-caro-wrap .process-caro .step-wrap .step-description {
    padding-left: var(--gutterpad);
    padding-right: var(--gutterpad);
  }
}
body section.family .family-member {
  display: flex;
  flex-direction: column;
}
body section.family .family-member .info {
  order: 2;
  padding-right: 2rem;
  padding-left: 2rem;
  padding-bottom: 2.5rem;
  padding-top: 1rem;
  display: grid;
  grid-template-areas: "nav nav" "fam famicon" "origin famicon" "meat meat";
  grid-template-rows: auto auto 1fr auto;
}
@media (min-width: 768px) {
  body section.family .family-member .info {
    padding-right: 3rem;
  }
}
@media (min-width: 768px) {
  body section.family .family-member .info {
    padding-left: 3rem;
  }
}
body section.family .family-member .info h2 {
  grid-area: fam;
  margin: 0 0 0.25rem;
}
body section.family .family-member .info .family-icon {
  grid-area: famicon;
  width: 1.7rem;
  height: 1.7rem;
  justify-self: end;
}
body section.family .family-member .info .main-text {
  grid-area: meat;
  padding-top: 2rem;
}
body section.family .family-member .info .main-text > *:last-child {
  margin-bottom: 0;
}
body section.family .family-member .info .origin {
  grid-area: origin;
  font-family: "Helvetica Neue", "Roboto", sans-serif;
  font-size: 1rem;
  color: #000000;
  font-weight: normal;
  line-height: 1.2;
  text-transform: uppercase;
  font-weight: 700;
}
@media (min-width: 768px) {
  body section.family .family-member .info .origin {
    font-size: 0.825rem;
  }
}
body section.family .family-member .info .family-nav {
  grid-area: nav;
  align-self: end;
  margin-bottom: 0.5rem;
  grid-template-columns: max-content max-content 1fr;
  grid-template-areas: "prev next spacer";
}
body section.family .family-member .art {
  order: 1;
  aspect-ratio: 1/1;
  border-top: 1px solid #000000;
}
body section.family .family-member .art figure {
  width: 100%;
  height: 100%;
}
body section.family .family-member .art figure > * {
  object-fit: cover;
}
body section.family .family-member .art video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media (min-width: 768px) {
  body section.family {
    padding-top: 2rem;
    padding-left: 2rem;
    padding-right: 2rem;
    margin-bottom: 6rem;
  }
}
@media (min-width: 768px) and (min-width: 768px) {
  body section.family {
    padding-top: 3rem;
  }
}
@media (min-width: 768px) and (min-width: 768px) {
  body section.family {
    padding-left: 3rem;
  }
}
@media (min-width: 768px) and (min-width: 768px) {
  body section.family {
    padding-right: 3rem;
  }
}
@media (min-width: 768px) {
  body section.family .family-member {
    display: grid;
    grid-template-areas: "left right";
    grid-template-columns: calc(50% - 0.75rem);
    grid-template-rows: calc(50vw - 3rem - 0.75rem);
    gap: 1.5rem;
  }
  body section.family .family-member .info {
    grid-area: left;
    border-top: 1px solid #000000;
    padding: 0.5rem 0 calc(0.5rem - 1px);
    grid-template-areas: "fam famicon" "meat meat" "origin nav";
    grid-template-rows: auto 1fr auto;
  }
  body section.family .family-member .info h2 {
    margin-bottom: 0;
  }
  body section.family .family-member .info .main-text p {
    font-family: "Helvetica Neue", "Roboto", sans-serif;
    font-size: 1.25rem;
    color: #000000;
    line-height: 1.29;
    font-weight: 300;
  }
}
@media (min-width: 768px) and (min-width: 768px) {
  body section.family .family-member .info .main-text p {
    font-size: 1rem;
  }
}
@media (min-width: 768px) {
  body section.family .family-member .info .origin {
    align-self: end;
  }
  body section.family .family-member .info .family-nav {
    grid-template-columns: 1fr max-content;
    grid-template-areas: "prev next";
    justify-self: end;
    margin-bottom: 0;
  }
  body section.family .family-member .art {
    grid-area: right;
    border: none;
    aspect-ratio: unset;
  }
  body section.family .family-member:last-child .info {
    border-bottom: 1px solid #000000;
  }
}
@media (min-width: 1024px) {
  body section.family .family-member .info .main-text p {
    font-family: "Helvetica Neue", "Roboto", sans-serif;
    font-size: 1.5rem;
    color: #000000;
    font-weight: 300;
    line-height: 1.15;
  }
}
body footer {
  padding-top: 2rem;
  padding-right: 2rem;
  padding-left: 2rem;
  padding-bottom: 2rem;
  background-color: #ffffff;
  display: grid;
  grid-template-areas: "goods logo" "copyright copyright";
  grid-template-columns: 55% 45%;
  row-gap: 2rem;
}
@media (min-width: 768px) {
  body footer {
    padding-top: 3rem;
  }
}
@media (min-width: 768px) {
  body footer {
    padding-right: 3rem;
  }
}
@media (min-width: 768px) {
  body footer {
    padding-left: 3rem;
  }
}
@media (min-width: 768px) {
  body footer {
    padding-bottom: 3rem;
  }
}
body footer .footer-goods {
  grid-area: goods;
}
body footer .footer-goods .footer-nav {
  list-style: none;
  margin: 0 0 2rem;
  padding: 0;
}
body footer .footer-goods .footer-nav li {
  font-family: "Helvetica Neue", "Roboto", sans-serif;
  font-size: 1rem;
  color: #000000;
  font-weight: 700;
  line-height: 1.1;
  text-transform: uppercase;
  text-decoration: none;
}
@media (min-width: 768px) {
  body footer .footer-goods .footer-nav li {
    font-size: 1rem;
  }
}
body footer .footer-goods .footer-nav li a {
  color: #000000;
  text-decoration: none;
}
body footer .footer-goods .footer-nav li a:hover {
  color: #003AFF;
}
body footer .footer-goods .quote-wrap .words {
  font-family: "Hedvig Letters Serif", sans-serif;
  font-size: 2.5rem;
  color: #000000;
  font-weight: normal;
  line-height: 1.1;
}
body footer .footer-goods .quote-wrap .words > p {
  line-height: 1.1;
}
body footer .footer-goods .quote-wrap .words > *:last-child {
  margin-bottom: 0;
}
body footer .footer-goods .quote-wrap .mouth {
  font-family: "Helvetica Neue", "Roboto", sans-serif;
  font-size: 1rem;
  color: #000000;
  font-weight: 700;
  line-height: 1.1;
  text-transform: uppercase;
  margin-top: 0.5rem;
}
body footer .footer-logo {
  grid-area: logo;
  text-align: right;
  align-self: self-start;
  justify-self: right;
}
body footer .footer-logo svg {
  height: 9rem;
  display: block;
}
body footer .copyright {
  grid-area: copyright;
}
body footer .copyright > * {
  font-family: "Helvetica Neue", "Roboto", sans-serif;
  font-size: 1rem;
  color: #000000;
  font-weight: normal;
  line-height: 1.2;
  font-size: 0.8rem;
}
@media (min-width: 768px) {
  body footer .copyright > * {
    font-size: 0.825rem;
  }
}
body footer .copyright > *:last-child {
  margin-bottom: 0;
}
@media (min-width: 768px) {
  body footer {
    margin-bottom: 0;
    grid-template-areas: "goods logo" "copyright logo";
    grid-template-columns: 75% 25%;
  }
  body footer .footer-logo {
    grid-area: logo;
    text-align: right;
    align-self: center;
    justify-self: right;
  }
  body footer .footer-logo svg {
    height: 12rem;
  }
}

body.template-project .project-hero .project-hero-info {
  margin-top: 1.8rem;
  padding-left: 2rem;
  padding-right: 2rem;
  padding-bottom: 2rem;
}
@media (min-width: 768px) {
  body.template-project .project-hero .project-hero-info {
    padding-left: 3rem;
  }
}
@media (min-width: 768px) {
  body.template-project .project-hero .project-hero-info {
    padding-right: 3rem;
  }
}
@media (min-width: 768px) {
  body.template-project .project-hero .project-hero-info {
    padding-bottom: 3rem;
  }
}
body.template-project .project-hero .project-hero-info .project-hero-header h1 {
  font-family: "Helvetica Neue", "Roboto", sans-serif;
  font-size: 1rem;
  color: #000000;
  line-height: 1;
  font-size: 1.4rem;
  font-weight: 500;
  margin-bottom: 1rem;
}
@media (min-width: 768px) {
  body.template-project .project-hero .project-hero-info .project-hero-header h1 {
    font-size: 1.125rem;
  }
}
body.template-project .project-hero .project-hero-info .project-hero-header .location > * {
  font-family: "Helvetica Neue", "Roboto", sans-serif;
  font-size: 1rem;
  color: #000000;
  line-height: 1;
  font-weight: 500;
  margin-bottom: 2rem;
}
@media (min-width: 768px) {
  body.template-project .project-hero .project-hero-info .project-hero-header .location > * {
    font-size: 1.125rem;
  }
}
body.template-project .project-hero .project-hero-info .project-hero-text > * {
  font-family: "Hedvig Letters Serif", sans-serif;
  font-size: 1.8rem;
  color: #000000;
  font-weight: normal;
  line-height: 1.3;
}
@media (min-width: 768px) {
  body.template-project .project-hero .project-hero-info .project-hero-text > * {
    font-size: 2rem;
  }
}
body.template-project .project-hero .project-hero-art {
  position: relative;
}
body.template-project .project-hero .project-hero-art .placeholder {
  width: 100%;
  height: 50vh;
  background-color: #F6F6F1;
}
body.template-project .project-hero .project-hero-art figure {
  height: 50vh;
}
body.template-project .project-hero .project-hero-art figure picture > * {
  object-fit: cover;
}
body.template-project .project-hero .project-hero-art video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
body.template-project .project-hero .project-hero-art .desktop.has-mobile-hero {
  display: none;
}
@media (min-width: 1024px) {
  body.template-project .project-hero .project-hero-info {
    display: grid;
    grid-template-areas: "header text";
    grid-template-columns: calc(16.6666666667vw + 3rem) 1fr;
    padding-bottom: 4rem;
  }
  body.template-project .project-hero .project-hero-info .project-hero-header {
    grid-area: header;
    padding-top: 0.3rem;
  }
  body.template-project .project-hero .project-hero-info .project-hero-header h1 {
    align-self: self-start;
    margin-bottom: 3rem;
  }
  body.template-project .project-hero .project-hero-info .project-hero-text > *:last-child {
    margin-bottom: 0;
  }
  body.template-project .project-hero .project-hero-art .placeholder {
    width: 100%;
    height: calc(100vh - 6rem);
    background-color: #F6F6F1;
  }
  body.template-project .project-hero .project-hero-art figure, body.template-project .project-hero .project-hero-art video {
    height: calc(100vh - 6rem);
    max-height: max-content;
  }
  body.template-project .project-hero .project-hero-art .mobile {
    display: none;
  }
  body.template-project .project-hero .project-hero-art .desktop.has-mobile-hero {
    display: block;
  }
}

.project-list-header {
  margin: 2rem 2rem 0;
  height: 5rem;
  display: flex;
  align-items: end;
  padding-bottom: 0.35rem;
  border-bottom: 1px solid #000000;
}
.project-list-header nav a {
  font-family: "Helvetica Neue", "Roboto", sans-serif;
  font-size: 0.85rem;
  color: #000000;
  font-weight: normal;
  line-height: 1.1;
  text-transform: uppercase;
  text-decoration: none;
  margin-right: 2rem;
}
.project-list-header nav a:hover {
  color: #003AFF;
  text-decoration: underline;
}
.project-list-header nav a[aria-current=page] {
  font-weight: 500;
}
@media (min-width: 768px) {
  .project-list-header {
    height: 10rem;
    margin: 3rem 3rem 0;
  }
  .project-list-header nav a {
    margin-right: 3rem;
  }
}

.project-list {
  width: calc(100% - 4rem);
  margin: 0 2rem 4rem;
}
.project-list .project {
  padding-top: 0.5rem;
}
.project-list .project:not(:last-child) {
  margin-bottom: 1rem;
}
.project-list .project:not(:first-child) {
  border-top: 1px solid #000000;
}
.project-list .project .project-label {
  margin-bottom: 0.3rem;
  font-family: "Helvetica Neue", "Roboto", sans-serif;
  font-size: 0.85rem;
  color: #000000;
  font-weight: normal;
  line-height: 1.1;
  text-transform: uppercase;
}
.project-list .project .project-label:not(.project-date):not(.project-experience-label) {
  margin-bottom: 0.7rem;
}
.project-list .project .project-label > p {
  font-family: "Helvetica Neue", "Roboto", sans-serif;
  font-size: 0.85rem;
  color: #000000;
  font-weight: normal;
  line-height: 1.1;
  text-transform: uppercase;
}
.project-list .project .project-who {
  aspect-ratio: 1/1;
  margin-bottom: 0.8rem;
}
.project-list .project .project-who .project-art figure {
  aspect-ratio: 1/1;
  height: 100%;
}
.project-list .project .project-who .project-art figure > * {
  object-fit: cover;
}
.project-list .project .project-who .project-art .placeholder {
  aspect-ratio: 1/1;
  height: 100%;
  background-color: #000000;
}
.project-list .project .project-what {
  margin-bottom: 1.25rem;
}
.project-list .project .project-when {
  text-align: right;
}
.project-list .project .project-experience {
  margin-bottom: 1.25rem;
}
.project-list .project .project-experience .project-content > * {
  font-family: "Helvetica Neue", "Roboto", sans-serif;
  font-size: 1rem;
  color: #000000;
  font-weight: normal;
  line-height: 1.2;
}
@media (min-width: 768px) {
  .project-list .project .project-experience .project-content > * {
    font-size: 0.825rem;
  }
}
@media (min-width: 768px) {
  .project-list {
    margin: 0 3rem 6rem;
    width: calc(100% - 6rem);
  }
  .project-list .project {
    display: grid;
    grid-template-columns: 50%;
    grid-template-rows: 1fr;
    grid-template-areas: "who what" "who experience" "who when";
  }
  .project-list .project > *:not(:last-child) {
    padding-right: 2rem;
  }
  .project-list .project .project-who {
    margin-bottom: 0;
    grid-area: who;
  }
  .project-list .project .project-what {
    grid-area: what;
  }
  .project-list .project .project-experience {
    grid-area: experience;
  }
  .project-list .project .project-experience .project-content > *:last-child {
    margin-bottom: 0;
  }
  .project-list .project .project-label {
    margin-bottom: 1rem;
  }
  .project-list .project .project-when {
    grid-area: when;
    text-align: left;
  }
  .project-list .project .project-when .project-label {
    margin-bottom: 0;
  }
}
@media (min-width: 1024px) {
  .project-list .project {
    grid-template-columns: 25% 25% 1fr 10%;
    grid-template-areas: "who what experience when";
  }
  .project-list .project .project-what {
    margin-bottom: 0;
  }
  .project-list .project .project-experience {
    margin-bottom: 0;
  }
  .project-list .project .project-experience .project-content > *:last-child {
    margin-bottom: 0;
  }
  .project-list .project .project-when {
    justify-items: end;
  }
  .project-list .project .project-label {
    margin-bottom: 1rem;
  }
}

.identities-list {
  margin: 1rem 2rem 4rem;
}
.identities-list .identity {
  border: none;
  width: 100%;
  padding-bottom: 0;
  padding-top: 0;
  margin-bottom: 1.25rem;
}
.identities-list .identity figure {
  padding: 0;
  margin: 0;
  border: 1px solid #cccccc;
  aspect-ratio: 3/2;
}
.identities-list .identity figure > svg {
  width: 100%;
  height: auto;
  display: block;
  transform-origin: center;
  scale: var(--scale);
}
.identities-list .identity a:hover figure {
  border: 1px solid #003AFF;
}
@media (min-width: 768px) {
  .identities-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, calc(50% - 0.625rem));
    gap: 1.25rem;
    margin: 1rem 3rem 6rem;
  }
  .identities-list .identity {
    margin-bottom: 0;
  }
}
@media (min-width: 1024px) {
  .identities-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, calc(25% - 0.9375rem));
    gap: 1.25rem;
  }
}

.project-credits {
  margin: 2rem 2rem 1rem;
  padding-top: 0.5rem;
  border-top: 1px solid #000000;
}
.project-credits .credits-header {
  margin-bottom: 1.4rem;
}
.project-credits .credits-content {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.project-credits .credits-content .credit-wrap {
  width: calc(50% - 1rem);
  margin-bottom: 2rem;
}
.project-credits .credits-content .credit-wrap .role {
  font-family: "Helvetica Neue", "Roboto", sans-serif;
  font-size: 0.85rem;
  color: #000000;
  font-weight: normal;
  line-height: 1.1;
  text-transform: uppercase;
  margin-bottom: 0.25rem;
}
.project-credits .credits-content .credit-wrap .name > * {
  font-family: "Helvetica Neue", "Roboto", sans-serif;
  font-size: 1.1rem;
  color: #000000;
  font-weight: normal;
  line-height: 1.1;
}
@media (min-width: 768px) {
  .project-credits .credits-content .credit-wrap .name > * {
    font-size: 0.825rem;
  }
}
.project-credits .credits-content .credit-wrap .name > *:last-child {
  margin-bottom: 0;
}
@media (min-width: 768px) {
  .project-credits {
    margin: 0 3rem 3rem;
    display: grid;
    grid-template-areas: "header credits";
    grid-template-columns: calc(16.6666666667vw + 3rem) 1fr;
  }
  .project-credits .credits-header {
    grid-area: header;
    margin-bottom: 0;
  }
  .project-credits .credits-content {
    grid-area: credits;
    display: grid;
    grid-template-columns: repeat(auto-fill, calc(33.3333333333% - 2rem));
    column-gap: 1rem;
  }
  .project-credits .credits-content .credit-wrap {
    width: 100%;
  }
  .project-credits .credits-content .credit-wrap .role {
    font-family: "Helvetica Neue", "Roboto", sans-serif;
    font-size: 0.85rem;
    color: #000000;
    font-weight: normal;
    line-height: 1.1;
    text-transform: uppercase;
    margin-bottom: 0.25rem;
  }
  .project-credits .credits-content .credit-wrap .name > * {
    font-family: "Helvetica Neue", "Roboto", sans-serif;
    font-size: 1.5rem;
    color: #000000;
    font-weight: 300;
    line-height: 1.15;
  }
  .project-credits .credits-content .credit-wrap .name > *:last-child {
    margin-bottom: 0;
  }
}
@media (min-width: 1024px) {
  .project-credits .credits-content {
    grid-template-columns: repeat(auto-fill, calc(25% - 2rem));
  }
}

.project-gallery {
  margin: 0 2rem;
}
.project-gallery figure {
  margin-bottom: 1.5rem;
  display: flex;
}
.project-gallery figure picture > * {
  object-fit: contain;
  width: 100%;
  height: 100%;
}
.project-gallery video {
  margin-bottom: 1.5rem;
  width: 100%;
  height: auto;
}
.project-gallery .one {
  aspect-ratio: 2/1;
}
.project-gallery .two {
  aspect-ratio: 1/1;
}
.project-gallery .three {
  display: flex;
}
.project-gallery .three .pic {
  width: 50%;
  padding-right: 1rem;
  aspect-ratio: 2/3;
}
.project-gallery .three .words {
  width: 50%;
  padding-left: 1rem;
}
.project-gallery .three .words > * {
  font-family: "Helvetica Neue", "Roboto", sans-serif;
  font-size: 1rem;
  color: #000000;
  font-weight: normal;
  line-height: 1.2;
}
@media (min-width: 768px) {
  .project-gallery .three .words > * {
    font-size: 0.825rem;
  }
}
.project-gallery .four {
  aspect-ratio: 2/1;
}
@media (min-width: 768px) {
  .project-gallery {
    display: grid;
    margin: 0 3rem;
    grid-template-areas: "one one" "two three" "four four";
    grid-template-columns: calc(70% - 6rem) 30%;
    row-gap: 1.5rem;
    column-gap: 6rem;
  }
  .project-gallery figure {
    margin-bottom: 0;
  }
  .project-gallery .one {
    grid-area: one;
  }
  .project-gallery .two {
    grid-area: two;
  }
  .project-gallery .three {
    grid-area: three;
    flex-direction: column;
  }
  .project-gallery .three .pic {
    width: 100%;
    padding: 0;
    aspect-ratio: 2/3;
    margin-bottom: 0.5rem;
  }
  .project-gallery .three .pic > video {
    aspect-ratio: 2/3;
    width: 100%;
    height: 100%;
  }
  .project-gallery .three .words {
    grid-area: words;
    width: 100%;
    padding: 0;
  }
  .project-gallery .three .words > * {
    font-family: "Helvetica Neue", "Roboto", sans-serif;
    font-size: 1.25rem;
    color: #000000;
    line-height: 1.29;
    font-weight: 300;
  }
}
@media (min-width: 768px) and (min-width: 768px) {
  .project-gallery .three .words > * {
    font-size: 1rem;
  }
}
@media (min-width: 768px) {
  .project-gallery .four {
    grid-area: four;
  }
}

.project-bonus-gallery {
  margin: 0 2rem;
}
.project-bonus-gallery .gallery-image {
  aspect-ratio: 2/1;
  display: flex;
  margin-bottom: 1.5rem;
}
.project-bonus-gallery .gallery-image > * {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.project-bonus-gallery .gallery-image:last-child {
  margin-bottom: 0;
}
@media (min-width: 768px) {
  .project-bonus-gallery {
    margin: 1.5rem 3rem 0;
  }
}

body.template-project main {
  padding-bottom: 4rem;
}
@media (min-width: 768px) {
  body.template-project main {
    padding-bottom: 6rem;
  }
}

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