/* ═══════════════════════════════════════════════════════════════
   Tina Arjevanidze — Editorial Stylesheet
   A serious cinematographer's monograph, translated to web.
   ═══════════════════════════════════════════════════════════════ */

:root {
    /* Palette — warm cream paper, ink black, oxblood accent */
    --paper:        #F2EDE3;
    --paper-deep:   #ECE5D6;
    --ink:          #15120C;
    --ink-soft:     #3A3528;
    --ink-mute:     #6B6557;
    --ink-faint:    rgba(21, 18, 12, 0.16);
    --ink-hairline: rgba(21, 18, 12, 0.12);
    --oxblood:      #6B2520;
    --oxblood-dim:  #8E3F39;

    /* Type */
    /* Type — Montserrat (the var name stays --serif so existing rules keep working) */
    --serif: 'Montserrat', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;

    /* Spatial */
    --gutter:    clamp(1.5rem, 5vw, 6rem);
    --rule:      1px;

    /* Motion */
    --ease: cubic-bezier(0.65, 0, 0.35, 1);
}

/* ───── Reset & base ───── */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
    margin: 0;
    background: var(--paper);
    color: var(--ink);
    font-family: var(--serif);
    font-size: clamp(15px, 1.05vw + 12px, 17px);
    line-height: 1.55;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: hidden;
}
img, video, iframe { max-width: 100%; display: block; }
img { height: auto; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; background: none; border: 0; color: inherit; padding: 0; }

/* Selection */
::selection { background: var(--ink); color: var(--paper); }

/* ───── Type system ───── */
.eyebrow {
    font-family: var(--serif);
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--ink-mute);
    margin: 0 0 0.5rem;
}

h1, h2, h3, h4 {
    font-family: var(--serif);
    font-weight: 600;
    line-height: 1.04;
    letter-spacing: -0.025em;
    margin: 0;
    color: var(--ink);
}

h1 { font-size: clamp(2.4rem, 7vw, 6.5rem); line-height: 1.0; letter-spacing: -0.03em; }
h2 { font-size: clamp(1.9rem, 4.4vw, 3.6rem); line-height: 1.06; letter-spacing: -0.022em; }
h3 { font-size: clamp(1.4rem, 2.6vw, 2.2rem); line-height: 1.12; letter-spacing: -0.018em; }

/* Emphasis without italic — uses the oxblood accent for color contrast */
em, .italic {
    font-style: normal;
    color: var(--oxblood);
    font-weight: inherit;
}

/* ═══════════════════════════════════════════════════════════════
   MASTHEAD
   ═══════════════════════════════════════════════════════════════ */
.masthead {
    position: sticky;
    top: 0;
    z-index: 100;
    background: var(--paper);
    border-bottom: var(--rule) solid var(--ink-hairline);
    backdrop-filter: saturate(140%) blur(8px);
    background: rgba(242, 237, 227, 0.94);
}

.masthead__inner {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    padding: 1.1rem var(--gutter);
    gap: 2rem;
}

.wordmark {
    font-family: var(--serif);
    font-weight: 600;
    font-size: clamp(0.95rem, 1vw, 1.05rem);
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--ink);
    display: inline-flex;
    align-items: baseline;
    gap: 0;
}
.wordmark__t,
.wordmark__rest {
    font-size: 1em;
    line-height: 1;
}

.primary-nav {
    justify-self: end;
    display: flex;
    gap: clamp(1.4rem, 3vw, 2.6rem);
    align-items: baseline;
}
.nav-link {
    position: relative;
    font-family: var(--serif);
    font-size: 11px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.22em;
    color: var(--ink);
    padding: 0.4rem 0;
    transition: color 0.3s var(--ease);
}
.nav-link::after {
    content: '';
    position: absolute;
    left: 0; right: 0; bottom: 0.2rem;
    height: 1px;
    background: var(--ink);
    transform: scaleX(0);
    transform-origin: right;
    transition: transform 0.4s var(--ease);
}
.nav-link:hover::after,
.nav-link.is-current::after {
    transform: scaleX(1);
    transform-origin: left;
}
.nav-link.is-current { color: var(--ink); }

.nav-toggle {
    display: none;
    width: 28px;
    height: 28px;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
}
.nav-toggle span {
    display: block;
    height: 1px;
    background: var(--ink);
    transition: transform 0.3s var(--ease), opacity 0.3s var(--ease);
}
.nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(3px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { transform: translateY(-3px) rotate(-45deg); }

@media (max-width: 720px) {
    .nav-toggle { display: flex; }
    .primary-nav {
        position: fixed;
        inset: 67px 0 0 0;
        background: var(--paper);
        flex-direction: column;
        align-items: flex-start;
        padding: 3rem var(--gutter);
        gap: 1.4rem;
        opacity: 0;
        pointer-events: none;
        transform: translateY(-8px);
        transition: opacity 0.3s var(--ease), transform 0.3s var(--ease);
    }
    .primary-nav.is-open {
        opacity: 1;
        pointer-events: auto;
        transform: none;
    }
    .nav-link { font-size: 13px; }
}

/* ═══════════════════════════════════════════════════════════════
   WORK INDEX (homepage)
   ═══════════════════════════════════════════════════════════════ */
.work-intro {
    padding: clamp(4rem, 9vw, 9rem) var(--gutter) clamp(3rem, 6vw, 6rem);
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
}
.work-intro__eyebrow {
    font-family: var(--serif);
    font-size: 11px;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    color: var(--ink-mute);
    margin: 0;
    display: flex;
    align-items: center;
    gap: 1rem;
}
.work-intro__eyebrow::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--ink-hairline);
    max-width: 280px;
}
.work-intro__title {
    font-size: clamp(2.4rem, 6.5vw, 6rem);
    line-height: 0.96;
    max-width: 18ch;
    letter-spacing: -0.022em;
}
.work-intro__title em {
}

/* Uniform N-column grid driven by CSS variables (set per-page in views/work.php
   from the gallery_* settings). Defaults preserved if vars not set. */
.work-gallery {
    padding: 0 var(--gutter) clamp(4rem, 8vw, 8rem);
    display: grid;
    grid-template-columns: repeat(var(--gallery-cols, 2), 1fr);
    column-gap: var(--gallery-gap-x, 32px);
    row-gap: var(--gallery-gap-y, 64px);
}

.project-card {
    position: relative;
    display: block;
    text-decoration: none;
    color: inherit;
}
.project-card__media {
    position: relative;
    overflow: hidden;
    background: var(--paper-deep);
    aspect-ratio: 4 / 5;
}
.project-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 1.2s var(--ease), filter 0.6s var(--ease);
    filter: saturate(0.94) contrast(1.02);
}
.project-card:hover .project-card__media img {
    transform: scale(1.025);
    filter: saturate(1.05) contrast(1.04);
}
.project-card__media--placeholder {
    background:
        linear-gradient(135deg, transparent 30%, rgba(21,18,12,.04) 50%, transparent 70%),
        var(--paper-deep);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--serif);
    font-style: normal;
    color: var(--ink-mute);
    font-size: clamp(2rem, 4vw, 3.5rem);
    letter-spacing: -0.02em;
}

.project-card__meta {
    margin-top: 1.1rem;
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.75rem 1.2rem;
    align-items: baseline;
}
.project-card__num {
    font-family: var(--serif);
    font-size: 11px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--ink-mute);
    grid-row: 1 / span 2;
    align-self: start;
    padding-top: 0.25em;
}
.project-card__title {
    font-family: var(--serif);
    font-style: normal;
    font-weight: 600;
    font-size: clamp(1.2rem, 1.8vw, 1.5rem);
    line-height: 1.15;
    letter-spacing: -0.018em;
    margin: 0;
    transition: color 0.3s var(--ease);
}
.project-card:hover .project-card__title {
    color: var(--oxblood);
}
.project-card__sub {
    grid-column: 2;
    font-family: var(--serif);
    font-size: 11px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--ink-mute);
    margin: 0;
}

/* All cards: same column span, same aspect — uniform grid */
.project-card,
.project-card[data-size="s"],
.project-card[data-size="m"],
.project-card[data-size="l"],
.project-card[data-size="xl"] {
    grid-column: span 1;
    margin-top: 0;
}

.project-card .project-card__media,
.project-card[data-size="s"] .project-card__media,
.project-card[data-size="m"] .project-card__media,
.project-card[data-size="l"] .project-card__media,
.project-card[data-size="xl"] .project-card__media {
    aspect-ratio: var(--gallery-aspect, 16 / 10);
}

@media (max-width: 720px) {
    /* Force 1 column on phones regardless of admin setting */
    .work-gallery { grid-template-columns: 1fr !important; row-gap: 2.5rem !important; }
    .project-card .project-card__media,
    .project-card[data-size="s"] .project-card__media,
    .project-card[data-size="m"] .project-card__media,
    .project-card[data-size="l"] .project-card__media,
    .project-card[data-size="xl"] .project-card__media {
        aspect-ratio: 4 / 3;
    }
}

/* Tablet: cap at max 3 columns even if desktop is 4-5 */
@media (min-width: 721px) and (max-width: 1023px) {
    .work-gallery {
        grid-template-columns: repeat(min(var(--gallery-cols, 2), 3), 1fr);
    }
}

/* ═══════════════════════════════════════════════════════════════
   PROJECT DETAIL PAGE
   ═══════════════════════════════════════════════════════════════ */
.project-detail {
    padding: clamp(2rem, 5vw, 5rem) var(--gutter) 0;
}
.project-detail__back {
    font-family: var(--serif);
    font-size: 11px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--ink-mute);
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    transition: color 0.3s var(--ease);
}
.project-detail__back:hover { color: var(--ink); }

.project-detail__header {
    padding: clamp(3rem, 6vw, 5rem) 0 clamp(2rem, 4vw, 4rem);
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
    border-bottom: 1px solid var(--ink-hairline);
}
.project-detail__title {
    font-size: clamp(2.4rem, 7.5vw, 7rem);
    line-height: 0.96;
    max-width: 16ch;
    font-style: normal;
    letter-spacing: -0.025em;
}
.project-detail__excerpt {
    font-size: clamp(1.1rem, 1.7vw, 1.45rem);
    max-width: 56ch;
    line-height: 1.4;
    color: var(--ink-soft);
    margin: 0;
}
.project-detail__meta {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 2rem;
    padding: 2rem 0;
    border-bottom: 1px solid var(--ink-hairline);
}
.project-detail__meta dt {
    font-family: var(--serif);
    font-size: 10px;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    color: var(--ink-mute);
    margin: 0 0 0.5rem;
}
.project-detail__meta dd {
    margin: 0;
    font-size: 0.95rem;
    color: var(--ink);
}

.project-hero {
    margin: clamp(3rem, 6vw, 5rem) 0;
    display: flex;
    justify-content: center;
}
.project-hero > * { width: 100%; }
.project-hero img {
    width: 100%;
    height: auto;
}
/* Vertical / square hero — constrain max-width so it doesn't dominate the page */
.project-hero--9-16,
.project-hero--3-4,
.project-hero--4-5 {
    padding: 0 var(--gutter);
}
.project-hero--9-16 > * { max-width: 420px; margin: 0 auto; }
.project-hero--1-1  > *,
.project-hero--3-4  > *,
.project-hero--4-5  > * { max-width: 720px; margin: 0 auto; }

.project-description {
    max-width: 60ch;
    margin: clamp(3rem, 6vw, 5rem) auto;
    padding: 0 var(--gutter);
}
.project-description p {
    font-size: clamp(1rem, 1.3vw, 1.15rem);
    line-height: 1.65;
    color: var(--ink-soft);
    margin: 0 0 1.4em;
}
.project-description p:first-child::first-letter {
    font-size: 4.6em;
    line-height: 0.85;
    float: left;
    margin: 0.05em 0.12em -0.05em 0;
    font-style: normal;
    color: var(--oxblood);
}

.project-gallery {
    padding: clamp(2rem, 4vw, 4rem) var(--gutter) clamp(4rem, 8vw, 7rem);
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    column-gap: var(--proj-gap-x, clamp(1rem, 2.5vw, 2rem));
    row-gap: var(--proj-gap-y, clamp(1rem, 2.5vw, 2rem));
    align-items: start;
}

/* Uniform mode — overrides per-item layouts, every item spans 1 of N columns */
.project-gallery--uniform {
    grid-template-columns: repeat(var(--proj-cols, 2), 1fr);
}
.project-gallery--uniform .project-gallery__item,
.project-gallery--uniform .project-gallery__item[data-layout] {
    grid-column: span 1 !important;
}
.project-gallery__item { display: block; }
.project-gallery__item[data-layout="full"]      { grid-column: span 12; }
.project-gallery__item[data-layout="two-third"] { grid-column: span 8; }
.project-gallery__item[data-layout="half"]      { grid-column: span 6; }
.project-gallery__item[data-layout="one-third"] { grid-column: span 4; }
.project-gallery__item[data-layout="quarter"]   { grid-column: span 3; }

/* Image fits its container — actual aspect comes from the inline style attribute set by PHP */
.project-gallery__item img {
    width: 100%;
    height: auto;
    display: block;
}

/* Vertical media (9:16) inside a wider layout cell — center, don't stretch */
.project-gallery__item[data-aspect="9:16"] .video-embed,
.project-gallery__item[data-aspect="9:16"] img {
    max-width: 360px;
    margin: 0 auto;
    display: block;
}
.project-gallery__caption {
    margin-top: 0.7rem;
    font-family: var(--serif);
    font-size: 11px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--ink-mute);
}

@media (max-width: 1024px) {
    .project-gallery__item[data-layout="quarter"]   { grid-column: span 6; }
    .project-gallery__item[data-layout="one-third"] { grid-column: span 6; }
    .project-gallery__item[data-layout="two-third"] { grid-column: span 12; }
}

@media (max-width: 720px) {
    .project-gallery { grid-template-columns: 1fr; gap: 1.5rem; }
    .project-gallery__item { grid-column: 1 / -1 !important; }
}

.video-embed {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9; /* default — overridden by inline style for vertical/square */
    background: #000;
    overflow: hidden;
}
.video-embed iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
}
.native-video {
    width: 100%;
    height: auto;
    background: #000;
}

.project-nav {
    border-top: 1px solid var(--ink-hairline);
    padding: clamp(3rem, 5vw, 5rem) var(--gutter);
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
}
.project-nav a {
    display: block;
    transition: color 0.3s var(--ease);
}
.project-nav a:hover { color: var(--oxblood); }
.project-nav__dir {
    font-family: var(--serif);
    font-size: 11px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--ink-mute);
    margin-bottom: 0.5rem;
}
.project-nav__title {
    font-style: normal;
    font-size: clamp(1.4rem, 2.5vw, 2rem);
}
.project-nav .next { text-align: right; }

/* ═══════════════════════════════════════════════════════════════
   SERVICES
   ═══════════════════════════════════════════════════════════════ */
.services-intro {
    padding: clamp(4rem, 9vw, 9rem) var(--gutter) clamp(2rem, 4vw, 4rem);
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
}
.services-intro__title {
    font-size: clamp(2.2rem, 5.5vw, 5rem);
    max-width: 22ch;
}
.services-intro__lede {
    max-width: 56ch;
    font-size: clamp(1.05rem, 1.4vw, 1.25rem);
    line-height: 1.45;
    color: var(--ink-soft);
    margin: 0;
}

.tiers {
    padding: 0 var(--gutter) clamp(4rem, 8vw, 8rem);
    display: grid;
    grid-template-columns: 1fr;
}

.tier {
    display: grid;
    grid-template-columns: 1fr 2fr 1fr;
    gap: clamp(1.5rem, 4vw, 4rem);
    padding: clamp(2.5rem, 5vw, 4rem) 0;
    border-top: 1px solid var(--ink-hairline);
    align-items: start;
}
.tier:last-child { border-bottom: 1px solid var(--ink-hairline); }

.tier__num {
    font-family: var(--serif);
    font-style: normal;
    font-size: clamp(3rem, 7vw, 6.5rem);
    line-height: 0.85;
    color: var(--ink);
    letter-spacing: -0.03em;
}
.tier__num small {
    display: block;
    font-style: normal;
    font-size: 11px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--ink-mute);
    margin-top: 1rem;
    line-height: 1;
}

.tier__body { padding-top: 0.5rem; }
.tier__title {
    font-size: clamp(1.7rem, 3vw, 2.6rem);
    line-height: 1;
    margin: 0 0 0.4rem;
    letter-spacing: -0.012em;
}
.tier__subtitle {
    font-style: normal;
    color: var(--ink-mute);
    font-size: 1.05rem;
    margin: 0 0 1.4rem;
}
.tier__desc {
    color: var(--ink-soft);
    font-size: 1rem;
    line-height: 1.55;
    max-width: 50ch;
    margin: 0 0 1.8rem;
}
.tier__features {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.5rem 1.5rem;
}
.tier__features li {
    position: relative;
    padding-left: 1.1rem;
    font-size: 0.92rem;
    color: var(--ink-soft);
    line-height: 1.5;
}
.tier__features li::before {
    content: '—';
    position: absolute;
    left: 0;
    color: var(--ink-faint);
}

.tier__price {
    text-align: right;
    padding-top: 0.8rem;
}
.tier__price-label {
    font-family: var(--serif);
    font-size: 11px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--ink-mute);
    margin: 0 0 0.4rem;
}
.tier__price-value {
    font-style: normal;
    font-size: clamp(1.2rem, 1.8vw, 1.5rem);
    margin: 0 0 1.4rem;
}
.tier__cta {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    font-family: var(--serif);
    font-size: 11px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--ink);
    border-bottom: 1px solid var(--ink);
    padding-bottom: 0.3rem;
    transition: color 0.3s var(--ease), border-color 0.3s var(--ease);
}
.tier__cta:hover {
    color: var(--oxblood);
    border-color: var(--oxblood);
}

@media (max-width: 880px) {
    .tier { grid-template-columns: auto 1fr; gap: 1.5rem; }
    .tier__features { grid-template-columns: 1fr; }
    .tier__price {
        grid-column: 1 / -1;
        text-align: left;
        padding-top: 0;
        border-top: 1px solid var(--ink-hairline);
        padding-top: 1.5rem;
        display: flex;
        justify-content: space-between;
        align-items: center;
    }
    .tier__price > * { margin: 0; }
}

/* ═══════════════════════════════════════════════════════════════
   ABOUT
   ═══════════════════════════════════════════════════════════════ */
.about {
    padding: clamp(3rem, 6vw, 6rem) var(--gutter) clamp(4rem, 8vw, 8rem);
    display: grid;
    grid-template-columns: 1fr;
    gap: clamp(2rem, 5vw, 4rem);
    max-width: 1300px;
    margin: 0 auto;
}
.about__photo {
    grid-column: 1;
    aspect-ratio: 3 / 4;
    background: var(--paper-deep);
    overflow: hidden;
    position: relative;
}
.about__photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: saturate(0.95) contrast(1.02);
}
.about__photo--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--serif);
    font-style: normal;
    color: var(--ink-mute);
    font-size: 6rem;
}
.about__text {
    max-width: 60ch;
}
.about__eyebrow {
    font-family: var(--serif);
    font-size: 11px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--ink-mute);
    margin: 0 0 1.5rem;
    display: flex;
    align-items: center;
    gap: 1rem;
}
.about__eyebrow::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--ink-hairline);
    max-width: 200px;
}
.about__headline {
    font-size: clamp(1.9rem, 4.5vw, 3.6rem);
    line-height: 1.05;
    margin: 0 0 2rem;
    letter-spacing: -0.014em;
    font-style: normal;
}
.about__bio p {
    font-size: clamp(1rem, 1.3vw, 1.12rem);
    line-height: 1.65;
    color: var(--ink-soft);
    margin: 0 0 1.4em;
}

@media (min-width: 880px) {
    .about {
        grid-template-columns: 5fr 6fr;
        align-items: start;
    }
    .about__photo { position: sticky; top: 100px; }
}

/* ═══════════════════════════════════════════════════════════════
   CONTACT
   ═══════════════════════════════════════════════════════════════ */
.contact {
    padding: clamp(3rem, 6vw, 6rem) var(--gutter) clamp(4rem, 8vw, 8rem);
    max-width: 1300px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr;
    gap: clamp(2rem, 5vw, 5rem);
}
.contact__intro {}
.contact__title {
    font-size: clamp(2.2rem, 6vw, 5.5rem);
    margin: 1rem 0;
    line-height: 0.96;
    letter-spacing: -0.022em;
}
.contact__lede {
    font-size: clamp(1rem, 1.4vw, 1.2rem);
    color: var(--ink-soft);
    line-height: 1.5;
    max-width: 50ch;
    margin: 0 0 2.5rem;
}
.contact__channels {
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--ink-hairline);
}
.contact__channel {
    display: flex;
    align-items: baseline;
    gap: 1rem;
}
.contact__channel-label {
    font-family: var(--serif);
    font-size: 10px;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    color: var(--ink-mute);
    width: 80px;
    flex-shrink: 0;
}
.contact__channel-value {
    font-style: normal;
    font-size: 1.1rem;
}
.contact__channel a {
    border-bottom: 1px solid var(--ink-hairline);
    transition: color 0.3s var(--ease), border-color 0.3s var(--ease);
}
.contact__channel a:hover {
    color: var(--oxblood);
    border-color: var(--oxblood);
}

/* Form */
.contact-form {
    display: grid;
    gap: 0;
    padding: 0;
    align-self: start;
}
.field {
    border-bottom: 1px solid var(--ink-hairline);
    padding: 1.4rem 0 1.1rem;
    position: relative;
}
.field label {
    display: block;
    font-family: var(--serif);
    font-size: 10px;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    color: var(--ink-mute);
    margin-bottom: 0.6rem;
}
.field input,
.field textarea {
    width: 100%;
    border: 0;
    background: transparent;
    font-family: var(--serif);
    font-size: clamp(1.1rem, 1.5vw, 1.3rem);
    color: var(--ink);
    padding: 0;
    resize: vertical;
    outline: none;
    line-height: 1.4;
}
.field input::placeholder,
.field textarea::placeholder {
    color: var(--ink-faint);
    font-style: normal;
}
.field textarea { min-height: 120px; }
.field--honeypot {
    position: absolute;
    left: -9999px;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

.form-submit {
    margin-top: 2rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}
.btn {
    display: inline-flex;
    align-items: center;
    gap: 0.7rem;
    font-family: var(--serif);
    font-size: 11px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--paper);
    background: var(--ink);
    padding: 1rem 1.6rem;
    border: 1px solid var(--ink);
    transition: background 0.3s var(--ease), color 0.3s var(--ease);
}
.btn:hover { background: var(--oxblood); border-color: var(--oxblood); }
.btn[disabled] { opacity: 0.5; cursor: wait; }

.form-status {
    font-style: normal;
    font-size: 0.95rem;
    color: var(--ink-mute);
}
.form-status.is-success { color: var(--ink); }
.form-status.is-error   { color: var(--oxblood); }

@media (min-width: 880px) {
    .contact { grid-template-columns: 5fr 6fr; }
}

/* ═══════════════════════════════════════════════════════════════
   COLOPHON / FOOTER
   ═══════════════════════════════════════════════════════════════ */
.colophon {
    border-top: 1px solid var(--ink-hairline);
    padding: clamp(3rem, 5vw, 5rem) var(--gutter) clamp(2rem, 3vw, 3rem);
    background: var(--paper);
}
.colophon__inner {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 2rem;
    max-width: 1400px;
    margin: 0 auto;
}
.colophon__col--brand .colophon__name {
    font-size: clamp(1.5rem, 2.5vw, 2.1rem);
    margin: 0 0 0.5rem;
    line-height: 1;
}
.colophon__col--brand .colophon__tag {
    font-family: var(--serif);
    font-size: 10px;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    color: var(--ink-mute);
    margin: 0;
}
.colophon__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}
.colophon__list a {
    transition: color 0.3s var(--ease);
}
.colophon__list a:hover { color: var(--oxblood); }
.colophon__meta {
    font-family: var(--serif);
    font-size: 0.85rem;
    color: var(--ink-mute);
    margin: 0 0 0.4rem;
    line-height: 1.5;
}

/* ═══════════════════════════════════════════════════════════════
   404
   ═══════════════════════════════════════════════════════════════ */
.notfound {
    padding: clamp(5rem, 12vw, 12rem) var(--gutter);
    text-align: center;
    max-width: 600px;
    margin: 0 auto;
}
.notfound__num {
    font-style: normal;
    font-size: clamp(6rem, 18vw, 14rem);
    line-height: 0.9;
    color: var(--oxblood);
    margin: 0 0 1rem;
}
.notfound__msg {
    font-size: clamp(1.1rem, 1.6vw, 1.3rem);
    color: var(--ink-soft);
    margin: 0 0 2rem;
}

/* ═══════════════════════════════════════════════════════════════
   PAGE LOAD ANIMATION (subtle, single moment)
   ═══════════════════════════════════════════════════════════════ */
@media (prefers-reduced-motion: no-preference) {
    .work-intro > *,
    .project-detail__header > *,
    .services-intro > *,
    .about > *,
    .contact > * {
        opacity: 0;
        transform: translateY(12px);
        animation: rise 0.8s var(--ease) forwards;
    }
    .work-intro > *:nth-child(1),
    .project-detail__header > *:nth-child(1),
    .services-intro > *:nth-child(1),
    .about > *:nth-child(1),
    .contact > *:nth-child(1) { animation-delay: 0.05s; }
    .work-intro > *:nth-child(2),
    .project-detail__header > *:nth-child(2),
    .services-intro > *:nth-child(2),
    .about > *:nth-child(2),
    .contact > *:nth-child(2) { animation-delay: 0.18s; }
    .work-intro > *:nth-child(3),
    .project-detail__header > *:nth-child(3),
    .services-intro > *:nth-child(3),
    .about > *:nth-child(3),
    .contact > *:nth-child(3) { animation-delay: 0.30s; }

    .project-card {
        opacity: 0;
        transform: translateY(20px);
        transition: opacity 1s var(--ease), transform 1s var(--ease);
    }
    .project-card.is-visible {
        opacity: 1;
        transform: none;
    }
}

@keyframes rise {
    to { opacity: 1; transform: none; }
}

/* ═══════════════════════════════════════════════════════════════
   MONTSERRAT TUNING — display weights for elements that previously
   used italic to feel intentional. Sans needs weight + tracking
   instead of italic flourish.
   ═══════════════════════════════════════════════════════════════ */
.project-detail__title,
.about__headline,
.contact__title,
.notfound__num {
    font-weight: 700;
    letter-spacing: -0.03em;
}

.project-card__title,
.project-nav__title,
.tier__title,
.colophon__col--brand .colophon__name {
    font-weight: 600;
    letter-spacing: -0.018em;
}

.tier__num,
.tier__price-value,
.contact__channel-value {
    font-weight: 700;
    letter-spacing: -0.02em;
}

.tier__subtitle {
    font-weight: 500;
}

/* Em emphasis — replaces italic with oxblood color, applied everywhere */
.work-intro__title em,
.contact__title em,
.about__headline em,
.tier__num em,
h1 em, h2 em, h3 em, h4 em {
    color: var(--oxblood);
    font-style: normal;
}

/* Drop cap on project description — make it bold sans rather than italic serif */
.project-description p:first-child::first-letter {
    font-size: 4em;
    line-height: 0.85;
    float: left;
    margin: 0.05em 0.15em -0.05em 0;
    font-weight: 700;
    color: var(--oxblood);
    letter-spacing: -0.04em;
}

/* Body copy — Montserrat needs slightly tighter line-height than the serif default */
body { line-height: 1.6; }
.project-description p,
.about__bio p { line-height: 1.7; }

/* ═══════════════════════════════════════════════════════════════
   MOBILE PASS — comprehensive small-screen tuning
   Apple HIG: 44px tap targets, no horizontal scroll, generous
   line-height. Tested at 320px, 375px, 414px, 768px.
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 720px) {
    :root {
        --gutter: 1.25rem;
    }

    /* Masthead — tighter nav row */
    .masthead__inner {
        padding: 0.85rem var(--gutter);
        gap: 0.5rem;
    }
    .wordmark {
        font-size: 0.9rem;
        letter-spacing: 0.16em;
    }

    /* Project detail — keep meta readable, ensure description not cramped */
    .project-detail__meta {
        grid-template-columns: 1fr 1fr;
        gap: 1rem;
        padding: 1.5rem 0;
    }
    .project-detail__title {
        font-size: clamp(2rem, 9vw, 3.5rem);
    }

    /* Project description: smaller drop cap on phones */
    .project-description p:first-child::first-letter {
        font-size: 3.4em;
        margin: 0.04em 0.1em -0.04em 0;
    }

    /* Project nav — stack on phones */
    .project-nav {
        grid-template-columns: 1fr;
        gap: 1.5rem;
    }
    .project-nav .next { text-align: left; }

    /* Tier (services) page already stacks — make sure features don't touch edges */
    .tier {
        padding: 2rem 0;
    }
    .tier__num {
        font-size: clamp(2.5rem, 14vw, 5rem);
    }

    /* About — sticky photo unsticks on mobile */
    .about__photo { position: static !important; max-height: 60vh; }

    /* Contact — labels above inputs feel generous on phone */
    .field {
        padding: 1rem 0 0.9rem;
    }
    .field input,
    .field textarea {
        font-size: 1rem;
    }

    /* Form submit row — tap target sizing */
    .btn {
        padding: 0.95rem 1.4rem;
        min-height: 44px;
    }

    /* Hide animation entrance shifts on mobile to feel snappier */
    .work-intro > *,
    .project-detail__header > *,
    .services-intro > *,
    .about > *,
    .contact > * {
        animation-duration: 0.4s;
    }

    /* Footer — looser */
    .colophon__inner {
        gap: 1.5rem;
    }
    .colophon__col {
        padding: 0;
    }

    /* 404 — smaller numerals so no horizontal scroll */
    .notfound__num {
        font-size: clamp(4rem, 28vw, 8rem);
    }

    /* Universal: never let an image or video overflow a constrained parent */
    img, video, iframe { max-width: 100%; }
}

/* Very narrow phones (e.g. iPhone SE 320px) */
@media (max-width: 380px) {
    :root { --gutter: 1rem; }
    .project-detail__meta { grid-template-columns: 1fr; }
    .nav-link { font-size: 12px; }
}

/* Tap targets — ensure buttons and links meet HIG 44×44pt minimum on touch */
@media (hover: none) and (pointer: coarse) {
    .nav-link {
        padding: 0.75rem 0.5rem;
    }
    .colophon__list a,
    .actions a,
    .actions button {
        padding: 0.5rem 0;
        display: inline-block;
        min-height: 32px;
    }
    .tier__cta {
        padding: 0.6rem 0;
    }
}
