:root {
  --primary: #7eb5be;
  --secondary: #005f6b;
  --text: #f3f7f6;
  --text-muted: #cad2da;
  --interactive-muted: var(--text-muted);
  --bg-dark: #000000;
  --radius: 16px;
  --site-header-height: 65px;
  --site-footer-block-size: 6.5625rem;

  /* Hero */
  --hero-size-scale: 0.85;

  /* Rim */
  --rim-thickness: 1.08;
  --rim-brightness: 6;
  --rim-surface-brightness: 0.8;
  --rim-reaction-distance: 0.75;
  --rim-surface-transmission: clamp(0, var(--rim-surface-brightness), 1);
  --rim-surface-block-alpha: calc(1 - var(--rim-surface-transmission));
  --rim-surface-block: rgb(0 6 7 / var(--rim-surface-block-alpha));
  --rim-static-alpha: calc(
    var(--rim-brightness) * 0.6666667 * clamp(0, var(--rim-thickness), 1)
  );
  --rim-static-width: max(0px, calc(var(--rim-thickness) * 0.9259259px));
  --rim-static-focus-width: max(0px, calc(var(--rim-thickness) * 2.7777778px));
  --rim-static-photo-width: max(0px, calc(var(--rim-thickness) * 1.8518519px));

  /* Glass blur */
  --nav-bg-blur: 2px;
  --footer-bg-blur: 2px;
  --hero-bg-blur: 1px;
  --button-bg-blur: 2px;
  --cta-bg-blur: 2px;
  --card-layer-1-bg-blur: 2px;
  --card-layer-2-bg-blur: 3px;
  --card-layer-3-bg-blur: 4px;
  --form-layer-1-bg-blur: var(--card-layer-1-bg-blur);
  --form-layer-2-bg-blur: var(--card-layer-2-bg-blur);
  --modal-bg-blur: 2px;
  --card-bg-brightness: 1;
  --cta-bg-brightness: 1;

  /* Glass tint */
  --nav-bg-tint: #0a0a0a;
  --footer-bg-tint: #0a0a0a;
  --hero-bg-tint: #ffffff;
  --button-bg-tint: #7eb5be;
  --cta-bg-tint: #0a0a0a;
  --card-layer-1-bg-tint: #ffffff;
  --card-layer-2-bg-tint: #ffffff;
  --card-layer-3-bg-tint: #7eb5be;
  --form-layer-1-bg-tint: var(--card-layer-1-bg-tint);
  --form-layer-2-bg-tint: var(--card-layer-2-bg-tint);
  --modal-bg-tint: #0a1619;

  /* Blobs */
  --blob-color-1: #00ffaa;
  --blob-color-2: #00ddff;
  --blob-color-3: #0059ff;
  --blob-color-cycle-speed: 1;
  --blob-max-size: 0.7;
  --blob-intensity: 0.5;
  --blob-grow-1: 1;
  --blob-grow-2: 1;
  --blob-grow-3: 1;
  --blob-grow-4: 1;
  --blob-grow-5: 1;
  --blob-grow-cursor: 1;
  --blob-rim-interaction: 1;
}

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

html {
  scrollbar-gutter: stable;
  overflow-x: clip;
  overflow-y: scroll;
}

.combined-page-section {
  scroll-margin-top: clamp(5rem, 10vh, 7.5rem);
}

#home {
  scroll-margin-top: 0;
}

body {
  font-family:
    "Roboto",
    system-ui,
    -apple-system,
    sans-serif;
  background: var(--bg-dark);
  color: var(--text);
  -webkit-font-smoothing: antialiased;
  line-height: 1.6;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  position: relative;
  max-width: 100%;
  overflow-x: clip;
  padding-top: var(--site-header-height);
}

@supports not (overflow: clip) {
  html,
  body {
    overflow-x: hidden;
  }
}

body:has(.home-bg) {
  padding-top: 0;
}

#dot-canvas,
#bg-canvas {
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100vh;
  height: 100lvh;
  height: 100dvh;
  pointer-events: none;
  display: none;
}

#dot-canvas {
  /* Below the blob canvas. */
  z-index: -2;
}

#bg-canvas {
  z-index: -1;
}

body.picture-bg-on #dot-canvas,
body.webgpu-active #bg-canvas {
  display: block;
}

body > main {
  flex: 1;
}

.viewport-render-ready .viewport-render-unit.viewport-render-culled {
  height: var(--viewport-render-block-size, auto);
  min-height: var(--viewport-render-block-size, auto);
  overflow: hidden !important;
  visibility: hidden !important;
  pointer-events: none !important;
  transform: none !important;
  filter: none !important;
  transition: none !important;
  animation: none !important;
  will-change: auto !important;
}

.viewport-render-ready
  .viewport-render-unit.viewport-render-culled:not(
    .viewport-render-measurable
  ) {
  content-visibility: hidden !important;
  contain: layout style paint;
  contain-intrinsic-size: var(--viewport-render-block-size, 40rem);
}

.viewport-render-ready
  .viewport-render-unit.viewport-render-culled:not(.viewport-render-measurable)
  > * {
  display: none !important;
}

.viewport-render-ready
  .viewport-render-unit.viewport-render-culled:not(.viewport-render-measurable)
  :is(video, iframe, canvas) {
  display: none !important;
}

.viewport-render-ready .viewport-render-unit.viewport-render-culled:focus-within {
  content-visibility: visible !important;
  contain: none;
  height: auto;
  min-height: 0;
  overflow: visible !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

/* Elements with reactive rim controls. */
.btn,
.filter-btn,
.badge,
.site-header,
.site-footer,
.card,
.card-dark,
.resume-card,
.story-card,
.project-preview,
.project-details-panel,
.contact-layout,
.mission-overlay,
.cta-banner,
.field-glass,
.interest-icon,
.form-group input,
.form-group textarea,
.about-photo-ring,
.hero-arrow-glass {
  --btn-rim-alpha: 1; /* Rim opacity. */
  --btn-rim-cutoff: 0.02; /* Rim threshold. */
  --btn-rim-falloff: 1; /* Rim contrast. */
  --btn-rim-tint: #ffffff; /* Rim color multiplier. */
}

:where(
  .site-header,
  .site-footer,
  .hero-heading,
  .btn,
  .filter-btn,
  .badge,
  .card,
  .card-dark,
  .resume-card,
  .story-card,
  .project-preview,
  .project-details-panel,
  .contact-layout,
  .mission-overlay,
  .cta-banner,
  .field-glass,
  .interest-icon,
  .about-photo-ring,
  .hero-arrow-glass
) {
  position: relative;
  isolation: isolate;
  border-color: transparent !important;
  --ui-rim-size: max(0px, calc(var(--rim-thickness) * 1px));
  --ui-rim-pad-top: var(--ui-rim-size);
  --ui-rim-pad-right: var(--ui-rim-size);
  --ui-rim-pad-bottom: var(--ui-rim-size);
  --ui-rim-pad-left: var(--ui-rim-size);
  --ui-rim-clip-top: 0px;
  --ui-rim-clip-right: 0px;
  --ui-rim-clip-bottom: 0px;
  --ui-rim-clip-left: 0px;
  --ui-rim-background:
    radial-gradient(
      circle at var(--ui-rim-pm, 50% 50%),
      var(--ui-rim-cm, transparent) 0,
      transparent var(--ui-rim-rm, 0px)
    ),
    radial-gradient(
      circle at var(--ui-rim-p1, 50% 50%),
      var(--ui-rim-c1, transparent) 0,
      transparent var(--ui-rim-r1, 0px)
    ),
    radial-gradient(
      circle at var(--ui-rim-p2, 50% 50%),
      var(--ui-rim-c2, transparent) 0,
      transparent var(--ui-rim-r2, 0px)
    ),
    radial-gradient(
      circle at var(--ui-rim-p3, 50% 50%),
      var(--ui-rim-c3, transparent) 0,
      transparent var(--ui-rim-r3, 0px)
    ),
    radial-gradient(
      circle at var(--ui-rim-p4, 50% 50%),
      var(--ui-rim-c4, transparent) 0,
      transparent var(--ui-rim-r4, 0px)
    ),
    radial-gradient(
      circle at var(--ui-rim-p5, 50% 50%),
      var(--ui-rim-c5, transparent) 0,
      transparent var(--ui-rim-r5, 0px)
    );
}

:where(
    .site-header,
    .site-footer,
    .btn,
    .filter-btn,
    .badge,
    .card,
    .card-dark,
    .resume-card,
    .story-card,
    .project-preview,
    .project-details-panel,
    .contact-layout,
    .mission-overlay,
    .cta-banner,
    .field-glass,
    .interest-icon,
    .about-photo-ring,
    .hero-arrow-glass
  )::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  border-radius: inherit;
  padding: var(--ui-rim-pad-top, var(--ui-rim-size))
    var(--ui-rim-pad-right, var(--ui-rim-size))
    var(--ui-rim-pad-bottom, var(--ui-rim-size))
    var(--ui-rim-pad-left, var(--ui-rim-size));
  background: var(--ui-rim-background);
  opacity: min(
    1,
    calc(
      var(--ui-rim-opacity, 0) * var(--btn-rim-alpha, 1) *
        clamp(0, var(--rim-thickness), 1)
    )
  );
  -webkit-mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  mask-composite: exclude;
}

a {
  color: inherit;
  text-decoration: none;
}

:where(a[href], button, [role="link"], [role="button"]) {
  cursor: pointer;
  -webkit-tap-highlight-color: rgba(126, 181, 190, 0.18);
}

:where(a[href], button, [role="link"], [role="button"]):focus-visible {
  outline: 2px solid rgba(212, 250, 255, 0.75);
  outline-offset: 3px;
}

:where(
  .logo,
  .nav-toggle,
  .reactive-letter,
  .read-more-btn,
  .resume-card a,
  .badge,
  .badge i,
  .si-icon,
  .interest-icon,
  body > main a[href]:not(.btn):not(.hero-arrow)
) {
  --inline-muted-color: var(--interactive-muted);
  --inline-reactive-color: color-mix(
    in srgb,
    var(--ui-blob-accent-color, var(--inline-muted-color))
      var(--ui-blob-accent-mix, 0%),
    var(--inline-muted-color)
  );
  --inline-reactive-glow: var(--ui-blob-accent-glow, transparent);
}

body > main a[href]:not(.btn):not(.hero-arrow) {
  color: var(--interactive-muted);
  text-shadow: none;
  transition:
    color 0.2s ease,
    text-shadow 0.2s ease;
}

.reactive-letter {
  display: inline-block;
  color: var(--inline-reactive-color);
  text-shadow: 0 0 12px var(--inline-reactive-glow);
  transition:
    color 0.2s ease,
    text-shadow 0.2s ease;
}

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

.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1.5rem;
}

.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  --btn-glow-alpha: 0; /* Header glow. */
  --chrome-glass-tint-alpha: 0; /* Header tint. */
  --chrome-glass-noise: 2; /* Header shader noise. */
  --glass-chrome-backdrop-filter: blur(var(--nav-bg-blur)) saturate(140%);
  --nav-chrome-opacity: 0.68; /* Header chrome opacity. */
  z-index: 300;
  overflow: visible;
  border-bottom: 1px solid
    rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha)));
  background: color-mix(
    in srgb,
    var(--nav-bg-tint) var(--chrome-glass-tint-mix, 9.425%),
    transparent
  );
  backdrop-filter: var(--glass-chrome-backdrop-filter);
  -webkit-backdrop-filter: var(--glass-chrome-backdrop-filter);
  transition:
    transform 0.35s ease,
    opacity 0.25s ease;
  will-change: transform;
}

.site-header.has-chrome-glass,
.site-footer.has-chrome-glass,
.site-nav.has-chrome-glass {
  background: transparent;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.site-header.has-chrome-glass {
  background: rgba(10, 10, 10, 0.02925);
  backdrop-filter: var(--glass-chrome-backdrop-filter);
  -webkit-backdrop-filter: var(--glass-chrome-backdrop-filter);
}

.site-header,
.site-header.has-chrome-glass,
.site-footer,
.site-footer.has-chrome-glass {
  background-image: linear-gradient(
    var(--rim-surface-block),
    var(--rim-surface-block)
  );
}

.chrome-glass-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 0;
}

.site-header > .chrome-glass-canvas {
  opacity: calc(
    var(--nav-chrome-opacity) * 0.1625 * var(--rim-surface-transmission)
  );
}

.site-footer > .chrome-glass-canvas {
  opacity: calc(0.11050000000000001 * var(--rim-surface-transmission));
}

.site-header.site-header--hidden {
  transform: translateY(-100%);
  opacity: 0;
  pointer-events: none;
}

.header-inner {
  position: relative;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 64px;
}

.logo {
  display: inline-flex;
  font-size: calc(clamp(1.75rem, 5.3vw, 2.5rem) * 0.8);
  font-weight: 700;
  color: var(--inline-reactive-color);
  letter-spacing: -0.02em;
  transition:
    color 0.24s ease,
    text-shadow 0.24s ease,
    transform 0.24s ease;
}

.logo:hover,
.logo:focus-visible {
  color: var(--inline-reactive-color);
  text-shadow: 0 0 16px var(--inline-reactive-glow);
  transform: translateY(-1px);
}

.site-nav {
  position: relative;
  z-index: 3;
  display: flex;
  align-items: center;
}

.site-nav > .chrome-glass-canvas {
  display: none;
}

.nav-links {
  position: relative;
  z-index: 3;
  display: flex;
  list-style: none;
  gap: 2rem;
}

.nav-links a {
  --nav-muted-active: var(--interactive-muted);
  --nav-active-color: color-mix(
    in srgb,
    var(--ui-blob-accent-color, var(--nav-muted-active))
      var(--ui-blob-accent-mix, 0%),
    var(--nav-muted-active)
  );
  --nav-indicator-color: var(--nav-active-color);
  --nav-indicator-glint: color-mix(
    in srgb,
    var(--ui-blob-accent-color, var(--nav-indicator-color))
      var(--ui-blob-accent-mix, 0%),
    var(--nav-indicator-color)
  );
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--nav-muted-active);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  transition:
    color 0.24s ease,
    text-shadow 0.24s ease;
  position: relative;
}

.nav-links a::after {
  content: "";
  --nav-underline-cycle: 84px;
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 100%;
  height: 2px;
  opacity: 0;
  transform: scaleX(0.45);
  transform-origin: center;
  background: linear-gradient(
    90deg,
    transparent 0%,
    transparent 16%,
    color-mix(in srgb, var(--nav-indicator-color) 10%, transparent) 24%,
    color-mix(in srgb, var(--nav-indicator-color) 68%, transparent) 48%,
    var(--nav-indicator-glint) 56%,
    color-mix(in srgb, var(--nav-indicator-color) 18%, transparent) 72%,
    transparent 84%,
    transparent 100%
  );
  background-position: 0 50%;
  background-repeat: repeat-x;
  background-size: var(--nav-underline-cycle) 100%;
  border-radius: 1px;
  -webkit-mask-image: linear-gradient(
    90deg,
    transparent 0%,
    #000 12%,
    #000 88%,
    transparent 100%
  );
  mask-image: linear-gradient(
    90deg,
    transparent 0%,
    #000 12%,
    #000 88%,
    transparent 100%
  );
  transition:
    opacity 0.22s ease,
    transform 0.3s ease;
  will-change: opacity, transform, background-position;
}

.nav-links a:hover::after,
.nav-links a:focus-visible::after {
  opacity: 1;
  transform: scaleX(1);
  animation: nav-gradient-flow 9s linear infinite;
}

.nav-links a:hover,
.nav-links a:focus-visible,
.nav-links a.active {
  color: var(--nav-muted-active);
  text-shadow: 0 0 12px rgba(243, 247, 246, 0.16);
}

.nav-links a.active::after {
  opacity: 1;
  transform: scaleX(1);
  animation: nav-gradient-flow 9s linear infinite;
}

@keyframes nav-gradient-flow {
  from {
    background-position: 0 50%;
  }
  to {
    background-position: var(--nav-underline-cycle) 50%;
  }
}

@media (prefers-reduced-motion: reduce) {
  .nav-links a:hover::after,
  .nav-links a.active::after {
    animation: none;
  }
}

.nav-toggle {
  display: none;
  background-color: transparent;
  background-image: none;
  border: 0;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  color: var(--inline-reactive-color);
  font-size: 1.5rem;
  padding: 0.25rem;
  border-radius: 8px;
  transition:
    color 0.24s ease,
    transform 0.24s ease;
}

.nav-toggle:hover,
.nav-toggle:focus-visible {
  color: var(--inline-reactive-color);
  background-color: transparent;
  box-shadow: none;
  text-shadow: 0 0 14px var(--inline-reactive-glow);
  transform: none;
}

@media (max-width: 768px) {
  :root {
    --mobile-nav-row: clamp(4.5rem, 12vw, 6rem);
    --mobile-nav-control: clamp(3.25rem, 9.5vw, 4.5rem);
    --mobile-nav-icon: clamp(2rem, 5.8vw, 2.75rem);
    --mobile-logo-size: calc(clamp(1.75rem, 5.3vw, 2.5rem) * 1.2);
    --mobile-logo-control: calc(clamp(3.25rem, 9.5vw, 4.5rem) * 1.2);
    --mobile-nav-link-height: clamp(3.25rem, 9vw, 4.25rem);
    --mobile-nav-link-x: clamp(1.25rem, 4vw, 2rem);
    --mobile-nav-underline-y: clamp(0.75rem, 2.2vw, 0.95rem);
    --mobile-page-gap: clamp(1rem, 4vw, 1.5rem);
  }

  body {
    padding-top: var(--mobile-nav-row);
  }

  body:has(.home-bg) {
    padding-top: 0;
  }

  .site-header {
    position: fixed;
    left: 0;
    right: 0;
    overflow: hidden;
  }

  .site-header.site-header--nav-open {
    border-bottom-color: transparent;
  }

  .header-inner {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-rows: var(--mobile-nav-row) 0fr;
    align-items: center;
    height: auto;
    min-height: var(--mobile-nav-row);
    transition: grid-template-rows 0.35s ease;
  }

  .site-header.site-header--nav-open .header-inner,
  .site-header:has(.nav-links.open) .header-inner {
    grid-template-rows: var(--mobile-nav-row) 1fr;
  }

  .logo {
    align-items: center;
    justify-content: center;
    justify-self: start;
    width: var(--mobile-logo-control);
    min-width: var(--mobile-logo-control);
    min-height: var(--mobile-logo-control);
    font-size: var(--mobile-logo-size);
    line-height: 1;
  }

  .nav-toggle {
    display: inline-grid;
    place-items: center;
    width: var(--mobile-nav-control);
    height: var(--mobile-nav-control);
    padding: 0;
    font-size: var(--mobile-nav-icon);
    justify-self: end;
    line-height: 1;
    border: 1px solid transparent;
    border-radius: clamp(0.75rem, 2.4vw, 1rem);
    transition:
      color 0.24s ease,
      background-color 0.24s ease,
      border-color 0.24s ease,
      box-shadow 0.24s ease,
      text-shadow 0.24s ease;
  }

  .nav-toggle:hover,
  .nav-toggle:focus-visible {
    background: transparent;
    border-color: transparent;
    box-shadow: none;
    text-shadow: none;
  }

  .site-nav {
    grid-column: 1 / -1;
    position: relative;
    z-index: 3;
    display: block;
    overflow: hidden;
    min-height: 0;
    pointer-events: auto;
    background: transparent !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    --chrome-glass-tint-alpha: 0;
  }

  .site-nav > .chrome-glass-canvas {
    display: none;
  }

  .nav-links {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0;
    text-align: center;
    max-height: 0;
    opacity: 0;
    visibility: hidden;
    overflow: hidden;
    padding: 0;
    margin: 0;
    pointer-events: none;
    background: transparent;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    transition:
      max-height 0.35s ease,
      opacity 0.22s ease,
      visibility 0.22s ease,
      padding 0.35s ease,
      gap 0.35s ease;
  }

  .nav-links.open {
    max-height: clamp(340px, 64vh, 520px);
    opacity: 1;
    visibility: visible;
    padding: clamp(0.5rem, 1.6vw, 0.875rem) 0 clamp(1.75rem, 5vw, 2.75rem);
    gap: clamp(0.85rem, 2.5vw, 1.35rem);
    pointer-events: auto;
  }

  .nav-links li {
    width: 100%;
  }

  .nav-links a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: var(--mobile-nav-link-height);
    padding: 0 var(--mobile-nav-link-x);
    border: 1px solid transparent;
    border-radius: clamp(0.875rem, 2.8vw, 1.25rem);
    font-size: clamp(1.05rem, 3.8vw, 1.45rem);
    font-weight: 700;
    line-height: 1.15;
    background: transparent;
    box-shadow: 0 0 0 transparent;
    transition:
      color 0.24s ease,
      background-color 0.24s ease,
      border-color 0.24s ease,
      box-shadow 0.24s ease,
      text-shadow 0.24s ease;
  }

  .nav-links a:hover,
  .nav-links a:focus-visible,
  .nav-links a.active {
    color: var(--nav-muted-active);
    background: transparent;
    border-color: transparent;
    box-shadow: none;
    text-shadow: none;
  }

  .nav-links a::after {
    left: 50%;
    bottom: var(--mobile-nav-underline-y);
    width: calc(100% - (var(--mobile-nav-link-x) * 2));
    transform: translateX(-50%) scaleX(0.35);
    transform-origin: center;
    transition:
      opacity 0.2s ease,
      transform 0.28s ease;
  }

  .nav-links a:hover::after,
  .nav-links a:focus-visible::after,
  .nav-links a.active::after {
    opacity: 1;
    transform: translateX(-50%) scaleX(1);
  }

  .site-header:has(.nav-links.open) {
    border-bottom-color: transparent;
  }
}

.site-footer {
  position: relative;
  z-index: 300;
  overflow: hidden;
  --btn-glow-alpha: 0; /* Footer glow. */
  --chrome-glass-tint-alpha: 0; /* Footer tint. */
  --chrome-glass-noise: 2; /* Footer shader noise. */
  --glass-chrome-backdrop-filter: blur(var(--footer-bg-blur)) saturate(140%);
  padding: 2rem 0 3rem;
  text-align: center;
  color: var(--text-muted);
  font-size: 0.925rem;
  border-top: 1px solid rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha)));
  background: color-mix(
    in srgb,
    var(--footer-bg-tint) var(--chrome-glass-tint-mix, 9.425%),
    transparent
  );
  backdrop-filter: var(--glass-chrome-backdrop-filter);
  -webkit-backdrop-filter: var(--glass-chrome-backdrop-filter);
}

.site-footer.has-chrome-glass {
  background: color-mix(in srgb, var(--footer-bg-tint) 2.925%, transparent);
  backdrop-filter: var(--glass-chrome-backdrop-filter);
  -webkit-backdrop-filter: var(--glass-chrome-backdrop-filter);
}

.footer-inner {
  position: relative;
  z-index: 3;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem;
}

@media (max-width: 600px) {
  .footer-inner {
    flex-direction: column;
  }
}

.footer-inner > p > span {
  color: var(--interactive-muted);
  text-shadow: none;
}

.section {
  padding: 4rem 0;
}

.section-label {
  text-transform: uppercase;
  font-size: 0.8125rem;
  font-weight: 700;
  color: var(--primary);
  letter-spacing: 0.05em;
  margin-bottom: 0.5rem;
}

.section-title {
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 1.5rem;
}

.card {
  background: color-mix(
    in srgb,
    var(--card-layer-1-bg-tint) 0.65%,
    transparent
  );
  border-radius: var(--radius);
  padding: 1.5rem;
  border: 1px solid rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha)));
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.040625);
  isolation: isolate;
  transition:
    border-color 0.3s,
    box-shadow 0.3s;
}

.card::before,
.story-card::before,
.resume-card::before,
.contact-layout::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  border-radius: inherit;
  background:
    linear-gradient(var(--rim-surface-block), var(--rim-surface-block)),
    linear-gradient(
      var(--ui-blob-accent-wash, transparent),
      var(--ui-blob-accent-wash, transparent)
    ),
    color-mix(in srgb, var(--card-layer-1-bg-tint) 0.65%, transparent);
  backdrop-filter: blur(var(--card-layer-1-bg-blur)) saturate(140%)
    brightness(var(--card-bg-brightness));
  -webkit-backdrop-filter: blur(var(--card-layer-1-bg-blur)) saturate(140%)
    brightness(var(--card-bg-brightness));
}

.card:hover {
  border-color: rgb(126 181 190 / calc(0.024375 * var(--rim-static-alpha)));
  box-shadow: 0 8px 32px rgba(0, 95, 107, 0.024375);
}

.card-dark {
  background: color-mix(
    in srgb,
    var(--card-layer-1-bg-tint) 0.65%,
    transparent
  );
  border: 1px solid rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha)));
}

.badge {
  position: relative;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.25rem 0.75rem;
  border-radius: 9999px;
  font-size: 0.75rem;
  font-weight: 500;
  background: color-mix(
    in srgb,
    var(--card-layer-3-bg-tint) 3.25%,
    transparent
  );
  background-image: linear-gradient(
    var(--rim-surface-block),
    var(--rim-surface-block)
  );
  color: var(--interactive-muted);
  border: 1px solid
    color-mix(in srgb, var(--inline-reactive-color) 12%, transparent);
  backdrop-filter: blur(var(--card-layer-3-bg-blur)) saturate(140%)
    brightness(var(--card-bg-brightness));
  -webkit-backdrop-filter: blur(var(--card-layer-3-bg-blur)) saturate(140%)
    brightness(var(--card-bg-brightness));
  text-shadow: none;
}

.badge svg {
  flex-shrink: 0;
}

.badge :where(img, .si-icon) {
  flex-shrink: 0;
  width: 14px;
  height: 14px;
}

.badge .si-icon {
  color: var(--inline-reactive-color);
}

.badge i {
  flex-shrink: 0;
  font-size: 0.8rem;
  color: var(--inline-reactive-color);
  text-shadow: 0 0 10px var(--inline-reactive-glow);
}

.badge span.si-icon {
  display: inline-block;
  background: currentColor;
  -webkit-mask: var(--si-icon-mask) center / contain no-repeat;
  mask: var(--si-icon-mask) center / contain no-repeat;
  opacity: var(--ui-blob-icon-opacity, 0.74);
  filter: drop-shadow(0 0 8px var(--inline-reactive-glow));
}

.badge img.si-icon {
  filter: brightness(0) invert(1)
    drop-shadow(0 0 8px var(--inline-reactive-glow));
  opacity: var(--ui-blob-icon-opacity, 0.74);
}

.badge-light {
  background: color-mix(
    in srgb,
    var(--card-layer-3-bg-tint) 3.25%,
    transparent
  );
  background-image:
    linear-gradient(var(--rim-surface-block), var(--rim-surface-block)),
    linear-gradient(
      var(--ui-blob-accent-wash, transparent),
      var(--ui-blob-accent-wash, transparent)
    );
  color: var(--interactive-muted);
  border-color: color-mix(
    in srgb,
    var(--inline-reactive-color) 12%,
    transparent
  );
}

.btn {
  --glass-control-backdrop-filter: blur(var(--button-bg-blur)) saturate(160%);
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.625rem 1.5rem;
  border-radius: 9999px;
  font-size: 0.9375rem;
  font-weight: 500;
  cursor: pointer;
  font-family: inherit;
  text-decoration: none;
  position: relative;
  overflow: hidden;
  color: #fff;
  background-color: color-mix(
    in srgb,
    var(--button-bg-tint) 3.25%,
    transparent
  );
  background-image:
    linear-gradient(var(--rim-surface-block), var(--rim-surface-block)),
    linear-gradient(
      var(--ui-blob-accent-wash, transparent),
      var(--ui-blob-accent-wash, transparent)
    );
  border: 1px solid rgb(126 181 190 / calc(0.0325 * var(--rim-static-alpha)));
  backdrop-filter: var(--glass-control-backdrop-filter);
  -webkit-backdrop-filter: var(--glass-control-backdrop-filter);
  box-shadow: 0 0 0 rgba(126, 181, 190, 0);
  transition:
    color 0.2s ease,
    transform 0.2s ease,
    border-color 0.2s ease,
    background-color 0.2s ease,
    box-shadow 0.2s ease;
}

.site-footer,
.card,
.story-card,
.cta-banner {
  position: relative;
}

.field-glass {
  position: relative;
  display: block;
  border-radius: 8px;
  isolation: isolate;
}

.field-glass::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  border-radius: inherit;
  background:
    linear-gradient(var(--rim-surface-block), var(--rim-surface-block)),
    linear-gradient(
      var(--ui-blob-accent-wash, transparent),
      var(--ui-blob-accent-wash, transparent)
    ),
    color-mix(in srgb, var(--form-layer-1-bg-tint) 0.65%, transparent);
  backdrop-filter: blur(var(--form-layer-1-bg-blur)) saturate(140%)
    brightness(var(--card-bg-brightness));
  -webkit-backdrop-filter: blur(var(--form-layer-1-bg-blur)) saturate(140%)
    brightness(var(--card-bg-brightness));
}

.field-glass > input,
.field-glass > textarea {
  position: relative;
  z-index: 1;
  display: block;
}

.btn:hover,
.btn:focus-visible {
  color: #fff;
  transform: translateY(-1px);
  border-color: rgb(126 181 190 / calc(0.05525 * var(--rim-static-alpha)));
  background-color: color-mix(
    in srgb,
    var(--button-bg-tint) 4.55%,
    transparent
  );
  box-shadow:
    0 10px 24px rgba(0, 0, 0, 0.03575),
    0 0 18px rgba(126, 181, 190, 0.026);
}

.btn:active {
  transform: translateY(0);
}

.btn-primary {
  --btn-rim-tint: #ffffff;
  --btn-glow-tint: #ffffff;
}

.btn-outline {
  color: rgba(255, 255, 255, 0.85);
}

.btn-outline:hover,
.btn-outline:focus-visible {
  color: var(--primary);
}

.grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
}

@media (max-width: 768px) {
  .grid-2 {
    grid-template-columns: 1fr;
  }
}

.grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  align-items: start;
  gap: 1.5rem;
}

.interest-grid {
  align-items: stretch;
}

.interest-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 0.75rem;
  transition: none;
}

.interest-card:hover {
  border-color: rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha)));
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.040625);
}

.interest-header {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
}

.interest-icon {
  position: relative;
  overflow: hidden;
  width: 42px;
  height: 42px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: color-mix(in srgb, var(--button-bg-tint) 3.25%, transparent);
  background-image:
    linear-gradient(var(--rim-surface-block), var(--rim-surface-block)),
    linear-gradient(
      var(--ui-blob-accent-wash, transparent),
      var(--ui-blob-accent-wash, transparent)
    );
  border: 1px solid
    color-mix(in srgb, var(--inline-reactive-color) 12%, transparent);
  font-size: 1.1rem;
  color: var(--inline-reactive-color);
  flex-shrink: 0;
  --btn-rim-alpha: 1;
  --btn-rim-cutoff: 0.02;
  --btn-rim-falloff: 1;
  --btn-rim-tint: #ffffff;
  --btn-glow-alpha: 1;
  --btn-glow-falloff: 1;
  --btn-glow-tint: #ffffff;
}

.interest-icon > i {
  position: relative;
  z-index: 1;
  color: currentColor;
  text-shadow: 0 0 12px var(--inline-reactive-glow);
}

.interest-card h3 {
  margin-bottom: 0;
}

.interest-card p {
  color: var(--text-muted);
  font-size: 0.9375rem;
  margin: 0;
}

@media (max-width: 768px) {
  .grid-3 {
    grid-template-columns: 1fr;
  }
}

.home-intro {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: none;
  place-items: center;
  overflow: hidden;
  color: #f3f7f6;
  background: #000;
  pointer-events: auto;
}

html.home-intro-enabled:not(.home-intro-complete):not(.home-intro-timeout)
  .home-intro {
  display: grid;
}

body.home-intro-running {
  overflow-x: hidden;
  overscroll-behavior: none;
}

body.home-intro-running #dot-canvas {
  opacity: 0;
}

.home-intro::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: none;
  opacity: 0;
}

.home-intro-loader,
.home-intro-logo {
  position: absolute;
  left: 50%;
  top: 50%;
  translate: -50% -50%;
}

.home-intro-loader {
  display: grid;
  width: min(34rem, calc(100vw - 3rem));
  justify-items: center;
  opacity: 0;
}

.home-intro-progress {
  display: block;
  font-family:
    "Roboto",
    system-ui,
    -apple-system,
    sans-serif;
  font-size: clamp(5rem, 14vmin, 10rem);
  font-weight: 700;
  line-height: 1;
  color: #f3f7f6;
  text-align: center;
  font-variant-numeric: tabular-nums;
  text-shadow: none;
  filter: none;
}

.home-intro-logo {
  display: inline-flex;
  align-items: baseline;
  justify-content: center;
  font-family: "Roboto Mono", monospace;
  font-size: clamp(8rem, 19vmin, 15rem);
  font-weight: 700;
  line-height: 0.9;
  color: #f3f7f6;
  opacity: 0;
  text-shadow: none;
}

.home-intro-logo-k,
.home-intro-logo-dash {
  display: inline-block;
  transform-style: preserve-3d;
  will-change: transform, opacity;
}

.home-intro-logo-k {
  transform-origin: 50% 100%;
}

.home-intro-logo-dash {
  margin-left: 0.05em;
  transform-origin: left center;
}

@media (max-width: 768px) {
  .home-intro-progress {
    font-size: clamp(3.25rem, 18vw, 4.75rem);
  }

  .home-intro-logo {
    font-size: clamp(5.25rem, 27vw, 7.25rem);
  }
}

@media (max-width: 380px) {
  .home-intro-progress {
    font-size: clamp(3rem, 17vw, 4.25rem);
  }

  .home-intro-logo {
    font-size: clamp(4.75rem, 25vw, 6.5rem);
  }
}

.home-bg {
  background: transparent;
}

.hero {
  position: relative;
  height: 100vh;
  height: 100svh;
  min-height: 100vh;
  min-height: 100svh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 2rem 0;
  overflow: hidden;
}

.hero-arrow {
  --hero-arrow-visual-opacity: 1;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 6vh;
  margin-inline: auto;
  translate: 0px 0;
  width: 64px;
  height: 64px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: rgba(255, 255, 255, 0.34);
  transition: color 0.2s ease;
  z-index: 3;
  border-radius: 50%;
  overflow: hidden;
  opacity: 1;
  scale: none;
  visibility: visible;
  pointer-events: auto;
  transition:
    color 0.2s ease,
    opacity 1.25s cubic-bezier(0.22, 1, 0.36, 1),
    scale 0.32s cubic-bezier(0.22, 1, 0.36, 1),
    filter 0.32s ease,
    visibility 0s linear 0s;
}

.hero-arrow-ssaa {
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 200%;
  height: 200%;
  transform: scale(0.5);
  transform-origin: top left;
  display: block;
  opacity: var(--hero-arrow-visual-opacity);
  transition: opacity 1.25s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: transform;
}

.hero-arrow:hover,
.hero-arrow:focus-visible {
  color: rgba(255, 255, 255, 0.082);
  scale: 1.04;
}

.hero-arrow.is-hidden {
  --hero-arrow-visual-opacity: 0;
  opacity: 0;
  scale: 0.92;
  filter: blur(1px);
  visibility: hidden;
  pointer-events: none;
  transition:
    color 0.2s ease,
    opacity 0.24s ease,
    scale 0.24s ease,
    filter 0.24s ease,
    visibility 0s linear 0.24s;
}

.hero-arrow.is-prebuzz-hidden {
  --hero-arrow-visual-opacity: 0;
  opacity: 1;
  scale: none;
  visibility: visible;
  pointer-events: none;
  transition:
    color 0.2s ease,
    scale 0.32s cubic-bezier(0.22, 1, 0.36, 1);
}

.hero-arrow.is-reveal-reset .hero-arrow-glass,
.hero-arrow.is-reveal-reset .hero-arrow-ssaa {
  opacity: 0;
  transition: none;
}

.hero-arrow-glass {
  --glass-control-backdrop-filter: blur(var(--button-bg-blur)) saturate(160%);
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  border-radius: 50%;
  overflow: hidden;
  opacity: var(--hero-arrow-visual-opacity);
  transition: opacity 1.25s cubic-bezier(0.22, 1, 0.36, 1);
  --btn-rim-alpha: 1;
  --btn-rim-cutoff: 0.02;
  --btn-rim-falloff: 1;
  --btn-rim-tint: #ffffff;
  --btn-glow-alpha: 0.35; /* Arrow glow. */
  --btn-glow-falloff: 1; /* Arrow glow contrast. */
  --btn-glow-tint: #ffffff; /* Arrow glow tint. */
  background-color: color-mix(
    in srgb,
    var(--button-bg-tint) 3.25%,
    transparent
  );
  background-image:
    linear-gradient(var(--rim-surface-block), var(--rim-surface-block)),
    linear-gradient(
      var(--ui-blob-accent-wash, transparent),
      var(--ui-blob-accent-wash, transparent)
    ),
    linear-gradient(
      180deg,
      rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha))),
      rgb(255 255 255 / calc(0.0040625 * var(--rim-static-alpha)))
    );
  backdrop-filter: var(--glass-control-backdrop-filter);
  -webkit-backdrop-filter: var(--glass-control-backdrop-filter);
}

.hero-arrow-prewarm {
  --glass-control-backdrop-filter: blur(var(--button-bg-blur)) saturate(160%);
  position: fixed;
  left: -192px;
  top: 50vh;
  width: 64px;
  height: 64px;
  z-index: -1;
  pointer-events: none;
  border-radius: 50%;
  opacity: 0.01;
  background-color: color-mix(
    in srgb,
    var(--button-bg-tint) 3.25%,
    transparent
  );
  background-image: linear-gradient(
    180deg,
    rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha))),
    rgb(255 255 255 / calc(0.0040625 * var(--rim-static-alpha)))
  );
  backdrop-filter: var(--glass-control-backdrop-filter);
  -webkit-backdrop-filter: var(--glass-control-backdrop-filter);
  transform: translateZ(0);
  contain: strict;
}

.hero-arrow-stroke {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 1;
  display: block;
  width: calc(24px * 2);
  height: calc(24px * 2);
  transform: translate(calc(-50% + 0px * 2), calc(-50% + 2px * 2));
  shape-rendering: geometricPrecision;
  filter: drop-shadow(0 0 6px var(--chevron-glow, transparent))
    drop-shadow(0 -1px 1px rgba(0, 0, 0, 0.55))
    drop-shadow(0 1px 1px rgba(255, 255, 255, 0.35));
}

.hero-arrow.idle-buzz {
  animation: hero-arrow-buzz 2.8s ease-in-out infinite;
}

@keyframes hero-arrow-buzz {
  0%,
  32%,
  100% {
    transform: translateX(0) rotate(0);
  }
  4% {
    transform: translateX(2px) rotate(1.4deg);
  }
  8% {
    transform: translateX(-2px) rotate(-1.4deg);
  }
  12% {
    transform: translateX(2px) rotate(1.2deg);
  }
  16% {
    transform: translateX(-2px) rotate(-1.2deg);
  }
  20% {
    transform: translateX(1px) rotate(0.8deg);
  }
  24% {
    transform: translateX(-1px) rotate(-0.8deg);
  }
  28% {
    transform: translateX(0.5px) rotate(0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .hero-arrow.idle-buzz {
    animation: none;
  }
}

.hero-content {
  --hero-proportion: 1;
  width: min(100%, var(--hero-content-width, 1200px));
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 2rem;
  text-align: left;
}

.hero-name {
  font-size: calc(1rem * var(--hero-proportion));
  text-transform: uppercase;
  color: var(--interactive-muted);
  letter-spacing: 0.1em;
  margin-bottom: calc(4rem * var(--hero-proportion));
  transform: translateX(calc(0.5rem * var(--hero-proportion)));
}

.hero-heading {
  font-family: "Roboto Mono", monospace;
  position: relative;
  margin-top: calc(-1 * 6px * var(--hero-proportion));
  margin-left: 0rem;
  padding-top: calc(6px * var(--hero-proportion));
  --btn-rim-alpha: 1;
  --btn-rim-cutoff: 0.02;
  --btn-rim-falloff: 1;
  --btn-rim-tint: #ffffff;
  --btn-glow-alpha: 0;
  --btn-glow-falloff: 1;
  --btn-glow-tint: #7eb5be85;
}

.hero-title-svg {
  position: absolute;
  inset: 0;
  z-index: 2;
  width: 100%;
  height: 100%;
  overflow: visible;
  pointer-events: none;
  color: rgb(126 181 190 / calc(0.01625 * var(--rim-static-alpha)));
  opacity: 0;
  transition: opacity 0.2s ease;
}

.hero-heading.frosted-ready .hero-title-svg {
  opacity: 1;
}

.hero-title-text {
  fill: currentColor;
  text-rendering: geometricPrecision;
}

.hero-title-letter {
  fill: rgb(126 181 190 / 0.2);
}

.hero-intro-title-svg {
  position: absolute;
  inset: 0;
  z-index: 4;
  width: 100%;
  height: 100%;
  overflow: visible;
  pointer-events: none;
  opacity: 0;
}

.hero-intro-letter {
  fill: rgb(126 181 190 / 0.2);
  stroke: none;
  text-rendering: geometricPrecision;
  will-change: transform, opacity, filter;
}

.hero-frost-stroke {
  position: absolute;
  inset: 0;
  z-index: 3;
  display: block;
  pointer-events: none;
  background: var(--ui-rim-background);
  opacity: 0;
  clip-path: inset(
    var(--ui-rim-clip-top, 0px) var(--ui-rim-clip-right, 0px)
      var(--ui-rim-clip-bottom, 0px) var(--ui-rim-clip-left, 0px)
  );
  -webkit-mask-image: var(--hero-stroke, none);
  mask-image: var(--hero-stroke, none);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: top left;
  mask-position: top left;
  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;
}

.hero-frost-fill {
  --glass-hero-backdrop-filter: blur(var(--hero-bg-blur)) saturate(180%);
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  background:
    linear-gradient(var(--rim-surface-block), var(--rim-surface-block)),
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0) 0%,
      rgba(255, 255, 255, 0) 35%,
      rgba(255, 255, 255, 0.013000000000000001) 100%
    ),
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.06825),
      rgba(255, 255, 255, 0.06825)
    );

  backdrop-filter: var(--glass-hero-backdrop-filter);
  -webkit-backdrop-filter: var(--glass-hero-backdrop-filter);
  -webkit-mask-image: var(--hero-mask, none);
  mask-image: var(--hero-mask, none);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: top left;
  mask-position: top left;
  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;
  opacity: 0;
  transition: opacity 0.2s ease;
}

.hero-frost-fill {
  opacity: 0;
}

.hero-heading.frosted-ready .hero-frost-fill {
  opacity: 1;
}

.hero-heading.frosted-ready .hero-frost-stroke {
  opacity: min(
    1,
    calc(
      var(--ui-rim-opacity, 0) * var(--btn-rim-alpha, 1) *
        clamp(0, var(--rim-thickness), 1)
    )
  );
}

.hero-heading .hero-sub,
.hero-heading .hero-main {
  visibility: hidden;
}

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.hero-sub {
  display: block;
  font-size: var(--hero-heading-size, clamp(4rem, 15vw, 12rem));
  font-weight: 700;
  line-height: 1;
  color: rgba(255, 255, 255, 0.013000000000000001);
  text-shadow: 0 0 40px rgba(255, 255, 255, 0.008125);
}

.hero-main {
  display: block;
  font-size: var(--hero-heading-size, clamp(4rem, 15vw, 12rem));
  font-weight: 700;
  line-height: 1;

  padding-bottom: 0.25em;

  color: rgba(255, 255, 255, 0.024375);
  text-shadow: 0 0 40px rgba(255, 255, 255, 0.013000000000000001);
}

.hero-tagline {
  color: var(--text-muted);
  margin-top: calc(1.5rem * var(--hero-proportion));
  font-size: calc(1rem * var(--hero-proportion));
  transform: translateX(calc(0.5rem * var(--hero-proportion)));
}

@media (max-width: 768px) {
  .hero {
    height: 100svh;
    min-height: 100svh;
    padding: clamp(1.5rem, 6vh, 3rem) 0;
    overflow: hidden;
  }

  .hero-content {
    width: 100%;
    max-width: min(100%, 36rem);
    padding: 0 clamp(1.25rem, 6vw, 2rem);
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    text-align: left;
  }

  .hero-name,
  .hero-tagline {
    max-width: 100%;
  }

  .hero-name {
    margin-bottom: 3rem;
    transform: translateX(0);
  }

  .hero-heading {
    display: inline-block;
    width: max-content;
    max-width: 100%;
    margin-left: 0;
    transform: none;
  }

  .hero-sub,
  .hero-main {
    font-size: var(
      --hero-heading-size,
      clamp(1.75rem, calc(17vw - 0.35rem), 5rem)
    );
    line-height: 1.05;
    white-space: nowrap;
  }

  .hero-tagline {
    margin-top: 1.75rem;
    max-width: 22rem;
    transform: none;
  }
}

.page-header {
  padding: 4rem 0 2rem;
  text-align: left;
}

.page-header h1 {
  font-size: var(--page-title-size, 2.5rem);
  font-weight: 700;
  line-height: 1.08;
  text-wrap: balance;
}

.mobile-title-break {
  display: none;
}

.page-intro-transition.scroll-reveal,
.page-intro-transition.scroll-reveal.is-visible {
  opacity: 1;
  transform: none;
  animation: none;
}

.page-intro-transition.is-page-intro-running .section-label,
.page-intro-transition.is-page-intro-running h1,
.page-intro-transition.is-page-intro-running .section-title {
  visibility: visible;
}

.resume-entry-ready .resume-about.scroll-reveal,
.resume-entry-ready .resume-about.scroll-reveal.is-visible,
.resume-entry-ready .resume-about > .scroll-reveal,
.resume-entry-ready .resume-about > .scroll-reveal.is-visible,
.resume-entry-ready .resume-card.scroll-reveal,
.resume-entry-ready .resume-card.scroll-reveal.is-visible {
  animation: none;
}

.resume-entry-ready .resume-card.scroll-reveal > *,
.resume-entry-ready .resume-card.scroll-reveal.is-visible > * {
  opacity: 1;
  transform: none;
  animation: none;
}

.about-entry-ready .about-intro.scroll-reveal,
.about-entry-ready .about-intro.scroll-reveal.is-visible,
.about-entry-ready .story-card.scroll-reveal,
.about-entry-ready .story-card.scroll-reveal.is-visible,
.about-entry-ready .interest-card.scroll-reveal,
.about-entry-ready .interest-card.scroll-reveal.is-visible {
  opacity: 1;
  transform: none;
  animation: none;
}

.about-entry-ready .story-card.scroll-reveal > *,
.about-entry-ready .story-card.scroll-reveal.is-visible > *,
.about-entry-ready .interest-card.scroll-reveal > *,
.about-entry-ready .interest-card.scroll-reveal.is-visible > * {
  opacity: 1;
  transform: none;
  animation: none;
}

.contact-entry-ready .contact-layout.scroll-reveal,
.contact-entry-ready .contact-layout.scroll-reveal.is-visible,
.contact-entry-ready .contact-image.scroll-reveal,
.contact-entry-ready .contact-image.scroll-reveal.is-visible {
  animation: none;
}

.contact-entry-ready .contact-layout.scroll-reveal > *,
.contact-entry-ready .contact-layout.scroll-reveal.is-visible > *,
.contact-entry-ready .contact-image.scroll-reveal > *,
.contact-entry-ready .contact-image.scroll-reveal.is-visible > *,
.contact-entry-ready .contact-layout.scroll-reveal .contact-form-panel > h2,
.contact-entry-ready
  .contact-layout.scroll-reveal.is-visible
  .contact-form-panel
  > h2,
.contact-entry-ready .contact-layout.scroll-reveal .form-group label,
.contact-entry-ready .contact-layout.scroll-reveal.is-visible .form-group label,
.contact-entry-ready .contact-layout.scroll-reveal .field-glass,
.contact-entry-ready .contact-layout.scroll-reveal.is-visible .field-glass,
.contact-entry-ready .contact-layout.scroll-reveal .contact-form-panel .btn,
.contact-entry-ready
  .contact-layout.scroll-reveal.is-visible
  .contact-form-panel
  .btn {
  opacity: 1;
  transform: none;
  animation: none;
}

.combined-page-section--about,
.combined-page-section--resume,
.combined-page-section--contact,
.about-entry-ready,
.resume-entry-ready,
.contact-entry-ready {
  overflow-x: clip;
}

@supports not (overflow: clip) {
  .combined-page-section--about,
  .combined-page-section--resume,
  .combined-page-section--contact,
  .about-entry-ready,
  .resume-entry-ready,
  .contact-entry-ready {
    overflow-x: hidden;
  }
}

.combined-page-section--contact {
  display: grid;
  align-content: center;
  justify-items: stretch;
  min-height: calc(100vh - var(--site-footer-block-size));
  min-height: calc(100svh - var(--site-footer-block-size));
}

.combined-page-section--contact > .container,
.combined-page-section--contact > .section {
  width: 100%;
}

@media (min-width: 769px) {
  .combined-page-section--about,
  .combined-page-section--resume {
    --section-edge-space: clamp(3.5rem, 6vh, 5rem);
    --section-heading-offset: 1.8125rem;
    padding-top: var(--section-edge-space);
    padding-bottom: 0;
  }

  .resume-cta,
  .about-cta {
    margin-top: calc(
      var(--section-edge-space, clamp(3.5rem, 6vh, 5rem)) +
        var(--section-heading-offset, 1.8125rem)
    );
  }
}

@media (min-width: 769px) and (max-height: 980px) {
  .combined-page-section--contact .page-header {
    padding: clamp(1.5rem, 4vh, 2.25rem) 0 clamp(0.75rem, 2.25vh, 1.25rem);
  }

  .combined-page-section--contact > .section {
    padding: clamp(1rem, 2.6vh, 1.5rem) 0;
  }

  .combined-page-section--contact .contact-form-panel {
    padding: clamp(1.5rem, 3vh, 2rem);
  }

  .combined-page-section--contact .contact-form-panel h2 {
    margin-bottom: 0.95rem;
  }

  .combined-page-section--contact .form-group {
    margin-bottom: 0.7rem;
  }

  .combined-page-section--contact .form-group label {
    margin-bottom: 0.25rem;
  }

  .combined-page-section--contact .form-group input,
  .combined-page-section--contact .form-group textarea {
    padding: 0.55rem 0.875rem;
  }

  .combined-page-section--contact .form-group textarea {
    min-height: 5.5rem;
  }

  .combined-page-section--contact .contact-image-overlay {
    padding: 1.35rem;
  }
}

.project-page-header {
  margin-bottom: 2rem;
}

.project-stack-deck {
  --project-stack-top: clamp(5.25rem, 11vh, 7.75rem);
  --project-stack-gap: clamp(6.25rem, 14vh, 9.5rem);
  perspective: 1200px;
}

.project-stack-active .project-card.project-stack-card {
  position: sticky;
  top: var(--project-card-sticky-top, var(--project-stack-top));
  z-index: calc(10 + var(--project-stack-index, 0));
  margin-bottom: var(--project-stack-gap);
  transform-origin: top center;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  will-change: auto;
}

.project-stack-active.project-stack-blur-enabled
  .project-card.project-stack-card.project-stack-card-rendered {
  will-change: transform, opacity, filter;
}

.project-stack-active .project-card.project-stack-card.project-stack-card-rendered {
  will-change: transform, opacity;
}

.project-stack-active
  .project-card.project-stack-card.project-stack-card-rendered.scroll-reveal {
  will-change: transform, opacity;
}

.project-stack-active .project-card.project-stack-card-spaced {
  margin-bottom: calc(
    var(--project-stack-gap) + var(--project-card-extra-gap, 0px)
  );
}

.project-stack-active .project-card.project-stack-card-culled {
  height: var(--project-card-cull-height);
  overflow: hidden;
  translate: none !important;
  rotate: none !important;
  scale: none !important;
  transform: none !important;
  opacity: 0 !important;
  filter: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
  content-visibility: hidden !important;
  contain-intrinsic-size: var(--project-card-cull-height);
  transition: none !important;
  animation: none !important;
  will-change: auto;
}

.project-stack-active .project-card.scroll-reveal,
.project-stack-active .project-card.scroll-reveal.is-visible,
.project-stack-active .project-card.scroll-reveal > *,
.project-stack-active .project-card.scroll-reveal.is-visible > *,
.project-stack-active .project-card.scroll-reveal .project-preview,
.project-stack-active .project-card.scroll-reveal.is-visible .project-preview,
.project-stack-active .project-card.scroll-reveal .project-details-panel,
.project-stack-active
  .project-card.scroll-reveal.is-visible
  .project-details-panel {
  opacity: 1;
  animation: none;
}

.project-stack-active .project-card.scroll-reveal,
.project-stack-active .project-card.scroll-reveal.is-visible,
.project-stack-active .project-card.scroll-reveal > *,
.project-stack-active .project-card.scroll-reveal.is-visible > *,
.project-stack-active .project-card.scroll-reveal .project-preview,
.project-stack-active .project-card.scroll-reveal.is-visible .project-preview,
.project-stack-active .project-card.scroll-reveal .project-details-panel,
.project-stack-active
  .project-card.scroll-reveal.is-visible
  .project-details-panel {
  transform: none;
  will-change: auto;
}

@media (max-width: 1024px) {
  .project-stack-deck {
    --project-stack-top: clamp(3.5rem, 8vh, 5.375rem);
    --project-stack-gap: clamp(0.5rem, 2vh, 1.25rem);
    perspective: none;
  }

  .project-stack-active .project-card.project-stack-card {
    position: sticky;
    top: var(--project-card-sticky-top, var(--project-stack-top));
    z-index: calc(10 + var(--project-stack-index, 0));
    min-height: 0;
    margin-bottom: var(--project-stack-gap);
    transform-origin: top center;
    will-change: auto;
    filter: none !important;
  }

  .project-stack-active .project-card.project-stack-card.project-stack-card-rendered {
    will-change: transform, opacity;
  }

  .project-stack-active
    .project-card.project-stack-card.project-stack-card-rendered.scroll-reveal {
    will-change: transform, opacity;
  }

  .project-stack-active.project-stack-ios
    .project-card.project-stack-card-fading {
    isolation: isolate;
  }

  .project-stack-active .project-card.project-stack-card-culled {
    height: auto;
    overflow: visible;
    opacity: inherit !important;
    visibility: visible !important;
    pointer-events: auto !important;
    content-visibility: visible !important;
    contain-intrinsic-size: auto;
  }

  .project-stack-active .project-card.project-stack-card-mobile-culled {
    background: transparent !important;
    background-image: none !important;
    border-color: transparent !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    height: var(--project-card-cull-height);
    min-height: var(--project-card-cull-height);
    overflow: hidden;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    transform: none !important;
    filter: none !important;
    transition: none !important;
    animation: none !important;
    content-visibility: hidden !important;
    contain-intrinsic-size: var(--project-card-cull-height);
    contain: layout style paint;
    will-change: auto;
  }

  .project-stack-active .project-card.project-stack-card-mobile-culled > * {
    display: none !important;
  }

  .project-stack-active .project-card.project-stack-card-mobile-culled * {
    transition: none !important;
    animation: none !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  .project-stack-deck .project-stack-card,
  .project-stack-deck .project-card {
    position: relative;
    top: auto;
    z-index: auto;
    transform: none !important;
    opacity: 1 !important;
    filter: none !important;
    height: auto;
    overflow: visible;
    visibility: visible !important;
    pointer-events: auto;
    content-visibility: visible;
  }
}

.project-card {
  margin-bottom: 2rem;
}

.project-card:hover {
  border-color: rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha)));
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.040625);
}

.project-card h2 {
  font-size: 1.25rem;
  font-weight: 700;
  margin-bottom: 0.75rem;
  color: var(--text);
}

.project-card h3 {
  font-size: 0.9375rem;
  font-weight: 700;
  margin-top: 1.5rem;
  color: var(--text);
}

.project-card p {
  color: var(--text-muted);
  margin-bottom: 1rem;
  line-height: 1.7;
}

.project-card ul {
  color: var(--text-muted);
  font-size: 0.875rem;
  padding-left: 1.25rem;
  margin-bottom: 1rem;
}

.project-meta {
  font-size: 0.8125rem;
  text-transform: uppercase;
  color: var(--primary);
  margin-bottom: 0.5rem;
  letter-spacing: 0.05em;
}

.project-role {
  font-size: 0.875rem;
  font-weight: 600;
  margin-bottom: 1rem;
  color: var(--text);
  line-height: 1.7;
}

.project-role .badge {
  margin-right: 0.75rem;
  vertical-align: middle;
  transform: translateY(-1px);
}

.tech-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.resume-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  align-items: stretch;
}

.resume-grid > div {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  justify-content: space-between;
}

@media (max-width: 768px) {
  .resume-grid {
    grid-template-columns: 1fr;
  }
}

.resume-card h3 {
  font-size: 1.125rem;
  font-weight: 700;
  margin-bottom: 0.75rem;
}

.resume-card ul {
  padding-left: 1.25rem;
  color: var(--text-muted);
  font-size: 0.9375rem;
}

.resume-card ul li {
  margin-bottom: 0.25rem;
}

.form-group {
  margin-bottom: 1.25rem;
}

.form-actions {
  display: flex;
  justify-content: flex-end;
}

.form-group label {
  display: block;
  font-size: 0.875rem;
  font-weight: 600;
  margin-bottom: 0.375rem;
}

.form-group input,
.form-group textarea {
  width: 100%;
  padding: 0.75rem 1rem;
  background:
    linear-gradient(var(--rim-surface-block), var(--rim-surface-block)),
    color-mix(in srgb, var(--form-layer-1-bg-tint) 0.65%, transparent);
  border: 1px solid rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha)));
  border-radius: 8px;
  color: var(--text);
  font-family: inherit;
  font-size: 0.9375rem;
  transition:
    border-color 0.3s,
    box-shadow 0.3s;
  backdrop-filter: blur(var(--form-layer-2-bg-blur)) saturate(140%)
    brightness(var(--card-bg-brightness));
  -webkit-backdrop-filter: blur(var(--form-layer-2-bg-blur)) saturate(140%)
    brightness(var(--card-bg-brightness));
}

.form-group input:focus,
.form-group textarea:focus {
  outline: none;
  border-color: rgb(126 181 190 / calc(0.05525 * var(--rim-static-alpha)));
  box-shadow: 0 0 0 3px
    rgb(126 181 190 / calc(0.01625 * var(--rim-static-alpha)));
}

.form-group input:hover,
.form-group textarea:hover {
  border-color: rgb(126 181 190 / calc(0.05525 * var(--rim-static-alpha)));
  box-shadow: 0 0 0 3px rgba(126, 181, 190, 0.00975);
}

.form-group textarea {
  resize: none;
  min-height: 120px;
  overflow: hidden;
}

.about-intro {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(220px, 1fr);
  grid-template-areas:
    "name photo"
    "copy photo";
  column-gap: 3rem;
  row-gap: 0.75rem;
  align-items: start;
}

.about-name {
  grid-area: name;
  font-size: 1.5rem;
  margin: 0;
}

.about-copy {
  grid-area: copy;
}

.about-copy p {
  color: var(--text-muted);
  line-height: 1.7;
  margin: 0;
}

.about-copy p + p {
  margin-top: 1rem;
}

.about-copy-emphasis {
  font-style: italic;
}

@media (max-width: 768px) {
  .about-intro {
    grid-template-columns: 1fr;
    grid-template-areas:
      "name"
      "copy"
      "photo";
  }
}

.about-photo-frame {
  grid-area: photo;
  display: flex;
  justify-content: center;
  align-self: start;
}

.about-photo-ring {
  width: 200px;
  height: 200px;
  border-radius: 50%;
  margin: 0 auto;
  border: 0;
  box-shadow: none;
}

.about-photo {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  object-fit: cover;
}

.about-intro picture,
.resume-about picture,
.story-card picture,
.contact-image picture {
  display: contents;
}

.mission-overlay,
.cta-banner {
  position: relative;
  --glass-tint-alpha: 0.35; /* CTA tint. */
  --glass-cta-backdrop-filter: blur(var(--cta-bg-blur)) saturate(140%)
    brightness(var(--cta-bg-brightness));
  background:
    linear-gradient(var(--rim-surface-block), var(--rim-surface-block)),
    linear-gradient(
      var(--ui-blob-accent-wash, transparent),
      var(--ui-blob-accent-wash, transparent)
    ),
    color-mix(
      in srgb,
      var(--cta-bg-tint) var(--glass-tint-mix, 0.65%),
      transparent
    );
  backdrop-filter: var(--glass-cta-backdrop-filter);
  -webkit-backdrop-filter: var(--glass-cta-backdrop-filter);
  border-top: 1px solid rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha)));
  border-bottom: 1px solid
    rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha)));
}

.mission-overlay {
  padding: 5rem 0;
}

.mission-transition {
  min-height: 100vh;
  min-height: 100svh;
  padding: 0;
  overflow: hidden;
  border-top: 0;
  border-bottom: 0;
}

.mission-transition-pin {
  min-height: 100vh;
  min-height: 100svh;
  display: grid;
  place-items: center;
  padding: clamp(4rem, 8vh, 6.5rem) 1.5rem;
  perspective: 1500px;
}

.mission-sentence-stage {
  position: relative;
  width: min(1200px, 100%);
  min-height: min(72vh, 42rem);
  display: grid;
  place-items: center;
  text-align: left;
  color: var(--text);
  transform-style: preserve-3d;
  isolation: isolate;
  overflow: visible;
}

.mission-sentence {
  display: inline-block;
  width: auto;
  max-width: 100%;
  padding: 0;
  margin: 0;
  font-family:
    "Roboto",
    system-ui,
    -apple-system,
    sans-serif;
  font-size: clamp(0.95rem, 1.04vw, 1.22rem);
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0;
  text-align: left;
  overflow: visible;
  will-change: transform, opacity, filter;
}

.mission-sentence--label {
  grid-area: label;
  align-self: start;
  color: var(--primary);
  font-size: clamp(0.95rem, 1.04vw, 1.22rem);
  font-weight: 800;
  font-family:
    "Roboto",
    system-ui,
    -apple-system,
    sans-serif;
  text-align: left;
  text-transform: uppercase;
}

.mission-typography {
  grid-area: 1 / 1;
  width: min(100%, 67rem);
  justify-self: center;
  display: grid;
  grid-template-areas:
    "label right"
    "left right";
  grid-template-columns: max-content minmax(0, 34rem);
  grid-template-rows: auto 1fr;
  align-items: stretch;
  justify-content: center;
  column-gap: clamp(3rem, 5vw, 5rem);
  row-gap: clamp(0.8rem, 1.7vh, 1.35rem);
  text-align: left;
  transform-style: preserve-3d;
  will-change: transform, opacity, filter;
}

.mission-intro-layer {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  overflow: visible;
  transform-style: preserve-3d;
}

.mission-intro-ghost {
  position: absolute;
  display: block;
  will-change: transform, opacity, filter;
}

.mission-intro-ghost--label {
  width: max-content;
  max-width: none;
  white-space: nowrap;
}

.mission-intro-ghost--label .mission-word,
.mission-intro-ghost--label .mission-char {
  white-space: nowrap;
}

.mission-intro-ghost--headline > span,
.mission-intro-target--headline-center > span {
  white-space: nowrap;
}

.mission-intro-ghost--headline .mission-word {
  white-space: nowrap;
}

.mission-type-left,
.mission-type-right {
  min-width: 0;
  min-height: 100%;
  display: grid;
  align-content: stretch;
  transform-style: preserve-3d;
}

.mission-type-left {
  grid-area: left;
  grid-template-rows: 1fr;
}

.mission-type-right {
  grid-area: right;
  grid-template-rows: auto 1fr;
  gap: 0;
  max-width: min(100%, 34rem);
  padding-top: 0;
  justify-self: end;
}

.mission-type-headline {
  width: max-content;
  max-width: 100%;
  align-self: end;
  margin: 0;
  display: grid;
  row-gap: clamp(0.35rem, 0.9vh, 0.65rem);
  font-family:
    "Roboto",
    system-ui,
    -apple-system,
    sans-serif;
  font-size: clamp(2rem, 2.32vw, 2.75rem);
  font-weight: 800;
  font-style: italic;
  line-height: 1.28;
  letter-spacing: 0;
  color: var(--text);
  text-align: left;
  text-wrap: balance;
  transform-origin: 50% 50%;
  will-change: transform, opacity, filter;
}

.mission-type-headline span {
  display: block;
}

.mission-headline-line {
  display: block;
  width: max-content;
  max-width: 100%;
  white-space: nowrap;
}

.mission-headline-line--left {
  justify-self: start;
  text-align: left;
}

.mission-headline-line--right {
  justify-self: end;
  text-align: right;
}

.mission-type-headline em {
  color: var(--primary);
  font-style: inherit;
}

.mission-type-lead {
  align-self: start;
  max-width: 100%;
  margin: 0;
  color: var(--text-muted);
  font-size: clamp(1rem, 1.14vw, 1.18rem);
  font-weight: 600;
  line-height: 1.68;
  text-align: left;
  text-wrap: pretty;
  will-change: transform, opacity, filter;
}

.mission-lead-sentence {
  margin: 0;
}

.mission-type-detail {
  align-self: end;
  max-width: 100%;
  margin: 0;
  color: var(--text-muted);
  font-size: clamp(0.98rem, 1.08vw, 1.12rem);
  font-weight: 600;
  line-height: 1.68;
  text-align: left;
  text-wrap: pretty;
  will-change: transform, opacity, filter;
}

.text-keep {
  white-space: nowrap;
}

.mission-line,
.mission-line-mask,
.mission-word,
.mission-word-mask,
.mission-char,
.mission-char-mask {
  will-change: transform, opacity, filter, color;
}

.mission-line {
  text-align: inherit !important;
}

.mission-line-mask,
.mission-word-mask,
.mission-char-mask {
  display: inline-block;
  vertical-align: top;
  padding: 0.08em 0.18em 0.16em;
  margin: -0.08em -0.18em -0.16em;
}

.mission-word,
.mission-char {
  display: inline-block;
}

@media (min-width: 769px) and (max-height: 760px) {
  .mission-transition-pin {
    padding-block: clamp(2.75rem, 5.5vh, 4rem);
  }

  .mission-sentence-stage {
    min-height: min(76vh, 34rem);
  }

  .mission-type-headline {
    font-size: clamp(1.9rem, 2.18vw, 2.45rem);
    line-height: 1.3;
    row-gap: clamp(0.45rem, 1vh, 0.7rem);
  }

  .mission-type-right {
    gap: 0;
  }

  .mission-type-lead,
  .mission-type-detail {
    font-size: clamp(0.98rem, 1.16vw, 1.18rem);
    line-height: 1.56;
  }
}

.mission-transition.scroll-reveal,
.mission-transition.scroll-reveal.is-visible,
.mission-transition.scroll-reveal > *,
.mission-transition.scroll-reveal.is-visible > * {
  opacity: 1;
  transform: none;
  animation: none;
  will-change: auto;
}

.home-cta {
  text-align: center;
  padding: 4rem 0 5rem;
}

.home-cta .section-title {
  margin-bottom: 0.5rem;
}

.home-cta p {
  margin-bottom: 1.5rem;
}

.home-cta-transition {
  min-height: 100vh;
  min-height: 100svh;
  padding: 0;
  overflow: hidden;
  display: grid;
  place-items: center;
  border-top: 0;
  border-bottom: 0;
}

.home-cta-transition-inner {
  width: min(1200px, 100%);
  min-height: min(72vh, 42rem);
  display: grid;
  place-items: center;
  align-content: center;
  gap: clamp(1.1rem, 3vh, 2rem);
  padding: clamp(4rem, 8vh, 6.5rem) 1.5rem;
  text-align: center;
  transform-style: preserve-3d;
}

.home-cta-transition .section-label {
  margin: 0;
  color: var(--primary);
  font-family:
    "Roboto",
    system-ui,
    -apple-system,
    sans-serif;
  font-size: clamp(0.95rem, 1.25vw, 1.35rem);
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0;
  text-transform: uppercase;
  text-align: center;
  will-change: transform, opacity;
}

.home-cta-transition .section-title {
  max-width: min(100%, 58rem);
  margin: 0;
  color: var(--text);
  font-family:
    "Roboto",
    system-ui,
    -apple-system,
    sans-serif;
  font-size: clamp(2.8rem, 5.2vw, 5.8rem);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: 0;
  text-align: center;
  text-wrap: balance;
  will-change: transform, opacity;
}

.home-cta-copy {
  max-width: min(100%, 56rem);
  margin: 0;
  color: var(--text-muted);
  font-size: clamp(1.12rem, 2vw, 2rem);
  font-weight: 700;
  line-height: 1.35;
  text-align: center;
  text-wrap: balance;
  will-change: transform, opacity;
}

.home-cta-line,
.home-cta-word,
.home-cta-char {
  will-change: transform, opacity;
}

.home-cta-line-mask,
.home-cta-word-mask,
.home-cta-char-mask {
  display: inline-block;
  vertical-align: top;
  padding: 0.08em 0.12em 0.16em;
  margin: -0.08em -0.12em -0.16em;
}

.home-cta-word,
.home-cta-char {
  display: inline-block;
}

.home-cta-transition.scroll-reveal,
.home-cta-transition.scroll-reveal.is-visible,
.home-cta-transition.scroll-reveal > *,
.home-cta-transition.scroll-reveal.is-visible > *,
.home-cta-transition.scroll-reveal > .container > *,
.home-cta-transition.scroll-reveal.is-visible > .container > * {
  opacity: 1;
  transform: none;
  animation: none;
}

.cta-banner.scroll-reveal,
.cta-banner.scroll-reveal.is-visible,
.cta-banner.scroll-reveal > *,
.cta-banner.scroll-reveal.is-visible > *,
.cta-banner.scroll-reveal > .container > *,
.cta-banner.scroll-reveal.is-visible > .container > * {
  opacity: 1;
  transform: none;
  animation: none;
}

.cta-banner {
  --cta-transition-scroll: 165vh;
  min-height: calc(100vh + var(--cta-transition-scroll));
  min-height: calc(100svh + var(--cta-transition-scroll));
  display: block;
  text-align: center;
  padding: 0;
  margin-bottom: 0;
  overflow: visible;
  border-top: 0;
  border-bottom: 0;
}

.cta-transition-pin {
  position: sticky;
  top: 0;
  height: 100vh;
  height: 100svh;
  min-height: 100vh;
  min-height: 100svh;
  display: grid;
  place-items: center;
  padding: 0;
  overflow: hidden;
  perspective: 1500px;
}

.cta-banner .section-label {
  margin: 0;
  color: var(--primary);
  font-family:
    "Roboto",
    system-ui,
    -apple-system,
    sans-serif;
  font-size: clamp(0.95rem, 1.25vw, 1.35rem);
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0;
  text-transform: uppercase;
  text-align: center;
}

.cta-banner .section-title {
  max-width: min(100%, 58rem);
  margin: 0;
  color: var(--text);
  font-family:
    "Roboto",
    system-ui,
    -apple-system,
    sans-serif;
  font-size: clamp(2.8rem, 5.2vw, 5.8rem);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: 0;
  text-align: center;
  text-wrap: balance;
}

.cta-banner p {
  max-width: min(100%, 56rem);
  margin: 0;
  color: var(--text-muted);
  font-size: clamp(1.12rem, 2vw, 2rem);
  font-weight: 700;
  line-height: 1.35;
  text-align: center;
  text-wrap: balance;
}

.cta-transition-pin > .container,
.cta-banner > .container {
  width: min(1200px, 100%);
  min-height: min(72vh, 42rem);
  display: grid;
  place-items: center;
  align-content: center;
  gap: clamp(1.1rem, 3vh, 2rem);
  padding: clamp(4rem, 8vh, 6.5rem) 1.5rem;
  text-align: center;
  transform-style: preserve-3d;
}

.home-cta-transition:not(.cta-transition-ready) .section-label,
.home-cta-transition:not(.cta-transition-ready) .section-title,
.home-cta-transition:not(.cta-transition-ready) .home-cta-copy,
.cta-banner:not(.cta-transition-ready) .section-label,
.cta-banner:not(.cta-transition-ready) .section-title,
.cta-banner:not(.cta-transition-ready)
  .cta-transition-pin
  > .container
  > p:not(.section-label),
.cta-banner:not(.cta-transition-ready) > .container > p:not(.section-label) {
  opacity: 0;
  visibility: hidden;
}

.resume-cta,
.about-cta,
.project-cta {
  padding: 0;
  margin-bottom: 0;
}

.project-cta {
  margin-top: 0;
}

.resume-cta .section-label,
.about-cta .section-label,
.project-cta .section-label {
  margin-top: 0;
  margin-bottom: 0;
}

.resume-cta .section-title,
.about-cta .section-title,
.project-cta .section-title {
  margin-bottom: 0;
}

.resume-cta .section-title + p,
.about-cta .section-title + p,
.project-cta .section-title + p {
  margin-top: 0;
  margin-bottom: 0;
}

.project-filter {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 0 0 1.5rem;
}

.project-filter .filter-btn {
  --glass-compact-backdrop-filter: blur(var(--button-bg-blur)) saturate(140%);
  position: relative;
  overflow: hidden;
  border: 1px solid rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha)));
  background:
    linear-gradient(var(--rim-surface-block), var(--rim-surface-block)),
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.0065),
      rgba(255, 255, 255, 0.0025)
    ),
    color-mix(in srgb, var(--nav-bg-tint) 13%, transparent);
  backdrop-filter: var(--glass-compact-backdrop-filter);
  -webkit-backdrop-filter: var(--glass-compact-backdrop-filter);
  padding: 0.5rem 1rem;
  border-radius: 9999px;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--text);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  box-shadow: 0 0 0 rgba(126, 181, 190, 0);
  transition:
    color 0.24s ease,
    border-color 0.24s ease,
    background-color 0.24s ease,
    box-shadow 0.24s ease,
    transform 0.24s ease;
  font-family: inherit;
}

.project-filter .filter-btn:hover:not(.active),
.project-filter .filter-btn:focus-visible:not(.active) {
  color: #fff;
  border-color: rgb(255 255 255 / calc(0.0325 * var(--rim-static-alpha)));
  background:
    linear-gradient(var(--rim-surface-block), var(--rim-surface-block)),
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.011),
      rgba(255, 255, 255, 0.004)
    ),
    color-mix(in srgb, var(--nav-bg-tint) 10%, transparent);
  box-shadow:
    0 10px 24px rgba(0, 0, 0, 0.039),
    0 0 18px rgba(255, 255, 255, 0.018);
  transform: translateY(-2px) scale(1.035);
}

.project-filter .filter-btn:not(.active) .reactive-letter {
  color: inherit;
  text-shadow: none;
}

.project-filter .filter-btn.active {
  color: var(--interactive-muted);
  border-color: rgb(255 255 255 / calc(0.06175 * var(--rim-static-alpha)));
  background:
    linear-gradient(var(--rim-surface-block), var(--rim-surface-block)),
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.029),
      rgba(255, 255, 255, 0.011)
    ),
    color-mix(in srgb, #ffffff 7.5%, transparent);
  box-shadow: none;
}

.project-filter .filter-btn.active .reactive-letter {
  color: var(--inline-reactive-color);
  text-shadow: 0 0 12px var(--inline-reactive-glow);
}

.project-filter .filter-btn.active:hover,
.project-filter .filter-btn.active:focus-visible {
  border-color: rgb(255 255 255 / calc(0.078 * var(--rim-static-alpha)));
  background:
    linear-gradient(var(--rim-surface-block), var(--rim-surface-block)),
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.036),
      rgba(255, 255, 255, 0.014)
    ),
    color-mix(in srgb, #ffffff 9%, transparent);
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.039);
  transform: translateY(-2px) scale(1.035);
}

.project-filter .filter-btn:active {
  transform: translateY(0);
}

.project-item {
  transition:
    opacity 0.4s,
    transform 0.4s;
}

.project-item.hidden {
  display: none;
}

.project-preview {
  border-radius: var(--radius);
  --project-preview-padding: 1.25rem;
  --project-preview-gap: 0.5rem;
  --glass-tint-alpha: 0.35;
  background:
    linear-gradient(var(--rim-surface-block), var(--rim-surface-block)),
    linear-gradient(
      var(--ui-blob-accent-wash, transparent),
      var(--ui-blob-accent-wash, transparent)
    ),
    color-mix(
      in srgb,
      var(--card-layer-2-bg-tint) var(--glass-tint-mix, 0.65%),
      transparent
    );
  backdrop-filter: blur(var(--card-layer-2-bg-blur)) saturate(140%)
    brightness(var(--card-bg-brightness));
  -webkit-backdrop-filter: blur(var(--card-layer-2-bg-blur)) saturate(140%)
    brightness(var(--card-bg-brightness));
  padding: var(--project-preview-padding);
  min-height: 140px;
  width: 100%;
  position: relative;
  overflow: hidden;
  border: 1px solid rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha)));
  display: flex;
  flex-direction: column;
  gap: var(--project-preview-gap);
  height: 100%;
  transition:
    border-color 0.3s,
    transform 0.3s;
}

.project-preview:hover {
  border-color: rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha)));
  transform: none;
}

.project-details-panel {
  border-radius: var(--radius);
  --glass-tint-alpha: 0.35;
  background:
    linear-gradient(var(--rim-surface-block), var(--rim-surface-block)),
    linear-gradient(
      var(--ui-blob-accent-wash, transparent),
      var(--ui-blob-accent-wash, transparent)
    ),
    color-mix(
      in srgb,
      var(--card-layer-2-bg-tint) var(--glass-tint-mix, 0.65%),
      transparent
    );
  backdrop-filter: blur(var(--card-layer-2-bg-blur)) saturate(140%)
    brightness(var(--card-bg-brightness));
  -webkit-backdrop-filter: blur(var(--card-layer-2-bg-blur)) saturate(140%)
    brightness(var(--card-bg-brightness));
  padding: 1.25rem;
  width: 100%;
  border: 1px solid rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha)));
  height: 100%;
  display: flex;
  flex-direction: column;
}

.project-details-panel h3 {
  font-size: 0.9375rem;
  font-weight: 700;
  margin: 1.25rem 0 0.5rem;
  color: var(--text);
}

.project-details-panel h3:first-of-type {
  margin-top: 0;
}

.project-details-panel p {
  font-size: 0.875rem;
  color: var(--text-muted);
  margin-bottom: 0.5rem;
}

.project-details-panel ul {
  font-size: 0.875rem;
  color: var(--text-muted);
  padding-left: 1.25rem;
  margin-bottom: 0.75rem;
}

.project-details-panel .tech-tags {
  margin-top: auto;
}

.project-preview .preview-label {
  display: block;
  margin-bottom: 0;
  flex-shrink: 0;
  order: 1;
  font-weight: 600;
  line-height: 1.2;
  color: var(--text);
}

.preview-media {
  position: relative;
  width: 100%;
  min-height: 200px;
  flex: 1 1 auto;
  border-radius: 10px;
  overflow: hidden;
  background: #000;
  cursor: pointer;
  order: 2;
}

.preview-media:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 3px;
}

.preview-media picture {
  display: block;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.preview-screenshot {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  display: block;
  transform: scale(1);
  transform-origin: center;
  transition:
    opacity 0.4s ease,
    transform 0.5s cubic-bezier(0.22, 1, 0.36, 1),
    filter 0.42s ease;
}

.poster-crop-preview {
  align-self: stretch;
  height: 100%;
}

.poster-crop-preview .preview-media {
  aspect-ratio: 16 / 9;
  flex: 1 1 auto;
  min-height: 0;
}

.poster-crop-preview .preview-screenshot {
  object-position: center top;
}

.preview-media iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
  opacity: 0;
  transition: opacity 0.4s ease;
  pointer-events: none;
}

.video-preview {
  align-self: stretch;
  height: 100%;
  min-height: 320px;
}

.video-embed {
  position: relative;
  width: 100%;
  flex: 1 1 auto;
  min-height: clamp(180px, 30vw, 360px);
  border-radius: 10px;
  overflow: hidden;
  background: #000;
  cursor: pointer;
  order: 2;
  isolation: isolate;
}

.video-embed iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.35s ease;
}

.video-embed.video-active iframe {
  opacity: 1;
  pointer-events: auto;
}

.video-placeholder {
  -webkit-appearance: none;
  appearance: none;
  position: absolute;
  inset: 0;
  z-index: 1;
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
  padding: 0;
  border: 0;
  border-radius: inherit;
  background: #000;
  color: #fff;
  cursor: pointer;
  overflow: hidden;
  isolation: isolate;
  transition:
    opacity 0.35s ease,
    filter 0.35s ease;
}

.video-placeholder img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  opacity: 0.92;
  transform: scale(1);
  z-index: 0;
  transition:
    transform 0.5s cubic-bezier(0.22, 1, 0.36, 1),
    filter 0.42s ease;
}

.video-play-indicator {
  position: relative;
  z-index: 2;
  display: grid;
  place-items: center;
  width: 72px;
  height: 52px;
  border-radius: 16px;
  background: #ff0000;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35);
  pointer-events: none;
  transform: translateZ(0);
}

.video-play-indicator::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  margin-left: 4px;
  border-top: 12px solid transparent;
  border-bottom: 12px solid transparent;
  border-left: 20px solid #fff;
}

.video-placeholder:hover img,
.video-placeholder:focus-visible img {
  transform: scale(1.045);
  filter: saturate(1.08) brightness(1.04);
}

.video-placeholder:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: -4px;
}

.video-embed.video-active .video-placeholder {
  opacity: 0;
  pointer-events: none;
}

.scaled-preview .preview-media iframe {
  width: 200%;
  height: 200%;
  transform: scale(0.5);
  transform-origin: top left;
}

.project-preview:hover .preview-loaded iframe {
  opacity: 0;
  pointer-events: none;
}

.project-preview:hover .preview-loaded .preview-screenshot,
.project-preview:hover .preview-loaded .preview-placeholder {
  opacity: 1;
}

.preview-media:hover .preview-screenshot,
.preview-media:focus-visible .preview-screenshot,
.preview-media:hover .preview-placeholder,
.preview-media:focus-visible .preview-placeholder {
  transform: scale(1.045);
  filter: saturate(1.08) brightness(1.04);
}

.preview-placeholder {
  width: 100%;
  height: 100%;
  border-radius: 10px;
  background: linear-gradient(
    90deg,
    rgba(255, 255, 255, 0.03) 25%,
    rgba(255, 255, 255, 0.06) 50%,
    rgba(255, 255, 255, 0.03) 75%
  );
  background-size: 200% 100%;
  animation: placeholder-shimmer 1.4s ease-in-out infinite;
  transform: scale(1);
  transform-origin: center;
  transition:
    transform 0.5s cubic-bezier(0.22, 1, 0.36, 1),
    filter 0.42s ease;
}

body.asset-modal-open {
  overflow: hidden;
}

.asset-modal {
  align-items: center;
  display: flex;
  inset: 0;
  justify-content: center;
  padding: clamp(0.75rem, 2vw, 1.5rem);
  position: fixed;
  z-index: 2000;
}

.asset-modal[hidden] {
  display: none;
}

.asset-modal-backdrop {
  --glass-modal-backdrop-filter: blur(var(--modal-bg-blur)) saturate(140%);
  background: color-mix(in srgb, var(--modal-bg-tint) 8.775%, transparent);
  backdrop-filter: var(--glass-modal-backdrop-filter);
  -webkit-backdrop-filter: var(--glass-modal-backdrop-filter);
  border: 0;
  cursor: pointer;
  inset: 0;
  padding: 0;
  position: absolute;
}

.asset-modal-shell {
  --asset-modal-control-size: 3.25rem;
  --asset-modal-control-gap: clamp(0.7rem, 1.4vw, 1.1rem);
  align-items: center;
  display: grid;
  gap: var(--asset-modal-control-gap);
  grid-template-columns: var(--asset-modal-control-size) minmax(0, auto) var(
      --asset-modal-control-size
    );
  justify-content: center;
  max-height: 100%;
  max-width: 100%;
  position: relative;
  z-index: 1;
}

.asset-modal-dialog {
  --glass-modal-backdrop-filter: blur(var(--modal-bg-blur)) saturate(140%);
  background:
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--modal-bg-tint) 0.73125%, transparent),
      color-mix(in srgb, var(--modal-bg-tint) 0.24375%, transparent)
    ),
    color-mix(in srgb, var(--modal-bg-tint) 9.425%, transparent);
  backdrop-filter: var(--glass-modal-backdrop-filter);
  -webkit-backdrop-filter: var(--glass-modal-backdrop-filter);
  border: 1px solid rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha)));
  border-radius: var(--radius);
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.089375);
  display: grid;
  gap: 0.65rem;
  grid-template-rows: auto minmax(0, auto);
  max-height: calc(100dvh - 3rem);
  max-width: min(1500px, calc(100vw - 9.5rem));
  overflow: hidden;
  padding: 0.65rem;
  position: relative;
  width: fit-content;
}

.asset-modal-header {
  align-items: center;
  display: flex;
  gap: 1rem;
  justify-content: space-between;
}

.asset-modal-header h2 {
  color: var(--text);
  font-size: 1rem;
  line-height: 1.2;
  margin: 0;
}

.asset-modal-close {
  --glass-control-backdrop-filter: blur(var(--button-bg-blur)) saturate(160%);
  background: color-mix(in srgb, var(--button-bg-tint) 3.25%, transparent);
  backdrop-filter: var(--glass-control-backdrop-filter);
  -webkit-backdrop-filter: var(--glass-control-backdrop-filter);
  border: 1px solid rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha)));
  border-radius: 999px;
  color: var(--text);
  cursor: pointer;
  font-size: 0.8125rem;
  font-weight: 700;
  line-height: 1;
  padding: 0.55rem 0.75rem;
}

.asset-modal-close:hover,
.asset-modal-close:focus-visible {
  background: color-mix(in srgb, var(--button-bg-tint) 4.55%, transparent);
  outline: none;
}

.asset-modal-stage {
  align-items: center;
  background: color-mix(in srgb, var(--modal-bg-tint) 2.275%, transparent);
  border-radius: 10px;
  display: flex;
  justify-content: center;
  height: var(--asset-stage-height, auto);
  min-height: 0;
  max-height: calc(100dvh - 7rem);
  max-width: 100%;
  overflow: hidden;
  padding: 0;
  position: relative;
  aspect-ratio: var(--asset-stage-aspect, 16 / 9);
  touch-action: none;
  width: var(--asset-stage-width, min(70vw, 1200px));
}

.asset-modal--zoomed .asset-modal-stage {
  cursor: grab;
}

.asset-modal--zoomed .asset-modal-stage.is-panning {
  cursor: grabbing;
}

.asset-modal-nav {
  --glass-control-backdrop-filter: blur(var(--button-bg-blur)) saturate(160%);
  align-items: center;
  aspect-ratio: 1;
  background:
    linear-gradient(
      180deg,
      rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha))),
      rgb(255 255 255 / calc(0.0040625 * var(--rim-static-alpha)))
    ),
    color-mix(in srgb, var(--button-bg-tint) 3.25%, transparent);
  border: 1px solid rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha)));
  border-radius: 999px;
  backdrop-filter: var(--glass-control-backdrop-filter);
  -webkit-backdrop-filter: var(--glass-control-backdrop-filter);
  color: var(--text);
  cursor: pointer;
  display: inline-flex;
  flex: 0 0 var(--asset-modal-control-size);
  justify-content: center;
  line-height: 1;
  padding: 0;
  position: relative;
  transform: translateY(var(--asset-nav-offset, 0));
  width: var(--asset-modal-control-size);
  z-index: 2;
}

.asset-modal--controls-active .asset-modal-nav {
  opacity: 1;
}

.asset-modal.asset-modal--controls-dimmed .asset-modal-nav,
.asset-modal.asset-modal--controls-dimmed .asset-modal-nav:hover,
.asset-modal.asset-modal--controls-dimmed .asset-modal-nav:focus-visible {
  background:
    linear-gradient(
      180deg,
      rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha))),
      rgb(255 255 255 / calc(0.0040625 * var(--rim-static-alpha)))
    ),
    color-mix(in srgb, var(--button-bg-tint) 5.85%, transparent);
  opacity: 0.28;
}

.asset-modal-prev {
  justify-self: end;
}

.asset-modal-next {
  justify-self: start;
}

.asset-modal-nav:hover,
.asset-modal-nav:focus-visible {
  background: color-mix(in srgb, var(--button-bg-tint) 4.55%, transparent);
  outline: none;
}

.asset-modal-chevron {
  color: var(--text);
  display: block;
  flex: 0 0 1.5rem;
  filter: drop-shadow(0 0 6px var(--chevron-glow, transparent))
    drop-shadow(0 1px 2px rgba(0, 0, 0, 0.35));
  height: 1.5rem;
  transform-box: fill-box;
  transform-origin: center;
  width: 1.5rem;
}

.asset-modal-prev .asset-modal-chevron {
  transform: rotate(90deg);
}

.asset-modal-next .asset-modal-chevron {
  transform: rotate(-90deg);
}

.asset-modal-image {
  border-radius: 10px;
  display: block;
  height: 100%;
  max-height: 100%;
  max-width: 100%;
  object-fit: contain;
  transform: translate3d(var(--asset-pan-x, 0), var(--asset-pan-y, 0), 0)
    scale(var(--asset-zoom, 1));
  transform-origin: center;
  transition: transform 0.18s ease;
  user-select: none;
  -webkit-user-drag: none;
  width: 100%;
  will-change: transform;
}

.asset-modal-stage.is-panning .asset-modal-image {
  transition: none;
}

.asset-modal-zoom {
  --glass-control-backdrop-filter: blur(var(--button-bg-blur)) saturate(160%);
  align-items: center;
  background:
    linear-gradient(
      180deg,
      rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha))),
      rgb(255 255 255 / calc(0.0040625 * var(--rim-static-alpha)))
    ),
    color-mix(in srgb, var(--button-bg-tint) 5.85%, transparent);
  border: 1px solid rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha)));
  border-radius: 999px;
  backdrop-filter: var(--glass-control-backdrop-filter);
  -webkit-backdrop-filter: var(--glass-control-backdrop-filter);
  bottom: 0.85rem;
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.0455);
  color: var(--text);
  cursor: pointer;
  display: inline-flex;
  font-size: 0.8125rem;
  font-weight: 700;
  justify-content: center;
  left: 50%;
  line-height: 1;
  opacity: 0.28;
  padding: 0.6rem 0.9rem;
  position: absolute;
  transform: translateX(-50%);
  transition:
    opacity 0.4s ease,
    background 0.28s ease,
    box-shadow 0.28s ease;
  z-index: 3;
}

.asset-modal--controls-active .asset-modal-zoom {
  background:
    linear-gradient(
      180deg,
      rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha))),
      rgb(255 255 255 / calc(0.0040625 * var(--rim-static-alpha)))
    ),
    color-mix(in srgb, var(--button-bg-tint) 8.125%, transparent);
  opacity: 0.72;
  outline: none;
}

.asset-modal-zoom:hover {
  background:
    linear-gradient(
      180deg,
      rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha))),
      rgb(255 255 255 / calc(0.0040625 * var(--rim-static-alpha)))
    ),
    color-mix(in srgb, var(--button-bg-tint) 8.125%, transparent);
}

.asset-modal-zoom:focus-visible {
  outline: 2px solid rgba(93, 236, 255, 0.55);
  outline-offset: 3px;
}

.asset-modal-zoom:active {
  opacity: 0.9;
}

@keyframes placeholder-shimmer {
  0% {
    background-position: 200% 0;
  }
  100% {
    background-position: -200% 0;
  }
}

.project-preview p.small {
  flex: 1 1 auto;
  margin: 0;
  order: 3;
  font-size: 0.875rem;
  color: var(--text-muted);
}

.project-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  margin-top: 1rem;
}

@media (max-width: 768px) {
  .project-row {
    grid-template-columns: 1fr;
    gap: var(--mobile-page-gap, 1rem);
    margin-top: 0;
  }

  .project-card {
    margin-bottom: var(--mobile-page-gap, 1rem);
  }

  .project-preview,
  .project-details-panel {
    padding: var(--mobile-page-gap, 1rem);
  }

  .project-preview .preview-label {
    margin-bottom: 0;
  }

  .preview-media {
    min-height: 160px;
  }

  .video-preview {
    align-self: stretch;
    height: auto;
    min-height: 0;
  }

  .video-embed {
    aspect-ratio: 16 / 9;
    flex: 0 0 auto;
    min-height: 0;
  }

  .asset-modal {
    padding: 0.5rem;
  }

  .asset-modal-shell {
    --asset-modal-control-size: 2.75rem;
    display: block;
    max-width: calc(100vw - 1rem);
    width: fit-content;
  }

  .asset-modal-dialog {
    max-height: calc(100dvh - 1rem);
    max-width: calc(100vw - 1rem);
    padding: 0.6rem;
  }

  .asset-modal-header {
    gap: 0.75rem;
  }

  .asset-modal-header h2 {
    font-size: 0.9rem;
  }

  .asset-modal-stage {
    max-height: calc(100dvh - 5.5rem);
    width: min(
      var(--asset-stage-width, calc(100vw - 2.2rem)),
      calc(100vw - 2.2rem)
    );
  }

  .asset-modal-nav {
    --glass-control-backdrop-filter: blur(var(--button-bg-blur)) saturate(1.45);
    background:
      linear-gradient(
        180deg,
        rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha))),
        rgb(255 255 255 / calc(0.0040625 * var(--rim-static-alpha)))
      ),
      color-mix(in srgb, var(--button-bg-tint) 5.85%, transparent);
    backdrop-filter: var(--glass-control-backdrop-filter);
    -webkit-backdrop-filter: var(--glass-control-backdrop-filter);
    box-shadow: 0 10px 26px rgba(0, 0, 0, 0.0455);
    opacity: 0.28;
    position: absolute;
    top: var(--asset-mobile-nav-top, 50%);
    transform: translateY(-50%);
    transition:
      opacity 0.4s ease,
      background 0.28s ease,
      box-shadow 0.28s ease;
    width: var(--asset-modal-control-size);
  }

  .asset-modal--controls-active .asset-modal-nav,
  .asset-modal-nav:hover,
  .asset-modal-nav:focus-visible {
    background:
      linear-gradient(
        180deg,
        rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha))),
        rgb(255 255 255 / calc(0.0040625 * var(--rim-static-alpha)))
      ),
      color-mix(in srgb, var(--button-bg-tint) 8.125%, transparent);
    opacity: 0.68;
  }

  .asset-modal-nav:active {
    opacity: 0.86;
  }

  .asset-modal-zoom {
    display: none;
  }

  .asset-modal-prev {
    left: 1rem;
  }

  .asset-modal-next {
    right: 1rem;
  }
}

@media (max-width: 1024px) and (max-height: 560px) and (orientation: landscape) {
  .asset-modal {
    padding: 0.35rem;
  }

  .asset-modal-shell {
    --asset-modal-control-size: 2.5rem;
    display: block;
    max-width: calc(100vw - 0.7rem);
    width: fit-content;
  }

  .asset-modal-dialog {
    gap: 0.45rem;
    max-height: calc(100dvh - 0.7rem);
    max-width: calc(100vw - 0.7rem);
    padding: 0.5rem;
  }

  .asset-modal-header {
    gap: 0.55rem;
    min-height: 2.25rem;
  }

  .asset-modal-header h2 {
    font-size: 0.85rem;
  }

  .asset-modal-close {
    font-size: 0.75rem;
    padding: 0.45rem 0.65rem;
  }

  .asset-modal-stage {
    max-height: calc(100dvh - 4.05rem);
    width: min(
      var(--asset-stage-width, calc(100vw - 1.7rem)),
      calc(100vw - 1.7rem)
    );
  }

  .asset-modal-nav {
    --glass-control-backdrop-filter: blur(var(--button-bg-blur)) saturate(1.45);
    background:
      linear-gradient(
        180deg,
        rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha))),
        rgb(255 255 255 / calc(0.0040625 * var(--rim-static-alpha)))
      ),
      color-mix(in srgb, var(--button-bg-tint) 5.85%, transparent);
    backdrop-filter: var(--glass-control-backdrop-filter);
    -webkit-backdrop-filter: var(--glass-control-backdrop-filter);
    box-shadow: 0 10px 26px rgba(0, 0, 0, 0.0455);
    opacity: 0.28;
    position: absolute;
    top: var(--asset-mobile-nav-top, 50%);
    transform: translateY(-50%);
    transition:
      opacity 0.4s ease,
      background 0.28s ease,
      box-shadow 0.28s ease;
    width: var(--asset-modal-control-size);
  }

  .asset-modal--controls-active .asset-modal-nav,
  .asset-modal-nav:hover,
  .asset-modal-nav:focus-visible {
    background:
      linear-gradient(
        180deg,
        rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha))),
        rgb(255 255 255 / calc(0.0040625 * var(--rim-static-alpha)))
      ),
      color-mix(in srgb, var(--button-bg-tint) 8.125%, transparent);
    opacity: 0.68;
  }

  .asset-modal-nav:active {
    opacity: 0.86;
  }

  .asset-modal-zoom {
    display: none;
  }

  .asset-modal-prev {
    left: 0.65rem;
  }

  .asset-modal-next {
    right: 0.65rem;
  }
}

@media (hover: none), (pointer: coarse) {
  .asset-modal-nav:hover,
  .asset-modal-nav:focus-visible {
    background:
      linear-gradient(
        180deg,
        rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha))),
        rgb(255 255 255 / calc(0.0040625 * var(--rim-static-alpha)))
      ),
      color-mix(in srgb, var(--button-bg-tint) 5.85%, transparent);
    opacity: 0.28;
    outline: none;
  }

  .asset-modal--controls-active .asset-modal-nav,
  .asset-modal--controls-active .asset-modal-nav:hover,
  .asset-modal--controls-active .asset-modal-nav:focus-visible {
    background:
      linear-gradient(
        180deg,
        rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha))),
        rgb(255 255 255 / calc(0.0040625 * var(--rim-static-alpha)))
      ),
      color-mix(in srgb, var(--button-bg-tint) 8.125%, transparent);
    opacity: 0.68;
  }

  .asset-modal-nav:active {
    opacity: 0.86;
  }
}

.scroll-reveal {
  opacity: 0;
  transform: translateY(30px);
  will-change: transform, opacity;
}

.scroll-reveal.is-visible {
  opacity: 1;
  transform: none;
  will-change: auto;
  animation: none;
}

@keyframes scroll-reveal-in {
  from {
    opacity: 0;
    transform: translateY(30px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.card.scroll-reveal,
.story-card.scroll-reveal,
.resume-card.scroll-reveal,
.contact-layout.scroll-reveal,
.mission-overlay.scroll-reveal,
.cta-banner.scroll-reveal,
.home-cta.scroll-reveal,
.project-filter.scroll-reveal {
  opacity: 1;
  transform: translateY(30px);
  will-change: transform;
}

.card.scroll-reveal.is-visible,
.story-card.scroll-reveal.is-visible,
.resume-card.scroll-reveal.is-visible,
.contact-layout.scroll-reveal.is-visible,
.mission-overlay.scroll-reveal.is-visible,
.cta-banner.scroll-reveal.is-visible,
.home-cta.scroll-reveal.is-visible,
.project-filter.scroll-reveal.is-visible {
  opacity: 1;
  transform: none;
  will-change: auto;
  animation: none;
}

.card.scroll-reveal > *,
.story-card.scroll-reveal > *,
.resume-card.scroll-reveal > *,
.contact-layout.scroll-reveal > *,
.mission-overlay.scroll-reveal > *,
.cta-banner.scroll-reveal > *,
.home-cta.scroll-reveal > * {
  opacity: 0;
  transform: translateY(18px);
  will-change: opacity, transform;
}

.card.scroll-reveal.is-visible > *,
.story-card.scroll-reveal.is-visible > *,
.resume-card.scroll-reveal.is-visible > *,
.contact-layout.scroll-reveal.is-visible > *,
.mission-overlay.scroll-reveal.is-visible > *,
.cta-banner.scroll-reveal.is-visible > *,
.home-cta.scroll-reveal.is-visible > * {
  opacity: 1;
  transform: none;
  will-change: auto;
  animation: none;
}

.card.scroll-reveal > .project-row,
.contact-layout.scroll-reveal > .contact-form-panel,
.mission-overlay.scroll-reveal > .container,
.cta-banner.scroll-reveal > .container,
.home-cta.scroll-reveal > .container,
.project-filter.scroll-reveal {
  opacity: 1;
  transform: none;
  will-change: auto;
  animation: none;
}

.mission-overlay.scroll-reveal > .container > *,
.cta-banner.scroll-reveal > .container > *,
.home-cta.scroll-reveal > .container > *,
.contact-layout.scroll-reveal .contact-form-panel > h2,
.contact-layout.scroll-reveal .form-group label,
.contact-layout.scroll-reveal .form-actions {
  opacity: 0;
  transform: translateY(18px);
  will-change: opacity, transform;
}

.mission-overlay.scroll-reveal.is-visible > .container > *,
.cta-banner.scroll-reveal.is-visible > .container > *,
.home-cta.scroll-reveal.is-visible > .container > *,
.contact-layout.scroll-reveal.is-visible .contact-form-panel > h2,
.contact-layout.scroll-reveal.is-visible .form-group label,
.contact-layout.scroll-reveal.is-visible .form-actions {
  opacity: 1;
  transform: none;
  will-change: auto;
  animation: none;
}

.card.scroll-reveal .project-preview,
.card.scroll-reveal .project-details-panel,
.contact-layout.scroll-reveal .field-glass,
.contact-layout.scroll-reveal .contact-form-panel .btn,
.project-filter.scroll-reveal .filter-btn,
.mission-overlay.scroll-reveal .btn,
.cta-banner.scroll-reveal .btn,
.home-cta.scroll-reveal .btn {
  opacity: 1;
  transform: translateY(18px);
  will-change: transform;
}

.card.scroll-reveal.is-visible .project-preview,
.card.scroll-reveal.is-visible .project-details-panel,
.contact-layout.scroll-reveal.is-visible .field-glass,
.contact-layout.scroll-reveal.is-visible .contact-form-panel .btn,
.project-filter.scroll-reveal.is-visible .filter-btn,
.mission-overlay.scroll-reveal.is-visible .btn,
.cta-banner.scroll-reveal.is-visible .btn,
.home-cta.scroll-reveal.is-visible .btn {
  opacity: 1;
  transform: none;
  will-change: auto;
  animation: none;
}

@keyframes glass-content-reveal-in {
  from {
    opacity: 0;
    transform: translateY(18px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes glass-surface-reveal-in {
  from {
    transform: translateY(30px);
  }

  to {
    transform: translateY(0);
  }
}

@keyframes glass-inner-surface-reveal-in {
  from {
    transform: translateY(18px);
  }

  to {
    transform: translateY(0);
  }
}

.scroll-reveal-linked,
.scroll-reveal-linked.is-visible {
  opacity: var(--scroll-reveal-progress, 0);
  transform: translateY(var(--scroll-reveal-y, 30px));
  animation: none !important;
  will-change: transform, opacity;
}

.scroll-reveal-linked.scroll-reveal-complete {
  will-change: auto;
}

.card.scroll-reveal-linked,
.story-card.scroll-reveal-linked,
.resume-card.scroll-reveal-linked,
.contact-layout.scroll-reveal-linked,
.mission-overlay.scroll-reveal-linked,
.cta-banner.scroll-reveal-linked,
.home-cta.scroll-reveal-linked,
.project-filter.scroll-reveal-linked,
.card.scroll-reveal-linked.is-visible,
.story-card.scroll-reveal-linked.is-visible,
.resume-card.scroll-reveal-linked.is-visible,
.contact-layout.scroll-reveal-linked.is-visible,
.mission-overlay.scroll-reveal-linked.is-visible,
.cta-banner.scroll-reveal-linked.is-visible,
.home-cta.scroll-reveal-linked.is-visible,
.project-filter.scroll-reveal-linked.is-visible {
  opacity: 1;
  transform: translateY(var(--scroll-reveal-y, 30px));
  animation: none !important;
  will-change: transform;
}

.card.scroll-reveal-linked.scroll-reveal-complete,
.story-card.scroll-reveal-linked.scroll-reveal-complete,
.resume-card.scroll-reveal-linked.scroll-reveal-complete,
.contact-layout.scroll-reveal-linked.scroll-reveal-complete,
.mission-overlay.scroll-reveal-linked.scroll-reveal-complete,
.cta-banner.scroll-reveal-linked.scroll-reveal-complete,
.home-cta.scroll-reveal-linked.scroll-reveal-complete,
.project-filter.scroll-reveal-linked.scroll-reveal-complete {
  will-change: auto;
}

.card.scroll-reveal-linked > *,
.story-card.scroll-reveal-linked > *,
.resume-card.scroll-reveal-linked > *,
.contact-layout.scroll-reveal-linked > *,
.mission-overlay.scroll-reveal-linked > *,
.cta-banner.scroll-reveal-linked > *,
.home-cta.scroll-reveal-linked > *,
.card.scroll-reveal-linked.is-visible > *,
.story-card.scroll-reveal-linked.is-visible > *,
.resume-card.scroll-reveal-linked.is-visible > *,
.contact-layout.scroll-reveal-linked.is-visible > *,
.mission-overlay.scroll-reveal-linked.is-visible > *,
.cta-banner.scroll-reveal-linked.is-visible > *,
.home-cta.scroll-reveal-linked.is-visible > * {
  opacity: var(--scroll-reveal-progress, 0);
  transform: translateY(var(--scroll-reveal-inner-y, 18px));
  animation: none !important;
  will-change: opacity, transform;
}

.card.scroll-reveal-linked > .project-row,
.contact-layout.scroll-reveal-linked > .contact-form-panel,
.mission-overlay.scroll-reveal-linked > .container,
.cta-banner.scroll-reveal-linked > .container,
.home-cta.scroll-reveal-linked > .container,
.project-filter.scroll-reveal-linked,
.card.scroll-reveal-linked.is-visible > .project-row,
.contact-layout.scroll-reveal-linked.is-visible > .contact-form-panel,
.mission-overlay.scroll-reveal-linked.is-visible > .container,
.cta-banner.scroll-reveal-linked.is-visible > .container,
.home-cta.scroll-reveal-linked.is-visible > .container,
.project-filter.scroll-reveal-linked.is-visible {
  opacity: 1;
  transform: none;
  animation: none !important;
  will-change: auto;
}

.mission-overlay.scroll-reveal-linked > .container > *,
.cta-banner.scroll-reveal-linked > .container > *,
.home-cta.scroll-reveal-linked > .container > *,
.contact-layout.scroll-reveal-linked .contact-form-panel > h2,
.contact-layout.scroll-reveal-linked .form-group label,
.contact-layout.scroll-reveal-linked .form-actions,
.mission-overlay.scroll-reveal-linked.is-visible > .container > *,
.cta-banner.scroll-reveal-linked.is-visible > .container > *,
.home-cta.scroll-reveal-linked.is-visible > .container > *,
.contact-layout.scroll-reveal-linked.is-visible .contact-form-panel > h2,
.contact-layout.scroll-reveal-linked.is-visible .form-group label,
.contact-layout.scroll-reveal-linked.is-visible .form-actions {
  opacity: var(--scroll-reveal-progress, 0);
  transform: translateY(var(--scroll-reveal-inner-y, 18px));
  animation: none !important;
  will-change: opacity, transform;
}

.card.scroll-reveal-linked .project-preview,
.card.scroll-reveal-linked .project-details-panel,
.contact-layout.scroll-reveal-linked .field-glass,
.contact-layout.scroll-reveal-linked .contact-form-panel .btn,
.project-filter.scroll-reveal-linked .filter-btn,
.mission-overlay.scroll-reveal-linked .btn,
.cta-banner.scroll-reveal-linked .btn,
.home-cta.scroll-reveal-linked .btn,
.card.scroll-reveal-linked.is-visible .project-preview,
.card.scroll-reveal-linked.is-visible .project-details-panel,
.contact-layout.scroll-reveal-linked.is-visible .field-glass,
.contact-layout.scroll-reveal-linked.is-visible .contact-form-panel .btn,
.project-filter.scroll-reveal-linked.is-visible .filter-btn,
.mission-overlay.scroll-reveal-linked.is-visible .btn,
.cta-banner.scroll-reveal-linked.is-visible .btn,
.home-cta.scroll-reveal-linked.is-visible .btn {
  opacity: 1;
  transform: translateY(var(--scroll-reveal-inner-y, 18px));
  animation: none !important;
  will-change: transform;
}

.scroll-reveal-linked.scroll-reveal-complete > *,
.scroll-reveal-linked.scroll-reveal-complete .project-preview,
.scroll-reveal-linked.scroll-reveal-complete .project-details-panel,
.scroll-reveal-linked.scroll-reveal-complete .field-glass,
.scroll-reveal-linked.scroll-reveal-complete .contact-form-panel .btn,
.scroll-reveal-linked.scroll-reveal-complete .filter-btn,
.scroll-reveal-linked.scroll-reveal-complete .btn {
  will-change: auto;
}

@media (prefers-reduced-motion: reduce) {
  .scroll-reveal {
    animation: none;
    opacity: 1;
    transform: none;
  }

  .card.scroll-reveal > *,
  .story-card.scroll-reveal > *,
  .resume-card.scroll-reveal > *,
  .contact-layout.scroll-reveal > *,
  .mission-overlay.scroll-reveal > *,
  .cta-banner.scroll-reveal > *,
  .home-cta.scroll-reveal > *,
  .mission-overlay.scroll-reveal > .container > *,
  .cta-banner.scroll-reveal > .container > *,
  .home-cta.scroll-reveal > .container > *,
  .contact-layout.scroll-reveal .contact-form-panel > h2,
  .contact-layout.scroll-reveal .form-group label,
  .contact-layout.scroll-reveal .form-actions,
  .card.scroll-reveal .project-preview,
  .card.scroll-reveal .project-details-panel,
  .contact-layout.scroll-reveal .field-glass,
  .contact-layout.scroll-reveal .contact-form-panel .btn,
  .project-filter.scroll-reveal .filter-btn,
  .mission-overlay.scroll-reveal .btn,
  .cta-banner.scroll-reveal .btn,
  .home-cta.scroll-reveal .btn {
    animation: none;
    opacity: 1;
    transform: none;
    will-change: auto;
  }

  .preview-media,
  .preview-screenshot,
  .preview-placeholder,
  .project-filter .filter-btn,
  .story-card,
  .story-card img,
  .read-more-btn {
    transition: none;
  }

  .preview-media:hover .preview-screenshot,
  .preview-media:focus-visible .preview-screenshot,
  .preview-media:hover .preview-placeholder,
  .preview-media:focus-visible .preview-placeholder,
  .project-filter .filter-btn:hover,
  .project-filter .filter-btn:focus-visible,
  .story-card:hover,
  .story-card:focus-visible,
  .story-card:hover img,
  .story-card:focus-visible img,
  .read-more-btn:hover,
  .read-more-btn:focus-visible {
    transform: none;
    translate: none;
    filter: none;
  }
}

.story-card {
  border-radius: var(--radius);
  overflow: hidden;
  background: color-mix(
    in srgb,
    var(--card-layer-1-bg-tint) 0.65%,
    transparent
  );
  border: 1px solid rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha)));
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.040625);
  cursor: pointer;
  isolation: isolate;
  translate: 0 0;
  transition:
    border-color 0.28s ease,
    box-shadow 0.28s ease,
    translate 0.28s ease,
    background-color 0.28s ease;
}

.story-card:hover,
.story-card:focus-visible {
  border-color: rgb(126 181 190 / calc(0.08125 * var(--rim-static-alpha)));
  background-color: color-mix(
    in srgb,
    var(--card-layer-1-bg-tint) 3.25%,
    transparent
  );
  box-shadow:
    0 16px 36px rgba(0, 0, 0, 0.04875),
    0 0 26px rgba(126, 181, 190, 0.026);
  translate: 0 -3px;
}

.story-card:active {
  translate: 0 -1px;
}

.story-card img {
  width: 100%;
  height: 200px;
  object-fit: cover;
  transform: scale(1);
  transition:
    transform 0.5s cubic-bezier(0.22, 1, 0.36, 1),
    filter 0.32s ease;
}

.story-card:hover img,
.story-card:focus-visible img {
  transform: scale(1.045);
  filter: saturate(1.08) brightness(1.04);
}

.story-card-body {
  padding: 1.25rem;
  text-align: center;
}

.story-card-body h3 {
  font-size: 1.0625rem;
  font-weight: 700;
  margin-bottom: 0.5rem;
  min-height: 3rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.card-text {
  color: var(--text-muted);
  line-height: 1.7;
  display: grid;
  grid-template-rows: 0fr;
  transition:
    grid-template-rows 0.35s ease,
    opacity 0.35s ease;
  opacity: 0;
  margin-top: 1rem;
}

.card-text > * {
  overflow: hidden;
}

.card-text.expanded {
  grid-template-rows: 1fr;
  opacity: 1;
}

.story-card-body .card-text {
  font-size: 0.875rem;
}

.read-more-btn {
  background: none;
  border: none;
  color: var(--interactive-muted);
  font-size: 0.875rem;
  padding: 0;
  margin-top: 0.5rem;
  display: inline-block;
  font-family: inherit;
  text-decoration: none;
  text-underline-offset: 0.2em;
  transition:
    color 0.2s ease,
    text-shadow 0.2s ease,
    transform 0.2s ease;
}

.read-more-btn:hover,
.read-more-btn:focus-visible {
  color: var(--interactive-muted);
  text-decoration: none;
  text-shadow: none;
  transform: translateY(-1px);
}

.story-card:hover .read-more-btn,
.story-card:focus-visible .read-more-btn {
  color: var(--interactive-muted);
  text-shadow: none;
}

.read-more-btn:active {
  transform: translateY(0);
}

.resume-about {
  display: grid;
  grid-template-columns: 1fr 250px;
  gap: 3rem;
  align-items: center;
  padding: 3rem 0;
}

@media (max-width: 768px) {
  .resume-about {
    grid-template-columns: 1fr;
    text-align: center;
  }
}

.resume-about .about-photo-ring {
  width: 200px;
  height: 200px;
}

.resume-card {
  position: relative;
  background: color-mix(
    in srgb,
    var(--card-layer-1-bg-tint) 0.65%,
    transparent
  );
  border: 1px solid rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha)));
  border-radius: var(--radius);
  padding: 1.5rem;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.040625);
  isolation: isolate;
  transition: border-color 0.3s;
}

@media (max-width: 768px) {
  .resume-mobile-culling-active .resume-card.resume-card-mobile-culled {
    background: transparent !important;
    background-image: none !important;
    border-color: transparent !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    height: var(--resume-card-cull-height, 12rem);
    min-height: var(--resume-card-cull-height, 12rem);
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    overflow: hidden;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    transform: none !important;
    filter: none !important;
    transition: none !important;
    animation: none !important;
    content-visibility: hidden !important;
    contain-intrinsic-size: var(--resume-card-cull-height, 12rem);
    contain: layout style paint;
    will-change: auto;
  }

  .resume-mobile-culling-active .resume-card.resume-card-mobile-culled > * {
    display: none !important;
  }
}

.resume-card .card-header-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.5rem;
}

.resume-card .card-header-row h3,
.resume-card .card-header-row .job-title {
  margin-bottom: 0;
}

.resume-card .date-pill {
  flex-shrink: 0;
  white-space: nowrap;
}

.resume-card:hover {
  border-color: rgb(126 181 190 / calc(0.024375 * var(--rim-static-alpha)));
}

.resume-card h3 {
  font-size: 1.125rem;
  font-weight: 700;
  margin-bottom: 0.75rem;
}

.resume-card p {
  color: var(--text-muted);
  font-size: 0.9375rem;
  line-height: 1.7;
}

.resume-card .contact-link-row {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  flex-wrap: wrap;
}

.resume-card .contact-link-row + .contact-link-row {
  margin-top: 0.5rem;
}

.resume-card .contact-pill {
  min-width: 6.25rem;
  justify-content: center;
  padding-inline: 0.625rem;
}

.resume-card .contact-pill svg {
  width: 14px;
  height: 14px;
  fill: currentColor;
  color: var(--inline-reactive-color);
  filter: drop-shadow(0 0 8px var(--inline-reactive-glow));
}

.resume-card ul {
  padding-left: 1.25rem;
  color: var(--text-muted);
  font-size: 0.9375rem;
}

.resume-card ul li {
  margin-bottom: 0.25rem;
}

.resume-card a {
  color: var(--interactive-muted);
  text-underline-offset: 0.2em;
  transition:
    color 0.2s ease,
    opacity 0.2s ease,
    text-shadow 0.2s ease;
}

.resume-card a:hover,
.resume-card a:focus-visible {
  color: var(--interactive-muted);
  opacity: 1;
  text-decoration: underline;
  text-shadow: none;
}

.resume-card .job-title {
  font-weight: 600;
  font-size: 0.9375rem;
  color: var(--text);
  margin-bottom: 0.25rem;
}

.resume-card + .resume-card {
  margin-top: 0;
}

.contact-layout {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  min-height: 500px;
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha)));
  background: color-mix(
    in srgb,
    var(--card-layer-1-bg-tint) 0.65%,
    transparent
  );
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.040625);
  isolation: isolate;
}

@media (max-width: 768px) {
  .contact-layout {
    grid-template-columns: 1fr;
  }
}

.contact-image {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius) 0 0 var(--radius);
  height: 100%;
  min-height: 0;
}

@media (max-width: 768px) {
  .contact-image {
    border-radius: var(--radius) var(--radius) 0 0;
  }
}

.contact-image img {
  display: block;
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
}

.contact-image-overlay {
  position: absolute;
  bottom: 0;
  left: 0;
  padding: 2rem;
  background: linear-gradient(transparent, rgba(0, 0, 0, 0.7));
  width: 100%;
}

.contact-image-overlay p {
  font-size: 0.875rem;
  text-transform: uppercase;
  font-weight: 300;
  margin-bottom: 0;
}

.contact-image-overlay h2 {
  font-size: 2rem;
  font-weight: 700;
}

.contact-form-panel {
  padding: 2.5rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.contact-form-panel h2 {
  font-size: 1.125rem;
  text-transform: uppercase;
  font-weight: 300;
  margin-bottom: 2rem;
  color: var(--text);
}

.form-success {
  text-align: center;
  padding: 2rem;
}

.form-success svg {
  margin-bottom: 1rem;
}

.form-success h3 {
  font-weight: 700;
  margin-bottom: 0.5rem;
}

.form-success p {
  color: var(--text-muted);
  margin-bottom: 1rem;
}

.form-error {
  background: rgba(220, 53, 69, 0.1);
  border: 1px solid rgba(220, 53, 69, 0.3);
  border-radius: 8px;
  padding: 0.75rem 1rem;
  color: #f8d7da;
  font-size: 0.875rem;
  margin-bottom: 1rem;
  display: none;
}

.form-error.visible {
  display: block;
}

@media (max-width: 768px) {
  :root {
    --mobile-section-y-space: clamp(4.25rem, 10vh, 5.5rem);
    --mobile-section-header-top: clamp(5.5rem, 12vh, 7rem);
    --mobile-section-header-bottom: clamp(4rem, 9vh, 5.25rem);
  }

  .container {
    padding-inline: var(--mobile-page-gap, 1rem);
  }

  .site-footer {
    padding: 1rem 0 2rem;
  }

  .section {
    padding: var(--mobile-section-y-space) 0;
  }

  .section > .container > h2 {
    margin-bottom: 1rem !important;
  }

  .section-title {
    margin-bottom: 0.5rem !important;
  }

  .page-header {
    padding: var(--mobile-section-header-top) 0
      var(--mobile-section-header-bottom);
    text-align: center;
  }

  .page-header h1 {
    --page-title-size: clamp(1.5rem, 8.125vw, 2.5rem);
    max-width: 100%;
    text-wrap: normal;
    text-align: center;
  }

  .container:has(+ .section .contact-layout) > .page-header,
  .combined-page-section--contact .page-header {
    padding-top: var(--mobile-section-header-top);
    padding-bottom: var(--mobile-section-header-bottom);
  }

  .combined-page-section--projects > .container:first-child {
    padding-bottom: var(--mobile-section-y-space);
  }

  .combined-page-section--resume > .section {
    padding-top: var(--mobile-section-y-space) !important;
    padding-bottom: var(--mobile-section-y-space) !important;
  }

  .mobile-title-break {
    display: initial;
  }

  .project-page-header {
    margin-bottom: 1rem;
  }

  .grid-2,
  .grid-3,
  .resume-grid,
  .resume-grid > div,
  .interest-grid {
    gap: var(--mobile-page-gap, 1rem);
  }

  .card,
  .story-card-body,
  .project-preview,
  .project-details-panel,
  .resume-card {
    padding: var(--mobile-page-gap, 1rem);
  }

  .project-preview {
    --project-preview-padding: var(--mobile-page-gap, 1rem);
    --project-preview-gap: var(--mobile-page-gap, 1rem);
  }

  .project-card {
    margin-bottom: var(--mobile-page-gap, 1rem);
  }

  .project-card h3 {
    margin-top: 0.5rem;
  }

  .project-card p,
  .project-card ul,
  .project-role,
  .project-details-panel ul {
    margin-bottom: var(--mobile-page-gap, 1rem);
  }

  .project-filter {
    margin: 0 0 var(--mobile-page-gap, 1rem);
  }

  .project-row {
    gap: var(--mobile-page-gap, 1rem);
    margin-top: 0;
  }

  .project-card > .project-row + .project-row {
    margin-top: var(--mobile-page-gap, 1rem);
  }

  .project-preview .preview-label {
    margin-bottom: 0;
  }

  .preview-media {
    min-height: 160px;
  }

  .about-intro {
    row-gap: var(--mobile-page-gap, 1rem);
  }

  .about-photo-frame {
    margin-block: clamp(1.5rem, 6vh, 3rem);
  }

  .about-name {
    text-align: center;
  }

  .about-copy p + p {
    margin-top: var(--mobile-page-gap, 1rem);
  }

  .mission-overlay {
    padding: 4rem 0;
  }

  .mission-transition {
    min-height: 100vh;
    min-height: 100svh;
    padding: 0;
  }

  .mission-transition-pin {
    min-height: 100vh;
    min-height: 100svh;
    padding: clamp(4rem, 9vh, 5.5rem) var(--mobile-page-gap, 1rem);
    place-items: center;
  }

  .mission-sentence-stage {
    width: min(100%, 42rem);
    min-height: min(76vh, 40rem);
    place-items: center;
  }

  .mission-sentence {
    width: auto;
    padding-inline: 0;
    font-size: clamp(0.86rem, 3.6vw, 1.05rem);
    line-height: 1;
  }

  .mission-typography {
    width: 100%;
    min-height: auto;
    justify-self: stretch;
    grid-template-areas:
      "label"
      "left"
      "right";
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    gap: clamp(1.25rem, 4.5vh, 2.2rem);
    text-align: left;
  }

  .mission-type-left,
  .mission-type-right {
    max-width: 100%;
    min-height: auto;
    grid-template-rows: auto;
    padding-top: 0;
    gap: clamp(1rem, 3vh, 1.65rem);
    justify-self: stretch;
  }

  .mission-type-headline {
    width: 100%;
    max-width: 100%;
    align-self: auto;
    justify-self: stretch;
    margin-top: 0;
    font-size: clamp(1.75rem, 10vw, 4.8rem);
    line-height: 1.14;
    row-gap: clamp(0.16rem, 0.8vh, 0.45rem);
    text-align: center;
  }

  .mission-intro-ghost--headline,
  .mission-intro-target--headline-center {
    text-align: center !important;
  }

  .mission-type-detail {
    align-self: auto;
  }

  .mission-headline-line {
    justify-self: center;
    text-align: center;
    white-space: normal;
  }

  .mission-type-lead {
    max-width: 100%;
    font-size: clamp(0.98rem, 4.1vw, 1.1rem);
    line-height: 1.55;
    text-align: left;
  }

  .mission-type-detail {
    max-width: 100%;
    font-size: clamp(0.92rem, 3.75vw, 1rem);
    line-height: 1.55;
    text-align: left;
  }

  .text-keep {
    white-space: normal;
  }

  .home-cta {
    padding: 3rem 0 4rem;
  }

  .home-cta-transition {
    min-height: 100vh;
    min-height: 100svh;
    padding: 0;
  }

  .home-cta-transition-inner {
    min-height: min(76vh, 40rem);
    gap: clamp(1rem, 3.6vh, 1.8rem);
    padding: clamp(4rem, 9vh, 5.5rem) var(--mobile-page-gap, 1rem);
  }

  .home-cta-transition .section-title {
    font-size: clamp(1.75rem, 8.2vw, 3.15rem);
    line-height: 1.06;
    text-wrap: balance;
  }

  .home-cta-copy {
    font-size: clamp(1rem, 4.9vw, 1.34rem);
    line-height: 1.45;
  }

  .cta-banner {
    --cta-transition-scroll: 165vh;
    min-height: calc(100vh + var(--cta-transition-scroll));
    min-height: calc(100svh + var(--cta-transition-scroll));
    padding: 0;
    margin-bottom: 0;
    overflow: visible;
  }

  .cta-transition-pin {
    position: sticky;
    top: 0;
    height: 100vh;
    height: 100svh;
    min-height: 100vh;
    min-height: 100svh;
    padding: 0;
    overflow: hidden;
    place-items: center;
  }

  .cta-transition-pin > .container,
  .cta-banner > .container {
    min-height: min(76vh, 40rem);
    gap: clamp(1rem, 3.6vh, 1.8rem);
    padding: clamp(4rem, 9vh, 5.5rem) var(--mobile-page-gap, 1rem);
  }

  .cta-banner .section-title {
    font-size: clamp(1.75rem, 8.2vw, 3.15rem);
    line-height: 1.06;
    text-wrap: balance;
  }

  .project-cta .section-title {
    white-space: nowrap;
  }

  .home-cta-transition .section-title,
  .resume-cta .section-title {
    white-space: nowrap;
  }

  .cta-banner p {
    font-size: clamp(1rem, 4.9vw, 1.34rem);
    line-height: 1.45;
  }

  .resume-cta,
  .about-cta,
  .project-cta {
    padding: 0;
    margin-bottom: 0;
  }

  .project-cta {
    margin-top: 0;
  }

  .resume-cta .section-label,
  .about-cta .section-label,
  .project-cta .section-label {
    margin-bottom: 0;
  }

  .resume-cta .section-title + p,
  .about-cta .section-title + p,
  .project-cta .section-title + p,
  .home-cta p,
  .cta-banner p {
    margin-bottom: 0;
  }

  .card-text {
    margin-top: var(--mobile-page-gap, 1rem);
  }

  .resume-about {
    gap: 2rem;
    padding: 2rem 0;
  }

  .resume-about .about-photo-ring {
    margin-block: clamp(1.5rem, 6vh, 3rem);
  }

  .resume-card .card-header-row {
    gap: var(--mobile-page-gap, 1rem);
  }

  .form-group {
    margin-bottom: 0.75rem;
  }

  .contact-layout {
    min-height: 0;
  }

  .contact-image-overlay {
    padding: 1rem;
  }

  .contact-form-panel {
    padding: 1.5rem;
  }

  .contact-form-panel h2 {
    margin-bottom: 1rem;
  }

  .form-success {
    padding: 1rem;
  }
}

:is(
  .btn,
  .filter-btn,
  .badge,
  .card,
  .card-dark,
  .resume-card,
  .story-card,
  .project-preview,
  .project-details-panel,
  .contact-layout,
  .field-glass,
  .interest-icon,
  .form-group input,
  .form-group textarea
) {
  border-width: var(--rim-static-width);
}

.site-header,
.site-header.has-chrome-glass,
.site-footer,
.site-footer.has-chrome-glass,
.card,
.card-dark,
.story-card,
.resume-card,
.contact-layout {
  background-image: linear-gradient(
    var(--rim-surface-block),
    var(--rim-surface-block)
  );
}

.site-header {
  border-bottom-width: var(--rim-static-width);
}

.site-footer {
  border-top-width: var(--rim-static-width);
}

.mission-overlay,
.cta-banner {
  border-top-width: var(--rim-static-width);
  border-bottom-width: var(--rim-static-width);
}

.cta-banner {
  border-top-width: 0;
  border-bottom-width: 0;
}

.about-photo-ring {
  border-width: 0;
  box-shadow: none;
}

.badge,
.badge-light,
.interest-icon {
  border-color: color-mix(
    in srgb,
    var(--inline-reactive-color) calc(12% * var(--rim-static-alpha)),
    transparent
  );
}

.project-filter .filter-btn {
  border-width: var(--rim-static-width);
}

.btn:hover,
.btn:focus-visible {
  box-shadow:
    0 10px 24px rgba(0, 0, 0, 0.03575),
    0 0 18px rgb(126 181 190 / calc(0.026 * var(--rim-static-alpha)));
}

.form-group input:focus,
.form-group textarea:focus {
  box-shadow: 0 0 0 var(--rim-static-focus-width)
    rgb(126 181 190 / calc(0.01625 * var(--rim-static-alpha)));
}

.form-group input:hover,
.form-group textarea:hover {
  box-shadow: 0 0 0 var(--rim-static-focus-width)
    rgb(126 181 190 / calc(0.00975 * var(--rim-static-alpha)));
}

.project-filter .filter-btn:hover:not(.active),
.project-filter .filter-btn:focus-visible:not(.active) {
  box-shadow:
    0 10px 24px rgba(0, 0, 0, 0.039),
    0 0 18px rgb(255 255 255 / calc(0.018 * var(--rim-static-alpha)));
}

.project-filter .filter-btn.active {
  box-shadow: none;
}

.project-filter .filter-btn.active:hover,
.project-filter .filter-btn.active:focus-visible {
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.039);
}

.story-card:hover,
.story-card:focus-visible {
  box-shadow:
    0 16px 36px rgba(0, 0, 0, 0.04875),
    0 0 26px rgb(126 181 190 / calc(0.026 * var(--rim-static-alpha)));
}
