:root {
  color-scheme: dark;
  --bg: #0a0b0c;
  --bg-top: #0a0b0c;
  --glow-1: rgba(159, 181, 255, 0.08);
  --glow-2: rgba(159, 181, 255, 0.05);
  --grid-x: rgba(255, 255, 255, 0.025);
  --grid-y: rgba(255, 255, 255, 0.02);
  --header-bg: rgba(10, 11, 12, 0.82);
  --text: #f3f1ed;
  --muted: #a2a9b4;
  --accent: #9fb5ff;
  --accent-dot: rgba(159, 181, 255, 0.86);
  --accent-tag: #7f92c6;
  --accent-title: #b7c7ff;
  --hero-accent: #b7c7ff;
  --hero-orbit-text: rgba(219, 226, 242, 0.5);
  --hero-cloud-core: rgba(148, 171, 255, 0.7);
  --hero-cloud: rgba(148, 171, 255, 0.25);
  --hero-cloud-secondary: rgba(243, 241, 237, 0.16);
  --hero-stripe: rgba(255, 255, 255, 0.15);
  --hero-ball-bg: rgba(18, 24, 37, 0.34);
  --hero-ball-border: rgba(226, 235, 255, 0.34);
  --hero-ball-text: #edf2ff;
  --hero-ball-shadow: rgba(6, 10, 18, 0.18);
  --portrait-stage:
    radial-gradient(circle at 56% 28%, rgba(27, 26, 30, 0.18), transparent 42%),
    linear-gradient(135deg, #0a0b0c 0%, #121214 55%, #171518 100%);
  --accent-soft: rgba(159, 181, 255, 0.1);
  --accent-border: rgba(159, 181, 255, 0.35);
  --accent-hover-border: rgba(159, 181, 255, 0.28);
  --chip-text: #c3d0ff;
  --fragment-title: #d7e1ff;
  --line: rgba(255, 255, 255, 0.1);
  --line-strong: rgba(255, 255, 255, 0.18);
  --hero-note-line: rgba(255, 255, 255, 0.18);
  --timeline-date: #7f8896;
  --placeholder-bg:
    radial-gradient(circle at top, rgba(159, 181, 255, 0.08), transparent 38%),
    linear-gradient(180deg, rgba(18, 22, 30, 0.96), rgba(12, 15, 21, 0.96));
  --placeholder-bg-hover:
    radial-gradient(circle at top, rgba(159, 181, 255, 0.12), transparent 40%),
    linear-gradient(180deg, rgba(20, 24, 33, 0.98), rgba(13, 17, 24, 0.98));
  --placeholder-dash: rgba(255, 255, 255, 0.12);
  --placeholder-hover-border: rgba(159, 181, 255, 0.35);
  --film-shell-bg: #06080c;
  --film-frame-bg: linear-gradient(180deg, rgba(13, 16, 22, 0.96), rgba(9, 12, 17, 0.96));
  --film-frame-bg-hover: linear-gradient(180deg, rgba(17, 21, 29, 0.98), rgba(11, 14, 20, 0.98));
  --film-frame-border-hover: rgba(159, 181, 255, 0.28);
  --phone-stack-bg:
    radial-gradient(circle at top, rgba(159, 181, 255, 0.09), transparent 40%),
    linear-gradient(180deg, rgba(20, 24, 32, 0.98), rgba(12, 15, 22, 0.98));
  --phone-stack-border: rgba(255, 255, 255, 0.12);
  --card-swap-card-bg:
    linear-gradient(180deg, rgba(17, 20, 28, 0.92), rgba(11, 14, 20, 0.96));
  --card-swap-card-border: rgba(226, 235, 255, 0.2);
  --card-swap-card-shadow: rgba(0, 0, 0, 0.18);
  --card-swap-kicker: rgba(183, 199, 255, 0.72);
  --toggle-shell: #efe4d5;
  --toggle-shell-border: rgba(69, 58, 47, 0.18);
  --toggle-thumb: rgba(255, 255, 255, 0.76);
  --toggle-thumb-shadow: rgba(6, 9, 14, 0.16);
  --toggle-glyph: #1e1b18;
  --toggle-glyph-muted: rgba(30, 27, 24, 0.55);
  --selection: rgba(159, 181, 255, 0.28);
  --max-width: 1260px;
  --ease: 220ms ease;
  --display: "Inter Tight", "Inter", sans-serif;
  --hero-serif: "Newsreader", Georgia, serif;
  --body: "Inter", sans-serif;
}

:root[data-theme="light"] {
  color-scheme: light;
  --bg: #ffffff;
  --bg-top: #ffffff;
  --glow-1: rgba(255, 255, 255, 0.72);
  --glow-2: rgba(142, 148, 196, 0.06);
  --grid-x: rgba(138, 126, 114, 0.04);
  --grid-y: rgba(138, 126, 114, 0.03);
  --header-bg: rgba(255, 255, 255, 0.88);
  --text: #171715;
  --muted: #6d6a64;
  --accent: #7588d3;
  --accent-dot: rgba(117, 136, 211, 0.75);
  --accent-tag: #6d7fbf;
  --accent-title: #8799dc;
  --hero-accent: #8799dc;
  --hero-orbit-text: rgba(62, 67, 81, 0.34);
  --hero-cloud-core: rgba(126, 149, 246, 0.58);
  --hero-cloud: rgba(126, 149, 246, 0.18);
  --hero-cloud-secondary: rgba(255, 255, 255, 0.92);
  --hero-stripe: rgba(255, 255, 255, 0.74);
  --hero-ball-bg: rgba(255, 255, 255, 0.74);
  --hero-ball-border: rgba(117, 136, 211, 0.34);
  --hero-ball-text: #3f4e87;
  --hero-ball-shadow: rgba(117, 136, 211, 0.14);
  --portrait-stage:
    radial-gradient(circle at 54% 26%, rgba(255, 255, 255, 0.88), transparent 46%),
    linear-gradient(135deg, #ffffff 0%, #fcfcfd 58%, #f6f6f8 100%);
  --accent-soft: rgba(117, 136, 211, 0.08);
  --accent-border: rgba(117, 136, 211, 0.24);
  --accent-hover-border: rgba(117, 136, 211, 0.24);
  --chip-text: #5d71bd;
  --fragment-title: #2b3040;
  --line: #e5dfd7;
  --line-strong: #d6cec4;
  --hero-note-line: #d6cec4;
  --timeline-date: #8b847b;
  --placeholder-bg:
    linear-gradient(180deg, rgba(255, 255, 255, 0.84), rgba(241, 237, 230, 0.58));
  --placeholder-bg-hover:
    linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(241, 237, 230, 0.72));
  --placeholder-dash: rgba(142, 135, 126, 0.22);
  --placeholder-hover-border: #d6cec4;
  --film-shell-bg: #201d1a;
  --film-frame-bg: linear-gradient(180deg, rgba(249, 247, 243, 0.96), rgba(241, 237, 230, 0.96));
  --film-frame-bg-hover: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(245, 241, 234, 0.98));
  --film-frame-border-hover: #d6cec4;
  --phone-stack-bg:
    linear-gradient(180deg, rgba(255, 255, 255, 0.86), rgba(241, 237, 230, 0.84));
  --phone-stack-border: rgba(142, 135, 126, 0.22);
  --card-swap-card-bg:
    linear-gradient(180deg, rgba(255, 255, 255, 0.58), rgba(255, 255, 255, 0.58));
  --card-swap-card-border: rgba(0, 0, 0, 0.08);
  --card-swap-card-shadow: rgba(20, 24, 34, 0.045);
  --card-swap-kicker: rgba(117, 136, 211, 0.7);
  --toggle-shell: #eee5d7;
  --toggle-shell-border: rgba(69, 58, 47, 0.14);
  --toggle-thumb: rgba(255, 255, 255, 0.9);
  --toggle-thumb-shadow: rgba(23, 23, 21, 0.12);
  --toggle-glyph: #1e1b18;
  --toggle-glyph-muted: rgba(30, 27, 24, 0.52);
  --selection: rgba(117, 136, 211, 0.18);
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  min-width: 320px;
  background: var(--bg);
  color: var(--text);
  font-family: var(--body);
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  overflow-x: clip;
}

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

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

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

#root {
  width: 100%;
  overflow-x: clip;
}

.page-shell {
  position: relative;
  overflow-x: clip;
}

.page-shell::before {
  display: none;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  width: min(calc(100% - 3rem), var(--max-width));
  margin: 0 auto;
  padding: 1.2rem 0 0.55rem;
  background: var(--header-bg);
  border-bottom: 0;
  backdrop-filter: blur(18px);
}

.site-header-divider {
  grid-column: 1 / -1;
  margin-top: 0.04rem;
}

.site-header > .theme-toggle {
  grid-column: 2;
  justify-self: end;
}

.timeline-entry::after,
.fragment-link::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  height: 1px;
  background:
    radial-gradient(
        circle at 0 50%,
        transparent 0.21rem,
        var(--accent-dot) 0.22rem,
        var(--accent-dot) 0.31rem,
        transparent 0.32rem
      )
      repeat-x;
  background-size: 0.74rem 1px;
  opacity: 0;
  transition: opacity var(--ease);
}

.timeline-entry:hover::after,
.fragment-link:hover::after {
  opacity: 0.78;
}

.theme-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 4.28rem;
  height: 2.28rem;
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
  transition:
    transform var(--ease);
}

.theme-toggle:hover {
  transform: translateY(-1px) scale(1.015);
}

.theme-toggle:focus-visible {
  outline: none;
}

.theme-toggle-shell {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  overflow: hidden;
  border: 1px solid var(--hero-ball-border);
  border-radius: 999px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.24), rgba(255, 255, 255, 0.05)),
    var(--hero-ball-bg);
  box-shadow:
    0 18px 38px var(--hero-ball-shadow),
    inset 0 1px 0 rgba(255, 255, 255, 0.28),
    inset 0 -1px 0 rgba(255, 255, 255, 0.05);
  backdrop-filter: blur(24px) saturate(160%);
  -webkit-backdrop-filter: blur(24px) saturate(160%);
  transition:
    border-color var(--ease),
    box-shadow var(--ease),
    background var(--ease);
}

.theme-toggle-shell::before {
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: inherit;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0) 48%),
    radial-gradient(circle at 26% 20%, rgba(255, 255, 255, 0.18), transparent 34%);
  opacity: 0.95;
  pointer-events: none;
}

.theme-toggle:focus-visible .theme-toggle-shell {
  box-shadow:
    0 0 0 4px var(--accent-soft),
    0 18px 38px var(--hero-ball-shadow),
    inset 0 1px 0 rgba(255, 255, 255, 0.28),
    inset 0 -1px 0 rgba(255, 255, 255, 0.05);
}

.theme-toggle-thumb {
  position: absolute;
  top: 0.17rem;
  left: 0.18rem;
  z-index: 1;
  width: 1.6rem;
  height: 1.6rem;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 999px;
  background: #171716;
  box-shadow:
    0 8px 16px rgba(0, 0, 0, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
  transition:
    transform var(--ease),
    width var(--ease),
    border-color var(--ease),
    background var(--ease),
    box-shadow var(--ease);
}

.theme-toggle.is-light .theme-toggle-thumb {
  transform: translateX(2.15rem);
  background: #fffdf7;
  border-color: rgba(17, 17, 17, 0.08);
  box-shadow:
    0 6px 14px rgba(0, 0, 0, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

.theme-toggle:active .theme-toggle-thumb {
  width: 1.72rem;
}

.theme-toggle.is-light:active .theme-toggle-thumb {
  transform: translateX(2.03rem);
}

.theme-toggle-glyph {
  position: absolute;
  top: 50%;
  z-index: 0;
  width: 0.92rem;
  height: 0.92rem;
  transform: translateY(-50%);
  transition:
    opacity var(--ease),
    transform var(--ease);
  pointer-events: none;
}

.theme-toggle-glyph-sun {
  left: 0.54rem;
}

.theme-toggle-glyph-moon {
  right: 0.52rem;
}

.theme-toggle-glyph-sun::before,
.theme-toggle-glyph-moon::before {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  font-size: 0.84rem;
  line-height: 1;
}

.theme-toggle-glyph-sun::before {
  content: "✺";
  color: rgba(31, 31, 29, 0.9);
}

.theme-toggle-glyph-moon::before {
  content: "☾";
  color: rgba(243, 241, 237, 0.94);
}

.theme-toggle.is-dark .theme-toggle-glyph-sun {
  opacity: 0;
}

.theme-toggle.is-dark .theme-toggle-glyph-moon {
  opacity: 0.9;
  transform: translateY(-50%) scale(1.04);
}

.theme-toggle.is-light .theme-toggle-glyph-sun {
  opacity: 0.96;
  transform: translateY(-50%) scale(1.04);
}

.theme-toggle.is-light .theme-toggle-glyph-moon {
  opacity: 0;
}

main {
  width: min(calc(100% - 3rem), var(--max-width));
  margin: 0 auto;
  padding-bottom: 5rem;
}

.section {
  padding: 6.5rem 0;
  border-top: 0;
  scroll-margin-top: 5.5rem;
}

.hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 0.95fr);
  gap: clamp(2.5rem, 7vw, 7rem);
  min-height: calc(100svh - 5rem);
  padding-top: 5rem;
  border-top: none;
  align-items: center;
  isolation: isolate;
}

.hero-liquid-field {
  position: absolute;
  inset: -3rem -4.4rem -2.8rem -2.5rem;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}

.hero-copy {
  display: grid;
  gap: 1.8rem;
  max-width: 45rem;
  position: relative;
  z-index: 1;
}

.hero-title {
  margin: 0;
  color: var(--text);
  font-family: var(--display);
  font-size: clamp(2.3rem, 4.9vw, 3.8rem);
  font-weight: 600;
  letter-spacing: -0.05em;
  line-height: 1;
  white-space: nowrap;
  perspective: 1100px;
}

.hero-title > .split-parent,
.hero-title > span {
  display: inline-block;
}

.hero-title-primary {
  max-width: 100%;
  margin-right: 0.7ch;
}

.hero-title-accent {
  color: var(--accent-title);
}

.split-parent {
  overflow: hidden;
}

.split-text-content {
  display: inline-block;
}

.split-unit,
.split-whitespace {
  display: inline-block;
}

.split-unit {
  backface-visibility: hidden;
  transform-origin: 50% 100%;
}

.hero-subtitle {
  margin: 0;
  max-width: 38rem;
  color: var(--muted);
  font-family: var(--hero-serif);
  font-size: clamp(0.96rem, 1.18vw, 1.08rem);
  font-weight: 400;
  letter-spacing: -0.01em;
  line-height: 1.7;
}

.hero-subtitle-cursor {
  color: var(--accent-title);
}

.text-type {
  display: inline-block;
  white-space: pre-wrap;
}

.text-type__cursor {
  margin-left: 0.18rem;
  display: inline-block;
  opacity: 1;
}

.text-type__cursor--hidden {
  display: none;
}

.hero-side-nav {
  position: relative;
  align-self: center;
  width: min(33rem, 100%);
  height: 39rem;
  margin-left: auto;
  isolation: isolate;
  z-index: 1;
}

.metaballs-container {
  position: relative;
  width: 100%;
  height: 100%;
}

.hero-metaballs {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  opacity: 0.96;
  mask-image: radial-gradient(
    ellipse at 137% 50%,
    rgba(0, 0, 0, 1) 0%,
    rgba(0, 0, 0, 0.98) 13%,
    rgba(0, 0, 0, 0.84) 26%,
    rgba(0, 0, 0, 0.2) 42%,
    transparent 67%
  );
  -webkit-mask-image: radial-gradient(
    ellipse at 137% 50%,
    rgba(0, 0, 0, 1) 0%,
    rgba(0, 0, 0, 0.98) 13%,
    rgba(0, 0, 0, 0.84) 26%,
    rgba(0, 0, 0, 0.2) 42%,
    transparent 67%
  );
}

.hero-metaballs::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    linear-gradient(
      90deg,
      transparent 0%,
      rgba(0, 0, 0, 0.003) 50%,
      rgba(0, 0, 0, 0.02) 61%,
      rgba(0, 0, 0, 0.12) 74%,
      rgba(0, 0, 0, 0.56) 85%,
      rgba(0, 0, 0, 0.86) 100%
    );
  mix-blend-mode: destination-in;
}

.hero-metaballs::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    radial-gradient(
      ellipse at 143% 50%,
      rgba(255, 255, 255, 0.042) 0%,
      rgba(255, 255, 255, 0.018) 16%,
      transparent 52%
    );
}

.hero-metaballs .metaballs-container {
  width: 100%;
  height: 100%;
  mask-image: linear-gradient(
    90deg,
    transparent 0%,
    rgba(0, 0, 0, 0.006) 56%,
    rgba(0, 0, 0, 0.05) 66%,
    rgba(0, 0, 0, 0.64) 80%,
    rgba(0, 0, 0, 1) 100%
  );
  -webkit-mask-image: linear-gradient(
    90deg,
    transparent 0%,
    rgba(0, 0, 0, 0.006) 56%,
    rgba(0, 0, 0, 0.05) 66%,
    rgba(0, 0, 0, 0.64) 80%,
    rgba(0, 0, 0, 1) 100%
  );
}

.hero-metaballs canvas {
  display: block;
  width: 100%;
  height: 100%;
}

:root[data-theme="light"] .hero-metaballs {
  opacity: 0.9;
  mask-image: radial-gradient(
    ellipse at 135% 50%,
    rgba(0, 0, 0, 1) 0%,
    rgba(0, 0, 0, 0.96) 14%,
    rgba(0, 0, 0, 0.7) 27%,
    rgba(0, 0, 0, 0.12) 41%,
    transparent 63%
  );
  -webkit-mask-image: radial-gradient(
    ellipse at 135% 50%,
    rgba(0, 0, 0, 1) 0%,
    rgba(0, 0, 0, 0.96) 14%,
    rgba(0, 0, 0, 0.7) 27%,
    rgba(0, 0, 0, 0.12) 41%,
    transparent 63%
  );
}

:root[data-theme="light"] .hero-metaballs::before {
  display: none;
}

:root[data-theme="light"] .hero-metaballs::after {
  background: radial-gradient(
    ellipse at 140% 50%,
    rgba(255, 255, 255, 0.14) 0%,
    rgba(255, 255, 255, 0.06) 17%,
    transparent 48%
  );
}

:root[data-theme="light"] .hero-metaballs .metaballs-container {
  mask-image: linear-gradient(
    90deg,
    transparent 0%,
    rgba(0, 0, 0, 0.002) 58%,
    rgba(0, 0, 0, 0.02) 68%,
    rgba(0, 0, 0, 0.24) 82%,
    rgba(0, 0, 0, 0.72) 100%
  );
  -webkit-mask-image: linear-gradient(
    90deg,
    transparent 0%,
    rgba(0, 0, 0, 0.002) 58%,
    rgba(0, 0, 0, 0.02) 68%,
    rgba(0, 0, 0, 0.24) 82%,
    rgba(0, 0, 0, 0.72) 100%
  );
}

:root[data-theme="light"] .hero-subtitle,
:root[data-theme="light"] .about-current-copy,
:root[data-theme="light"] .experience-date,
:root[data-theme="light"] .experience-role,
:root[data-theme="light"] .experience-place {
  color: #171715;
}

:root[data-theme="light"] .hero-subtitle-cursor,
:root[data-theme="light"] .about-current-cursor {
  color: #171715;
}

.hero-ball-link {
  position: absolute;
  left: var(--ball-x);
  top: var(--ball-y);
  z-index: 1;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  width: var(--ball-size);
  height: var(--ball-size);
  padding: 0.55rem;
  border: 1px solid var(--hero-ball-border);
  border-radius: 999px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.24), rgba(255, 255, 255, 0.05)),
    var(--hero-ball-bg);
  color: var(--hero-ball-text);
  box-shadow:
    0 22px 46px var(--hero-ball-shadow),
    inset 0 1px 0 rgba(255, 255, 255, 0.34),
    inset 0 -1px 0 rgba(255, 255, 255, 0.06);
  backdrop-filter: blur(32px) saturate(185%);
  -webkit-backdrop-filter: blur(32px) saturate(185%);
  transform: translate(-50%, -50%);
  transition:
    color var(--ease),
    border-color var(--ease),
    background var(--ease),
    box-shadow var(--ease),
    transform var(--ease);
}

.hero-ball-link::before {
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: inherit;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.22), rgba(255, 255, 255, 0) 48%),
    radial-gradient(circle at 28% 22%, rgba(255, 255, 255, 0.22), transparent 38%);
  opacity: 0.95;
  pointer-events: none;
}

.hero-ball-link span {
  position: relative;
  z-index: 1;
  max-width: 80%;
  font-family: var(--hero-serif);
  font-size: clamp(0.78rem, 0.96vw, 0.92rem);
  font-weight: 400;
  line-height: 1.08;
  letter-spacing: -0.01em;
  text-align: center;
  text-wrap: balance;
}

.hero-ball-link:hover,
.hero-ball-link:focus-visible {
  color: var(--text);
}

.hero-ball-link:hover,
.hero-ball-link:focus-visible {
  border-color: var(--accent-hover-border);
  box-shadow:
    0 24px 50px var(--hero-ball-shadow),
    0 0 0 0.35rem var(--accent-soft);
  transform: translate(-50%, -50%) scale(1.06);
}

.section-heading h2,
.about-copy h2,
.contact-copy h2 {
  margin: 0;
  font-family: var(--display);
  font-weight: 600;
  letter-spacing: -0.05em;
  line-height: 0.92;
  text-wrap: balance;
}

.section-heading h2,
.about-copy h2,
.contact-copy h2 {
  font-size: clamp(2.3rem, 5vw, 4.8rem);
}

.section-heading p,
.about-current p,
.timeline-copy p,
.film-meta span,
.fragment-link small,
.contact-copy p {
  margin: 0;
  color: var(--muted);
  font-size: 1rem;
  line-height: 1.72;
}

.section-tag {
  margin: 0 0 1.25rem;
  color: var(--accent-tag);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.section-heading {
  display: grid;
  gap: 0.9rem;
  max-width: 54rem;
}

.about-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(260px, 0.72fr);
  gap: clamp(2.8rem, 5vw, 5rem);
  align-items: start;
}

.fragments-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(280px, 0.78fr);
  gap: 4rem;
  align-items: start;
}

.about-copy {
  display: grid;
  gap: 1.55rem;
  padding-top: 0.2rem;
}

.about-copy h2 {
  max-width: none;
  white-space: nowrap;
}

.about-visual {
  display: flex;
  justify-content: flex-end;
  align-items: flex-end;
  padding: 0.65rem 0.35rem 1.15rem 0;
}

.about-portrait {
  display: block;
  width: min(100%, 27rem);
  height: auto;
  max-height: 38rem;
  object-fit: contain;
  filter: none;
  mix-blend-mode: normal;
  transform: translate(-0.9rem, 3.35rem);
}

.descriptor-line {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.descriptor-line span {
  position: relative;
  display: inline-flex;
  align-items: center;
  overflow: hidden;
  min-height: 2rem;
  padding: 0.3rem 0.72rem;
  border: 1px solid var(--hero-ball-border);
  border-radius: 0.22rem;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.22), rgba(255, 255, 255, 0.05)),
    var(--hero-ball-bg);
  color: var(--hero-ball-text);
  box-shadow:
    0 12px 24px var(--hero-ball-shadow),
    inset 0 1px 0 rgba(255, 255, 255, 0.24),
    inset 0 -1px 0 rgba(255, 255, 255, 0.04);
  backdrop-filter: blur(18px) saturate(150%);
  -webkit-backdrop-filter: blur(18px) saturate(150%);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.about-current {
  display: grid;
  gap: 0.8rem;
  max-width: 38rem;
  padding-top: 1.1rem;
  border-top: 1px solid var(--line);
}

.about-current-copy {
  display: block;
  max-width: 38rem;
  color: var(--muted);
  font-family: var(--hero-serif);
  font-size: clamp(1rem, 1.18vw, 1.1rem);
  font-weight: 400;
  letter-spacing: -0.01em;
  line-height: 1.72;
}

.about-current-copy .text-type__content {
  display: block;
}

.about-current-keyword {
  color: var(--accent-title);
  font-weight: 500;
}

.about-current-cursor {
  color: var(--accent-title);
}

.placeholder-media {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 0.8rem;
  overflow: hidden;
  padding: 1.15rem;
  border: 1px solid var(--line);
  background: var(--placeholder-bg);
  transition:
    transform var(--ease),
    border-color var(--ease),
    background var(--ease);
}

.placeholder-media::before {
  content: "";
  position: absolute;
  inset: 0.8rem;
  border: 1px dashed var(--placeholder-dash);
  pointer-events: none;
}

.placeholder-media span,
.placeholder-media small {
  position: relative;
  z-index: 1;
}

.placeholder-media span {
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: -0.02em;
}

.placeholder-media small {
  color: var(--muted);
  line-height: 1.6;
}

.placeholder-media:hover {
  transform: translateY(-4px);
  border-color: var(--placeholder-hover-border);
  background: var(--placeholder-bg-hover);
}

.portrait-large {
  min-height: 35rem;
  aspect-ratio: 4 / 5;
}

.timeline-section .section-heading h2,
.moments-intro .section-heading h2,
.fragments-copy .section-heading h2,
.skills-shell .section-heading h2 {
  max-width: 12ch;
}

.timeline-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.14fr) minmax(27rem, 0.86fr);
  gap: clamp(1rem, 2vw, 2rem);
  align-items: start;
}

.timeline-main {
  min-width: 0;
}

.timeline-heading-block {
  display: grid;
  gap: 0.95rem;
}

.timeline-heading-block .section-tag {
  margin: 0 0 1.25rem;
  color: var(--accent-tag);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.timeline-heading {
  max-width: none;
  margin: 0;
  color: var(--text);
  font-family: var(--display);
  font-size: clamp(2rem, 4.1vw, 4rem);
  font-weight: 600;
  letter-spacing: -0.038em;
  line-height: 0.92;
  white-space: nowrap;
}

.timeline-heading-block .section-tag + .timeline-heading {
  color: var(--text);
}

.timeline-list {
  display: grid;
  gap: 0;
  margin-top: 2.6rem;
}

.experience-row-shell {
  overflow: visible;
}

.experience-row {
  position: relative;
  padding: 0.18rem 0 0.44rem;
}

.experience-line {
  display: block;
  width: 100%;
  height: 2.15rem;
  overflow: visible;
}

.ripple-divider {
  position: relative;
  width: 100%;
  height: 2.15rem;
  overflow: visible;
}

.ripple-divider-line {
  display: block;
  width: 100%;
  height: 100%;
  overflow: visible;
}

.experience-line path,
.ripple-divider path {
  fill: none;
  stroke: var(--line-strong);
  stroke-width: 1.65;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 1;
  stroke-dashoffset: 1;
  transition: stroke 180ms ease;
}

.experience-row-shell.is-visible .experience-line path,
.ripple-divider.is-visible path {
  stroke-dashoffset: 0;
  transition:
    stroke-dashoffset var(--divider-draw-duration, 950ms)
      cubic-bezier(0.22, 1, 0.36, 1) var(--divider-draw-delay, 0ms),
    stroke 180ms ease;
}

.experience-row-copy {
  display: grid;
  grid-template-columns: 6.55rem 13.15rem minmax(19.4rem, 1fr);
  column-gap: 0.34rem;
  row-gap: 0;
  align-items: start;
  padding-top: 0.58rem;
}

.experience-date,
.experience-role,
.experience-place {
  display: block;
  font-family: var(--hero-serif);
  line-height: 1.45;
  white-space: nowrap;
}

.experience-date {
  color: var(--timeline-date);
  font-size: 0.82rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.experience-role {
  color: var(--text);
  font-size: 0.98rem;
  font-weight: 500;
  letter-spacing: -0.02em;
}

.experience-place {
  color: var(--muted);
  font-size: 0.94rem;
  letter-spacing: -0.015em;
  padding-left: 2.45rem;
}

.timeline-orbit-shell {
  position: sticky;
  top: 5.8rem;
  align-self: start;
  overflow: visible;
}

.timeline-orbit-card {
  position: relative;
  width: min(100%, 47.4rem);
  margin-left: auto;
  overflow: visible;
  transform: translate(3.05rem, 2.4rem);
}

.orbit-container {
  position: relative;
  width: 100%;
  overflow: visible;
  margin-left: auto;
  margin-right: auto;
}

.orbit-scaling-container {
  position: absolute;
  left: 50%;
  top: 50%;
  transform-origin: center center;
}

.orbit-rotation-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  transform: rotate(var(--orbit-base-rotation, 0deg));
}

.orbit-motion-layer {
  position: absolute;
  inset: 0;
}

.orbit-path-ghost {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0.94;
  pointer-events: none;
}

.orbit-item {
  position: absolute;
  left: 0;
  top: 0;
  will-change: transform;
  user-select: none;
  offset-distance: 0%;
  animation: orbit-travel linear infinite;
}

.orbit-frame {
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
  overflow: visible;
  border: 0;
  border-radius: 0;
  background: transparent;
}

.orbit-image {
  position: relative;
  z-index: 1;
  display: block;
  width: 100%;
  height: 100%;
  border-radius: 0;
  object-fit: cover;
  box-shadow: 0 10px 18px rgba(0, 0, 0, 0.14);
}

.orbit-center-content {
  position: absolute;
  inset: 0;
  z-index: 4;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}

@keyframes orbit-travel {
  from {
    offset-distance: 0%;
  }

  to {
    offset-distance: 100%;
  }
}

.skills-shell {
  display: grid;
  gap: 2rem;
}

.skills-heading-block {
  display: grid;
  gap: 0.95rem;
}

.skills-heading {
  max-width: 15ch;
  margin: 0;
  color: var(--text);
  font-family: var(--hero-serif);
  font-size: clamp(1.9rem, 3.2vw, 3rem);
  font-weight: 400;
  letter-spacing: -0.025em;
  line-height: 1;
}

.skills-marquee-stack {
  display: grid;
  gap: 1rem;
  margin-top: 0.3rem;
}

.skills-marquee {
  --skills-gap: 3.4rem;
  position: relative;
  overflow: hidden;
  width: min(100%, 58rem);
  margin: 0 auto;
  padding: 0.45rem 0;
  mask-image: linear-gradient(
    to right,
    transparent,
    black 7%,
    black 93%,
    transparent
  );
  -webkit-mask-image: linear-gradient(
    to right,
    transparent,
    black 7%,
    black 93%,
    transparent
  );
}

.skills-marquee-lane {
  display: flex;
  width: max-content;
  will-change: transform;
}

.skills-marquee-copy {
  display: flex;
  align-items: stretch;
  gap: var(--skills-gap);
  min-width: max-content;
  padding-right: var(--skills-gap);
}

.skills-marquee-left .skills-marquee-lane {
  animation: skills-marquee-left 34s linear infinite;
}

.skills-marquee-right .skills-marquee-lane {
  animation: skills-marquee-right 36s linear infinite;
}

.skill-glass-card {
  position: relative;
  display: grid;
  justify-items: center;
  gap: 0.62rem;
  width: 6.4rem;
  min-height: 6.85rem;
  padding: 0.05rem 0.08rem 0.35rem;
  background: transparent;
}

.skill-glass-stack {
  position: relative;
  width: 4.5rem;
  height: 4.5rem;
}

.skill-glass-front {
  position: relative;
  display: flex;
  width: 100%;
  height: 100%;
  border-radius: 1.2rem;
  background-color: hsla(0, 0%, 100%, 0.13);
  border: 1px solid var(--hero-ball-border);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.22), rgba(255, 255, 255, 0.05)),
    var(--hero-ball-bg);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.28),
    inset 0 -1px 0 rgba(255, 255, 255, 0.04);
  backdrop-filter: blur(28px) saturate(175%);
  -webkit-backdrop-filter: blur(28px) saturate(175%);
  overflow: hidden;
}

.skill-glass-front::before {
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: inherit;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0) 48%),
    radial-gradient(circle at 28% 20%, rgba(255, 255, 255, 0.18), transparent 34%);
  pointer-events: none;
}

.skill-glass-icon {
  position: relative;
  z-index: 1;
  margin: auto;
  width: 1.78rem;
  height: 1.78rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.skill-glyph {
  width: 100%;
  height: 100%;
  color: var(--hero-ball-text);
}

.skill-glass-label {
  display: block;
  margin-top: 0;
  color: var(--text);
  font-family: var(--hero-serif);
  font-size: 0.76rem;
  font-weight: 400;
  line-height: 1.24;
  letter-spacing: -0.015em;
  text-align: center;
}

.moments-intro {
  max-width: 46rem;
}

.moments-intro-dome {
  max-width: none;
  display: grid;
  gap: 0.55rem;
}

.moments-heading {
  margin: 0;
  color: var(--text);
  font-family: var(--display);
  font-size: clamp(0.7rem, 1.95vw, 2.05rem);
  font-weight: 600;
  letter-spacing: -0.038em;
  line-height: 0.94;
  white-space: nowrap;
}

.moments-dome-shell {
  position: relative;
  margin-top: 0.34rem;
  height: clamp(34rem, 61vw, 48rem);
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  overflow: hidden;
  isolation: isolate;
}

.sphere-root {
  position: relative;
  width: 100%;
  height: 100%;
  --radius: 520px;
  --viewer-pad: 72px;
  --circ: calc(var(--radius) * 3.14);
  --rot-y: calc((360deg / var(--segments-x)) / 2);
  --rot-x: calc((360deg / var(--segments-y)) / 2);
  --item-width: calc(var(--circ) / var(--segments-x));
  --item-height: calc(var(--circ) / var(--segments-y));
}

.sphere-root * {
  box-sizing: border-box;
}

.sphere,
.item,
.item__image {
  transform-style: preserve-3d;
}

main.sphere-main {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  overflow: hidden;
  touch-action: none;
  user-select: none;
  -webkit-user-select: none;
  background: transparent;
}

.stage {
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
  perspective: calc(var(--radius) * 2);
  perspective-origin: 50% 50%;
  contain: layout paint size;
}

.sphere {
  transform: translateZ(calc(var(--radius) * -1));
  will-change: transform;
}

.overlay,
.overlay--blur {
  position: absolute;
  inset: 0;
  margin: auto;
  z-index: 3;
  pointer-events: none;
}

.overlay {
  background-image: radial-gradient(
    rgba(235, 235, 235, 0) 65%,
    var(--overlay-blur-color, #120f17) 100%
  );
}

.overlay--blur {
  -webkit-mask-image: radial-gradient(
    rgba(235, 235, 235, 0) 70%,
    rgba(0, 0, 0, 1) 90%
  );
  mask-image: radial-gradient(
    rgba(235, 235, 235, 0) 70%,
    rgba(0, 0, 0, 1) 90%
  );
  backdrop-filter: blur(3px);
}

.item {
  width: calc(var(--item-width) * var(--item-size-x));
  height: calc(var(--item-height) * var(--item-size-y));
  position: absolute;
  top: -999px;
  bottom: -999px;
  left: -999px;
  right: -999px;
  margin: auto;
  transform-origin: 50% 50%;
  backface-visibility: hidden;
  transition: transform 300ms;
  transform: rotateY(
      calc(
        var(--rot-y) * (var(--offset-x) + ((var(--item-size-x) - 1) / 2)) +
          var(--rot-y-delta, 0deg)
      )
    )
    rotateX(
      calc(
        var(--rot-x) * (var(--offset-y) - ((var(--item-size-y) - 1) / 2)) +
          var(--rot-x-delta, 0deg)
      )
    )
    translateZ(var(--radius));
}

.item__image {
  position: absolute;
  display: block;
  inset: 10px;
  border-radius: var(--tile-radius, 12px);
  background: transparent;
  overflow: hidden;
  backface-visibility: hidden;
  transition: transform 300ms;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  pointer-events: auto;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
}

.item__image:focus {
  outline: none;
}

.item__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  pointer-events: none;
  backface-visibility: hidden;
  filter: var(--image-filter, none);
}

.viewer {
  position: absolute;
  inset: 0;
  z-index: 20;
  pointer-events: none;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--viewer-pad);
}

.viewer .frame {
  height: 100%;
  aspect-ratio: 1;
  border-radius: var(--enlarge-radius, 32px);
  display: flex;
}

@media (max-aspect-ratio: 1 / 1) {
  .viewer .frame {
    height: auto;
    width: 100%;
  }
}

.viewer .scrim {
  position: absolute;
  inset: 0;
  z-index: 10;
  background: rgba(0, 0, 0, 0.4);
  pointer-events: none;
  opacity: 0;
  transition: opacity 500ms ease;
  backdrop-filter: blur(3px);
}

.sphere-root[data-enlarging="true"] .viewer .scrim {
  opacity: 1;
  pointer-events: all;
}

.viewer .enlarge {
  position: absolute;
  z-index: 30;
  border-radius: var(--enlarge-radius, 32px);
  overflow: hidden;
  transition:
    transform 500ms ease,
    opacity 500ms ease;
  transform-origin: top left;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.35);
}

.viewer .enlarge img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  filter: var(--image-filter, none);
}

.sphere-root .enlarge-closing img {
  filter: var(--image-filter, none);
}

.edge-fade {
  position: absolute;
  left: 0;
  right: 0;
  height: 120px;
  z-index: 5;
  pointer-events: none;
  background: linear-gradient(
    to bottom,
    transparent,
    var(--overlay-blur-color, #120f17)
  );
}

.edge-fade--top {
  top: 0;
  transform: rotate(180deg);
}

.edge-fade--bottom {
  bottom: 0;
}

body.dg-scroll-lock {
  overflow: hidden;
}

.film-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.8rem;
  margin-top: 3rem;
  padding: 0.8rem;
  border: 1px solid var(--line-strong);
  background: var(--film-shell-bg);
}

.film-frame {
  display: grid;
  gap: 0.75rem;
  padding: 0.65rem;
  border: 1px solid var(--line);
  background: var(--film-frame-bg);
  transition:
    transform var(--ease),
    border-color var(--ease),
    background var(--ease);
}

.film-frame:hover {
  transform: translateY(-4px);
  border-color: var(--film-frame-border-hover);
  background: var(--film-frame-bg-hover);
}

.moment-placeholder {
  min-height: 18rem;
  padding: 0.95rem;
}

.moment-placeholder::before {
  inset: 0.7rem;
}

.film-frame.landscape .moment-placeholder {
  min-height: 13.2rem;
}

.film-frame.square .moment-placeholder {
  min-height: 14.8rem;
}

.film-meta {
  display: grid;
  gap: 0.2rem;
  padding: 0 0.1rem;
}

.film-meta p {
  margin: 0;
  font-size: 0.98rem;
  font-weight: 600;
  letter-spacing: -0.02em;
}

.fragments-shell {
  display: grid;
  grid-template-columns: minmax(24rem, 0.86fr) minmax(46rem, 1.9fr);
  gap: clamp(2.8rem, 5vw, 5.6rem);
  align-items: start;
}

.fragments-tagline {
  display: grid;
  gap: 1.25rem;
  align-content: start;
  padding-top: 0;
  margin-top: -5.4rem;
}

.fragments-heading {
  margin: 0;
  color: var(--text);
  font-family: var(--display);
  font-size: clamp(0.68rem, 1.82vw, 1.84rem);
  font-weight: 600;
  letter-spacing: -0.038em;
  line-height: 0.98;
}

.fragments-heading span {
  display: block;
  white-space: nowrap;
}

.fragments-heading em {
  color: var(--accent-title);
  font-style: normal;
}

.fragments-swap-stage {
  position: relative;
  min-height: 42rem;
  margin-top: -1.85rem;
  overflow: visible;
}

.card-swap-container {
  position: absolute;
  right: 0;
  bottom: 0;
  transform: translate(0%, 1%);
  transform-origin: bottom right;
  perspective: 900px;
  overflow: visible;
}

.card-swap-card {
  position: absolute;
  top: 50%;
  left: 50%;
  display: grid;
  align-content: start;
  gap: 1rem;
  padding: 1.8rem 1.9rem 1.95rem;
  border-radius: 1.28rem;
  border: 1px solid var(--card-swap-card-border);
  background: var(--card-swap-card-bg);
  box-shadow: 0 18px 34px var(--card-swap-card-shadow);
  overflow: hidden;
  transform-style: preserve-3d;
  will-change: transform;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

:root[data-theme="light"] .card-swap-card {
  background: rgba(255, 255, 255, 0.86);
  backdrop-filter: blur(10px) saturate(120%);
  -webkit-backdrop-filter: blur(10px) saturate(120%);
  border-color: rgba(0, 0, 0, 0.08);
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.1);
}

.city-notes-section {
  padding-top: 3rem;
  padding-bottom: 2.4rem;
}

.city-notes-shell {
  display: grid;
  justify-items: start;
  gap: 1.8rem;
}

.city-notes-copy {
  margin: 0.9rem 0 0;
  color: var(--text);
  font-family: var(--display);
  font-size: clamp(0.68rem, 1.82vw, 1.84rem);
  font-weight: 600;
  letter-spacing: -0.038em;
  line-height: 0.98;
  max-width: 38ch;
}

.city-notes-copy span {
  display: block;
  white-space: nowrap;
}

.city-notes-gallery {
  position: relative;
  width: 100%;
  height: clamp(26rem, 42vw, 34rem);
  margin-top: 0.4rem;
}

.circular-gallery {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  touch-action: none;
  user-select: none;
  cursor: grab;
}

.circular-gallery:active {
  cursor: grabbing;
}

.circular-gallery canvas {
  display: block;
  width: 100%;
  height: 100%;
}

.circular-gallery-item {
  position: absolute;
  top: 50%;
  left: 50%;
  transform-origin: center center;
  will-change: transform, opacity;
}

.xhs-poster {
  width: 100%;
  height: 100%;
  display: grid;
  grid-template-rows: minmax(0, 1fr) auto;
  gap: 0.88rem;
  padding: 0.95rem;
  border-radius: 1.45rem;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background:
    linear-gradient(180deg, rgba(14, 17, 25, 0.96), rgba(8, 10, 16, 0.98)),
    radial-gradient(circle at top, rgba(159, 181, 255, 0.06), transparent 45%);
  box-shadow: 0 20px 40px rgba(3, 5, 10, 0.2);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

:root[data-theme="light"] .xhs-poster {
  border-color: rgba(117, 136, 211, 0.16);
  background:
    linear-gradient(180deg, rgba(244, 246, 252, 0.96), rgba(236, 239, 246, 0.98)),
    radial-gradient(circle at top, rgba(117, 136, 211, 0.08), transparent 45%);
  box-shadow: 0 18px 32px rgba(117, 136, 211, 0.08);
}

.xhs-poster-media {
  display: grid;
  gap: 0.62rem;
  min-height: 0;
  align-content: stretch;
  grid-template-rows: repeat(var(--shot-count), minmax(0, 1fr));
}

.xhs-shot {
  margin: 0;
  min-height: 0;
  padding: 0.38rem;
  border-radius: 1rem;
  background:
    linear-gradient(180deg, rgba(7, 9, 15, 0.96), rgba(18, 21, 29, 0.92)),
    radial-gradient(circle at top, rgba(255, 255, 255, 0.08), transparent 42%);
  overflow: hidden;
}

:root[data-theme="light"] .xhs-shot {
  background:
    linear-gradient(180deg, rgba(222, 228, 241, 0.92), rgba(246, 248, 252, 0.98)),
    radial-gradient(circle at top, rgba(255, 255, 255, 0.65), transparent 46%);
}

.xhs-shot img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  border-radius: 0.72rem;
}

.xhs-poster-label {
  margin: 0;
  color: var(--text);
  font-family: var(--display);
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.1;
}

.fragment-card-kicker {
  margin: 0;
  color: var(--card-swap-kicker);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.card-swap-card h3 {
  margin: 0;
  color: var(--text);
  font-family: var(--display);
  font-size: 2rem;
  font-weight: 600;
  letter-spacing: -0.04em;
  line-height: 0.98;
}

.card-swap-card p {
  margin: 0;
  color: var(--muted);
  font-size: 0.98rem;
  line-height: 1.7;
}

.fragment-card-panel {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: grid;
  padding: 1.4rem 1.45rem 1.45rem;
  overflow: hidden;
  border-radius: inherit;
  isolation: isolate;
}

.fragment-card-panel--split {
  grid-template-rows: minmax(0, 1fr) auto minmax(0, 1fr);
  gap: 0.92rem;
  align-content: stretch;
}

.fragment-card-panel--part-time {
  grid-template-rows: auto auto;
  gap: 1rem;
  align-content: center;
}

.fragment-card-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    radial-gradient(circle at center, rgba(6, 8, 14, 0.02) 0%, rgba(6, 8, 14, 0.22) 100%),
    linear-gradient(180deg, rgba(6, 8, 14, 0.3) 0%, rgba(6, 8, 14, 0.18) 100%);
}

.fragment-card-row {
  position: relative;
  z-index: 0;
  display: grid;
  min-width: 0;
  align-items: center;
  justify-items: stretch;
  transform: none;
}

.fragment-card-row--3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.02rem;
}

.fragment-card-row--4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.78rem;
}

.fragment-card-row--top {
  align-self: stretch;
}

.fragment-card-row--bottom {
  align-self: stretch;
}

.fragment-card-panel--split .fragment-card-row {
  width: calc(100% - 2.35rem);
  margin-left: -1.45rem;
  margin-right: 0;
}

.fragment-card-panel--split .fragment-card-row--4 {
  width: calc(100% - 2.65rem);
  margin-left: -1.6rem;
}

.fragment-card-panel--split .fragment-shot {
  aspect-ratio: 5 / 4;
}

.fragment-shot {
  position: relative;
  left: auto;
  right: auto;
  top: auto;
  bottom: auto;
  width: 100%;
  height: auto;
  min-width: 0;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.06);
  box-shadow: 0 10px 24px rgba(7, 10, 18, 0.14);
  transform: none;
}

.fragment-shot img,
.fragment-shot-image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.fragment-shot-image--lifted {
  object-position: center 34%;
}

.fragment-card-copy {
  position: relative;
  z-index: 2;
  display: grid;
  gap: 0.5rem;
  padding: 0;
  border: 0;
  background: transparent;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.fragment-card-copy--middle {
  align-self: center;
  margin: 0 0.12rem;
}

.fragment-card-copy--bottom {
  align-self: end;
}

.fragment-card-panel--part-time .fragment-shot {
  aspect-ratio: 3 / 4;
}

.fragment-card-panel--part-time .fragment-card-row {
  width: calc(100% - 2.5rem);
  margin-left: -1.55rem;
  margin-right: 0;
}

.fragment-card-panel--part-time .fragment-card-row--4 {
  gap: 0.62rem;
}

.fragment-card-title,
.fragment-card-detail,
.fragment-card-description {
  margin: 0;
  font-family: var(--hero-serif);
  letter-spacing: -0.012em;
}

.fragment-card-title {
  color: var(--text);
  font-size: 1.46rem;
  line-height: 1.02;
}

.fragment-card-detail {
  color: rgba(243, 241, 237, 0.92);
  font-size: 0.95rem;
  line-height: 1.56;
}

.fragment-card-description {
  color: rgba(243, 241, 237, 0.74);
  font-size: 0.9rem;
  line-height: 1.52;
}

:root[data-theme="light"] .fragment-card-panel::before {
  background: none;
}

:root[data-theme="light"] .fragment-shot {
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 8px 20px rgba(20, 24, 34, 0.04);
  border: 1px solid rgba(0, 0, 0, 0.08);
}

:root[data-theme="light"] .fragment-shot img {
  opacity: 1;
  filter: none;
}

:root[data-theme="light"] .fragment-card-title {
  color: #171715;
}

:root[data-theme="light"] .fragment-card-detail {
  color: #2a2925;
}

:root[data-theme="light"] .fragment-card-description {
  color: #4c4942;
}

.corners-shell {
  display: grid;
  gap: 0.85rem;
  max-width: 38rem;
}

.corners-shell h2 {
  margin: 0;
  color: var(--text);
  font-family: var(--display);
  font-size: clamp(2.1rem, 4.7vw, 4.3rem);
  font-weight: 600;
  letter-spacing: -0.048em;
  line-height: 0.94;
}

.contact-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(19rem, 24rem);
  gap: clamp(2.6rem, 4vw, 4.1rem);
  row-gap: 0.7rem;
  align-items: center;
  padding-bottom: 0;
}

.contact-divider {
  grid-column: 1 / -1;
  margin-top: 0.22rem;
}

.contact-copy {
  max-width: 36rem;
  display: grid;
  gap: 1.45rem;
}

.contact-copy .section-tag {
  margin: 0;
  color: var(--accent-tag);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.contact-copy h2 {
  color: var(--text);
  font-size: clamp(1.95rem, 3.15vw, 2.75rem);
  line-height: 0.96;
  letter-spacing: -0.045em;
}

.contact-copy h2 span {
  color: var(--accent-title);
}

.contact-connect-shiny {
  margin-left: 0.32em;
}

.contact-copy p {
  max-width: 29rem;
}

.contact-links {
  width: auto;
  display: flex;
  flex-wrap: nowrap;
  gap: 1.4rem;
  justify-self: end;
  align-self: center;
  align-items: center;
  margin-top: 4.35rem;
  transform: translateX(-0.65rem);
}

.contact-email-wrap {
  position: relative;
  display: flex;
  align-items: center;
}

.contact-text-link {
  color: var(--text);
  font-family: var(--hero-serif);
  font-size: clamp(0.95rem, 1vw, 1rem);
  font-weight: 400;
  letter-spacing: -0.02em;
  line-height: 1.1;
  text-decoration: none;
  white-space: nowrap;
  transition:
    color var(--ease),
    transform var(--ease);
}

.contact-text-trigger {
  appearance: none;
  background: transparent;
  border: 0;
  cursor: pointer;
  padding: 0;
}

.contact-text-link:hover,
.contact-text-link:focus-visible {
  color: var(--accent-title);
  transform: translateX(0.16rem);
}

.contact-email-card {
  position: absolute;
  left: -0.3rem;
  bottom: calc(100% + 1.05rem);
  min-width: max-content;
  padding: 0.88rem 1.08rem 0.92rem;
  border-radius: 1rem;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(9, 11, 18, 0.74);
  color: var(--text);
  font-family: var(--hero-serif);
  font-size: 0.98rem;
  font-weight: 400;
  letter-spacing: -0.018em;
  line-height: 1;
  white-space: nowrap;
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  box-shadow: 0 20px 50px rgba(5, 9, 20, 0.2);
  opacity: 0;
  pointer-events: none;
  transform: translateY(0.22rem) scale(0.92);
  transform-origin: bottom left;
  transition:
    opacity 280ms var(--ease),
    transform 340ms cubic-bezier(0.22, 1, 0.36, 1);
}

.contact-email-wrap.is-open .contact-email-card {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0) scale(1);
}

:root[data-theme="light"] .contact-email-card {
  border-color: rgba(22, 25, 38, 0.08);
  background: rgba(255, 255, 255, 0.84);
  box-shadow: 0 22px 55px rgba(91, 103, 149, 0.12);
}

.shiny-text {
  display: inline-block;
}

@keyframes skills-marquee-left {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(-50%);
  }
}

@keyframes skills-marquee-right {
  from {
    transform: translateX(-50%);
  }

  to {
    transform: translateX(0);
  }
}

.reveal {
  opacity: 0;
  transform: translateY(18px);
  transition:
    opacity 700ms ease,
    transform 700ms ease;
}

.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

@media (max-width: 960px) {
  .site-header,
  main {
    width: min(calc(100% - 2rem), var(--max-width));
  }

  .site-header {
    grid-template-columns: minmax(0, 1fr) auto;
  }

  .hero,
  .about-grid,
  .timeline-layout,
  .fragments-grid,
  .contact-shell {
    grid-template-columns: 1fr;
  }

  .hero {
    min-height: auto;
    gap: 3rem;
    padding-top: 4.2rem;
  }

  .hero-side-nav {
    width: min(30rem, 100%);
    height: 33rem;
    margin-left: 0;
  }

  .hero-liquid-field {
    inset: -2rem -2.6rem -2.1rem -1.5rem;
  }

  .hero-metaballs {
    opacity: 0.9;
  }

  .about-visual {
    justify-content: flex-start;
  }

  .about-portrait {
    width: min(100%, 22.5rem);
    transform: translate(-0.45rem, 2.15rem);
  }

  .hero-ball-link span {
    font-size: 0.82rem;
  }

  .timeline-entry {
    grid-template-columns: 1fr;
    gap: 0.5rem;
  }

  .experience-row-copy {
    grid-template-columns: 1fr;
    gap: 0.28rem;
    padding-top: 0.42rem;
  }

  .experience-date,
  .experience-role,
  .experience-place {
    white-space: normal;
  }

  .experience-place {
    padding-left: 0;
  }

  .timeline-orbit-shell {
    position: static;
    top: auto;
    padding-top: 0.65rem;
  }

  .timeline-orbit-card {
    width: min(100%, 32.4rem);
    margin-left: 0;
    transform: none;
  }

  .fragments-shell {
    grid-template-columns: 1fr;
    gap: 1.4rem;
  }

  .fragments-tagline {
    margin-top: -2rem;
  }

  .fragments-heading {
    font-size: clamp(0.72rem, 2.2vw, 1.28rem);
  }

  .fragments-heading span {
    white-space: normal;
  }

  .fragments-swap-stage {
    min-height: 35rem;
    margin-top: -0.85rem;
  }

  .city-notes-section {
    padding-top: 1.8rem;
    padding-bottom: 1.8rem;
  }

  .city-notes-copy {
    max-width: 24ch;
  }

  .city-notes-gallery {
    height: clamp(22rem, 52vw, 28rem);
  }

  .skill-glass-card {
    width: 6rem;
    min-height: 6.55rem;
  }

  .moments-dome-shell {
    height: clamp(30rem, 88vw, 44rem);
  }

  .fragment-card-copy {
    right: 1.2rem;
    left: 1.2rem;
    bottom: 1.2rem;
  }

  .film-strip {
    grid-template-columns: 1fr 1fr;
  }

  .contact-links {
    width: auto;
    justify-self: start;
  }
}

@media (max-width: 680px) {
  .site-header {
    padding-top: 1.05rem;
  }

  .section {
    padding: 4.6rem 0;
  }

  .hero {
    gap: 2.35rem;
    padding-top: 3.6rem;
  }

  .fragments-tagline {
    margin-top: 0;
  }

  .fragments-swap-stage {
    margin-top: -0.55rem;
  }

  .city-notes-section {
    padding-top: 1.2rem;
    padding-bottom: 1.4rem;
  }

  .city-notes-copy {
    max-width: none;
  }

  .city-notes-copy span {
    white-space: normal;
  }

  .city-notes-shell {
    gap: 1.25rem;
  }

  .city-notes-gallery {
    height: 20rem;
  }

  .xhs-poster {
    padding: 0.8rem;
    border-radius: 1.1rem;
  }

  .xhs-poster-media {
    gap: 0.5rem;
  }

  .xhs-shot {
    padding: 0.28rem;
    border-radius: 0.8rem;
  }

  .hero-title {
    font-size: clamp(2.35rem, 10.5vw, 3.2rem);
    white-space: normal;
  }

  .hero-subtitle {
    font-size: 0.96rem;
    line-height: 1.55;
  }

  .hero-side-nav {
    height: 27rem;
  }

  .hero-liquid-field {
    inset: -1rem -1.4rem -1.2rem -0.75rem;
  }

  .hero-metaballs {
    opacity: 0.82;
  }

  .about-copy h2 {
    white-space: normal;
  }

  .about-visual {
    padding-bottom: 0.65rem;
  }

  .about-portrait {
    transform: translate(-0.2rem, 1.4rem);
  }

  .timeline-list {
    margin-top: 2.4rem;
  }

  .timeline-orbit-card {
    width: min(100%, 25.6rem);
  }

  .skills-heading {
    max-width: 11ch;
  }

  .skills-marquee-stack {
    gap: 0.75rem;
  }

  .skills-marquee {
    --skills-gap: 2.15rem;
    width: 100%;
  }

  .skill-glass-card {
    width: 5.35rem;
    min-height: 5.95rem;
    gap: 0.64rem;
    padding: 0.08rem 0.05rem 0.28rem;
  }

  .skill-glass-stack {
    width: 3.85rem;
    height: 3.85rem;
  }

  .skill-glass-front {
    border-radius: 1rem;
  }

  .skill-glass-icon {
    width: 1.56rem;
    height: 1.56rem;
  }

  .skill-glass-label {
    font-size: 0.76rem;
  }

  .card-swap-container {
    transform: scale(0.64) translate(18%, 18%);
  }

  .card-swap-card {
    padding: 1.2rem 1.2rem 1.35rem;
  }

  .fragment-card-panel {
    display: grid;
    position: absolute;
    inset: 0;
    padding: 1rem;
    gap: 0.72rem;
    overflow: hidden;
  }

  .fragment-card-panel--split {
    grid-template-rows: auto auto auto;
  }

  .fragment-card-panel--part-time {
    grid-template-rows: auto auto;
  }

  .fragment-card-copy {
    position: relative;
    inset: auto;
  }

  .fragment-card-row {
    position: relative;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.6rem;
  }

  .fragment-shot {
    position: relative;
    inset: unset;
    width: 100%;
    height: auto;
    min-height: 0;
    aspect-ratio: 4 / 3;
    transform: none;
    border-radius: 0.9rem;
  }

  .fragment-card-title {
    font-size: 1.3rem;
  }

  .fragment-card-detail,
  .fragment-card-description {
    font-size: 0.88rem;
    line-height: 1.48;
  }

  .moments-heading {
    font-size: clamp(0.56rem, 2.35vw, 0.72rem);
    letter-spacing: -0.018em;
    line-height: 1.05;
  }

  .moments-dome-shell {
    height: clamp(26rem, 96vw, 35rem);
    margin-top: 0.28rem;
    padding: 0;
    border-radius: 0;
  }

  .item__image {
    inset: 6px;
    border-radius: 1rem;
  }

  .hero-ball-link {
    padding: 0.42rem;
  }

  .hero-ball-link span {
    max-width: 84%;
    font-size: 0.74rem;
    line-height: 1.02;
  }

  .section-heading h2,
  .about-copy h2,
  .contact-copy h2 {
    font-size: clamp(2.15rem, 10vw, 3.45rem);
  }

  .portrait-large,
  .fragments-visual .placeholder-media {
    min-height: 24rem;
  }

  .film-strip {
    grid-template-columns: 1fr;
  }

  .contact-links {
    width: auto;
  }

  .corners-shell h2 {
    font-size: clamp(1.7rem, 9.5vw, 2.7rem);
  }
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  .reveal,
  .placeholder-media,
  .film-frame,
  .contact-links a,
  .theme-toggle,
  .theme-toggle-shell,
  .theme-toggle-thumb,
  .theme-toggle-glyph,
  .hero-ball-link,
  .timeline-entry::after,
  .fragment-link::after {
    transition: none;
  }

  .skills-marquee-lane {
    animation: none;
  }

}
