    :root {
      --font-sans: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
      --max-width: 1120px;
      --radius: 8px;
      --ease-out: cubic-bezier(.2, .8, .2, 1);
    }

    html[data-theme="light"] {
      --bg: #f7f5f2;
      --bg-elevated: #ffffff;
      --bg-muted: #efeeeb;
      --text: #111111;
      --text-muted: #68686d;
      --line: rgba(17, 17, 17, .11);
      --line-strong: rgba(17, 17, 17, .2);
      --accent: #e53935;
      --accent-strong: #b71c1c;
      --accent-soft: rgba(229, 57, 53, .1);
    }

    html[data-theme="dark"] {
      --bg: #101010;
      --bg-elevated: #1b1b1d;
      --bg-muted: #242426;
      --text: #f5f5f7;
      --text-muted: #b8b8bf;
      --line: rgba(255, 255, 255, .12);
      --line-strong: rgba(255, 255, 255, .24);
      --accent: #ff453a;
      --accent-strong: #ff6b61;
      --accent-soft: rgba(255, 69, 58, .13);
    }

    * {
      box-sizing: border-box;
    }

    html {
      width: 100%;
      max-width: 100%;
      overflow-x: hidden;
      scroll-behavior: smooth;
      background: var(--bg);
      color: var(--text);
    }

    body {
      width: 100%;
      max-width: 100%;
      min-width: 0;
      margin: 0;
      overflow-x: hidden;
      font-family: var(--font-sans);
      line-height: 1.5;
      background:
        radial-gradient(circle at 8% 4%, color-mix(in srgb, var(--accent), transparent 80%), transparent 22rem),
        radial-gradient(circle at 92% 7%, color-mix(in srgb, var(--accent-strong), transparent 84%), transparent 24rem),
        var(--bg);
      color: var(--text);
    }

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

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

    button {
      font: inherit;
    }

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

    .skip-link {
      position: fixed;
      left: 1rem;
      top: 1rem;
      z-index: 200;
      transform: translateY(-150%);
      border-radius: var(--radius);
      background: var(--text);
      color: var(--bg);
      padding: .75rem 1rem;
      transition: transform .2s ease;
    }

    .skip-link:focus {
      transform: translateY(0);
    }

    .site-header {
      position: sticky;
      top: 0;
      z-index: 100;
      border-bottom: 1px solid var(--line);
      background: color-mix(in srgb, var(--bg-elevated), transparent 16%);
      backdrop-filter: blur(22px) saturate(1.35);
    }

    .nav-shell {
      width: min(100% - 2rem, var(--max-width));
      min-height: 74px;
      margin: 0 auto;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 1rem;
    }

    .brand {
      display: inline-flex;
      align-items: center;
      color: var(--text);
      font-size: 1rem;
      font-weight: 850;
      letter-spacing: 0;
      white-space: nowrap;
    }

    .nav-actions {
      display: flex;
      align-items: center;
      gap: .35rem;
    }

    .nav-link {
      min-height: 38px;
      display: inline-flex;
      align-items: center;
      border-radius: 999px;
      color: var(--text-muted);
      font-size: .9rem;
      font-weight: 780;
      padding: .52rem .9rem;
      transition: color .2s ease, background .2s ease, transform .2s ease;
    }

    .nav-link:hover,
    .nav-link:focus-visible {
      background: var(--bg-muted);
      color: var(--text);
      outline: none;
      transform: translateY(-1px);
    }

    main {
      width: min(100% - 2rem, var(--max-width));
      margin: 0 auto;
      padding: clamp(3rem, 8vw, 6.5rem) 0 4rem;
    }

    .hero {
      display: grid;
      grid-template-columns: minmax(0, .78fr) minmax(260px, .32fr);
      gap: clamp(1.5rem, 4vw, 3rem);
      align-items: end;
      padding-bottom: clamp(4rem, 9vw, 7rem);
    }

    .eyebrow {
      display: inline-flex;
      align-items: center;
      gap: .55rem;
      margin: 0;
      color: var(--accent);
      font-size: .82rem;
      font-weight: 850;
      letter-spacing: .08em;
      text-transform: uppercase;
    }

    h1,
    p {
      margin-top: 0;
    }

    h1 {
      max-width: 9ch;
      margin-bottom: 0;
      font-size: clamp(4rem, 13vw, 8rem);
      line-height: .9;
      letter-spacing: 0;
      text-transform: lowercase;
    }

    .hero-copy {
      max-width: 62ch;
      margin-bottom: 0;
      color: var(--text-muted);
      font-size: clamp(1.04rem, 2vw, 1.22rem);
    }

    .photo-grid {
      columns: 3 260px;
      column-gap: 1rem;
    }

    .photo-grid.is-arranged {
      position: relative;
      columns: auto;
    }

    .photo-grid.is-arranged.columns-1 .photo-card {
      width: 100%;
    }

    .photo-grid.is-arranged.columns-2 .photo-card {
      width: calc((100% - 1rem) / 2);
    }

    .photo-grid.is-arranged.columns-3 .photo-card {
      width: calc((100% - 2rem) / 3);
    }

    .photo-card {
      min-width: 0;
      width: 100%;
      display: inline-block;
      break-inside: avoid;
      overflow: hidden;
      margin: 0 0 1rem;
      border: 2px solid #050505;
      border-radius: var(--radius);
      background: transparent;
      cursor: zoom-in;
      transition: transform .22s var(--ease-out), border-color .2s ease, box-shadow .2s ease;
    }

    .photo-grid.is-arranged .photo-card {
      position: absolute;
      left: 0;
      top: 0;
      margin: 0;
    }

    .photo-card:hover,
    .photo-card:focus-visible {
      border-color: var(--line-strong);
      box-shadow: 0 18px 48px rgba(0, 0, 0, .12);
      outline: none;
      transform: translateY(-3px);
    }

    .photo-frame {
      overflow: hidden;
      border-radius: calc(var(--radius) - 2px);
      background: transparent;
    }

    .photo-frame img {
      width: 100%;
      height: auto;
    }

    .site-footer {
      width: min(100% - 2rem, var(--max-width));
      margin: 0 auto;
      display: flex;
      justify-content: space-between;
      gap: 1rem;
      border-top: 1px solid var(--line);
      padding: 1.5rem 0 2rem;
      color: var(--text-muted);
      font-size: .9rem;
    }

    .photo-lightbox {
      position: fixed;
      inset: 0;
      z-index: 300;
      display: grid;
      place-items: center;
      background: rgba(0, 0, 0, .86);
      cursor: zoom-out;
      padding: clamp(1rem, 4vw, 2rem);
    }

    .photo-lightbox-content {
      width: min(100%, 1480px);
      max-height: calc(100vh - 4rem);
      display: flex;
      align-items: center;
      justify-content: center;
    }

    .photo-lightbox-media {
      min-width: 0;
      max-width: 100%;
      max-height: calc(100vh - 4rem);
      display: grid;
      place-items: center;
    }

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

    .photo-lightbox-close {
      position: fixed;
      top: clamp(1rem, 3vw, 1.6rem);
      left: clamp(1rem, 3vw, 1.6rem);
      width: 44px;
      height: 44px;
      display: grid;
      place-items: center;
      border: 1px solid rgba(255, 255, 255, .24);
      border-radius: 999px;
      background: rgba(0, 0, 0, .52);
      color: #ffffff;
      cursor: pointer;
      font-size: 1.35rem;
      line-height: 1;
      transition: transform .2s ease, background .2s ease, border-color .2s ease;
    }

    .photo-lightbox-close:hover,
    .photo-lightbox-close:focus-visible {
      border-color: rgba(255, 255, 255, .5);
      background: rgba(229, 57, 53, .78);
      outline: none;
      transform: translateY(-1px);
    }

    .photo-lightbox-media img {
      max-width: min(100%, 1180px);
      max-height: calc(100vh - 4rem);
      border: 1px solid rgba(255, 255, 255, .18);
      border-radius: var(--radius);
      background: #050505;
      box-shadow: 0 28px 90px rgba(0, 0, 0, .5);
      object-fit: contain;
    }

    .photo-lightbox-details {
      display: none;
    }

    .photo-detail {
      margin: 0;
    }

    body.is-lightbox-open {
      overflow: hidden;
    }

    @media (prefers-reduced-motion: no-preference) {
      .hero > * {
        opacity: 0;
        transform: translateY(20px);
        animation: photo-rise .72s var(--ease-out) both;
      }

      .hero > *:nth-child(2) {
        animation-delay: .12s;
      }

      .js .photo-card {
        opacity: 0;
      }

      .js .photo-grid.is-ready .photo-card {
        animation: photo-fade-in .72s var(--ease-out) both;
        animation-delay: calc(.16s + var(--i, 0) * 72ms);
      }

      .photo-lightbox:not([hidden]) img {
        animation: photo-open .22s var(--ease-out) both;
      }
    }

    @keyframes photo-rise {
      from {
        opacity: 0;
        transform: translateY(26px);
      }

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

    @keyframes photo-open {
      from {
        opacity: 0;
        transform: scale(.985);
      }

      to {
        opacity: 1;
        transform: scale(1);
      }
    }

    @keyframes photo-fade-in {
      from {
        opacity: 0;
      }

      to {
        opacity: 1;
      }
    }

    @media (prefers-reduced-motion: reduce) {
      .js .photo-card {
        opacity: 1;
      }
    }

    @media (max-width: 900px) {
      .hero {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }
    }

    @media (min-width: 960px) {
      .photo-lightbox-content {
        --detail-gap: clamp(4.75rem, 7vw, 7.5rem);
        gap: var(--detail-gap);
        padding-left: min(12vw, 9rem);
      }

      .photo-lightbox-media {
        flex: 0 1 auto;
        max-width: calc(100% - 19rem - var(--detail-gap));
      }

      .photo-lightbox-details {
        position: relative;
        width: 19rem;
        flex: 0 0 19rem;
        display: grid;
        gap: 1.15rem;
        align-self: center;
        padding: 1.35rem 0 1.35rem 1.25rem;
        color: #ffffff;
      }

      .photo-lightbox-details::before {
        content: "";
        position: absolute;
        top: 0;
        right: 100%;
        width: var(--detail-gap);
        height: 1px;
        background: rgba(255, 255, 255, .72);
        transform: scaleX(0);
        transform-origin: left;
      }

      .photo-lightbox-details::after {
        content: "";
        position: absolute;
        top: 0;
        left: -1px;
        width: 1px;
        height: 100%;
        background: rgba(255, 255, 255, .72);
        transform: scaleY(0);
        transform-origin: top;
      }

      .photo-detail {
        display: grid;
        gap: .12rem;
        opacity: 0;
        transform: translateY(-12px);
      }

      .photo-detail-label {
        color: rgba(255, 255, 255, .58);
        font-size: .68rem;
        font-weight: 850;
        letter-spacing: .08em;
        text-transform: uppercase;
      }

      .photo-detail-value {
        max-width: 24ch;
        color: #ffffff;
        font-size: .98rem;
        font-weight: 720;
        line-height: 1.35;
      }

      .photo-detail-subject .photo-detail-value {
        font-size: clamp(1.15rem, 1.8vw, 1.5rem);
        font-weight: 820;
      }

      .photo-detail-tag {
        width: max-content;
        margin-top: .35rem;
        border: 1px solid rgba(255, 255, 255, .34);
        border-radius: 999px;
        padding: .2rem .5rem;
        color: rgba(255, 255, 255, .82);
        font-size: .68rem;
        font-weight: 800;
        letter-spacing: .06em;
        line-height: 1;
        text-transform: uppercase;
      }

      .photo-detail-tag[hidden] {
        display: none;
      }

      @media (prefers-reduced-motion: no-preference) {
        .photo-lightbox-content.is-annotated .photo-lightbox-details::before {
          animation: detail-line-out .38s .18s var(--ease-out) both;
        }

        .photo-lightbox-content.is-annotated .photo-lightbox-details::after {
          animation: detail-line-down .42s .56s var(--ease-out) both;
        }

        .photo-lightbox-content.is-annotated .photo-detail {
          animation: detail-text-down .42s var(--ease-out) both;
        }

        .photo-lightbox-content.is-annotated .photo-detail:nth-child(1) {
          animation-delay: .58s;
        }

        .photo-lightbox-content.is-annotated .photo-detail:nth-child(2) {
          animation-delay: .7s;
        }

        .photo-lightbox-content.is-annotated .photo-detail:nth-child(3) {
          animation-delay: .82s;
        }
      }

      @media (prefers-reduced-motion: reduce) {
        .photo-lightbox-details::before,
        .photo-lightbox-details::after {
          transform: none;
        }

        .photo-detail {
          opacity: 1;
          transform: none;
        }
      }
    }

    @keyframes detail-line-out {
      from {
        transform: scaleX(0);
      }

      to {
        transform: scaleX(1);
      }
    }

    @keyframes detail-line-down {
      from {
        transform: scaleY(0);
      }

      to {
        transform: scaleY(1);
      }
    }

    @keyframes detail-text-down {
      from {
        opacity: 0;
        transform: translateY(-12px);
      }

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

    @media (max-width: 620px) {
      .nav-shell,
      main,
      .site-footer {
        width: min(100% - 1.25rem, var(--max-width));
      }

      .nav-shell {
        min-height: auto;
        flex-wrap: wrap;
        padding: .75rem 0;
      }

      .nav-actions {
        width: 100%;
        flex-wrap: wrap;
        justify-content: flex-start;
      }

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

      .site-footer {
        flex-direction: column;
      }
    }
