:root {
  --site-max: 82rem;
  --content-max: 46rem;
  --font-sans: "Hoefler Text", "Iowan Old Style", "Palatino Linotype", "Book Antiqua", Garamond, "Times New Roman", serif;
  --color-bg: #f4eee6;
  --color-bg-deep: #e5d8cb;
  --color-surface: rgba(255, 255, 255, 0.52);
  --color-panel: rgba(247, 240, 233, 0.82);
  --color-panel-strong: #f7f0e7;
  --color-text: #231a1f;
  --color-muted: #6d5d61;
  --color-line: rgba(35, 26, 31, 0.08);
  --color-frame-line: rgba(35, 26, 31, 0.11);
  --color-frame-line-strong: rgba(35, 26, 31, 0.22);
  --color-header: rgba(245, 238, 232, 0.84);
  --color-hero-shadow: rgba(9, 10, 16, 0.58);
  --color-accent: #7b2d3a;
  --color-accent-soft: rgba(123, 45, 58, 0.12);
  --resume-paper: #f6efe7;
  --resume-paper-strong: #fcf9f4;
  --resume-ink: #20171d;
  --resume-ink-soft: #5d4f52;
  --resume-line: rgba(35, 26, 31, 0.12);
  --resume-shadow: 0 38px 104px rgba(24, 17, 20, 0.16);
  --shadow-soft: 0 36px 90px rgba(27, 20, 24, 0.1);
  --shadow-panel: 0 22px 48px rgba(27, 20, 24, 0.1);
  --shadow-deep: 0 44px 120px rgba(16, 12, 18, 0.22);
  --radius-sm: 0.16rem;
  --radius-md: 0.24rem;
  --radius-lg: 0.36rem;
  --space-2xs: 0.4rem;
  --space-xs: 0.75rem;
  --space-sm: 1rem;
  --space-md: 1.5rem;
  --space-lg: 2.5rem;
  --space-xl: 4rem;
  --space-2xl: clamp(4rem, 7vw, 7rem);
  --transition: 220ms cubic-bezier(0.22, 1, 0.36, 1);
}

html {
  scroll-behavior: smooth;
  color-scheme: light;
}

html[data-theme="dark"] {
  color-scheme: dark;
  --color-bg: #0f1828;
  --color-bg-deep: #172438;
  --color-surface: rgba(255, 255, 255, 0.05);
  --color-panel: rgba(16, 25, 40, 0.78);
  --color-panel-strong: #152134;
  --color-text: #f3ece2;
  --color-muted: #c4b7b6;
  --color-line: rgba(124, 139, 164, 0.18);
  --color-frame-line: rgba(112, 126, 149, 0.28);
  --color-frame-line-strong: rgba(159, 171, 191, 0.38);
  --color-header: rgba(11, 17, 29, 0.78);
  --color-hero-shadow: rgba(4, 7, 14, 0.78);
  --color-accent: #b35b6e;
  --color-accent-soft: rgba(179, 91, 110, 0.18);
  --resume-paper: #f0e5d7;
  --resume-paper-strong: #f8f2ea;
  --resume-ink: #130f14;
  --resume-ink-soft: #564a4c;
  --resume-line: rgba(35, 26, 31, 0.16);
  --resume-shadow: 0 42px 120px rgba(3, 5, 11, 0.52);
  --shadow-soft: 0 38px 110px rgba(3, 5, 11, 0.4);
  --shadow-panel: 0 24px 60px rgba(3, 5, 11, 0.32);
  --shadow-deep: 0 56px 160px rgba(2, 4, 9, 0.56);
}

html[data-theme="dark"] .home-hero__frame {
  border: 0;
  background: transparent;
}

body.accent-forest {
  --color-accent: #345544;
  --color-accent-soft: rgba(52, 85, 68, 0.1);
}

body.accent-plum {
  --color-accent: #5d4464;
  --color-accent-soft: rgba(93, 68, 100, 0.1);
}

body.accent-bronze {
  --color-accent: #7b5b43;
  --color-accent-soft: rgba(123, 91, 67, 0.1);
}

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

body {
  margin: 0;
  min-width: 20rem;
  min-height: 100vh;
  position: relative;
  isolation: isolate;
  font-family: var(--font-sans);
  color: var(--color-text);
  background:
    radial-gradient(circle at top left, rgba(255, 255, 255, 0.78), transparent 28%),
    radial-gradient(circle at 82% 18%, rgba(123, 45, 58, 0.1), transparent 26%),
    linear-gradient(180deg, #fbf6ef 0%, var(--color-bg) 38%, var(--color-bg-deep) 100%);
  line-height: 1.6;
  text-rendering: optimizeLegibility;
}

html[data-theme="dark"] body {
  background:
    radial-gradient(circle at top left, rgba(255, 255, 255, 0.04), transparent 24%),
    radial-gradient(circle at 82% 16%, rgba(179, 91, 110, 0.16), transparent 30%),
    linear-gradient(180deg, #0b1220 0%, var(--color-bg) 34%, var(--color-bg-deep) 100%);
}

body::before,
body::after {
  content: "";
  position: fixed;
  inset: auto;
  pointer-events: none;
  z-index: -1;
}

body::before {
  top: -12rem;
  right: -10rem;
  width: 34rem;
  height: 34rem;
  border-radius: 999px;
  background: radial-gradient(circle, var(--color-accent-soft) 0%, rgba(255, 255, 255, 0) 70%);
}

body::after {
  bottom: -18rem;
  left: -12rem;
  width: 38rem;
  height: 38rem;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(53, 40, 30, 0.06) 0%, rgba(255, 255, 255, 0) 72%);
}

html[data-theme="dark"] body::after {
  background: radial-gradient(circle, rgba(255, 255, 255, 0.03) 0%, rgba(255, 255, 255, 0) 72%);
}

img,
svg,
video {
  display: block;
  max-width: 100%;
}

iframe {
  width: 100%;
  border: 0;
}

a {
  color: inherit;
  text-decoration: none;
  transition: color var(--transition), opacity var(--transition), border-color var(--transition);
}

a:hover {
  color: var(--color-accent);
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 3px;
}

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

.skip-link {
  position: absolute;
  top: -4rem;
  left: 1rem;
  z-index: 999;
  padding: 0.7rem 1rem;
  border-radius: var(--radius-sm);
  background: var(--color-text);
  color: #fff;
}

.skip-link:focus {
  top: 1rem;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  padding-inline: 0;
  border-bottom: 1px solid var(--color-line);
  background: rgba(247, 242, 235, 0.76);
  backdrop-filter: blur(18px);
}

.site-header__inner,
.site-footer__inner,
.content-section,
.home-hero {
  width: min(calc(100% - 2rem), var(--site-max));
  margin: 0 auto;
}

.site-header__inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 1.1rem;
  padding: 1rem 0;
}

.site-header__brand {
  display: flex;
  align-items: center;
}

.site-title-text {
  font-size: clamp(1.34rem, 2.25vw, 1.82rem);
  font-weight: 600;
  letter-spacing: 0.03em;
  white-space: nowrap;
  color: var(--color-text);
}

.site-nav {
  justify-self: end;
}

.site-title-subtle {
  display: none;
}

.site-nav__list {
  display: flex;
  flex-wrap: wrap;
  gap: 1.25rem;
  align-items: center;
  justify-content: flex-end;
  margin: 0;
  padding: 0;
  list-style: none;
}

.site-nav__list a {
  position: relative;
  color: var(--color-text);
  font-size: 0.82rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  opacity: 0.78;
}

.site-nav__list a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -0.25rem;
  width: 100%;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--transition);
}

.site-nav__list a:hover::after,
.site-nav__list a:focus-visible::after {
  transform: scaleX(1);
}

.site-nav__list a:hover,
.site-nav__list a:focus-visible,
.site-nav__list .current-menu-item > a,
.site-nav__list .current-menu-ancestor > a {
  opacity: 1;
}

.menu-toggle {
  display: none;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  background: transparent;
  padding: 0.55rem 0.2rem 0.55rem 0.85rem;
  color: var(--color-text);
}

.site-header__actions {
  display: inline-flex;
  align-items: center;
  justify-self: end;
}

.theme-toggle {
  --theme-toggle-index: 1;
  position: relative;
  isolation: isolate;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: center;
  min-width: 7.7rem;
  padding: 0.18rem;
  border: 1px solid var(--color-line);
  border-radius: var(--radius-sm);
  background: linear-gradient(180deg, var(--color-panel-strong), var(--color-panel));
  box-shadow: var(--shadow-panel);
  transition: border-color var(--transition), transform var(--transition), background var(--transition), box-shadow var(--transition);
}

.theme-toggle::before {
  content: "";
  position: absolute;
  inset: 0.18rem auto 0.18rem 0.18rem;
  width: calc((100% - 0.36rem) / 3);
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.56);
  box-shadow: 0 10px 20px rgba(18, 16, 14, 0.08);
  transform: translateX(calc(var(--theme-toggle-index) * 100%));
  transition: transform 320ms cubic-bezier(0.22, 1, 0.36, 1), background var(--transition), box-shadow var(--transition);
  z-index: 0;
}

html[data-theme="dark"] .theme-toggle::before {
  background: rgba(255, 255, 255, 0.08);
  box-shadow: 0 14px 24px rgba(0, 0, 0, 0.3);
}

.theme-toggle:hover,
.theme-toggle:focus-within,
.menu-toggle:hover,
.menu-toggle:focus-visible {
  transform: translateY(-1px);
  border-color: var(--color-frame-line-strong);
  box-shadow: var(--shadow-soft);
}

.theme-toggle__option {
  position: relative;
  z-index: 1;
  display: inline-grid;
  place-items: center;
  width: 2.35rem;
  height: 2.15rem;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--color-muted);
  cursor: pointer;
  transition: color var(--transition), transform var(--transition), opacity var(--transition);
}

.theme-toggle__option:hover,
.theme-toggle__option:focus-visible {
  color: var(--color-text);
  transform: translateY(-1px);
}

.theme-toggle__option[data-active="true"] {
  color: var(--color-text);
}

.theme-toggle__icon {
  width: 1rem;
  height: 1rem;
  stroke: currentColor;
  fill: none;
}

.theme-toggle--footer {
  min-width: 6.6rem;
  padding: 0.12rem;
  border-color: var(--color-line);
  background: transparent;
  box-shadow: none;
  opacity: 0.78;
}

.theme-toggle--footer::before {
  inset: 0.12rem auto 0.12rem 0.12rem;
  width: calc((100% - 0.24rem) / 3);
  background: rgba(255, 255, 255, 0.64);
  box-shadow: 0 8px 18px rgba(18, 16, 14, 0.05);
}

.theme-toggle--footer .theme-toggle__option {
  width: 2rem;
  height: 1.85rem;
}

.theme-toggle--footer .theme-toggle__icon {
  width: 0.92rem;
  height: 0.92rem;
}

.theme-toggle--footer:hover,
.theme-toggle--footer:focus-within {
  opacity: 1;
}

html[data-theme="dark"] .theme-toggle--footer {
  border-color: rgba(232, 226, 219, 0.12);
  background: rgba(255, 255, 255, 0.01);
}

html[data-theme="dark"] .theme-toggle--footer::before {
  background: rgba(255, 255, 255, 0.05);
  box-shadow: none;
}

.site-main {
  padding: clamp(1.4rem, 3vw, 2.75rem) 0 5rem;
}

.home-page {
  display: grid;
  gap: clamp(1.35rem, 3vw, 3rem);
}

.home-hero--full {
  width: min(calc(100% - 1rem), 104rem);
  padding-top: clamp(0.35rem, 1.5vw, 1rem);
}

.home-hero__frame,
.feature-media__embed,
.editorial-layout__figure,
.portfolio-card__media,
.gallery-card__media,
.resume-gallery__item {
  overflow: hidden;
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.55);
  box-shadow: var(--shadow-soft);
}

.home-hero__frame {
  position: relative;
  aspect-ratio: 16 / 8.6;
  min-height: clamp(30rem, 74vh, 54rem);
  border: 1px solid var(--color-frame-line);
  border-radius: calc(var(--radius-lg) + 0.08rem);
  box-shadow: var(--shadow-deep);
}

.home-hero__frame::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(8, 9, 14, 0.03) 0%, rgba(8, 9, 14, 0.2) 36%, rgba(8, 9, 14, 0.48) 70%, var(--color-hero-shadow) 100%),
    linear-gradient(104deg, rgba(6, 8, 14, 0.54) 0%, rgba(6, 8, 14, 0.22) 36%, rgba(6, 8, 14, 0) 68%);
  z-index: 1;
}

.home-hero__slides {
  position: absolute;
  inset: 0;
}

.home-hero__slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 900ms ease;
}

.home-hero__slide.is-active {
  opacity: 1;
}

.home-hero__controls {
  position: absolute;
  right: clamp(1rem, 3vw, 2rem);
  bottom: clamp(1rem, 3vw, 2rem);
  z-index: 3;
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
}

.home-hero__control,
.home-hero__dot {
  border: 1px solid rgba(255, 255, 255, 0.18);
  background: rgba(10, 13, 20, 0.4);
  color: rgba(250, 246, 239, 0.92);
  cursor: pointer;
  transition: transform var(--transition), border-color var(--transition), background var(--transition), opacity var(--transition);
}

.home-hero__control {
  display: inline-grid;
  place-items: center;
  width: 3rem;
  height: 3rem;
  border-radius: 999px;
  backdrop-filter: blur(12px);
}

.home-hero__control > span[aria-hidden="true"] {
  display: block;
  font-size: 1.06rem;
  line-height: 1;
  transform: translateY(0.18rem);
}

.home-hero__dot {
  width: 0.8rem;
  height: 0.8rem;
  padding: 0;
  border-radius: 999px;
  opacity: 0.5;
}

.home-hero__pagination {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
}

.home-hero__control:hover,
.home-hero__control:focus-visible,
.home-hero__dot:hover,
.home-hero__dot:focus-visible,
.home-hero__dot.is-active {
  transform: translateY(-1px);
  border-color: rgba(255, 255, 255, 0.4);
  background: rgba(10, 13, 20, 0.6);
  opacity: 1;
}

.home-hero__production,
.portfolio-card__media img,
.gallery-card__media img,
.resume-gallery__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: relative;
  z-index: 0;
}

.home-hero__overlay {
  position: absolute;
  left: clamp(1.5rem, 5vw, 4.2rem);
  right: clamp(1.5rem, 7vw, 7rem);
  bottom: clamp(1.5rem, 6vw, 4.5rem);
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
  gap: 0.85rem 1.35rem;
  max-width: none;
}

.section-label {
  margin: 0;
  color: var(--color-accent);
  font-size: 0.73rem;
  font-weight: 650;
  letter-spacing: 0.24em;
  text-transform: uppercase;
}

.home-hero__overlay .section-label {
  color: rgba(255, 255, 255, 0.84);
}

.home-hero__title {
  margin: 0;
  font-size: clamp(4.2rem, 8.8vw, 7.5rem);
  line-height: 0.88;
  letter-spacing: -0.062em;
  max-width: none;
  white-space: nowrap;
  color: rgba(247, 242, 235, 0.95);
  text-shadow: 0 14px 36px rgba(0, 0, 0, 0.24);
}

.page-header__title {
  margin: 0;
  font-size: clamp(3.4rem, 8vw, 6rem);
  line-height: 0.9;
  letter-spacing: -0.055em;
}

.home-hero__tagline,
.page-header__intro {
  margin: 0;
  color: var(--color-muted);
  font-size: clamp(1.05rem, 1.8vw, 1.35rem);
  line-height: 1.55;
}

.home-hero__tagline {
  max-width: none;
  justify-self: end;
  text-align: right;
  white-space: nowrap;
  margin-bottom: clamp(0.6rem, 1.4vw, 1rem);
  color: rgba(255, 255, 255, 0.88);
  text-shadow: 0 8px 26px rgba(0, 0, 0, 0.22);
}

.home-hero__supporting {
  max-width: 23rem;
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.96rem;
  line-height: 1.65;
  text-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
}

.home-hero__supporting p {
  margin: 0;
}

.page-header__intro {
  max-width: 34rem;
}

.rich-text {
  color: var(--color-muted);
  max-width: var(--content-max);
}

.home-feature-band {
  width: min(calc(100% - 2rem), var(--site-max));
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(18rem, 0.82fr) minmax(0, 1.18fr);
  gap: clamp(0.9rem, 1.8vw, 1.5rem);
  align-items: start;
  margin-top: 0;
  position: relative;
  z-index: 2;
}

.home-bio-panel {
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, var(--color-panel), rgba(255, 255, 255, 0.08));
  box-shadow: var(--shadow-panel);
}

.home-headshot-card {
  position: relative;
}

.home-headshot-card::before {
  content: "";
  position: absolute;
  inset: 1rem -0.7rem -0.7rem 1rem;
  border: 1px solid var(--color-frame-line);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.12);
  box-shadow: var(--shadow-panel);
  z-index: -1;
}

.home-headshot-card__media {
  overflow: hidden;
  border-radius: var(--radius-sm);
  background: var(--color-surface);
  aspect-ratio: 4 / 5.08;
  border: 1px solid var(--color-frame-line);
  box-shadow: var(--shadow-soft);
}

.home-headshot-card__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.home-bio-panel {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  display: grid;
  gap: 1rem;
  padding: clamp(1.2rem, 2.35vw, 1.75rem);
  background:
    linear-gradient(160deg, rgba(255, 255, 255, 0.24), rgba(255, 255, 255, 0.02)),
    linear-gradient(180deg, var(--color-panel), rgba(255, 255, 255, 0.08));
}

.home-bio-panel::before,
.home-bio-panel::after {
  content: "";
  position: absolute;
  pointer-events: none;
  z-index: 0;
}

.home-bio-panel::before {
  top: -5rem;
  right: -3rem;
  width: 13rem;
  height: 13rem;
  background: radial-gradient(circle, var(--color-accent-soft) 0%, rgba(255, 255, 255, 0) 72%);
  opacity: 0.95;
}

.home-bio-panel::after {
  display: none;
}

.home-bio-panel > * {
  position: relative;
  z-index: 1;
}

.home-bio-panel__intro {
  margin: -0.15rem 0 0;
  max-width: 24rem;
  color: var(--color-muted);
  font-size: 0.98rem;
  line-height: 1.5;
}

.home-bio-panel__body {
  max-width: 36rem;
}

.home-news-panel {
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, var(--color-panel), rgba(255, 255, 255, 0.08));
  box-shadow: var(--shadow-panel);
}

.home-news-panel {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  display: grid;
  gap: 1.25rem;
  padding: clamp(1.35rem, 2.6vw, 2rem);
  background:
    linear-gradient(160deg, rgba(255, 255, 255, 0.24), rgba(255, 255, 255, 0.02)),
    linear-gradient(180deg, var(--color-panel), rgba(255, 255, 255, 0.08));
}

.home-news-panel::before,
.home-news-panel::after {
  content: "";
  position: absolute;
  pointer-events: none;
  z-index: 0;
}

.home-news-panel::before {
  top: -5rem;
  right: -3rem;
  width: 13rem;
  height: 13rem;
  background: radial-gradient(circle, var(--color-accent-soft) 0%, rgba(255, 255, 255, 0) 72%);
  opacity: 0.95;
}

.home-news-panel::after {
  display: none;
}

.home-news-panel > * {
  position: relative;
  z-index: 1;
}

.home-news-panel__intro {
  margin: -0.15rem 0 0;
  max-width: 24rem;
  color: var(--color-muted);
  font-size: 0.98rem;
  line-height: 1.5;
}

.home-news-list {
  display: grid;
  gap: 1.15rem;
}

.home-news-list .work-card {
  position: relative;
  overflow: hidden;
  gap: 0.9rem;
  padding: 1.3rem 1.35rem 1.45rem;
  background: linear-gradient(160deg, rgba(255, 255, 255, 0.16), rgba(255, 255, 255, 0.02));
}

.home-news-list .work-card::before,
.home-news-list .work-card::after {
  display: none;
}

.work-card[data-work-status="recent"] {
  --work-accent: #7b5b43;
}

.work-card[data-work-status="current"] {
  --work-accent: #7c3a3b;
}

.work-card[data-work-status="upcoming"] {
  --work-accent: #5d4464;
}

.home-statement-band {
  width: min(calc(100% - 2rem), var(--site-max));
  margin: 0 auto;
  padding: 0.25rem 0 0;
}

.home-statement-band__copy {
  margin: 0;
  max-width: 58rem;
  padding: 0;
  color: var(--color-text);
  font-size: clamp(1.14rem, 2vw, 1.48rem);
  line-height: 1.45;
  letter-spacing: -0.012em;
}

.rich-text > :first-child,
.portfolio-card__content > :first-child,
.work-card > :first-child,
.gallery-card__content > :first-child,
.detail-card > :first-child {
  margin-top: 0;
}

.rich-text > :last-child,
.portfolio-card__content > :last-child,
.work-card > :last-child,
.gallery-card__content > :last-child,
.detail-card > :last-child {
  margin-bottom: 0;
}

.rich-text p,
.rich-text ul,
.rich-text ol {
  margin: 0 0 1rem;
  font-size: clamp(1.04rem, 1.22vw, 1.16rem);
  line-height: 1.72;
}

.rich-text h2,
.rich-text h3,
.rich-text h4 {
  margin: 2rem 0 0.8rem;
  color: var(--color-text);
}

.rich-text ul,
.rich-text ol {
  padding-left: 1.2rem;
}

.rich-text blockquote {
  margin: 1.75rem 0;
  padding-left: 1.25rem;
  border-left: 2px solid var(--color-accent);
  color: var(--color-text);
}

.section-link a,
.back-link a {
  color: var(--color-accent);
  font-weight: 600;
}

.content-section {
  display: grid;
  gap: clamp(1.75rem, 3vw, 2.75rem);
}

.content-section--contact {
  margin-top: clamp(1.35rem, 4vw, 3rem);
}

.content-section--work {
  padding-top: 1rem;
  border-top: 1px solid var(--color-line);
}

.content-section--gallery {
  gap: clamp(2.25rem, 5vw, 4.5rem);
}

.content-section--404 {
  min-height: clamp(30rem, 68vh, 44rem);
  align-content: center;
}

.section-heading,
.page-header {
  display: grid;
  gap: 0.95rem;
  max-width: 48rem;
}

.section-heading h2,
.feature-media__content h2,
.contact-panel__content h2,
.detail-card h2 {
  margin: 0;
  font-size: clamp(2.2rem, 5vw, 3.4rem);
  line-height: 0.94;
  letter-spacing: -0.045em;
}

.section-heading--compact h2 {
  font-size: clamp(1.85rem, 4vw, 2.5rem);
}

.content-shell {
  width: min(100%, var(--content-max));
}

.error-stage {
  display: grid;
  grid-template-columns: minmax(0, 0.7fr) minmax(18rem, 1fr);
  gap: clamp(1.5rem, 4vw, 4rem);
  align-items: end;
  width: min(100%, 62rem);
}

.error-stage__code {
  margin: 0;
  color: color-mix(in srgb, var(--color-accent) 28%, var(--color-text));
  font-size: clamp(5.5rem, 20vw, 13rem);
  font-weight: 650;
  line-height: 0.84;
  letter-spacing: -0.08em;
}

.error-stage__card {
  display: grid;
  gap: 1.15rem;
  padding: clamp(1.35rem, 3vw, 2.1rem);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-md);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.12), transparent 42%),
    var(--color-panel);
  box-shadow: var(--shadow-panel);
}

.error-stage__lead {
  margin: 0;
  font-size: clamp(1.1rem, 2vw, 1.35rem);
  line-height: 1.35;
  letter-spacing: -0.02em;
}

.error-stage__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.content-section--portfolio-stream {
  gap: clamp(2rem, 5vw, 4.5rem);
}

.page-header--portfolio {
  max-width: none;
  justify-items: center;
  text-align: center;
  padding-top: 1.35rem;
}

.page-header--portfolio .page-header__title {
  max-width: none;
}

.page-header--portfolio .page-header__intro {
  max-width: 30rem;
}

.portfolio-stream {
  display: grid;
  gap: clamp(2.5rem, 5vw, 5rem);
}

.portfolio-cluster {
  display: grid;
  gap: 1.5rem;
}

.portfolio-cluster + .portfolio-cluster {
  margin-top: clamp(2.4rem, 6vw, 5rem);
}

.portfolio-cluster__header {
  display: grid;
  gap: 0.25rem;
}

.portfolio-cluster__title {
  margin: 0;
  font-size: clamp(2rem, 4.5vw, 3rem);
  line-height: 0.94;
  letter-spacing: -0.05em;
}

.portfolio-entry {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(18rem, 0.92fr);
  gap: clamp(1.5rem, 4vw, 4rem);
  align-items: center;
}

.portfolio-entry + .portfolio-entry {
  padding-top: clamp(2.5rem, 5vw, 4rem);
  border-top: 1px solid var(--color-line);
}

.portfolio-entry--reverse .portfolio-entry__media {
  order: 2;
}

.portfolio-entry--reverse .portfolio-entry__content {
  order: 1;
}

.portfolio-entry__media,
.portfolio-entry__content {
  display: grid;
  gap: 1rem;
}

.portfolio-entry__media {
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border: 1px solid var(--color-frame-line);
  border-radius: var(--radius-lg);
  background: linear-gradient(145deg, var(--color-panel-strong), var(--color-panel));
  box-shadow: var(--shadow-soft);
}

.portfolio-entry__media iframe,
.portfolio-entry__media img,
.portfolio-entry__media video {
  width: 100%;
  height: 100%;
  border: 0;
  object-fit: cover;
}

.portfolio-entry__content {
  max-width: 32rem;
}

.portfolio-entry__meta {
  margin: 0;
  color: var(--color-muted);
  font-size: 0.78rem;
  font-weight: 650;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.portfolio-entry__title {
  margin: 0;
  font-size: clamp(2.15rem, 5vw, 3.75rem);
  line-height: 0.94;
  letter-spacing: -0.05em;
}

.portfolio-entry__summary,
.portfolio-entry__details,
.portfolio-entry__action {
  margin: 0;
}

.portfolio-entry__summary,
.portfolio-entry__details {
  color: var(--color-muted);
  font-size: clamp(1rem, 1.5vw, 1.12rem);
}

.portfolio-entry__action a {
  color: inherit;
}

.portfolio-entry__action-link {
  display: inline-grid;
  place-items: center;
  width: 2.6rem;
  height: 2.6rem;
  border: 1px solid var(--color-line);
  border-radius: 999px;
  color: var(--color-text);
  background: rgba(255, 255, 255, 0.08);
  transition: transform var(--transition), border-color var(--transition), background var(--transition);
}

.portfolio-entry__action-link:hover,
.portfolio-entry__action-link:focus-visible {
  color: var(--color-text);
  transform: translateY(-1px);
  border-color: var(--color-frame-line-strong);
  background: rgba(255, 255, 255, 0.16);
}

.portfolio-entry__action-icon {
  width: 1rem;
  height: 1rem;
}

.portfolio-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(1.4rem, 3vw, 2.25rem);
}

.portfolio-card {
  background: linear-gradient(180deg, var(--color-panel), rgba(255, 255, 255, 0.04));
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: transform var(--transition), border-color var(--transition), box-shadow var(--transition), background var(--transition);
}

.portfolio-card:hover,
.portfolio-card:focus-within {
  transform: translateY(-0.4rem);
  border-color: rgba(22, 21, 20, 0.22);
  box-shadow: var(--shadow-panel);
}

.portfolio-card:nth-child(even) {
  margin-top: clamp(2rem, 4vw, 4rem);
}

.portfolio-card__link {
  display: grid;
  color: inherit;
}

.portfolio-card__media {
  aspect-ratio: 4 / 5.1;
  border-radius: 0;
  box-shadow: none;
}

.portfolio-card:nth-child(3n + 2) .portfolio-card__media {
  aspect-ratio: 4 / 4.35;
}

.portfolio-card__content,
.gallery-card__content {
  display: grid;
  gap: 0.7rem;
  padding: 1.45rem 1.45rem 1.85rem;
}

.portfolio-card__content h3,
.gallery-card__content h3,
.work-card h3 {
  margin: 0;
  font-size: 1.5rem;
  line-height: 1.05;
}

.portfolio-card__content p,
.gallery-card__content p,
.work-card p,
.detail-card p,
.feature-media__content p,
.contact-panel__content p {
  margin: 0;
}

.work-grid,
.detail-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.25rem;
}

.work-card,
.detail-card {
  display: grid;
  gap: 0.75rem;
  padding: 1.45rem;
  border: 1px solid var(--color-line);
  border-radius: var(--radius-md);
  background: linear-gradient(180deg, var(--color-panel), rgba(255, 255, 255, 0.04));
  box-shadow: var(--shadow-panel);
}

.work-card__status {
  width: fit-content;
  padding: 0.26rem 0.5rem;
  border: 0;
  border-radius: var(--radius-sm);
  background: var(--work-accent, var(--color-text));
  color: rgba(249, 244, 237, 0.98);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.06);
}

.work-card__meta {
  color: var(--color-muted);
  font-size: 0.75rem;
  font-weight: 650;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.work-card__summary {
  color: var(--color-muted);
  line-height: 1.55;
}

.work-card__link {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  width: fit-content;
  padding-top: 0.2rem;
  color: var(--color-text);
  font-size: 0.76rem;
  font-weight: 650;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.work-card__link-icon {
  display: inline-block;
  transition: transform var(--transition);
}

.work-card__link:hover .work-card__link-icon,
.work-card__link:focus-visible .work-card__link-icon {
  transform: translate(0.12rem, -0.1rem);
}

.detail-meta {
  color: var(--color-muted);
  font-size: 0.92rem;
}

.page-header {
  padding-top: 0.9rem;
}

.page-header--gallery {
  max-width: none;
  justify-items: center;
  text-align: center;
  padding-top: 1.35rem;
}

.page-header__title {
  max-width: 14ch;
}

.page-header--gallery .page-header__title {
  max-width: none;
  font-size: clamp(3.5rem, 9vw, 6.4rem);
}

.page-header__intro {
  max-width: 36rem;
}

.editorial-layout,
.feature-media,
.resume-layout,
.contact-panel {
  display: grid;
  grid-template-columns: minmax(0, 1.42fr) minmax(17rem, 0.58fr);
  gap: clamp(1.5rem, 4vw, 4rem);
  align-items: start;
}

.editorial-layout--about {
  grid-template-columns: minmax(0, 1fr) minmax(20rem, 0.94fr);
  gap: clamp(1.75rem, 4vw, 4.5rem);
}

.editorial-layout--about .editorial-layout__aside {
  padding-top: 0;
  margin-top: clamp(-4.5rem, -5vw, -3rem);
}

.editorial-layout__main {
  display: grid;
  gap: 2rem;
}

.about-layout__main {
  max-width: 44rem;
  gap: 1.8rem;
}

.editorial-layout__figure {
  margin: 0;
  box-shadow: var(--shadow-soft);
}

.editorial-layout__figure img {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
}

.editorial-layout__aside {
  padding-top: clamp(1rem, 5vw, 4rem);
}

.editorial-layout__aside,
.feature-media__content,
.resume-layout__content {
  display: grid;
  gap: 1.25rem;
}

.about-rail {
  gap: 1rem;
  padding-top: 0;
}

.about-image-rail {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 0.9rem;
}

.about-image-rail__item {
  grid-column: span 3;
  overflow: hidden;
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-frame-line);
  background: linear-gradient(180deg, var(--color-panel), rgba(255, 255, 255, 0.06));
  box-shadow: var(--shadow-soft);
}

.about-image-rail__item--1,
.about-image-rail__item--4 {
  grid-column: span 6;
}

.about-image-rail__trigger {
  display: block;
  color: inherit;
}

.about-image-rail__image {
  width: 100%;
  height: 100%;
  min-height: 14rem;
  object-fit: cover;
  transition: transform 480ms cubic-bezier(0.22, 1, 0.36, 1);
}

.about-image-rail__trigger:hover .about-image-rail__image,
.about-image-rail__trigger:focus-visible .about-image-rail__image {
  transform: scale(1.03);
}

.about-rail__split {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.about-rail-card {
  position: relative;
  isolation: isolate;
  display: grid;
  align-content: end;
  gap: 0.45rem;
  min-height: clamp(13rem, 22vw, 16rem);
  padding: 1.2rem;
  border: 0;
  border-radius: var(--radius-lg);
  background:
    linear-gradient(180deg, rgba(18, 15, 13, 0.04), rgba(18, 15, 13, 0.72)),
    linear-gradient(145deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.015));
  box-shadow: var(--shadow-soft);
  overflow: hidden;
  color: #f6f0e8;
  transition: transform var(--transition), box-shadow var(--transition);
}

.about-rail-card::before {
  content: "";
  position: absolute;
  top: -3.5rem;
  right: -2.4rem;
  width: 9.5rem;
  height: 9.5rem;
  border-radius: 999px;
  background: radial-gradient(circle, var(--color-accent-soft) 0%, rgba(255, 255, 255, 0) 72%);
  opacity: 0.8;
  z-index: 0;
  pointer-events: none;
}

.about-rail-card:hover,
.about-rail-card:focus-visible {
  transform: translateY(-0.24rem);
  box-shadow: var(--shadow-deep);
  color: #f6f0e8;
}

.about-rail-card > * {
  position: relative;
  z-index: 1;
}

.about-rail-card__visual {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.about-rail-card__visual::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(18, 15, 13, 0.02), rgba(18, 15, 13, 0.7)),
    linear-gradient(150deg, rgba(18, 15, 13, 0) 28%, rgba(18, 15, 13, 0.24) 100%);
}

.about-rail-card__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.about-rail-card__eyebrow,
.about-feature-card__meta {
  margin: 0;
  font-size: 0.74rem;
  font-weight: 650;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.about-rail-card__eyebrow {
  color: rgba(246, 240, 232, 0.7);
}

.about-rail-card__title {
  font-size: clamp(1.4rem, 2.3vw, 1.9rem);
  line-height: 0.98;
  letter-spacing: -0.04em;
}

.about-rail-card__copy {
  color: rgba(246, 240, 232, 0.84);
  line-height: 1.45;
}

.about-feature-card {
  position: relative;
  isolation: isolate;
  display: grid;
  align-content: end;
  min-height: clamp(18rem, 32vw, 23rem);
  padding: clamp(1.35rem, 2.6vw, 2rem);
  border: 0;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background:
    linear-gradient(160deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.02)),
    linear-gradient(180deg, rgba(28, 23, 20, 0.88), rgba(28, 23, 20, 0.74));
  box-shadow: var(--shadow-panel);
  color: #f6f0e8;
}

.about-feature-card::before {
  content: "";
  position: absolute;
  top: -4.5rem;
  right: -3rem;
  width: 13rem;
  height: 13rem;
  border-radius: 999px;
  background: radial-gradient(circle, var(--color-accent-soft) 0%, rgba(255, 255, 255, 0) 72%);
  opacity: 0.95;
  pointer-events: none;
  z-index: 0;
}

.about-feature-card__visual {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.about-feature-card__visual::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(18, 15, 13, 0.06), rgba(18, 15, 13, 0.86)),
    linear-gradient(145deg, rgba(18, 15, 13, 0) 26%, rgba(18, 15, 13, 0.3) 100%);
}

.about-feature-card__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.about-feature-card__body {
  position: relative;
  z-index: 1;
  display: grid;
  align-content: end;
  gap: 0.8rem;
  min-height: 100%;
}

.about-feature-card h2 {
  margin: 0;
  font-size: clamp(2rem, 4vw, 3.2rem);
  line-height: 0.94;
  letter-spacing: -0.05em;
}

.about-feature-card__copy {
  max-width: 24rem;
  color: rgba(246, 240, 232, 0.9);
  line-height: 1.55;
}

.about-feature-card p:last-of-type {
  margin-bottom: 0;
}

.about-feature-card__meta {
  color: rgba(246, 240, 232, 0.72);
  opacity: 1;
}

.about-feature-card__supporting {
  color: rgba(246, 240, 232, 0.64);
  max-width: 28rem;
  padding-top: 0.2rem;
}

.about-feature-card__action {
  margin: 0;
  padding-top: 0.25rem;
}

.about-feature-card__link {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  color: #f6f0e8;
  font-size: 0.9rem;
  font-weight: 650;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.about-feature-card__link:hover,
.about-feature-card__link:focus-visible {
  color: #f6f0e8;
}

.feature-media {
  padding: 1.5rem;
  border: 1px solid var(--color-frame-line);
  border-radius: var(--radius-lg);
  background: linear-gradient(145deg, var(--color-panel-strong), var(--color-panel));
  box-shadow: var(--shadow-soft);
}

.feature-media__embed {
  min-height: 28rem;
}

.feature-media__embed iframe,
.feature-media__embed img {
  width: 100%;
  height: 100%;
  min-height: 28rem;
  object-fit: cover;
}

.feature-media--single {
  margin-bottom: 2rem;
}

.content-section--project {
  display: grid;
  gap: clamp(1.5rem, 4vw, 3rem);
}

.project-stage {
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(18rem, 0.82fr);
  gap: clamp(1.5rem, 4vw, 4rem);
  align-items: start;
}

.project-stage {
  margin-top: 0.25rem;
}

.project-stage__media {
  overflow: hidden;
  border: 1px solid var(--color-frame-line);
  border-radius: var(--radius-lg);
  background: linear-gradient(145deg, var(--color-panel-strong), var(--color-panel));
  box-shadow: var(--shadow-soft);
}

.project-stage__media iframe,
.project-stage__media video {
  display: block;
  width: 100%;
  min-height: clamp(24rem, 42vw, 36rem);
  border: 0;
}

.project-stage__media img {
  display: block;
  width: 100%;
  height: auto;
}

.project-stage__content {
  display: grid;
  gap: 1rem;
  max-width: 30rem;
  padding-top: clamp(0.25rem, 1vw, 0.7rem);
}

.project-stage__meta,
.project-gallery__meta,
.project-pagination__eyebrow {
  margin: 0;
  color: var(--color-muted);
  font-size: 0.76rem;
  font-weight: 650;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.project-stage__title {
  margin: 0;
  font-size: clamp(2.85rem, 6vw, 5.25rem);
  line-height: 0.9;
  letter-spacing: -0.06em;
}

.project-stage__summary,
.project-stage__body {
  margin: 0;
}

.project-stage__summary {
  font-size: clamp(1.05rem, 1.8vw, 1.28rem);
  line-height: 1.45;
}

.project-stage__body.rich-text {
  max-width: none;
  display: grid;
  gap: 0.9rem;
  color: var(--color-muted);
}

.project-stage__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.9rem 1.1rem;
  padding-top: 0.35rem;
}

.project-stage__action {
  color: var(--color-accent);
  font-size: 0.78rem;
  font-weight: 650;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.project-gallery {
  display: grid;
  gap: 1rem;
}

.project-gallery__hero {
  display: grid;
  grid-template-columns: minmax(0, 1.38fr) minmax(0, 0.88fr);
  gap: 1rem;
  align-items: stretch;
}

.project-gallery__hero--single {
  grid-template-columns: 1fr;
}

.project-gallery__supporting,
.project-gallery__wall {
  display: grid;
  gap: 1rem;
}

.project-gallery__wall {
  grid-template-columns: repeat(12, minmax(0, 1fr));
  align-items: start;
}

.project-still {
  display: block;
  min-height: 100%;
}

.project-gallery__wall .project-still {
  grid-column: span 4;
}

.project-gallery__wall .project-still:nth-child(5n + 2),
.project-gallery__wall .project-still:nth-child(5n + 5) {
  grid-column: span 6;
}

.project-still__trigger {
  display: block;
  color: inherit;
}

.project-still__trigger:hover,
.project-still__trigger:focus-visible {
  color: inherit;
}

.project-still__media {
  overflow: hidden;
  border: 1px solid var(--color-frame-line);
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, var(--color-panel), rgba(255, 255, 255, 0.04));
  box-shadow: var(--shadow-soft);
  transition: transform var(--transition), border-color var(--transition), box-shadow var(--transition);
}

.project-still__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 480ms cubic-bezier(0.22, 1, 0.36, 1);
}

.project-still--hero .project-still__media {
  height: 100%;
  min-height: clamp(24rem, 42vw, 34rem);
}

.project-still--supporting .project-still__media {
  aspect-ratio: 16 / 10.75;
}

.project-gallery__wall .project-still__media {
  aspect-ratio: 4 / 4.6;
}

.project-gallery__wall .project-still:nth-child(5n + 2) .project-still__media,
.project-gallery__wall .project-still:nth-child(5n + 5) .project-still__media {
  aspect-ratio: 16 / 10;
}

.project-gallery__wall .project-still:nth-child(5n + 4) .project-still__media {
  aspect-ratio: 4 / 5.4;
}

.project-still__trigger:hover .project-still__media,
.project-still__trigger:focus-visible .project-still__media {
  transform: translateY(-0.2rem);
  border-color: var(--color-frame-line-strong);
  box-shadow: var(--shadow-deep);
}

.project-still__trigger:hover .project-still__media img,
.project-still__trigger:focus-visible .project-still__media img {
  transform: scale(1.03);
}

.project-pagination__item,
.project-pagination__archive {
  border: 1px solid var(--color-line);
  border-radius: var(--radius-md);
  background: linear-gradient(180deg, var(--color-panel), rgba(255, 255, 255, 0.04));
  box-shadow: var(--shadow-soft);
}

.project-pagination {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  gap: 1rem;
  align-items: stretch;
}

.project-pagination__item,
.project-pagination__archive {
  padding: 1rem 1.15rem;
  color: inherit;
}

.project-pagination__item {
  display: grid;
  gap: 0.35rem;
}

.project-pagination__item strong {
  font-size: 1.1rem;
  line-height: 1.05;
  letter-spacing: -0.03em;
}

.project-pagination__item--next {
  text-align: right;
  justify-items: end;
}

.project-pagination__archive {
  display: inline-grid;
  place-items: center;
  font-size: 0.78rem;
  font-weight: 650;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.project-pagination__item--placeholder {
  visibility: hidden;
}

.content-section--resume {
  width: min(calc(100% - 1.5rem), 95rem);
}

.resume-stage {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
  gap: clamp(0.9rem, 1.55vw, 1.55rem);
  align-items: start;
  width: 100%;
  margin-inline: auto;
}

.resume-primary-cluster {
  display: grid;
  grid-template-columns: minmax(7.1rem, 8.2rem) minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
}

.resume-side-stack {
  display: grid;
  gap: 0.65rem;
  align-content: start;
  align-self: start;
}

.resume-side-stack__item {
  position: relative;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  border-radius: calc(var(--radius-md) + 0.05rem);
  border: 1px solid var(--color-frame-line);
  background: linear-gradient(180deg, var(--color-panel), rgba(255, 255, 255, 0.05));
  box-shadow: var(--shadow-soft);
  padding: 0.22rem;
}

.resume-side-stack__trigger {
  display: grid;
  place-items: center;
  height: 100%;
  color: inherit;
}

.resume-side-stack__image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  transition: transform 420ms cubic-bezier(0.22, 1, 0.36, 1);
}

.resume-side-stack__trigger:hover .resume-side-stack__image,
.resume-side-stack__trigger:focus-visible .resume-side-stack__image {
  transform: scale(1.03);
}

.resume-primary,
.resume-sheet {
  min-height: 0;
  height: auto;
  aspect-ratio: 4 / 5;
  padding: clamp(0.62rem, 0.82vw, 0.72rem);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
  overflow: hidden;
}

.resume-primary {
  display: block;
  position: relative;
  background: linear-gradient(145deg, var(--color-panel-strong), var(--color-panel));
}

.resume-sheet {
  aspect-ratio: 4 / 5;
  min-height: 0;
  position: relative;
  display: grid;
  grid-template-rows: minmax(0, 1fr);
  align-content: stretch;
  gap: 0;
  width: 100%;
  padding: clamp(0.54rem, 0.76vw, 0.66rem);
  border-color: rgba(23, 20, 18, 0.08);
  background: linear-gradient(180deg, var(--resume-paper-strong), var(--resume-paper));
  box-shadow: var(--resume-shadow);
}

.resume-sheet::before {
  content: none;
}

html[data-theme="dark"] .resume-sheet {
  border-color: rgba(247, 239, 229, 0.12);
  box-shadow:
    0 30px 90px rgba(0, 0, 0, 0.44),
    0 0 0 1px rgba(255, 255, 255, 0.03);
}

html[data-theme="dark"] .resume-sheet::before {
  content: none;
}

.resume-download-button {
  position: absolute;
  top: 0.95rem;
  right: 0.95rem;
  z-index: 3;
  display: inline-grid;
  place-items: center;
  width: 3rem;
  height: 3rem;
  border: 1px solid rgba(23, 20, 18, 0.12);
  border-radius: 999px;
  color: var(--resume-ink);
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 18px 34px rgba(23, 20, 18, 0.16);
  transition:
    transform 220ms ease,
    border-color 220ms ease,
    background-color 220ms ease,
    box-shadow 220ms ease;
}

.resume-download-button:hover,
.resume-download-button:focus-visible {
  color: var(--resume-ink);
  transform: translateY(-1px);
  border-color: rgba(23, 20, 18, 0.18);
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 22px 38px rgba(23, 20, 18, 0.18);
}

.resume-download-button__icon {
  width: 0.95rem;
  height: 0.95rem;
}

.resume-primary__figure {
  margin: 0;
  display: grid;
  place-items: center;
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.16);
  box-shadow: var(--shadow-panel);
}

.resume-primary__image,
.resume-primary__figure img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
}

.resume-sheet__viewport {
  position: relative;
  min-height: 0;
  overflow: hidden;
  height: 100%;
}

.resume-sheet__viewport--embed {
  display: grid;
  place-items: center;
  padding: clamp(0.18rem, 0.42vw, 0.3rem);
  background: var(--resume-paper-strong);
  border-radius: calc(var(--radius-lg) - 0.2rem);
}

.resume-sheet__embed {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 0;
  border: 0;
  border-radius: calc(var(--radius-lg) - 0.34rem);
  background: var(--resume-paper-strong);
}

.resume-sheet__fallback {
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 1.5rem;
  color: var(--resume-ink-soft);
  font-size: 0.92rem;
  text-align: center;
}

.resume-sheet__fallback a {
  color: var(--resume-ink);
  border-bottom: 1px solid rgba(23, 20, 18, 0.14);
}

.resume-sheet__content {
  display: grid;
  gap: 0;
  min-height: 0;
  height: 100%;
  width: 100%;
}

.resume-sheet__content.rich-text {
  max-width: none;
  position: relative;
  z-index: 1;
  color: var(--resume-ink);
  font-size: 0.98rem;
  line-height: 1.42;
}

.resume-sheet__content.rich-text p,
.resume-sheet__content.rich-text li {
  color: var(--resume-ink-soft);
}

.resume-paper {
  container-type: inline-size;
  position: relative;
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
  gap: clamp(0.18rem, 0.95cqw, 0.34rem);
  height: 100%;
}

.resume-paper__facts {
  margin: 0;
  padding: 0 1.2rem clamp(0.2rem, 0.95cqw, 0.34rem) 0;
  color: var(--resume-ink-soft);
  font-size: clamp(0.42rem, 1.8cqw, 0.56rem);
  line-height: 1.1;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.resume-paper__section {
  display: block;
  margin: 0;
}

.resume-paper__meta {
  display: grid;
  grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.2fr);
  gap: clamp(0.28rem, 1.5cqw, 0.5rem);
  min-height: 0;
  width: calc(100% / 0.8);
  transform: scale(0.8);
  transform-origin: top left;
}

.resume-paper__meta-column {
  display: grid;
  gap: clamp(0.16rem, 0.88cqw, 0.32rem);
  align-content: start;
}

.resume-paper__label {
  margin: 0;
  color: var(--resume-ink);
  font-size: clamp(0.46rem, 2.05cqw, 0.64rem);
  line-height: 1;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 650;
}

.resume-paper__section > .resume-paper__label + * {
  margin-top: clamp(0.08rem, 0.52cqw, 0.18rem);
}

.resume-paper__credits {
  display: grid;
  gap: 0.08rem;
}

.resume-paper__theatre-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(0.08rem, 0.4cqw, 0.14rem) clamp(0.18rem, 0.92cqw, 0.3rem);
}

.resume-paper__theatre-row {
  display: grid;
  gap: 0.02rem;
  align-content: start;
}

.resume-paper__theatre-copy,
.resume-paper__theatre-meta {
  margin: 0;
}

.resume-paper__theatre-copy {
  color: var(--resume-ink);
  font-size: clamp(0.44rem, 1.88cqw, 0.58rem);
  line-height: 1.05;
  text-wrap: pretty;
}

.resume-paper__theatre-title {
  font-weight: 650;
}

.resume-paper__theatre-title span {
  color: var(--resume-ink-soft);
  font-weight: 500;
  font-size: 0.72em;
  vertical-align: text-top;
}

.resume-paper__theatre-meta {
  color: var(--resume-ink-soft);
  font-size: clamp(0.32rem, 1.3cqw, 0.42rem);
  line-height: 1.08;
  text-wrap: pretty;
}

.resume-paper__credit {
  display: grid;
  gap: 0.02rem;
}

.resume-paper__credit-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.26rem;
  align-items: end;
}

.resume-paper__credit-title,
.resume-paper__credit-role,
.resume-paper__credit-venue,
.resume-paper__compact-title,
.resume-paper__compact-meta,
.resume-paper__training-title,
.resume-paper__training-meta,
.resume-paper__training-copy,
.resume-paper__list li,
.resume-paper__skills li,
.resume-paper__note {
  margin: 0;
}

.resume-paper__credit-title {
  color: var(--resume-ink);
  font-size: 0.62rem;
  line-height: 0.98;
  font-weight: 650;
}

.resume-paper__credit-title span {
  color: var(--resume-ink-soft);
  font-weight: 500;
}

.resume-paper__credit-role {
  color: var(--resume-ink);
  font-size: 0.52rem;
  line-height: 1.02;
}

.resume-paper__credit-venue {
  color: var(--resume-ink-soft);
  font-size: 0.4rem;
  line-height: 0.96;
  text-align: right;
}

.resume-paper__note {
  color: var(--resume-ink-soft);
  font-size: clamp(0.28rem, 1.18cqw, 0.38rem);
  line-height: 1.04;
  text-align: right;
  margin-top: clamp(0.08rem, 0.52cqw, 0.18rem);
}

.resume-paper__compact-list {
  display: grid;
  gap: clamp(0.05rem, 0.4cqw, 0.12rem);
}

.resume-paper__compact-line {
  margin: 0;
  color: var(--resume-ink-soft);
  font-size: clamp(0.34rem, 1.46cqw, 0.44rem);
  line-height: 1.08;
}

.resume-paper__training {
  display: grid;
  gap: clamp(0.05rem, 0.42cqw, 0.12rem);
}

.resume-paper__compact-strong,
.resume-paper__training-strong {
  color: var(--resume-ink);
  font-weight: 650;
}

.resume-paper__training-line {
  margin: 0;
  color: var(--resume-ink-soft);
  font-size: clamp(0.34rem, 1.46cqw, 0.44rem);
  line-height: 1.08;
}

.resume-paper__training-copy {
  color: var(--resume-ink-soft);
  font-size: clamp(0.3rem, 1.24cqw, 0.38rem);
  line-height: 1.06;
}

.resume-doc {
  display: grid;
  gap: 0.42rem 0.8rem;
  grid-template-columns: minmax(0, 1.08fr) minmax(0, 0.92fr);
  align-content: start;
  width: calc(100% / 1.12);
  transform: scale(1.12);
  transform-origin: top left;
}

.resume-doc__masthead {
  grid-column: 1 / -1;
}

.resume-doc > .resume-doc__section--credits:nth-of-type(1) {
  grid-column: 1;
  grid-row: 2 / span 3;
  align-self: start;
}

.resume-doc > .resume-doc__section--credits:nth-of-type(2) {
  grid-column: 2;
  grid-row: 2;
}

.resume-doc > .resume-doc__section--credits:nth-of-type(3) {
  grid-column: 2;
  grid-row: 3;
}

.resume-doc > .resume-doc__meta-grid {
  grid-column: 2;
  grid-row: 4;
}

.resume-doc__masthead {
  display: grid;
  gap: 0.3rem;
  padding-bottom: 0.38rem;
  border-bottom: 1px solid rgba(23, 20, 18, 0.08);
}

.resume-doc__masthead--stacked {
  gap: 0.2rem;
  justify-items: start;
}

.resume-doc__name-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 1rem;
}

.resume-doc__name {
  margin: 0;
  font-size: clamp(1.74rem, 2.4vw, 2.22rem);
  line-height: 0.96;
  letter-spacing: -0.045em;
  color: var(--resume-ink);
  font-weight: 650;
}

.resume-doc__name--center {
  text-align: center;
}

.resume-doc__link {
  margin: 0;
  color: var(--resume-ink-soft);
  font-size: 0.7rem;
  font-weight: 650;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.resume-doc__link a {
  color: var(--resume-ink);
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding-bottom: 0.1rem;
  border-bottom: 1px solid rgba(23, 20, 18, 0.16);
}

.resume-doc__contact-line,
.resume-doc__subfacts {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.24rem 0.72rem;
  margin: 0;
}

.resume-doc__contact-line {
  font-size: 0.78rem;
  line-height: 1.25;
  color: var(--resume-ink-soft);
}

.resume-doc__contact-label {
  color: var(--resume-ink);
  font-weight: 650;
}

.resume-doc__contact-line a {
  color: var(--resume-ink);
  text-decoration: none;
  border-bottom: 1px solid rgba(23, 20, 18, 0.14);
}

.resume-doc__subfacts {
  font-size: 0.8rem;
  line-height: 1.14;
  color: var(--resume-ink-soft);
}

.resume-doc__subfacts span {
  white-space: nowrap;
}

.resume-doc__subfacts span + span::before {
  content: "\2022";
  margin-right: 0.54rem;
  color: var(--resume-ink-soft);
}

.resume-doc__facts {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.28rem 0.8rem;
}

.resume-doc__fact {
  display: flex;
  flex-wrap: nowrap;
  gap: 0.3rem 0.45rem;
  margin: 0;
  font-size: 0.84rem;
  color: var(--resume-ink-soft);
  white-space: nowrap;
}

.resume-doc__fact-label {
  color: var(--resume-ink);
  font-weight: 600;
}

.resume-doc__section {
  display: grid;
  gap: 0.2rem;
}

.resume-doc__section + .resume-doc__section {
  padding-top: 0.08rem;
  border-top: none;
}

.resume-doc__section--credits {
  gap: 0.16rem;
}

.resume-doc__section--credits + .resume-doc__section--credits {
  padding-top: 0.08rem;
}

.resume-doc__section-title {
  margin: 0;
  color: var(--resume-ink);
  font-size: 0.66rem;
  font-weight: 650;
  line-height: 1.1;
  letter-spacing: 0.13em;
  text-transform: uppercase;
}

.resume-credits {
  display: grid;
  gap: 0.08rem;
}

.resume-credits--tight {
  gap: 0.04rem;
}

.resume-credit {
  display: grid;
  grid-template-columns: minmax(0, 1.22fr) minmax(5.4rem, 0.62fr);
  grid-template-areas:
    "production venue"
    "role venue";
  gap: 0.06rem 0.44rem;
  align-items: start;
  padding: 0.04rem 0;
}

.resume-credit + .resume-credit {
  border-top: none;
}

.resume-credit p {
  margin: 0;
  font-size: 0.86rem;
  line-height: 1.14;
}

.resume-credit__production {
  grid-area: production;
  color: var(--resume-ink);
  font-weight: 600;
}

.resume-credit__production span {
  color: var(--resume-ink-soft);
  font-weight: 400;
}

.resume-credit__role,
.resume-doc__list li,
.resume-doc__skills-copy {
  color: var(--resume-ink-soft);
}

.resume-credit__role {
  grid-area: role;
  color: var(--resume-ink);
}

.resume-credit__venue {
  grid-area: venue;
  color: var(--resume-ink-soft);
  text-align: right;
  align-self: center;
  font-size: 0.64rem;
  line-height: 1.14;
}

.resume-doc__footnote {
  margin: 0;
  text-align: right;
  font-size: 0.42rem;
  line-height: 1.04;
  letter-spacing: 0.02em;
  color: var(--resume-ink-soft);
}

.resume-doc__meta-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.16rem;
  align-items: start;
}

.resume-doc__meta-side {
  display: grid;
  gap: 0.18rem;
  align-content: start;
}

.resume-doc__section--training {
  gap: 0.08rem;
}

.resume-doc__training {
  display: grid;
  gap: 0.1rem;
}

.resume-doc__training-group {
  display: grid;
  gap: 0.02rem;
}

.resume-doc__training-title,
.resume-doc__training-copy,
.resume-doc__training-faculty {
  margin: 0;
}

.resume-doc__training-title {
  font-size: 0.56rem;
  line-height: 1.06;
  color: var(--resume-ink);
  font-weight: 600;
}

.resume-doc__training-title span {
  color: var(--resume-ink-soft);
  font-weight: 500;
}

.resume-doc__training-copy,
.resume-doc__training-faculty {
  font-size: 0.48rem;
  line-height: 1.08;
  color: var(--resume-ink-soft);
}

.resume-doc__training-copy strong {
  color: var(--resume-ink);
  font-weight: 650;
}

.resume-doc__training-faculty {
  font-style: italic;
}

.resume-doc__skills-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.08rem 0.42rem;
}

.resume-doc__skills-list .resume-doc__skills-copy {
  margin: 0;
}

.resume-doc__list {
  display: grid;
  gap: 0.08rem 0.5rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.resume-doc__list--compact {
  gap: 0.04rem;
}

.resume-doc__section--awards .resume-doc__list--compact {
  gap: 0.04rem;
}

.resume-doc__section--awards .resume-doc__list li {
  font-size: 0.62rem;
  line-height: 1.06;
}

.resume-doc__list li,
.resume-doc__skills-copy {
  font-size: 0.58rem;
  line-height: 1.08;
}

.resume-doc__section--skills {
  gap: 0.06rem;
}

.resume-doc__section--skills .resume-doc__skills-copy {
  font-size: 0.56rem;
  line-height: 1.06;
}

.resume-sheet__content.rich-text .resume-doc__name,
.resume-sheet__content.rich-text .resume-doc__section-title,
.resume-sheet__content.rich-text .resume-doc__fact-label,
.resume-sheet__content.rich-text .resume-credit__production,
.resume-sheet__content.rich-text .resume-credit__role,
.resume-sheet__content.rich-text .resume-doc__link a,
.resume-sheet__content.rich-text .resume-doc__contact-label,
.resume-sheet__content.rich-text .resume-doc__contact-line a,
.resume-sheet__content.rich-text .resume-doc__training-title {
  color: var(--resume-ink);
}

.resume-sheet__content.rich-text .resume-doc__link,
.resume-sheet__content.rich-text .resume-doc__contact-line,
.resume-sheet__content.rich-text .resume-doc__subfacts,
.resume-sheet__content.rich-text .resume-credit__production span,
.resume-sheet__content.rich-text .resume-credit__venue,
.resume-sheet__content.rich-text .resume-doc__list li,
.resume-sheet__content.rich-text .resume-doc__footnote,
.resume-sheet__content.rich-text .resume-doc__training-title span,
.resume-sheet__content.rich-text .resume-doc__training-copy,
.resume-sheet__content.rich-text .resume-doc__training-faculty,
.resume-sheet__content.rich-text .resume-doc__skills-copy {
  color: var(--resume-ink-soft);
}

.gallery-section {
  display: grid;
  gap: 1.4rem;
}

.gallery-section + .gallery-section {
  margin-top: clamp(1.4rem, 4vw, 2.8rem);
}

.gallery-section__header,
.gallery-section__heading {
  display: grid;
  gap: 0.7rem;
}

.gallery-section__title {
  margin: 0;
  font-size: clamp(1.9rem, 4vw, 2.8rem);
  line-height: 0.92;
  letter-spacing: -0.05em;
}

.gallery-section__intro {
  margin: 0;
  color: var(--color-muted);
  font-size: 1rem;
  line-height: 1.55;
}

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

.gallery-collection-card {
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, var(--color-panel), rgba(255, 255, 255, 0.06));
  box-shadow: var(--shadow-panel);
  overflow: hidden;
}

.gallery-collection-card__trigger {
  display: grid;
  grid-template-columns: minmax(0, 22rem) minmax(0, 1fr);
  gap: 1rem;
  align-items: stretch;
  width: 100%;
  padding: 0;
  border: 0;
  background: transparent;
  text-align: left;
  cursor: pointer;
  color: inherit;
}

.gallery-collection-card__cover {
  overflow: hidden;
  background: rgba(255, 255, 255, 0.04);
}

.gallery-collection-card__cover-image {
  width: 100%;
  height: 100%;
  min-height: 100%;
  aspect-ratio: 16 / 10.5;
  object-fit: cover;
  transition: transform 480ms cubic-bezier(0.22, 1, 0.36, 1);
}

.gallery-collection-card__trigger:hover .gallery-collection-card__cover-image,
.gallery-collection-card__trigger:focus-visible .gallery-collection-card__cover-image {
  transform: scale(1.04);
}

.gallery-collection-card__body {
  display: grid;
  align-content: center;
  gap: 0.5rem;
  padding: 1.3rem 1.35rem 1.3rem 0;
}

.gallery-collection-card__eyebrow,
.gallery-sheet-modal__eyebrow,
.gallery-sheet-modal__count {
  margin: 0;
  color: var(--color-muted);
  font-size: 0.74rem;
  font-weight: 650;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.gallery-collection-card__title,
.gallery-sheet-modal__title {
  margin: 0;
  font-size: clamp(1.7rem, 2.45vw, 2.2rem);
  line-height: 0.98;
  letter-spacing: -0.045em;
}

.gallery-collection-card__meta {
  margin: 0;
  color: var(--color-accent);
  font-size: 0.76rem;
  font-weight: 650;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.gallery-collection-card__copy,
.gallery-sheet-modal__copy {
  margin: 0;
  color: var(--color-muted);
  line-height: 1.55;
}

.gallery-collection-card__action {
  display: inline-grid;
  place-items: center;
  width: 2.6rem;
  height: 2.6rem;
  margin-top: 0.3rem;
  border: 1px solid var(--color-line);
  border-radius: 999px;
  color: var(--color-text);
  background: rgba(255, 255, 255, 0.08);
  transition: transform var(--transition), border-color var(--transition), background var(--transition);
}

.gallery-collection-card__action svg {
  width: 1rem;
  height: 1rem;
}

.gallery-collection-card__trigger:hover .gallery-collection-card__action,
.gallery-collection-card__trigger:focus-visible .gallery-collection-card__action {
  transform: translateY(-1px);
  border-color: var(--color-frame-line-strong);
  background: rgba(255, 255, 255, 0.16);
}

.gallery-card--sheet {
  flex: initial;
}

.gallery-card__media--sheet {
  aspect-ratio: 4 / 4.9;
}

.gallery-flow {
  position: relative;
}

.gallery-flow::before,
.gallery-flow::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: clamp(1.5rem, 4vw, 4rem);
  pointer-events: none;
  z-index: 2;
}

.gallery-flow::before {
  left: 0;
  background: linear-gradient(90deg, var(--color-bg) 0%, rgba(243, 238, 231, 0) 100%);
}

.gallery-flow::after {
  right: 0;
  background: linear-gradient(270deg, var(--color-bg) 0%, rgba(243, 238, 231, 0) 100%);
}

html[data-theme="dark"] .gallery-flow::before {
  background: linear-gradient(90deg, var(--color-bg) 0%, rgba(15, 16, 18, 0) 100%);
}

html[data-theme="dark"] .gallery-flow::after {
  background: linear-gradient(270deg, var(--color-bg) 0%, rgba(15, 16, 18, 0) 100%);
}

.gallery-track {
  display: flex;
  gap: 1rem;
  overflow-x: auto;
  padding: 0.5rem clamp(1.5rem, 4vw, 3rem) 0.8rem;
  scroll-snap-type: x mandatory;
  scroll-padding-inline: clamp(1.5rem, 4vw, 3rem);
  scrollbar-width: none;
  overscroll-behavior-inline: contain;
}

.gallery-track::-webkit-scrollbar {
  display: none;
}

.gallery-card {
  display: block;
  flex: 0 0 clamp(20rem, 36vw, 32rem);
  min-height: 100%;
  scroll-snap-align: start;
}

.gallery-card__trigger {
  display: block;
  color: inherit;
}

.gallery-card__trigger:hover,
.gallery-card__trigger:focus-visible {
  color: inherit;
}

.gallery-card__media {
  aspect-ratio: 16 / 10;
  overflow: hidden;
  border: 1px solid var(--color-frame-line);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.04);
  box-shadow: var(--shadow-soft);
  transition: transform var(--transition), border-color var(--transition), box-shadow var(--transition);
}

.gallery-card__media img {
  transition: transform 480ms cubic-bezier(0.22, 1, 0.36, 1);
}

.gallery-card__trigger:hover .gallery-card__media,
.gallery-card__trigger:focus-visible .gallery-card__media {
  transform: translateY(-0.2rem) scale(1.01);
  border-color: var(--color-frame-line-strong);
  box-shadow: var(--shadow-deep);
}

html[data-theme="dark"] .about-rail-card,
html[data-theme="dark"] .about-feature-card,
html[data-theme="dark"] .about-image-rail__item,
html[data-theme="dark"] .gallery-collection-card,
html[data-theme="dark"] .gallery-card__media,
html[data-theme="dark"] .portfolio-entry__media,
html[data-theme="dark"] .project-stage__media,
html[data-theme="dark"] .project-still__media,
html[data-theme="dark"] .resume-side-stack__item,
html[data-theme="dark"] .site-footer__profile-link {
  border-color: transparent;
}

html[data-theme="dark"] .about-rail-card {
  background:
    linear-gradient(180deg, rgba(12, 13, 16, 0.08), rgba(12, 13, 16, 0.68)),
    linear-gradient(145deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.01));
}

html[data-theme="dark"] .about-feature-card {
  background:
    linear-gradient(160deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.01)),
    linear-gradient(180deg, rgba(16, 17, 20, 0.96), rgba(16, 17, 20, 0.88));
}

html[data-theme="dark"] .gallery-card__media {
  background: rgba(255, 255, 255, 0.02);
}

html[data-theme="dark"] .gallery-collection-card,
html[data-theme="dark"] .about-image-rail__item,
html[data-theme="dark"] .resume-side-stack__item,
html[data-theme="dark"] .site-footer__profile-link {
  background: rgba(255, 255, 255, 0.03);
}

html[data-theme="dark"] .site-header {
  background: rgba(10, 16, 28, 0.76);
  border-bottom-color: rgba(234, 228, 221, 0.1);
}

html[data-theme="dark"] .resume-download-button {
  border-color: rgba(255, 255, 255, 0.1);
  background: rgba(7, 12, 21, 0.72);
  color: rgba(248, 244, 236, 0.92);
  box-shadow: 0 18px 34px rgba(0, 0, 0, 0.34);
}

html[data-theme="dark"] .resume-download-button:hover,
html[data-theme="dark"] .resume-download-button:focus-visible {
  border-color: rgba(255, 255, 255, 0.2);
  background: rgba(9, 15, 27, 0.9);
}

html[data-theme="dark"] .portfolio-entry__media,
html[data-theme="dark"] .project-stage__media,
html[data-theme="dark"] .project-still__media {
  background: rgba(255, 255, 255, 0.02);
}

html[data-theme="dark"] .project-still__trigger:hover .project-still__media,
html[data-theme="dark"] .project-still__trigger:focus-visible .project-still__media {
  border-color: transparent;
}

.gallery-card__trigger:hover .gallery-card__media img,
.gallery-card__trigger:focus-visible .gallery-card__media img {
  transform: scale(1.035);
}

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

.gallery-sheet-modal {
  position: fixed;
  inset: 0;
  z-index: 998;
  display: grid;
  place-items: center;
  padding: 1rem;
}

.gallery-sheet-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(10, 11, 14, 0.68);
  backdrop-filter: blur(12px);
}

.gallery-sheet-modal__dialog {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 1.1rem;
  width: min(100%, 96rem);
  height: min(calc(100dvh - 2rem), 58rem);
  max-height: 100%;
  margin: 0;
  padding: 1.5rem;
  overflow: auto;
  border: 1px solid var(--color-line);
  border-radius: calc(var(--radius-lg) + 0.05rem);
  background: linear-gradient(180deg, var(--color-panel-strong), var(--color-panel));
  box-shadow: 0 36px 90px rgba(0, 0, 0, 0.24);
}

.gallery-sheet-modal__close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  display: inline-grid;
  place-items: center;
  width: 3rem;
  height: 3rem;
  border: 1px solid var(--color-line);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.14);
  color: var(--color-text);
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
  transition: transform var(--transition), border-color var(--transition), background var(--transition);
}

.gallery-sheet-modal__close:hover,
.gallery-sheet-modal__close:focus-visible {
  transform: translateY(-1px);
  border-color: var(--color-frame-line-strong);
  background: rgba(255, 255, 255, 0.24);
}

.gallery-sheet-modal__header {
  display: grid;
  gap: 0.55rem;
  max-width: 50rem;
  padding-right: 3.8rem;
}

.gallery-sheet-modal__meta {
  display: grid;
  gap: 0.5rem;
}

.gallery-sheet-modal__grid {
  width: 100%;
}

.gallery-sheet-modal__grid-inner {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(20rem, 100%), 1fr));
  gap: 0.7rem;
  width: 100%;
}

.gallery-lightbox[hidden] {
  display: none;
}

.gallery-lightbox {
  position: fixed;
  inset: 0;
  z-index: 999;
}

.gallery-lightbox__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(12, 11, 10, 0.76);
  backdrop-filter: blur(12px);
}

.gallery-lightbox__dialog {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 1rem;
  width: min(calc(100% - 2rem), 92rem);
  min-height: 100dvh;
  margin: 0 auto;
  padding: 4.5rem 0 2rem;
}

.gallery-lightbox__figure {
  margin: 0;
  display: grid;
  gap: 1rem;
  align-items: end;
}

.gallery-lightbox__image {
  width: 100%;
  max-height: calc(100dvh - 8rem);
  object-fit: contain;
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.08);
  box-shadow: 0 32px 90px rgba(0, 0, 0, 0.32);
}

.gallery-lightbox__caption {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: end;
  width: min(100%, 54rem);
  padding: 1rem 1.15rem;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-md);
  background: rgba(18, 17, 16, 0.68);
  color: rgba(255, 255, 255, 0.92);
}

.gallery-lightbox__meta {
  display: grid;
  gap: 0.45rem;
}

.gallery-lightbox__caption h2,
.gallery-lightbox__caption p {
  margin: 0;
}

.gallery-lightbox__eyebrow,
.gallery-lightbox__count {
  color: rgba(255, 255, 255, 0.68);
  font-size: 0.76rem;
  font-weight: 650;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.gallery-lightbox__caption h2 {
  font-size: clamp(1.1rem, 2.2vw, 1.55rem);
  line-height: 1;
  letter-spacing: -0.03em;
}

.gallery-lightbox__close,
.gallery-lightbox__nav {
  display: inline-grid;
  place-items: center;
  width: 3.25rem;
  height: 3.25rem;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: var(--radius-sm);
  background: rgba(18, 17, 16, 0.74);
  color: rgba(255, 255, 255, 0.92);
  cursor: pointer;
  transition: transform var(--transition), border-color var(--transition), background var(--transition);
}

.gallery-lightbox__close:hover,
.gallery-lightbox__close:focus-visible,
.gallery-lightbox__nav:hover,
.gallery-lightbox__nav:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(255, 255, 255, 0.34);
  background: rgba(18, 17, 16, 0.9);
}

.gallery-lightbox__close {
  position: absolute;
  top: 1.5rem;
  right: 0;
  font-size: 1.65rem;
  line-height: 1;
}

.has-lightbox-open {
  overflow: hidden;
}

.has-gallery-sheet-open {
  overflow: hidden;
}

.contact-panel {
  grid-template-columns: minmax(0, 1.08fr) minmax(0, 0.92fr);
  gap: clamp(1.75rem, 4vw, 3.4rem);
  width: 100%;
  padding: clamp(1.4rem, 3vw, 2rem);
  border-radius: var(--radius-lg);
  background: linear-gradient(145deg, var(--color-panel-strong), var(--color-panel));
  border: 1px solid var(--color-line);
  box-shadow: var(--shadow-soft);
}

@supports (content-visibility: auto) {
  .gallery-lane,
  .portfolio-entry,
  .project-gallery,
  .project-pagination {
    content-visibility: auto;
  }

  .gallery-lane {
    contain-intrinsic-size: 1px 34rem;
  }

  .portfolio-entry,
  .project-gallery {
    contain-intrinsic-size: 1px 48rem;
  }

  .project-pagination {
    contain-intrinsic-size: 1px 10rem;
  }
}

.contact-panel__content,
.contact-panel__form {
  display: grid;
  gap: 1rem;
}

.contact-panel__content {
  max-width: none;
  gap: 1.3rem;
  padding-right: clamp(0.2rem, 1vw, 0.85rem);
}

.contact-panel__details {
  display: grid;
  gap: 0.75rem;
  margin-top: 0.35rem;
  padding-top: 1rem;
  border-top: 1px solid var(--color-line);
}

.contact-panel__meta-label {
  margin: 0;
  color: var(--color-muted);
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.detail-list--compact {
  gap: 0.55rem;
}

.contact-panel__form {
  align-content: start;
  min-width: 0;
  padding: clamp(1.15rem, 2.8vw, 1.7rem);
  border: 1px solid var(--color-frame-line);
  border-radius: var(--radius-md);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.03));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

.contact-form {
  display: grid;
  gap: 0.9rem;
}

.contact-form__field {
  display: grid;
  gap: 0.35rem;
}

.contact-form label {
  font-size: 0.9rem;
  color: var(--color-muted);
}

.contact-form input,
.contact-form textarea,
.contact-form select {
  width: 100%;
  padding: 0.9rem 1rem;
  border: 1px solid rgba(22, 21, 20, 0.14);
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.06);
  color: var(--color-text);
}

.contact-form__field--hidden {
  position: absolute;
  left: -9999px;
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  width: fit-content;
  padding: 0.95rem 1.4rem;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.08);
  color: var(--color-text);
  cursor: pointer;
  transition: transform var(--transition), background var(--transition), border-color var(--transition);
}

.button:hover,
.button:focus-visible {
  transform: translateY(-1px);
}

.button--primary {
  background: var(--color-accent);
  color: #fff;
}

.contact-form__notice {
  padding: 0.95rem 1rem;
  border-radius: var(--radius-sm);
}

.contact-form__notice--success {
  background: rgba(54, 110, 78, 0.12);
  color: #2f6248;
}

.contact-form__notice--error {
  background: rgba(124, 58, 59, 0.12);
  color: var(--color-accent);
}

.back-link,
.section-link {
  margin: 0;
}

.site-footer {
  padding: 0 0 2.5rem;
}

.site-footer__inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
  gap: 1.5rem;
  padding-top: 2.5rem;
  border-top: 1px solid var(--color-line);
}

.site-footer__meta {
  display: grid;
  justify-items: end;
  align-content: end;
  justify-self: end;
  gap: 0.65rem;
}

.site-footer__group {
  display: grid;
  align-content: start;
}

.site-footer__group--connect {
  gap: 0.8rem;
}

.site-footer__eyebrow {
  margin: 0 0 0.75rem;
  color: var(--color-muted);
  font-size: 0.8rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.site-footer__profiles {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.site-footer__profiles--connect {
  align-items: center;
}

.site-footer__profile-link {
  display: inline-grid;
  place-items: center;
  width: 2.8rem;
  height: 2.8rem;
  border: 1px solid var(--color-line);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.12);
  color: var(--color-text);
  transition: transform var(--transition), border-color var(--transition), background var(--transition);
}

.site-footer__profile-link:hover,
.site-footer__profile-link:focus-visible {
  color: var(--color-text);
  transform: translateY(-1px);
  border-color: var(--color-frame-line-strong);
  background: rgba(255, 255, 255, 0.2);
}

.site-footer__profile-icon svg {
  width: 1.1rem;
  height: 1.1rem;
}

.site-footer__credit {
  margin: 0;
  color: var(--color-muted);
  font-size: 0.9rem;
  text-align: right;
}

.empty-state,
.media-placeholder {
  display: grid;
  place-items: center;
  min-height: 12rem;
  margin: 0;
  padding: 1.5rem;
  border: 1px dashed rgba(22, 21, 20, 0.18);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.04);
  color: var(--color-muted);
  text-align: center;
}

.actor-portfolio-media-preview {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 0.75rem;
}

.actor-portfolio-media-preview img {
  width: 4.5rem;
  height: 4.5rem;
  object-fit: cover;
  border-radius: var(--radius-sm);
}

@media (max-width: 68rem) {
  .work-grid,
  .detail-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

  .site-header__actions {
    gap: 0;
  }

  .menu-toggle {
    display: inline-flex;
  }

  .site-nav {
    display: none;
    grid-column: 1 / -1;
    justify-self: stretch;
    margin-top: 0.25rem;
    padding-top: 0.85rem;
    padding-bottom: 0.25rem;
    border-top: 1px solid var(--color-line);
  }

  .site-header[data-nav-open="true"] .site-nav {
    display: block;
  }

  .site-nav__list {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.85rem;
    padding-top: 0;
  }

  .home-hero,
  .home-feature-band,
  .editorial-layout,
  .feature-media,
  .project-stage,
  .project-gallery__hero,
  .portfolio-entry,
  .resume-stage,
  .resume-layout,
  .contact-panel,
  .error-stage,
  .gallery-lane__header,
  .gallery-lightbox__figure {
    grid-template-columns: 1fr;
  }

  .editorial-layout--about .editorial-layout__aside {
    margin-top: 0;
  }

  .portfolio-grid {
    grid-template-columns: 1fr 1fr;
  }

  .portfolio-card:nth-child(even),
  .home-headshot-card {
    margin-top: 0;
    transform: none;
  }

  .portfolio-entry--reverse .portfolio-entry__media,
  .portfolio-entry--reverse .portfolio-entry__content {
    order: initial;
  }

  .home-hero__frame {
    aspect-ratio: 7 / 6;
  }

  .site-footer__inner {
    grid-template-columns: 1fr 1fr;
  }

  .site-footer__meta {
    justify-self: start;
  }

  .gallery-lightbox__dialog {
    grid-template-columns: 1fr;
    gap: 0.75rem;
    padding-top: 4rem;
  }

  .gallery-lightbox__nav {
    display: none;
  }

  .gallery-lightbox__image {
    max-height: 70dvh;
  }

  .gallery-lightbox__caption {
    width: 100%;
  }

  .gallery-sheet-modal__dialog {
    width: min(calc(100% - 1.5rem), 82rem);
    height: min(calc(100dvh - 1.5rem), 54rem);
    margin: 0;
    padding: 1.15rem;
  }

  .gallery-sheet-modal__grid-inner {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .project-gallery__wall {
    grid-template-columns: repeat(6, minmax(0, 1fr));
  }

  .project-gallery__wall .project-still {
    grid-column: span 3;
  }

  .project-gallery__wall .project-still:nth-child(5n + 2),
  .project-gallery__wall .project-still:nth-child(5n + 5) {
    grid-column: span 6;
  }

  .project-pagination {
    grid-template-columns: 1fr;
  }

  .project-pagination__item--next {
    text-align: left;
    justify-items: start;
  }

  .project-pagination__item--placeholder {
    display: none;
  }
}

@media (max-width: 46rem) {
  .site-header__inner,
  .site-footer__inner,
  .content-section,
  .home-hero,
  .home-feature-band {
    width: min(calc(100% - 1.25rem), var(--site-max));
  }

  .home-hero--full {
    width: min(calc(100% - 1.25rem), var(--site-max));
  }

  .portfolio-grid,
  .work-grid,
  .detail-grid,
  .site-footer__inner {
    grid-template-columns: 1fr;
  }

  .site-footer__meta {
    justify-self: start;
  }

  .portfolio-entry {
    gap: 1.25rem;
  }

  .portfolio-entry__content {
    max-width: none;
  }

  .about-rail__split {
    grid-template-columns: 1fr;
  }

  .home-page {
    gap: 1.45rem;
    overflow-x: clip;
  }

  .home-hero,
  .home-hero--full {
    width: calc(100% - 1.25rem);
    max-width: calc(100vw - 1.25rem);
    overflow-x: clip;
  }

  .home-hero__frame {
    width: 100%;
    max-width: 100%;
    overflow: hidden;
  }

  .home-feature-band {
    gap: 0.9rem;
    margin-top: 0;
  }

  .home-headshot-card {
    width: min(82vw, 19rem);
    justify-self: center;
  }

  .home-headshot-card::before {
    content: none;
  }

  .home-headshot-card__media {
    aspect-ratio: 4 / 4.96;
  }

  .home-bio-panel,
  .home-news-panel {
    min-width: 0;
    padding: 1.1rem 1rem 1.15rem;
  }

  .home-bio-panel__intro,
  .home-news-panel__intro {
    font-size: 0.88rem;
  }

  .section-heading--compact h2 {
    font-size: clamp(1.28rem, 5.8vw, 1.62rem);
    line-height: 1;
    text-wrap: balance;
  }

  .resume-stage {
    gap: 0.9rem;
    justify-items: center;
  }

  .resume-sheet__viewport {
    overflow: hidden;
  }

  .resume-sheet__viewport--embed {
    padding: 0.22rem;
  }

  .resume-sheet__embed {
    width: 100%;
    height: 100%;
    min-height: 100%;
  }

  .resume-sheet__content {
    width: 100%;
    transform: none;
  }

  .resume-doc__name-row {
    align-items: start;
  }

  .resume-doc__contact-line,
  .resume-doc__subfacts {
    justify-content: flex-start;
  }

  .resume-doc__name {
    font-size: clamp(1.9rem, 8vw, 2.3rem);
  }

  .resume-doc__contact-line {
    font-size: 0.86rem;
  }

  .resume-doc__subfacts {
    font-size: 0.88rem;
  }

  .resume-doc__section-title {
    font-size: 0.76rem;
  }

  .resume-credit p {
    font-size: 0.92rem;
    line-height: 1.24;
  }

  .resume-credit__venue {
    font-size: 0.82rem;
  }

  .resume-doc__footnote {
    font-size: 0.56rem;
    line-height: 1.04;
  }

  .resume-doc__training-title {
    font-size: 0.9rem;
  }

  .resume-doc__section--training .resume-doc__training-title {
    font-size: 0.84rem;
    line-height: 1.08;
  }

  .resume-doc__training-copy,
  .resume-doc__training-faculty,
  .resume-doc__skills-copy,
  .resume-doc__list li {
    font-size: 0.82rem;
    line-height: 1.24;
  }

  .resume-doc__section--training .resume-doc__training-copy {
    font-size: 0.76rem;
    line-height: 1.16;
  }

  .resume-doc__section--awards .resume-doc__list li {
    font-size: 0.8rem;
    line-height: 1.16;
  }

  .resume-doc__section--skills .resume-doc__skills-copy {
    font-size: 0.72rem;
    line-height: 1.1;
  }

  .resume-paper__flow {
    display: block;
  }

  .resume-paper__facts {
    font-size: 0.82rem;
    line-height: 1.18;
    text-align: left;
    padding-right: 2rem;
  }

  .resume-paper__meta {
    grid-template-columns: 1fr;
    gap: 0.8rem;
    width: 100%;
    transform: none;
  }

  .resume-paper__meta-column {
    gap: 0.72rem;
  }

  .resume-paper__label {
    font-size: 0.72rem;
  }

  .resume-paper__theatre-row {
    gap: 0.04rem;
  }

  .resume-paper__theatre-grid {
    grid-template-columns: 1fr;
    gap: 0.16rem;
  }

  .resume-paper__theatre-copy {
    font-size: 0.8rem;
    line-height: 1.08;
  }

  .resume-paper__theatre-meta {
    font-size: 0.64rem;
    line-height: 1.08;
  }

  .resume-paper__credits,
  .resume-paper__compact-list,
  .resume-paper__training {
    gap: 0.14rem;
  }

  .resume-paper__credit-title {
    font-size: 0.94rem;
  }

  .resume-paper__credit-role {
    font-size: 0.82rem;
  }

  .resume-paper__credit-venue {
    font-size: 0.68rem;
  }

  .resume-paper__compact-title {
    font-size: 0.84rem;
  }

  .resume-paper__compact-line,
  .resume-paper__training-line,
  .resume-paper__training-copy {
    font-size: 0.74rem;
    line-height: 1.16;
  }

  .resume-paper__note {
    font-size: 0.54rem;
    line-height: 1.02;
    text-align: left;
  }

  .resume-doc {
    grid-template-columns: 1fr;
    gap: 0.22rem;
    width: 100%;
    transform: none;
  }

  .resume-doc > .resume-doc__section--credits:nth-of-type(1),
  .resume-doc > .resume-doc__section--credits:nth-of-type(2),
  .resume-doc > .resume-doc__section--credits:nth-of-type(3),
  .resume-doc > .resume-doc__meta-grid {
    grid-column: auto;
    grid-row: auto;
  }

  .resume-doc__meta-grid {
    grid-template-columns: 1fr;
    gap: 0.18rem;
  }

  .resume-doc__meta-side {
    gap: 0.18rem;
  }

  .resume-doc__skills-list {
    grid-template-columns: 1fr;
    gap: 0.12rem;
  }

  .resume-doc__facts {
    display: grid;
    gap: 0.35rem 0.65rem;
  }

  .resume-doc__fact {
    white-space: normal;
  }

  .project-gallery__wall {
    grid-template-columns: 1fr;
  }

  .project-gallery__wall .project-still,
  .project-gallery__wall .project-still:nth-child(5n + 2),
  .project-gallery__wall .project-still:nth-child(5n + 5) {
    grid-column: span 1;
  }

  .project-still--hero .project-still__media,
  .project-still--supporting .project-still__media,
  .project-gallery__wall .project-still__media,
  .project-gallery__wall .project-still:nth-child(5n + 2) .project-still__media,
  .project-gallery__wall .project-still:nth-child(5n + 5) .project-still__media,
  .project-gallery__wall .project-still:nth-child(5n + 4) .project-still__media {
    aspect-ratio: 4 / 4.9;
    min-height: 0;
  }

  .home-hero__title,
  .page-header__title {
    font-size: clamp(2.75rem, 14vw, 4.6rem);
  }

  .home-hero__frame {
    min-height: 22rem;
    border-radius: var(--radius-lg);
  }

  .home-hero__overlay {
    left: 1rem;
    right: 1rem;
    bottom: 1rem;
    gap: 0.8rem;
    grid-template-columns: 1fr;
  }

  .home-hero__title {
    white-space: normal;
  }

  .resume-doc__facts,
  .resume-credit {
    grid-template-columns: 1fr;
    grid-template-areas:
      "production"
      "role"
      "venue";
    gap: 0.3rem;
  }

  .resume-credit__venue {
    text-align: left;
    align-self: start;
  }

  .resume-doc__footnote {
    text-align: left;
  }

  .gallery-lightbox__dialog {
    width: min(calc(100% - 1rem), 92rem);
    padding-top: 4.25rem;
  }

  .gallery-lightbox__caption {
    grid-template-columns: 1fr;
    padding: 0.95rem;
  }

  .theme-toggle__option,
  .menu-toggle span {
    font-size: 0.68rem;
    letter-spacing: 0.16em;
  }
}

@media (max-width: 68rem) {
  .site-header {
    top: 0;
    padding-inline: 0;
  }

  .site-header__inner {
    padding: 0.9rem 0;
  }

  .home-hero__controls {
    bottom: 1rem;
  }

  .about-image-rail {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .about-image-rail__item,
  .about-image-rail__item--1,
  .about-image-rail__item--4 {
    grid-column: span 1;
  }

  .gallery-collection-card__trigger {
    grid-template-columns: 1fr;
    gap: 0;
  }

  .gallery-collection-card__body {
    padding: 1rem;
  }

  .gallery-collection-card__cover-image {
    aspect-ratio: 16 / 9.4;
  }
}

@media (max-width: 46rem) {
  .site-title-text {
    font-size: 1.08rem;
    letter-spacing: 0.03em;
  }

  .site-nav__list a {
    font-size: 0.76rem;
  }

  .home-hero__tagline {
    justify-self: start;
    max-width: 18rem;
    text-align: left;
    white-space: normal;
  }

  .home-hero__controls {
    right: 0.8rem;
    gap: 0.55rem;
  }

  .home-hero__control {
    width: 2.55rem;
    height: 2.55rem;
  }

  .home-headshot-card {
    width: min(86vw, 22rem);
    justify-self: center;
  }

  .home-statement-band {
    width: calc(100% - 1.25rem);
  }

  .home-statement-band__copy {
    font-size: 1.04rem;
  }

  .resume-primary-cluster {
    grid-template-columns: 1fr;
    width: min(100%, 24rem);
  }

  .resume-side-stack {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    width: 100%;
  }

  .resume-side-stack__trigger {
    height: auto;
  }

  .resume-side-stack__image {
    height: auto;
    aspect-ratio: 4 / 5;
  }

  .resume-primary,
  .resume-sheet {
    width: min(100%, 24rem);
    min-height: 0;
    overflow: hidden;
  }

  .resume-sheet {
    aspect-ratio: 17 / 22;
  }

  .resume-download-button {
    top: 0.75rem;
    right: 0.75rem;
    width: 2.7rem;
    height: 2.7rem;
  }

  .gallery-sheet-modal__dialog {
    width: min(calc(100% - 1rem), 92rem);
    max-height: calc(100dvh - 1rem);
    height: min(calc(100dvh - 1rem), 52rem);
    margin: 0;
    padding: 1rem;
  }

  .gallery-sheet-modal__header {
    padding-right: 3.1rem;
  }

  .gallery-sheet-modal__grid-inner {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .gallery-card__media--sheet {
    aspect-ratio: 4 / 5.1;
  }
}
