@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Roboto+Flex:opsz,wght@8..144,100..1000&family=Roboto:ital,wght@0,100..900;1,100..900&display=swap");
/* -------------------------------------------------------------------------- */
/*                                  Typefaces                                 */
/* -------------------------------------------------------------------------- */
@font-face {
  font-family: "Sharp Grotesk";
  src: local("Sharp Grotesk Medium 21"), local("SharpGroteskMedium-21"), url("./_assets/type/SharpGroteskMedium-21.woff2") format("woff2");
  font-display: auto;
  font-style: normal;
  font-weight: 500;
  font-stretch: 80%;
}
@font-face {
  font-family: "Sharp Grotesk";
  src: local("Sharp Grotesk Medium 20"), local("SharpGroteskMedium-20"), url("./_assets/type/SharpGroteskBook-20.woff2") format("woff2");
  font-display: auto;
  font-style: normal;
  font-weight: 500;
  font-stretch: 75%;
}
@font-face {
  font-family: "Sharp Grotesk";
  src: local("Sharp Grotesk Book 21"), local("SharpGroteskBook-21"), url("./_assets/type/SharpGroteskBook-21.woff2") format("woff2");
  font-display: auto;
  font-style: normal;
  font-weight: 400;
  font-stretch: 80%;
}
@font-face {
  font-family: "Sharp Grotesk";
  src: local("Sharp Grotesk Book 20"), local("SharpGroteskBook-20"), url("_assets/type/SharpGroteskBook-20.woff2") format("woff2");
  font-display: auto;
  font-style: normal;
  font-weight: 400;
  font-stretch: 75%;
}
@font-face {
  font-family: "Sharp Grotesk";
  src: local("Sharp Grotesk Light 21"), local("SharpGroteskLight-21"), url("_assets/type/SharpGroteskLight-21.woff2") format("woff2");
  font-display: auto;
  font-style: normal;
  font-weight: 300;
  font-stretch: 80%;
}
@font-face {
  font-family: "Sharp Grotesk";
  src: local("Sharp Grotesk Light 20"), local("SharpGroteskLight-20"), url("/_assets/type/SharpGroteskLight-20.woff2") format("woff2");
  font-display: auto;
  font-style: normal;
  font-weight: 300;
  font-stretch: 75%;
}
*,
*::before,
*::after,
.svg-tspan {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  font-weight: unset;
  font-size: var(--fsz-root);
  font-family: var(--secondary-type-B);
  font-weight: 400;
  font-kerning: normal;
  scroll-behavior: smooth;
}

p,
a {
  color: inherit;
}

a:not(.header, .footer) {
  text-underline-offset: 0.25em;
}

p a:is(:hover, :focus, :active) {
  background: var(--foreground-color);
  color: var(--background-color);
}

ol,
ul,
menu {
  list-style: none;
}

img,
.svg-tspan {
  display: block;
}

img {
  width: 100%;
  height: auto;
  vertical-align: middle;
  text-align: center;
  font-style: italic;
  background: var(--_placeholder);
  background-repeat: no-repeat;
  background-size: cover;
  shape-margin: 0.5rem;
}

fieldset {
  border: none;
}

/* revert the 'white-space' property for textarea elements on Safari */
textarea {
  white-space: revert;
}

/* remove default dot (•) sign */
::marker {
  content: initial;
}

/* fix the feature of 'hidden' attribute.
 display:revert; revert to element instead of attribute */
:where([hidden]) {
  display: none;
}

:root {
  /* -------------------------------------------------------------------------- */
  /*                                    Colors                                  */
  /* -------------------------------------------------------------------------- */
  --hsl-night: 240, 10%, 20%;
  --hsl-bright: 60, 5%, 95%;
  --rgb-night: 46, 46, 56;
  --rgb-bright: 243, 243, 243;
  --rgb-accent: 20, 20, 117;
  --glass-opacity: 0.895;
  --main-night: hsl(240, 10%, 14%);
  --night-glass: hsla(240, 10%, 20%, 0.725);
  --main-bright: hsl(300, 6%, 93%);
  --bright-glass: hsla(300, 6%, 93%, 0.725);
  /* -------------------------------------------------------------------------- */
  /*                                Type Variables                              */
  /* -------------------------------------------------------------------------- */
  /* Family */
  --primary-type: "Sharp Grotesk", Archivo, Helvetica, Arial, sans-serif;
  --primary-type-B: "Sharp Grotesk", Archivo, Helvetica, Arial, sans-serif;
  --secondary-type: "Sharp Grotesk", Archivo, Helvetica, Arial, sans-serif;
  --secondary-type-B: "Sharp Grotesk", Archivo, Helvetica, Arial, sans-serif;
  --tertiary-type: "Sharp Grotesk", Archivo, Helvetica, Arial, sans-serif;
  --tertiary-type-B: "Sharp Grotesk", Archivo, Helvetica, Arial, sans-serif;
  --ff-A: var(--primary-type);
  --ff-B: var(--primary-type);
  --ff-C: var(--secondary-type);
  --ff-D: var(--secondary-type-B);
  --ff-E: var(--secondary-type-B);
  /* Size */
  --fsz-root: clamp(1rem, calc(0.25rem + 0.7925vw), calc(0.5rem + 0.723vw));
  --fsz-A: clamp(31px, calc(1rem + 2.785vw), calc(1rem + 2.785vw));
  --fsz-B: clamp(22px, calc(1rem + 1.75vw), calc(1rem + 1.75vw));
  --fsz-C: clamp(19px, calc(0.5rem + 1.0671vw), calc(0.5rem + 1.0671vw));
  --fsz-D: var(--fs-root);
  --fsz-E: var(--fs-root);
  /* Weight */
  --fw-A: 500;
  --fw-B: 500;
  --fw-C: 400;
  --fw-D: 400;
  --fw-E: 400;
  /* Stretch */
  --fst-A: 80%;
  --fst-B: 80%;
  --fst-C: 80%;
  --fst-D: 75%;
  --fst-E: 75%;
  /* Leading */
  --lh-A: 1.25;
  --lh-B: 1.2;
  --lh-C: 1.25;
  --lh-D: 1.4;
  --lh-E: 1.5;
  /* Tracking */
  --ls-A: -0.025em;
  --ls-B: -0.0275em;
  --ls-C: 0.00em;
  --ls-D: -0.01em;
  --ls-E: 0.0105em;
  /* -------------------------------------------------------------------------- */
  /*                               Set base values                              */
  /* -------------------------------------------------------------------------- */
  --foreground-color: var(--main-night);
  --background-color: var(--main-bright);
  --fg-glass: var(--night-glass);
  --bg-glass: var(--bright-glass);
  --unit-root: var(--fsz-root);
  --unit-base: calc(var(--fsz-root) * 2.5);
  --unit: calc(var(--unit-base) * 0.5);
  --unit-A: calc(var(--unit) * 6);
  --unit-B: calc(var(--unit) * 4);
  --unit-C: calc(var(--unit) * 3);
  --unit-D: var(--unit-base);
  --unit-E: var(--unit);
  --unit-F: calc(var(--unit) * 0.5);
  --border-width: 1px;
  --border-radius: var(--unit-F);
  --layout-unit: clamp(18px, calc(0.75rem + 2vw), calc(0.75rem + 2vw));
  --base-columns: repeat(12, 1fr);
  /* -------------------------------------------------------------------------- */
  /*                               Property Units                               */
  /* -------------------------------------------------------------------------- */
  --ease-curve-A: cubic-bezier(0, 1, 0, 1);
  --ease-curve-B: cubic-bezier(0, 0.75, 0.25, 1);
  --ease-curve-C: cubic-bezier(0, 0.5, 0.5, 1);
  --blur-strength: calc(var(--unit-E) * 0.25);
  --nav-zIndex: 100;
  --base-zIndex: 25;
  /* page content */
  --tag-correction: calc(var(--fsz-B) / 5);
  /* project cards */
  --global-delay: 400ms;
}

/* -------------------------------------------------------------------------- */
/*                                                                            */
/*                                                                            */
/*                                 UTILITIES                                  */
/*                                                                            */
/*                                                                            */
/* -------------------------------------------------------------------------- */
.noevents {
  /* Used for: hero animation, removed on complete */
  pointer-events: none;
}

/* -------------------------------------------------------------------------- */
/*                               GRID UTILITIES                               */
.start1 {
  grid-column-start: 1;
}

.start2 {
  grid-column-start: 2;
}

.start3 {
  grid-column-start: 3;
}

.start4 {
  grid-column-start: 4;
}

.start5 {
  grid-column-start: 5;
}

.start6 {
  grid-column-start: 6;
}

.start7 {
  grid-column-start: 7;
}

.start8 {
  grid-column-start: 8;
}

.start9 {
  grid-column-start: 9;
}

.end5 {
  grid-column-end: 5;
}

.end6 {
  grid-column-end: 6;
}

.end7 {
  grid-column-end: 7;
}

.end8 {
  grid-column-end: 8;
}

.end9 {
  grid-column-end: 9;
}

.end10 {
  grid-column-end: 10;
}

.end11 {
  grid-column-end: 11;
}

.end12 {
  grid-column-end: 12;
}

.end13 {
  grid-column-end: 13;
}

@keyframes fadeInStatic {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes fadeOutStatic {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes fadeOutSharpen {
  0% {
    opacity: 1;
    -webkit-backdrop-filter: blur(5px);
            backdrop-filter: blur(5px);
  }
  100% {
    opacity: 0;
    -webkit-backdrop-filter: blur(0px);
            backdrop-filter: blur(0px);
  }
}
@keyframes fadeIn {
  0% {
    opacity: 0;
    translate: 0 var(--unit-D) 0;
  }
  85% {
    translate: 0 0 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes fadeIn-top {
  0% {
    margin-top: -10%;
    opacity: 0;
  }
  100% {
    margin-top: 0;
    opacity: 1;
  }
}
@keyframes fadeIn-bottom {
  0% {
    margin-bottom: -10%;
    opacity: 0;
  }
  100% {
    margin-bottom: 0;
    opacity: 1;
  }
}
.visually-hidden {
  display: block;
  height: 0;
  width: 0;
  opacity: 0;
}

/* -------------------------------------------------------------------------- */
/*                               Mobile Nav Menu                              */
.header__content {
  pointer-events: none;
  padding: 0 var(--unit) calc(var(--unit-B) + var(--unit-E));
}

.toggle--menu::after {
  background: var(--bg-glass);
  opacity: 0;
  transition: opacity 300ms var(--ease-curve-B);
  pointer-events: none;
}

.toggle--menu:checked::after {
  opacity: 1;
  pointer-events: all;
}

.content__wrapper,
.nav__wrapper {
  gap: var(--unit-F);
}

.nav__item {
  pointer-events: all;
  color: var(--background-color);
  background: var(--fg-glass);
  border: var(--border-width) solid var(--fg-glass);
  border-radius: var(--unit-F);
  -webkit-backdrop-filter: blur(var(--blur-strength));
          backdrop-filter: blur(var(--blur-strength));
  opacity: 0;
  transition: all 750ms var(--ease-curve-A);
  transform: translateY(1em);
}

.nav__link {
  pointer-events: none;
  padding: 1rem var(--unit) 0.85rem var(--unit);
  letter-spacing: 0.025em;
  text-transform: uppercase;
  text-decoration: none;
  text-underline-offset: 0.5rem;
  text-decoration-thickness: var(--border-width);
  color: var(--background-color);
}

/* -------------------------------------- */
/*         Navigation Menu Toggle         */
.toggle--menu {
  pointer-events: none;
  visibility: none;
  all: unset;
  overflow: hidden;
}

.toggle--menu--label {
  pointer-events: all;
  inset-block-end: -4.5rem;
  inset-inline-end: 50%;
  transform: translateX(50%);
  cursor: pointer;
  background: var(--bg-glass);
  width: var(--unit-A);
  height: var(--unit-A);
  border-radius: 50%;
  border: var(--border-width) solid var(--bg-glass);
  -webkit-backdrop-filter: blur(var(--blur-strength));
          backdrop-filter: blur(var(--blur-strength));
  filter: drop-shadow(0px 4px 10px rgba(121, 121, 121, 0.35));
  transition: all 750ms var(--ease-curve-B);
}

.toggle--menu--label::before,
.toggle--menu--label::after {
  text-transform: uppercase;
  text-align: center;
  padding-top: calc(var(--unit-F) * 1.7);
}

.toggle--menu--label::before {
  content: "Menu";
  color: var(--foreground-color);
}

.toggle--menu--label::after {
  content: "✖";
  font-size: 1.4em;
  color: var(--background-color);
  opacity: 0;
  padding-top: calc(var(--unit-F) * 1.125);
}

.toggle--menu:checked ~ .content__wrapper ~ .toggle--menu--label {
  border-color: var(--fg-glass);
  background-color: var(--fg-glass);
  inset-block-end: var(--unit);
  width: var(--unit-C);
  height: var(--unit-C);
}

.toggle--menu:checked ~ .content__wrapper ~ .toggle--menu--label::before {
  opacity: 0;
}

.toggle--menu:checked ~ .content__wrapper ~ .toggle--menu--label::after {
  opacity: 1;
}

.toggle--menu ~ .content__wrapper .nav__item {
  pointer-events: none;
}

.toggle--menu:checked ~ .content__wrapper .nav__link {
  pointer-events: all;
}

.toggle--menu:checked ~ .content__wrapper .nav__item {
  transform: translateY(0em);
  opacity: 1;
  pointer-events: unset;
}

/* -------------------------------------- */
/*              Theme Toggle              */
.toggle--theme--label {
  pointer-events: all;
  cursor: pointer;
  margin-inline-start: auto;
  padding: 3px 4px;
  height: 1.75rem;
  width: 3rem;
  border: 2px solid var(--foreground-color);
  border-radius: 2rem;
}

.toggle--theme--label::after {
  aspect-ratio: 1;
  border-radius: 2rem;
  background-color: var(--foreground-color);
  width: 50%;
  aspect-ratio: 1;
  transition: all 300ms var(--ease-curve-B);
}

.toggle--theme[type=checkbox]:checked + .toggle--theme--label::after {
  transform: translateX(100%);
}

.theme__input::after {
  content: "";
  display: block;
  height: 1.75rem;
  aspect-ratio: 1;
  border-radius: 99rem;
  background-color: var(--foreground-color);
  margin-inline-start: 0.5rem;
}

.nav__item .coming-soon,
.list-item .coming-soon {
  /* this isn't typical of me, trying to get this site deployed! */
  pointer-events: none !important;
  position: relative;
}

.nav__link.coming-soon::after,
.link.coming-soon::after {
  border: none;
}

.list-wrapper {
  display: inline-block;
}

.link {
  position: relative;
}

.list-item {
  width: -moz-fit-content;
  width: fit-content;
  margin-block-start: 0.125em;
  overflow: clip;
}

/**TODO-place correctly v**/
.coming-soon::before {
  pointer-events: none;
  content: "Coming Soon";
  display: block;
  position: absolute;
  width: 100%;
  background-color: var(--foreground-color);
  border-radius: var(--border-radius);
  color: var(--background-color);
  font-size: 0.75em;
  box-shadow: 0px 2px 2px var(--bg-glass);
  text-align: center;
  top: 0.1em;
  rotate: -3.25deg;
  padding: 0 0.25em;
}

.header .coming-soon::before {
  top: 0em;
  left: 0;
  padding: 0.5em 0.25em;
  rotate: 1.25deg;
  translate: 0 1em;
}

.footer .coming-soon::before {
  rotate: 1deg;
}

@keyframes underline {
  0% {
    margin-left: -110%;
  }
  50% {
    margin-left: 0%;
  }
  100% {
    margin-left: 110%;
  }
}
/**TODO clean this up too**/
.footer .link {
  text-decoration: none;
}

.footer .link::after {
  content: "";
  display: block;
  width: 110%;
  height: 0;
  border-top: var(--border-width) solid var(--foreground-color);
  margin-block-start: 0.125em;
  background-color: var(--foreground-color);
}

/*                                                                            */
/* -------------------------------------------------------------------------- */
.frame-wrapper {
  --spacing-v: 1rem;
  --spacing-h: 1.25rem;
  font-optical-sizing: auto;
  --clr-bright: hsla(0, 100%, 100%, 1);
  --clr-night: hsla(0, 0%, 10%, 1);
  --clr-middle: hsla(0, 0%, 50%, .5);
  --clr-middle-B: hsla(0, 0%, 50%, .25);
  --fg: var(--clr-night);
  --bg: var(--clr-bright);
}

.frame-wrapper * {
  font-family: "Roboto Flex", sans-serif;
  font-size: 14px;
}

.frame-wrapper.dark {
  background-color: var(--clr-middle);
}

@media (prefers-color-scheme: dark) {
  .frame-wrapper {
    --bg: var(--clr-night);
    --fg: var(--clr-bright);
  }
}
[data-color-scheme=dark] .frame-wrapper {
  --bg: var(--clr-night);
  --fg: var(--clr-bright);
}

.frame-wrapper {
  --outer-radius: 2rem;
  --padding: .5rem;
  aspect-ratio: 1/1.5;
  width: min(420px, 100%);
  padding: var(--padding);
  background-color: var(--clr-middle);
  border-radius: var(--outer-radius);
  display: flex;
}

.screen-wrapper {
  font-family: inherit;
}

.screen-wrapper,
.app-wrapper,
.email-wrapper {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  flex: 1 1 100%;
}

.screen-wrapper {
  width: 100%;
  --_inner-radius: calc(var(--outer-radius) - var(--padding));
  --screen-padding: var(--spacing-v);
  background-color: var(--bg);
  border-radius: var(--_inner-radius);
  overflow: clip;
  position: relative;
}

.app-wrapper {
  height: 100%;
}

.app-nav {
  display: flex;
  justify-content: space-between;
}

.app-nav .icon,
.reply .icon {
  height: 24px;
  width: auto;
}

.app-nav .options {
  display: flex;
  gap: 1.5rem;
}

.app-header,
.app-nav {
  padding-inline: var(--spacing-h);
}

.app-header {
  padding-block-start: var(--spacing-v);
}

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

.generic-block {
  padding-inline: var(--spacing-h);
}

.phone-bar,
.app-nav {
  padding-block: var(--spacing-v);
}

.email-wrapper {
  padding: var(--spacing-v);
  padding-block-end: 0;
}

/* --------------- */
.field-label,
.field-value {
  font-weight: 600;
}

.field-value,
.send-time {
  font-weight: 500;
}

.subtle {
  opacity: 0.5;
}

/* --------------- */
.phone-bar {
  width: 100%;
  justify-content: space-between;
  font-weight: 600;
  letter-spacing: -0.0125em;
}

.phone-bar,
.system {
  display: flex;
}

.active,
.system {
  flex: 0 1 auto;
}

.system,
.reply {
  display: flex;
  gap: 0.25em;
}

.system .icon {
  aspect-ratio: 1/1;
  height: 16px;
}

.wifi {
  margin-right: -0.25em;
}

.envelope-info,
.send-info {
  display: flex;
  gap: 0.5rem;
}

.send-info {
  justify-content: space-between;
  gap: 1rem;
  padding-block-start: var(--spacing-v);
}

.subject-line {
  font-weight: 700;
  font-size: 1.5em;
  margin-bottom: 0;
}

.sent .from {
  font-size: 1.25em;
  font-weight: 600;
}

.app-actionbar {
  width: 100%;
  padding: var(--spacing-h);
  border-top: 1px solid var(--clr-middle);
  background: var(--bg);
}

.reply {
  align-items: center;
  gap: 1rem;
}

.reply .text {
  font-size: 1.25rem;
  line-height: 0.9;
}

iframe {
  overflow: visible;
}

iframe::-webkit-scrollbar,
iframe::-moz-scrollbar {
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.p__carousel {
  width: 100%;
  display: flex;
  width: -moz-fit-content;
  width: fit-content;
}

.crs_child {
  flex-shrink: 0;
  padding-inline-end: var(--unit-B);
}

.email-child {
  width: min(420px, 100%);
}

.webpage-child {
  max-width: max(22ch, 80vw);
}

.section--carousel {
  padding-block-start: calc(1 * var(--unit-A));
}

.section--carousel .intro-copy {
  width: min(40ch, 100%);
  margin-bottom: var(--unit-E);
}

.section--carousel .intro-copy {
  padding-inline: var(--unit-D);
}

.p__carousel {
  padding-inline: var(--unit-D) var(--unit-B);
}

.crs__title {
  margin-bottom: 0.5em;
}

.crs__item,
.crs-image-wrapper {
  flex-shrink: 0;
}

.crs-image-wrapper {
  transition: all 300ms var(--ease-curve-C);
}

.webpage-child,
.webpage-child .crs-image-wrapper,
.webpage-child .crs-image-wrapper:hover {
  position: relative;
  contain: layout;
}

.crs-image-wrapper::before,
.crs-child::before {
  content: "View live site ↗";
  color: var(--background-color);
  background: var(--foreground-color);
  display: block;
  width: -moz-max-content;
  width: max-content;
  padding: 0.5em 0.9em 0.5em 1.1em;
  border-radius: var(--border-radius);
  font-size: var(--fsz-D);
  margin-bottom: var(--unit-E);
  margin-inline: auto;
  opacity: 0;
  transition: all 300ms var(--ease-curve-B);
}

.crs-image-wrapper:hover {
  transform: scale(97%);
}

.crs-image-wrapper:hover::before,
.crs-child:hover::before {
  opacity: 1;
}

.crs-image-wrapper::after {
  content: "";
  background: var(--background-color);
  display: block;
  height: 100%;
  width: 100%;
  border-radius: var(--border-radius);
  position: absolute;
  z-index: 998;
  top: 0;
  left: 0;
  opacity: 0;
  transition: all 300ms var(--ease-curve-B);
}

.crs-image-wrapper:hover::after {
  opacity: 0.7;
}

.crs__item {
  max-height: 60vh;
}

@media (max-width: 700px) {
  .webpage-child {
    max-width: max(22ch, 97vw);
  }
  .crs_child {
    padding-inline-end: var(--unit-D);
  }
  .crs-image-wrapper::before,
  .crs-child::before {
    opacity: 1;
  }
}
/* -------------------------------------------------------------------------- */
/*                                   Basics                                   */
/* -------------------------------------------------------------------------- */
html {
  transition: all 1.25s ease;
}

[data-color-scheme=dark][data-color-flavor] {
  --foreground-color: var(--main-bright);
  --background-color: var(--main-night);
  --fg-glass: var(--bright-glass);
  --bg-glass: var(--night-glass);
  transition: color, backgroud-color, background 5s ease;
}

[data-color-scheme=light][data-color-flavor] {
  --foreground-color: var(--main-night);
  --background-color: var(--main-bright);
  --fg-glass: var(--night-glass);
  --bg-glass: var(--bright-glass);
}

[data-color-flavor=alertness] {
  --main-night: hsl(0, 70%, 45%);
  --night-glass: hsla(0, 70%, 45%, var(--glass-opacity));
}

[data-color-flavor=vibes] {
  --main-night: hsl(258, 61%, 51%);
  --night-glass: hsla(255, 97%, 70%, var(--glass-opacity));
}

[data-color-flavor=studious] {
  --main-night: hsl(172, 100%, 14%);
  --night-glass: hsla(172, 100%, 14%, var(--glass-opacity));
}

[data-color-flavor=confident] {
  --main-night: hsl(225, 84%, 45%);
  --night-glass: hsla(225, 85%, 48%, var(--glass-opacity));
}

body,
.toggle--theme--label,
.main,
.footer {
  background-color: var(--background-color);
}

body {
  color: var(--foreground-color);
}

p {
  font-family: var(--ff-E);
  font-size: var(--fsz-E);
  font-stretch: var(--fst-E);
  font-weight: var(--fw-E);
  letter-spacing: var(--ls-E);
  line-height: var(--lh-E);
}

img {
  aspect-ratio: var(--_ratio);
  position: relative;
}

:is(.cover, .proj__cover, .gall-image-wrapper, .expts__card-img).loading {
  position: relative;
}

:is(.cover, .proj__cover, .gall-image-wrapper, .expts__card-img).loading::before,
:is(.cover, .proj__cover, .gall-image-wrapper, .expts__card-img).loading::after {
  content: "";
  position: absolute;
  top: 0;
  display: block;
  width: 100%;
  height: 100%;
  aspect-ratio: var(--_ratio);
  background-size: cover;
  border-radius: var(--border-radius);
}

:is(.cover, .proj__cover, .gall-image-wrapper, .expts__card-img).loading::before {
  z-index: 98;
  -webkit-backdrop-filter: blur(3px);
          backdrop-filter: blur(3px);
}

:is(.cover, .proj__cover, .gall-image-wrapper, .expts__card-img).loading::after {
  z-index: 97;
  position: absolute;
  background-image: var(--_placeholder);
  filter: blur(2px);
}

:is(.cover, .proj__cover, .gall-image-wrapper, .expts__card-img).loading::before,
:is(.cover, .proj__cover, .gall-image-wrapper, .expts__card-img).loading::after {
  animation: fadeOutSharpen 1s ease-in forwards;
  animation-delay: 0.5s;
}

::-moz-selection {
  background-color: var(--foreground-color);
  color: var(--background-color);
}

::selection {
  background-color: var(--foreground-color);
  color: var(--background-color);
}

.toggle--menu::after,
.nav__link,
.toggle--menu--label,
.toggle--menu--label::before,
.toggle--menu--label::after,
.toggle--theme--label::after,
.footer::before,
.footer__bar::after {
  display: block;
}

.content__wrapper,
.nav__wrapper,
.theme__input,
.toggle--theme--label,
.main__hero-text,
.project-card,
.footer {
  display: flex;
}

.marquee,
.marquee__txt::after {
  display: inline-block;
}

.header,
.header__content,
.toggle--menu::after,
.theme__input,
.toggle--menu--label {
  position: fixed;
}

.footer__bar {
  position: sticky;
}

.section *,
.home--projects,
.footer {
  position: relative;
}

.toggle--menu--label::before,
.toggle--menu--label::after,
.home--work__svg,
.footer::before {
  position: absolute;
}

.header__content,
.toggle--menu::after,
.nav {
  inset-inline-start: 0;
}

.home--work__svg {
  inset-inline-end: 0;
}

.home--work__svg,
.footer::before {
  inset-block-start: 0;
}

.header__content,
.toggle--menu::after,
.nav,
.footer__bar {
  inset-block-end: 0;
}

.header {
  padding-block: var(--layout-unit);
}

.section {
  padding-block: var(--unit-D);
}

.header,
.footer,
.section {
  padding-inline: var(--layout-unit);
}

.header__content,
.toggle--menu::after,
.content__wrapper,
.toggle--menu--label::before,
.toggle--menu--label::after,
.footer__bar::after {
  width: 100%;
}

.toggle--menu::after,
.toggle--theme--label::after {
  height: 100%;
}

.main {
  overflow-x: clip;
}

.content__wrapper,
.nav__wrapper,
.project-card {
  flex-direction: column;
}

.toggle--theme--label,
.main__hero-text {
  align-items: center;
}

.content__wrapper,
.nav__wrapper {
  gap: var(--unit-F);
}

.footer {
  gap: calc(2 * var(--layout-unit));
}

/* Z-Index */
.home--work__svg {
  z-index: 10;
}

.section * {
  z-index: calc(var(--base-zIndex) + 1);
}

.header,
.toggle--menu::after {
  z-index: var(--nav-zIndex);
}

.nav,
.toggle--menu--label {
  z-index: calc(var(--nav-zIndex) + 1);
}

.footer__bar {
  z-index: -1;
}

.toggle--menu::after,
.toggle--menu--label::before,
.toggle--menu--label::after,
.toggle--theme--label::after,
.footer::before,
.footer__bar::after {
  content: "";
}

.marquee__txt::after {
  content: "—";
}

.hero-container {
  padding-block-start: var(--unit-D);
  min-height: max(55vh, 30vw + 10vw - 10vh);
}

.text__graf:not(:first-child) {
  margin-block: 1em;
}

.video {
  width: 100%;
}

.gall__text-wrapper {
  padding-block: var(--layout-unit);
}

.gall__image {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}

.gall__image,
.gall__video {
  border-radius: var(--border-radius);
}

.gall__video {
  display: block;
}

/* -------------------------------------------------------------------------- */
/*                                 Typesetting                                */
/* -------------------------------------------------------------------------- */
.level-A {
  font-family: var(--ff-A);
  font-size: var(--fsz-A);
  font-stretch: var(--fst-A);
  font-weight: var(--fw-A);
  letter-spacing: var(--ls-A);
  line-height: var(--lh-A);
}

.level-B {
  font-family: var(--ff-B);
  font-size: var(--fsz-B);
  font-stretch: var(--fst-B);
  font-weight: var(--fw-B);
  letter-spacing: var(--ls-B);
  line-height: var(--lh-B);
}

.level-C {
  font-family: var(--ff-C);
  font-size: var(--fsz-C);
  font-stretch: var(--fst-C);
  font-weight: var(--fw-C);
  letter-spacing: var(--ls-C);
  line-height: var(--lh-C);
}

.level-D {
  font-family: var(--ff-D);
  font-size: var(--fsz-D);
  font-stretch: var(--fst-D);
  font-weight: var(--fw-D);
  letter-spacing: var(--ls-D);
  line-height: var(--lh-D);
}

.level-E {
  font-family: var(--ff-E);
  font-size: var(--fsz-E);
  font-stretch: var(--fst-E);
  font-weight: var(--fw-E);
  letter-spacing: var(--ls-E);
  line-height: var(--lh-E);
}

.overline {
  display: block;
  font-family: var(--ff-A);
  font-size: calc(var(--fsz-root) * 0.95);
  font-stretch: var(--fst-A);
  font-weight: var(--fw-A);
  letter-spacing: 0.045em;
  line-height: var(--lh-C);
  text-transform: uppercase;
}

.subtle {
  opacity: 0.625;
}

/* -------------------------------------------------------------------------- */
/*                             ## Overall Wrapper                             */
/* -------------------------------------------------------------------------- */
.body {
  opacity: 0;
  animation: fadeInStatic 1s var(--ease-curve-B) forwards;
  animation-delay: var(--global-delay);
}

/* -------------------------------------------------------------------------- */
/*                                  ## Header                                 */
/* -------------------------------------------------------------------------- */
.header {
  pointer-events: none;
}

.logo-link {
  pointer-events: all;
  grid-column-end: span 3;
}

.logotype {
  fill: var(--foreground-color);
  height: calc(0.75 * var(--unit-C));
}

.nav {
  order: 5;
}

.toggle--menu--label::before,
.toggle--menu--label::after {
  text-transform: uppercase;
  padding-top: calc(var(--unit-F) * 1.7);
}

.toggle--menu--label::before {
  content: "Menu";
  color: var(--foreground-color);
}

.toggle--menu--label::after {
  content: "✖";
  font-size: 1.4em;
  color: var(--background-color);
  opacity: 0;
  padding-top: calc(var(--unit-F) * 1.125);
}

.theme__input {
  inset-block-start: var(--layout-unit);
  inset-inline-end: var(--layout-unit);
}

/* -------------------------------------------------------------------------- */
/*                                 Main - Hero                                */
/* -------------------------------------------------------------------------- */
.main__hero-text {
  max-width: 23ch;
  justify-content: center;
  padding-block-start: calc(var(--unit-A) * 1.8);
}

.main__hero-caption {
  display: block;
  width: min(27.5rem, 80%);
  margin-block: var(--unit-D) calc(var(--unit-C) * 1.5);
}

.home--projects {
  padding-top: 0;
  scroll-margin-top: 8rem;
}

/* -------------------------------------------------------------------------- */
/*                               Main - Projects                              */
/* -------------------------------------------------------------------------- */
/* SVG Graphic */
@keyframes simpleSpin {
  0% {
    rotate: 0deg;
  }
  100% {
    rotate: 360deg;
  }
}
.home--work__svg {
  fill: var(--foreground-color);
  max-width: 200px;
  border-radius: 999rem;
  translate: 50% -50%;
  animation: simpleSpin 30s linear 0s infinite;
}

.svg-circle {
  fill: none;
  stroke-width: 2;
  stroke: var(--foreground-color);
}

.svg-tpath {
  dominant-baseline: central;
}

.svg-tspan {
  color: var(--foreground-color);
  font-size: 17px;
  text-transform: uppercase;
  letter-spacing: 0.115em;
}

/* Featured Project Cards */
.project-gallery {
  padding-block-end: var(--layout-unit);
  scroll-padding-block-start: var(--unit-A);
}

.project-card {
  text-decoration: none;
  border-radius: var(--border-radius);
  margin-block-end: calc(2 * var(--layout-unit));
  transition: all 150ms var(--ease-curve-B);
}

.cover {
  transition: scale 300ms var(--ease-curve-B);
}

.cover:where(:hover, :target, :focus, :active, :not(.cover.not-active)) {
  scale: 1.015;
}

.project-card__text {
  order: 2;
  padding-block: calc(0.75 * var(--unit-E)) var(--unit-E);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
  transition: all 150ms var(--ease-curve-B);
}

.cover,
.cover-img {
  border-radius: var(--border-radius);
}

.project-name {
  padding-inline-end: 20%;
}

.main-tag {
  line-height: 100%;
  margin-top: var(--tag-correction);
}

/* Archived Project List */
.listed-projects {
  margin-block: var(--unit-B);
}

.listings-header {
  margin-bottom: 1em;
}

.archive-card {
  text-decoration: none;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  padding-block: calc(var(--unit-F) * 1.5);
  transition: all 150ms var(--ease-curve-B);
}

.archive-item:not(:first-of-type) {
  border-top: var(--border-width) solid var(--foreground-color);
}

.archive-item:last-of-type {
  border-bottom: var(--border-width) solid var(--foreground-color);
}

.archive-item .archive-card:is(:hover, :target, :focus, :active) {
  padding-inline: 1em;
  background: var(--foreground-color);
  color: var(--background-color);
  border-radius: var(--border-radius);
}

.archive-item:hover,
.archive-item:focus-within,
:is(.archive-item:hover, .archive-item:focus-within) + .archive-item {
  border-top-color: var(--background-color);
}

.archive-item:hover {
  border-bottom-color: var(--background-color);
}

.archive-card::after {
  content: "↗";
  margin-top: var(--tag-correction);
  font-size: calc(var(--fsz-B) * 1.25);
  line-height: 0.65em;
}

.archive-copy {
  display: flex;
  flex-wrap: wrap;
}

.archive-name {
  white-space: nowrap;
  margin-inline-end: 0.55rem;
}

.archive-tag {
  margin-top: var(--tag-correction);
  line-height: 0.8em;
}

/* Featured but not live */
.not-live {
  transition: opacity 300ms var(--ease-curve-C);
}

.not-live::after {
  content: "🔒";
  position: absolute;
  z-index: 999;
  top: 0.5em;
  left: 0.5em;
  font-size: 1.5em;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5em;
  aspect-ratio: 1;
  border-radius: 99rem;
  background-color: var(--bg-glass);
}

.not-live:hover .cover {
  opacity: 0.65;
  cursor: not-allowed;
}

/* -------------------------------------------------------------------------- */
/*                                 ## Footer                                  */
/* -------------------------------------------------------------------------- */
.footer,
.footer-content,
.footer-sub-section {
  display: flex;
  gap: var(--layout-unit);
  row-gap: var(--unit-C);
}

.footer,
.footer-content {
  flex-wrap: wrap;
}

.footer {
  padding: var(--unit-C) var(--layout-unit) calc(1 * var(--layout-unit));
  border-radius: 0 0 var(--border-radius) var(--border-radius);
  justify-content: space-between;
  -moz-column-gap: 35ch;
       column-gap: 35ch;
}

.footer::before {
  height: 0.25rem;
  inset-inline: var(--layout-unit);
  border-top: var(--border-width) solid var(--foreground-color);
  padding-bottom: var(--layout-unit);
}

.footer-svg {
  cursor: pointer;
  stroke: var(--foreground-color);
  stroke-width: 3px;
  fill: none;
  aspect-ratio: 1;
  height: 5vw;
  min-height: 100px;
  margin-block-start: -1%;
  margin-inline-start: -1%;
  animation: simpleSpin 13s linear infinite;
  transition: scale 300ms var(--ease-curve-B);
}

.footer-svg:active {
  scale: 0.9;
  animation-play-state: paused;
}

.footer-content {
  flex: 0 0 calc((100% - var(--layout-unit)) / 2);
}

.link-fblock,
.extlink-fblock {
  min-width: 13ch;
}

.link-fblock,
.extlink-fblock {
  flex: 1 1 calc(100% - var(--layout-unit) / 2);
}

.icon-fblock {
  min-width: 10ch;
  flex: 0 1 calc((100% - var(--layout-unit) * 2) / 3 * 1);
}

.footer-sub-section {
  flex: 2 0 calc((100% - var(--layout-unit) * 2) / 3 * 2);
}

.ftr-header {
  margin-bottom: 1em;
}

.list-item {
  margin-block: 0.5em;
}

/* -------------------------------------------------------------------------- */
/*                                 FOOTER BAR                                 */
@keyframes marquee-anim {
  0% {
    transform: translateX(0%);
  }
  100% {
    transform: translateX(-100%);
  }
}
.footer__bar {
  bottom: 0;
  background-color: var(--foreground-color);
  color: var(--background-color);
  overflow-x: hidden;
  white-space: nowrap;
  padding-block: var(--unit-A) var(--unit-B);
  bottom: 0;
  margin-top: calc(-1 * var(--unit-C));
  z-index: -1;
}

.footer__bar:hover > div {
  animation-play-state: paused;
}

.marquee {
  animation: marquee-anim 100s linear infinite;
}

.marquee__txt::after {
  content: "—";
  padding-inline: 2rem;
}

.footer__bar::after {
  background-color: --foreground-color;
}

/* -------------------------------------------------------------------------- */
/*                          ##  Project Page - Indiv                          */
/* -------------------------------------------------------------------------- */
.proj__hero {
  display: flex;
  align-items: end;
}

.hero__title {
  margin-block-end: calc(-0.7 * var(--unit-F));
}

.hero__copy {
  display: flex;
  flex-wrap: wrap;
  gap: calc(var(--layout-unit) * 2);
  margin-bottom: calc(-0.3 * var(--unit-E));
  align-items: end;
}

.hero__question {
  margin-inline-end: min(var(--unit-D) - 10vw, 0%);
}

.q-tag,
.q-prompt {
  margin-block: var(--unit-F) 0;
}

.hero-cover__img {
  min-height: 50vh;
  -o-object-fit: cover;
     object-fit: cover;
}

.stepA-top {
  animation: fadeIn-top 1.15s var(--ease-curve-B) forwards;
  animation-delay: calc(var(--global-delay) + 0s);
}

.stepA {
  opacity: 0;
  animation: fadeIn 1.2s var(--ease-curve-B) forwards;
  animation-delay: calc(var(--global-delay) + 0s);
}

.stepB {
  opacity: 0;
  animation: fadeIn 1.2s var(--ease-curve-B) forwards;
  animation-delay: calc(var(--global-delay) + 0.15s);
}

.stepC {
  opacity: 0;
  animation: fadeIn 1.2s var(--ease-curve-B) forwards;
  animation-delay: calc(var(--global-delay) + 0.25s);
}

/* -------------------------------------------------------------------------- */
/*                                  Proj Desc                                 */
.p-copy__wrapper,
.p-info,
.p-attr {
  display: flex;
  gap: var(--layout-unit);
  row-gap: var(--layout-unit);
  flex-wrap: wrap;
}

.p-copy__wrapper {
  row-gap: calc(4 * var(--layout-unit));
}

.proj__copy-intro {
  padding-block-end: var(--unit-B);
}

.p-copy-block {
  row-gap: calc(2 * var(--layout-unit));
}

.p-copy-block {
  flex: 1 0 calc((100% - var(--layout-unit) * 11) / 12 * 6);
  min-width: min(32ch, 100%);
}

.p-livetag,
.p-infotag {
  margin-block-end: 1em;
}

.p-livelink {
  display: inline-block;
  line-height: var(--lh-E);
  margin-inline-end: max(0%, 25vw - 8vh);
}

.p-desc__list-u {
  list-style-type: disc;
  margin-left: 1em;
}

.p-desc__list-item {
  line-height: 150%;
}

.p-desc__list-item::marker {
  margin-right: 0.5em;
}

.p-discipline,
.p-team-member {
  margin-bottom: 0.25em;
}

.p-attr {
  width: 100%;
}

.attr-section {
  flex: 1 1 40%;
  min-width: -moz-fit-content;
  min-width: fit-content;
}

.p-team-member:only-child::before {
  content: "That would be ";
}

.p-team-member:not(:only-child):last-child:before {
  content: "…and ";
}

/* -------------------------------------------------------------------------- */
/*                                Proj Gallery                                */
.gallery__item:not(p) {
  margin-block-end: var(--layout-unit);
}

/* -------------------------------------------------------------------------- */
/*                             Proj Pagination Nav                            */
.proj__nav-wrapper {
  display: flex;
  width: 100%;
  padding-inline: var(--layout-unit);
  padding-block-start: calc(var(--unit-B) * 3);
  justify-content: flex-end;
}

.proj__nav {
  padding-bottom: 0;
}

.proj__nav-item {
  min-width: min(100%, 36ch);
  flex: 0 1 calc((100% - var(--layout-unit)) / 2);
}

.proj__nav-label {
  margin-block-end: 1em;
}

.proj__nav-link {
  text-decoration: none;
  display: block;
  padding: var(--unit-C) var(--unit-C) calc(var(--unit-C) * 1.9) var(--unit-C);
  margin-bottom: calc(var(--unit-C) * -1);
  border: var(--border-width) solid var(--foreground-color);
  border-bottom: none;
  border-radius: var(--unit-E) var(--unit-E) 0 0;
  transition: all 300ms var(--ease-curve-B);
}

.proj__nav-link:hover {
  background-color: var(--foreground-color);
  color: var(--background-color);
  rotate: -2.5deg;
  translate: -2.5% -7%;
  border-radius: var(--unit-E);
  scale: 1.01;
  outline: 6px solid var(--background-color);
}

.proj__nav-name {
  margin-inline-start: -0.055em;
}

/* -------------------------------------------------------------------------- */
/*                              Indiv About Page                              */
/* -------------------------------------------------------------------------- */
/*                              INDIV ABOUT PAGE                              */
/* -------------------------------------------------------------------------- */
.about__intro,
.about__experience {
  padding-bottom: var(--unit-A);
}

.about__intro {
  display: flex;
  flex-wrap: wrap;
  gap: var(--layout-unit);
  row-gap: calc(4 * var(--layout-unit));
}

.about__intro-heading,
.about__intro-copy {
  min-width: 20ch;
}

.about__intro-heading {
  flex: 1 1 20%;
  display: flex;
  flex-direction: column;
  gap: var(--layout-unit);
}

.about__subheading {
  margin-bottom: var(--unit-F);
}

.about__subheading + p {
  width: min(42ch, 100%);
}

.abt_name-block {
  display: block;
}

.name-label {
  margin-bottom: var(--unit-F);
}

.about__intro-copy {
  margin-block-start: -0.675rem;
  flex: 1 1 70.5%;
}

.about__intro {
  padding-block-start: calc(2.25 * var(--unit-A));
  padding-bottom: 0;
}

.about__graf {
  font-size: calc(var(--fsz-B) * 1);
  font-weight: 400;
  font-stretch: 70%;
  margin-bottom: 1em;
  letter-spacing: -0.03em;
  line-height: 1.4;
}

.about__conf {
  padding-block: var(--unit-C);
}

.about__conf-wrapper {
  grid-column: 7/-1;
  gap: var(--layout-unit);
}

.about__conf-heading {
  margin-bottom: 1em;
}

.conf__list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--unit-F);
}

.conf__card,
.conf__item:last-of-type {
  display: block;
  padding: calc(var(--unit-F) * 1.125) var(--unit-E) var(--unit-F);
  border: var(--border-width) solid transparent;
  border-radius: var(--border-radius);
  text-decoration: none;
  transition: all 500ms var(--ease-curve-B);
}

.conf__item:not(:last-of-type) .conf__card {
  background-color: var(--fg-glass);
  color: var(--background-color);
}

.conf__item:last-of-type {
  border-color: var(--foreground-color);
}

.conf__card:hover {
  background-color: var(--foreground-color);
}

.conf__item:nth-child(odd) .conf__card:hover {
  transform: rotate(-2deg);
}

.conf__item:nth-child(even) .conf__card:hover {
  transform: rotate(2deg);
}

.conf__list {
  grid-column: 7/-1;
}

.about__exp-wrapper,
.about__conf,
.about__conf-wrapper {
  grid-template-columns: var(--base-columns);
}

.about__exp-wrapper {
  gap: var(--layout-unit);
}

.exp__heading,
.about__conf-heading {
  margin-bottom: var(--unit-D);
  grid-column: 1/span 3;
}

.exp__list {
  grid-column: 7/-1;
}

.about__experience,
.exp__item {
  font-weight: 300;
}

.exp__item {
  margin-bottom: var(--unit-D);
}

.exp__item-heading,
.exp__item-heading__org {
  margin-bottom: 0.5rem;
}

.exp__item-heading {
  line-height: var(--lh-C);
  font-size: var(--fsz-C);
}

.exp__item-heading__org {
  display: block;
  margin-top: 0.25rem;
}

.exp__item-subheading,
.exp__item-scope {
  margin-bottom: 0;
}

.exp__item-desc {
  font-size: 0.9em;
  margin-bottom: 0.5rem;
}

.experiments__hero {
  padding-block-start: calc(2.25 * var(--unit-A));
}

.experiments__gallery {
  display: flex;
  flex-wrap: wrap;
  gap: var(--layout-unit);
}

.experiments__card,
.card-copy {
  display: flex;
  flex-direction: column;
}

.experiments__card {
  flex: 1 0 min(30ch, 100%);
  gap: var(--layout-unit);
  margin-bottom: calc(2 * var(--layout-unit));
}

.exp-heading,
.exp__copy-title {
  margin-block-end: var(--unit-F);
}

.exp__copy-info {
  font-weight: 400;
  margin-block-end: var(--unit-E);
}

@media (min-width: 970px) {
  /* -------------------------------------------------------------------------- */
  /*                                  !! Header                                 */
  .header__content,
  .toggle--menu,
  .toggle--menu--label,
  .toggle--menu--label::before,
  .toggle--menu--label::after,
  .toggle--theme--label {
    position: static;
  }
  .toggle--menu::after,
  .toggle--menu--label::before,
  .toggle--menu--label::after {
    content: none;
  }
  .toggle--menu:not(:checked) ~ .content__wrapper .nav__item {
    transform: translateY(0em);
    opacity: 1;
    pointer-events: unset;
  }
  .header {
    display: grid;
    grid-template-columns: var(--base-columns);
    gap: var(--layout-unit);
    width: 100%;
  }
  .header__content {
    grid-column: 7/-1;
    padding: 0;
    display: flex;
  }
  .content__wrapper {
    flex-direction: row;
    justify-content: space-between;
  }
  .theme__input,
  .logo-link {
    z-index: 100;
  }
  .theme__input {
    position: static;
  }
  .nav {
    order: initial;
  }
  .nav__wrapper {
    flex-direction: row;
    gap: var(--layout-unit);
  }
  .nav__item {
    background: none;
    border: none;
    -webkit-backdrop-filter: none;
            backdrop-filter: none;
  }
  .list-item .link,
  .nav__link {
    overflow-x: clip;
  }
  .nav__link,
  .link {
    pointer-events: all;
    padding: 0;
    color: var(--foreground-color);
  }
  .nav__link::after,
  .footer .link::after {
    content: "";
    display: block;
    width: 110%;
    height: 0;
    border-top: var(--border-width) solid var(--foreground-color);
    margin-block-start: 0.125em;
    background-color: var(--foreground-color);
    margin-left: -110%;
  }
  /*TODO - make sure in correct place, organizational*/
  .footer .link {
    text-decoration: none;
    position: relative;
  }
  .nav__link:hover::after,
  .footer .link:hover::after {
    animation: underline 1.25s ease infinite;
  }
  .header .coming-soon::before {
    -webkit-backdrop-filter: blur(var(--blur-strength));
            backdrop-filter: blur(var(--blur-strength));
    padding: 0 0.25em;
    translate: 0 0em;
  }
  .toggle--menu--label {
    display: none;
  }
  .toggle--theme--label,
  .theme__input::after {
    height: 1.25rem;
  }
  .toggle--theme--label {
    aspect-ratio: 1/2;
  }
  /* -------------------------------------------------------------------------- */
  /*                              !!! Home - hero                              */
  /* -------------------------------------------------------------------------- */
  .main__hero-caption {
    margin-left: auto;
    margin-block: 10rem 0;
  }
  /* -------------------------------------------------------------------------- */
  /*                              !!! Home - Projs                              */
  /* -------------------------------------------------------------------------- */
  .home--work__svg {
    position: static;
    translate: -50% -50%;
  }
  .home--work__svg,
  .featured-projects {
    grid-row-start: 1;
  }
  .home--work__svg,
  .feature:first-of-type {
    grid-column: 6/-1;
  }
  .home--projects,
  .project-gallery,
  .featured-projects {
    display: grid;
    gap: var(--layout-unit);
    grid-template-columns: var(--base-columns);
  }
  .home--projects {
    scroll-margin-top: 16rem;
  }
  .project-gallery,
  .featured-projects {
    grid-column: 1/-1;
  }
  .featured-projects {
    grid-auto-flow: row dense;
  }
  .feature {
    display: block;
  }
  .feature:nth-child(2) {
    align-self: end;
  }
  .listed-projects {
    grid-column: 2/span 8;
  }
  /* -------------------------------------------------------------------------- */
  /*                               !! Project Page                              */
  .hero__copy {
    display: grid;
    grid-template-columns: var(--base-columns);
  }
  .hero__title {
    grid-column: 1/span 9;
  }
  .hero__question {
    margin-inline-end: 0;
    grid-column: -1/-4;
  }
  .p__gallery {
    display: grid;
    grid-template-columns: var(--base-columns);
    gap: var(--layout-unit);
  }
  .gallery__item:not(p) {
    margin-block-end: 0;
  }
  /* -------------------------------------------------------------------------- */
  /*                          !! Project Pagination Nav                         */
  .proj__nav {
    justify-content: end;
  }
  /* -------------------------------------------------------------------------- */
  /*                          !!  INDIV ABOUT PAGE                              */
  .about__intro {
    flex-direction: column;
    row-gap: var(--layout-unit);
  }
  .about__intro-heading {
    flex-direction: row;
  }
  .about__exp-wrapper,
  .about__conf-wrapper {
    display: grid;
    gap: var(--layout-unit);
  }
  /* -------------------------------------------------------------------------- */
  /*                                 !!! Footer                                 */
  /* -------------------------------------------------------------------------- */
  /* -------------------------------------------------------------------------- */
  /*                               !!! Footer bar                               */
  /* -------------------------------------------------------------------------- */
  .footer__bar {
    padding-block: var(--unit-A) var(--unit-C);
  }
}
@media (prefers-color-scheme: dark) {
  :root {
    --foreground-color: var(--main-bright);
    --background-color: var(--main-night);
    --fg-glass: var(--bright-glass);
    --bg-glass: var(--night-glass);
  }
}
@media (prefers-reduced-motion: reduce) {
  .home--work__svg,
  .footer-svg {
    animation: none;
  }
}/*# sourceMappingURL=style.css.map */