*, *::before, *::after {
  box-sizing: border-box;
}

html {
  -moz-text-size-adjust: none;
  -webkit-text-size-adjust: none;
  text-size-adjust: none;
}

body, h1, h2, h3, h4, p, figure, blockquote, dl, dd {
  margin: 0;
}

ul[role=list], ol[role=list] {
  list-style: none;
}

body {
  min-height: 100vh;
  line-height: 1.5;
}

h1, h2, h3, h4, button, input, label {
  line-height: 1.1;
}

h1, h2, h3, h4 {
  text-wrap: balance;
}

a:not([class]) {
  text-decoration-skip-ink: auto;
  color: currentColor;
}

img, picture, video {
  max-width: 100%;
  display: block;
  height: auto;
}

input, button, textarea, select {
  font: inherit;
}

textarea:not([rows]) {
  min-height: 10em;
}

h1, h2, h3, h4, h5, h6 {
  font-weight: normal;
}

h1, h2, h3, h4, h5, h6, p, ul, ol {
  margin: 0;
  padding: 0;
}

@font-face {
  font-display: swap;
  font-family: "GT America";
  font-style: normal;
  font-weight: 400;
  src: url("/assets/webfonts/GTAmerica-Regular.woff2") format("woff2");
}
@font-face {
  font-display: swap;
  font-family: "GT America";
  font-style: normal;
  font-weight: 600;
  src: url("/assets/webfonts/GTAmerica-Medium.woff2") format("woff2");
}
@font-face {
  font-display: swap;
  font-family: "Scto Grotesk A";
  font-style: normal;
  font-weight: 400;
  src: url("/assets/webfonts/SctoGroteskA-Medium.woff2") format("woff2");
}
* {
  box-sizing: border-box;
}

html {
  font-size: 18px;
  scroll-behavior: smooth;
  scrollbar-gutter: stable;
  interpolate-size: allow-keywords;
  --nav-bg: #f0dcaa;
  --header-height: 82.0px;
  --quicknav-height: 51.6px;
  --max-width: 1400px;
  --padding-side: 2rem;
}
html:has(dialog[open]) {
  overflow: hidden;
}
@media screen and (max-width: 1023px) {
  html {
    font-size: 18px;
    --header-height: 74.3px;
    --quicknav-height: 46.4px;
  }
}
@media screen and (max-width: 779px) {
  html {
    font-size: 16px;
    --header-height: 58px;
    --padding-side: 1rem;
  }
}
html:has(.open-nav) {
  overflow: hidden;
}

body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-family: "Helvetica", Arial, sans-serif;
  line-height: 1.33;
}

a {
  cursor: pointer;
  text-underline-offset: 0.16em;
  text-decoration-thickness: 0.06em;
  text-decoration-skip-ink: none;
}
a:link, a:visited, a:hover, a:active {
  color: inherit;
}

#skip-to-content-link {
  position: fixed;
  top: 0;
  background: black;
  color: white;
  left: 50%;
  padding: 8px;
  transform: translate(-50%, -150%);
  transition: transform 0.3s;
  z-index: 100;
  border-bottom-left-radius: 3px;
  border-bottom-right-radius: 3px;
}
#skip-to-content-link:focus {
  transform: translate(-50%, 0);
}

.font-size-13 {
  font-size: 0.8125rem;
}

.font-size-15 {
  font-size: 0.9375rem;
}

.font-size-16 {
  font-size: 1rem;
}

.font-size-17 {
  font-size: 1.0625rem;
}

.font-size-19 {
  font-size: 1.1875rem;
}

.font-size-24 {
  font-size: 1.5rem;
}

.font-size-26 {
  font-size: 1.55rem;
}

.font-size-29 {
  font-size: 1.8125rem;
}

.font-size-40 {
  font-size: 2.5rem;
}

@media screen and (max-width: 779px) {
  .font-size-29 {
    font-size: 1.6rem;
  }
  .font-size-40 {
    font-size: 2rem;
  }
}
.visually-hidden {
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  height: 1px;
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}

.content-width {
  max-width: var(--max-width);
  padding-inline: var(--padding-side);
  margin-inline: auto;
}

button {
  border: none;
  border-radius: 0;
  background: none;
  cursor: pointer;
}
button:focus:not(:focus-visible) {
  outline: none;
}

#menu-toggle {
  --button-width: 30px;
  width: var(--button-width);
  height: calc(var(--button-width) * 0.65);
  padding: 1em;
  margin-top: -1em;
  margin-right: -1em;
  margin-bottom: -1em;
  margin-left: auto;
  box-sizing: content-box;
  color: inherit;
}
#menu-toggle .bar {
  width: var(--button-width);
  height: 2px;
  display: block;
  background-color: currentColor;
  transform-origin: 56% 50%;
  transition: transform 0.2s ease-in-out 0.2s, opacity 0.1s linear 0.2s;
}
#menu-toggle .middleBar {
  margin: 7px 0;
  transition: transform 0.2s ease-in-out 0.2s, background-color 0.2s ease-in-out 0.2s;
  position: relative;
}
#menu-toggle .middleBar .inside {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: currentColor;
  transition: transform 0.2s ease-in-out;
}
.open-nav #menu-toggle {
  color: black;
}
.open-nav #menu-toggle .bar {
  transition: transform 0.2s ease-in-out, opacity 0.1s linear 0.2s;
}
.open-nav #menu-toggle .bar.topBar {
  transform: translateY(7px);
  opacity: 0;
  transform-origin: 0 1px;
}
.open-nav #menu-toggle .bar.middleBar {
  background: transparent;
  transition: transform 0.2s ease-in-out 0.2s;
}
.open-nav #menu-toggle .bar.middleBar .inside {
  transition: transform 0.2s ease-in-out 0.2s;
  transform: rotate(45deg);
}
.open-nav #menu-toggle .bar.middleBar .inside:last-child {
  transform: rotate(-45deg);
}
.open-nav #menu-toggle .bar.bottomBar {
  transform: translateY(-7px);
  opacity: 0;
}

#main-header {
  --bg-color: white;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 4;
  display: grid;
  grid-template-columns: 11ch 1fr 11ch;
  align-items: center;
  padding-block: 1rem;
  pointer-events: none;
  background: var(--bg-color);
  transition: background-color 0.2s ease-out 0.25s;
}
@media screen and (max-width: 779px) {
  #main-header {
    padding-block: 0.75rem;
  }
}
#main-header::after {
  content: " ";
  position: absolute;
  left: 50%;
  width: 100vw;
  translate: -50% 0;
  top: 0;
  bottom: 0;
  background-color: var(--bg-color);
  z-index: -1;
  transition: background-color 0.2s ease-out 0.25s;
}
#main-header h1 {
  text-align: center;
  transition: opacity 0.2s ease-out 0.2s;
}
.open-nav #main-header, .start #main-header {
  transition-delay: 0s;
}
.open-nav #main-header h1 {
  opacity: 0;
  transition-delay: 0s;
}
.open-nav #main-header::after {
  transition-delay: 0s;
}
#main-header a, #main-header button {
  pointer-events: auto;
}
#main-header #menu-toggle {
  grid-column-start: 3;
}

.logo {
  position: relative;
  --bg: white;
}
.open-nav .logo {
  --bg: var( --nav-bg );
}
.logo .longform {
  display: flex;
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
  background-color: var(--bg);
  transition: opacity 0s ease-out 0.4s;
}
.logo .longform span {
  max-width: 0;
  transition: max-width 0.4s ease-out;
  overflow: hidden;
}
.logo .longform span.visible {
  max-width: none;
}
body:not(.scrolled) .logo .longform {
  opacity: 1;
  transition: opacity 0s ease-out 0s;
  padding-right: 0.25em;
}
body:not(.scrolled) .logo .longform span {
  max-width: 1.5ch;
}
@media (hover: hover) {
  .logo:hover .longform {
    opacity: 1;
    transition: opacity 0s ease-out 0s;
    padding-right: 0.25em;
  }
  .logo:hover .longform span {
    max-width: 1.5ch;
  }
}

@media (hover: hover) {
  .start.scrolled:has(.logo:hover) #quick-nav ul {
    opacity: 0;
    transition-delay: 0s;
  }
  body:not(.start):has(.logo:hover) #main-header h1 {
    opacity: 0;
    transition-delay: 0s;
  }
}
#main-nav-wrapper {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 3;
  translate: 0 -100%;
  transition: translate 0.4s ease-out;
  max-height: 100%;
  overflow: auto;
}
.open-nav #main-nav-wrapper {
  translate: 0 0;
}
#main-nav-wrapper .main-nav {
  padding-top: 6rem;
}
@media screen and (max-width: 899px) {
  #main-nav-wrapper #contact-signup-wrapper {
    display: none;
  }
  #main-nav-wrapper .main-nav {
    display: flex;
    flex-direction: column;
    height: 100dvh;
    justify-content: space-between;
    padding-top: 5rem;
  }
  #main-nav-wrapper nav > ul {
    flex-direction: column;
    width: 100%;
    text-align: center;
    gap: 2rem;
  }
  #main-nav-wrapper .nav-headline {
    margin-top: 2rem;
  }
}

.main-nav {
  padding-block: 2rem;
}
.main-nav #contact-signup-wrapper {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
  flex-direction: column;
}
@media screen and (max-width: 899px) {
  .main-nav #contact-signup-wrapper {
    flex-direction: row;
  }
}

.nav-links {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 2rem;
  line-height: 1.5;
}
.nav-links ul {
  list-style-type: "";
}
.nav-links > ul {
  display: flex;
  justify-content: space-between;
  gap: 3rem;
}
.nav-links > ul > li > a {
  display: block;
  margin-bottom: 1rem;
}
@media screen and (max-width: 779px) {
  .nav-links > ul > li > a {
    margin-bottom: 0.5rem;
  }
}
.nav-links .contact h2,
.nav-links .sign-up h2 {
  margin-bottom: 1rem;
}
.nav-links .social-media {
  margin-top: 1lh;
}

.nav-headline {
  text-align: center;
  margin-top: 5rem;
}

#main-footer {
  margin-top: 3rem;
  border-top: 1px solid lightgray;
}
#main-footer .contact .address,
#main-footer .contact .social-media {
  margin-bottom: 1lh;
}

#quick-nav {
  position: absolute;
  top: calc(var(--header-height));
  left: 50%;
  width: 100%;
  padding-bottom: 1rem;
  padding-inline: var(--padding-side);
  z-index: 2;
  pointer-events: none;
  background-color: white;
  translate: -50% 0%;
}
.start #quick-nav {
  top: 0;
  left: initial;
  position: sticky;
  translate: 0 0;
}
.scrolled:not(.start) #quick-nav {
  position: fixed;
  top: calc(var(--header-height) - var(--quicknav-height));
  translate: -50% 0%;
  pointer-events: none;
  transition: translate 0.4s ease-out;
}
.scrolled.nav-down:not(.start) #quick-nav {
  translate: -50% 100%;
  pointer-events: auto;
}
#quick-nav ul {
  list-style-type: "";
  display: flex;
  justify-content: center;
  column-gap: 1em;
  flex-wrap: wrap;
  transition: opacity 0.2s ease-out 0.2s;
}
#quick-nav a {
  pointer-events: auto;
}

#main {
  padding-top: var(--header-height);
}

.start {
  --quicknav-height: 71.6px;
}
.start #quick-nav {
  padding-top: 1rem;
}
@media screen and (max-width: 779px) {
  .start #quick-nav {
    position: static;
  }
}
.start #main {
  padding-top: calc(var(--header-height) + 2.5rem);
}

#featured-swiper {
  /*
  margin-inline: 4rem;

  @media screen and (max-width: 779px){
    margin-inline: calc( var( --padding-side ) * -1 );
  }

   */
}
#featured-swiper .swiper-slide {
  height: auto;
  overflow: clip;
}
@media screen and (max-width: 779px) {
  #featured-swiper .swiper-slide .project-name {
    padding-inline: var(--padding-side);
  }
}
#featured-swiper .swiper-pagination {
  display: none;
  left: auto;
  width: max-content;
  right: 0;
  bottom: 0.2em;
}
#featured-swiper .inner {
  display: flex;
  flex-direction: column;
  gap: 0.5em;
}
#featured-swiper a {
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: 1em;
}
#featured-swiper a picture {
  flex: 1;
}
#featured-swiper img {
  height: 100%;
  max-height: 80vh;
  object-fit: cover;
}

.no-underline a {
  text-decoration: none;
}
.underline-hover a {
  text-decoration: underline;
  text-decoration-color: transparent;
  text-underline-offset: 0.2em;
  text-decoration-thickness: 0.06em;
  transition: text-decoration-color 0.2s ease-out;
}
.underline-hover a:hover, .underline-hover a:focus, .underline-hover a[aria-current=page] {
  text-decoration-color: currentColor;
}

.masonry {
  --cols: 2;
  display: grid;
  grid-template-columns: repeat(var(--cols), minmax(0, 1fr));
  column-gap: 3rem;
  row-gap: 3rem;
  align-items: start;
}
@media screen and (max-width: 779px) {
  .masonry {
    --cols: 1;
    grid-auto-rows: initial;
  }
}
.start .masonry {
  margin-top: 5rem;
}
.masonry .masonry-element.center {
  margin-inline: auto;
}
.masonry .masonry-element.right {
  margin-left: auto;
}
.masonry .masonry-element.narrow {
  width: 60%;
}
.masonry .masonry-element.margin-minus3 {
  margin-top: -6rem;
}
.masonry .masonry-element.margin-minus2 {
  margin-top: -4rem;
}
.masonry .masonry-element.margin-minus1 {
  margin-top: -2rem;
}
.masonry .masonry-element.margin-1 {
  margin-top: 2rem;
}
.masonry .masonry-element.margin-2 {
  margin-top: 4rem;
}
.masonry .masonry-element.margin-3 {
  margin-top: 6rem;
}

#start-tiles a {
  display: block;
}
@media screen and (max-width: 779px) {
  #start-tiles {
    --padding-side: 1.5rem;
  }
}

.practiceTile a,
.studioTile a {
  /*
  text-decoration: none;
  transition: background-color 0.2s ease-out;

  &:hover{
    background-color: transparent;

    .title{
      text-decoration-color: currentColor;
    }
  }

   */
}
.practiceTile .title,
.studioTile .title {
  text-decoration-line: underline;
  text-decoration-color: transparent;
  text-underline-offset: 0.16em;
  text-decoration-thickness: 0.06em;
  text-decoration-skip-ink: none;
  transition: text-decoration-color 0.2s ease-out;
}

.practiceTile a {
  background-color: #e2e1e1;
  padding: 2rem;
}
@media screen and (max-width: 1199px) {
  .practiceTile a {
    padding: 1.5rem;
  }
}
.practiceTile .practice-image {
  aspect-ratio: 1;
  overflow: clip;
}
.practiceTile .practice-image.circle {
  border-radius: 50%;
}
.practiceTile .practice-image.diamond {
  clip-path: polygon(50% 0, 100% 50%, 50% 100%, 0 50%);
  margin-top: -1rem;
  margin-bottom: -0.5rem;
}
.practiceTile .practice-image.square {
  padding: 1.5rem;
}
.practiceTile .practice-image picture {
  height: 100%;
}
.practiceTile .practice-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.practiceTile .title {
  margin-top: 1.5rem;
  margin-bottom: 1rem;
}

.projectPreview .type, .projectPreview picture, .projectPreview video,
.studioTile .type,
.studioTile picture,
.studioTile video {
  margin-bottom: 0.8rem;
}

.projectPreview .text {
  margin-top: 1rem;
  margin-bottom: 0.5rem;
  /*
  text-decoration: underline;
  text-decoration-color: transparent;
  text-underline-offset: 0.16em;
  text-decoration-thickness: 0.06em;
  text-decoration-skip-ink: none;

  transition: text-decoration-color 0.2s ease-out;

   */
}
.projectPreview a {
  text-underline-offset: 0.16em;
  text-decoration-thickness: 0.06em;
  text-decoration-skip-ink: none;
}
.projectPreview a:hover .text {
  text-decoration-color: currentColor;
}

.content-blocks .headline,
.content-blocks .text,
.content-blocks .images {
  max-width: 70ch;
  margin-inline: auto;
}
.content-blocks .headline:has(.wide),
.content-blocks .text:has(.wide),
.content-blocks .images:has(.wide) {
  max-width: var(--max-width);
}
.content-blocks .quote {
  max-width: 90ch;
  margin-inline: auto;
  margin-block: 5rem;
}
.content-blocks .quote blockquote {
  line-height: 1.2;
}
.content-blocks .quote .source {
  margin-top: 0.5rem;
}
.content-blocks .images:has(.fullBleed) {
  max-width: 100%;
  padding-inline: 0;
}
.content-blocks .images:has(.fullBleed) img {
  width: 100%;
}
@media screen and (max-width: 779px) {
  .content-blocks .images:has(.wide) {
    max-width: 100%;
    padding-inline: 0;
  }
  .content-blocks .images:has(.wide) figcaption {
    padding-inline: var(--padding-side);
  }
}
@media screen and (max-width: 899px) {
  .content-blocks .images:has(.narrow) {
    max-width: 100%;
    padding-inline: 5rem;
  }
}
@media screen and (max-width: 779px) {
  .content-blocks .images:has(.narrow) {
    padding-inline: 2rem;
  }
}
.content-blocks .headline {
  margin-top: 5em;
  margin-bottom: 2em;
  text-align: center;
}
.content-blocks .headline h2 {
  scroll-margin-top: calc(var(--header-height) + 4rem);
}
.content-blocks .text {
  hyphens: auto;
}
.content-blocks .text p + p {
  margin-top: 1lh;
}
.content-blocks .text h2, .content-blocks .text h3 {
  margin-top: 1.2em;
  margin-bottom: 0.8em;
}
.content-blocks .text .teaser p {
  display: inline;
}
.content-blocks .text .teaser button {
  color: #4d4d4d;
  padding: 0;
  transition: color 0.2s ease-out;
}
.content-blocks .text .teaser button:hover, .content-blocks .text .teaser button:focus {
  color: currentColor;
}
.content-blocks .text .teaser + .long-text {
  display: none;
  transition-property: height, margin, display;
  transition-timing-function: ease-out;
  transition-duration: 0.4s, 0.2s, 0.1s;
  transition-behavior: allow-discrete;
}
.content-blocks .text.show .teaser + .long-text {
  display: block;
  height: auto;
  margin-top: 1lh;
}
@starting-style {
  .content-blocks .text.show .teaser + .long-text {
    margin-top: 0;
    height: 0px;
  }
}
.content-blocks .text.show .teaser p {
  display: block;
}
.content-blocks .text.show .teaser button {
  display: none;
}
.content-blocks .images {
  margin-block: 2rem;
}
.content-blocks .images .grid {
  --cols: 2;
  display: grid;
  grid-template-columns: repeat(var(--cols), minmax(0, 1fr));
  gap: 1rem;
}
@media screen and (max-width: 779px) {
  .content-blocks .images .grid {
    --cols: 1;
  }
}
.content-blocks .images .swiper-slide {
  cursor: url("/assets/arrow-right.svg") 66 20, auto;
}
.content-blocks .images .swiper-slide figcaption {
  display: none;
}
.content-blocks .images .swiper-slide video {
  pointer-events: none;
}
.content-blocks .images .swiper-footer {
  margin-top: 1rem;
  display: flex;
  gap: 1rem;
}
.content-blocks .images .swiper-footer .caption {
  flex: 1;
}
@media screen and (max-width: 779px) {
  .content-blocks .images:has(.wide) .swiper-footer, .content-blocks .images:has(.fullBleed) .swiper-footer {
    padding-inline: var(--padding-side);
  }
}
.content-blocks .images .swiper-pagination {
  position: static;
  text-align: left;
  width: 4ch;
  font-variant-numeric: tabular-nums;
}
.content-blocks .credits {
  margin-top: 4rem;
}
.content-blocks .credits h2, .content-blocks .credits dt {
  color: #43855e;
}
.content-blocks .credits h2 {
  margin-bottom: 1lh;
}
.content-blocks .credits dl {
  column-count: 2;
  column-gap: 1em;
}
@media screen and (max-width: 779px) {
  .content-blocks .credits dl {
    column-count: 1;
  }
}
.content-blocks .credits dl dt, .content-blocks .credits dl dd {
  display: inline;
}
.content-blocks .team {
  --cols: 4;
  display: grid;
  grid-template-columns: repeat(var(--cols), minmax(0, 1fr));
  gap: 2rem 1rem;
}
@media screen and (max-width: 1023px) {
  .content-blocks .team {
    --cols: 3;
  }
}
@media screen and (max-width: 779px) {
  .content-blocks .team {
    --cols: 2;
  }
}

figure figcaption {
  margin-top: 0.4rem;
}

.work #main,
.studio #main {
  margin-bottom: 6rem;
}
.work .content-blocks,
.studio .content-blocks {
  margin-top: 4rem;
  --gap: 2rem;
}
.work .content-blocks .block + .block,
.studio .content-blocks .block + .block {
  margin-top: 5rem;
}

.imageText {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  column-gap: var(--gap, 2rem);
  row-gap: 1lh;
}
.imageText img {
  width: 100%;
}
.imageText:has(.image-wrapper.wide-image) .headline,
.imageText:has(.image-wrapper.wide-image) .text-wrapper {
  padding-right: var(--padding-side);
  width: calc(700px - var(--gap, 2rem) * 0.5);
  max-width: 100%;
}
.imageText:has(.image-wrapper.wide-image):has(.image-wrapper.right) .headline {
  padding-left: var(--padding-side);
  width: calc(700px - var(--gap, 2rem) * 0.5);
  max-width: 100%;
  margin-left: auto;
}
.imageText:has(.image-wrapper.wide-image):has(.image-wrapper.right) .text-wrapper {
  padding-left: var(--padding-side);
  padding-right: 0;
  margin-left: auto;
}
.imageText:has(.image-wrapper.right) .headline {
  grid-column-start: 1;
}
.imageText:has(.image-wrapper.right) .image-wrapper {
  grid-column-start: 2;
}
.imageText:has(.image-wrapper.right) .text-wrapper {
  grid-column-start: 1;
  grid-row-start: 2;
}
.imageText .headline-wrapper {
  grid-column: 1/-1;
  display: grid;
  grid-template-columns: subgrid;
}
.imageText .headline {
  font-size: 1em;
  font-weight: bold;
  margin: 0;
  text-align: left;
  grid-column-start: 2;
}
.imageText .text-wrapper h2, .imageText .text-wrapper h3 {
  font-size: 1em;
  margin-bottom: 0.2em;
  font-weight: bold;
}

.work section {
  margin-top: 7em;
  margin-bottom: 2em;
  scroll-margin-top: calc(var(--header-height) + 4rem);
}
@media screen and (max-width: 779px) {
  .work #selected-projects {
    --padding-side: 1.5rem;
  }
}
.work #main h2 {
  text-align: center;
  margin-bottom: 1em;
}
.work .type {
  display: none;
}
.work .projectPreview a {
  display: block;
}
.work #project-list ul {
  display: grid;
  grid-template-columns: auto auto auto;
  gap: 0 1em;
  list-style-type: "";
}
.work #project-list ul li {
  grid-column: 1/-1;
  display: grid;
  grid-template-columns: subgrid;
  border-top: 1px solid currentColor;
  padding-block: 0.5rem;
  color: rgb(128, 128, 128);
}
.work #project-list ul li:last-child {
  border-bottom: 1px solid currentColor;
}
.work #project-list ul li .year {
  font-variant-numeric: tabular-nums;
}
.work #project-list ul li a {
  grid-column: 1/-1;
  display: grid;
  grid-template-columns: subgrid;
  color: black;
  text-decoration: none;
}
.single-project {
  padding-top: calc(var(--header-height) + 1px);
}
.single-project h1 {
  text-align: center;
  margin-top: 3rem;
  margin-bottom: 3rem;
  line-height: 1.2;
}
.single-project .intro {
  max-width: 70ch;
  margin-inline: auto;
  line-height: 1.2;
}
.single-project .content-blocks {
  margin-top: 3rem;
}
.single-project .related-projects {
  margin-top: 5rem;
}
.single-project .related-projects ul {
  --cols: 3;
  margin-top: 2rem;
  display: grid;
  grid-template-columns: repeat(var(--cols), minmax(0, 1fr));
  gap: 1rem;
  list-style-type: "";
}
@media screen and (max-width: 779px) {
  .single-project .related-projects ul {
    --cols: 2;
  }
}
.single-project .related-projects ul li:nth-child(n+3) {
  display: none;
}
.single-project .related-projects ul picture {
  margin-bottom: 1rem;
}
.single-project .related-projects ul a {
  display: block;
}
.single-project .grid {
  --cols: 2;
  display: grid;
  grid-template-columns: repeat(var(--cols), minmax(0, 1fr));
  gap: 2rem;
  row-gap: 4rem;
}
@media screen and (max-width: 779px) {
  .single-project .grid {
    --cols: 1;
  }
}
.single-project .grid .block {
  grid-column: 1/-1;
}
.single-project .singleImage {
  display: grid;
  grid-column: 1/-1;
  grid-template-columns: subgrid;
}
.single-project .singleImage .center {
  margin-inline: auto;
}
.single-project .singleImage .right {
  grid-column-start: -1;
}
.single-project .singleImage .center {
  grid-column: 1/-1;
  width: 50%;
  margin-inline: auto;
}
@media screen and (max-width: 779px) {
  .single-project .singleImage .center {
    width: 100%;
  }
}
.single-project .imageText {
  display: grid;
  grid-column: 1/-1;
  grid-template-columns: subgrid;
}
.single-project .imageText p + p {
  margin-top: 1lh;
}

.awards ul,
.clients ul {
  list-style-type: "";
}
.awards ul li,
.clients ul li {
  text-wrap: balance;
}
.awards a,
.clients a {
  text-underline-offset: 0.15em;
}
.awards .columns,
.clients .columns {
  column-count: var(--cols, 3);
  column-gap: 1rem;
}

.clients {
  --cols: 3;
}
@media screen and (max-width: 899px) {
  .clients {
    --cols: 2;
  }
}
@media screen and (max-width: 779px) {
  .clients {
    --cols: 1;
  }
}
.clients {
  margin-top: 4rem;
}
.headline + .clients {
  margin-top: 0;
}
.clients h3 {
  margin-bottom: 1em;
  text-align: center;
}
.clients li {
  padding-left: 1em;
  text-indent: -1em;
  break-inside: avoid;
}

.awards {
  --cols: 2;
}
@media screen and (max-width: 779px) {
  .awards {
    --cols: 1;
  }
}
.awards .year,
.awards .awards-list {
  margin-bottom: 1lh;
}
.awards .awards-list li {
  padding-left: 1em;
  text-indent: -1em;
  break-inside: avoid;
}

.team {
  margin-top: 2rem;
}

.person .image-wrapper {
  aspect-ratio: 2/3;
  margin-bottom: 0.5em;
  display: block;
  background-color: ghostwhite;
}
.person .content {
  font-size: 0.9em;
}
.person summary {
  list-style: none;
}
.person .name {
  text-decoration: underline;
  text-decoration-color: transparent;
  text-underline-offset: 0.15em;
  transition: text-decoration 0.2s ease-out;
}
.person .titles {
  margin-bottom: 1lh;
}
.person .infos:first-child {
  margin-top: 1lh;
}
.person .infos p:not(:last-child) {
  margin-bottom: 1lh;
}

details:has(.content) {
  cursor: pointer;
}
details:has(.content):hover .name {
  text-decoration-color: currentColor;
}

details summary::-webkit-details-marker {
  display: none;
}

.page .content-blocks {
  margin-top: 5rem;
}

/*
@view-transition {
  navigation: auto;
}

 */
/*
::view-transition-old(main) {
  animation: 0.4s ease-in move-out;
}

 */
/*
#transition-background{
  opacity: 0.5;
  pointer-events: none;

  background: #E76E91;
  background: linear-gradient(0deg, #E76E91, #F0A853);

  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 10;

  transition: opacity 0.2s ease-out;

  .transitioning &{
    opacity: 1;
  }
}

 */
/*
#main {
  view-transition-name: main;
}

#main-header{
  view-transition-name: header;
}

::view-transition-group(main) {
  animation-duration: 0.2s;
}

::view-transition-group(header) {
  animation-duration: 0.2s;
}
*/
#slideshow {
  --swiper-navigation-color: currentColor;
  --distanceSide: 3rem;
  --swiper-navigation-size: 28px;
  margin: 0;
  width: 100%;
  height: 100%;
  max-width: none;
  max-height: none;
  padding: 3rem var(--distanceSide);
}
@media screen and (max-width: 779px) {
  #slideshow {
    --distanceSide: 1rem;
  }
}
#slideshow {
  color: white;
  background-color: black;
  border: none;
}
#slideshow img, #slideshow video {
  max-height: 80svh;
  object-fit: contain;
  object-position: center;
}
#slideshow figure:has(figcaption) img, #slideshow figure:has(figcaption) video {
  max-height: calc(80svh - 2lh);
}
#slideshow .swiper {
  height: calc(100svh - 6rem - 2lh);
  margin-right: 3rem;
}
#slideshow .swiper-slide {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
#slideshow aside {
  display: flex;
  justify-content: space-between;
  flex-direction: column;
  gap: 1rem;
  position: fixed;
  top: 3rem;
  bottom: 3rem;
  right: calc(var(--distanceSide) * 0.6);
  z-index: 2;
}
#slideshow .swiper-buttons {
  display: flex;
  flex-direction: column;
  gap: 2ch;
  justify-content: space-between;
  width: auto;
  z-index: 12;
}
#slideshow .swiper-buttons .swiper-button-prev,
#slideshow .swiper-buttons .swiper-button-next {
  position: static;
  translate: 0 50%;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  border: 1px solid currentColor;
  transition-property: background, border, color;
  transition-duration: 0.2s;
}
#slideshow .swiper-buttons .swiper-button-prev:hover, #slideshow .swiper-buttons .swiper-button-prev:focus,
#slideshow .swiper-buttons .swiper-button-next:hover,
#slideshow .swiper-buttons .swiper-button-next:focus {
  background: white;
  border-color: white;
  color: black;
}
#slideshow .swiper-buttons .swiper-button-prev::after,
#slideshow .swiper-buttons .swiper-button-next::after {
  translate: var(--translate, 0 0);
}
#slideshow .swiper-buttons .swiper-button-prev {
  --translate: -10% 0 ;
}
#slideshow .swiper-buttons .swiper-button-next {
  --translate: 10% 0 ;
}
#slideshow .swiper-pagination {
  position: static;
  width: max-content;
  margin-inline: auto;
}
#slideshow form {
  --height: 1.2rem;
}
#slideshow form button {
  position: relative;
  color: inherit;
  display: block;
  height: 2.5rem;
  width: 2.5rem;
  padding: 0.5rem;
  border: 1px solid currentColor;
  border-radius: 50%;
}
#slideshow form button::after, #slideshow form button::before {
  content: " ";
  width: calc(var(--height) * 1);
  height: 2px;
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  background-color: currentColor;
}
#slideshow form button::after {
  rotate: 45deg;
}
#slideshow form button::before {
  rotate: -45deg;
}
#slideshow form button {
  transition-property: background, border, color;
  transition-duration: 0.2s;
}
#slideshow form button:hover, #slideshow form button:focus {
  background: white;
  border-color: white;
  color: black;
}
#slideshow .swiper-footer {
  position: fixed;
  bottom: 1rem;
  left: var(--distanceSide);
  right: var(--distanceSide);
  display: flex;
  gap: 2rem;
  align-items: center;
}
#slideshow .swiper-footer .caption {
  flex: 1;
  height: 2lh;
  display: flex;
  align-items: center;
}
#slideshow .swiper-footer .caption .inner {
  max-width: 40ch;
  text-wrap: balance;
}

.swiper-pagination-fraction {
  display: flex;
  gap: 0.2ch;
}

/*# sourceMappingURL=bhs-la.css.map */
