:root {
    --bg: #f2eee8;
    --surface: #fbf8f3;
    --surface-strong: #ffffff;
    --surface-muted: #efe8dc;
    --ink: #1d1a16;
    --ink-soft: #645d56;
    --line: #d6cec0;
    --line-strong: #b7ab98;
    --accent: #2e2924;
    --accent-strong: #14110d;
    --accent-soft: rgba(46, 41, 36, 0.08);
    --danger: #be123c;
    --shadow-soft: 0 14px 30px rgba(34, 30, 24, 0.08);
    --shadow-card: 0 22px 44px rgba(34, 30, 24, 0.12);
    --radius-sm: 8px;
    --radius-md: 12px;
    --radius-lg: 18px;
    --content-width: 1180px;
    --content-narrow: 760px;
    --page-gutter: 2rem;
    --page-gutter-narrow: 2rem;
    --space-1: 0.25rem;
    --space-2: 0.5rem;
    --space-3: 0.75rem;
    --space-4: 1rem;
    --space-5: 1.5rem;
    --space-6: 2rem;
    --space-7: 3rem;
    --space-8: 4rem;
    --space-9: 6rem;
    --mobile-nav-height: 0px;
    --font-sans: 'Sora', sans-serif;
    --font-serif: 'Cormorant Garamond', Georgia, serif;
}

* {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    color: var(--ink);
    background:
        radial-gradient(circle at 6% 3%, rgba(140, 122, 102, 0.14), transparent 32%),
        radial-gradient(circle at 95% 3%, rgba(186, 168, 148, 0.2), transparent 26%),
        var(--bg);
    font-family: var(--font-sans);
    line-height: 1.6;
    min-height: 100vh;
}

img {
    max-width: 100%;
    display: block;
}

a {
    color: inherit;
    text-decoration: none;
    transition: color 180ms ease, opacity 180ms ease, border-color 180ms ease, transform 180ms ease;
}

@media (hover: hover) and (pointer: fine) {
    a:hover {
        color: var(--accent-strong);
    }
}

.page-loader {
    position: fixed;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2000;
    opacity: 0;
    pointer-events: none;
    transition: opacity 160ms ease;
}

.page-loader.htmx-request,
.htmx-request .page-loader {
    opacity: 1;
    pointer-events: auto;
}

.page-loader__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(242, 238, 232, 0.68);
    backdrop-filter: blur(3px);
}

.page-loader__spinner {
    width: 2.2rem;
    height: 2.2rem;
    border-radius: 999px;
    border: 3px solid rgba(46, 41, 36, 0.2);
    border-top-color: var(--accent);
    animation: spin 0.85s linear infinite;
    position: relative;
    z-index: 1;
}

.page-loader.htmx-request {
    cursor: progress;
}

@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}

/* Bootstrap utility compatibility used by templates after framework removal */
.d-flex {
    display: flex !important;
}

.justify-content-center {
    justify-content: center !important;
}

.align-items-center {
    align-items: center !important;
}

.text-center {
    text-align: center !important;
}

.mb-2 {
    margin-bottom: 0.5rem !important;
}

.mb-3 {
    margin-bottom: 1rem !important;
}

.mb-4 {
    margin-bottom: 1.5rem !important;
}

.mb-5 {
    margin-bottom: 3rem !important;
}

.mt-4 {
    margin-top: 1.5rem !important;
}

.mt-5 {
    margin-top: 3rem !important;
}

main {
    min-height: 100vh;
}

.site-shell {
    width: min(calc(100% - var(--page-gutter)), var(--content-width));
    margin: 0 auto;
}

.glass-panel {
    border: 1px solid var(--line);
    background: var(--surface);
    box-shadow: var(--shadow-soft);
}

.site-header {
    position: sticky;
    top: 0;
    z-index: 1000;
    padding: 0.25rem 0;
    background: rgba(242, 238, 232, 0.9);
    backdrop-filter: blur(6px);
    border-bottom: 1px solid var(--line);
}

.site-header__inner {
    border-radius: var(--radius-lg);
    padding: 0.62rem 0.8rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
}

.site-header__actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.62rem;
    min-width: 0;
}

.site-header__actions::before {
    content: '';
    width: 1px;
    height: 1.9rem;
    background: rgba(183, 171, 152, 0.55);
}

.brand-mark {
    display: inline-flex;
    align-items: center;
    gap: var(--space-3);
    min-width: 0;
}

.brand-mark__icon {
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 999px;
    border: 1px solid var(--line-strong);
    background: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.brand-mark__icon-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.brand-mark__text {
    display: flex;
    flex-direction: column;
    gap: 0.05rem;
}

.brand-mark__name {
    font-size: 0.84rem;
    font-weight: 700;
    letter-spacing: 0.09em;
    text-transform: uppercase;
}

.brand-mark__role {
    color: var(--ink-soft);
    font-size: 0.7rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.site-nav {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.28rem;
    flex-wrap: nowrap;
}

.site-nav__link {
    padding: 0.52rem 0.68rem;
    border-radius: 999px;
    color: var(--ink-soft);
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.site-nav__link:hover {
    color: var(--ink);
    background: var(--surface-muted);
}

.site-nav__link--cta {
    color: #fff;
    background: var(--accent);
    box-shadow: none;
}

.site-nav__link--cta:hover {
    color: #fff;
    background: var(--accent-strong);
}

@media (hover: none) {
    .site-nav__link:hover,
    .site-nav__link--cta:hover,
    .language-switcher__button:hover {
        color: inherit;
        background: initial;
    }

    .site-nav__link--cta:hover {
        color: #fff;
        background: var(--accent);
    }
}

.language-switcher {
    display: inline-flex;
    align-items: center;
    gap: 0.18rem;
    margin-left: 0;
    padding: 0.18rem;
    border-radius: 999px;
    border: 1px solid rgba(183, 171, 152, 0.6);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.86), rgba(241, 234, 226, 0.92));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65), 0 1px 2px rgba(34, 30, 24, 0.08);
}

.language-switcher__button {
    border: 1px solid transparent;
    background: transparent;
    color: var(--ink-soft);
    font-size: 0.62rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    border-radius: 999px;
    padding: 0.34rem 0.56rem;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    gap: 0.26rem;
    cursor: pointer;
    min-height: 1.85rem;
}

.language-switcher__button:hover {
    color: var(--ink);
    background: rgba(255, 255, 255, 0.72);
}

.language-switcher__button.is-active {
    background: var(--accent);
    border-color: var(--accent);
    color: #fff;
    box-shadow: 0 4px 10px rgba(20, 17, 13, 0.2);
}

.language-switcher__code {
    font-size: 0.59rem;
    letter-spacing: 0.09em;
}

.language-switcher__name {
    font-size: 0.61rem;
    letter-spacing: 0.02em;
}

.site-main {
    padding: var(--space-7) 0 var(--space-8);
}

.site-main::before {
    content: '';
    position: fixed;
    inset: 0;
    pointer-events: none;
    background-image: linear-gradient(rgba(60, 52, 43, 0.045) 1px, transparent 1px),
                      linear-gradient(90deg, rgba(60, 52, 43, 0.045) 1px, transparent 1px);
    background-size: 38px 38px;
    opacity: 0.34;
}

#content-body {
    animation: panel-enter 260ms ease;
}

@keyframes panel-enter {
    from {
        opacity: 0;
        transform: translateY(12px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.section-shell {
    width: min(calc(100% - var(--page-gutter)), var(--content-width));
    margin: 0 auto;
}

.section-heading {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: var(--space-4);
    margin-bottom: var(--space-4);
}

.eyebrow {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    color: var(--ink-soft);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.display-title,
.spec,
.big-text,
.exp,
.job-title {
    line-height: 1.02;
    letter-spacing: -0.04em;
}

.display-title {
    font-size: clamp(2.4rem, 4.8vw, 4.2rem);
    font-weight: 700;
    font-family: var(--font-serif);
}

.spec {
    font-size: clamp(1.8rem, 3.6vw, 2.8rem);
    letter-spacing: -0.03em;
    font-family: var(--font-serif);
}

.big-text {
    font-size: clamp(1.45rem, 2.4vw, 2.4rem);
    font-weight: 700;
}

.xl-light-font {
    font-weight: 500;
}

.light-font {
    color: var(--ink-soft);
    font-weight: 500;
}

.semi-bold {
    font-weight: 700;
}

.white,
.project-a {
    color: #fff !important;
}

.text-underline {
    text-decoration: none;
}

.pill-link,
.button-link,
.btn,
button.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    min-height: 3rem;
    padding: 0.8rem 1.2rem;
    border-radius: 999px;
    border: 1px solid var(--accent);
    background: var(--accent);
    color: #fff !important;
    font-weight: 600;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    box-shadow: none;
}

.pill-link--ghost,
.btn-outline,
.btn-info {
    background: transparent;
    color: var(--ink) !important;
    border-color: var(--line);
    box-shadow: none;
}

.pill-link:hover,
.button-link:hover,
.btn:hover {
    transform: none;
    opacity: 1;
}

.mobile-fab-contact {
    display: none;
    position: fixed;
    right: max(0.8rem, env(safe-area-inset-right, 0));
    bottom: max(4rem, env(safe-area-inset-bottom, 0));
    z-index: 1350;
    min-height: 2.85rem;
    padding: 0.72rem 1rem;
    border-radius: 999px;
    border: 1px solid var(--accent);
    background: var(--accent);
    color: #fff;
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    box-shadow: 0 12px 28px rgba(20, 17, 13, 0.22);
}

.hero-panel {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(280px, 0.85fr);
    gap: var(--space-6);
    align-items: center;
    padding: clamp(1.5rem, 2vw, 2rem);
    border-radius: var(--radius-lg);
    border: 1px solid rgba(255, 255, 255, 0.58);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.86) 0%, rgba(255, 255, 255, 0.7) 100%);
    box-shadow: var(--shadow-card);
}

.box-one {
    height: auto;
    margin: 0;
    padding: 0;
    z-index: 1;
}

.name {
    margin-top: 0;
    font-size: 1rem;
    color: var(--ink-soft);
    text-transform: uppercase;
    letter-spacing: 0.12em;
}

.hero-copy {
    display: grid;
    gap: var(--space-4);
}

.hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-3);
    margin-top: var(--space-2);
}

.hero-meta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-3);
    color: var(--ink-soft);
    font-size: 0.95rem;
}

.home-minimal {
    max-width: 1120px;
}

.home-gallery {
    position: relative;
}

.home-gallery::before {
    content: '';
    position: absolute;
    inset: -1rem auto auto 0;
    width: min(620px, 58%);
    height: 1px;
    background: var(--line);
}

.home-hero {
    padding: 0;
}

.home-hero-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(260px, 0.65fr);
    gap: clamp(1.4rem, 3vw, 3rem);
    align-items: start;
    border: 1px solid var(--line);
    background: var(--surface);
    padding: clamp(1.5rem, 3.2vw, 2.7rem);
}

.home-hero-main {
    display: grid;
    gap: var(--space-4);
    padding-right: clamp(0rem, 3vw, 2rem);
}

.home-hero-title {
    font-family: var(--font-serif);
    font-size: clamp(2.4rem, 5vw, 4.4rem);
    line-height: 0.98;
    letter-spacing: -0.015em;
    max-width: 13ch;
    margin: 0;
}

.home-hero-subtitle {
    margin: 0;
    max-width: 58ch;
    color: var(--ink-soft);
    font-size: 0.96rem;
}

.home-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-3);
    margin-top: var(--space-2);
}

.home-hero-side {
    border-left: 1px solid var(--line);
    padding-left: clamp(1rem, 2.1vw, 1.8rem);
    display: grid;
    gap: var(--space-5);
    align-content: start;
}

.gallery-note-title {
    font-size: 0.74rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--ink-soft);
    font-weight: 700;
}

.gallery-note-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 0.8rem;
    color: var(--ink);
    font-size: 0.92rem;
}

.gallery-note-list li {
    border-bottom: 1px solid var(--line);
    padding-bottom: 0.75rem;
}

.gallery-note-links {
    display: grid;
    gap: 0.65rem;
}

.gallery-note-links a {
    font-size: 0.83rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--ink-soft);
    font-weight: 600;
}

.minimal-card {
    display: block;
    height: 100%;
    border: 1px solid var(--line);
    border-radius: 0;
    background: var(--surface-strong);
    padding: clamp(1.2rem, 2.3vw, 2rem);
}

.minimal-card:hover {
    border-color: var(--line-strong);
    transform: none;
    box-shadow: var(--shadow-soft);
}

.minimal-card-meta {
    font-size: 0.7rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--ink-soft);
    font-weight: 700;
}

.minimal-card-title {
    margin: 0.75rem 0 0;
    font-size: clamp(1.5rem, 2.5vw, 2.2rem);
    font-family: var(--font-serif);
    letter-spacing: -0.02em;
    line-height: 1.05;
}

.minimal-card-copy {
    margin: 0.9rem 0 1.2rem;
    color: var(--ink-soft);
}

.minimal-card-link {
    display: inline-flex;
    align-items: center;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--ink-soft);
    text-transform: uppercase;
    letter-spacing: 0.12em;
}

.home-asym-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(280px, 0.9fr);
    gap: clamp(1rem, 2vw, 1.8rem);
    align-items: stretch;
}

.stacked-piece-list {
    display: grid;
    gap: 1rem;
}

.featured-piece {
    display: grid;
    min-height: 100%;
    border: 1px solid var(--line);
    background: var(--surface-strong);
}

.featured-piece-image {
    width: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
    border-bottom: 1px solid var(--line);
}

.featured-piece-image--project {
    width: 100%;
    height: auto;
    aspect-ratio: auto;
    object-fit: contain;
    border-bottom: none;
    background: #fff;
    padding: 0;
}

.featured-piece-body {
    padding: clamp(1.1rem, 2vw, 1.8rem);
    display: grid;
    gap: 0.65rem;
}

.featured-piece-title {
    margin: 0;
    font-family: var(--font-serif);
    font-size: clamp(2rem, 3.4vw, 3.2rem);
    line-height: 0.98;
}

.featured-piece-copy {
    margin: 0.2rem 0 1.1rem;
    color: var(--ink-soft);
}

.gallery-strip {
    position: relative;
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    min-height: clamp(240px, 40vw, 460px);
    margin-top: 2.2rem;
    margin-bottom: 2.4rem;
    background-size: cover;
    background-position: center 50%;
    will-change: background-position;
}

.gallery-strip--short {
    min-height: clamp(200px, 32vw, 360px);
}

@media (prefers-reduced-motion: reduce) {
    .gallery-strip {
        will-change: auto;
        background-position: center !important;
    }
}

.gallery-strip-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(26, 22, 18, 0.12) 0%, rgba(26, 22, 18, 0.75) 100%);
    color: #f5efe6;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    gap: 0.5rem;
    padding: clamp(1rem, 3vw, 2.2rem);
}

.gallery-strip-eyebrow {
    font-size: 0.72rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    opacity: 0.9;
}

.gallery-strip-title {
    font-family: var(--font-serif);
    font-size: clamp(1.8rem, 4vw, 3.2rem);
    line-height: 0.98;
    max-width: 18ch;
}

.home-cta {
    margin-top: var(--space-7);
    padding: var(--space-6) 0 0;
    border-top: 1px solid var(--line);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    flex-wrap: wrap;
}

.home-cta p {
    margin: 0;
    color: var(--ink-soft);
    font-size: 0.95rem;
}

.page-shell {
    padding: 0 0 var(--space-8);
}

.page-head {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: var(--space-4);
}

.collection-page {
    max-width: 1140px;
}

.collection-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(1rem, 2vw, 1.6rem);
}

.collection-card {
    border: 1px solid var(--line);
    background: var(--surface-strong);
    display: grid;
    min-height: 100%;
}

.collection-card[data-collection-link="true"] {
    transition: border-color 200ms ease, box-shadow 200ms ease;
    cursor: pointer;
}

.collection-card[data-collection-link="true"]:hover,
.collection-card[data-collection-link="true"]:active {
    border-color: var(--line-strong);
    box-shadow: 0 0 0 1px rgba(58, 51, 43, 0.12);
}

.collection-card-image {
    width: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
    border-bottom: 1px solid var(--line);
}

.collection-card-image--project {
    width: 100%;
    height: auto;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    border-bottom: none;
    background: #fff;
    padding: 0;
}

.collection-card-body {
    padding: clamp(1rem, 2vw, 1.6rem);
    display: grid;
    gap: 0.65rem;
}

.collection-card-title {
    margin: 0;
    font-family: var(--font-serif);
    font-size: clamp(1.5rem, 2.4vw, 2.25rem);
    line-height: 1.02;
}

.collection-card-copy {
    margin: 0;
    color: var(--ink-soft);
}

.article-index-page {
    max-width: 1220px;
}

.article-index-hero {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(300px, 0.8fr);
    gap: clamp(1.2rem, 3vw, 2.6rem);
    align-items: start;
}

.article-index-intro {
    display: grid;
    gap: 0.9rem;
    max-width: 50rem;
}

.article-index-copy {
    margin: 0;
    color: var(--ink-soft);
    font-size: 1rem;
    line-height: 1.75;
    max-width: 44rem;
}

.article-audience-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    align-content: flex-start;
    max-height: 15rem;
    overflow: auto;
    padding-right: 0.2rem;
}

.article-audience-pill {
    border: 1px solid var(--line);
    background: #fff;
    padding: 0.56rem 0.72rem;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    transition: border-color 180ms ease, transform 180ms ease, box-shadow 180ms ease;
}

.article-audience-pill:hover {
    border-color: var(--line-strong);
    box-shadow: 0 8px 22px rgba(34, 30, 24, 0.06);
    transform: translateY(-1px);
}

.article-audience-pill__title {
    font-family: var(--font-serif);
    font-size: 1rem;
    line-height: 1.1;
}

.article-audience-pill__count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.2rem;
    padding: 0.12rem 0.42rem;
    border-radius: 999px;
    border: 1px solid rgba(58, 46, 32, 0.2);
    background: rgba(58, 46, 32, 0.05);
    color: var(--ink-soft);
    font-size: 0.67rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.article-audience-pill--business {
    border-left: 4px solid #916f2d;
}

.article-audience-pill--tech {
    border-left: 4px solid #315c73;
}

.article-audience-pill--personal {
    border-left: 4px solid #8a5560;
}

.article-audience-pill--general {
    border-left: 4px solid #5d5a54;
}

.article-lead {
    border: 1px solid var(--line);
    background: linear-gradient(135deg, #fbf7ef 0%, #f4eee4 100%);
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(280px, 0.9fr);
    align-items: stretch;
    overflow: hidden;
}

.article-lead-copy-wrap {
    padding: clamp(1.2rem, 3vw, 2rem);
    display: grid;
    gap: 0.9rem;
    align-content: center;
}

.article-lead-title {
    margin: 0;
    font-family: var(--font-serif);
    font-size: clamp(2rem, 4vw, 3.3rem);
    line-height: 0.95;
    max-width: 12ch;
}

.article-lead-copy {
    margin: 0;
    color: #3a332b;
    font-size: 1rem;
    line-height: 1.78;
    max-width: 40rem;
}

.article-lead-subtitle {
    margin: -0.2rem 0 0;
    color: var(--ink-soft);
    font-size: 0.98rem;
    line-height: 1.62;
    max-width: 36rem;
}

.article-lead-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
    padding-top: 0.2rem;
}

.article-lead-tag {
    font-size: 0.72rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--ink-soft);
}

.article-lead-link {
    color: var(--ink);
}

.article-lead-media {
    min-height: 100%;
    border-left: 1px solid rgba(58, 46, 32, 0.12);
}

.article-lead-image {
    width: 100%;
    height: 100%;
    min-height: 100%;
    object-fit: cover;
    display: block;
}

.article-audience-stack {
    display: grid;
    gap: 1.25rem;
}

.article-audience-section {
    border: 1px solid var(--line);
    background: #fff;
    padding: clamp(1rem, 2.4vw, 1.5rem);
    display: grid;
    gap: 1rem;
}

.article-audience-section--business {
    background: linear-gradient(180deg, rgba(247, 242, 230, 0.72) 0%, #fff 100%);
}

.article-audience-section--tech {
    background: linear-gradient(180deg, rgba(234, 241, 245, 0.82) 0%, #fff 100%);
}

.article-audience-section--personal {
    background: linear-gradient(180deg, rgba(247, 236, 239, 0.82) 0%, #fff 100%);
}

.article-audience-section--general {
    background: linear-gradient(180deg, rgba(243, 241, 236, 0.82) 0%, #fff 100%);
}

.article-audience-head {
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(280px, 0.8fr);
    gap: 1rem;
    align-items: end;
    padding-bottom: 0.9rem;
    border-bottom: 1px solid var(--line);
}

.article-audience-label {
    font-size: 0.7rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--ink-soft);
    margin-bottom: 0.35rem;
}

.article-audience-title {
    margin: 0;
    font-family: var(--font-serif);
    font-size: clamp(1.5rem, 2.8vw, 2.3rem);
    line-height: 1;
}

.article-audience-summary {
    margin: 0;
    color: var(--ink-soft);
    font-size: 0.95rem;
    line-height: 1.7;
}

.article-audience-count {
    justify-self: end;
    align-self: center;
    font-size: 0.68rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--ink-soft);
    border: 1px solid rgba(58, 46, 32, 0.2);
    border-radius: 999px;
    padding: 0.22rem 0.55rem;
    background: rgba(255, 255, 255, 0.85);
}

.article-story-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.article-story-card {
    border: 1px solid rgba(58, 46, 32, 0.12);
    background: rgba(255, 255, 255, 0.92);
    padding: 1rem;
    display: grid;
    gap: 0.7rem;
    min-height: 100%;
    transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}

.article-story-card:hover {
    transform: translateY(-1px);
    border-color: var(--line-strong);
    box-shadow: 0 10px 24px rgba(34, 30, 24, 0.06);
}

.article-story-meta {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    font-size: 0.72rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--ink-soft);
}

.article-tone-dot {
    width: 0.55rem;
    height: 0.55rem;
    border-radius: 999px;
    flex: 0 0 auto;
}

.article-tone-dot--business {
    background: #916f2d;
}

.article-tone-dot--tech {
    background: #315c73;
}

.article-tone-dot--personal {
    background: #8a5560;
}

.article-tone-dot--general {
    background: #5d5a54;
}

.article-story-title {
    margin: 0;
    font-family: var(--font-serif);
    font-size: 1.45rem;
    line-height: 1.08;
}

.article-story-copy {
    margin: 0;
    color: var(--ink-soft);
    line-height: 1.68;
}

.article-story-subtitle {
    margin: -0.15rem 0 0;
    color: #4a433b;
    font-size: 0.9rem;
    line-height: 1.5;
}

.article-story-link {
    color: var(--ink);
    margin-top: auto;
}

.article-story-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.8rem;
    flex-wrap: wrap;
    margin-top: auto;
}

.article-story-time {
    font-size: 0.72rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--ink-soft);
}

.article-reader-page {
    max-width: 1160px;
}

.article-reader-page--business {
    --article-accent: #916f2d;
}

.article-reader-page--tech {
    --article-accent: #315c73;
}

.article-reader-page--personal {
    --article-accent: #8a5560;
}

.article-reader-page--general {
    --article-accent: #5d5a54;
}

.article-reader-hero {
    display: grid;
    gap: clamp(1rem, 3vw, 2rem);
    align-items: start;
}

.article-reader-hero--with-image {
    grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr);
}

.article-reader-hero--text-only {
    grid-template-columns: 1fr;
}

.article-reader-hero-main {
    display: grid;
    gap: 1rem;
}

.article-reader-headline {
    display: grid;
    gap: 0.85rem;
    max-width: 44rem;
    padding: clamp(1.1rem, 2.6vw, 1.8rem);
    border: 1px solid var(--line);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(248, 244, 237, 0.9) 100%);
    position: relative;
}

.article-reader-headline::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 6px;
    background: linear-gradient(180deg, var(--article-accent) 0%, rgba(255, 255, 255, 0) 100%);
}

.article-reader-meta-row {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    flex-wrap: wrap;
    color: var(--ink-soft);
    font-size: 0.72rem;
    letter-spacing: 0.13em;
    text-transform: uppercase;
}

.article-reader-kicker {
    color: var(--article-accent);
    font-weight: 700;
}

.article-reader-separator {
    width: 1.8rem;
    height: 1px;
    background: rgba(58, 46, 32, 0.24);
}

.article-reader-title {
    margin: 0;
    font-family: var(--font-serif);
    font-size: clamp(2.4rem, 5.6vw, 5rem);
    line-height: 0.9;
    letter-spacing: -0.02em;
    max-width: 11ch;
}

.article-reader-subtitle {
    margin: -0.1rem 0 0;
    max-width: 45ch;
    color: #3e372f;
    font-size: clamp(1rem, 2vw, 1.25rem);
    line-height: 1.55;
}

.article-reader-context {
    border: 1px solid var(--line);
    background: linear-gradient(180deg, rgba(245, 240, 232, 0.96) 0%, rgba(255, 255, 255, 0.98) 100%);
    padding: clamp(1rem, 2vw, 1.3rem);
    display: grid;
    gap: 0.5rem;
    position: relative;
    overflow: hidden;
}

.article-reader-context::before {
    content: '';
    position: absolute;
    inset: 0 auto 0 0;
    width: 4px;
    background: var(--article-accent);
}

.article-reader-context-label,
.article-reader-rail-label {
    font-size: 0.68rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--ink-soft);
}

.article-reader-context-title {
    margin: 0;
    font-family: var(--font-serif);
    font-size: 1.35rem;
    line-height: 1.06;
}

.article-reader-context-copy {
    margin: 0;
    color: var(--ink-soft);
    line-height: 1.72;
}

.article-reader-hero-media {
    margin: 0;
    min-height: 100%;
    border: 1px solid var(--line);
    background: var(--surface-strong);
    overflow: hidden;
    position: relative;
}

.article-reader-hero-media::after {
    content: '';
    position: absolute;
    inset: auto 0 0 0;
    height: 28%;
    background: linear-gradient(180deg, rgba(19, 17, 15, 0) 0%, rgba(19, 17, 15, 0.18) 100%);
    pointer-events: none;
}

.article-reader-hero-image {
    display: block;
    width: 100%;
    height: 100%;
    min-height: 100%;
    max-height: 620px;
    object-fit: cover;
}

.article-reader-layout {
    display: grid;
    grid-template-columns: minmax(180px, 0.28fr) minmax(0, 1fr);
    gap: clamp(1rem, 3vw, 2.5rem);
    align-items: start;
}

.article-reader-rail {
    position: sticky;
    top: 5.4rem;
    display: grid;
    gap: 0.85rem;
}

.article-reader-rail-card {
    border: 1px solid var(--line);
    background: #fff;
    padding: 0.95rem;
    display: grid;
    gap: 0.45rem;
    box-shadow: 0 10px 24px rgba(34, 30, 24, 0.04);
}

.article-reader-rail-card--muted {
    background: rgba(248, 244, 237, 0.72);
}

.article-reader-rail-card p {
    margin: 0;
    color: var(--ink-soft);
    line-height: 1.65;
    font-size: 0.9rem;
}

.article-reader-body {
    min-width: 0;
}

.article-reader-body-frame {
    border: 1px solid var(--line);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(249, 245, 238, 0.98) 100%);
    padding: clamp(1.1rem, 3vw, 2.2rem);
    position: relative;
    overflow: hidden;
}

.article-reader-body-frame::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg, rgba(58, 46, 32, 0) 0%, rgba(58, 46, 32, 0.28) 50%, rgba(58, 46, 32, 0) 100%);
}

.article-reader-body-mark {
    margin-bottom: 0.9rem;
    font-size: 0.68rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--article-accent);
    font-weight: 700;
}

.article-reader-prose {
    border: none;
    background: transparent;
    padding: 0;
    max-width: 44rem;
    margin: 0 auto;
    font-size: 1.08rem;
    line-height: 1.96;
    color: #241f19;
}

.article-reader-prose > p:first-of-type {
    font-size: 1.18rem;
    line-height: 1.88;
    color: #2e271f;
}

.article-reader-prose > p:first-of-type::first-letter {
    float: left;
    font-family: var(--font-serif);
    font-size: 4.2rem;
    line-height: 0.86;
    padding-right: 0.4rem;
    padding-top: 0.12rem;
    color: var(--article-accent);
}

.article-reader-prose h2,
.article-reader-prose h3,
.article-reader-prose h4 {
    line-height: 1.08;
    margin-top: 1.8em;
    margin-bottom: 0.58em;
}

.article-reader-prose h2 {
    font-size: clamp(1.65rem, 2.8vw, 2.2rem);
}

.article-reader-prose h3 {
    font-size: clamp(1.28rem, 2vw, 1.55rem);
}

.article-reader-prose p,
.article-reader-prose ul,
.article-reader-prose ol,
.article-reader-prose blockquote {
    max-width: 44rem;
}

.article-reader-prose blockquote {
    margin: 1.6rem 0;
    padding: 0.2rem 0 0.2rem 1rem;
    border-left: 3px solid var(--article-accent);
    color: #3b342b;
    font-family: var(--font-serif);
    font-size: 1.12rem;
    line-height: 1.7;
}

.article-reader-prose img {
    margin: 1.6rem auto;
}

.article-reader-more-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.article-story-card--reading {
    border-top: 3px solid var(--article-accent);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.95) 0%, rgba(247, 242, 234, 0.84) 100%);
}

.detail-page {
    max-width: 980px;
}

.detail-hero {
    border: 1px solid var(--line);
    background: var(--surface);
    padding: clamp(1rem, 2.2vw, 1.8rem);
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(180px, 0.32fr);
    gap: var(--space-5);
}

.detail-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.7rem;
    margin-top: 1rem;
}

.detail-meta {
    border-left: 1px solid var(--line);
    padding-left: var(--space-4);
    display: grid;
    gap: 0.75rem;
    align-content: start;
}

.detail-meta strong {
    display: block;
    font-size: 0.68rem;
    text-transform: uppercase;
    letter-spacing: 0.13em;
    color: var(--ink-soft);
}

.detail-meta span {
    font-size: 0.95rem;
}

.detail-image-wrap {
    border: 1px solid var(--line);
    background: var(--surface-strong);
}

.detail-image {
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
}

.detail-image--project {
    width: 100%;
    height: auto;
    aspect-ratio: auto;
    object-fit: contain;
    background: #fff;
    padding: 0;
    min-height: 0;
}

.project-shot-window {
    max-height: 430px;
    overflow: auto;
    border-bottom: 1px solid var(--line);
    background: #fff;
    scrollbar-width: thin;
}

.project-shot-window--hero {
    max-height: 520px;
}

.project-shot-window img {
    display: block;
}

.project-shot-stage {
    position: relative;
    border-bottom: 1px solid var(--line);
    background: linear-gradient(180deg, #f9f5ee 0%, #f2eadf 100%);
}

.project-shot-stage--hero {
    background: linear-gradient(180deg, #fbf7ef 0%, #efe5d6 100%);
}

.project-shot-toolbar {
    position: absolute;
    top: 0.55rem;
    left: 0.65rem;
    z-index: 2;
    display: inline-flex;
    gap: 0.35rem;
}

.project-shot-toolbar span {
    width: 0.52rem;
    height: 0.52rem;
    border-radius: 999px;
    border: 1px solid rgba(58, 46, 32, 0.24);
    background: rgba(255, 255, 255, 0.9);
}

.project-shot-chip {
    position: absolute;
    top: 0.5rem;
    right: 0.6rem;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.24rem 0.55rem;
    border: 1px solid rgba(58, 46, 32, 0.22);
    background: rgba(252, 248, 240, 0.92);
    color: #5b5044;
    font-size: 0.62rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    font-weight: 600;
}

.project-shot-stage::after {
    content: '';
    position: absolute;
    right: 0.6rem;
    bottom: 0.6rem;
    z-index: 2;
    color: transparent;
    font-size: 0.6rem;
    letter-spacing: 0.11em;
    text-transform: uppercase;
    opacity: 1;
}

.collection-card-link {
    font-weight: 600;
    color: var(--ink-soft);
    transition: color 180ms ease;
}

.collection-card:hover .collection-card-link,
.collection-card:active .collection-card-link {
    color: var(--ink);
}

.collection-card--with-image {
    grid-template-rows: auto 1fr;
}

.project-shot-chip--collection {
    opacity: 0.72;
    backdrop-filter: blur(4px);
}

.project-shot-window {
    scrollbar-color: rgba(87, 74, 56, 0.4) rgba(246, 237, 225, 0.9);
}

.project-shot-window--collection {
    max-height: 340px;
}

.project-shot-window::-webkit-scrollbar {
    width: 7px;
    height: 7px;
}

.project-shot-window::-webkit-scrollbar-thumb {
    background: rgba(87, 74, 56, 0.35);
    border-radius: 999px;
}

.project-shot-window::-webkit-scrollbar-track {
    background: rgba(246, 237, 225, 0.9);
}

@media (hover: none) {
    .project-shot-stage::after {
        content: '';
        opacity: 0;
    }
}

.detail-content {
    border: 1px solid var(--line);
    background: var(--surface-strong);
    padding: clamp(1rem, 2.4vw, 2rem);
    font-size: 1rem;
    line-height: 1.72;
}

.detail-content p:last-child {
    margin-bottom: 0;
}

.detail-content h2,
.detail-content h3,
.detail-content h4 {
    font-family: var(--font-serif);
    margin-top: 1.4em;
}

.detail-content img {
    max-width: 100%;
    height: auto;
}

.project-detail-page {
    max-width: 1180px;
}

.project-detail-grid {
    display: grid;
    grid-template-columns: minmax(270px, 0.42fr) minmax(0, 1fr);
    gap: clamp(1rem, 2.2vw, 2rem);
    align-items: start;
}

.project-context-panel {
    position: sticky;
    top: 5.2rem;
    border: 1px solid var(--line);
    background: var(--surface);
    padding: clamp(0.9rem, 1.9vw, 1.4rem);
    display: grid;
    gap: 0.8rem;
    max-height: calc(100vh - 6.4rem);
    overflow: auto;
}

.project-detail-title {
    margin: 0;
    font-family: var(--font-serif);
    font-size: clamp(1.8rem, 3.1vw, 2.7rem);
    line-height: 0.97;
}

.project-context-meta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
    padding: 0.75rem 0;
}

.project-context-meta strong {
    display: block;
    font-size: 0.64rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--ink-soft);
}

.project-context-meta span {
    font-size: 0.92rem;
}

.project-context-summary {
    margin: 0;
    color: var(--ink-soft);
    font-size: 0.94rem;
    line-height: 1.6;
}

.project-context-actions {
    gap: 0.5rem;
    margin-top: 0.2rem;
}

.project-detail-main {
    display: grid;
    gap: 1rem;
}

.project-shot-stage--detail {
    border: 1px solid var(--line);
}

.project-shot-window--detail {
    max-height: clamp(360px, 66vh, 760px);
}

.project-shot-controls {
    border: 1px solid var(--line);
    border-top: none;
    background: var(--surface);
    padding: 0.55rem 0.65rem;
    display: grid;
    grid-template-columns: repeat(3, auto) minmax(0, 1fr);
    gap: 0.5rem;
    align-items: center;
}

.project-shot-btn {
    border: 1px solid var(--line);
    background: #fff;
    color: var(--ink-soft);
    min-height: 2rem;
    padding: 0.35rem 0.72rem;
    font-size: 0.63rem;
    letter-spacing: 0.11em;
    text-transform: uppercase;
    font-weight: 700;
}

.project-shot-btn:hover {
    border-color: var(--line-strong);
    color: var(--ink);
}

.project-shot-slider {
    width: 100%;
    accent-color: #3a332b;
}

.project-text-revamp {
    margin-top: clamp(1.1rem, 2.8vw, 2.2rem);
    border: 1px solid var(--line);
    background: linear-gradient(180deg, #fff 0%, #f9f6f1 100%);
    padding: clamp(1rem, 2.3vw, 1.75rem);
    display: grid;
    gap: clamp(0.85rem, 2vw, 1.25rem);
}

.project-text-revamp-head {
    display: grid;
    gap: 0.32rem;
    border-bottom: 1px solid var(--line);
    padding-bottom: 0.7rem;
}

.project-text-revamp-title {
    margin: 0;
    font-family: var(--font-serif);
    font-size: clamp(1.22rem, 2.2vw, 1.8rem);
    line-height: 1.08;
    letter-spacing: 0.01em;
}

.project-text-revamp-grid {
    display: grid;
    grid-template-columns: minmax(240px, 0.8fr) minmax(0, 1.25fr);
    gap: clamp(0.85rem, 2vw, 1.2rem);
    align-items: start;
}

.project-content-panel {
    border: 1px solid var(--line);
    background: var(--surface);
}

.project-content-panel summary {
    list-style: none;
    cursor: pointer;
    padding: 0.85rem 1rem;
    font-size: 0.74rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--ink-soft);
    border-bottom: 1px solid var(--line);
    user-select: none;
}

.project-content-panel summary::-webkit-details-marker {
    display: none;
}

.detail-content--project {
    border: none;
    padding-top: 1rem;
    color: #1f1b16;
    font-size: 1rem;
    line-height: 1.72;
}

.detail-content--project h2,
.detail-content--project h3,
.detail-content--project h4 {
    line-height: 1.12;
    margin-top: 1.55em;
    margin-bottom: 0.5em;
    scroll-margin-top: 6rem;
}

.detail-content--project p {
    margin-bottom: 1.1em;
}

.detail-content--project ul,
.detail-content--project ol {
    margin-bottom: 1.2em;
    padding-left: 1.3rem;
}

.project-text-studio {
    display: grid;
    gap: 0.95rem;
}

.project-text-studio--aside {
    gap: 0.7rem;
}

.project-brief-shell,
.project-notes-panel {
    border: 1px solid var(--line);
    background: var(--surface);
    padding: 0.75rem;
}

.project-notes-panel--main {
    padding: clamp(0.95rem, 1.8vw, 1.35rem);
}

.project-notes-panel--revamp {
    background: #fff;
    border-color: rgba(163, 150, 134, 0.45);
    padding: clamp(0.85rem, 1.8vw, 1.15rem);
}

.project-notes-panel--revamp[data-notes-panel-toggle] {
    cursor: pointer;
    transition: border-color 180ms ease, box-shadow 180ms ease;
}

.project-notes-panel--revamp[data-notes-panel-toggle]:hover,
.project-notes-panel--revamp[data-notes-panel-toggle]:focus-visible,
.project-notes-panel--revamp[data-notes-panel-toggle].is-expanded {
    border-color: var(--line-strong);
    box-shadow: 0 0 0 1px rgba(58, 51, 43, 0.08);
}

.project-notes-panel--revamp[data-notes-panel-toggle]:focus-visible {
    outline: none;
}

.project-snapshot-shell {
    border: 1px solid var(--line);
    background: #fff;
    padding: 0.85rem;
}

.project-snapshot-shell--revamp {
    background: rgba(255, 255, 255, 0.75);
    border-color: rgba(163, 150, 134, 0.45);
    padding: 0.7rem 0.75rem;
}

.project-snapshot-grid {
    margin-top: 0.45rem;
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
}

.project-snapshot-grid--revamp {
    margin-top: 0;
    gap: 0.2rem;
}

.project-snapshot-card {
    border: none;
    border-top: 1px solid var(--line);
    background: transparent;
    padding: 0.62rem 0.1rem 0.62rem 0.35rem;
    display: grid;
    gap: 0.28rem;
    min-height: 100%;
}

.project-snapshot-card--revamp {
    border-top: none;
    border-bottom: 1px solid var(--line);
    padding: 0.68rem 0.12rem;
}

.project-snapshot-card--revamp:last-child {
    border-bottom: none;
    padding-bottom: 0.46rem;
}

.project-snapshot-card strong {
    font-size: 0.6rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--ink-soft);
    font-weight: 700;
}

.project-snapshot-card p {
    margin: 0;
    font-size: 0.83rem;
    line-height: 1.5;
    color: #2b2621;
}

.project-brief-eyebrow {
    font-size: 0.66rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--ink-soft);
    font-weight: 700;
}

.project-brief-lead {
    margin-top: 0.45rem;
    font-family: var(--font-serif);
    font-size: clamp(1.3rem, 2.4vw, 2rem);
    line-height: 1.07;
    max-width: 36ch;
}

.project-brief-grid {
    margin-top: 0.9rem;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.6rem;
}

.project-brief-card {
    border: 1px solid var(--line);
    background: #fff;
    padding: 0.55rem 0.65rem;
    display: grid;
    gap: 0.3rem;
}

.project-brief-card strong {
    font-size: 0.62rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--ink-soft);
}

.project-brief-card span {
    font-size: 0.86rem;
    color: var(--ink);
}

.project-notes-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.6rem;
}

.project-notes-head--revamp {
    padding-bottom: 0.45rem;
    border-bottom: 1px solid var(--line);
}

.project-notes-hint {
    font-size: 0.6rem;
    letter-spacing: 0.11em;
    text-transform: uppercase;
    color: var(--ink-soft);
}

.project-notes-toggle {
    border: 1px solid var(--line);
    background: #fff;
    color: var(--ink-soft);
    min-height: 2rem;
    padding: 0.3rem 0.72rem;
    font-size: 0.62rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    font-weight: 700;
}

.project-notes-content {
    margin-top: 0.55rem;
    max-height: 11.8rem;
    overflow: hidden;
    position: relative;
}

.project-notes-content--main {
    max-height: 18rem;
}

.project-notes-content--revamp {
    margin-top: 0.5rem;
    max-height: 15.5rem;
    padding: 0;
    font-size: 0.98rem;
    line-height: 1.8;
}

.project-notes-content--revamp p {
    max-width: 64ch;
}

.project-notes-content::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 2.2rem;
    background: linear-gradient(180deg, rgba(251, 248, 243, 0) 0%, rgba(251, 248, 243, 1) 100%);
    pointer-events: none;
}

.project-notes-content.is-expanded {
    max-height: none;
}

.project-notes-content.is-expanded::after {
    display: none;
}

.about-page {
    max-width: 1080px;
    display: grid;
    gap: clamp(1.3rem, 2.2vw, 2rem);
}

.page-head--about {
    margin-bottom: 0;
}

.page-head--about-section {
    margin-bottom: 0;
}

.about-intro {
    border: 1px solid var(--line);
    background: var(--surface);
    border-radius: var(--radius-md);
    padding: clamp(1rem, 2.6vw, 2rem);
    display: grid;
    grid-template-columns: minmax(230px, 0.48fr) minmax(0, 1fr);
    gap: clamp(1rem, 3vw, 2.5rem);
    align-items: start;
}

.about-portrait-wrap {
    border: 1px solid var(--line);
    background: var(--surface-strong);
    padding: 0.75rem;
    border-radius: calc(var(--radius-md) - 2px);
}

.about-portrait {
    width: 100%;
    aspect-ratio: 4 / 5;
    object-fit: cover;
}

.about-bio {
    display: grid;
    gap: 0.9rem;
    color: var(--ink-soft);
}

.about-kicker {
    display: inline-flex;
    width: fit-content;
    align-items: center;
    font-size: 0.68rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    font-weight: 700;
    color: var(--ink-soft);
    padding: 0.25rem 0.5rem;
    border: 1px solid var(--line);
    background: var(--surface-muted);
}

.about-title {
    margin: 0;
    font-family: var(--font-serif);
    color: var(--ink);
    font-size: clamp(1.8rem, 3.4vw, 3rem);
    line-height: 1;
}

.about-lead {
    margin: 0;
    line-height: 1.7;
}

.about-location {
    margin: 0;
    display: inline-flex;
    align-items: baseline;
    gap: 0.45rem;
    width: fit-content;
    border-top: 1px solid var(--line);
    padding-top: 0.55rem;
    color: var(--ink);
    font-weight: 600;
}

.about-location span {
    color: var(--ink-soft);
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-weight: 700;
}

.about-links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
}

.about-links a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.35rem;
    padding: 0.55rem 0.9rem;
    border: 1px solid var(--line);
    background: var(--surface-strong);
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.11em;
    color: var(--ink-soft);
    font-weight: 600;
}

.about-capabilities {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1px;
    border: 1px solid var(--line);
    background: var(--line);
    border-radius: var(--radius-md);
    overflow: hidden;
    margin-bottom: var(--space-7);
}

.about-capability-group {
    background: var(--surface);
    padding: clamp(1rem, 2.4vw, 1.75rem);
    display: grid;
    gap: 0.75rem;
    align-content: start;
}

.about-capability-label {
    font-size: 0.68rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    font-weight: 700;
    color: var(--ink-soft);
    padding-bottom: 0.6rem;
    border-bottom: 1px solid var(--line);
}

.about-capability-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 0.45rem;
}

.about-capability-list li {
    font-size: 0.82rem;
    color: var(--ink-soft);
    line-height: 1.4;
    padding-left: 0.85rem;
    position: relative;
}

.about-capability-list li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.55em;
    width: 3px;
    height: 3px;
    border-radius: 50%;
    background: var(--line-strong);
}

.timeline-list {
    border: 1px solid var(--line);
    background: var(--surface);
    border-radius: var(--radius-md);
    overflow: hidden;
}

.timeline-item {
    display: grid;
    grid-template-columns: minmax(84px, 120px) minmax(0, 1fr);
    gap: var(--space-4);
    padding: clamp(0.95rem, 2vw, 1.35rem);
    border-bottom: 1px solid var(--line);
}

.timeline-item:last-child {
    border-bottom: none;
}

.timeline-year {
    font-family: var(--font-serif);
    font-size: clamp(1.7rem, 4.4vw, 3rem);
    line-height: 0.95;
    color: var(--ink-soft);
}

.timeline-body {
    display: grid;
    gap: 0.32rem;
}

.timeline-title {
    margin: 0;
    font-size: clamp(1.2rem, 2.5vw, 1.7rem);
    font-family: var(--font-serif);
}

.timeline-place {
    margin-top: 0.35rem;
    color: var(--ink-soft);
}

.timeline-date {
    margin-top: 0.1rem;
    font-size: 0.82rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--ink-soft);
}

#image-div {
    margin-top: 0;
}

.hero-portrait {
    position: relative;
    padding: var(--space-4);
    border-radius: calc(var(--radius-lg) + 0.5rem);
    background: linear-gradient(180deg, rgba(15, 118, 110, 0.12) 0%, rgba(212, 163, 115, 0.2) 100%);
}

.hero-portrait img {
    width: 100%;
    object-fit: cover;
    border-radius: calc(var(--radius-lg) - 0.4rem);
    box-shadow: var(--shadow-soft);
}

.projects {
    position: relative;
    margin-bottom: var(--space-6);
    overflow: hidden;
}

.project-card-link {
    display: block;
    height: 100%;
}

.pro-image {
    width: 100%;
    min-height: 320px;
    aspect-ratio: 4 / 4.5;
    overflow: hidden;
    filter: brightness(0.5);
    object-fit: cover;
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-soft);
}

.text-block {
    position: absolute;
    inset: auto 1.8rem 1.8rem 1.8rem;
    display: grid;
    gap: var(--space-2);
    padding: var(--space-5);
    color: #fff;
    background: linear-gradient(180deg, transparent 0%, rgba(21, 19, 17, 0.85) 100%);
    border-radius: 0 0 var(--radius-md) var(--radius-md);
}

.logo-skill {
    width: 100%;
    max-width: 190px;
    height: 88px;
    object-fit: contain;
    filter: grayscale(100%);
    opacity: 0.78;
}

.logo-skill:hover {
    filter: grayscale(0%);
    opacity: 1;
}

.home-skill-card {
    padding: var(--space-5);
    border-radius: var(--radius-md);
    border: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.66);
    min-height: 100%;
}

.content-panel,
.contact-panel,
.pagination-shell,
.about-card,
.footer-panel {
    border-radius: var(--radius-lg);
    border: 1px solid var(--line);
    background: var(--surface);
    box-shadow: none;
}

.contact-page {
    width: min(calc(100% - var(--page-gutter-narrow)), 1080px);
    margin: 0 auto;
    padding: 0 0 var(--space-8);
}

.contact-panel {
    padding: clamp(1.5rem, 3vw, 2.5rem);
}

.contact-grid {
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.15fr);
    gap: var(--space-6);
    align-items: start;
}

.contact-copy {
    display: grid;
    gap: var(--space-4);
}

.contact-copy p {
    margin: 0;
    color: var(--ink-soft);
}

.contact-metadata {
    display: grid;
    gap: var(--space-4);
    padding: var(--space-5);
    border-radius: var(--radius-md);
    border: 1px solid var(--line);
    background: var(--surface-muted);
}

.contact-metadata strong {
    display: block;
    font-size: 0.82rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--ink-soft);
    margin-bottom: var(--space-1);
}

.contact-meta-compact {
    display: none;
}

.contact-form-card {
    padding: clamp(1.5rem, 2vw, 2rem);
    border-radius: var(--radius-md);
    border: 1px solid var(--line);
    background: var(--surface-strong);
    box-shadow: none;
}

.form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-4);
}

.field-group {
    display: grid;
    gap: 0.5rem;
}

.field-group--full {
    grid-column: 1 / -1;
}

.field-label {
    font-size: 0.9rem;
    font-weight: 700;
    letter-spacing: 0.01em;
}

.field-help {
    margin: 0;
    color: var(--ink-soft);
    font-size: 0.9rem;
}

.form-control,
textarea.form-control,
input.form-control {
    width: 100%;
    min-height: 3.25rem;
    padding: 0.95rem 1rem;
    border-radius: 1.05rem;
    border: 1px solid var(--line);
    background: #fff;
    color: var(--ink);
    box-shadow: none;
}

textarea.form-control {
    min-height: 10rem;
    resize: vertical;
}

.form-control:focus {
    border-color: rgba(15, 118, 110, 0.45);
    box-shadow: 0 0 0 0.24rem rgba(15, 118, 110, 0.12);
}

.phone_number,
#id_phone_number {
    display: none;
}

.form-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    flex-wrap: wrap;
}

.form-note {
    margin: 0;
    color: var(--ink-soft);
    font-size: 0.92rem;
}

.alert {
    border: none;
    border-radius: 1rem;
    padding: 1rem 1.2rem;
    margin-bottom: var(--space-5);
}

.alert-success {
    color: #065f46;
    background: #d1fae5;
}

.contact-success {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: var(--space-5);
    padding: clamp(3rem, 8vw, 6rem) var(--space-6);
}

.contact-success__icon {
    width: 3.5rem;
    height: 3.5rem;
    border-radius: 50%;
    border: 1.5px solid var(--line-strong);
    background: var(--surface);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.3rem;
    color: var(--ink-soft);
}

.contact-success__title {
    margin: 0;
    font-family: var(--font-serif);
    font-size: clamp(2rem, 5vw, 3.5rem);
    line-height: 1;
    color: var(--ink);
}

.contact-success__body {
    margin: 0;
    color: var(--ink-soft);
    max-width: 36ch;
    line-height: 1.7;
}

.pagination-shell {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.7rem;
    margin: var(--space-6) auto 0;
    padding: 0.85rem;
}

.pagination-link,
.pagination-current {
    min-width: 2.8rem;
    min-height: 2.8rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.7rem 1rem;
    border-radius: 999px;
    border: 1px solid var(--line);
    font-weight: 700;
}

.pagination-link {
    background: #fff;
}

.pagination-current {
    background: var(--accent);
    border-color: var(--accent);
    color: #fff;
}

.site-footer {
    padding-bottom: var(--space-7);
}

.footer-panel {
    padding: clamp(1.1rem, 2vw, 1.7rem);
}

.footer-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.3fr) repeat(2, minmax(0, 0.75fr));
    gap: clamp(1rem, 2.4vw, 2rem);
    align-items: start;
}

.footer-primary {
    display: grid;
    gap: 0.5rem;
}

.footer-email {
    margin-top: 0.8rem;
}

.footer-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 0.6rem;
}

.footer-header {
    font-size: 0.82rem;
    margin-bottom: 1rem;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--ink-soft);
}

.footer-title {
    font-size: clamp(1.4rem, 2.8vw, 2.1rem);
    line-height: 1.05;
    margin-bottom: var(--space-3);
    font-family: var(--font-serif);
}

.footer-copy {
    color: var(--ink-soft);
    max-width: 28rem;
}

.footer-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-top: var(--space-6);
    padding-top: var(--space-4);
    border-top: 1px solid var(--line);
    font-size: 0.74rem;
    color: var(--ink-soft);
}

.footer-bottom-tag {
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-size: 0.66rem;
    font-weight: 600;
}

.about-background {
    background: linear-gradient(135deg, #0f766e 0%, #1e293b 100%);
    border-radius: 0 0 var(--radius-lg) var(--radius-lg);
    height: 250px;
    position: relative !important;
}

.headline {
    padding-top: 80px;
    color: white;
}

.year {
    font-size: clamp(4rem, 10vw, 8rem);
    margin-top: 0;
    padding-top: 0;
    color: rgba(23, 23, 23, 0.16);
}

.work-exp {
    padding-top: 3rem;
    min-height: 380px;
}

.work-place {
    font-size: 1.2rem;
    color: var(--ink-soft);
}

.engineering-page {
    max-width: 1120px;
}

.engineering-hero {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(260px, 0.75fr);
    gap: clamp(1rem, 2.6vw, 2rem);
    border: 1px solid var(--line);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.95) 0%, rgba(247, 241, 233, 0.82) 100%);
    padding: clamp(1rem, 2.8vw, 2rem);
}

.engineering-hero__main {
    display: grid;
    gap: 0.9rem;
}

.engineering-lead {
    margin: 0;
    color: #3f382f;
    max-width: 60ch;
    line-height: 1.75;
}

.engineering-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    margin-top: 0.35rem;
}

.engineering-trust-panel {
    border-left: 1px solid var(--line);
    padding-left: clamp(0.8rem, 1.8vw, 1.3rem);
    display: grid;
    gap: 0.8rem;
    align-content: start;
}

.engineering-trust-panel__title {
    margin: 0;
    font-size: 0.72rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--ink-soft);
    font-weight: 700;
}

.engineering-trust-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 0.5rem;
}

.engineering-trust-list li {
    padding: 0.62rem 0.7rem;
    border: 1px solid var(--line);
    background: #fff;
    font-size: 0.9rem;
    line-height: 1.5;
}

.engineering-workflow-shell {
    width: min(100%, 920px);
    margin: 0 auto;
    display: grid;
    grid-template-columns: minmax(220px, 0.42fr) minmax(0, 1fr);
    gap: 0.9rem;
    align-items: start;
}

.engineering-workflow-intro {
    border: 1px solid var(--line);
    background: linear-gradient(180deg, rgba(247, 241, 232, 0.95) 0%, rgba(255, 255, 255, 0.98) 100%);
    padding: 0.85rem;
    display: grid;
    gap: 0.55rem;
    position: sticky;
    top: 5.4rem;
}

.engineering-workflow-intro__label {
    font-size: 0.64rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--ink-soft);
    font-weight: 700;
}

.engineering-workflow-intro h3 {
    margin: 0;
    font-family: var(--font-serif);
    font-size: 1.45rem;
    line-height: 1.02;
}

.engineering-workflow-intro p {
    margin: 0;
    color: var(--ink-soft);
    font-size: 0.9rem;
    line-height: 1.55;
}

.engineering-workflow-intro ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 0.45rem;
}

.engineering-workflow-intro li {
    border: 1px solid rgba(183, 171, 152, 0.55);
    background: rgba(255, 255, 255, 0.86);
    padding: 0.42rem 0.5rem;
    font-size: 0.78rem;
    line-height: 1.45;
    color: #564c42;
}

.engineering-workflow {
    list-style: none;
    margin: 0;
    padding: 0;
    position: relative;
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.72rem;
    border: none;
    background: transparent;
}

.engineering-workflow::before {
    content: '';
    position: absolute;
    left: 1rem;
    top: 0.15rem;
    bottom: 0.15rem;
    width: 2px;
    background: linear-gradient(180deg, rgba(106, 90, 69, 0.55) 0%, rgba(106, 90, 69, 0.2) 100%);
}

.engineering-workflow li {
    display: grid;
    grid-template-columns: 2rem minmax(0, 1fr);
    gap: 0.72rem;
    align-items: start;
    padding: 0;
    border: none;
    background: transparent;
}

.engineering-workflow__step {
    width: 2rem;
    height: 2rem;
    border-radius: 999px;
    border: 1px solid rgba(106, 90, 69, 0.55);
    background: linear-gradient(180deg, rgba(250, 244, 234, 1) 0%, rgba(242, 230, 214, 1) 100%);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.62rem;
    letter-spacing: 0.08em;
    color: #5f5346;
    font-weight: 700;
    position: relative;
    z-index: 1;
}

.engineering-workflow__body {
    display: grid;
    gap: 0.35rem;
    border: 1px solid var(--line);
    background: #fff;
    padding: 0.8rem 0.9rem;
}

.engineering-workflow h3 {
    margin: 0;
    font-size: 1.02rem;
    font-family: var(--font-serif);
    line-height: 1.08;
}

.engineering-workflow p {
    margin: 0;
    color: var(--ink-soft);
    line-height: 1.5;
    font-size: 0.87rem;
}

.engineering-workflow span {
    margin-top: 0.22rem;
    display: inline-flex;
    width: fit-content;
    font-size: 0.62rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #5e564d;
    border: 1px solid rgba(108, 96, 82, 0.4);
    background: rgba(246, 238, 228, 0.8);
    padding: 0.2rem 0.46rem;
    border-radius: 999px;
}

.engineering-principles {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.9rem;
}

.engineering-principles article {
    border: 1px solid var(--line);
    background: #fff;
    padding: 0.95rem;
}

.engineering-principles h3 {
    margin: 0;
    font-family: var(--font-serif);
    font-size: 1.25rem;
    line-height: 1.08;
}

.engineering-principles p {
    margin: 0.55rem 0 0;
    color: var(--ink-soft);
}

.engineering-tools {
    border: 1px solid var(--line);
    background: var(--surface);
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.engineering-tools > div {
    padding: 0.95rem;
    border-right: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
}

.engineering-tools > div:nth-child(2n) {
    border-right: none;
}

.engineering-tools > div:nth-last-child(-n + 2) {
    border-bottom: none;
}

.engineering-tools h3 {
    margin: 0;
    font-size: 0.78rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--ink-soft);
}

.engineering-tools p {
    margin: 0.45rem 0 0;
    font-family: var(--font-serif);
    font-size: 1.35rem;
    line-height: 1.12;
}

.engineering-lifecycle {
    width: min(100%, 980px);
    margin: 0 auto;
    border: 1px solid var(--line);
    background: linear-gradient(180deg, rgba(252, 249, 244, 0.95) 0%, rgba(255, 255, 255, 0.98) 100%);
}

.engineering-lifecycle__row {
    display: grid;
    grid-template-columns: minmax(200px, 0.35fr) minmax(0, 1fr);
    gap: 0;
    border-bottom: 1px solid var(--line);
}

.engineering-lifecycle__row:last-child {
    border-bottom: none;
}

.engineering-lifecycle__stage {
    padding: 0.82rem;
    border-right: 1px solid var(--line);
    background: rgba(248, 242, 234, 0.9);
    display: grid;
    gap: 0.35rem;
    align-content: center;
}

.engineering-lifecycle__stage span {
    display: inline-flex;
    width: fit-content;
    font-size: 0.62rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--ink-soft);
    border: 1px solid rgba(183, 171, 152, 0.7);
    background: #fff;
    padding: 0.14rem 0.4rem;
}

.engineering-lifecycle__stage h3 {
    margin: 0;
    font-family: var(--font-serif);
    font-size: 1.2rem;
    line-height: 1.05;
}

.engineering-lifecycle__detail {
    padding: 0.82rem 0.9rem;
    display: grid;
    gap: 0.45rem;
}

.engineering-lifecycle__detail p {
    margin: 0;
    color: var(--ink-soft);
    line-height: 1.55;
    font-size: 0.9rem;
}

.engineering-lifecycle__detail ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.32rem;
}

.engineering-lifecycle__detail li {
    border: 1px solid rgba(183, 171, 152, 0.58);
    background: #fff;
    color: #5f564d;
    font-size: 0.63rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 0.2rem 0.42rem;
}

.engineering-domain-suite {
    width: min(100%, 980px);
    margin: 0 auto;
    display: grid;
    gap: 0.9rem;
}

.engineering-domain-anchor {
    border: 1px solid var(--line);
    background: linear-gradient(140deg, rgba(247, 241, 232, 0.96) 0%, rgba(255, 255, 255, 0.98) 100%);
    padding: clamp(0.9rem, 2vw, 1.2rem);
    display: grid;
    gap: 0.5rem;
}

.engineering-domain-anchor__label {
    font-size: 0.64rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--ink-soft);
    font-weight: 700;
}

.engineering-domain-anchor h3 {
    margin: 0;
    font-family: var(--font-serif);
    font-size: clamp(1.5rem, 2.8vw, 2rem);
    line-height: 1.04;
    max-width: 20ch;
}

.engineering-domain-anchor p {
    margin: 0;
    color: var(--ink-soft);
    line-height: 1.66;
    max-width: 70ch;
}

.engineering-domain-anchor ul {
    list-style: none;
    margin: 0.1rem 0 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.engineering-domain-anchor li {
    border: 1px solid rgba(183, 171, 152, 0.6);
    background: rgba(255, 255, 255, 0.88);
    padding: 0.28rem 0.5rem;
    font-size: 0.72rem;
    color: #564c42;
}

.engineering-domain-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.72rem;
}

.engineering-domain-card {
    border: 1px solid var(--line);
    background: #fff;
    padding: 0.82rem;
    display: grid;
    gap: 0.45rem;
}

.engineering-domain-card header {
    display: grid;
    gap: 0.25rem;
    border-bottom: 1px solid var(--line);
    padding-bottom: 0.45rem;
}

.engineering-domain-card h4 {
    margin: 0;
    font-family: var(--font-serif);
    font-size: 1.45rem;
    line-height: 1.02;
}

.engineering-domain-card__focus {
    margin: 0;
    display: inline-flex;
    width: fit-content;
    font-size: 0.66rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--ink-soft);
    font-weight: 700;
}

.engineering-domain-card__summary {
    margin: 0;
    color: var(--ink-soft);
    font-size: 0.9rem;
    line-height: 1.55;
}

.engineering-domain-card ul {
    list-style: none;
    margin: 0.05rem 0 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
}

.engineering-domain-card li {
    border: 1px solid rgba(183, 171, 152, 0.58);
    background: rgba(250, 246, 239, 0.92);
    padding: 0.22rem 0.45rem;
    font-size: 0.66rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #5e554b;
}

.engineering-domain-more {
    border: 1px dashed rgba(183, 171, 152, 0.8);
    background: rgba(251, 248, 243, 0.9);
    padding: 0.62rem 0.72rem;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.engineering-domain-more__label {
    font-size: 0.62rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--ink-soft);
    font-weight: 700;
}

.engineering-domain-more__items {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
}

.engineering-domain-more__items span {
    border: 1px solid rgba(183, 171, 152, 0.65);
    background: #fff;
    padding: 0.2rem 0.45rem;
    font-size: 0.66rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #5e554b;
}

.engineering-case-study {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(260px, 0.8fr);
    gap: 0.9rem;
}

.engineering-case-study__lead {
    border: 1px solid var(--line);
    background: linear-gradient(160deg, rgba(250, 246, 239, 0.95) 0%, #fff 100%);
    padding: clamp(0.9rem, 2vw, 1.35rem);
    display: grid;
    gap: 0.65rem;
}

.engineering-case-study__lead h3 {
    margin: 0;
    font-family: var(--font-serif);
    font-size: clamp(1.6rem, 3vw, 2.2rem);
    line-height: 1.02;
}

.engineering-case-study__lead p {
    margin: 0;
    color: var(--ink-soft);
    line-height: 1.65;
}

.engineering-case-study__rail {
    border: 1px solid var(--line);
    background: #fff;
    display: grid;
    align-content: start;
}

.engineering-case-study__rail a {
    display: grid;
    gap: 0.32rem;
    padding: 0.74rem 0.82rem;
    border-bottom: 1px solid var(--line);
}

.engineering-case-study__rail a:last-child {
    border-bottom: none;
}

.engineering-case-study__rail span {
    font-size: 0.63rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--ink-soft);
}

.engineering-case-study__rail strong {
    font-family: var(--font-serif);
    font-size: 1rem;
    line-height: 1.2;
    font-weight: 600;
}

.engineering-empty {
    border: 1px dashed var(--line-strong);
    background: var(--surface);
    padding: 0.9rem;
}

.engineering-empty p {
    margin: 0;
    color: var(--ink-soft);
}

@media only screen and (max-width: 991px) {
    .site-header__inner,
    .hero-panel,
    .contact-grid,
    .home-hero-grid,
    .detail-hero,
    .about-intro {
        grid-template-columns: 1fr;
    }

    .contact-metadata {
        display: none;
    }

    .contact-meta-compact {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0.75rem;
        padding: 0.65rem 0.9rem;
        border: 1px solid var(--line);
        border-radius: var(--radius-sm);
        background: var(--surface-muted);
        font-size: 0.78rem;
        color: var(--ink-soft);
        flex-wrap: wrap;
    }

    .contact-meta-compact a {
        font-weight: 600;
        color: var(--ink);
    }

    .about-capabilities {
        grid-template-columns: 1fr;
    }

    .home-asym-grid {
        grid-template-columns: 1fr;
    }

    .project-detail-grid {
        grid-template-columns: 1fr;
    }

    .project-text-revamp-grid {
        grid-template-columns: 1fr;
    }

    .project-context-panel {
        position: static;
        max-height: none;
        overflow: visible;
    }

    .article-index-hero,
    .article-lead,
    .article-audience-head,
    .article-reader-hero,
    .article-reader-layout {
        grid-template-columns: 1fr;
    }

    .article-story-grid,
    .article-reader-more-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .article-lead-media {
        min-height: 320px;
        border-left: none;
        border-top: 1px solid rgba(58, 46, 32, 0.12);
    }

    .article-reader-rail {
        position: static;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .article-reader-title {
        max-width: none;
    }

    .article-reader-image {
        max-height: 520px;
    }

    .collection-grid {
        grid-template-columns: 1fr;
    }

    .engineering-hero,
    .engineering-case-study {
        grid-template-columns: 1fr;
    }

    .engineering-trust-panel {
        border-left: none;
        border-top: 1px solid var(--line);
        padding-left: 0;
        padding-top: 0.8rem;
    }

    .engineering-principles,
    .engineering-tools {
        grid-template-columns: 1fr;
    }

    .engineering-lifecycle__row {
        grid-template-columns: 1fr;
    }

    .engineering-lifecycle__stage {
        border-right: none;
        border-bottom: 1px solid var(--line);
    }

    .engineering-domain-grid {
        grid-template-columns: 1fr;
    }

    .engineering-workflow-shell {
        grid-template-columns: 1fr;
    }

    .engineering-workflow-intro {
        position: static;
    }

    .engineering-tools > div,
    .engineering-tools > div:nth-child(2n),
    .engineering-tools > div:nth-last-child(-n + 2) {
        border-right: none;
        border-bottom: 1px solid var(--line);
    }

    .engineering-tools > div:last-child {
        border-bottom: none;
    }

    .collection-card {
        border-radius: var(--radius-sm);
    }

    .collection-card-image--project {
        aspect-ratio: 16 / 10;
        max-height: 280px;
    }

    .project-shot-window {
        max-height: 280px;
    }

    .project-shot-toolbar {
        display: none;
    }

    .project-shot-chip--collection {
        top: 0.42rem;
        right: 0.48rem;
        padding: 0.18rem 0.44rem;
        font-size: 0.56rem;
    }

    .collection-card-body {
        padding: 0.95rem;
        gap: 0.5rem;
    }

    .collection-card-title {
        font-size: clamp(1.25rem, 6vw, 1.8rem);
        line-height: 1.08;
    }

    .collection-card-copy {
        font-size: 0.9rem;
        line-height: 1.5;
    }

    .collection-card-link {
        font-size: 0.85rem;
    }

    .minimal-card-meta {
        font-size: 0.75rem;
    }

    .detail-meta {
        border-left: none;
        border-top: 1px solid var(--line);
        padding-left: 0;
        padding-top: 0.8rem;
    }

    .site-header__inner {
        align-items: center;
    }

    .footer-grid {
        grid-template-columns: 1fr 1fr;
    }

    .footer-primary {
        grid-column: 1 / -1;
    }

    .site-nav {
        justify-content: flex-start;
    }
}

@media only screen and (max-width: 767px) {
    :root {
        --mobile-nav-height: 4.9rem;
        --page-gutter: 1.5rem;
        --page-gutter-narrow: 1.5rem;
    }

    .about-capabilities {
        grid-template-columns: 1fr 1fr;
    }

    .about-capability-group {
        padding: 0.9rem;
    }

    .page-shell {
        padding-top: 0;
        padding-bottom: var(--space-7);
    }

    .site-header {
        position: static;
        border-bottom: none;
        background: transparent;
        backdrop-filter: none;
        padding: 0.55rem 0 0;
    }

    .site-header__inner {
        padding: 0.8rem;
        border-radius: var(--radius-md);
        justify-content: flex-start;
        gap: 0.65rem;
    }

    .site-header__actions {
        margin-left: auto;
        gap: 0.45rem;
    }

    .site-header__actions::before {
        display: none;
    }

    .site-nav {
        position: fixed;
        left: 0.5rem;
        right: 0.5rem;
        bottom: 0;
        z-index: 1200;
        display: flex;
        flex-direction: row;
        gap: 0.4rem;
        padding: 0.5rem 0.5rem calc(0.5rem + env(safe-area-inset-bottom, 0));
        background: rgba(251, 248, 243, 0.98);
        border: 1px solid var(--line);
        border-bottom: none;
        border-radius: 0.95rem 0.95rem 0 0;
        box-shadow: 0 -10px 26px rgba(34, 30, 24, 0.12);
        backdrop-filter: blur(8px);
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    .site-nav::-webkit-scrollbar {
        display: none;
    }

    .site-nav__link {
        min-height: 2.8rem;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
        white-space: nowrap;
        border-radius: 0.65rem;
        padding: 0.6rem 0.9rem;
        font-size: 0.75rem;
        font-weight: 600;
        letter-spacing: 0.06em;
        text-transform: uppercase;
        background: rgba(255, 255, 255, 0.72);
        border: 1px solid rgba(183, 171, 152, 0.5);
        color: var(--ink-soft);
        touch-action: manipulation;
        -webkit-tap-highlight-color: rgba(46, 41, 36, 0.16);
        transition: all 140ms ease;
    }

    .site-nav__link:active {
        color: var(--ink);
        background: var(--surface-strong);
        border-color: var(--line);
    }

    .site-nav__link--cta {
        background: var(--accent);
        border-color: var(--accent);
        color: #fff;
        font-weight: 700;
        margin-left: auto;
        flex-shrink: 1;
        display: none;
    }

    .language-switcher {
        margin: 0;
        transform: none;
        padding: 0.16rem;
    }

    .language-switcher__name {
        display: none;
    }

    .language-switcher__button {
        min-width: 3.2rem;
        justify-content: center;
    }

    .brand-mark {
        min-width: 0;
        flex: 1;
    }

    .brand-mark__text {
        flex-direction: row;
        align-items: baseline;
        gap: 0.4rem;
    }

    .brand-mark__name {
        font-size: 0.72rem;
    }

    .brand-mark__role {
        font-size: 0.6rem;
    }

    .site-main {
        padding-top: var(--space-6);
        padding-bottom: calc(var(--space-8) + var(--mobile-nav-height) + env(safe-area-inset-bottom, 0));
    }

    .about-page {
        gap: 1rem;
    }

    .about-intro {
        padding: 0.9rem;
        gap: 0.85rem;
    }

    .about-portrait-wrap {
        width: min(100%, 420px);
        margin: 0 auto;
        padding: 0.5rem;
    }

    .about-title {
        font-size: clamp(1.45rem, 7.2vw, 2.1rem);
        line-height: 1.05;
    }

    .about-lead {
        font-size: 0.92rem;
        line-height: 1.62;
    }

    .about-location {
        border-top: none;
        padding-top: 0;
        font-size: 0.9rem;
    }

    .about-links {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.5rem;
    }

    .about-links a {
        width: 100%;
        min-height: 2.6rem;
        font-size: 0.68rem;
        letter-spacing: 0.1em;
    }

    .timeline-list {
        border: none;
        background: transparent;
        border-radius: 0;
        overflow: visible;
        display: grid;
        gap: 0.55rem;
    }

    .hero-panel,
    .contact-panel,
    .footer-panel {
        padding: 1.2rem;
    }

    .hero-actions,
    .form-actions,
    .home-hero-actions,
    .home-cta {
        flex-direction: column;
        align-items: stretch;
    }

    .home-hero-actions .pill-link,
    .home-cta .pill-link {
        width: 100%;
        min-height: 3.2rem;
    }

    .home-hero-title {
        max-width: none;
        font-size: clamp(2rem, 10vw, 2.9rem);
        line-height: 1.02;
    }

    .home-hero-grid {
        padding: 1.15rem;
    }

    .home-hero-side {
        border-left: none;
        border-top: 1px solid var(--line);
        padding-left: 0;
        padding-top: 1rem;
    }

    .featured-piece-title {
        font-size: clamp(1.8rem, 8vw, 2.6rem);
    }

    .article-index-page {
        padding-top: 0.2rem;
    }

    .article-index-hero {
        gap: 1rem;
    }

    .article-index-intro {
        gap: 0.3rem;
    }

    .article-audience-nav {
        display: flex;
        gap: 0.65rem;
        overflow-x: auto;
        overflow-y: hidden;
        max-height: none;
        padding-bottom: 0.15rem;
        scroll-snap-type: x proximity;
        -webkit-overflow-scrolling: touch;
    }

    .article-audience-nav::-webkit-scrollbar {
        display: none;
    }

    .article-audience-pill {
        flex: 0 0 15rem;
        min-width: 15rem;
        padding: 0.78rem 0.84rem;
        gap: 0.42rem;
        scroll-snap-align: start;
    }

    .article-audience-pill__title {
        font-size: 0.95rem;
    }

    .article-audience-pill__count {
        font-size: 0.62rem;
    }

    .article-lead {
        gap: 0;
        border-radius: var(--radius-md);
    }

    .article-lead-copy-wrap {
        padding: 0.95rem 0.95rem 1rem;
        gap: 0.72rem;
    }

    .article-lead-copy {
        display: none;
    }

    .article-lead-footer {
        align-items: flex-start;
        gap: 0.5rem;
    }

    .article-lead-tag {
        font-size: 0.62rem;
        letter-spacing: 0.12em;
    }

    .article-lead-media {
        min-height: 220px;
    }

    .article-lead-image {
        aspect-ratio: 16 / 9;
        min-height: 220px;
    }

    .article-audience-stack {
        gap: 0.9rem;
    }

    .article-audience-section {
        padding: 0.82rem;
        gap: 0.8rem;
        border-radius: var(--radius-sm);
    }

    .article-audience-head {
        gap: 0.28rem;
        padding-bottom: 0.22rem;
        border-bottom: none;
    }

    .article-audience-label {
        font-size: 0.62rem;
        margin-bottom: 0.24rem;
    }

    .article-audience-title {
        font-size: clamp(1.18rem, 6.4vw, 1.5rem);
        line-height: 1.08;
    }

    .article-audience-summary {
        display: none;
    }

    .article-audience-count {
        justify-self: start;
        margin-top: 0.2rem;
    }

    .article-story-grid {
        grid-template-columns: 1fr;
        gap: 0.6rem;
    }

    .article-reader-more-grid,
    .article-reader-rail {
        grid-template-columns: 1fr;
    }

    .article-lead-title {
        max-width: none;
        font-size: clamp(1.65rem, 9vw, 2.5rem);
    }

    .article-reader-title {
        font-size: clamp(1.75rem, 10vw, 2.8rem);
        line-height: 0.96;
    }

    .article-reader-intro {
        font-size: 0.94rem;
        line-height: 1.68;
    }

    .article-reader-context,
    .article-reader-rail-card {
        padding: 0.82rem;
    }

    .article-reader-prose {
        font-size: 0.98rem;
        line-height: 1.8;
    }

    .article-reader-prose blockquote {
        font-size: 1rem;
        padding-left: 0.82rem;
    }

    .article-story-title {
        font-size: 1.25rem;
    }

    .article-story-card {
        padding: 0.72rem;
        gap: 0.38rem;
        border-left: 3px solid rgba(58, 46, 32, 0.18);
        box-shadow: none;
    }

    .article-story-meta {
        font-size: 0.63rem;
        letter-spacing: 0.1em;
    }

    .article-story-title {
        font-size: 1.08rem;
    }

    .article-story-copy {
        display: none;
    }

    .article-story-subtitle {
        font-size: 0.84rem;
    }

    .article-story-link {
        font-size: 0.76rem;
    }

    .collection-card {
        border-radius: var(--radius-sm);
    }

    .collection-card--with-image {
        grid-template-columns: 116px minmax(0, 1fr);
        grid-template-rows: 1fr;
        align-items: stretch;
    }

    .project-shot-stage--collection {
        height: 100%;
        border-right: 1px solid var(--line);
        border-bottom: none;
    }

    .project-shot-window--collection {
        height: 100%;
        max-height: 150px;
        border-bottom: none;
        overflow: hidden;
    }

    .collection-card-image--project {
        width: 100%;
        height: 100%;
        aspect-ratio: auto;
        max-height: none;
        object-fit: cover;
    }

    .project-shot-toolbar,
    .project-shot-chip--collection {
        display: none;
    }

    .collection-card-body {
        padding: 0.76rem 0.8rem;
        gap: 0.34rem;
        align-content: center;
    }

    .collection-card-title {
        font-size: clamp(1rem, 5vw, 1.18rem);
        line-height: 1.08;
    }

    .collection-card-copy {
        font-size: 0.8rem;
        line-height: 1.4;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }

    .collection-card-link {
        font-size: 0.72rem;
        margin-top: 0.08rem;
    }

    .minimal-card-meta {
        font-size: 0.64rem;
    }

    .project-shot-controls {
        grid-template-columns: 1fr;
        padding: 0.44rem 0.52rem;
        gap: 0.38rem;
    }

    .project-shot-slider {
        grid-column: auto;
        min-height: 2rem;
    }

    .project-shot-btn {
        display: none;
    }

    .project-shot-toolbar,
    .project-shot-chip {
        display: none;
    }

    .project-shot-window--detail {
        max-height: clamp(260px, 56vh, 440px);
    }

    .project-detail-grid {
        gap: 0.8rem;
    }

    .project-context-panel {
        padding: 0.82rem;
        gap: 0.58rem;
    }

    .project-detail-title {
        font-size: clamp(1.35rem, 8.6vw, 2rem);
        line-height: 1.02;
    }

    .project-context-summary {
        font-size: 0.9rem;
        line-height: 1.54;
    }

    .project-text-revamp {
        margin-top: 0.9rem;
        padding: 0.84rem;
        gap: 0.72rem;
    }

    .project-text-revamp-head {
        gap: 0.22rem;
        padding-bottom: 0.56rem;
    }

    .project-text-revamp-title {
        font-size: clamp(1.08rem, 6.2vw, 1.35rem);
        line-height: 1.12;
    }

    .project-snapshot-shell--revamp,
    .project-notes-panel--revamp {
        padding: 0.64rem;
    }

    .project-snapshot-card--revamp {
        padding: 0.58rem 0.08rem;
    }

    .project-snapshot-card p {
        font-size: 0.8rem;
        line-height: 1.46;
    }

    .project-notes-head {
        align-items: flex-start;
        gap: 0.45rem;
    }

    .project-notes-hint {
        font-size: 0.54rem;
    }

    .project-notes-content--revamp {
        max-height: 12.5rem;
        font-size: 0.93rem;
        line-height: 1.7;
    }

    .project-notes-content--revamp h2 {
        font-size: 1.2rem;
    }

    .project-notes-content--revamp h3 {
        font-size: 1.05rem;
    }

    .project-notes-content--revamp ul,
    .project-notes-content--revamp ol {
        padding-left: 1.05rem;
    }

    .project-context-meta {
        grid-template-columns: 1fr;
    }

    .project-brief-grid {
        grid-template-columns: 1fr;
    }

    .project-snapshot-grid {
        grid-template-columns: 1fr;
    }

    .timeline-item {
        grid-template-columns: 1fr;
        gap: 0.45rem;
        border: 1px solid var(--line);
        background: var(--surface);
        border-radius: var(--radius-sm);
        padding: 0.78rem;
        margin: 0;
    }

    .timeline-year {
        font-size: 1.6rem;
        color: var(--ink);
    }

    .gallery-strip {
        width: 100%;
        margin-left: 0;
        margin-right: 0;
        margin-top: 1.4rem;
        margin-bottom: 1.6rem;
        min-height: 220px;
        border-radius: var(--radius-md);
        overflow: hidden;
    }

    .mobile-fab-contact {
        display: inline-flex;
    }

    .form-grid {
        grid-template-columns: 1fr;
    }

    .footer-grid {
        grid-template-columns: 1fr;
        gap: 1.05rem;
    }

    .footer-panel {
        border-radius: var(--radius-md);
        padding: 0.95rem 0.95rem 1rem;
        background: var(--surface-muted);
        border-color: rgba(164, 146, 122, 0.22);
    }

    .site-footer {
        padding-bottom: calc(var(--space-5) + var(--mobile-nav-height) + env(safe-area-inset-bottom, 0));
    }

    .footer-primary {
        gap: 0.35rem;
    }

    .footer-title {
        font-size: clamp(1.08rem, 5.6vw, 1.38rem);
        line-height: 1.14;
        margin-bottom: 0.2rem;
    }

    .footer-copy {
        font-size: 0.85rem;
        line-height: 1.5;
        max-width: 36ch;
        opacity: 0.9;
    }

    .footer-email {
        margin-top: 0.45rem;
        font-size: 0.86rem;
    }

    .footer-bottom {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.4rem;
    }

    .footer-header {
        margin-bottom: 0.55rem;
        font-size: 0.68rem;
        letter-spacing: 0.11em;
    }

    .footer-list {
        gap: 0.45rem;
    }

    .footer-list a {
        font-size: 0.86rem;
        color: var(--ink-soft);
    }

    .pro-image {
        min-height: 280px;
    }

    .text-block {
        inset: auto 1rem 1rem 1rem;
        padding: 1rem;
    }

    .about-background {
        display: none;
    }

    .year {
        font-size: 3rem;
    }

    .work-exp {
        padding-top: 2rem;
        min-height: auto;
    }
}

@media only screen and (max-width: 420px) {
    .about-capabilities {
        grid-template-columns: 1fr;
    }

    .brand-mark__role {
        display: none;
    }

    .site-nav {
        gap: 0.35rem;
        padding: 0.45rem 0.45rem calc(0.45rem + env(safe-area-inset-bottom, 0));
    }

    .site-nav__link {
        margin: auto;
        min-height: 2.7rem;
        padding: 0.55rem 0.75rem;
        font-size: 0.5rem;
        gap: 0.3rem;
        box-shadow: none;
    }

    .site-nav__link--cta {
        display: none;
    }

    .mobile-fab-contact {
        display: inline-flex;
        min-height: 2.7rem;
        padding: 0.66rem 0.88rem;
        font-size: 0.62rem;
    }

    .about-links {
        grid-template-columns: 1fr;
    }

    .footer-copy {
        display: none;
    }

    .footer-grid > section:last-child {
        display: none;
    }

}

@media only screen and (max-width: 520px) {
    .article-reader-meta-row {
        gap: 0.45rem;
        font-size: 0.62rem;
    }

    .article-reader-separator {
        width: 1rem;
    }

    .article-reader-intro {
        font-size: 0.88rem;
    }

    .article-reader-context-title {
        font-size: 1.12rem;
    }

    .article-reader-context-copy,
    .article-reader-rail-card p {
        font-size: 0.84rem;
        line-height: 1.55;
    }

    .article-reader-image {
        max-height: 260px;
    }

    .article-reader-prose {
        font-size: 0.94rem;
        line-height: 1.72;
    }

    .article-reader-prose h2 {
        font-size: 1.28rem;
    }

    .article-reader-prose h3 {
        font-size: 1.12rem;
    }

    .article-index-hero {
        gap: 0.82rem;
    }

    .article-audience-pill {
        flex-basis: 13.25rem;
        min-width: 13.25rem;
        padding: 0.58rem 0.64rem;
    }

    .article-audience-pill__count {
        min-width: 1.95rem;
        padding: 0.1rem 0.36rem;
    }

    .article-lead-copy-wrap {
        padding: 0.82rem;
    }

    .article-lead-title {
        font-size: clamp(1.35rem, 8vw, 1.72rem);
    }

    .article-lead-copy {
        display: none;
    }

    .article-lead-media,
    .article-lead-image {
        min-height: 180px;
    }

    .article-audience-section {
        padding: 0.72rem;
    }

    .engineering-hero {
        padding: 0.9rem;
    }

    .engineering-lead {
        font-size: 0.9rem;
        line-height: 1.62;
    }

    .engineering-hero__actions {
        flex-direction: column;
    }

    .engineering-hero__actions .pill-link {
        width: 100%;
    }

    .engineering-lifecycle__stage,
    .engineering-lifecycle__detail {
        padding: 0.68rem 0.72rem;
    }

    .engineering-lifecycle__stage h3 {
        font-size: 1.03rem;
    }

    .engineering-lifecycle__detail p {
        font-size: 0.82rem;
    }

    .engineering-lifecycle__detail li {
        font-size: 0.56rem;
    }

    .engineering-workflow-shell {
        gap: 0.6rem;
    }

    .engineering-workflow-intro {
        padding: 0.72rem;
    }

    .engineering-workflow-intro h3 {
        font-size: 1.15rem;
    }

    .engineering-workflow-intro p {
        font-size: 0.82rem;
    }

    .engineering-workflow-intro li {
        font-size: 0.72rem;
        padding: 0.35rem 0.42rem;
    }

    .engineering-workflow {
        grid-template-columns: 1fr;
        gap: 0.58rem;
    }

    .engineering-workflow li {
        grid-template-columns: 1.8rem minmax(0, 1fr);
        gap: 0.4rem;
    }

    .engineering-workflow::before {
        left: 0.9rem;
    }

    .engineering-workflow__step {
        width: 1.8rem;
        height: 1.8rem;
    }

    .engineering-workflow h3 {
        font-size: 0.98rem;
    }

    .engineering-workflow p {
        font-size: 0.8rem;
    }

    .engineering-workflow__body {
        padding: 0.68rem 0.72rem;
    }

    .engineering-workflow span {
        font-size: 0.56rem;
    }

    .engineering-principles article {
        padding: 0.72rem;
    }

    .engineering-principles h3 {
        font-size: 1.06rem;
    }

    .engineering-principles p,
    .engineering-domain-card__summary,
    .engineering-case-study__lead p {
        font-size: 0.84rem;
    }

    .engineering-tools p {
        font-size: 1.02rem;
    }

    .engineering-domain-anchor {
        padding: 0.72rem;
    }

    .engineering-domain-anchor h3 {
        font-size: 1.18rem;
    }

    .engineering-domain-anchor p {
        font-size: 0.82rem;
    }

    .engineering-domain-anchor li {
        font-size: 0.65rem;
    }

    .engineering-domain-card {
        padding: 0.68rem;
    }

    .engineering-domain-card h4 {
        font-size: 1.02rem;
    }

    .engineering-domain-card__focus {
        font-size: 0.6rem;
    }

    .engineering-domain-card li {
        font-size: 0.58rem;
    }

    .engineering-domain-more {
        padding: 0.52rem 0.58rem;
    }

    .engineering-domain-more__label,
    .engineering-domain-more__items span {
        font-size: 0.56rem;
    }

    .engineering-case-study__lead {
        padding: 0.8rem;
    }

    .engineering-case-study__lead h3 {
        font-size: 1.22rem;
    }

    .engineering-case-study__rail strong {
        font-size: 0.9rem;
    }

    .article-audience-title {
        font-size: 1.08rem;
    }

    .article-audience-summary {
        display: none;
    }

    .article-story-card {
        padding: 0.66rem;
    }

    .article-story-title {
        font-size: 1rem;
    }

    .article-story-copy {
        display: none;
    }

    .article-story-link {
        font-size: 0.72rem;
    }

    .collection-card--with-image {
        grid-template-columns: 92px minmax(0, 1fr);
    }

    .project-shot-stage--collection {
        min-height: 118px;
    }

    .project-shot-window--collection {
        max-height: 118px;
    }

    .collection-card-body {
        padding: 0.66rem;
        gap: 0.28rem;
    }

    .collection-card-title {
        font-size: 0.98rem;
    }

    .collection-card-copy {
        font-size: 0.75rem;
        -webkit-line-clamp: 2;
    }

    .collection-card-link {
        font-size: 0.68rem;
    }

    .minimal-card-meta {
        font-size: 0.6rem;
    }

    .project-context-meta {
        padding: 0.62rem 0;
        gap: 0.5rem;
    }

    .project-text-revamp {
        padding: 0.7rem;
    }

    .project-notes-content--revamp {
        max-height: 11rem;
    }
}

/* ─── Homepage Mobile Revamp ──────────────────────────────────── */
@media only screen and (max-width: 767px) {

    /* Hero section */
    .home-gallery {
        padding-bottom: 0.3rem;
        margin-bottom: 0.85rem;
    }

    .home-gallery::before {
        display: none;
    }

    .home-hero-grid {
        display: flex;
        flex-direction: column;
        gap: 0;
        padding: 0;
        border: none;
        background: transparent;
    }

    .home-hero-main {
        background: var(--surface);
        border: 1px solid var(--line);
        padding: 1.2rem 1rem 1.25rem;
        gap: var(--space-3);
        padding-right: 1rem;
    }

    .home-hero-title {
        font-size: clamp(2.1rem, 11vw, 3rem);
        line-height: 1;
        letter-spacing: -0.02em;
        max-width: none;
    }

    .home-hero-subtitle {
        font-size: 0.9rem;
        line-height: 1.62;
        color: var(--ink-soft);
        max-width: none;
    }

    .home-hero-actions {
        flex-direction: row;
        flex-wrap: wrap;
        gap: 0.55rem;
        margin-top: 0.3rem;
    }

    .home-hero-actions .pill-link {
        width: auto;
        flex: 1 1 auto;
        min-height: 3rem;
        font-size: 0.72rem;
        padding: 0.8rem 1rem;
        text-align: center;
    }

    /* Exhibit notes sidebar: compact inline tag wrap */
    .home-hero-side {
        border-left: none;
        border-top: 1px solid var(--line);
        padding: 0.7rem 1rem;
        background: var(--bg);
        display: block;
        overflow: hidden;
    }

    .gallery-note-title {
        display: none;
    }

    .gallery-note-list {
        display: flex;
        flex-direction: row;
        flex-wrap: wrap;
        gap: 0.4rem 0.6rem;
        margin: 0;
        padding: 0;
        list-style: none;
        color: var(--ink-soft);
        font-size: 0.68rem;
    }

    .gallery-note-list::-webkit-scrollbar {
        display: none;
    }

    .gallery-note-list li {
        border-bottom: none;
        border-right: none;
        padding: 0.22rem 0.55rem;
        margin: 0;
        background: var(--surface-muted);
        border: 1px solid var(--line);
        border-radius: 999px;
        white-space: nowrap;
        flex-shrink: 0;
        line-height: 1.4;
    }

    .gallery-note-links {
        display: none;
    }

    /* Section headings */
    .section-heading {
        margin-bottom: var(--space-3);
    }

    .section-heading .eyebrow {
        font-size: 0.65rem;
    }

    .section-heading .spec {
        font-size: clamp(1.4rem, 7vw, 2rem);
    }

    /* Featured piece */
    .featured-piece {
        border-radius: var(--radius-sm);
        overflow: hidden;
    }

    .featured-piece-body {
        padding: 1rem 1rem 1.1rem;
        gap: 0.5rem;
    }

    .featured-piece-title {
        font-size: clamp(1.5rem, 7.5vw, 2rem);
        line-height: 1.02;
    }

    .featured-piece-copy {
        font-size: 0.88rem;
        line-height: 1.55;
        margin: 0 0 0.6rem;
    }

    /* Stacked minimal card list */
    .stacked-piece-list {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.55rem;
    }

    .stacked-piece-list .minimal-card:nth-child(n + 3) {
        display: none;
    }

    .minimal-card {
        border-radius: var(--radius-sm);
        padding: 0.9rem 0.85rem;
        display: flex;
        flex-direction: column;
        gap: 0.38rem;
        min-height: 0;
    }

    .minimal-card-title {
        margin: 0;
        font-size: clamp(1rem, 5vw, 1.3rem);
        line-height: 1.1;
    }

    .minimal-card-copy {
        font-size: 0.82rem;
        line-height: 1.48;
        margin: 0 0 0.4rem;
        display: -webkit-box;
        -webkit-line-clamp: 3;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }

    .minimal-card-link {
        margin-top: auto;
        font-size: 0.68rem;
    }

    /* Asymmetric grid already 1fr at 991px, keep tight spacing on mobile */
    .home-asym-grid {
        gap: 0.75rem;
    }

    .gallery-strip,
    .gallery-strip--short {
        display: none;
    }

    /* Show all / archive buttons */
    .d-flex.justify-content-center.mb-2 {
        margin-top: 0.85rem;
    }

    .d-flex.justify-content-center .pill-link {
        font-size: 0.72rem;
        min-height: 3rem;
        width: 100%;
        padding: 0.8rem 1.1rem;
    }

    /* Bottom CTA strip */
    .home-cta {
        margin-top: var(--space-5);
        padding-top: var(--space-4);
        flex-direction: column;
        align-items: flex-start;
        gap: var(--space-3);
    }

    .home-cta p {
        font-size: 0.88rem;
        max-width: 34ch;
    }

    .home-cta .pill-link {
        width: 100%;
        min-height: 3rem;
        font-size: 0.74rem;
    }
}

@media only screen and (max-width: 767px) {
    /* Engineering page mobile - better readability, all content visible */
    
    /* Hero section */
    .engineering-hero {
        grid-template-columns: 1fr;
        gap: 1.2rem;
        padding: 1.2rem;
        border-radius: var(--radius-md);
    }

    .engineering-hero__main {
        gap: 0.9rem;
    }

    .engineering-hero__main h1 {
        font-size: clamp(1.4rem, 6.5vw, 1.9rem);
        line-height: 1.08;
        letter-spacing: -0.02em;
    }

    .engineering-lead {
        font-size: 0.96rem;
        line-height: 1.75;
        color: #5a5047;
        max-width: none;
    }

    .engineering-hero__actions {
        flex-direction: column;
        gap: 0.6rem;
        margin-top: 0.6rem;
    }

    .engineering-hero__actions .pill-link {
        width: 100%;
        min-height: 2.9rem;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 0.85rem;
    }

    /* Trust panel - adapt to mobile */
    .engineering-trust-panel {
        border-left: none;
        border-top: 2px solid var(--line);
        padding-left: 0;
        padding-top: 1rem;
    }

    .engineering-trust-panel__title {
        font-size: 0.76rem;
        margin-bottom: 0.7rem;
    }

    .engineering-trust-list {
        gap: 0.6rem;
    }

    .engineering-trust-list li {
        padding: 0.7rem;
        font-size: 0.9rem;
        line-height: 1.65;
        background: rgba(255,255,255,0.8);
    }

    /* Workflow */
    .engineering-workflow-shell {
        grid-template-columns: 1fr;
        gap: 0;
        width: 100%;
        display: block;
    }

    .engineering-workflow-intro {
        position: static;
        margin-bottom: 1.2rem;
        padding: 0.9rem;
        border: 1px solid var(--line);
        border-radius: var(--radius-md);
    }

    .engineering-workflow-intro h3 {
        font-size: 1.3rem;
        margin-bottom: 0.4rem;
    }

    .engineering-workflow-intro p {
        font-size: 0.9rem;
        margin-bottom: 0.6rem;
    }

    .engineering-workflow-intro li {
        padding: 0.5rem 0.6rem;
        font-size: 0.87rem;
        line-height: 1.6;
        background: rgba(255,255,255,0.9);
    }

    .engineering-workflow {
        gap: 0.9rem;
    }

    .engineering-workflow::before {
        display: none;
    }

    .engineering-workflow li {
        grid-template-columns: 2.3rem minmax(0, 1fr);
        gap: 0.85rem;
        align-items: start;
    }

    .engineering-workflow__step {
        width: 2.3rem;
        height: 2.3rem;
        font-size: 0.66rem;
        border: 2px solid rgba(106, 90, 69, 0.6);
        flex-shrink: 0;
        margin-top: 0.1rem;
    }

    .engineering-workflow__body {
        border: 1px solid var(--line);
        padding: 0.85rem;
        gap: 0.35rem;
    }

    .engineering-workflow h3 {
        font-size: 1.02rem;
        line-height: 1.1;
    }

    .engineering-workflow p {
        font-size: 0.88rem;
        line-height: 1.65;
        color: #6a6259;
    }

    .engineering-workflow span {
        font-size: 0.63rem;
        padding: 0.2rem 0.4rem;
    }

    /* Principles */
    .engineering-principles {
        grid-template-columns: 1fr;
        gap: 0.85rem;
    }

    .engineering-principles article {
        padding: 0.95rem;
        border-radius: var(--radius-sm);
    }

    .engineering-principles h3 {
        font-size: 1.08rem;
        line-height: 1.12;
        margin-bottom: 0.4rem;
    }

    .engineering-principles p {
        margin: 0;
        font-size: 0.9rem;
        line-height: 1.68;
    }

    /* Lifecycle */
    .engineering-lifecycle {
        width: 100%;
    }

    .engineering-lifecycle__row {
        grid-template-columns: 1fr;
        gap: 0.6rem;
    }

    .engineering-lifecycle__stage {
        border-right: none;
        border-bottom: 2px solid var(--line);
        padding: 0.85rem;
        border-radius: var(--radius-sm) var(--radius-sm) 0 0;
    }

    .engineering-lifecycle__stage h3 {
        font-size: 1.1rem;
        margin-bottom: 0.2rem;
    }

    .engineering-lifecycle__detail {
        padding: 0.85rem;
        border-radius: 0 0 var(--radius-sm) var(--radius-sm);
    }

    .engineering-lifecycle__detail p {
        font-size: 0.88rem;
        line-height: 1.65;
    }

    .engineering-lifecycle__detail li {
        font-size: 0.77rem;
        padding: 0.18rem 0.35rem;
    }

    /* Domain suite */
    .engineering-domain-suite {
        width: 100%;
    }

    .engineering-domain-anchor {
        padding: 0.95rem;
        border-radius: var(--radius-md);
    }

    .engineering-domain-anchor h3 {
        font-size: clamp(1.3rem, 6vw, 1.8rem);
        margin-bottom: 0.4rem;
    }

    .engineering-domain-anchor p {
        font-size: 0.9rem;
        line-height: 1.68;
    }

    .engineering-domain-grid {
        grid-template-columns: 1fr;
        gap: 0.8rem;
    }

    .engineering-domain-card {
        padding: 0.85rem;
        border-radius: var(--radius-sm);
    }

    .engineering-domain-card h4 {
        font-size: 1.3rem;
        line-height: 1.05;
        margin-bottom: 0.2rem;
    }

    .engineering-domain-card__summary {
        font-size: 0.88rem;
        line-height: 1.6;
    }

    .engineering-domain-card li {
        font-size: 0.75rem;
    }

    /* Case studies */
    .engineering-case-study {
        grid-template-columns: 1fr;
        gap: 0.9rem;
    }

    .engineering-case-study__lead {
        padding: 1rem;
        border-radius: var(--radius-md);
        gap: 0.65rem;
    }

    .engineering-case-study__lead h3 {
        font-size: clamp(1.2rem, 6vw, 1.7rem);
        line-height: 1.1;
    }

    .engineering-case-study__lead p {
        font-size: 0.9rem;
        line-height: 1.68;
    }

    .engineering-case-study__rail {
        border-radius: var(--radius-md);
    }

    .engineering-case-study__rail a {
        padding: 0.8rem;
        gap: 0.3rem;
    }

    .engineering-case-study__rail span {
        font-size: 0.64rem;
    }

    .engineering-case-study__rail strong {
        font-size: 0.96rem;
        line-height: 1.2;
    }

    /* Section spacing improvements */
    .engineering-page .section-heading {
        margin-bottom: 1.1rem;
        margin-top: 1.6rem;
    }

    .engineering-page .mb-5 {
        margin-bottom: 1.8rem !important;
    }

    .eyebrow {
        font-size: 0.68rem;
        margin-bottom: 0.3rem;
    }

    .spec {
        font-size: clamp(1.5rem, 7vw, 2rem);
        line-height: 1.08;
    }
}

@media only screen and (max-width: 520px) {
    /* On very small screens, stack the 2-col card grid to 1 col */
    .stacked-piece-list {
        grid-template-columns: 1fr;
    }

    .home-hero-actions {
        flex-direction: column;
    }

    .home-hero-actions .pill-link {
        width: 100%;
    }

    .gallery-note-list li {
        font-size: 0.62rem;
        padding: 0.18rem 0.44rem;
    }

    /* Engineering page extra small screens - tighter but readable */
    .engineering-hero {
        padding: 1rem;
        gap: 1rem;
    }

    .engineering-hero__main h1 {
        font-size: 1.3rem;
        line-height: 1.12;
    }

    .eyebrow {
        font-size: 0.62rem;
    }

    .engineering-lead {
        font-size: 0.92rem;
        line-height: 1.7;
    }

    .engineering-hero__actions {
        gap: 0.5rem;
    }

    .engineering-hero__actions .pill-link {
        min-height: 2.7rem;
        font-size: 0.8rem;
    }

    .engineering-trust-panel {
        padding-top: 0.9rem;
    }

    .engineering-trust-list li {
        padding: 0.65rem;
        font-size: 0.87rem;
        line-height: 1.62;
    }

    /* Workflow - tighter but readable */
    .engineering-workflow-intro {
        margin-bottom: 1rem;
        padding: 0.8rem;
    }

    .engineering-workflow-intro h3 {
        font-size: 1.2rem;
        margin-bottom: 0.3rem;
    }

    .engineering-workflow li {
        grid-template-columns: 2rem minmax(0, 1fr);
        gap: 0.75rem;
    }

    .engineering-workflow__step {
        width: 2rem;
        height: 2rem;
        font-size: 0.6rem;
        border-width: 1.5px;
    }

    .engineering-workflow__body {
        padding: 0.75rem;
    }

    .engineering-workflow h3 {
        font-size: 0.95rem;
        line-height: 1.12;
    }

    .engineering-workflow p {
        font-size: 0.84rem;
        line-height: 1.6;
    }

    .engineering-workflow span {
        font-size: 0.58rem;
        padding: 0.15rem 0.32rem;
    }

    /* Principles - compact spacing */
    .engineering-principles {
        gap: 0.75rem;
    }

    .engineering-principles article {
        padding: 0.8rem;
    }

    .engineering-principles h3 {
        font-size: 0.98rem;
        line-height: 1.15;
        margin-bottom: 0.35rem;
    }

    .engineering-principles p {
        font-size: 0.85rem;
        line-height: 1.62;
    }

    /* Lifecycle - more compact */
    .engineering-lifecycle__row {
        gap: 0.5rem;
    }

    .engineering-lifecycle__stage {
        padding: 0.75rem;
    }

    .engineering-lifecycle__stage h3 {
        font-size: 1rem;
    }

    .engineering-lifecycle__detail {
        padding: 0.75rem;
    }

    .engineering-lifecycle__detail p {
        font-size: 0.85rem;
        line-height: 1.62;
    }

    .engineering-lifecycle__detail li {
        font-size: 0.73rem;
    }

    /* Domain suite - readable compact */
    .engineering-domain-anchor {
        padding: 0.85rem;
    }

    .engineering-domain-anchor h3 {
        font-size: 1.25rem;
        margin-bottom: 0.3rem;
    }

    .engineering-domain-anchor p {
        font-size: 0.87rem;
        line-height: 1.65;
    }

    .engineering-domain-grid {
        gap: 0.7rem;
    }

    .engineering-domain-card {
        padding: 0.75rem;
    }

    .engineering-domain-card h4 {
        font-size: 1.15rem;
        line-height: 1.08;
        margin-bottom: 0.15rem;
    }

    .engineering-domain-card__summary {
        font-size: 0.85rem;
        line-height: 1.58;
    }

    .engineering-domain-card li {
        font-size: 0.72rem;
    }

    /* Case studies - optimized */
    .engineering-case-study {
        gap: 0.7rem;
    }

    .engineering-case-study__lead {
        padding: 0.9rem;
        gap: 0.5rem;
    }

    .engineering-case-study__lead h3 {
        font-size: 1.15rem;
        line-height: 1.12;
    }

    .engineering-case-study__lead p {
        font-size: 0.87rem;
        line-height: 1.62;
    }

    .engineering-case-study__rail a {
        padding: 0.7rem;
        gap: 0.2rem;
    }

    .engineering-case-study__rail span {
        font-size: 0.6rem;
    }

    .engineering-case-study__rail strong {
        font-size: 0.9rem;
        line-height: 1.15;
    }

    .engineering-page .section-heading {
        margin-bottom: 0.95rem;
        margin-top: 1.4rem;
    }

    .engineering-page .section-heading .spec {
        font-size: 1.4rem;
    }

    .engineering-page .mb-5 {
        margin-bottom: 1.6rem !important;
    }
}