:root {
  --ink: #12120f;
  --paper: #e4e0d8;
  --stone: #bcb6ab;
  --sand: #cfcbc2;
  --line: rgba(18, 18, 15, .24);
  --white-line: rgba(228, 224, 216, .28);
  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans: 'Manrope', Arial, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: auto; background: var(--ink); }
body { margin: 0; overflow-x: hidden; background: var(--paper); color: var(--ink); font-family: var(--sans); }
body::selection { background: var(--ink); color: var(--paper); }
body.lightbox-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
button { font: inherit; }
img { display: block; width: 100%; max-width: 100%; }
.eyebrow { margin: 0; font-size: 10px; font-weight: 800; letter-spacing: .13em; line-height: 1.2; text-transform: uppercase; }

.loader { position: fixed; z-index: 100; inset: 0; display: grid; padding: 27px 3.1vw; background: var(--ink); color: var(--paper); grid-template: auto 1fr auto / 1fr; opacity: 0; pointer-events: none; visibility: hidden; }
.js.is-loading .loader { opacity: 1; pointer-events: auto; visibility: visible; }
.loader-top { display: flex; justify-content: space-between; font-size: 10px; font-weight: 700; letter-spacing: .11em; text-transform: uppercase; }
.loader-top > span:first-child { font-size: 12px; letter-spacing: -.04em; text-transform: none; }
.loader-bar { align-self: center; width: 100%; height: 1px; overflow: hidden; background: rgba(228,224,216,.25); }.loader-bar i { display: block; width: 100%; height: 100%; background: var(--paper); transform: scaleX(0); transform-origin: left; }
.loader > p { margin: 0; font: italic clamp(33px, 5vw, 76px)/.8 var(--serif); letter-spacing: -.045em; }

.transition-curtain { position: fixed; z-index: 80; inset: 0; display: grid; background: var(--ink); color: var(--paper); place-items: center; pointer-events: none; transform: scaleY(0); transform-origin: bottom; }.transition-curtain span { font: italic clamp(50px, 9vw, 140px)/.75 var(--serif); letter-spacing: -.075em; }
.cursor { display: none; }
.scroll-meter { position: fixed; z-index: 55; top: 0; left: 0; width: 100%; height: 3px; background: rgba(255,255,255,.17); mix-blend-mode: difference; }.scroll-meter i { display: block; width: 100%; height: 100%; background: #fff; transform: scaleX(0); transform-origin: left; }

.site-header { position: fixed; z-index: 50; top: 0; left: 0; display: grid; width: 100%; padding: 24px 3.1vw; color: var(--paper); grid-template-columns: 1fr auto 1fr; pointer-events: none; text-shadow: 0 1px 16px rgba(0,0,0,.72), 0 0 2px rgba(0,0,0,.54); }.site-header::before { position: absolute; z-index: -1; top: 0; right: 0; left: 0; height: 124px; background: linear-gradient(180deg, rgba(18,18,15,.58), rgba(18,18,15,.24) 48%, rgba(18,18,15,0)); content: ''; opacity: .76; pointer-events: none; }.site-header > * { pointer-events: auto; }
.wordmark { width: max-content; font-size: 22px; font-weight: 800; letter-spacing: -.09em; line-height: 1; transition: opacity .25s ease, transform .25s ease; }.wordmark span { position: relative; top: -9px; margin-left: 3px; font-size: 7px; letter-spacing: 0; }
.header-location { margin: 0; font-size: 8px; font-weight: 800; letter-spacing: .11em; line-height: 1.3; text-align: center; text-transform: uppercase; }
.header-actions { justify-self: end; display: flex; gap: 18px; align-items: center; }.header-contact-link { display: inline-flex; min-height: 34px; border: 1px solid rgba(228,224,216,.58); padding: 0 14px; background: rgba(18,18,15,.2); align-items: center; justify-content: center; font-size: 9px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; backdrop-filter: blur(12px); transition: background .25s ease, color .25s ease, border-color .25s ease, transform .25s ease, opacity .25s ease; }.header-contact-link:hover { border-color: var(--paper); background: var(--paper); color: var(--ink); text-shadow: none; transform: translateY(-1px); }.menu-toggle { justify-self: end; display: inline-grid; width: max-content; height: 25px; padding: 0; border: 0; background: none; color: inherit; cursor: pointer; grid-template-columns: auto 15px; column-gap: 8px; align-items: center; transition: opacity .25s ease, transform .25s ease; }.wordmark:hover, .menu-toggle:hover { opacity: .72; transform: translateY(-1px); }.menu-toggle span { grid-row: span 2; font-size: 9px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }.menu-toggle i { display: block; width: 15px; height: 1px; background: currentColor; box-shadow: 0 1px 8px rgba(0,0,0,.55); transition: transform .35s ease; }.menu-toggle.is-open i:first-of-type { transform: translateY(2px) rotate(45deg); }.menu-toggle.is-open i:last-of-type { transform: translateY(-2px) rotate(-45deg); }

.site-menu { position: fixed; z-index: 45; inset: 0; display: flex; visibility: hidden; padding: 21vh 9vw 8vh; background: var(--paper); color: var(--ink); flex-direction: column; justify-content: center; opacity: 0; pointer-events: none; transition: visibility 0s linear .55s, opacity .25s ease; }.site-menu.is-open { visibility: visible; opacity: 1; pointer-events: auto; transition-delay: 0s; }.menu-label { position: absolute; top: 105px; left: 9vw; margin: 0; font-size: 10px; font-weight: 800; letter-spacing: .13em; text-transform: uppercase; }.site-menu > a:not(.menu-instagram) { display: flex; width: max-content; align-items: baseline; gap: 31px; font: 500 clamp(58px, 9vw, 145px)/.79 var(--serif); letter-spacing: -.07em; transform: translateY(22px); transition: transform .65s cubic-bezier(.16,1,.3,1), color .25s ease; }.site-menu.is-open > a:not(.menu-instagram) { transform: none; }.site-menu > a:nth-of-type(2) { transition-delay: .04s; }.site-menu > a:nth-of-type(3) { transition-delay: .08s; }.site-menu > a:nth-of-type(4) { transition-delay: .12s; }.site-menu > a:not(.menu-instagram):hover { color: #77736d; }.site-menu > a:not(.menu-instagram) span { font: 800 9px var(--sans); letter-spacing: .1em; }.menu-instagram { position: absolute; right: 9vw; bottom: 8vh; padding-bottom: 7px; border-bottom: 1px solid currentColor; font-size: 10px; font-weight: 800; letter-spacing: .11em; text-transform: uppercase; }.menu-instagram span { padding-left: 14px; font-size: 16px; }

.hero { position: relative; height: 100svh; min-height: 640px; overflow: hidden; background: var(--ink); color: var(--paper); isolation: isolate; }.hero-media { position: absolute; inset: 0; z-index: 0; margin: 0; overflow: hidden; }.hero-media::after { position: absolute; z-index: 1; inset: 0; background: linear-gradient(90deg, rgba(0,0,0,.6) 0%, rgba(0,0,0,.2) 45%, rgba(0,0,0,.1)), linear-gradient(0deg, rgba(0,0,0,.43), transparent 42%); content: ''; pointer-events: none; }.hero-media img { width: 100%; height: 100%; object-fit: cover; object-position: center 23%; transform: scale(1.075); backface-visibility: hidden; will-change: transform; }.hero-media figcaption { position: absolute; z-index: 2; right: 3.1vw; bottom: 23px; font-size: 9px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }.hero-shade { position: absolute; z-index: 1; inset: 0; background: radial-gradient(circle at 68% 35%, transparent 0 18%, rgba(18,18,15,.22) 70%); pointer-events: none; }
.hero-copy { position: relative; z-index: 2; display: flex; width: 100%; height: 100%; padding: 24vh 6.4vw 6.5vh; flex-direction: column; }.hero-eyebrow { margin-bottom: 20px; }.hero-title { display: flex; margin: 0; flex-direction: column; font-family: var(--sans); font-size: clamp(68px, 13.2vw, 222px); font-weight: 800; letter-spacing: -.115em; line-height: .67; text-transform: uppercase; }.hero-title span { display: block; }.hero-title strong { display: block; margin-left: 12.5vw; font: italic 500 1em/.72 var(--serif); letter-spacing: -.105em; text-transform: none; }.hero-note { max-width: 246px; margin: 42px 0 0 12.7vw; color: rgba(228,224,216,.87); font-size: 12px; line-height: 1.75; }.hero-contact-link { display: inline-flex; width: max-content; margin: 24px 0 0 12.7vw; border-bottom: 1px solid rgba(228,224,216,.78); padding-bottom: 8px; color: var(--paper); align-items: center; gap: 12px; font-size: 10px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; transition: gap .25s ease, opacity .25s ease, transform .25s ease; }.hero-contact-link:hover { gap: 19px; opacity: .78; transform: translateY(-1px); }.hero-contact-link span { font-size: 15px; line-height: .5; }.hero-side { position: absolute; z-index: 2; right: 3.1vw; bottom: 82px; margin: 0; font-size: 9px; font-weight: 800; letter-spacing: .11em; text-transform: uppercase; transform: rotate(-90deg); transform-origin: right center; }.hero-side i { display: inline-block; width: 42px; height: 1px; margin-left: 10px; vertical-align: middle; background: currentColor; }

.statement { position: relative; min-height: 100svh; padding: 10.5vw 9vw 5.8vw; background: var(--paper); }.statement > .eyebrow { margin-bottom: clamp(90px, 14vw, 220px); }.statement-title-wrap { display: grid; width: min(100%, 1330px); margin-left: auto; grid-template-columns: minmax(0, 1fr) minmax(180px, 260px); gap: 8vw; align-items: end; }.statement h2 { margin: 0; font: 500 clamp(68px, 9.8vw, 155px)/.75 var(--serif); letter-spacing: -.085em; }.statement h2 em { font-style: italic; }.statement-title-wrap > p { max-width: 230px; margin: 0 0 8px; font-size: 13px; line-height: 1.8; }.statement-foot { position: absolute; right: 9vw; bottom: 34px; left: 9vw; display: flex; justify-content: space-between; padding-top: 13px; border-top: 1px solid var(--line); }.statement-foot span { font-size: 9px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }

.sessions { position: relative; padding: clamp(112px, 12vw, 180px) 9vw; background: #d9d5cd; color: var(--ink); }.sessions-head { display: grid; width: min(100%, 1320px); margin: 0 auto clamp(58px, 7vw, 96px); grid-template-columns: minmax(190px, .38fr) minmax(0, 1fr) minmax(210px, .38fr); gap: clamp(28px, 6vw, 88px); align-items: end; }.sessions-head .eyebrow { margin: 0 0 7px; }.sessions h2 { margin: 0; font: 500 clamp(62px, 8.6vw, 132px)/.75 var(--serif); letter-spacing: -.085em; }.sessions h2 em { font-style: italic; }.sessions-head > p:last-child { max-width: 275px; margin: 0; font-size: 13px; line-height: 1.8; }.sessions-list { width: min(100%, 1320px); margin: 0 auto; border-top: 1px solid var(--line); }.session-row { display: grid; min-height: 168px; border-bottom: 1px solid var(--line); padding: 26px 0; grid-template-columns: 58px minmax(220px, .72fr) minmax(260px, 1fr) minmax(190px, .48fr); gap: clamp(18px, 4vw, 56px); align-items: center; }.session-row > span { color: #77736d; font-size: 10px; font-weight: 800; letter-spacing: .12em; }.session-row p { margin: 0; }.session-row div:first-of-type p { margin-bottom: 10px; color: #77736d; font-size: 9px; font-weight: 800; letter-spacing: .13em; text-transform: uppercase; }.session-row h3 { margin: 0; font: 500 clamp(34px, 4.4vw, 62px)/.82 var(--serif); letter-spacing: -.06em; }.session-row > p { max-width: 470px; color: #4f4b45; font-size: 13px; line-height: 1.75; }.session-row div:last-child { display: grid; gap: 20px; justify-items: end; }.session-row small { color: #77736d; font-size: 9px; font-weight: 800; letter-spacing: .11em; line-height: 1.55; text-align: right; text-transform: uppercase; }.session-row button { display: inline-flex; width: max-content; border: 0; border-bottom: 1px solid currentColor; padding: 0 0 8px; background: transparent; color: var(--ink); align-items: center; gap: 12px; font-size: 9px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; cursor: pointer; transition: gap .25s ease, opacity .25s ease, transform .25s ease; }.session-row button:hover { gap: 18px; opacity: .72; transform: translateY(-1px); }.session-row button i { font-style: normal; font-size: 15px; line-height: .5; }

.archive { position: relative; background: var(--ink); color: var(--paper); }.archive-pin { position: relative; overflow: hidden; }.archive-hud { position: absolute; z-index: 3; top: 0; left: 0; width: 100%; padding: 9vh 9vw 0; pointer-events: none; }.archive-count { position: absolute; top: 9vh; right: 9vw; display: flex; gap: 12px; align-items: center; font-size: 10px; font-weight: 800; letter-spacing: .12em; }.archive-count i { display: block; width: 43px; height: 1px; background: rgba(228,224,216,.55); }.archive-track { display: grid; }.work { position: relative; display: grid; min-height: 100svh; padding: clamp(180px, 21vh, 230px) 9vw 7vh; background: var(--ink); grid-template-columns: minmax(0, 1.18fr) minmax(260px, .82fr); column-gap: 7vw; align-items: end; }.work:nth-child(odd) { background: #171713; }.work-art { position: relative; width: 100%; height: min(58vw, 69vh); overflow: hidden; cursor: zoom-in; }.work-art:focus-visible, .process-image:focus-visible { outline: 2px solid var(--paper); outline-offset: 6px; }.work-art img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s cubic-bezier(.16,1,.3,1); backface-visibility: hidden; }.work-art::after { position: absolute; inset: 0; background: linear-gradient(135deg, rgba(255,255,255,.18), transparent 24% 72%, rgba(0,0,0,.2)); content: ''; opacity: .5; pointer-events: none; transition: opacity .3s ease; }.work-art:hover img { transform: scale(1.045); }.work-art:hover::after { opacity: .3; }.work-art-no, .work-art-action { position: absolute; z-index: 2; font-size: 9px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }.work-art-no { top: 17px; left: 18px; }.work-art-action { right: 18px; bottom: 16px; opacity: 0; transform: translateY(7px); transition: opacity .35s ease, transform .35s ease; }.work-art:hover .work-art-action { opacity: 1; transform: none; }.work-caption { padding-bottom: 2vh; }.work-caption p { margin: 0 0 19px; font-size: 9px; font-weight: 800; letter-spacing: .13em; text-transform: uppercase; }.work-caption h3 { max-width: 520px; margin: 0; font: 500 clamp(53px, 5.4vw, 86px)/.8 var(--serif); letter-spacing: -.075em; }.work-caption h3 em { font-style: italic; }.work-caption button { display: inline-flex; gap: 15px; margin: 31px 0 0; border: 0; border-bottom: 1px solid currentColor; padding: 0 0 8px; background: none; color: inherit; font-size: 9px; font-weight: 800; letter-spacing: .11em; text-transform: uppercase; cursor: pointer; transition: gap .3s ease; }.work-caption button:hover { gap: 23px; }.work-caption button span { font-size: 16px; line-height: .5; }.work-portrait .work-art img { object-position: center 24%; }.work-monochrome .work-art img { object-position: center 17%; }.work-binou .work-art img { object-position: center 26%; }.work-cocker .work-art img { object-position: center 32%; }.archive-direction { position: absolute; z-index: 4; right: 9vw; bottom: 32px; margin: 0; font-size: 9px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }.archive-direction span { margin-left: 12px; font-size: 18px; }

.process { display: grid; min-height: 100svh; padding: 10vw 9vw; background: var(--paper); grid-template-columns: minmax(280px, .8fr) minmax(350px, 1.2fr); gap: 10vw; align-items: center; }.process-copy h2 { margin: 24px 0 29px; font: 500 clamp(64px, 7.7vw, 122px)/.72 var(--serif); letter-spacing: -.085em; }.process-copy h2 em { font-style: italic; }.process-copy > p:last-child { max-width: 280px; margin: 0; font-size: 13px; line-height: 1.8; }.process-image { position: relative; margin: 0; overflow: hidden; height: min(61vw, 780px); }.process-image img { width: 100%; height: 100%; object-fit: cover; object-position: center 13%; transition: transform 1.1s cubic-bezier(.16,1,.3,1); backface-visibility: hidden; will-change: transform; }.process-image:hover img { transform: scale(1.055); }.process-image figcaption { position: absolute; right: 17px; bottom: 16px; color: var(--paper); font-size: 9px; font-weight: 800; letter-spacing: .11em; text-transform: uppercase; }

.contact { min-height: 100svh; padding: 15vh 9vw 26px; background: var(--ink); color: var(--paper); }.contact h2 { max-width: 1100px; margin: 28px 0 clamp(60px, 8vw, 118px); font: 500 clamp(74px, 11vw, 175px)/.69 var(--serif); letter-spacing: -.095em; }.contact h2 em { font-style: italic; }.contact-address { display: grid; width: 100%; padding: 22px 0 17px; border-top: 1px solid var(--white-line); border-bottom: 1px solid var(--white-line); grid-template-columns: minmax(150px, .43fr) 1fr auto; gap: 25px; align-items: end; transition: padding .35s ease, color .35s ease; }.contact-address:hover { padding-right: 15px; padding-left: 15px; background: var(--paper); color: var(--ink); }.contact-address span { font-size: 9px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }.contact-address b { font: 500 clamp(29px, 4.2vw, 65px)/.8 var(--serif); letter-spacing: -.06em; }.contact-address i { font: 32px var(--serif); }.contact-panel { display: grid; border-top: 1px solid var(--white-line); border-bottom: 1px solid var(--white-line); padding: clamp(28px, 4vw, 54px) 0; grid-template-columns: minmax(220px, .55fr) minmax(360px, 1fr); gap: clamp(34px, 7vw, 112px); align-items: start; }.contact-intro { display: grid; gap: 28px; align-content: start; }.contact-intro > p:first-child { max-width: 310px; margin: 0; color: rgba(228,224,216,.72); font-size: 13px; line-height: 1.8; }.contact-instagram { width: max-content; border-bottom: 1px solid currentColor; padding-bottom: 8px; font-size: 10px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }.contact-instagram span { padding-left: 10px; font-size: 15px; }.contact-flash { margin: 0; padding: 15px 0; border-top: 1px solid currentColor; border-bottom: 1px solid currentColor; font-size: 10px; font-weight: 800; letter-spacing: .11em; line-height: 1.6; text-transform: uppercase; }.contact-flash-success { color: var(--paper); }.contact-flash-error { color: #d9aa9f; }.contact-form { display: grid; gap: 32px; }.contact-form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 25px clamp(26px, 4vw, 60px); }.contact-field { display: grid; gap: 8px; }.contact-field span { color: rgba(228,224,216,.62); font-size: 9px; font-weight: 800; letter-spacing: .13em; text-transform: uppercase; }.contact-field span em { color: rgba(228,224,216,.38); font-style: normal; }.contact-field input, .contact-field select, .contact-field textarea { width: 100%; border: 0; border-bottom: 1px solid rgba(228,224,216,.28); border-radius: 0; padding: 13px 0 15px; background: transparent; color: var(--paper); outline: 0; transition: border-color .25s ease, transform .25s ease; }.contact-field input:focus, .contact-field select:focus, .contact-field textarea:focus { border-color: var(--paper); }.contact-field textarea { resize: vertical; line-height: 1.65; }.contact-field select { appearance: none; }.contact-field option { background: var(--ink); color: var(--paper); }.contact-field small { color: #d9aa9f; font-size: 11px; line-height: 1.5; }.contact-field-full { grid-column: 1 / -1; }.contact-actions { display: flex; gap: 28px; align-items: center; justify-content: space-between; }.contact-submit { display: inline-flex; min-height: 54px; border: 1px solid rgba(228,224,216,.62); padding: 0 22px; background: var(--paper); color: var(--ink); align-items: center; gap: 12px; justify-content: center; font-size: 10px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; cursor: pointer; transition: transform .25s ease, background .25s ease, color .25s ease; }.contact-submit:hover { background: transparent; color: var(--paper); transform: translateY(-2px); }.contact-submit span { font-size: 15px; }.contact-actions p { max-width: 300px; margin: 0; color: rgba(228,224,216,.45); font-size: 10px; line-height: 1.7; }.honeypot-field { position: absolute; left: -10000px; width: 1px; height: 1px; overflow: hidden; }.contact footer { display: grid; margin-top: 11vh; color: #a09e96; grid-template-columns: 1fr 1.7fr auto; gap: 28px; font-size: 8px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }.contact footer a { color: var(--paper); }

.lightbox { width: 100vw; max-width: none; height: 100dvh; max-height: none; margin: 0; border: 0; padding: 0; background: var(--ink); color: var(--paper); opacity: 0; transform: scale(1.018); transition: opacity .3s ease, transform .5s cubic-bezier(.16,1,.3,1); }.lightbox::backdrop { background: rgba(0,0,0,.72); backdrop-filter: blur(8px); }.lightbox.is-open { opacity: 1; transform: none; }.lightbox-image-wrap { display: grid; width: 100%; height: calc(100dvh - 104px); padding: 70px 11vw 32px; place-items: center; }.lightbox-image-wrap img { width: auto; max-width: 100%; height: 100%; object-fit: contain; box-shadow: 0 25px 90px rgba(0,0,0,.28); }.lightbox-close { position: absolute; z-index: 2; top: 27px; right: 3.1vw; border: 0; padding: 0; background: transparent; color: inherit; font-size: 10px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; cursor: pointer; }.lightbox-close span { margin-right: 12px; }.lightbox-close:hover { opacity: .65; }.lightbox-nav { position: absolute; z-index: 2; top: 50%; display: grid; width: 52px; height: 52px; border: 1px solid rgba(228,224,216,.42); border-radius: 50%; padding: 0 0 3px; background: transparent; color: inherit; font: 400 27px/1 var(--serif); place-items: center; cursor: pointer; transform: translateY(-50%); transition: color .25s ease, background .25s ease, transform .25s ease; }.lightbox-nav:hover { background: var(--paper); color: var(--ink); }.lightbox-nav:active { transform: translateY(-50%) scale(.93); }.lightbox-prev { left: 3.1vw; }.lightbox-next { right: 3.1vw; }.lightbox-meta { position: absolute; right: 3.1vw; bottom: 22px; left: 3.1vw; display: grid; border-top: 1px solid var(--white-line); padding-top: 13px; grid-template-columns: 1fr auto 1fr; align-items: end; }.lightbox-meta p, .lightbox-meta span { margin: 0; color: #a09e96; font-size: 9px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }.lightbox-meta h2 { margin: 0; font: 500 clamp(25px, 2.6vw, 40px)/.8 var(--serif); letter-spacing: -.05em; text-align: center; }.lightbox-meta span { text-align: right; }

.contract-public { position: relative; min-height: 100svh; padding: clamp(120px, 12vw, 150px) 9vw 72px; background: var(--paper); color: var(--ink); }
.contract-public::before { position: fixed; z-index: 40; top: 0; right: 0; left: 0; height: 82px; background: var(--ink); content: ''; pointer-events: none; }
.contract-public-hero { display: grid; width: min(100%, 1120px); margin: 0 auto clamp(42px, 6vw, 82px); gap: 28px; }
.contract-public-hero h1 { max-width: 980px; margin: 0; font: 500 clamp(66px, 10vw, 142px)/.72 var(--serif); letter-spacing: -.085em; }
.contract-public-hero h1 em { font-style: italic; }
.private-kicker { margin: 0; color: #77736d; font-size: 10px; font-weight: 800; letter-spacing: .13em; text-transform: uppercase; }
.private-meta { display: flex; max-width: 880px; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); flex-wrap: wrap; }
.private-meta span { padding: 12px 18px 12px 0; color: #5d5850; font-size: 9px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.private-flash { width: min(100%, 1120px); margin: 0 auto 28px; border-top: 1px solid currentColor; border-bottom: 1px solid currentColor; padding: 15px 0; color: #1f5747; font-size: 10px; font-weight: 800; letter-spacing: .11em; text-transform: uppercase; }
.contract-public-document,
.contract-public-signature { width: min(100%, 1120px); margin: 0 auto; }
.contract-public-document { border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); padding: clamp(30px, 5vw, 58px) 0; }
.contract-public-body { max-width: 820px; color: #3f3b35; font-size: clamp(15px, 1.5vw, 18px); line-height: 1.95; }
.contract-public-signature { margin-top: 42px; }
.contract-public-signature form { display: grid; width: min(100%, 680px); gap: 24px; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); padding: 28px 0; }
.contract-public-signature label { display: grid; gap: 8px; }
.contract-public-signature label > span { color: #77736d; font-size: 9px; font-weight: 800; letter-spacing: .13em; text-transform: uppercase; }
.contract-public-signature input[type='text'],
.contract-public-signature input[type='email'] { width: 100%; border: 0; border-bottom: 1px solid var(--line); border-radius: 0; padding: 13px 0 15px; background: transparent; color: var(--ink); outline: 0; }
.contract-public-signature textarea { width: 100%; border: 1px solid var(--line); border-radius: 0; padding: 14px; background: rgba(255,255,255,.16); color: var(--ink); outline: 0; resize: vertical; line-height: 1.7; }
.contract-public-signature small,
.contract-error { color: #8a382d; font-size: 11px; line-height: 1.5; }
.contract-consent { display: flex !important; gap: 12px; align-items: flex-start; }
.contract-consent input { width: 18px; height: 18px; margin-top: 1px; flex: 0 0 auto; }
.contract-consent span { color: #4f4b45 !important; letter-spacing: 0 !important; line-height: 1.65; text-transform: none !important; }
.contract-public-signature button { display: inline-flex; width: max-content; min-height: 54px; border: 1px solid var(--ink); padding: 0 22px; background: var(--ink); color: var(--paper); align-items: center; justify-content: center; font-size: 10px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; transition: transform .25s ease, background .25s ease, color .25s ease; }
.contract-public-signature button:hover { background: transparent; color: var(--ink); transform: translateY(-2px); }
.private-empty { width: min(100%, 680px); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); padding: 28px 0; }
.private-empty p { margin: 0; color: #4f4b45; font-size: 14px; line-height: 1.8; }
.questionnaire-public-intro { max-width: 560px; margin: -10px 0 0; color: #4f4b45; font-size: 13px; line-height: 1.8; }
.questionnaire-public-form form { width: min(100%, 820px); }

@media (pointer: fine) { body { cursor: none; } a, button, [role='button'] { cursor: none; }.cursor { position: fixed; z-index: 90; top: 0; left: 0; display: grid; width: 66px; height: 66px; border-radius: 50%; background: var(--paper); color: var(--ink); mix-blend-mode: difference; opacity: 0; pointer-events: none; place-items: center; transform: translate3d(-120px, -120px, 0) scale(.35); transition: opacity .16s ease; will-change: transform, opacity; }.cursor.is-visible { opacity: 1; }.cursor span { font-size: 8px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; } }

.motion-enhanced .archive { height: 420vh; }.motion-enhanced .archive-pin { position: sticky; top: 0; height: 100svh; transform: translateZ(0); }.motion-enhanced .archive-track { display: flex; width: 400%; height: 100%; backface-visibility: hidden; will-change: transform; }.motion-enhanced .work { width: 100vw; min-height: 100%; flex: 0 0 100vw; }

@media (max-width: 760px) {
  .loader { padding: 20px 6vw; }.loader > p { font-size: 52px; }
  .site-header { padding: 20px 6vw; grid-template-columns: 1fr auto; }.header-location { display: none; }.header-actions { gap: 13px; }.header-contact-link { min-height: 31px; padding: 0 11px; font-size: 8px; }.site-menu { padding: 20vh 8vw 10vh; }.menu-label { top: 91px; left: 8vw; }.site-menu > a:not(.menu-instagram) { gap: 19px; font-size: clamp(59px, 18vw, 90px); }.menu-instagram { right: auto; bottom: 8vh; left: 8vw; }
  .hero { height: 100svh; min-height: 610px; }.hero-media::after { background: linear-gradient(90deg, rgba(0,0,0,.66), rgba(0,0,0,.05) 76%), linear-gradient(0deg, rgba(0,0,0,.43), transparent 39%); }.hero-copy { padding: max(145px, 21svh) 7vw 5vh; }.hero-media img { object-position: 54% 22%; }.hero-title { font-size: clamp(74px, 21vw, 118px); line-height: .65; }.hero-title strong { margin-left: 11vw; }.hero-note { max-width: 205px; margin: 32px 0 0 8vw; font-size: 11px; }.hero-contact-link { margin: 22px 0 0 8vw; font-size: 9px; }.hero-media figcaption { right: 7vw; bottom: 23px; max-width: 125px; text-align: right; }.hero-side { bottom: 29px; left: 7vw; right: auto; display: block; font-size: 8px; transform: none; }.hero-side i { width: 30px; }
  .statement { min-height: 92svh; padding: 112px 7vw 90px; }.statement > .eyebrow { margin-bottom: 94px; }.statement-title-wrap { display: block; }.statement h2 { font-size: clamp(64px, 18vw, 98px); line-height: .76; }.statement-title-wrap > p { margin: 40px 0 0 26%; font-size: 12px; }.statement-foot { right: 7vw; bottom: 26px; left: 7vw; flex-wrap: wrap; gap: 12px; }.statement-foot span { width: calc(50% - 7px); }
  .sessions { padding: 102px 7vw; }.sessions-head { display: block; margin-bottom: 50px; }.sessions-head .eyebrow { margin-bottom: 24px; }.sessions h2 { font-size: clamp(64px, 17vw, 96px); line-height: .74; }.sessions-head > p:last-child { margin-top: 30px; font-size: 12px; }.session-row { min-height: 0; padding: 28px 0 31px; grid-template-columns: 1fr; gap: 18px; }.session-row h3 { font-size: clamp(40px, 13vw, 62px); }.session-row > p { font-size: 12px; }.session-row div:last-child { justify-items: start; }.session-row small { text-align: left; }
  .archive { overflow: clip; }.archive-pin { overflow: visible; }.archive-hud { position: relative; min-height: 118px; padding: 104px 7vw 0; }.archive-count { top: 104px; right: 7vw; }.archive-count i { width: 26px; }.archive-track { display: block; }.work { min-height: 0; padding: 25px 7vw 94px; grid-template-columns: 1fr; gap: 28px; align-content: start; }.work:first-child { padding-top: 0; }.work-art { height: min(124vw, 610px); }.work-art-no { top: 15px; left: 15px; }.work-caption { display: grid; grid-template-columns: 1fr auto; gap: 0 16px; padding: 0; }.work-caption p { grid-column: 1 / -1; margin-bottom: 15px; }.work-caption h3 { grid-column: 1 / -1; font-size: clamp(54px, 15vw, 82px); line-height: .79; }.work-caption button { grid-column: 1 / -1; width: max-content; margin-top: 25px; }.work-art-action { display: none; }.archive-direction { display: none; }.motion-enhanced .archive { height: auto; }.motion-enhanced .archive-pin { position: relative; height: auto; overflow: visible; }.motion-enhanced .archive-track { display: block; width: 100%; height: auto; }.motion-enhanced .work { width: auto; min-height: 0; }
  .process { display: block; min-height: auto; padding: 112px 7vw; }.process-copy h2 { font-size: clamp(68px, 18vw, 96px); line-height: .73; }.process-copy > p:last-child { margin-bottom: 74px; }.process-image { height: 128vw; }.process-image img { object-position: center 13%; }
  .contact { min-height: 92svh; padding: 112px 7vw 23px; }.contact h2 { margin-bottom: 54px; font-size: clamp(80px, 20vw, 114px); }.contact-address { padding: 19px 0; grid-template-columns: 1fr auto; gap: 11px; }.contact-address span { grid-column: span 2; }.contact-address b { font-size: 34px; }.contact-panel { display: block; padding: 30px 0 34px; }.contact-intro { gap: 22px; margin-bottom: 38px; }.contact-form-grid { grid-template-columns: 1fr; gap: 22px; }.contact-actions { align-items: flex-start; flex-direction: column; }.contact-submit { width: 100%; }.contact-actions p { max-width: none; }.contact footer { margin-top: 10vh; grid-template-columns: 1fr; gap: 12px; }.contact footer span:last-of-type { max-width: 240px; }
  .contract-public { padding: 112px 7vw 54px; }.contract-public-hero h1 { font-size: clamp(62px, 18vw, 96px); }.private-meta { display: grid; }.private-meta span { padding: 10px 0; border-bottom: 1px solid rgba(18,18,15,.12); }.private-meta span:last-child { border-bottom: 0; }.contract-public-body { font-size: 14px; line-height: 1.85; }.contract-public-signature button { width: 100%; }
  .lightbox-image-wrap { height: calc(100dvh - 94px); padding: 66px 7vw 30px; }.lightbox-close { top: 21px; right: 7vw; }.lightbox-nav { top: auto; bottom: 21px; width: 38px; height: 38px; font-size: 22px; transform: none; }.lightbox-nav:active { transform: scale(.93); }.lightbox-prev { right: calc(7vw + 49px); left: auto; }.lightbox-next { right: 7vw; }.lightbox-meta { right: 7vw; bottom: 18px; left: 7vw; padding-right: 107px; grid-template-columns: 1fr auto; gap: 9px; }.lightbox-meta h2 { grid-row: 1; grid-column: 1; text-align: left; }.lightbox-meta p { grid-row: 2; grid-column: 1; }.lightbox-meta span { grid-row: 2; grid-column: 2; }
}

@media (prefers-reduced-motion: reduce) { *, *::before, *::after { scroll-behavior: auto !important; transition-duration: .01ms !important; animation-duration: .01ms !important; } }
