:root {
  --paper: #f8f7f3;
  --ink: #151515;
  --muted: #666666;
  --line: rgba(21, 21, 21, 0.18);
  --panel: #fcfbf8;
  --accent: #f10545;
  --red: #ed0706;
  --sky: #3596ee;
  --blue: #2155bc;
  --serif: "Noto Serif", Georgia, "Times New Roman", serif;
  --sans: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont,
    "Segoe UI", sans-serif;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--serif);
  font-size: 15px;
  line-height: 1.45;
}

img,
video {
  display: block;
  width: 100%;
  height: auto;
}

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

button {
  border: 0;
  padding: 0;
  background: transparent;
  color: inherit;
  font: inherit;
}

p,
h1,
h2,
h3,
h4,
dl {
  margin: 0;
}

.site-shell {
  display: grid;
  grid-template-columns: minmax(250px, 1fr) minmax(0, 3fr);
  min-height: 100vh;
}

.profile-column {
  position: sticky;
  top: 0;
  align-self: start;
  height: 100vh;
  min-height: 100vh;
  overflow-y: auto;
  scrollbar-width: none;
  padding: 28px 26px;
  background: var(--paper);
}

.profile-column::-webkit-scrollbar {
  display: none;
}

.wordmark,
.site-nav a,
.sidebar-section h2,
.contact-mini a,
.button-link,
.eyebrow,
.case-number,
.year-label,
.meta-line {
  font-family: var(--sans);
  letter-spacing: 0;
}

.wordmark {
  display: inline-block;
  margin-bottom: 22px;
  font-size: 16px;
  font-weight: 700;
  text-transform: uppercase;
  text-decoration-color: var(--accent);
}

.profile-kicker {
  margin-bottom: 4px;
  color: var(--muted);
  font-family: var(--serif);
  text-transform: none;
}

.profile-location {
  display: block;
  margin-bottom: 14px;
  color: var(--muted);
  cursor: pointer;
  text-align: left;
  transition: color 180ms ease;
}

.profile-location:hover,
.profile-location:focus-visible {
  color: var(--accent);
}

.profile-statement {
  max-width: 28ch;
  font-size: 21px;
  line-height: 1.12;
}

.hero h1,
.section-heading h2,
.about-section h2,
.skills-section h2,
.contact-section h2,
.case-header h3,
.selected-work h3,
.skills-grid h3 {
  font-family: var(--sans);
}

.site-nav {
  display: grid;
  gap: 8px;
  margin: 26px 0 0;
}

.site-nav a {
  width: max-content;
  font-size: 14px;
  text-transform: uppercase;
  transition:
    color 180ms ease,
    transform 180ms ease;
}

.site-nav a.is-active {
  color: var(--accent);
  transform: translateX(6px);
}

.sidebar-section {
  margin-top: 22px;
  padding-top: 10px;
}

.sidebar-section h2 {
  margin-bottom: 14px;
  font-size: 14px;
  font-weight: 700;
  text-transform: uppercase;
}

.sidebar-section ul {
  display: grid;
  gap: 4px;
  padding: 0;
  margin: 0;
  list-style: none;
}

.sidebar-section p,
.sidebar-section li {
  color: #2c2925;
  font-size: 14px;
  line-height: 1.25;
}

.sidebar-section li[data-focus] {
  width: max-content;
  cursor: default;
}

.contact-mini {
  display: grid;
  gap: 4px;
  margin-top: 22px;
  padding-top: 10px;
}

.contact-mini h2 {
  margin-bottom: 4px;
}

.contact-mini a {
  max-width: 100%;
  font-family: var(--serif);
  overflow-wrap: anywhere;
  font-size: 14px;
  transition: color 180ms ease;
}

.contact-mini a:hover,
.contact-mini a:focus-visible,
.contact-mini a:active {
  color: var(--accent);
}

.email-row {
  position: relative;
  display: inline-flex;
  align-items: baseline;
  gap: 6px 10px;
  max-width: 100%;
  text-transform: none;
}

.email-trigger {
  color: #2c2925;
  font-family: var(--serif);
  font-size: 14px;
}

.email-trigger {
  max-width: min(46vw, 220px);
  overflow-wrap: anywhere;
  transition: color 180ms ease;
}

.copy-email {
  opacity: 0;
  pointer-events: none;
  transform: translateY(4px);
  transition:
    opacity 180ms ease,
    transform 180ms ease,
    color 180ms ease;
}

.email-row:hover .email-trigger,
.email-row:focus-within .email-trigger,
.email-row.is-revealed .email-trigger {
  color: var(--accent);
}

.email-row:hover .copy-email,
.email-row:focus-within .copy-email,
.email-row.is-revealed .copy-email {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

.copy-email {
  position: relative;
  width: 17px;
  height: 17px;
  color: var(--accent);
  cursor: pointer;
  vertical-align: -3px;
}

.copy-email span,
.copy-email::before {
  position: absolute;
  width: 10px;
  height: 12px;
  border: 1.5px solid currentColor;
  content: "";
}

.copy-email span {
  top: 1px;
  left: 5px;
}

.copy-email::before {
  top: 4px;
  left: 1px;
  background: var(--paper);
}

.copy-email::after {
  position: absolute;
  inset: -5px;
  content: "";
}

.copy-email:hover,
.copy-email:focus-visible {
  color: var(--ink);
}

.copy-email.is-copied {
  color: var(--blue);
}

.work-columns {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
  align-content: start;
  padding: 24px;
}

.panel-wide {
  grid-column: 1 / -1;
}

.span-two {
  grid-column: span 2;
}

.hero {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(260px, 0.9fr);
  gap: 24px;
  min-height: 44vh;
  padding: 18px 0 26px;
}

.eyebrow {
  margin-bottom: 14px;
  color: var(--muted);
  font-size: 13px;
  text-transform: uppercase;
}

.hero h1 {
  max-width: 14ch;
  font-size: clamp(44px, 6.3vw, 92px);
  font-weight: 500;
  line-height: 0.96;
}

.hero-copy {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 18px;
  max-width: 44ch;
  color: #282522;
  font-size: 18px;
}

.cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.button-link {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
  padding: 10px 14px;
  background: var(--accent);
  color: var(--paper);
  font-size: 14px;
  text-decoration: none;
  text-transform: uppercase;
}

.button-link.secondary {
  background: transparent;
  color: var(--ink);
}

.section-heading {
  display: grid;
  grid-column: 1 / 2;
  gap: 10px;
  padding-top: 4px;
}

.section-heading h2,
.about-section h2,
.skills-section h2,
.contact-section h2 {
  max-width: 24ch;
  font-size: clamp(27px, 3.2vw, 46px);
  font-weight: 500;
  line-height: 1.02;
}

.section-heading h2 {
  font-weight: 400;
}

.about-section h2 {
  font-weight: 400;
}

.case-study,
.selected-work {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: minmax(220px, 0.92fr) minmax(0, 1.04fr) minmax(0, 1.04fr);
  gap: 20px;
  align-items: start;
  padding-top: 8px;
}

.selected-work + .selected-work {
  margin-top: 88px;
}

.selected-work.text-only .selected-copy {
  grid-column: 1 / -1;
  max-width: 52ch;
}

.case-study {
  margin-bottom: 88px;
  transition:
    opacity 180ms ease,
    transform 180ms ease,
    filter 180ms ease;
}

.case-copy,
.selected-copy {
  grid-column: 1 / 2;
  display: grid;
  gap: 12px;
  align-content: start;
}

.case-more {
  display: grid;
  gap: 12px;
}

.case-more[hidden] {
  display: none;
}

.case-more.is-entering > * {
  animation: caseMoreFadeIn 480ms ease both;
}

.case-media-more.is-entering {
  animation: caseMoreFadeIn 480ms ease both;
}

.case-media-more[hidden] {
  display: none !important;
}

.brand-social-videos {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

#mcdecaux-brand .brand-social-videos video {
  width: 100%;
  aspect-ratio: 9 / 16;
  object-fit: cover;
  background: transparent;
}

@keyframes caseMoreFadeIn {
  from {
    opacity: 0;
    transform: translateY(8px);
  }

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

.case-header {
  display: grid;
  gap: 10px;
}

.case-pretitle {
  margin-bottom: 18px;
  color: var(--muted);
  font-family: var(--sans);
  font-size: 14px;
  letter-spacing: 0;
  text-transform: uppercase;
}

.case-number {
  color: var(--accent);
  font-size: 14px;
}

.case-header h3 {
  max-width: 16ch;
  font-size: clamp(27px, 3vw, 44px);
  font-weight: 400;
  line-height: 1.02;
}

.case-header p:not(.case-number) {
  max-width: 52ch;
  color: #312d29;
}

.see-more-button {
  width: 26px;
  height: 26px;
  padding: 0;
  color: var(--accent);
  line-height: 1;
  cursor: pointer;
  transition: color 180ms ease;
}

.see-more-button span {
  display: inline-block;
  width: 15.6px;
  height: 18px;
  background: currentColor;
  clip-path: polygon(0 0, 100% 50%, 0 100%);
  transition: transform 180ms ease;
}

.see-more-button:hover,
.see-more-button:focus-visible {
  color: var(--ink);
}

.see-more-button[aria-expanded="true"] span {
  transform: rotate(90deg);
}

.media-stack,
.media-grid,
.selected-media {
  grid-column: 2 / 4;
  display: grid;
  gap: 10px;
}

.gallery-trigger {
  cursor: pointer;
}

.gallery-trigger:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 6px;
}

.media-stack img,
.media-stack video,
.media-grid img,
.selected-media img,
.selected-media video,
.selected-work img {
  aspect-ratio: 4 / 3;
  object-fit: cover;
  background: transparent;
}

.media-stack {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

#mcdecaux-brand .media-stack {
  margin-top: 34px;
}

#seminar-campaign {
  column-gap: 20px;
  row-gap: 18px;
}

#seminar-campaign .seminar-preview {
  grid-column: 2 / 4;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  column-gap: 10px;
  align-items: start;
}

#seminar-campaign .seminar-preview img,
#seminar-campaign .seminar-preview video {
  aspect-ratio: auto;
  object-fit: contain;
}

#seminar-campaign .seminar-preview-stack {
  display: grid;
  gap: 0;
}

#seminar-campaign .seminar-case-more {
  grid-column: 1 / -1;
  display: grid;
  gap: 24px;
  margin-top: calc(-1 * var(--seminar-more-pull, 0px));
}

#seminar-campaign .seminar-case-more[hidden] {
  display: none;
}

#seminar-campaign .seminar-block {
  display: grid;
  grid-template-columns: minmax(220px, 0.92fr) minmax(0, 1.04fr) minmax(0, 1.04fr);
  gap: 20px;
  align-items: start;
}

#seminar-campaign .seminar-block + .seminar-block {
  padding-top: 24px;
  border-top: 1px solid rgba(21, 21, 21, 0.24);
}

#seminar-campaign .seminar-copy {
  grid-column: 1 / 2;
}

#seminar-campaign .seminar-media {
  grid-column: 2 / 4;
  display: grid;
  gap: 10px;
}

#seminar-campaign .seminar-block:first-child .seminar-media {
  padding-top: var(--seminar-more-pull, 0px);
}

#seminar-campaign .seminar-media-2024 {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
}

#seminar-campaign .seminar-media img,
#seminar-campaign .seminar-media video {
  aspect-ratio: auto;
  object-fit: contain;
}

#seminar-campaign .seminar-media .seminar-2025-media {
  grid-column: auto;
  aspect-ratio: 4 / 3;
  object-fit: cover;
}

#seminar-campaign .seminar-2025-group {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

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

.selected-media {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.selected-media img:only-child,
.selected-media video:only-child {
  grid-column: 1 / -1;
}

.selected-media img.selected-thumb-wide,
.selected-media video.selected-thumb-wide {
  aspect-ratio: 16 / 9;
  background: transparent;
}

.media-grid img:first-child {
  grid-row: span 2;
  aspect-ratio: 3 / 4;
}

.case-details {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px 14px;
}

.case-details.compact {
  grid-template-columns: 1fr;
}

.case-details div {
  padding-top: 6px;
}

.case-details dt {
  margin-bottom: 6px;
  color: var(--muted);
  font-family: var(--sans);
  font-size: 12px;
  text-transform: uppercase;
}

.case-details dd {
  margin: 0;
  color: #282522;
}

.detail-list {
  margin: 10px 0 0;
  padding-left: 18px;
  color: #282522;
}

.detail-list li + li {
  margin-top: 8px;
}

.timeline-split {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin: 6px 0 0;
}

.timeline-split section {
  padding: 0;
  background: transparent;
}

.timeline-split section + section {
  position: relative;
  padding-top: 24px;
}

#seminar-campaign .timeline-split section + section::before {
  position: absolute;
  top: 0;
  left: 0;
  width: calc(326% + 40px);
  height: 1px;
  background: rgba(21, 21, 21, 0.24);
  content: "";
}

.year-label {
  margin-bottom: 10px;
  color: var(--accent);
  font-size: 13px;
}

.timeline-split h4 {
  font-family: var(--sans);
  margin-bottom: 12px;
  font-size: 18px;
  font-weight: 600;
}

.timeline-split p:not(.year-label) {
  margin-top: 10px;
  color: #2f2b27;
}

.atmospheric {
  background:
    linear-gradient(rgba(238, 238, 238, 0.9), rgba(238, 238, 238, 0.9)),
    linear-gradient(135deg, var(--accent), var(--sky), var(--red));
}

.gallery-overlay {
  position: fixed;
  inset: 0;
  z-index: 40;
  display: grid;
  place-items: center;
  padding: 24px;
}

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

.gallery-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(19, 19, 19, 0.68);
  cursor: pointer;
}

.gallery-panel {
  position: relative;
  z-index: 1;
  width: min(1120px, calc(100vw - 48px));
  max-height: calc(100vh - 48px);
  overflow-y: auto;
  padding: 20px;
  background: rgba(252, 251, 248, 0.98);
}

.gallery-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
}

.gallery-title {
  font-family: var(--sans);
  font-size: 14px;
  color: var(--muted);
}

.gallery-close {
  width: 28px;
  height: 28px;
  color: var(--muted);
  font-family: var(--sans);
  font-size: 26px;
  line-height: 1;
  cursor: pointer;
  transition: color 180ms ease;
}

.gallery-close:hover,
.gallery-close:focus-visible {
  color: var(--accent);
}

.gallery-grid-view {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.gallery-item {
  margin: 0;
  grid-column: 1 / -1;
}

.gallery-item.is-half {
  grid-column: span 1;
}

.gallery-video-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.gallery-item img {
  width: 100%;
  height: auto;
  background: transparent;
}

.gallery-item video {
  display: block;
  width: 100%;
  height: auto;
  background: transparent;
}

.selected-work h3 {
  font-size: 20px;
  font-weight: 600;
  line-height: 1.1;
}

.selected-work p {
  color: #312d29;
}

.meta-line {
  color: var(--muted);
  font-size: 12px;
}

.about-section,
.skills-section,
.contact-section {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 1fr);
  gap: 20px;
  padding: 24px 0;
}

.about-copy,
.skills-grid p,
.contact-section h2 {
  color: #2d2925;
}

.about-copy {
  padding-top: 32px;
}

.about-copy p + p {
  margin-top: 16px;
}

.skills-section {
  grid-template-columns: 1fr;
  gap: 0;
}

.skills-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.skills-grid div {
  padding-top: 0;
}

.skills-grid h3 {
  margin-bottom: 10px;
  font-size: 17px;
}

.contact-links {
  display: flex;
  flex-direction: column;
  justify-content: end;
  gap: 10px;
  font-size: 18px;
}

.contact-links a {
  font-family: var(--serif);
  font-size: 14px;
  transition: color 180ms ease;
}

.contact-links a:hover,
.contact-links a:focus-visible,
.contact-links a:active {
  color: var(--accent);
}

@media (max-width: 1080px) {
  .site-shell {
    grid-template-columns: 1fr;
  }

  .profile-column {
    position: relative;
    height: auto;
    min-height: auto;
    overflow-y: visible;
  }

  .profile-statement {
    max-width: 34ch;
  }

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

  .span-two,
  .panel-wide {
    grid-column: 1 / -1;
  }

  .case-study,
  .selected-work {
    grid-template-columns: 1fr;
  }

  .case-study {
    margin-bottom: 44px;
  }

  .selected-work + .selected-work {
    margin-top: 44px;
  }

  .case-copy,
  .selected-copy,
  .media-stack,
  .media-grid,
  .brand-social-videos,
  #seminar-campaign .seminar-preview,
  .selected-media,
  .section-heading {
    grid-column: 1 / -1;
  }

  .about-section > p {
    padding-top: 0;
  }

  #seminar-campaign .timeline-split section + section::before {
    width: 100%;
  }

  #seminar-campaign .seminar-block {
    grid-template-columns: 1fr;
  }

  #seminar-campaign .seminar-copy,
  #seminar-campaign .seminar-media,
  #seminar-campaign .seminar-2025-media,
  #seminar-campaign .seminar-2025-group {
    grid-column: 1 / -1;
  }

  #seminar-campaign .seminar-case-more {
    margin-top: 0;
  }

  #seminar-campaign .seminar-block:first-child .seminar-media {
    padding-top: 0;
  }
}

@media (max-width: 760px) {
  body {
    font-size: 14px;
  }

  .profile-column,
  .work-columns {
    padding: 20px;
  }

  .work-columns,
  .hero,
  .section-heading,
  .about-section,
  .contact-section,
  .skills-grid,
  .case-details,
  .timeline-split,
  .span-two .media-stack,
  #bubble-tea .media-stack,
  #seminar-campaign .seminar-2025-group,
  .media-grid,
  .brand-social-videos,
  .selected-media {
    grid-template-columns: 1fr;
  }

  .hero {
    min-height: auto;
  }

  .hero h1 {
    max-width: 12ch;
    font-size: 46px;
  }

  .hero-copy {
    font-size: 16px;
  }

  .gallery-overlay {
    padding: 14px;
  }

  .gallery-panel {
    width: min(100vw - 28px, 960px);
    max-height: calc(100vh - 28px);
    padding: 16px;
  }

  .gallery-grid-view {
    grid-template-columns: 1fr;
  }

  .gallery-item,
  .gallery-item.is-half {
    grid-column: 1 / -1;
  }

  .gallery-video-row {
    grid-template-columns: 1fr;
  }

  .media-grid img:first-child {
    grid-row: auto;
  }
}
