
:root {
  --primary: #7eb5be;
  --secondary: #005f6b;
  --text: #f3f7f6;
  --text-muted: #cad2da;
  --interactive-muted: var(--text-muted);
  --bg-dark: #000607;
  --radius: 16px;

  /* Rim */
  --rim-thickness: 1.08;
  --rim-brightness: 6;
  --rim-surface-brightness: 0.8;
  --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: 5px;
  --footer-bg-blur: 5px;
  --hero-bg-blur: 4px;
  --button-bg-blur: 5px;
  --cta-bg-blur: 5px;
  --card-layer-1-bg-blur: 5px;
  --card-layer-2-bg-blur: 6px;
  --card-layer-3-bg-blur: 7px;
  --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: 5px;
  --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: #00ff9d;
  --blob-color-2: #8400ff;
  --blob-color-3: #ff5e00;
  --blob-color-cycle-speed: 1;
  --blob-max-size: 0.7;
  --blob-intensity: 0.5;
}

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

html {
  scrollbar-gutter: stable;
}

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;
}

#dot-canvas,
#bg-canvas {
  position: fixed;
  inset: 0;
  width: 100vw;
  height: 100vh;
  height: 100lvh;
  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;
}

/* 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,
.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,
  .hero-arrow-glass
) {
  position: relative;
  isolation: isolate;
  border-color: transparent !important;
  --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,
  .hero-arrow-glass
)::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  border-radius: inherit;
  padding: max(0px, calc(var(--rim-thickness) * 1px));
  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)));
  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:
    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;
}

#blob-toggle,
#picture-bg-toggle {
  --glass-control-backdrop-filter: blur(var(--button-bg-blur)) saturate(160%);
  position: fixed;
  right: 12px;
  z-index: 9999;
  padding: 6px 10px;
  font: 500 12px/1 'Roboto', sans-serif;
  color: rgba(255, 255, 255, 0.85);
  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)))
  );
  border: 0;
  border-radius: 9999px;
  backdrop-filter: var(--glass-control-backdrop-filter);
  -webkit-backdrop-filter: var(--glass-control-backdrop-filter);
  transition:
    color 0.2s ease,
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

#blob-toggle:hover,
#blob-toggle:focus-visible,
#picture-bg-toggle:hover,
#picture-bg-toggle:focus-visible {
  color: #fff;
  transform: translateY(-1px);
  box-shadow: 0 0 16px rgb(126 181 190 / calc(0.024375 * var(--rim-static-alpha)));
}

#blob-toggle {
  bottom: 12px;
}

#picture-bg-toggle {
  bottom: 48px;
}

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: sticky;
  top: 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)
  );
  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-active-color) 10%, transparent) 24%,
    color-mix(in srgb, var(--nav-active-color) 68%, transparent) 48%,
    color-mix(in srgb, var(--ui-blob-accent-color, #f3f7f6) var(--ui-blob-accent-mix, 0%), transparent) 56%,
    color-mix(in srgb, var(--nav-active-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-bg {
  background: transparent;
}

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

.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 {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 2rem;
}

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

.hero-heading {
  font-family: 'Roboto Mono', monospace;
  position: relative;
  margin-top: calc(-1 * 6px);
  margin-left: 0rem;
  padding-top: 6px;
  --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-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, 13vw, 9rem));
  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, 13vw, 9rem));
  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: 1.5rem;
  font-size: 1rem;
  transform: translateX(0.5rem);
}

@media (max-width: 768px) {
  .hero {
    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;
  }
}

@media (min-width: 769px) {
  .home-bg {
    margin-top: -64px;
  }
}

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

.page-header h1 {
  font-size: 2.5rem;
  font-weight: 700;
}

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

.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 {
  width: 200px;
  height: 200px;
  border-radius: 50%;
  object-fit: cover;
  margin: 0 auto;
  border: 2px solid rgb(255 255 255 / calc(0.013 * var(--rim-static-alpha)));
  box-shadow:
    0 8px 32px rgba(0, 0, 0, 0.04875),
    0 0 0 1px rgb(126 181 190 / calc(0.02925 * var(--rim-static-alpha))),
    0 0 24px rgb(126 181 190 / calc(0.02925 * var(--rim-static-alpha)));
}

.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;
}

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

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

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

.cta-banner {
  text-align: center;
  padding: 5rem 0;
  margin-bottom: 2rem;
}

.cta-banner .section-label {
  color: var(--primary);
}

.cta-banner .section-title {
  color: var(--text);
}

.cta-banner p {
  color: var(--text-muted);
  margin-top: 1rem;
  margin-bottom: 1.5rem;
}

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

.project-cta {
  margin-top: 4rem;
}

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

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

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

.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: 0 0 18px rgba(255, 255, 255, 0.024);
}

.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), 0 0 24px rgba(255, 255, 255, 0.035);
  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: scroll-reveal-in 0.8s cubic-bezier(0.33, 1, 0.68, 1) var(--reveal-delay, 0ms) backwards;
}

@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: glass-surface-reveal-in 0.8s cubic-bezier(0.33, 1, 0.68, 1) var(--reveal-delay, 0ms) backwards;
}

.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: glass-content-reveal-in 0.8s cubic-bezier(0.33, 1, 0.68, 1) var(--reveal-delay, 0ms) backwards;
}

.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: glass-content-reveal-in 0.8s cubic-bezier(0.33, 1, 0.68, 1) var(--reveal-delay, 0ms) backwards;
}

.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: glass-inner-surface-reveal-in 0.8s cubic-bezier(0.33, 1, 0.68, 1) var(--reveal-delay, 0ms) backwards;
}

@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);
  }
}

@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 {
  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;
}

.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 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) {
  .container {
    padding-inline: var(--mobile-page-gap, 1rem);
  }

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

  .section {
    padding: 3rem 0;
  }

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

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

  .page-header {
    padding: 3rem 0 1rem;
  }

  .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-copy p + p {
    margin-top: var(--mobile-page-gap, 1rem);
  }

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

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

  .cta-banner {
    padding: 4rem 0;
    margin-bottom: 1rem;
  }

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

  .project-cta {
    margin-top: 3rem;
  }

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

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

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

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

  .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);
}

.about-photo {
  border-width: var(--rim-static-photo-width);
  box-shadow:
    0 8px 32px rgba(0, 0, 0, 0.04875),
    0 0 0 var(--rim-static-width) rgb(126 181 190 / calc(0.02925 * var(--rim-static-alpha))),
    0 0 24px rgb(126 181 190 / calc(0.02925 * var(--rim-static-alpha)));
}

.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: 0 0 18px rgb(255 255 255 / calc(0.024 * var(--rim-static-alpha)));
}

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

.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)));
}
