@font-face {
  font-family: "Cabin Graham";
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url("../dynamic/fonts/cabin/cabin.woff2") format("woff2");
}

.home-template {
  --body-font: "Cabin Graham", "Cabin", Arial, sans-serif;
  --heading-font: var(--body-font);
  --logo-font: var(--body-font);
  --menu-font: var(--body-font);
  --page-bg: #fff;
  --text-color: #1c1c1c;
  --link-color: #434343;
  --link-color-hover: #000;
  --nav-link-color: #1c1c1c;
  --nav-link-color-hover: #000;
  --logo-color: #1c1c1c;
  background: #f1f1f1;
  color: #1c1c1c;
  font-family: var(--body-font);
  font-size: 16px;
  isolation: isolate;
  line-height: 1.5;
  min-height: 100vh;
  position: relative;
}

html.graham-theme-dark body.home-template,
html.graham-theme-dark body:is(.page-template, .blogindex-template, .post-template) {
  background: #3b3b3b;
}

html.graham-theme-dark:has(body.home-template),
html.graham-theme-dark:has(body.page-template),
html.graham-theme-dark:has(body.blogindex-template),
html.graham-theme-dark:has(body.post-template) {
  background: #3b3b3b;
}

.home-template::before {
  background: #fff;
  bottom: 0;
  box-shadow: 0 0 9px rgba(0, 0, 0, 0.14);
  content: "";
  left: 50%;
  max-width: 100%;
  position: absolute;
  top: 0;
  transform: translateX(-50%);
  width: 1280px;
  z-index: -1;
}

.home-template .top {
  height: 54px;
  margin: 0 auto;
  max-width: 1280px;
  padding: 0 28px;
  width: 100%;
}

.home-template .top,
body:is(.page-template, .blogindex-template, .post-template) .top {
  background: transparent;
  isolation: isolate;
  overflow: visible;
}

.home-template .top::before,
body:is(.page-template, .blogindex-template, .post-template) .top::before {
  -webkit-backdrop-filter: blur(4px) saturate(120%);
  backdrop-filter: blur(4px) saturate(120%);
  background: rgba(255, 255, 255, 0.76);
  content: "";
  inset: 0;
  pointer-events: none;
  position: absolute;
  z-index: 0;
}

.home-template .top::after,
body:is(.page-template, .blogindex-template, .post-template) .top::after {
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter2'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter2)'/%3E%3C/svg%3E");
  content: "";
  inset: 0;
  opacity: 0.035;
  pointer-events: none;
  position: absolute;
  z-index: 0;
}

.home-template .top > *,
body:is(.page-template, .blogindex-template, .post-template) .top > * {
  position: relative;
  z-index: 1;
}

.home-template .top > .graham-glass-edge,
body:is(.page-template, .blogindex-template, .post-template) .top > .graham-glass-edge {
  --graham-edge-thickness: 2px;
  -webkit-backdrop-filter: blur(3px) brightness(112%) saturate(120%);
  backdrop-filter: blur(3px) brightness(112%) saturate(120%);
  background: rgba(255, 255, 255, 0.13);
  bottom: auto;
  height: var(--graham-edge-thickness);
  left: 0;
  pointer-events: none;
  position: absolute;
  right: 0;
  top: 54px;
  transition: background 220ms ease, -webkit-backdrop-filter 220ms ease, backdrop-filter 220ms ease;
  z-index: 0;
}

.home-template .top a,
body:is(.page-template, .blogindex-template, .post-template) .top a {
  transition: none;
}

.top.sticky.is-shown {
  animation: none;
  opacity: 1;
  top: 0;
}

.top.sticky.is-showing {
  animation: graham-header-slide-down 0.435s cubic-bezier(0, 0, 0.9, 1) forwards;
}

.top.sticky.is-hiding,
.top.sticky.is-shown.is-hiding {
  animation: graham-header-slide-up 0.435s cubic-bezier(0, 0, 0.9, 1) forwards;
}

@keyframes graham-header-slide-down {
  from {
    top: -100px;
  }

  to {
    top: 0;
  }
}

@keyframes graham-header-slide-up {
  from {
    top: 0;
  }

  to {
    top: -100px;
  }
}

.home-template .logo {
  font-family: var(--body-font);
  font-size: 20px;
  font-variation-settings: "wght" 400;
  line-height: 1;
  text-transform: lowercase;
}

.home-template .navbar .navbar__menu {
  column-gap: 26px;
}

.home-template .navbar .navbar__menu li {
  font-family: var(--body-font);
  font-size: 16px;
  font-variation-settings: "wght" 400;
  text-transform: uppercase;
}

.home-template .navbar .navbar__menu li a {
  padding: 0;
}

.home-template .navbar {
  margin-right: 0;
}

.home-template .navbar .navbar__menu > li:first-child > a,
.home-template .navbar .navbar__menu > li.active > a,
.home-template .navbar .navbar__menu > li.is-active > a {
  font-variation-settings: "wght" 700;
  font-weight: 700;
}

.graham-theme-toggle-item {
  align-items: center;
  display: inline-flex;
  font-size: 0 !important;
  line-height: 0;
}

.graham-theme-toggle {
  --graham-toggle-size: 12px;
  --graham-toggle-hit-pad: 10px;
  --graham-toggle-symbol: #3c3c3c;
  --graham-toggle-cutout: rgba(255, 255, 255, 0.98);
  cursor: pointer;
  display: inline-block;
  flex: 0 0 var(--graham-toggle-size);
  height: var(--graham-toggle-size);
  line-height: 0;
  margin: 0;
  overflow: visible;
  position: relative;
  transform: translateY(6px);
  width: var(--graham-toggle-size);
}

.graham-theme-toggle::before {
  border-radius: 999px;
  content: "";
  inset: calc(var(--graham-toggle-hit-pad) * -1);
  position: absolute;
}

html.graham-theme-dark .graham-theme-toggle {
  --graham-toggle-symbol: #d7d7d7;
}

.graham-theme-toggle input {
  cursor: pointer;
  height: calc(var(--graham-toggle-size) + (var(--graham-toggle-hit-pad) * 2));
  left: calc(var(--graham-toggle-hit-pad) * -1);
  margin: 0;
  opacity: 0;
  position: absolute;
  top: calc(var(--graham-toggle-hit-pad) * -1);
  width: calc(var(--graham-toggle-size) + (var(--graham-toggle-hit-pad) * 2));
  z-index: 2;
}

.graham-theme-toggle input + div {
  border-radius: 50%;
  box-shadow: inset 4.8px -4.8px 0 0 var(--graham-toggle-symbol);
  display: block;
  height: var(--graham-toggle-size);
  position: relative;
  transform: scale(1) rotate(-2deg);
  transition: box-shadow 500ms ease, transform 400ms ease 100ms;
  width: var(--graham-toggle-size);
}

.graham-theme-toggle input + div::before {
  border-radius: inherit;
  content: "";
  display: block;
  height: inherit;
  left: 0;
  position: absolute;
  top: 0;
  transition: background 300ms ease;
  width: inherit;
}

.graham-theme-toggle input + div::after {
  background: var(--graham-toggle-symbol);
  border-radius: 50%;
  box-shadow:
    0 -8px 0 var(--graham-toggle-symbol),
    0 8px 0 var(--graham-toggle-symbol),
    8px 0 0 var(--graham-toggle-symbol),
    -8px 0 0 var(--graham-toggle-symbol),
    5.65px 5.65px 0 var(--graham-toggle-symbol),
    -5.65px 5.65px 0 var(--graham-toggle-symbol),
    5.65px -5.65px 0 var(--graham-toggle-symbol),
    -5.65px -5.65px 0 var(--graham-toggle-symbol);
  content: "";
  display: block;
  height: 1.8px;
  left: 50%;
  margin: -0.9px 0 0 -0.9px;
  position: absolute;
  top: 50%;
  transform: scale(0);
  transition: transform 300ms ease;
  width: 1.8px;
}

.graham-theme-toggle input:checked + div {
  box-shadow: inset 12px -12px 0 0 var(--graham-toggle-cutout);
  transform: scale(0.58) rotate(0deg);
  transition: box-shadow 500ms ease, transform 220ms ease-out;
}

.graham-theme-toggle input:checked + div::before {
  background: var(--graham-toggle-symbol);
  transition: background 300ms ease 100ms;
}

.graham-theme-toggle input:checked + div::after {
  transform: scale(1.72);
  transition: transform 340ms ease-out 140ms;
}

.graham-default-nav .navbar__menu {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1rem;
}

.graham-nav-toggle {
  background: transparent;
  border: 0;
  border-radius: 0;
  color: #1c1c1c;
  display: none;
  height: 40px;
  justify-content: center;
  margin: 0;
  padding: 10px 8px;
  width: 40px;
}

.graham-nav-toggle:active,
.graham-nav-toggle:focus,
.graham-nav-toggle:hover {
  background: transparent;
  color: #1c1c1c;
}

.graham-burger {
  cursor: pointer;
  display: block;
  height: 18px;
  position: relative;
  width: 22px;
}

.graham-burger span {
  background-color: currentColor;
  border-radius: 2px;
  display: block;
  height: 2px;
  left: 0;
  position: absolute;
  transition: all 300ms ease-in-out;
  width: 100%;
}

.graham-burger span:nth-child(1) {
  top: 1px;
}

.graham-burger span:nth-child(2) {
  top: 8px;
}

.graham-burger span:nth-child(3) {
  top: 15px;
}

.graham-burger.active span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.graham-burger.active span:nth-child(2) {
  opacity: 0;
  transform: translateX(-10px);
}

.graham-burger.active span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

.graham-home {
  margin: 26px auto 0;
  max-width: var(--graham-home-width);
  width: calc(100% - 2rem);
}

.graham-home__section + .graham-home__section {
  margin-top: var(--graham-section-gap);
}

.graham-video-frame {
  aspect-ratio: 1.724 / 1;
  overflow: hidden;
  width: 100%;
}

.graham-video-frame iframe {
  border: 0;
  display: block;
  height: 100%;
  width: 100%;
}

.graham-carousel__slides {
  aspect-ratio: 1.344 / 1;
  overflow: hidden;
  position: relative;
  width: 100%;
}

.graham-carousel__slide,
.graham-carousel__slide.is-loaded {
  display: block;
  height: 100%;
  inset: 0;
  opacity: 0;
  object-fit: cover;
  position: absolute;
  transition: none;
  width: 100%;
}

.graham-carousel__slide.is-active,
.graham-carousel__slide.is-active.is-loaded {
  opacity: 1;
  z-index: 1;
}

.graham-carousel__arrow {
  align-items: center;
  background: rgba(30, 30, 30, 0.72);
  border: 0;
  border-radius: 50%;
  color: #fff;
  display: flex;
  height: 48px;
  justify-content: center;
  margin: 0;
  opacity: 0;
  padding: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  transition: background-color 120ms ease-out, opacity 160ms ease-out;
  visibility: hidden;
  width: 48px;
  z-index: 2;
}

.graham-carousel__slides:hover .graham-carousel__arrow,
.graham-carousel__arrow:focus-visible {
  opacity: 1;
  visibility: visible;
}

.graham-carousel__arrow:hover,
.graham-carousel__arrow:focus {
  background: rgba(30, 30, 30, 0.84);
  color: #fff;
}

.graham-carousel__arrow--previous {
  left: 10px;
}

.graham-carousel__arrow--next {
  right: 10px;
}

.graham-carousel__arrow span {
  border-bottom: 3px solid currentColor;
  border-left: 3px solid currentColor;
  display: block;
  height: 12px;
  width: 12px;
}

.graham-carousel__arrow--previous span {
  margin-left: 5px;
  transform: rotate(45deg);
}

.graham-carousel__arrow--next span {
  margin-right: 5px;
  transform: rotate(225deg);
}

.graham-carousel__dots {
  align-items: center;
  display: flex;
  font-size: 0;
  gap: 13px;
  height: 10px;
  justify-content: center;
  line-height: 0;
  margin-top: 20px;
}

.graham-carousel__dots button {
  -webkit-appearance: none;
  appearance: none;
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  display: block;
  flex: 0 0 10px;
  height: 10px;
  line-height: 0;
  margin: 0 !important;
  min-height: 0;
  min-width: 0;
  overflow: visible;
  padding: 0;
  position: relative;
  transform: none;
  transition: flex-basis 300ms ease, margin-left 300ms ease, width 300ms ease;
  width: 10px;
}

.graham-carousel__dots button::before {
  background: #c9c9c9;
  border-radius: 50%;
  content: "";
  display: block;
  height: 10px;
  left: 50%;
  opacity: 1;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%) scale(1);
  transform-origin: center;
  transition: background-color 300ms ease, opacity 300ms ease, transform 300ms ease;
  width: 10px;
}

.graham-carousel__dots button.is-active::before {
  background: #252525;
}

.graham-carousel__dots button.is-dot-hidden {
  flex-basis: 0;
  margin-left: -13px !important;
  pointer-events: none;
  width: 0;
}

.graham-carousel__dots button.is-dot-hidden::before {
  opacity: 0;
  transform: translate(-50%, -50%) scale(0);
}

.graham-carousel__dots button.is-dot-small::before {
  transform: translate(-50%, -50%) scale(0.7);
}

.graham-carousel__dots button.is-dot-tiny::before {
  opacity: 0.85;
  transform: translate(-50%, -50%) scale(0.45);
}

.graham-carousel__dots button:hover::before,
.graham-carousel__dots button:focus::before {
  background: #646464;
}

.graham-home__promo {
  color: #434343;
  font-size: 16px;
  line-height: 1.5;
  margin: 20px 0 0;
  text-align: center;
}

.graham-home__promo a {
  text-decoration: underline;
}

.graham-home__mentions {
  align-items: start;
  display: grid;
  gap: 27px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.graham-home__mentions > * {
  min-width: 0;
}

.graham-home__gallery + .graham-home__mentions {
  margin-top: 60px;
}

.graham-home__mentions ~ .graham-home__tiles {
  margin-top: var(--graham-mention-tile-gap, 64px);
}

.graham-home__mentions .twitter-tweet {
  border: 0;
  color: #1c1c1c;
  font-family: Georgia, serif;
  font-size: 16px;
  font-style: normal;
  font-variation-settings: normal;
  margin: 0;
  padding: 0;
}

.graham-home__mentions .twitter-tweet footer {
  font-size: 15px;
  margin-top: 12px;
}

.graham-home__tiles {
  display: grid;
  gap: 27px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.graham-home__tiles a {
  display: block;
}

.graham-home__tiles img {
  aspect-ratio: 1.607 / 1;
  display: block;
  object-fit: cover;
  width: 100%;
}

.footer__social img {
  display: inline-block;
  height: 44px;
  margin: 0 3px;
  opacity: 1;
  transition: opacity 100ms ease-out;
  width: 44px;
}

.footer__social:hover img {
  opacity: 0.65;
}

.footer__social:hover a:hover img {
  opacity: 1;
}

.home-template .footer {
  border-top: 0;
  margin: 78px auto 0;
  max-width: var(--graham-home-width, 65.5rem);
  padding-bottom: 29px;
  padding-top: 0;
  text-align: center;
}

.home-template .footer__social {
  display: inline-flex;
  gap: 6px;
  justify-content: center;
}

.home-template .footer__social a,
.home-template .footer__social img,
.home-template .footer__social svg {
  display: block;
}

.home-template .footer__social img,
.home-template .footer__social svg {
  height: 44px;
  margin: 0;
  width: 44px;
}

body:is(.page-template, .blogindex-template, .post-template) {
  --body-font: "Cabin Graham", "Cabin", Arial, sans-serif;
  --heading-font: var(--body-font);
  --logo-font: var(--body-font);
  --menu-font: var(--body-font);
  --page-bg: #fff;
  --text-color: #1c1c1c;
  --link-color: #79acbe;
  --link-color-hover: #557e8e;
  --nav-link-color: #1c1c1c;
  --nav-link-color-hover: #000;
  --logo-color: #1c1c1c;
  background: #f1f1f1;
  color: #434343;
  display: flex;
  flex-direction: column;
  font-family: var(--body-font);
  font-size: 16px;
  isolation: isolate;
  line-height: 1.55;
  min-height: 100vh;
  position: relative;
}

body:is(.page-template, .blogindex-template, .post-template)::before {
  background: #fff;
  bottom: 0;
  box-shadow: 0 0 9px rgba(0, 0, 0, 0.14);
  content: "";
  left: 50%;
  max-width: 100%;
  position: absolute;
  top: 0;
  transform: translateX(-50%);
  width: 1280px;
  z-index: -1;
}

body:is(.page-template, .blogindex-template, .post-template) .top {
  flex: 0 0 auto;
  height: 54px;
  margin: 0 auto;
  max-width: 1280px;
  padding: 0 28px;
  width: 100%;
}

body:is(.page-template, .blogindex-template, .post-template) .logo {
  font-family: var(--body-font);
  font-size: 20px;
  font-variation-settings: "wght" 400;
  line-height: 1;
  text-transform: lowercase;
}

body:is(.page-template, .blogindex-template, .post-template) .navbar {
  margin-right: 0;
}

body:is(.page-template, .blogindex-template, .post-template) .navbar .navbar__menu {
  column-gap: 26px;
}

body:is(.page-template, .blogindex-template, .post-template) .navbar .navbar__menu li {
  font-family: var(--body-font);
  font-size: 16px;
  font-variation-settings: "wght" 400;
  text-transform: uppercase;
}

body:is(.page-template, .blogindex-template, .post-template) .navbar .navbar__menu li a {
  padding: 0;
}

body:is(.page-template, .blogindex-template, .post-template) .graham-default-nav .navbar__menu > li:first-child > a {
  font-variation-settings: "wght" 400;
  font-weight: 400;
}

body.graham-page--about .graham-default-nav .navbar__menu > li:nth-child(4) > a,
body.graham-page--about .navbar .navbar__menu > li.active > a,
body.graham-page--about .navbar .navbar__menu > li.is-active > a {
  font-variation-settings: "wght" 700;
  font-weight: 700;
}

body.graham-page--portfolio .graham-default-nav .navbar__menu > li:nth-child(2) > a,
body.graham-page--portfolio .navbar .navbar__menu > li.active > a,
body.graham-page--portfolio .navbar .navbar__menu > li.is-active > a {
  font-variation-settings: "wght" 700;
  font-weight: 700;
}

body.graham-page--blog .graham-default-nav .navbar__menu > li:nth-child(3) > a,
body.graham-page--blog .navbar .navbar__menu > li.active > a,
body.graham-page--blog .navbar .navbar__menu > li.is-active > a {
  font-variation-settings: "wght" 700;
  font-weight: 700;
}

.graham-about {
  flex: 1 0 auto;
  margin: 87px auto 0;
  max-width: var(--graham-home-width, 1154px);
  width: calc(100% - 2rem);
}

.graham-about__title {
  color: #434343;
  font-family: var(--body-font);
  font-size: 30px;
  font-variation-settings: "wght" 400;
  font-weight: 400;
  line-height: 1.2;
  margin: 0 0 89px;
  text-align: center;
  text-transform: uppercase;
}

.graham-about__entry {
  color: #434343;
  font-size: 16px;
  line-height: 1.55;
}

.graham-about__card {
  background: transparent;
  margin: 0 auto;
  max-width: 984px;
  padding: 29px;
  position: relative;
}

.graham-about__card::before {
  background: #f7f7f7;
  box-shadow: 0 3px 7px -3px rgba(0, 0, 0, 0.18), 3px 2px 7px -5px rgba(0, 0, 0, 0.14), -3px 2px 7px -5px rgba(0, 0, 0, 0.14);
  content: "";
  inset: 6px 68px 18px;
  position: absolute;
}

.graham-about__layout {
  align-items: stretch;
  display: grid;
  gap: clamp(28px, 3.82vw, 44px);
  grid-template-columns: minmax(290px, 440px) minmax(245px, 306px);
  justify-content: center;
  margin: 0 auto;
  max-width: 790px;
  position: relative;
  z-index: 1;
}

.graham-about__portrait {
  align-self: stretch;
  margin: 6px 0 18px;
  min-height: 0;
  overflow: hidden;
  position: relative;
}

.graham-about__portrait img {
  display: block;
  height: 100%;
  inset: 0;
  min-height: 0;
  object-fit: contain;
  object-position: center top;
  position: absolute;
  width: 100%;
}

.graham-about__entry h2 {
  color: #434343;
  font-family: var(--body-font);
  font-size: 16px;
  font-variation-settings: "wght" 700;
  font-weight: 700;
  line-height: 1.55;
  margin: 0 0 13px;
}

.graham-about__entry h2:not(:first-child) {
  margin-top: 13px;
}

.graham-about__entry p {
  margin: 0 0 13px;
}

.graham-about__entry a {
  color: #79acbe;
}

.graham-about__entry a:hover {
  color: #557e8e;
}

.graham-portfolio {
  flex: 1 0 auto;
  margin: 87px auto 0;
  max-width: var(--graham-home-width, 1154px);
  width: calc(100% - 2rem);
}

.graham-portfolio__title {
  color: #434343;
  font-family: var(--body-font);
  font-size: 30px;
  font-variation-settings: "wght" 400;
  font-weight: 400;
  line-height: 1.2;
  margin: 0 0 54px;
  text-align: center;
  text-transform: uppercase;
}

.graham-portfolio__videos {
  display: grid;
  gap: 27px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin: 0 auto;
  max-width: 870px;
  padding: 32px 0 0;
}

.graham-portfolio__video-item {
  margin: 0;
  text-align: center;
}

.graham-portfolio__video {
  background: transparent;
  border: 0;
  cursor: pointer;
  display: block;
  margin: 0;
  overflow: hidden;
  padding: 0;
  position: relative;
  width: 100%;
}

.graham-portfolio__video-thumbnail {
  display: block;
  height: auto;
  width: 100%;
}

.graham-portfolio__video:hover,
.graham-portfolio__video:focus,
.graham-portfolio__video:active {
  background: transparent;
  color: inherit;
}

.graham-portfolio__video-play {
  height: auto;
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  transition: transform 180ms ease-out;
  width: 48px;
}

.graham-portfolio__video:hover .graham-portfolio__video-play,
.graham-portfolio__video:focus-visible .graham-portfolio__video-play {
  transform: translate(-50%, -50%) scale(1.045);
}

.graham-portfolio__video-title {
  color: #686868;
  display: block;
  font-family: var(--body-font);
  font-size: 16px;
  font-variation-settings: "wght" 400;
  font-weight: 400;
  font-style: normal;
  line-height: 1.45;
  margin-top: 3px;
  position: relative;
  top: -11px;
}

.graham-portfolio__project {
  margin: 23px auto 0;
  padding-top: 32px;
  position: relative;
}

.graham-portfolio__project::before {
  background: linear-gradient(90deg, transparent, #dfdfdf 12%, #dfdfdf 88%, transparent);
  content: "";
  height: 1px;
  left: 0;
  position: absolute;
  right: 0;
  top: 0;
}

.graham-portfolio__heading {
  color: #686868;
  font-family: var(--body-font);
  font-size: 16px;
  font-variation-settings: "wght" 400;
  font-weight: 400;
  line-height: 1.5;
  margin: 0 0 17px;
  text-align: center;
}

.graham-portfolio__project .graham-carousel {
  margin: 0 auto;
  max-width: 870px;
}

.graham-portfolio__vr-images {
  display: grid;
  gap: 27px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin: 50px auto 0;
  max-width: 870px;
}

.graham-portfolio__vr-images img,
.graham-portfolio__gallery img {
  display: block;
  height: auto;
  width: 100%;
}

.graham-portfolio__vr-pair {
  display: grid;
  gap: 27px;
}

.graham-portfolio__gallery {
  display: grid;
  gap: 27px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin: 34px auto 0;
  padding-top: 32px;
  position: relative;
}

.graham-portfolio__gallery::before {
  background: linear-gradient(90deg, transparent, #dfdfdf 12%, #dfdfdf 88%, transparent);
  content: "";
  height: 1px;
  left: 0;
  position: absolute;
  right: 0;
  top: 0;
}

.graham-portfolio__gallery-column {
  display: grid;
  gap: 27px;
  height: max-content;
}

.graham-portfolio__vr-images img.graham-portfolio__lightbox-trigger,
.graham-portfolio__gallery img.graham-portfolio__lightbox-trigger {
  cursor: zoom-in;
}

body.graham-lightbox-open {
  overflow: hidden;
}

.graham-lightbox {
  align-items: center;
  background: rgba(0, 0, 0, 0.92);
  display: none;
  inset: 0;
  justify-content: center;
  padding: 48px 38px;
  position: fixed;
  z-index: 1000;
}

.graham-lightbox.is-open {
  display: flex;
}

.graham-lightbox__stage {
  align-items: center;
  display: flex;
  height: 100%;
  justify-content: center;
  max-height: calc(100vh - 96px);
  max-width: 100%;
  position: relative;
  width: 100%;
}

.graham-lightbox__image {
  display: block;
  height: auto;
  max-height: 100%;
  max-width: 100%;
  object-fit: contain;
  width: auto;
}

.graham-lightbox__close {
  background: transparent;
  border: 0;
  color: #e7e7e7;
  cursor: pointer;
  height: 42px;
  margin: 0;
  padding: 0;
  position: absolute;
  right: 17px;
  top: 15px;
  width: 42px;
  z-index: 3;
}

.graham-lightbox__close::before,
.graham-lightbox__close::after {
  background: currentColor;
  content: "";
  height: 2px;
  left: 10px;
  position: absolute;
  top: 20px;
  transform: rotate(45deg);
  width: 22px;
}

.graham-lightbox__close::after {
  transform: rotate(-45deg);
}

.graham-lightbox__close:hover,
.graham-lightbox__close:focus-visible {
  color: #fff;
}

.graham-lightbox__stage:hover .graham-carousel__arrow,
.graham-lightbox__stage .graham-carousel__arrow:focus-visible {
  opacity: 1;
  visibility: visible;
}

.graham-video-lightbox__frame {
  aspect-ratio: 16 / 9;
  background: #000;
  width: min(100%, 1480px, calc((100vh - 96px) * 16 / 9));
}

.graham-video-lightbox__frame iframe {
  border: 0;
  display: block;
  height: 100%;
  width: 100%;
}

.graham-video-lightbox__frame.is-portrait {
  aspect-ratio: 9 / 16;
  width: min(100%, 630px, calc((100vh - 96px) * 9 / 16));
}

.graham-blog {
  flex: 1 0 auto;
  margin: 87px auto 0;
  max-width: var(--graham-home-width, 1154px);
  width: calc(100% - 2rem);
}

.graham-blog__title {
  color: #434343;
  font-family: var(--body-font);
  font-size: 30px;
  font-variation-settings: "wght" 400;
  font-weight: 400;
  line-height: 1.2;
  margin: 0 0 82px;
  text-align: center;
  text-transform: uppercase;
}

.graham-blog__feed {
  display: grid;
  gap: 34px;
  margin: 0 auto;
  max-width: 984px;
  padding: 0;
}

.graham-blog__item {
  --graham-feed-image-width: 320px;
  align-items: start;
  background: #f7f7f7;
  box-shadow: 0 3px 7px -3px rgba(0, 0, 0, 0.18), 3px 2px 7px -5px rgba(0, 0, 0, 0.14), -3px 2px 7px -5px rgba(0, 0, 0, 0.14);
  display: grid;
  gap: 42px;
  grid-template-columns: var(--graham-feed-image-width) minmax(0, 1fr);
  margin: 0;
  padding: 29px;
}

.graham-blog__item:not(:has(.feed__image)) {
  grid-template-columns: 1fr;
  margin-left: auto;
  margin-right: auto;
  max-width: 762px;
  width: 100%;
}

.graham-blog__item .feed__image {
  aspect-ratio: 16 / 9;
  height: auto;
  margin: 0;
  width: var(--graham-feed-image-width);
}

.graham-blog__item .feed__image img {
  border-radius: 0;
  display: block;
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.graham-blog__entry {
  color: #434343;
  display: flex;
  flex-direction: column;
  font-family: var(--body-font);
  font-size: 16px;
  line-height: 1.55;
  text-align: left;
}

.graham-blog__item:has(.feed__image) .graham-blog__entry {
  min-height: calc(var(--graham-feed-image-width) * 9 / 16);
}

.graham-blog__entry .feed__meta {
  color: #777;
  font-family: var(--body-font);
  font-size: 14px;
  font-style: normal;
  gap: 14px;
  margin: 0 0 19px;
}

.graham-blog__entry .feed__author,
.graham-blog__entry .feed__date {
  color: #666;
}

.graham-blog__entry .feed__title {
  font-family: var(--body-font);
  font-size: 29px;
  font-variation-settings: "wght" 400;
  font-weight: 400;
  line-height: 1.25;
  margin: -7px 0 18px;
}

.graham-blog__entry .feed__title a {
  color: #343434;
}

.graham-blog__entry p {
  color: #434343;
  margin: 0 0 23px;
}

.graham-blog__entry .feed__readmore {
  align-self: flex-start;
  color: #5c899a;
  display: inline-block;
  font-family: var(--body-font);
  font-size: 16px;
  font-style: normal;
  margin-top: 0;
  text-decoration: underline;
}

.graham-blog__item:has(.feed__image) .feed__readmore {
  margin-top: auto;
  transform: translateY(4px);
}

@media all and (min-width: 63.5rem) {
  .graham-blog__item:has(.feed__image) .graham-blog__entry {
    height: calc(var(--graham-feed-image-width) * 9 / 16);
    min-height: 0;
    overflow: clip;
    overflow-clip-margin: 6px;
  }

  .graham-blog__item:has(.feed__image) .graham-blog__entry p {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    overflow: hidden;
  }
}

.graham-blog .pagination {
  margin-top: 15px;
}

.graham-post {
  flex: 1 0 auto;
  margin: 87px auto 0;
  max-width: var(--graham-home-width, 1154px);
  width: calc(100% - 2rem);
}

.graham-post .hero {
  margin: 0 auto;
  max-width: 720px;
}

.graham-post .hero--noimage::after {
  content: none;
  display: none;
}

.graham-post .hero__content {
  padding: 0;
}

.graham-post .hero__content .wrapper {
  max-width: none;
  padding: 0;
}

.graham-post .hero__content h1 {
  color: #343434;
  font-family: var(--body-font);
  font-size: 29px;
  font-variation-settings: "wght" 400;
  font-weight: 400;
  line-height: 1.25;
  margin: 0;
}

.graham-post .content__meta {
  color: #666;
  font-family: var(--body-font);
  font-size: 14px;
  margin-top: 9px;
}

.graham-post .content__entry,
.graham-post .content__footer .entry-wrapper {
  color: #434343;
  font-family: var(--body-font);
  font-size: 16px;
  line-height: 1.65;
  margin-left: auto;
  margin-right: auto;
  max-width: 720px;
}

.graham-post .content__nav .wrapper {
  max-width: 1026px;
  padding-left: 0;
  padding-right: 0;
  width: calc(100% - 2rem);
}

.graham-post .content__nav-inner {
  --graham-post-nav-gap: 32px;
  border-bottom: 0;
  border-top: 0;
  display: flex;
  gap: var(--graham-post-nav-gap);
  justify-content: space-between;
  padding: var(--graham-post-nav-gap) 0;
  position: relative;
}

.graham-post .content__nav-inner::before,
.graham-post .content__nav-inner::after {
  background: linear-gradient(90deg, transparent, #dfdfdf 12%, #dfdfdf 88%, transparent);
  content: "";
  height: 1px;
  left: 0;
  position: absolute;
  right: 0;
}

.graham-post .content__nav-inner::before {
  top: 0;
}

.graham-post .content__nav-inner::after {
  bottom: 0;
}

.graham-post .content__nav-link {
  --graham-post-nav-label-gap: var(--baseline);
  align-items: flex-start;
  flex-direction: column;
  font-style: normal;
  gap: var(--graham-post-nav-label-gap);
  justify-content: flex-start;
  width: calc(4rem * 16 / 9);
}

.graham-post .content__nav-link > div {
  font-style: normal;
  width: 100%;
}

.graham-post .content__nav-link span {
  margin-bottom: 0;
}

.graham-post .content__nav-next .content__nav-link {
  align-items: flex-end;
}

.graham-post .content__nav-prev + .content__nav-next {
  margin-left: auto;
  margin-top: 0;
}

.graham-post .content__nav-next .content__nav-image {
  order: 0;
}

.graham-post .content__nav-next .content__nav-link > div {
  order: 1;
  text-align: right;
}

.graham-post .content__nav-image {
  aspect-ratio: 16 / 9;
  flex: 0 0 auto;
  height: 4rem;
  width: calc(4rem * 16 / 9);
}

.graham-post .content__nav-image > img {
  height: 100%;
  object-fit: cover;
  width: 100%;
}

@media all and (min-width: 37.5em) and (max-width: 56.1875em) {
  .graham-post .content__nav-link {
    width: min(18rem, calc(50vw - 3rem));
  }

  .graham-post .content__nav-image {
    flex-basis: auto;
    height: 6rem;
    width: calc(6rem * 16 / 9);
  }
}

@media all and (min-width: 56.25em) {
  .graham-post .content__nav-prev {
    transform: translateX(50px);
  }

  .graham-post .content__nav-next {
    transform: translateX(-50px);
  }

  .graham-post .content__nav-link {
    width: 21.5rem;
  }

  .graham-post .content__nav-image {
    flex-basis: auto;
    height: 8rem;
    width: calc(8rem * 16 / 9);
  }
}

@media all and (max-width: 37.4375em) {
  .graham-post .content__nav-inner {
    --graham-post-nav-gap: 24px;
  }
}

body:is(.page-template, .blogindex-template, .post-template) .footer {
  border-top: 0;
  flex: 0 0 auto;
  margin: 66px auto 0;
  max-width: var(--graham-home-width, 65.5rem);
  padding-bottom: 29px;
  padding-top: 0;
  text-align: center;
}

body:is(.page-template, .blogindex-template, .post-template) .footer__social {
  display: inline-flex;
  gap: 6px;
  justify-content: center;
}

body:is(.page-template, .blogindex-template, .post-template) .footer__social a,
body:is(.page-template, .blogindex-template, .post-template) .footer__social img,
body:is(.page-template, .blogindex-template, .post-template) .footer__social svg {
  display: block;
}

body:is(.page-template, .blogindex-template, .post-template) .footer__social img,
body:is(.page-template, .blogindex-template, .post-template) .footer__social svg {
  height: 44px;
  margin: 0;
  width: 44px;
}

@media all and (max-width: 56.1875em) {
  .home-template .top {
    align-items: center;
    display: flex;
    height: 54px;
    padding-left: 28px;
    padding-right: 28px;
    padding-top: 0;
  }

  body:is(.page-template, .blogindex-template, .post-template) .top {
    align-items: center;
    display: flex;
    height: 54px;
    padding-left: 28px;
    padding-right: 28px;
    padding-top: 0;
  }

  .home-template .logo {
    display: block;
    margin-bottom: 0;
  }

  body:is(.page-template, .blogindex-template, .post-template) .logo {
    display: block;
    margin-bottom: 0;
  }

  .graham-default-nav .navbar__menu {
    display: flex;
  }

  .home-template .navbar {
    margin-right: 0;
  }

  body:is(.page-template, .blogindex-template, .post-template) .navbar {
    margin-right: 0;
  }

  .graham-home {
    margin-top: 26px;
  }

  .graham-about {
    margin-top: 62px;
  }

  .graham-portfolio {
    margin-top: 62px;
  }

  .graham-blog,
  .graham-post {
    margin-top: 62px;
  }
}

@media all and (max-width: 42rem) {
  html:has(body.home-template),
  html:has(body.page-template),
  html:has(body.blogindex-template),
  html:has(body.post-template) {
    background: #fff;
  }

  .home-template .top,
  body:is(.page-template, .blogindex-template, .post-template) .top {
    overflow: visible;
  }

  .home-template .top .logo,
  body:is(.page-template, .blogindex-template, .post-template) .top .logo {
    left: 28px;
    position: absolute;
    top: 17px;
  }

  .home-template .top::before,
  body:is(.page-template, .blogindex-template, .post-template) .top::before,
  .home-template .top::after,
  body:is(.page-template, .blogindex-template, .post-template) .top::after {
    bottom: auto;
    height: 54px;
    top: 0;
    transition: height 300ms ease-in-out;
  }

  .home-template .top > .graham-glass-edge,
  body:is(.page-template, .blogindex-template, .post-template) .top > .graham-glass-edge {
    transition: top 300ms ease-in-out;
  }

  .home-template .top.is-menu-open::before,
  body:is(.page-template, .blogindex-template, .post-template) .top.is-menu-open::before,
  .home-template .top.is-menu-open::after,
  body:is(.page-template, .blogindex-template, .post-template) .top.is-menu-open::after {
    height: 110px;
  }

  .home-template .top.is-menu-open > .graham-glass-edge,
  body:is(.page-template, .blogindex-template, .post-template) .top.is-menu-open > .graham-glass-edge {
    top: 110px;
  }

  .graham-default-nav {
    margin-left: auto;
    position: static !important;
  }

  .graham-nav-toggle {
    display: flex;
    position: absolute;
    right: 20px;
    top: 7px;
  }

  .graham-default-nav .navbar__menu {
    align-items: center;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 22px;
    justify-content: center;
    left: 0;
    margin: 0;
    opacity: 0;
    pointer-events: none;
    position: absolute;
    right: 0;
    top: 68px;
    transition: opacity 95ms ease-out, visibility 0s linear 95ms;
    visibility: hidden;
    width: 100%;
    z-index: 1;
  }

  .top.is-menu-open .graham-default-nav .navbar__menu {
    opacity: 1;
    pointer-events: auto;
    transition-delay: 190ms, 0s;
    visibility: visible;
  }

  .top.is-menu-open .graham-theme-toggle {
    transform: translateY(0);
  }

  .graham-home__mentions,
  .graham-portfolio__videos,
  .graham-portfolio__vr-images,
  .graham-portfolio__gallery,
  .graham-blog__item {
    grid-template-columns: 1fr;
  }

  .graham-home__tiles {
    gap: clamp(8px, 3vw, 27px);
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .graham-home__mentions {
    grid-template-columns: minmax(0, 1fr);
  }

  .graham-home__mentions iframe,
  .graham-home__mentions .twitter-tweet-rendered {
    max-width: 100% !important;
    min-width: 0 !important;
    width: 100% !important;
  }

  .graham-home__promo {
    margin-top: 26px;
  }

  .graham-about__layout {
    gap: 34px;
    grid-template-columns: 1fr;
  }

  .graham-about__card {
    padding: 20px;
  }

  .graham-about__card::before {
    inset: 0;
  }

  .graham-about__portrait {
    margin: 0 auto;
    max-width: 354px;
    position: static;
  }

  .graham-about__portrait img {
    height: auto;
    position: static;
  }

  .graham-portfolio__title {
    margin-bottom: 40px;
  }

  .graham-portfolio__videos {
    padding: 24px 0 0;
  }

  .graham-portfolio__video-play {
    width: 44px;
  }

  .graham-portfolio__project {
    margin-top: 23px;
  }

  .graham-lightbox {
    padding: 54px 14px 24px;
  }

  .graham-lightbox__stage {
    max-height: calc(100vh - 78px);
  }

  .graham-video-lightbox__frame {
    width: min(100%, calc((100vh - 78px) * 16 / 9));
  }

  .graham-video-lightbox__frame.is-portrait {
    width: min(100%, calc((100vh - 78px) * 9 / 16));
  }

  .graham-lightbox__stage .graham-carousel__arrow {
    height: 44px;
    width: 44px;
  }

  .graham-blog__title {
    margin-bottom: 44px;
  }

  .graham-blog__feed {
    gap: 28px;
  }

  .graham-blog__item {
    gap: 24px;
    padding: 20px;
  }

  .graham-blog__item .feed__image {
    aspect-ratio: 16 / 9;
    height: auto;
    width: 100%;
  }

  .graham-blog__item:has(.feed__image) .graham-blog__entry {
    min-height: 0;
  }

  .graham-blog__item:has(.feed__image) .feed__readmore {
    margin-top: 0;
    transform: none;
  }

  .graham-blog__entry .feed__title {
    font-size: 25px;
    margin-top: 0;
  }

  .graham-post .hero__content h1 {
    font-size: 30px;
  }
}

:root {
  color-scheme: light;
  --white: #fff;
  --black: #17181e;
  --helper: #fff;
  --dark: #17181e;
  --gray: #57585a;
  --light: #cacbcf;
  --lighter: #f3f3f3;
  --page-bg: #fff;
  --color: #d73a42;
  --text-color: #17181e;
  --headings-color: #17181e;
  --link-color: #17181e;
  --link-color-hover: #d73a42;
  --nav-link-color: #17181e;
  --nav-link-color-hover: #17181e;
  --logo-color: #17181e;
}

html.graham-theme-dark {
  color-scheme: dark;
  --white: #f6f3ee;
  --black: #171717;
  --helper: #202020;
  --dark: #ece8e0;
  --gray: #b0ada8;
  --light: #4c4c4c;
  --lighter: #292929;
  --page-bg: #202020;
  --color: #8fc1d4;
  --text-color: #d9d6d1;
  --headings-color: #f0eee9;
  --link-color: #8fc1d4;
  --link-color-hover: #b7ddeb;
  --nav-link-color: #efefef;
  --nav-link-color-hover: #fff;
  --logo-color: #efefef;
}

html.graham-theme-dark body.home-template,
html.graham-theme-dark body:is(.page-template, .blogindex-template, .post-template) {
  --page-bg: #202020;
  --text-color: #e8e6e3;
  --link-color: #8fc1d4;
  --link-color-hover: #b7ddeb;
  --nav-link-color: #efefef;
  --nav-link-color-hover: #fff;
  --logo-color: #efefef;
  background: #171717;
  color: #d9d6d1;
}

html.graham-theme-dark:has(body.home-template),
html.graham-theme-dark:has(body.page-template),
html.graham-theme-dark:has(body.blogindex-template),
html.graham-theme-dark:has(body.post-template) {
  background: #171717;
}

html.graham-theme-dark body.home-template::before,
html.graham-theme-dark body:is(.page-template, .blogindex-template, .post-template)::before {
  background: #202020;
  box-shadow: 0 0 12px rgba(0, 0, 0, 0.46);
}

html.graham-theme-dark .home-template .top::before,
html.graham-theme-dark body:is(.page-template, .blogindex-template, .post-template) .top::before {
  -webkit-backdrop-filter: blur(4px) saturate(108%);
  backdrop-filter: blur(4px) saturate(108%);
  background: rgba(32, 32, 32, 0.76);
}

html.graham-theme-dark .home-template .top::after,
html.graham-theme-dark body:is(.page-template, .blogindex-template, .post-template) .top::after {
  opacity: 0.05;
}

html.graham-theme-dark .home-template .top > .graham-glass-edge,
html.graham-theme-dark body:is(.page-template, .blogindex-template, .post-template) .top > .graham-glass-edge {
  -webkit-backdrop-filter: blur(3px) saturate(110%);
  backdrop-filter: blur(3px) saturate(110%);
  background: rgba(32, 32, 32, 0.13);
}

html.graham-theme-to-light .home-template .top > .graham-glass-edge,
html.graham-theme-to-light body:is(.page-template, .blogindex-template, .post-template) .top > .graham-glass-edge {
  transition: background 240ms linear, -webkit-backdrop-filter 240ms linear, backdrop-filter 240ms linear;
}

html.graham-theme-dark .home-template .logo,
html.graham-theme-dark body:is(.page-template, .blogindex-template, .post-template) .logo,
html.graham-theme-dark .home-template .navbar .navbar__menu li a,
html.graham-theme-dark body:is(.page-template, .blogindex-template, .post-template) .navbar .navbar__menu li a,
html.graham-theme-dark .graham-nav-toggle,
html.graham-theme-dark .graham-nav-toggle:active,
html.graham-theme-dark .graham-nav-toggle:focus,
html.graham-theme-dark .graham-nav-toggle:hover {
  color: #efefef;
}

html.graham-theme-dark .home-template .navbar .navbar__menu li a:hover,
html.graham-theme-dark body:is(.page-template, .blogindex-template, .post-template) .navbar .navbar__menu li a:hover,
html.graham-theme-dark .home-template .navbar .navbar__menu li a:focus-visible,
html.graham-theme-dark body:is(.page-template, .blogindex-template, .post-template) .navbar .navbar__menu li a:focus-visible {
  color: #fff;
}

html.graham-theme-dark .graham-theme-toggle {
  --graham-toggle-symbol: #d7d7d7;
  --graham-toggle-cutout: #202020;
}

html.graham-theme-dark .graham-home__promo,
html.graham-theme-dark .graham-about__title,
html.graham-theme-dark .graham-about__entry,
html.graham-theme-dark .graham-about__entry h2,
html.graham-theme-dark .graham-portfolio__title,
html.graham-theme-dark .graham-portfolio__heading,
html.graham-theme-dark .graham-portfolio__video-title,
html.graham-theme-dark .graham-blog__title,
html.graham-theme-dark .graham-blog__entry,
html.graham-theme-dark .graham-blog__entry p,
html.graham-theme-dark .graham-post .content__entry,
html.graham-theme-dark .graham-post .content__footer .entry-wrapper,
html.graham-theme-dark .content__entry,
html.graham-theme-dark .content__entry p,
html.graham-theme-dark .content__entry li,
html.graham-theme-dark .content__entry h1,
html.graham-theme-dark .content__entry h2,
html.graham-theme-dark .content__entry h3,
html.graham-theme-dark .content__entry h4,
html.graham-theme-dark .content__entry h5,
html.graham-theme-dark .content__entry h6 {
  color: #d9d6d1;
}

html.graham-theme-dark .graham-about__title,
html.graham-theme-dark .graham-portfolio__title,
html.graham-theme-dark .graham-blog__title,
html.graham-theme-dark .graham-blog__entry .feed__title a,
html.graham-theme-dark .graham-post .hero__content h1 {
  color: #f0eee9;
}

html.graham-theme-dark .graham-home__promo a,
html.graham-theme-dark .graham-about__entry a,
html.graham-theme-dark .graham-blog__entry .feed__readmore,
html.graham-theme-dark .readmore,
html.graham-theme-dark .graham-post a,
html.graham-theme-dark .content__entry a,
html.graham-theme-dark .content__nav-link {
  color: #8fc1d4;
}

html.graham-theme-dark .graham-home__promo a:hover,
html.graham-theme-dark .graham-about__entry a:hover,
html.graham-theme-dark .graham-blog__entry .feed__readmore:hover,
html.graham-theme-dark .readmore:hover,
html.graham-theme-dark .graham-post a:hover,
html.graham-theme-dark .content__entry a:hover,
html.graham-theme-dark .content__nav-link:hover {
  color: #b7ddeb;
}

html.graham-theme-dark .graham-home__mentions .twitter-tweet {
  color: #d9d6d1;
}

html.graham-theme-dark .graham-about__card::before,
html.graham-theme-dark .graham-blog__item {
  background: #292929;
  box-shadow:
    0 4px 10px -6px rgba(0, 0, 0, 0.86),
    3px 3px 11px -7px rgba(0, 0, 0, 0.72),
    -3px 3px 11px -7px rgba(0, 0, 0, 0.72),
    inset 0 1px 0 rgba(255, 255, 255, 0.035);
}

html.graham-theme-dark .graham-blog__entry .feed__meta,
html.graham-theme-dark .graham-blog__entry .feed__author,
html.graham-theme-dark .graham-blog__entry .feed__date,
html.graham-theme-dark .graham-post .content__meta,
html.graham-theme-dark .content__updated,
html.graham-theme-dark .content__entry figcaption,
html.graham-theme-dark .content__entry .caption,
html.graham-theme-dark .content__nav-link span,
html.graham-theme-dark .content__nav-link small {
  color: #b0ada8;
}

html.graham-theme-dark .feed__author + .feed__date::before {
  background: rgba(255, 255, 255, 0.22);
}

html.graham-theme-dark .graham-portfolio__project::before,
html.graham-theme-dark .graham-portfolio__gallery::before,
html.graham-theme-dark .graham-post .content__nav-inner::before,
html.graham-theme-dark .graham-post .content__nav-inner::after {
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 255, 255, 0.16) 12%,
    rgba(255, 255, 255, 0.16) 88%,
    transparent
  );
}

html.graham-theme-dark .graham-carousel__dots button::before {
  background: #777;
}

html.graham-theme-dark .graham-carousel__dots button.is-active::before {
  background: #efefef;
}

html.graham-theme-dark .graham-carousel__dots button:hover::before,
html.graham-theme-dark .graham-carousel__dots button:focus::before {
  background: #bcbcbc;
}

html.graham-theme-dark .footer__social img {
  filter: invert(1) brightness(0.92);
}

html.graham-theme-dark .footer__social:hover img {
  opacity: 0.48;
}

html.graham-theme-dark .footer__social:hover a:hover img {
  opacity: 0.92;
}

html.graham-theme-dark .content__entry blockquote,
html.graham-theme-dark .content__entry table,
html.graham-theme-dark .content__entry th,
html.graham-theme-dark .content__entry td,
html.graham-theme-dark .content__entry figure {
  border-color: rgba(255, 255, 255, 0.16);
}

html.graham-theme-dark .content__entry table,
html.graham-theme-dark .content__entry th {
  background: rgba(255, 255, 255, 0.035);
}

html.graham-theme-dark .content__entry hr {
  background: rgba(255, 255, 255, 0.16);
}

html.graham-theme-dark .content__share-popup,
html.graham-theme-dark .msg,
html.graham-theme-dark pre,
html.graham-theme-dark code {
  background-color: #292929;
}

html.graham-theme-dark .content__share-popup > a:hover {
  background: #202020;
}

html.graham-theme-dark .content__tag > li > a,
html.graham-theme-dark .content__share-button,
html.graham-theme-dark .footer__bttop,
html.graham-theme-dark .btn,
html.graham-theme-dark [type="button"],
html.graham-theme-dark [type="submit"],
html.graham-theme-dark button {
  border-color: rgba(255, 255, 255, 0.28);
  color: #d9d6d1;
}

html.graham-theme-dark .content__tag > li > a:hover,
html.graham-theme-dark .content__share-button:hover,
html.graham-theme-dark .footer__bttop:hover,
html.graham-theme-dark .btn:hover,
html.graham-theme-dark [type="button"]:hover,
html.graham-theme-dark [type="submit"]:hover,
html.graham-theme-dark button:hover {
  border-color: rgba(255, 255, 255, 0.42);
}

html.graham-theme-dark .graham-nav-toggle,
html.graham-theme-dark .graham-nav-toggle:hover,
html.graham-theme-dark .graham-nav-toggle:focus,
html.graham-theme-dark .graham-nav-toggle:active,
html.graham-theme-dark .graham-portfolio__video,
html.graham-theme-dark .graham-portfolio__video:hover,
html.graham-theme-dark .graham-portfolio__video:focus,
html.graham-theme-dark .graham-portfolio__video:active,
html.graham-theme-dark .graham-lightbox__close,
html.graham-theme-dark .graham-lightbox__close:hover {
  background: transparent;
}

html.graham-theme-dark ::selection {
  background: rgba(143, 193, 212, 0.34);
  color: #fff;
}

@media all and (max-width: 42rem) {
  html.graham-theme-dark:has(body.home-template),
  html.graham-theme-dark:has(body.page-template),
  html.graham-theme-dark:has(body.blogindex-template),
  html.graham-theme-dark:has(body.post-template) {
    background: #202020;
  }
}

@media (prefers-reduced-motion: no-preference) {
  body.home-template,
  body:is(.page-template, .blogindex-template, .post-template),
  .home-template::before,
  body:is(.page-template, .blogindex-template, .post-template)::before,
  .home-template .top::before,
  body:is(.page-template, .blogindex-template, .post-template) .top::before,
  .graham-about__card::before,
  .graham-blog__item,
  .graham-about__title,
  .graham-portfolio__title,
  .graham-blog__title,
  .graham-post .hero__content h1,
  .graham-blog__entry .feed__title a,
  .graham-home__promo,
  .graham-about__entry,
  .graham-blog__entry,
  .graham-post .content__entry,
  .content__entry,
  .footer__social img {
    transition:
      background-color 180ms ease,
      background 180ms ease,
      border-color 180ms ease,
      box-shadow 180ms ease,
      color 180ms ease,
      filter 180ms ease,
      opacity 100ms ease-out;
  }
}
