/* =====================================================
   e45 Office — site styles
   Editorial / high-end fashion language matching the
   agency deck. Big bold Haffer, white space, no accents.
   ===================================================== */

/* --- FONTS --- */
@font-face {
    font-family: 'Haffer';
    src: url('fonts/HafferXHRegular.ttf') format('truetype');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

/* --- TOKENS --- */
:root {
    --black: #0a0a0a;
    --ink: #111;
    --grey: #8a8a8a;
    --line: #ececec;
    --paper: #ffffff;
    --image-bg: #f4f4f4;
    --font: 'Haffer', 'Helvetica Neue', Helvetica, Arial, sans-serif;
    --ease: cubic-bezier(0.16, 1, 0.3, 1);

    --pad-x: 48px;
    --pad-x-md: 32px;
    --pad-x-sm: 24px;
}

/* universe-artists class kept as a hook but no longer styled differently — both
   universes share the same white background. The "different universe" feeling
   comes from typography scale, not color. */

/* --- RESET --- */
*, *::before, *::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    scrollbar-width: none;
    overflow-x: hidden;
    max-width: 100vw;
    width: 100%;
    position: relative;
}
html::-webkit-scrollbar { display: none; }

body {
    font-family: var(--font);
    background: var(--paper);
    color: var(--ink);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: hidden;
    max-width: 100vw;
    width: 100%;
    position: relative;
    /* Prevent iOS elastic horizontal pan completely */
    touch-action: pan-y;
    overscroll-behavior-x: none;
    opacity: 0;
    transition: opacity 0.45s ease;
    font-size: 15px;
    line-height: 1.5;
    letter-spacing: 0;
}

/* Belt-and-braces — main and direct body children can never exceed viewport */
main { max-width: 100vw; overflow-x: hidden; }

body.is-visible { opacity: 1; }

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

/* =============== LANDING =============== */
.landing-page {
    height: 100vh;
    width: 100vw;
    background: #fff;
    overflow: hidden;
    position: relative;
    margin: 0;
}

.landing-word {
    position: absolute;
    top: 6vh;
    line-height: 0.9;
    letter-spacing: -0.015em;
    font-weight: 400;
    text-decoration: none;
    color: var(--ink);
    white-space: nowrap;
    transition: color 0.35s var(--ease);
}
/* Each word sized so it never collides with the other.
   Conservative scaling — leaves ~25% gap in middle at any viewport. */
.landing-word.left  { left: var(--pad-x);  font-size: clamp(3.4rem, 13vw, 14rem); }
.landing-word.right { right: var(--pad-x); font-size: clamp(2.8rem, 11vw, 12rem); }

/* Black by default, hot-pink on hover */
.landing-word:hover { color: #ff0099; }

.landing-footer {
    position: absolute;
    left: var(--pad-x);
    right: var(--pad-x);
    bottom: 32px;
    display: flex;
    align-items: baseline;
    gap: 64px;
    color: var(--ink);
}
.landing-mark {
    font-size: 1.15rem;
    letter-spacing: -0.01em;
    text-transform: none;
    font-weight: 400;
    color: var(--ink);
    text-decoration: none;
    transition: color 0.3s ease;
}
.landing-mark:hover { color: #ff0099; }
.landing-year {
    font-size: 1.15rem;
    letter-spacing: -0.01em;
    text-transform: none;
}

/* Tablet landing word sizes — full mobile rules live in the
   comprehensive mobile section near the bottom of this file */
@media (max-width: 900px) and (min-width: 769px) {
    .landing-word.left  { font-size: clamp(2.8rem, 14vw, 9rem); }
    .landing-word.right { font-size: clamp(2.4rem, 12vw, 8rem); }
}

/* =============== HEADER ===============
   Normal-flow on every internal page. HUGE "e45 Office" corner logo,
   small uppercase nav at top right. Scrolls away with content. */
header {
    position: relative;
    z-index: 200;
    background: transparent;
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: 36px var(--pad-x) 24px;
    border-bottom: none;
}

header.scrolled { border-bottom: none; background: transparent; }

.logo-small {
    font-size: clamp(2.2rem, 6vw, 6rem);
    line-height: 0.85;
    letter-spacing: -0.04em;
    font-weight: 400;
    text-decoration: none;
    color: var(--ink);
    transition: color 0.3s ease;
}
.logo-small:hover { color: #ff0099; }

nav {
    display: flex;
    gap: 40px;
    align-self: baseline;
}

nav a {
    font-size: 0.7rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    text-decoration: none;
    color: var(--grey);
    transition: color 0.2s ease;
}
nav a:hover  { color: var(--ink); }
nav a.active { color: var(--ink); }

/* =============== PAGE TITLE (Selected Cases / Artists) =============== */
.page-title {
    font-size: clamp(3rem, 7vw, 6rem);
    font-weight: 400;
    line-height: 0.95;
    letter-spacing: -0.035em;
    color: var(--ink);
    text-align: center;
    padding: 14vh 0 12vh;
}

.page-eyebrow {
    display: block;
    font-size: 0.65rem;
    letter-spacing: 0.3em;
    text-transform: uppercase;
    color: var(--grey);
    margin-bottom: 24px;
}

/* =============== INDEX (Work / Artists typographic list) ===============
   Stacked rows that always fill the viewport from top to bottom.
   Type scales to the number of rows. Hover → floating preview thumb.
   ======================================================================= */

/* ──── WORK: fullscreen vertical infinite scroll ──── */
body.page-work {
    height: 100vh;
    overflow: hidden;
}

.work-scroll {
    height: 100%;
    overflow-y: auto;
    overflow-x: hidden;
    scrollbar-width: none;
}
.work-scroll::-webkit-scrollbar { display: none; }

/* ──── ARTISTS: typographic stack like the InDesign deck ────
   Names stacked top-to-bottom from the top of the page.
   Tight line-height. Long names wrap naturally to the next line.
   Font scales to the row count — fewer artists = bigger names. */
.artists-page {
    min-height: 100vh;
    padding: 0 var(--pad-x) 80px;
}
.artists-page .artists-list {
    padding-top: 8px;
}

.artists-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.artists-list .index-row {
    overflow: visible;
}

.artists-list .index-row a {
    display: block;
    text-decoration: none;
    color: var(--ink);
    /* JS measures each row and sets inline font-size so the name fills its
       line width without overflowing. The fallback clamp is capped tightly
       so names never blow out the viewport even before JS has run. */
    font-size: var(
        --row-font-size,
        clamp(2rem, min(11vw, calc((100vh - 100px) / var(--row-count, 1) * 0.85)), 18vh)
    );
    line-height: 1.02;
    letter-spacing: -0.04em;
    font-weight: 400;
    padding: 0;
    cursor: none;
    transition: color 0.35s var(--ease);
    will-change: color;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: clip;
    max-width: 100%;
}
.artists-list .index-row { overflow: hidden; max-width: 100%; }
.artists-list { max-width: 100%; overflow: hidden; }
.artists-list .index-row a:hover { color: #ff0099; }

/* Hide the small role meta on artists — names only, like the deck */
.artists-list .row-meta { display: none; }
.artists-list .row-title { display: inline; }

/* ──── INDEX (shared row mechanics) ──── */
.index-list {
    list-style: none;
    margin: 0;
    padding: 32px var(--pad-x) 32px;
}

.index-row {
    position: relative;
}

.index-row a {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 32px;
    text-decoration: none;
    color: var(--ink);
    font-size: clamp(1.8rem, 4vw, 4rem);
    line-height: 1.05;
    letter-spacing: -0.025em;
    font-weight: 400;
    cursor: none;
    transition: opacity 0.4s var(--ease), transform 0.5s var(--ease);
    will-change: opacity, transform;
    padding: 2px 0;
}

/* Hot-pink on hover, no dimming */
.index-row a { transition: color 0.3s var(--ease), transform 0.5s var(--ease); }
.index-row a:hover { color: #ff0099; }

.index-row .row-title {
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.index-row .row-meta {
    font-size: 0.62rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--grey);
    flex-shrink: 0;
    font-weight: 400;
    align-self: center;
}

/* Hover preview thumbnail that follows the cursor */
.hover-preview {
    position: fixed;
    top: 0;
    left: 0;
    width: 280px;
    height: 360px;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.35s var(--ease);
    z-index: 50;
    overflow: hidden;
    background: var(--image-bg);
    transform: translate(-50%, -50%) scale(0.96);
    transition: opacity 0.35s var(--ease), transform 0.5s var(--ease);
}
.hover-preview.visible {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1);
}
.hover-preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

@media (max-width: 768px) {
    .hover-preview { display: none; }
    .index-row a {
        cursor: pointer;
        font-size: clamp(1.4rem, 7vw, 2.2rem);
    }
    .index-list:hover .index-row a { opacity: 1; }
    .index-list .index-row a:hover { transform: none; }
    .index-row .row-meta { display: none; }
}

/* =============== SELECTED CASES (list) =============== */
.stacked-cases {
    display: flex;
    flex-direction: column;
    margin-bottom: 160px;
}

.case-link {
    display: block;
    text-decoration: none;
    color: inherit;
}

.case-item {
    position: relative;
    width: 100%;
    overflow: hidden;
    background: var(--image-bg);
    aspect-ratio: 16 / 9;
    cursor: none;
}

.case-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 1.6s var(--ease);
}

.case-link:hover .case-item img {
    transform: scale(1.025);
}

.case-info {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: 24px var(--pad-x) 80px;
    gap: 32px;
}

.case-index {
    font-size: 0.65rem;
    letter-spacing: 0.2em;
    color: var(--grey);
    min-width: 40px;
}

.case-title {
    font-size: 1.05rem;
    font-weight: 400;
    letter-spacing: -0.01em;
    flex: 1;
}

.case-disciplines {
    font-size: 0.65rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--grey);
    text-align: right;
    max-width: 40%;
}

/* =============== ARTISTS GRID =============== */
.artist-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 64px var(--pad-x);
    padding: 0 var(--pad-x);
    margin-bottom: 160px;
}

.artist-link {
    text-decoration: none;
    color: inherit;
    display: block;
}

.image-wrapper {
    width: 100%;
    aspect-ratio: 3 / 4;
    overflow: hidden;
    background: var(--image-bg);
    cursor: none;
    margin-bottom: 18px;
}

.image-wrapper img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: grayscale(100%);
    transition: transform 1.6s var(--ease), filter 0.9s ease;
}

.artist-link:hover .image-wrapper img {
    filter: grayscale(0%);
    transform: scale(1.03);
}

.artist-info h2 {
    font-size: 1rem;
    font-weight: 400;
    letter-spacing: -0.005em;
    margin-bottom: 4px;
}

.artist-info p {
    font-size: 0.65rem;
    color: var(--grey);
    letter-spacing: 0.18em;
    text-transform: uppercase;
}

/* =============== ARTIST DETAIL =============== */
.artist-detail {
    padding-bottom: 160px;
}

.artist-hero {
    display: grid;
    grid-template-columns: 5fr 7fr;
    gap: var(--pad-x);
    padding: 48px var(--pad-x) 96px;
}

.artist-portrait {
    width: 100%;
    aspect-ratio: 3 / 4;
    overflow: hidden;
    background: var(--image-bg);
}
.artist-portrait img { width: 100%; height: 100%; object-fit: cover; }

.artist-meta { padding-top: 8px; }

.artist-name {
    font-size: clamp(2.4rem, 5vw, 4.5rem);
    font-weight: 400;
    line-height: 0.95;
    letter-spacing: -0.035em;
    margin-bottom: 32px;
}

.artist-meta-row {
    display: grid;
    grid-template-columns: 120px 1fr;
    gap: 16px;
    padding: 8px 0;
    font-size: 0.78rem;
}
.artist-meta-row dt {
    font-size: 0.62rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--grey);
    padding-top: 2px;
}
.artist-meta-row dd { color: var(--ink); }
.artist-meta-row dd a { color: inherit; text-decoration: none; border-bottom: 1px solid var(--line); }
.artist-meta-row dd a:hover { border-bottom-color: var(--ink); }

.artist-bio {
    margin-top: 40px;
    max-width: 56ch;
    font-size: 0.95rem;
    line-height: 1.65;
    color: var(--ink);
}
.artist-bio p + p { margin-top: 1em; }

/* =============== ARTIST DETAIL — INLINE META + PLATFORMS ===============
   Used inside the shared .case-hero layout on artist.html so the artist
   page and case study page share the same editorial bones. */
.artist-inline-meta {
    display: grid;
    gap: 6px;
    margin: 8px 0 48px;
    max-width: 460px;
}
.artist-inline-meta .artist-meta-row {
    display: grid;
    grid-template-columns: 130px 1fr;
    gap: 16px;
    padding: 8px 0;
    font-size: 0.82rem;
    border: 0;
}
.artist-inline-meta .artist-meta-row dt {
    font-size: 0.6rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--grey);
    padding-top: 2px;
}
.artist-inline-meta .artist-meta-row dd { color: var(--ink); }
.artist-inline-meta .artist-meta-row dd a {
    color: inherit;
    text-decoration: none;
    border-bottom: 1px solid var(--line);
    transition: border-color 0.25s ease, color 0.25s ease;
}
.artist-inline-meta .artist-meta-row dd a:hover { color: #ff0099; border-bottom-color: #ff0099; }

.artist-platforms-block { padding-top: 8px; }

.platforms-list {
    list-style: none;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 4px 24px;
    margin: 0;
    padding: 0;
    max-width: 460px;
}
.platforms-list li { margin: 0; }
.platforms-list a {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 16px;
    padding: 10px 0;
    border-bottom: 1px solid var(--line);
    text-decoration: none;
    color: var(--ink);
    font-size: 0.88rem;
    letter-spacing: -0.005em;
    transition: color 0.3s var(--ease), padding 0.45s var(--ease);
}
.platforms-list a:hover {
    color: #ff0099;
    padding-left: 6px;
}
.platforms-list a::after {
    content: '↗';
    font-size: 0.85rem;
    color: var(--grey);
    transition: color 0.3s var(--ease), transform 0.45s var(--ease);
}
.platforms-list a:hover::after {
    color: #ff0099;
    transform: translate(2px, -2px);
}
.platforms-list .platform-label {
    font-size: 0.6rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--grey);
    display: block;
    margin-bottom: 2px;
}
.platforms-list .platform-handle {
    display: block;
    line-height: 1.1;
}

@media (max-width: 768px) {
    .platforms-list { grid-template-columns: 1fr; }
}

/* =============== PROJECT (CASE STUDY) =============== */
.project-container { padding-bottom: 160px; }

.back-link {
    display: inline-block;
    padding: 32px var(--pad-x) 0;
    font-size: 0.62rem;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    color: var(--grey);
    text-decoration: none;
    transition: color 0.2s ease;
}
.back-link:hover { color: var(--ink); }

.case-hero {
    display: grid;
    grid-template-columns: 5fr 7fr;
    gap: var(--pad-x);
    padding: 56px var(--pad-x) 80px;
    align-items: start;
}

.case-hero-text { padding-top: 8px; }

.case-title-display {
    font-size: clamp(2.6rem, 5.5vw, 5rem);
    font-weight: 400;
    line-height: 0.95;
    letter-spacing: -0.035em;
    margin-bottom: 56px;
}

.case-section-label {
    font-size: 0.62rem;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    color: var(--grey);
    margin-bottom: 18px;
    display: block;
}

.case-overview {
    max-width: 50ch;
    font-size: 0.95rem;
    line-height: 1.65;
    color: var(--ink);
    margin-bottom: 64px;
}
.case-overview p + p { margin-top: 1em; }

.case-services {
    padding-top: 16px;
}

.services-list {
    list-style: none;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 6px 24px;
    margin: 0;
    padding: 0;
}
.services-list li {
    font-size: 0.85rem;
    line-height: 1.5;
    color: var(--ink);
    position: relative;
    padding-left: 18px;
}
.services-list li::before {
    content: '+';
    position: absolute;
    left: 0;
    top: 0;
    color: var(--grey);
}

/* Placeholder content (used when fields are empty in Sanity) */
.placeholder-text {
    font-size: 0.95rem;
    line-height: 1.65;
    color: var(--grey);
    font-style: italic;
}
.placeholder-image {
    background:
        repeating-linear-gradient(
            45deg,
            #f4f4f4,
            #f4f4f4 12px,
            #ececec 12px,
            #ececec 24px
        );
    position: relative;
}
.placeholder-image::after {
    content: 'Image coming soon';
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--grey);
    font-size: 0.65rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
}

.service-group h4 {
    font-size: 0.68rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    font-weight: 400;
    color: var(--ink);
    margin-bottom: 10px;
}
.service-group ul { list-style: none; }
.service-group li {
    font-size: 0.78rem;
    color: var(--grey);
    line-height: 1.7;
}

.case-hero-image {
    width: 100%;
    background: var(--image-bg);
    overflow: hidden;
    aspect-ratio: 4 / 5;
}
.case-hero-image img {
    width: 100%; height: 100%; object-fit: cover;
}

/* Image grid below hero */
.project-blocks {
    display: flex;
    flex-wrap: wrap;
    gap: 2px;
    padding: 0 0 0;
}

.project-block {
    flex: 0 0 100%;
    overflow: hidden;
    background: var(--image-bg);
}
.project-block.half { flex: 0 0 calc(50% - 1px); }
.project-block img {
    width: 100%;
    display: block;
    object-fit: cover;
}

.project-credits {
    padding: 96px var(--pad-x) 0;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    margin: 96px var(--pad-x) 0;
}
.credit-row { font-size: 0.75rem; }
.credit-row dt {
    font-size: 0.6rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--grey);
    margin-bottom: 4px;
}
.credit-row dd { color: var(--ink); }

/* =============== ABOUT / CONTACT =============== */
.editorial {
    padding: 0 0 160px;
}

.editorial-section {
    padding: 96px var(--pad-x);
}

.editorial-section.center {
    text-align: center;
    padding: 14vh var(--pad-x);
}
.editorial-section.left {
    text-align: left;
    padding: 14vh var(--pad-x);
}
.editorial-section.right {
    text-align: right;
    padding: 14vh var(--pad-x);
}
.editorial-section.right .editorial-body,
.editorial-section.right .editorial-lead {
    margin-left: auto;
    margin-right: 0;
}
.editorial-section.left .editorial-body,
.editorial-section.left .editorial-lead {
    margin-left: 0;
    margin-right: auto;
}

.editorial-display.left  { text-align: left;  margin-left: 0; }
.editorial-display.right { text-align: right; margin-right: 0; margin-left: auto; }

.editorial-number {
    display: inline-block;
    font-size: 0.6rem;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: var(--grey);
    margin-bottom: 32px;
}

.editorial-eyebrow {
    display: block;
    font-size: 0.62rem;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: var(--grey);
    margin-bottom: 32px;
}

.editorial-display {
    font-size: clamp(2.4rem, 5.2vw, 4.8rem);
    font-weight: 400;
    line-height: 1;
    letter-spacing: -0.035em;
    margin: 0 auto;
    max-width: 22ch;
}

.editorial-lead {
    font-size: clamp(1.4rem, 2.4vw, 2.1rem);
    font-weight: 400;
    line-height: 1.25;
    letter-spacing: -0.015em;
    max-width: 32ch;
    margin: 0 auto;
}

.editorial-body {
    max-width: 56ch;
    font-size: 0.95rem;
    line-height: 1.7;
    color: var(--ink);
    margin: 0 auto;
}
.editorial-body p + p { margin-top: 1em; }

.editorial-split {
    display: grid;
    grid-template-columns: 5fr 7fr;
    gap: var(--pad-x);
    align-items: start;
}

/* About-page figures (showroom, other circle) — small editorial inserts */
.about-figure {
    margin: 56px 0 0;
    max-width: 480px;
    width: 100%;
    aspect-ratio: 4 / 5;
    overflow: hidden;
    background: var(--image-bg);
    position: relative;
}
.about-figure.wide { aspect-ratio: 4 / 3; max-width: 560px; }
/* Align showroom figure to the right side of its section for visual rhythm */
#showroom-figure { margin-left: auto; margin-right: 0; }
.about-figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
/* When the image hasn't been uploaded yet, show striped placeholder */
.about-figure[data-empty="true"] {
    background:
        repeating-linear-gradient(
            45deg,
            #f4f4f4,
            #f4f4f4 14px,
            #ececec 14px,
            #ececec 28px
        );
}
.about-figure[data-empty="true"] img { display: none; }
.about-figure[data-empty="true"]::after {
    content: 'Image coming soon — upload via Sanity';
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--grey);
    font-size: 0.65rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
}

/* Selected Client List */
.client-list {
    columns: 3;
    column-gap: 48px;
    max-width: 1100px;
    margin: 56px auto 0;
    list-style: none;
    font-size: 0.85rem;
    line-height: 2;
    color: var(--ink);
    column-fill: balance;
}
.client-list li {
    break-inside: avoid;
}

/* Office image grid */
.office-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2px;
    margin-top: 56px;
}
.office-grid .image-cell {
    background: var(--image-bg);
    aspect-ratio: 4 / 5;
    overflow: hidden;
}
.office-grid img { width: 100%; height: 100%; object-fit: cover; }

/* ──── Contact Page ──── */
.contact-page {
    padding: 0 var(--pad-x) 120px;
    min-height: calc(100vh - 86px);
}

.contact-display {
    padding: 18vh 0 14vh;
}
.contact-display h1 {
    font-size: clamp(3.5rem, 11vw, 14rem);
    line-height: 0.85;
    letter-spacing: -0.05em;
    font-weight: 400;
}

.contact-list {
    display: flex;
    flex-direction: column;
    margin-bottom: 14vh;
}
.contact-row {
    display: grid;
    grid-template-columns: 220px 1fr;
    align-items: baseline;
    gap: 32px;
    text-decoration: none;
    color: var(--ink);
    padding: 4px 0;
    transition: transform 0.45s var(--ease);
}
.contact-row__label {
    font-size: 0.65rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--grey);
}
.contact-row__value {
    font-size: clamp(1.6rem, 3.4vw, 3.4rem);
    line-height: 1.05;
    letter-spacing: -0.025em;
    font-weight: 400;
    transition: color 0.3s var(--ease);
}
.contact-row:hover .contact-row__value { color: #ff0099; }
.contact-row:hover { transform: translateX(8px); }

.contact-bottom {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 64px var(--pad-x);
    padding-top: 64px;
    max-width: 1200px;
}
.contact-bottom-block h4 {
    font-size: 0.6rem;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    color: var(--grey);
    font-weight: 400;
    margin-bottom: 14px;
}
.contact-bottom-block p,
.contact-bottom-block a {
    font-size: 0.92rem;
    line-height: 1.65;
    color: var(--ink);
    text-decoration: none;
    display: block;
}
.contact-bottom-block a { transition: color 0.25s ease; }
.contact-bottom-block a:hover { color: #ff0099; }

@media (max-width: 768px) {
    .contact-row { grid-template-columns: 1fr; gap: 4px; padding: 12px 0; }
    .contact-row__value { font-size: clamp(1.4rem, 6vw, 2rem); }
    .contact-bottom { grid-template-columns: 1fr; gap: 40px; }
    .contact-display { padding: 12vh 0 8vh; }
}

/* =============== SITE LOCK (staging gate) ===============
   Fullscreen white password screen shown until the office unlocks the
   site. Body content is hidden under it so even DOM inspection feels empty.
   ── Real security still requires server-side auth — see netlify.toml /
   vercel.json for proper Cloudflare/Netlify/Vercel password protection. */
html.site-checking-lock body,
html.site-locked body {
    opacity: 0 !important;
    pointer-events: none;
}
html.site-locked {
    overflow: hidden;
    height: 100%;
}

.site-lock-overlay,
.site-lock-overlay * {
    /* Hardcoded — overlay sits outside <body> so we don't rely on cascade
       or CSS variables for typography */
    font-family: 'Haffer', 'Helvetica Neue', Helvetica, Arial, sans-serif !important;
}
.site-lock-overlay {
    position: fixed;
    inset: 0;
    z-index: 99999;
    background: #ffffff;
    color: #111111;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 48px 24px;
    pointer-events: auto;
    opacity: 1;
    font-size: 15px;
    line-height: 1.5;
    letter-spacing: 0;
    font-weight: 400;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
.site-lock-inner {
    width: 100%;
    max-width: 520px;
    text-align: left;
}
.site-lock-mark {
    font-size: clamp(2.4rem, 6vw, 5.5rem);
    line-height: 0.9;
    letter-spacing: -0.04em;
    margin-bottom: 36px;
    font-weight: 400;
}
.site-lock-message {
    font-size: clamp(1.05rem, 1.7vw, 1.4rem);
    line-height: 1.4;
    letter-spacing: -0.01em;
    color: var(--ink);
    margin-bottom: 48px;
    max-width: 36ch;
}
.site-lock-form {
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin-bottom: 56px;
}
.site-lock-field {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.site-lock-field span {
    font-size: 0.6rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--grey);
}
.site-lock-field input {
    font: inherit;
    font-size: 1rem;
    color: var(--ink);
    background: transparent;
    border: 0;
    border-bottom: 1px solid var(--ink);
    padding: 10px 0;
    outline: none;
    border-radius: 0;
    -webkit-appearance: none;
    appearance: none;
    transition: border-color 0.25s ease;
    font-family: var(--font);
}
.site-lock-field input:focus { border-bottom-color: #ff0099; }

.site-lock-button {
    align-self: flex-start;
    margin-top: 8px;
    padding: 16px 28px;
    background: var(--ink);
    color: var(--paper);
    border: 0;
    cursor: pointer;
    font-size: 0.7rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    transition: background 0.3s var(--ease);
    font-family: var(--font);
}
.site-lock-button:hover { background: #ff0099; }

.site-lock-error {
    font-size: 0.78rem;
    color: #ff0099;
    margin-top: 4px;
}
.site-lock-foot {
    font-size: 0.72rem;
    letter-spacing: 0.04em;
    color: var(--grey);
}
.site-lock-foot a { color: inherit; border-bottom: 1px solid var(--line); text-decoration: none; }
.site-lock-foot a:hover { color: #ff0099; border-bottom-color: #ff0099; }

/* =============== HIRING BANNER ===============
   Slim top strip injected by JS on every internal page when
   siteSettings.hiringTabVisible is true. Sits above the main header
   so the rest of the layout is untouched. */
.hiring-banner {
    position: relative;
    z-index: 250;
    background: var(--ink);
    color: var(--paper);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 10px var(--pad-x);
    font-size: 0.72rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    text-decoration: none;
    transition: background 0.3s var(--ease), color 0.3s var(--ease);
    gap: 14px;
}
.hiring-banner:hover {
    background: #ff0099;
    color: #fff;
}
.hiring-banner .hiring-banner-arrow {
    font-size: 0.85rem;
    letter-spacing: 0;
    text-transform: none;
    transition: transform 0.4s var(--ease);
}
.hiring-banner:hover .hiring-banner-arrow {
    transform: translateX(6px);
}

/* =============== HIRING PAGE =============== */
.hiring-page {
    padding: 0 var(--pad-x) 120px;
    min-height: calc(100vh - 86px);
}

.hiring-intro {
    padding: 12vh 0 8vh;
    max-width: 28ch;
}

.hiring-title {
    font-size: clamp(3rem, 9vw, 11rem);
    line-height: 0.88;
    letter-spacing: -0.045em;
    font-weight: 400;
    margin-bottom: 32px;
}
.hiring-heart {
    color: #ff0099;
    font-style: normal;
}

.hiring-lead {
    font-size: clamp(1.1rem, 1.8vw, 1.55rem);
    line-height: 1.35;
    letter-spacing: -0.01em;
    color: var(--ink);
    max-width: 38ch;
}

.hiring-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.hiring-row {
    display: block;
    border-top: 1px solid var(--line);
}
.hiring-row:last-child { border-bottom: 1px solid var(--line); }

.hiring-row a {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: baseline;
    gap: 32px;
    padding: 28px 0;
    text-decoration: none;
    color: var(--ink);
    transition: padding 0.45s var(--ease), color 0.3s var(--ease);
}
.hiring-row a:hover {
    color: #ff0099;
    padding-left: 16px;
    padding-right: 16px;
}

.hiring-row__title {
    font-size: clamp(1.8rem, 4.5vw, 4.4rem);
    line-height: 1;
    letter-spacing: -0.03em;
    font-weight: 400;
}
.hiring-row__meta {
    font-size: 0.62rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--grey);
    text-align: right;
    transition: color 0.3s var(--ease);
}
.hiring-row a:hover .hiring-row__meta { color: var(--ink); }

.hiring-row__summary {
    grid-column: 1 / -1;
    max-width: 60ch;
    font-size: 0.92rem;
    line-height: 1.55;
    color: var(--grey);
    margin-top: 14px;
}

.hiring-empty {
    padding: 18vh 0;
    color: var(--grey);
    font-style: italic;
    font-size: 1rem;
}

/* =============== JOB DETAIL PAGE =============== */
.job-page {
    padding-bottom: 160px;
    max-width: 880px;
    margin: 0 auto;
    padding-left: var(--pad-x);
    padding-right: var(--pad-x);
}

.job-hero {
    padding: 56px 0 64px;
}

.job-title-display {
    font-size: clamp(2.6rem, 6vw, 5.2rem);
    font-weight: 400;
    line-height: 0.95;
    letter-spacing: -0.035em;
    margin: 24px 0 48px;
}

.job-meta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px 32px;
    max-width: 560px;
}
.job-meta-row {
    display: grid;
    grid-template-columns: 110px 1fr;
    gap: 12px;
    align-items: baseline;
}
.job-meta-row dt {
    font-size: 0.6rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--grey);
}
.job-meta-row dd {
    font-size: 0.92rem;
    color: var(--ink);
}

.job-body { padding-top: 32px; }

.job-summary {
    font-size: clamp(1.1rem, 1.7vw, 1.4rem);
    line-height: 1.45;
    letter-spacing: -0.01em;
    color: var(--ink);
    margin-bottom: 56px;
    max-width: 56ch;
}

.job-description {
    font-size: 0.95rem;
    line-height: 1.7;
    color: var(--ink);
    max-width: 60ch;
    margin-bottom: 56px;
}
.job-description p + p { margin-top: 1em; }

.job-block { margin-bottom: 56px; max-width: 60ch; }

.job-bullets {
    list-style: none;
    margin: 0;
    padding: 0;
}
.job-bullets li {
    font-size: 0.92rem;
    line-height: 1.6;
    color: var(--ink);
    padding: 6px 0 6px 22px;
    position: relative;
}
.job-bullets li::before {
    content: '+';
    position: absolute;
    left: 0;
    top: 6px;
    color: var(--grey);
}

.job-apply {
    margin-top: 24px;
    padding-top: 32px;
    border-top: 1px solid var(--line);
}
.job-apply a.job-apply-button {
    display: inline-block;
    padding: 18px 28px;
    font-size: 0.72rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    text-decoration: none;
    color: var(--paper);
    background: var(--ink);
    transition: background 0.3s var(--ease);
}
.job-apply a.job-apply-button:hover { background: #ff0099; }
.job-apply .job-apply-note {
    display: block;
    margin-top: 14px;
    font-size: 0.75rem;
    color: var(--grey);
}

@media (max-width: 768px) {
    .job-meta { grid-template-columns: 1fr; }
    .hiring-row a { grid-template-columns: 1fr; gap: 8px; }
    .hiring-row__meta { text-align: left; }
}

/* =============== NEWSROOM ===============
   Gated press area. Visitors first see the GATE (request + code), then
   after a successful unlock the INDEX of releases is revealed. */
.newsroom-page {
    padding: 0 var(--pad-x) 160px;
    min-height: calc(100vh - 86px);
}

.newsroom-gate {
    padding: 10vh 0 12vh;
}
.newsroom-gate-inner {
    max-width: 1100px;
}

.newsroom-title {
    font-size: clamp(3rem, 8.5vw, 9.5rem);
    line-height: 0.9;
    letter-spacing: -0.045em;
    font-weight: 400;
    margin: 18px 0 32px;
    max-width: 14ch;
}
.newsroom-title.small {
    font-size: clamp(2.4rem, 6vw, 6rem);
    max-width: none;
    margin-bottom: 0;
}

.newsroom-lead {
    font-size: clamp(1.05rem, 1.7vw, 1.4rem);
    line-height: 1.45;
    letter-spacing: -0.01em;
    color: var(--ink);
    max-width: 48ch;
    margin-bottom: 80px;
}

.newsroom-gate-cols {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px var(--pad-x);
    max-width: 880px;
}

.newsroom-form {
    display: flex;
    flex-direction: column;
    gap: 18px;
    margin-top: 18px;
}

.newsroom-field {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.newsroom-field span {
    font-size: 0.6rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--grey);
}
.newsroom-field input,
.newsroom-field textarea {
    font: inherit;
    font-size: 0.95rem;
    color: var(--ink);
    background: transparent;
    border: 0;
    border-bottom: 1px solid var(--ink);
    padding: 8px 0;
    border-radius: 0;
    outline: none;
    transition: border-color 0.25s ease;
    -webkit-appearance: none;
    appearance: none;
    resize: none;
    font-family: var(--font);
}
.newsroom-field input:focus,
.newsroom-field textarea:focus {
    border-bottom-color: #ff0099;
}

.newsroom-button {
    align-self: flex-start;
    margin-top: 12px;
    padding: 16px 24px;
    background: var(--ink);
    color: var(--paper);
    border: 0;
    cursor: pointer;
    font-size: 0.7rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    transition: background 0.3s var(--ease);
    font-family: var(--font);
}
.newsroom-button:hover { background: #ff0099; }

.newsroom-note {
    font-size: 0.72rem;
    line-height: 1.55;
    color: var(--grey);
    max-width: 36ch;
    margin-top: 4px;
}
.newsroom-error {
    font-size: 0.78rem;
    color: #ff0099;
    margin-top: 4px;
}

/* ── Newsroom INDEX (after unlock) ── */
.newsroom-index { padding: 8vh 0 0; }
.newsroom-index-head {
    display: flex;
    align-items: baseline;
    gap: 32px;
    flex-wrap: wrap;
    margin-bottom: 64px;
}
.newsroom-lock {
    margin-left: auto;
    background: transparent;
    border: 0;
    cursor: pointer;
    font-size: 0.62rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--grey);
    transition: color 0.25s ease;
    padding: 4px 0;
    font-family: var(--font);
}
.newsroom-lock:hover { color: var(--ink); }

.press-list {
    list-style: none;
    margin: 0;
    padding: 0;
}
.press-row {
    border-top: 1px solid var(--line);
}
.press-row:last-child { border-bottom: 1px solid var(--line); }
.press-row a {
    display: grid;
    grid-template-columns: 80px 1fr 1.4fr 100px;
    align-items: baseline;
    gap: 32px;
    padding: 28px 0;
    text-decoration: none;
    color: var(--ink);
    transition: color 0.3s var(--ease), padding 0.45s var(--ease);
}
.press-row a:hover {
    color: #ff0099;
    padding-left: 16px;
    padding-right: 16px;
}
.press-row__date {
    font-size: 0.62rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--grey);
}
.press-row__client {
    font-size: 0.62rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--grey);
    transition: color 0.3s var(--ease);
}
.press-row a:hover .press-row__client { color: var(--ink); }
.press-row__title {
    font-size: clamp(1.2rem, 2.4vw, 2rem);
    line-height: 1.15;
    letter-spacing: -0.02em;
}
.press-row__category {
    font-size: 0.62rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--grey);
    text-align: right;
}

@media (max-width: 900px) {
    .newsroom-gate-cols { grid-template-columns: 1fr; gap: 56px; }
    .press-row a { grid-template-columns: 1fr; gap: 6px; }
    .press-row__category { text-align: left; }
}

/* ── Single press release ── */
.pressrelease-page {
    max-width: 880px;
    margin: 0 auto;
    padding: 0 var(--pad-x) 160px;
}
.press-article-head { padding: 48px 0 56px; }
.press-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 18px;
    font-size: 0.6rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--grey);
    margin-bottom: 32px;
}
.press-meta span:empty { display: none; }

.press-headline {
    font-size: clamp(2.4rem, 5.2vw, 4.8rem);
    line-height: 0.98;
    letter-spacing: -0.035em;
    font-weight: 400;
    margin-bottom: 24px;
}
.press-subtitle {
    font-size: clamp(1.1rem, 1.8vw, 1.45rem);
    line-height: 1.4;
    letter-spacing: -0.01em;
    color: var(--ink);
    max-width: 50ch;
}

.press-cover {
    margin: 0 0 64px;
    background: var(--image-bg);
    aspect-ratio: 16 / 10;
    overflow: hidden;
}
.press-cover img { width: 100%; height: 100%; object-fit: cover; }

.press-body {
    font-size: 1rem;
    line-height: 1.75;
    color: var(--ink);
    max-width: 60ch;
    margin: 0 0 80px;
}
.press-body p + p { margin-top: 1em; }

.press-gallery {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 2px;
    margin: 0 0 80px;
}
.press-gallery figure {
    background: var(--image-bg);
    overflow: hidden;
    margin: 0;
}
.press-gallery img { width: 100%; display: block; }
.press-gallery figcaption {
    font-size: 0.7rem;
    color: var(--grey);
    padding: 8px 0;
    letter-spacing: 0.04em;
}

.press-downloads { margin: 0 0 80px; }
.press-downloads ul {
    list-style: none;
    margin: 18px 0 0;
    padding: 0;
}
.press-downloads li {
    border-top: 1px solid var(--line);
}
.press-downloads li:last-child { border-bottom: 1px solid var(--line); }
.press-downloads a {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: 18px 0;
    text-decoration: none;
    color: var(--ink);
    font-size: 0.92rem;
    transition: color 0.25s ease;
}
.press-downloads a:hover { color: #ff0099; }
.press-downloads a::after {
    content: 'Download ↓';
    font-size: 0.6rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--grey);
}

.press-contact {
    border-top: 1px solid var(--line);
    padding: 32px 0 0;
    font-size: 0.92rem;
    line-height: 1.65;
    color: var(--ink);
}
.press-contact a { color: inherit; border-bottom: 1px solid var(--line); text-decoration: none; }
.press-contact a:hover { border-bottom-color: #ff0099; color: #ff0099; }

.press-contact-body {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 32px;
    margin-top: 18px;
}
.press-contact-card {
    font-size: 0.9rem;
    line-height: 1.55;
}
.press-contact-name {
    font-size: 0.95rem;
    color: var(--ink);
    margin-bottom: 2px;
}
.press-contact-role {
    font-size: 0.62rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--grey);
    margin-bottom: 8px;
}

@media (max-width: 768px) {
    .press-gallery { grid-template-columns: 1fr; }
}

/* =============== FOOTER =============== */
.site-footer {
    border-top: 1px solid var(--line);
    padding: 64px var(--pad-x) 56px;
}

.footer-inner {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr;
    gap: 32px;
    align-items: start;
}

.footer-col {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.footer-label {
    font-size: 0.6rem;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    color: var(--grey);
    margin-bottom: 6px;
}

.footer-inner a,
.footer-inner span.footer-line {
    font-size: 0.82rem;
    letter-spacing: 0;
    text-decoration: none;
    color: var(--ink);
    transition: opacity 0.2s ease;
}
.footer-inner a:hover { opacity: 0.55; }

.footer-bottom {
    margin-top: 64px;
    padding-top: 24px;
    border-top: 1px solid var(--line);
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    font-size: 0.62rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--grey);
}
.footer-brand {
    text-transform: none;
    letter-spacing: -0.01em;
    font-size: 1.05rem;
    color: var(--ink);
    text-decoration: none;
    transition: color 0.3s ease;
}
.footer-brand:hover { color: #ff0099; }

/* =============== ANIM =============== */
.fade-up {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 0.9s var(--ease), transform 0.9s var(--ease);
    will-change: opacity, transform;
}
.fade-up.visible {
    opacity: 1;
    transform: none;
}

/* =============== CURSOR ===============
   Text cursor: shows "<3" on Work and "<33" on Artists.
   No background — pure typography that follows the pointer. */
#custom-cursor {
    position: fixed;
    top: 0;
    left: 0;
    pointer-events: none;
    z-index: 9999;
    font-family: var(--font);
    font-weight: 400;
    line-height: 1;
    background: transparent;
    transform: translate(-50%, -50%) scale(0);
    opacity: 0;
    transition: transform 0.25s var(--ease), opacity 0.25s ease;
    mix-blend-mode: difference;
    color: #fff;
    white-space: nowrap;
    font-size: 1.6rem;
    letter-spacing: -0.02em;
}

#custom-cursor.active {
    transform: translate(-50%, -50%) scale(1);
    opacity: 1;
}

/* Custom text cursor is always visible on every internal page (not landing).
   Defaults to <3, switches to <33 on Artists. */
body:not(.landing-page) #custom-cursor {
    transform: translate(-50%, -50%) scale(1);
    opacity: 1;
}

#custom-cursor                     { font-size: 1.6rem; }
body.page-artists #custom-cursor   { font-size: 2rem; }

/* =============== LOADING =============== */
.cases-loading,
.artists-loading {
    height: 60vh;
}

/* =============== RESPONSIVE =============== */
@media (max-width: 1100px) {
    :root { --pad-x: var(--pad-x-md); }
    header { padding: 28px var(--pad-x); }
    nav { gap: 28px; }
    .case-hero { grid-template-columns: 1fr; gap: 48px; padding: 40px var(--pad-x) 64px; }
    .artist-hero { grid-template-columns: 1fr; gap: 40px; padding: 32px var(--pad-x) 64px; }
    .project-credits { grid-template-columns: repeat(2, 1fr); }
    .case-services { grid-template-columns: repeat(2, 1fr); }
}

/* =====================================================
   MOBILE — comprehensive pass. Editorial language on
   small screens: tight inline header, generous padding,
   centered landing, type that scales without overflow.
   ===================================================== */
@media (max-width: 768px) {
    :root { --pad-x: 20px; }
    body { font-size: 14px; line-height: 1.55; }

    /* ── Header: nav stacked AT TOP, big editorial logo below.
         Editorial mobile layout — like high-end fashion sites. ── */
    header {
        flex-direction: column;
        align-items: stretch;
        gap: 18px;
        padding: 16px var(--pad-x) 18px;
    }
    nav {
        order: -1; /* nav goes ABOVE the logo */
        display: flex;
        justify-content: space-between;
        gap: 6px;
        align-self: stretch;
        flex-wrap: nowrap;
        width: 100%;
    }
    nav a {
        font-size: 0.55rem;
        letter-spacing: 0.1em;
        white-space: nowrap;
        flex: 0 0 auto;
    }
    .logo-small {
        font-size: clamp(2.6rem, 11vw, 4rem);
        line-height: 0.85;
        letter-spacing: -0.04em;
    }

    /* Hide custom cursor — no pointer on touch devices */
    #custom-cursor { display: none !important; }
    .hover-preview { display: none !important; }

    /* ── Hiring banner ── */
    .hiring-banner {
        font-size: 0.62rem;
        letter-spacing: 0.16em;
        padding: 9px var(--pad-x);
        gap: 10px;
    }

    /* ── Landing: stack Work + Artist vertically, centered, same size ── */
    body.landing-page {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        gap: 8px;
        padding: 0;
    }
    .landing-word,
    .landing-word.left,
    .landing-word.right {
        position: static;
        top: auto;
        left: auto;
        right: auto;
        font-size: clamp(5rem, 30vw, 12rem);
        line-height: 0.88;
        letter-spacing: -0.03em;
        text-align: center;
        white-space: nowrap;
    }
    .landing-footer {
        position: absolute;
        left: var(--pad-x);
        right: var(--pad-x);
        bottom: 26px;
        gap: 24px;
        justify-content: space-between;
    }
    .landing-mark, .landing-year {
        font-size: 0.95rem;
    }

    /* ── Page title ── */
    .page-title { padding: 8vh 0 6vh; }

    /* ── Work index (cases.html) ── */
    .index-list { padding: 24px var(--pad-x) 24px; }
    .index-row a {
        cursor: pointer;
        font-size: clamp(1.6rem, 8vw, 2.6rem);
        gap: 14px;
        align-items: center;
    }
    .index-row .row-meta { display: none; }
    .index-row .row-title {
        white-space: normal;
        text-overflow: clip;
        overflow: visible;
        line-height: 1.05;
    }

    /* ── Artists list ── */
    .artists-page { padding: 0 var(--pad-x) 64px; }
    .artists-list .index-row a {
        line-height: 1.05;
        letter-spacing: -0.035em;
    }

    /* ── Project / case-study detail ── */
    .case-hero {
        grid-template-columns: 1fr;
        gap: 36px;
        padding: 32px var(--pad-x) 56px;
    }
    .case-title-display {
        font-size: clamp(2.2rem, 9vw, 3.6rem);
        margin-bottom: 36px;
    }
    .case-overview { font-size: 0.95rem; margin-bottom: 40px; }
    .case-services { padding-top: 8px; }
    .services-list { grid-template-columns: 1fr; gap: 4px; }
    .case-hero-image { aspect-ratio: 4 / 5; }

    .project-blocks { gap: 1px; }
    .project-block.half { flex: 0 0 100%; }
    .case-info { padding: 20px var(--pad-x) 56px; }
    .case-disciplines { display: none; }
    .project-credits {
        grid-template-columns: 1fr;
        margin: 56px var(--pad-x) 0;
        padding: 48px 0 0;
        gap: 18px;
    }

    /* ── Artist detail ── */
    .artist-hero {
        grid-template-columns: 1fr;
        gap: 32px;
        padding: 28px var(--pad-x) 48px;
    }
    .artist-name { font-size: clamp(2rem, 9vw, 3.4rem); margin-bottom: 24px; }
    .artist-meta { padding-top: 0; }
    .platforms-list { grid-template-columns: 1fr; max-width: none; }
    .artist-inline-meta { max-width: none; margin: 8px 0 36px; }
    .artist-inline-meta .artist-meta-row {
        grid-template-columns: 100px 1fr;
        gap: 12px;
        font-size: 0.78rem;
    }

    /* ── Artist grid (legacy) ── */
    .artist-grid { grid-template-columns: 1fr; gap: 40px var(--pad-x); }

    /* ── Editorial / About ── */
    .editorial-section,
    .editorial-section.center,
    .editorial-section.left,
    .editorial-section.right {
        padding: 56px var(--pad-x);
        text-align: left;
    }
    .editorial-section.right .editorial-body,
    .editorial-section.right .editorial-lead,
    .editorial-section.left .editorial-body,
    .editorial-section.left .editorial-lead {
        margin-left: 0;
        margin-right: 0;
    }
    .editorial-display { font-size: clamp(2rem, 9vw, 3.2rem); max-width: none; }
    .editorial-display.left,
    .editorial-display.right { text-align: left; margin-left: 0; }
    .editorial-lead { font-size: clamp(1.15rem, 5vw, 1.5rem); max-width: none; }
    .editorial-body { font-size: 0.95rem; max-width: none; }
    .editorial-split { grid-template-columns: 1fr; gap: 28px; }
    .about-figure { max-width: 100%; margin-top: 36px; }
    .about-figure.wide { max-width: 100%; }
    #showroom-figure { margin-left: 0; }
    .client-list { columns: 1; }
    .office-grid { grid-template-columns: 1fr; }

    /* ── Contact ── */
    .contact-page { padding: 0 var(--pad-x) 80px; }
    .contact-display { padding: 12vh 0 8vh; }
    .contact-display h1 {
        font-size: clamp(3rem, 16vw, 5.6rem);
        line-height: 0.85;
    }
    .contact-row {
        grid-template-columns: 1fr;
        gap: 4px;
        padding: 14px 0;
    }
    .contact-row__value { font-size: clamp(1.4rem, 7vw, 2rem); }
    .contact-row:hover { transform: none; }
    .contact-bottom {
        grid-template-columns: 1fr;
        gap: 36px;
        padding-top: 48px;
    }

    /* ── Hiring index ── */
    .hiring-page { padding: 0 var(--pad-x) 80px; }
    .hiring-intro { padding: 8vh 0 6vh; max-width: none; }
    .hiring-title { font-size: clamp(2.6rem, 13vw, 4.6rem); margin-bottom: 24px; }
    .hiring-lead { font-size: clamp(1rem, 4.4vw, 1.25rem); max-width: none; }
    .hiring-row a {
        grid-template-columns: 1fr;
        gap: 8px;
        padding: 22px 0;
    }
    .hiring-row a:hover {
        padding-left: 0;
        padding-right: 0;
    }
    .hiring-row__title { font-size: clamp(1.6rem, 7vw, 2.4rem); }
    .hiring-row__meta { text-align: left; }

    /* ── Job detail ── */
    .job-page { padding-bottom: 96px; }
    .job-hero { padding: 36px 0 48px; }
    .job-title-display { font-size: clamp(2rem, 9vw, 3.4rem); margin: 18px 0 32px; }
    .job-meta { grid-template-columns: 1fr; gap: 12px; }
    .job-meta-row { grid-template-columns: 100px 1fr; gap: 10px; }
    .job-summary { font-size: clamp(1.05rem, 4.4vw, 1.2rem); margin-bottom: 40px; }
    .job-description { margin-bottom: 40px; }
    .job-block { margin-bottom: 40px; }
    .job-apply-button { width: 100%; text-align: center; }

    /* ── Newsroom gate ── */
    .newsroom-page { padding: 0 var(--pad-x) 80px; }
    .newsroom-gate { padding: 8vh 0 8vh; }
    .newsroom-title { font-size: clamp(2.6rem, 13vw, 5rem); max-width: none; }
    .newsroom-title.small { font-size: clamp(2.2rem, 10vw, 4rem); }
    .newsroom-lead { font-size: clamp(1rem, 4.4vw, 1.25rem); max-width: none; margin-bottom: 56px; }
    .newsroom-gate-cols { grid-template-columns: 1fr; gap: 48px; max-width: none; }
    .newsroom-button { width: 100%; text-align: center; }

    /* ── Press release ── */
    .pressrelease-page { padding: 0 var(--pad-x) 96px; }
    .press-headline { font-size: clamp(2rem, 9vw, 3.4rem); }
    .press-subtitle { font-size: clamp(1.05rem, 4.4vw, 1.3rem); }
    .press-cover { aspect-ratio: 4 / 5; margin-bottom: 48px; }
    .press-body { font-size: 0.95rem; max-width: none; }
    .press-gallery { grid-template-columns: 1fr; }
    .press-row a {
        grid-template-columns: 1fr;
        gap: 4px;
        padding: 22px 0;
    }
    .press-row__date,
    .press-row__category { text-align: left; }

    /* ── Site lock screen ── */
    .site-lock-overlay { padding: 32px 22px; }
    .site-lock-mark { font-size: clamp(2.2rem, 11vw, 3.6rem); margin-bottom: 28px; }
    .site-lock-message { font-size: clamp(1rem, 4.4vw, 1.2rem); margin-bottom: 36px; max-width: none; }
    .site-lock-button { width: 100%; text-align: center; }

    /* ── Footer ── */
    .site-footer { padding: 48px var(--pad-x) 40px; }
    .footer-inner { grid-template-columns: 1fr 1fr; gap: 32px; }
    .footer-bottom { margin-top: 48px; padding-top: 18px; }
}

/* Very small phones (iPhone SE / small Android) */
@media (max-width: 480px) {
    :root { --pad-x: 20px; }
    .footer-inner { grid-template-columns: 1fr; gap: 28px; }
    .footer-bottom { flex-direction: column; align-items: flex-start; gap: 10px; }
    .landing-word.left  { font-size: 19vw; }
    .landing-word.right { font-size: 16vw; }
    nav { gap: 18px; }
    nav a { font-size: 0.6rem; }
}
