/* Hub home page: paper aesthetic, hero + block flow + outputs grid. */

.home-page { padding-bottom: var(--sp-9); }

/* ----- HERO (copy left, livestock figure right) ----- */

.home-hero {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.8fr);
    gap: var(--sp-7);
    align-items: center;
    padding: var(--sp-6) 0 var(--sp-7);
    margin-bottom: var(--sp-7);
}

@media (max-width: 960px) {
    .home-hero { grid-template-columns: 1fr; gap: var(--sp-5); }
}

.home-hero__copy { max-width: 640px; }

.home-hero .eyebrow {
    margin-bottom: var(--sp-3);
}

.home-hero-title {
    font-family: var(--font-display);
    font-size: clamp(2.25rem, 5vw, 3.75rem);
    font-weight: 400;
    line-height: 1.05;
    letter-spacing: -0.02em;
    margin: 0 0 var(--sp-5);
    color: var(--ink-umber);
}

.home-hero-lede {
    font-size: var(--text-xl);
    color: var(--ink-walnut);
    line-height: var(--leading-body);
    max-width: 56ch;
    margin-bottom: var(--sp-6);
}

.home-hero-ctas {
    display: flex;
    gap: var(--sp-3);
    flex-wrap: wrap;
}

.home-hero__figure {
    margin: 0;
    display: flex;
    justify-content: center;
    align-items: center;
}

.home-hero__figure img {
    width: 100%;
    max-width: 380px;
    height: auto;
    filter: drop-shadow(0 18px 32px rgba(58, 46, 34, 0.14));
}

@media (max-width: 960px) {
    .home-hero__figure img { max-width: 260px; }
}

.home-hero-art {
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}


/* ----- STATS STRIP ----- */

.home-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--sp-4);
    padding: var(--sp-5) var(--sp-6);
    background: var(--paper-kraft);
    border: 1px solid var(--paper-shadow);
    border-radius: var(--radius-lg);
    box-shadow: var(--elev-1), var(--elev-inset);
    margin: 0 0 var(--sp-8);
}

@media (max-width: 720px) {
    .home-stats { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 480px) {
    .home-stats {
        grid-template-columns: 1fr;
        padding: var(--sp-4);
    }

    .stat {
        border-right: 0;
        border-bottom: 1px dashed var(--paper-shadow);
        padding: 0 0 var(--sp-3);
    }

    .stat:last-child {
        border-bottom: 0;
        padding-bottom: 0;
    }
}

.stat {
    border-right: 1px dashed var(--paper-shadow);
    padding: 0 var(--sp-3);
}

.stat:last-child { border-right: 0; }

.stat-value {
    font-family: var(--font-display);
    font-size: var(--text-2xl);
    font-weight: 500;
    color: var(--ink-umber);
    margin: 0;
}

.stat-label {
    font-size: var(--text-sm);
    color: var(--ink-walnut);
    margin: 0;
}

/* ----- Workstream card plate (inline figure at top-right of each card) ----- */

.workstream-card {
    position: relative;
    overflow: hidden;
}

.workstream-plate {
    position: absolute;
    top: var(--sp-3);
    right: var(--sp-3);
    width: 72px;
    height: auto;
    opacity: 0.75;
    pointer-events: none;
}

@media (max-width: 720px) {
    .workstream-plate { width: 56px; }
}

/* ----- SOCIAL IMPACT ----- */

.social-impact {
    display: grid;
    grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.2fr);
    gap: var(--sp-7);
    align-items: center;
    padding: var(--sp-5) 0 var(--sp-7);
}

@media (max-width: 860px) {
    .social-impact { grid-template-columns: 1fr; gap: var(--sp-5); }
}

.social-impact__copy p {
    color: var(--ink-walnut);
    line-height: var(--leading-body);
    margin-bottom: var(--sp-4);
    max-width: 58ch;
}

.social-impact__figure {
    margin: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--sp-3);
}

.social-impact__figure img {
    width: 100%;
    max-width: 240px;
    height: auto;
    opacity: 0.5;
    filter: drop-shadow(0 14px 28px rgba(58, 46, 34, 0.08));
}

@media (max-width: 640px) {
    .social-impact__figure img {
        max-width: 150px;
    }
}

.social-impact__figure figcaption {
    font-size: var(--text-sm);
    color: var(--ink-walnut);
    text-align: center;
    max-width: 30ch;
}

.social-impact__figure figcaption strong {
    display: block;
    font-family: var(--font-mono);
    font-weight: 500;
    font-size: var(--text-xs);
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--ink-umber);
    margin-bottom: var(--sp-1);
}

/* ----- SECTIONS ----- */

.home-section {
    margin-bottom: var(--sp-8);
    max-width: 1040px;
    scroll-margin-top: var(--sp-6);
}

.section-eyebrow {
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--accent-rust);
    margin-bottom: var(--sp-2);
}

.section-title {
    font-size: var(--text-3xl);
    line-height: 1.15;
    margin-bottom: var(--sp-5);
    max-width: 24ch;
}

.home-section-lede {
    font-size: var(--text-lg);
    color: var(--ink-walnut);
    max-width: 62ch;
    margin-bottom: var(--sp-5);
    line-height: var(--leading-body);
}

.home-two-col {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(0, 1fr);
    gap: var(--sp-6);
    align-items: start;
}

@media (max-width: 860px) {
    .home-two-col { grid-template-columns: 1fr; }
}

.home-callout h3 { margin-bottom: var(--sp-2); }

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

.home-callout-list li {
    padding: var(--sp-2) 0;
    border-bottom: 1px dotted var(--paper-shadow);
    color: var(--ink-umber);
    font-size: var(--text-sm);
    line-height: var(--leading-body);
}

.home-callout-list li:last-child { border: 0; }

.home-callout-list li::before {
    content: "→ ";
    color: var(--accent-rust);
    font-weight: 600;
    margin-right: 4px;
}

/* ----- LIVING SCIENTIFIC WORKSTREAMS ----- */

.workstreams-system {
    position: relative;
    max-width: min(1180px, 100%);
    padding: clamp(2.5rem, 5vw, 4.5rem) 0;
    isolation: isolate;
}

.workstreams-system > .section-eyebrow {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: var(--sp-2);
    margin-bottom: clamp(2rem, 5vw, 3.5rem);
    color: var(--accent-rust-deep);
}

.block-flow {
    display: flex;
    flex-direction: column;
    gap: clamp(4rem, 8vw, 6.5rem);
}

.flow-row {
    --row-accent: var(--accent-rust);
    --row-accent-deep: var(--accent-rust-deep);
    position: relative;
    padding-left: clamp(0rem, 2vw, 1.25rem);
}

.flow-row--moss {
    --row-accent: var(--accent-moss);
    --row-accent-deep: var(--accent-moss-deep);
}

.flow-row::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.35rem;
    bottom: -1.5rem;
    width: 1px;
    background: linear-gradient(to bottom, transparent, color-mix(in srgb, var(--row-accent) 62%, transparent), transparent);
}

.flow-row__header {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: start;
    gap: clamp(1rem, 3vw, 1.75rem);
    margin-bottom: clamp(1.25rem, 3vw, 2.25rem);
    opacity: 0;
    transform: translateY(16px);
    transition: opacity 700ms var(--ease-standard), transform 700ms var(--ease-standard);
}

.flow-row.is-visible .flow-row__header {
    opacity: 1;
    transform: translateY(0);
}

.flow-row__num {
    display: inline-grid;
    place-items: center;
    width: 3.3rem;
    height: 3.3rem;
    border: 1px solid color-mix(in srgb, var(--row-accent) 42%, var(--paper-shadow));
    border-radius: 50%;
    background:
        radial-gradient(circle at 34% 28%, rgba(255, 249, 238, 0.86), transparent 54%),
        color-mix(in srgb, var(--row-accent) 10%, var(--paper-cream));
    box-shadow:
        inset 0 1px 0 rgba(255, 249, 238, 0.8),
        0 12px 30px color-mix(in srgb, var(--row-accent) 18%, transparent);
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    letter-spacing: 0.16em;
    color: var(--row-accent-deep);
}

.flow-row__intro {
    max-width: 760px;
}

.flow-row__status,
.flow-stage__meta {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    border: 1px solid rgba(107, 85, 60, 0.22);
    border-radius: var(--radius-pill);
    background: rgba(245, 239, 225, 0.62);
    box-shadow: inset 0 1px 0 rgba(255, 249, 238, 0.72);
    font-family: var(--font-mono);
    font-size: 0.66rem;
    font-weight: 500;
    letter-spacing: 0.13em;
    line-height: 1;
    text-transform: uppercase;
    color: var(--ink-walnut);
}

.flow-row__status {
    gap: var(--sp-2);
    padding: 0.48rem 0.68rem;
    margin-bottom: var(--sp-3);
}

.flow-row__status::before {
    content: "";
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--row-accent);
    box-shadow: 0 0 0 5px color-mix(in srgb, var(--row-accent) 15%, transparent);
}

.flow-row__title {
    font-family: var(--font-display);
    font-size: clamp(1.85rem, 3vw, 2.6rem);
    font-weight: 500;
    line-height: 1.08;
    color: var(--ink-umber);
    margin: 0;
}

.flow-row__lede {
    color: var(--ink-walnut);
    font-size: clamp(1rem, 1.4vw, 1.16rem);
    line-height: var(--leading-body);
    max-width: 66ch;
    margin: var(--sp-4) 0 0;
}

.flow-row__connector {
    position: absolute;
    left: clamp(1rem, 4vw, 2.5rem);
    right: clamp(1rem, 4vw, 2.5rem);
    top: clamp(11rem, 17vw, 14rem);
    width: calc(100% - clamp(2rem, 8vw, 5rem));
    height: 120px;
    z-index: 0;
    overflow: visible;
    pointer-events: none;
}

.flow-row__connector path {
    fill: none;
    vector-effect: non-scaling-stroke;
}

.flow-row__connector-track {
    stroke: rgba(107, 85, 60, 0.20);
    stroke-width: 1.4;
    stroke-dasharray: 7 12;
}

.flow-row__connector-draw {
    stroke: color-mix(in srgb, var(--row-accent) 72%, var(--accent-ink));
    stroke-width: 2.2;
    stroke-linecap: round;
    filter: drop-shadow(0 0 8px color-mix(in srgb, var(--row-accent) 24%, transparent));
    opacity: 0.72;
    stroke-dasharray: var(--path-length, 1);
    stroke-dashoffset: var(--path-length, 1);
    transition: stroke-dashoffset 1200ms cubic-bezier(0.16, 1, 0.3, 1), opacity 300ms var(--ease-standard);
}

.flow-row.is-visible .flow-row__connector-draw {
    stroke-dashoffset: 0;
}

.flow-row:has(.flow-stage:hover) .flow-row__connector-draw {
    opacity: 1;
    animation: connectorPulse 1400ms ease-in-out infinite;
}

.flow-stages {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: clamp(1rem, 2vw, 1.35rem);
    position: relative;
    z-index: 1;
}

.flow-stage.card-paper {
    --card-accent: var(--accent-rust);
    --mx: 50%;
    --my: 20%;
    min-height: clamp(250px, 24vw, 310px);
    padding: clamp(1.05rem, 2vw, 1.35rem);
    display: flex;
    flex-direction: column;
    gap: var(--sp-3);
    position: relative;
    list-style: none;
    overflow: hidden;
    border-color: rgba(107, 85, 60, 0.22);
    border-radius: 24px;
    background:
        radial-gradient(circle at var(--mx) var(--my), color-mix(in srgb, var(--card-accent) 16%, transparent), transparent 42%),
        linear-gradient(145deg, rgba(255, 249, 238, 0.72), rgba(232, 220, 196, 0.58)),
        var(--paper-kraft);
    box-shadow:
        0 1px 1px rgba(58, 46, 34, 0.08),
        0 16px 36px rgba(58, 46, 34, 0.10),
        inset 0 1px 0 rgba(255, 249, 238, 0.88),
        inset 0 -1px 0 rgba(107, 85, 60, 0.08);
    opacity: 0;
    transform: translateY(22px);
    transition:
        opacity 680ms var(--ease-standard),
        transform 680ms var(--ease-standard),
        border-color var(--dur-med) var(--ease-standard),
        box-shadow var(--dur-med) var(--ease-standard),
        background-position var(--dur-med) var(--ease-standard);
    transition-delay: calc(var(--stage-index, 0) * 90ms);
}

.flow-stage[data-accent="moss"] { --card-accent: var(--accent-moss); }
.flow-stage[data-accent="ochre"] { --card-accent: var(--accent-ochre); }
.flow-stage[data-accent="ink"] { --card-accent: var(--accent-ink); }

.flow-row.is-visible .flow-stage {
    opacity: 1;
    transform: translateY(0);
}

.flow-stage.card-paper::before,
.flow-stage.card-paper::after {
    content: "";
    position: absolute;
    pointer-events: none;
}

.flow-stage.card-paper::before {
    inset: 1px;
    border-radius: inherit;
    background:
        linear-gradient(120deg, rgba(255, 249, 238, 0.72), transparent 38%),
        radial-gradient(circle at 18% 16%, rgba(255, 255, 255, 0.42), transparent 30%);
    opacity: 0.72;
}

.flow-stage.card-paper::after {
    inset: 0;
    background-image: radial-gradient(rgba(58, 46, 34, 0.12) 0.6px, transparent 0.8px);
    background-size: 10px 10px;
    opacity: 0.08;
    mix-blend-mode: multiply;
}

.flow-stage.card-paper:hover {
    transform: translateY(-6px);
    border-color: color-mix(in srgb, var(--card-accent) 58%, var(--paper-shadow));
    box-shadow:
        0 2px 4px rgba(58, 46, 34, 0.08),
        0 24px 56px rgba(58, 46, 34, 0.14),
        0 0 0 1px color-mix(in srgb, var(--card-accent) 14%, transparent),
        0 0 36px color-mix(in srgb, var(--card-accent) 13%, transparent),
        inset 0 1px 0 rgba(255, 249, 238, 0.95);
}

.flow-stage.card-paper:focus-within {
    outline: 2px solid color-mix(in srgb, var(--card-accent) 72%, var(--ink-umber));
    outline-offset: 4px;
}

.flow-stage__meta,
.flow-stage__icon,
.flow-stage__title,
.flow-stage__list {
    position: relative;
    z-index: 1;
}

.flow-stage__meta {
    padding: 0.42rem 0.56rem;
    margin-bottom: var(--sp-2);
    color: color-mix(in srgb, var(--card-accent) 62%, var(--ink-walnut));
}

.flow-stage__icon.output-icon {
    width: 58px;
    height: 58px;
    border-radius: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: var(--sp-2);
    background:
        radial-gradient(circle at 34% 28%, rgba(255, 249, 238, 0.82), transparent 48%),
        color-mix(in srgb, var(--card-accent) 16%, var(--paper-cream));
    border: 1px solid color-mix(in srgb, var(--card-accent) 26%, var(--paper-shadow));
    box-shadow:
        inset 0 1px 0 rgba(255, 249, 238, 0.78),
        0 12px 26px color-mix(in srgb, var(--card-accent) 14%, transparent);
    transition: transform var(--dur-med) var(--ease-standard), box-shadow var(--dur-med) var(--ease-standard);
}

.flow-stage__icon.output-icon svg {
    width: 32px;
    height: 32px;
    overflow: visible;
}

.flow-stage:hover .flow-stage__icon.output-icon {
    transform: translate3d(0, -2px, 0) rotate(-1deg);
    box-shadow:
        inset 0 1px 0 rgba(255, 249, 238, 0.9),
        0 16px 34px color-mix(in srgb, var(--card-accent) 20%, transparent);
}

.flow-stage__icon svg path,
.flow-stage__icon svg line,
.flow-stage__icon svg ellipse,
.flow-stage__icon svg circle {
    transition: transform var(--dur-slow) var(--ease-standard), opacity var(--dur-med) var(--ease-standard), stroke var(--dur-med) var(--ease-standard);
    transform-box: fill-box;
    transform-origin: center;
}

.flow-stage:hover .flow-stage__icon svg circle,
.flow-stage:hover .flow-stage__icon svg ellipse {
    animation: iconPulse 1400ms ease-in-out infinite;
}

.flow-stage:hover .flow-stage__icon svg line,
.flow-stage:hover .flow-stage__icon svg path {
    stroke: color-mix(in srgb, var(--card-accent) 70%, var(--ink-umber));
}

.flow-stage__title {
    font-family: var(--font-display);
    font-size: clamp(1.35rem, 1.8vw, 1.72rem);
    font-weight: 500;
    line-height: 1.08;
    color: var(--ink-umber);
    margin: 0;
    transition: color var(--dur-med) var(--ease-standard);
}

.flow-stage:hover .flow-stage__title {
    color: color-mix(in srgb, var(--card-accent) 58%, var(--ink-umber));
}

.flow-stage__list {
    list-style: none;
    padding: var(--sp-4) 0 0;
    margin: auto 0 0;
    display: grid;
    gap: var(--sp-2);
    border-top: 1px solid rgba(107, 85, 60, 0.16);
}

.flow-stage__list li {
    font-size: var(--text-sm);
    line-height: 1.52;
    color: var(--ink-walnut);
    padding-left: var(--sp-4);
    position: relative;
}

.flow-stage__list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.72em;
    width: 7px;
    height: 7px;
    border: 1px solid color-mix(in srgb, var(--card-accent) 58%, var(--ink-mist));
    border-radius: 50%;
    background: rgba(245, 239, 225, 0.74);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--card-accent) 10%, transparent);
}

.flow-stage--outputs .flow-stage__title { color: var(--accent-ink); }

@keyframes connectorPulse {
    0%, 100% { filter: drop-shadow(0 0 8px color-mix(in srgb, var(--row-accent) 24%, transparent)); }
    50% { filter: drop-shadow(0 0 16px color-mix(in srgb, var(--row-accent) 34%, transparent)); }
}

@keyframes iconPulse {
    0%, 100% { transform: scale(1); opacity: 1; }
    50% { transform: scale(1.08); opacity: 0.82; }
}

@media (max-width: 960px) {
    .flow-row__connector {
        display: none;
    }

    .flow-stages {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: var(--sp-5);
    }
}

@media (max-width: 640px) {
    .home-page {
        padding-bottom: var(--sp-7);
    }

    .home-hero {
        padding-top: var(--sp-4);
        margin-bottom: var(--sp-6);
    }

    .home-hero-title {
        font-size: clamp(2rem, 12vw, 3rem);
    }

    .home-hero-lede,
    .home-section-lede {
        font-size: var(--text-base);
    }

    .home-hero-ctas .btn-paper {
        width: 100%;
        justify-content: center;
    }

    .section-title {
        max-width: none;
    }

    .workstreams-system {
        border-radius: 24px;
        padding: var(--sp-6) 0;
    }

    .flow-row {
        padding-left: var(--sp-3);
    }

    .flow-row::before {
        left: 0;
        top: 4.5rem;
        bottom: 0;
    }

    .flow-row__header {
        grid-template-columns: 1fr;
        gap: var(--sp-4);
    }

    .flow-row__num {
        width: 2.8rem;
        height: 2.8rem;
    }

    .flow-row__title {
        font-size: clamp(1.55rem, 9vw, 2.15rem);
    }

    .flow-stages {
        grid-template-columns: 1fr;
        gap: var(--sp-4);
    }

    .flow-stage.card-paper {
        min-height: auto;
        border-radius: 18px;
    }
}

@media (prefers-reduced-motion: reduce) {
    .flow-row__header,
    .flow-stage.card-paper,
    .flow-row__connector-draw {
        transition: none;
    }

    .flow-row__connector-draw {
        stroke-dashoffset: 0;
    }

    .flow-row:has(.flow-stage:hover) .flow-row__connector-draw,
    .flow-stage:hover .flow-stage__icon svg circle,
    .flow-stage:hover .flow-stage__icon svg ellipse {
        animation: none;
    }
}

/* ----- OUTPUTS GRID ----- */

.outputs-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: var(--sp-5);
}

.output-card {
    display: flex;
    flex-direction: column;
    gap: var(--sp-3);
    text-decoration: none;
    color: var(--ink-umber);
    position: relative;
    min-height: 320px;
    padding: var(--sp-5);
    transition: transform var(--dur-med) var(--ease-standard), box-shadow var(--dur-med) var(--ease-standard), border-color var(--dur-fast);
}

.output-card:hover {
    color: var(--ink-umber);
    border-color: var(--accent-rust);
}

.output-card h3 {
    font-size: var(--text-xl);
    margin: 0;
}

.output-icon {
    width: 56px;
    height: 56px;
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: var(--sp-2);
    box-shadow: var(--elev-1);
}

.output-icon svg { width: 32px; height: 32px; }

.output-icon--rust { background: rgba(181, 83, 60, 0.15); }
.output-icon--moss { background: rgba(107, 142, 78, 0.15); }
.output-icon--ink  { background: rgba(31, 58, 95, 0.12); }
.output-icon--ochre { background: rgba(212, 164, 55, 0.2); }

.output-blurb {
    color: var(--ink-walnut);
    font-size: var(--text-sm);
    margin: 0;
    flex-grow: 1;
}

.output-status {
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--ink-walnut);
    margin: 0;
}

.output-status--live {
    color: var(--accent-moss-deep);
}

.output-status--live::before {
    content: "● ";
    color: var(--accent-moss);
}

.output-status--prototype {
    color: var(--accent-rust);
}

.output-status--prototype::before {
    content: "◆ ";
    color: var(--accent-rust);
}

.output-links {
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    color: var(--ink-walnut);
    margin: 0;
    display: flex;
    gap: var(--sp-2);
    flex-wrap: wrap;
}

.output-cta {
    margin-top: auto;
    padding-top: var(--sp-3);
    font-weight: 500;
    color: var(--accent-rust);
    font-size: var(--text-sm);
    display: inline-flex;
    align-items: center;
    gap: var(--sp-2);
    transition: gap var(--dur-fast) var(--ease-standard);
}

.output-card:hover .output-cta { gap: var(--sp-3); }

/* Status is conveyed by the Prototype/Available/In preparation pill,
 * not by persistent border colour. Cards match on hover only. */

/* ----- OUTPUTS SHOWCASE: premium research artefacts ----- */

.outputs-showcase {
    position: relative;
    max-width: min(1180px, 100%);
    padding-top: clamp(1rem, 3vw, 2rem);
    isolation: isolate;
}

.outputs-showcase::before,
.outputs-showcase::after {
    content: "";
    position: absolute;
    pointer-events: none;
    z-index: -1;
}

.outputs-showcase::before {
    inset: 5.5rem -2rem auto;
    height: 18rem;
    background:
        radial-gradient(circle at 18% 32%, rgba(181, 83, 60, 0.12), transparent 18rem),
        radial-gradient(circle at 78% 12%, rgba(31, 58, 95, 0.10), transparent 20rem),
        linear-gradient(rgba(107, 85, 60, 0.08) 1px, transparent 1px),
        linear-gradient(90deg, rgba(107, 85, 60, 0.08) 1px, transparent 1px);
    background-size: auto, auto, 42px 42px, 42px 42px;
    mask-image: linear-gradient(to bottom, transparent, #000 25%, #000 72%, transparent);
    opacity: 0.72;
}

.outputs-showcase::after {
    right: 2rem;
    top: 9rem;
    width: 18rem;
    height: 18rem;
    border-radius: 50%;
    border: 1px solid rgba(107, 85, 60, 0.10);
    box-shadow:
        0 0 0 32px rgba(107, 85, 60, 0.035),
        0 0 0 74px rgba(107, 85, 60, 0.025);
    opacity: 0.5;
}

.outputs-showcase .section-title {
    margin-bottom: clamp(1.75rem, 4vw, 3rem);
}

.outputs-showcase .outputs-grid {
    grid-template-columns: minmax(0, 1.22fr) minmax(280px, 0.78fr);
    grid-auto-flow: dense;
    gap: clamp(1rem, 2vw, 1.4rem);
    align-items: stretch;
}

.outputs-showcase .output-card {
    --output-accent: var(--accent-rust);
    --mx: 50%;
    --my: 20%;
    min-height: 290px;
    padding: clamp(1.15rem, 2vw, 1.55rem);
    overflow: hidden;
    border-color: rgba(107, 85, 60, 0.22);
    border-radius: 26px;
    background:
        radial-gradient(circle at var(--mx) var(--my), color-mix(in srgb, var(--output-accent) 15%, transparent), transparent 42%),
        linear-gradient(150deg, rgba(255, 249, 238, 0.78), rgba(232, 220, 196, 0.62)),
        var(--paper-kraft);
    box-shadow:
        0 1px 1px rgba(58, 46, 34, 0.08),
        0 18px 44px rgba(58, 46, 34, 0.10),
        inset 0 1px 0 rgba(255, 249, 238, 0.9),
        inset 0 -1px 0 rgba(107, 85, 60, 0.08);
    opacity: 0;
    transform: translateY(24px);
    transition:
        opacity 720ms var(--ease-standard),
        transform 720ms var(--ease-standard),
        border-color var(--dur-med) var(--ease-standard),
        box-shadow var(--dur-med) var(--ease-standard),
        color var(--dur-med) var(--ease-standard);
    transition-delay: calc(var(--output-index, 0) * 90ms);
}

.outputs-showcase .output-card[data-output-accent="moss"] { --output-accent: var(--accent-moss); }
.outputs-showcase .output-card[data-output-accent="ink"] { --output-accent: var(--accent-ink); }
.outputs-showcase .output-card[data-output-accent="ochre"] { --output-accent: var(--accent-ochre); }

.outputs-showcase.is-visible .output-card {
    opacity: 1;
    transform: translateY(0);
}

.outputs-showcase .output-card::before,
.outputs-showcase .output-card::after {
    content: "";
    position: absolute;
    pointer-events: none;
}

.outputs-showcase .output-card::before {
    inset: 1px;
    border-radius: inherit;
    background:
        linear-gradient(118deg, rgba(255, 249, 238, 0.78), transparent 34%),
        radial-gradient(circle at 18% 14%, rgba(255, 255, 255, 0.42), transparent 30%);
    opacity: 0.72;
}

.outputs-showcase .output-card::after {
    inset: 0;
    background-image: radial-gradient(rgba(58, 46, 34, 0.13) 0.6px, transparent 0.8px);
    background-size: 10px 10px;
    opacity: 0.08;
    mix-blend-mode: multiply;
}

.outputs-showcase .output-card:hover,
.outputs-showcase .output-card:focus-visible {
    color: var(--ink-umber);
    transform: translateY(-6px);
    border-color: color-mix(in srgb, var(--output-accent) 58%, var(--paper-shadow));
    box-shadow:
        0 2px 4px rgba(58, 46, 34, 0.08),
        0 26px 66px rgba(58, 46, 34, 0.15),
        0 0 0 1px color-mix(in srgb, var(--output-accent) 14%, transparent),
        0 0 42px color-mix(in srgb, var(--output-accent) 13%, transparent),
        inset 0 1px 0 rgba(255, 249, 238, 0.95);
}

.outputs-showcase .output-card:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--output-accent) 72%, var(--ink-umber));
    outline-offset: 4px;
}

.outputs-showcase .output-card__body,
.outputs-showcase .output-card__topline,
.outputs-showcase .output-icon,
.outputs-showcase .output-card h3,
.outputs-showcase .output-blurb,
.outputs-showcase .output-links,
.outputs-showcase .output-cta,
.outputs-showcase .output-preview {
    position: relative;
    z-index: 1;
}

.outputs-showcase .output-card__body {
    display: flex;
    flex-direction: column;
    gap: var(--sp-3);
    min-width: 0;
}

.outputs-showcase .output-card__topline {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--sp-3);
}

.outputs-showcase .output-status,
.outputs-showcase .output-meta {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    border-radius: var(--radius-pill);
    font-family: var(--font-mono);
    font-size: 0.66rem;
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0.13em;
    text-transform: uppercase;
    white-space: nowrap;
}

.outputs-showcase .output-status {
    gap: var(--sp-2);
    padding: 0.48rem 0.66rem;
    border: 1px solid color-mix(in srgb, var(--output-accent) 28%, var(--paper-shadow));
    background: rgba(245, 239, 225, 0.68);
    color: color-mix(in srgb, var(--output-accent) 62%, var(--ink-walnut));
    margin: 0;
    box-shadow: inset 0 1px 0 rgba(255, 249, 238, 0.82);
}

.outputs-showcase .output-status::before {
    content: "";
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--output-accent);
    box-shadow: 0 0 0 5px color-mix(in srgb, var(--output-accent) 14%, transparent);
}

.outputs-showcase .output-status--live::before,
.outputs-showcase .output-status--prototype::before {
    animation: outputStatusPulse 1800ms ease-in-out infinite;
}

.outputs-showcase .output-meta {
    color: var(--ink-mist);
    opacity: 0.9;
}

.outputs-showcase .output-card:hover .output-meta {
    color: color-mix(in srgb, var(--output-accent) 60%, var(--ink-walnut));
}

.outputs-showcase .output-icon {
    width: 58px;
    height: 58px;
    border-radius: 18px;
    margin-bottom: var(--sp-1);
    background:
        radial-gradient(circle at 34% 28%, rgba(255, 249, 238, 0.82), transparent 48%),
        color-mix(in srgb, var(--output-accent) 16%, var(--paper-cream));
    border: 1px solid color-mix(in srgb, var(--output-accent) 26%, var(--paper-shadow));
    box-shadow:
        inset 0 1px 0 rgba(255, 249, 238, 0.78),
        0 12px 26px color-mix(in srgb, var(--output-accent) 14%, transparent);
    transition: transform var(--dur-med) var(--ease-standard), box-shadow var(--dur-med) var(--ease-standard);
}

.outputs-showcase .output-icon svg {
    width: 34px;
    height: 34px;
    overflow: visible;
}

.outputs-showcase .output-card:hover .output-icon {
    transform: translate3d(0, -2px, 0) rotate(-1deg);
}

.outputs-showcase .output-card:hover .output-icon svg path,
.outputs-showcase .output-card:hover .output-icon svg line,
.outputs-showcase .output-card:hover .output-icon svg ellipse {
    stroke: color-mix(in srgb, var(--output-accent) 70%, var(--ink-umber));
}

.outputs-showcase .output-card:hover .output-icon svg circle,
.outputs-showcase .output-card:hover .output-icon svg ellipse,
.outputs-showcase .output-card:hover .output-icon svg rect {
    animation: outputIconPulse 1500ms ease-in-out infinite;
    transform-box: fill-box;
    transform-origin: center;
}

.outputs-showcase .output-card h3 {
    font-family: var(--font-display);
    font-size: clamp(1.45rem, 2vw, 1.9rem);
    font-weight: 500;
    line-height: 1.08;
    color: var(--ink-umber);
    transition: color var(--dur-med) var(--ease-standard);
}

.outputs-showcase .output-card:hover h3 {
    color: color-mix(in srgb, var(--output-accent) 58%, var(--ink-umber));
}

.outputs-showcase .output-blurb {
    line-height: 1.58;
}

.outputs-showcase .output-links {
    font-size: 0.72rem;
    margin: var(--sp-1) 0 0;
}

.outputs-showcase .output-links span:not(:nth-child(2)) {
    padding: 0.34rem 0.5rem;
    border: 1px solid rgba(107, 85, 60, 0.16);
    border-radius: var(--radius-pill);
    background: rgba(245, 239, 225, 0.46);
}

.outputs-showcase .output-cta {
    font-weight: 600;
    color: color-mix(in srgb, var(--output-accent) 70%, var(--accent-rust-deep));
    transition: gap var(--dur-med) var(--ease-standard), color var(--dur-med) var(--ease-standard);
}

.outputs-showcase .output-card:hover .output-cta,
.outputs-showcase .output-card:focus-visible .output-cta {
    gap: var(--sp-3);
    color: color-mix(in srgb, var(--output-accent) 82%, var(--ink-umber));
}

.outputs-showcase .output-card--featured {
    grid-row: span 3;
    min-height: 520px;
    display: grid;
    grid-template-rows: auto minmax(210px, 1fr);
    gap: clamp(1.25rem, 3vw, 2rem);
    padding: clamp(1.35rem, 3vw, 2rem);
}

.outputs-showcase .output-card--featured h3 {
    font-size: clamp(2rem, 4vw, 3.1rem);
    max-width: 12ch;
}

.outputs-showcase .output-card--featured .output-blurb {
    max-width: 48ch;
    font-size: clamp(1rem, 1.2vw, 1.08rem);
}

.outputs-showcase .output-card--featured .output-icon {
    width: 68px;
    height: 68px;
    border-radius: 22px;
}

.outputs-showcase .output-card--featured .output-icon svg {
    width: 40px;
    height: 40px;
}

.output-preview {
    align-self: end;
    min-height: 210px;
    border: 1px solid rgba(107, 85, 60, 0.18);
    border-radius: 22px;
    overflow: hidden;
    background:
        radial-gradient(circle at 70% 28%, color-mix(in srgb, var(--output-accent) 18%, transparent), transparent 16rem),
        linear-gradient(145deg, rgba(245, 239, 225, 0.66), rgba(232, 220, 196, 0.44));
    box-shadow:
        inset 0 1px 0 rgba(255, 249, 238, 0.76),
        0 14px 34px rgba(58, 46, 34, 0.08);
}

.output-preview svg {
    width: 100%;
    height: 100%;
    min-height: 210px;
    display: block;
}

.output-preview__grid {
    stroke: rgba(107, 85, 60, 0.16);
    stroke-width: 1;
}

.output-preview__map {
    fill: rgba(181, 83, 60, 0.10);
    stroke: rgba(31, 58, 95, 0.38);
    stroke-width: 1.4;
}

.output-preview__curve {
    stroke: var(--accent-rust);
    stroke-width: 3;
    stroke-linecap: round;
    filter: drop-shadow(0 0 10px rgba(181, 83, 60, 0.26));
    stroke-dasharray: 420;
    stroke-dashoffset: 420;
}

.outputs-showcase.is-visible .output-preview__curve {
    animation: outputCurveDraw 1500ms cubic-bezier(0.16, 1, 0.3, 1) 420ms forwards;
}

.output-preview__node {
    fill: var(--paper-cream);
    stroke: var(--accent-rust);
    stroke-width: 2;
    animation: outputNodePulse 2200ms ease-in-out infinite;
}

.output-preview__node:nth-of-type(2) { animation-delay: 220ms; }
.output-preview__node:nth-of-type(3) { animation-delay: 440ms; }
.output-preview__node:nth-of-type(4) { animation-delay: 660ms; }

@keyframes outputCurveDraw {
    to { stroke-dashoffset: 0; }
}

@keyframes outputNodePulse {
    0%, 100% { r: 7; opacity: 0.9; }
    50% { r: 9; opacity: 0.68; }
}

@keyframes outputIconPulse {
    0%, 100% { transform: scale(1); opacity: 1; }
    50% { transform: scale(1.06); opacity: 0.84; }
}

@keyframes outputStatusPulse {
    0%, 100% { box-shadow: 0 0 0 5px color-mix(in srgb, var(--output-accent) 14%, transparent); }
    50% { box-shadow: 0 0 0 8px color-mix(in srgb, var(--output-accent) 8%, transparent); }
}

@media (max-width: 960px) {
    .outputs-showcase .outputs-grid {
        grid-template-columns: 1fr 1fr;
    }

    .outputs-showcase .output-card--featured {
        grid-column: 1 / -1;
        grid-row: auto;
        min-height: 0;
    }
}

@media (max-width: 640px) {
    .outputs-showcase::before,
    .outputs-showcase::after {
        display: none;
    }

    .outputs-showcase .outputs-grid {
        grid-template-columns: 1fr;
    }

    .outputs-showcase .output-card {
        min-height: auto;
        border-radius: 22px;
    }

    .outputs-showcase .output-card__topline {
        align-items: flex-start;
        flex-direction: column;
        gap: var(--sp-2);
    }

    .outputs-showcase .output-card--featured h3 {
        max-width: none;
    }
}

@media (prefers-reduced-motion: reduce) {
    .outputs-showcase .output-card,
    .outputs-showcase .output-preview__curve {
        transition: none;
        animation: none;
    }

    .outputs-showcase .output-preview__curve {
        stroke-dashoffset: 0;
    }

    .outputs-showcase .output-status--live::before,
    .outputs-showcase .output-status--prototype::before,
    .outputs-showcase .output-preview__node,
    .outputs-showcase .output-card:hover .output-icon svg circle,
    .outputs-showcase .output-card:hover .output-icon svg ellipse,
    .outputs-showcase .output-card:hover .output-icon svg rect {
        animation: none;
    }
}

/* ----- Team + partners on home page ----- */

.team-showcase {
    position: relative;
    max-width: min(1180px, 100%);
    padding-top: clamp(1rem, 3vw, 2rem);
    isolation: isolate;
}

.team-showcase::before,
.team-showcase::after {
    content: "";
    position: absolute;
    pointer-events: none;
    z-index: -1;
    display: none;
}

.team-showcase::before {
    inset: 5rem -2rem auto;
    height: 28rem;
    background:
        radial-gradient(circle at 14% 20%, rgba(31, 58, 95, 0.11), transparent 19rem),
        radial-gradient(circle at 82% 28%, rgba(212, 164, 55, 0.12), transparent 21rem),
        linear-gradient(120deg, transparent 0 48%, rgba(107, 85, 60, 0.10) 49%, transparent 50%),
        linear-gradient(rgba(107, 85, 60, 0.07) 1px, transparent 1px);
    background-size: auto, auto, 90px 90px, 44px 44px;
    mask-image: linear-gradient(to bottom, transparent, #000 20%, #000 74%, transparent);
    opacity: 0.72;
}

.team-showcase::after {
    top: 11rem;
    right: 8%;
    width: 20rem;
    height: 20rem;
    border-radius: 50%;
    border: 1px solid rgba(107, 85, 60, 0.10);
    box-shadow:
        -8rem 5rem 0 -7.9rem rgba(181, 83, 60, 0.24),
        0 0 0 34px rgba(107, 85, 60, 0.025),
        0 0 0 82px rgba(107, 85, 60, 0.018);
    opacity: 0.58;
}

.team-showcase .section-title {
    margin-bottom: clamp(1.75rem, 4vw, 3rem);
}

.team-showcase .pi-grid {
    position: relative;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: auto;
    align-items: start;
    gap: clamp(1rem, 2vw, 1.4rem);
}

.team-showcase .pi-grid::before {
    display: none;
}

.team-showcase .pi-card {
    --team-accent: var(--accent-rust);
    --mx: 50%;
    --my: 20%;
    min-height: auto;
    padding: clamp(1.2rem, 2.2vw, 1.7rem);
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: start;
    gap: clamp(1rem, 2.2vw, 1.4rem);
    position: relative;
    overflow: hidden;
    border-color: rgba(107, 85, 60, 0.22);
    border-radius: 28px;
    background:
        linear-gradient(145deg, rgba(255, 249, 238, 0.78), rgba(232, 220, 196, 0.62)),
        var(--paper-kraft);
    box-shadow:
        0 1px 1px rgba(58, 46, 34, 0.08),
        0 18px 44px rgba(58, 46, 34, 0.10),
        inset 0 1px 0 rgba(255, 249, 238, 0.9),
        inset 0 -1px 0 rgba(107, 85, 60, 0.08);
    opacity: 0;
    transform: translateY(24px);
    transition:
        opacity 720ms var(--ease-standard),
        transform 720ms var(--ease-standard),
        border-color var(--dur-med) var(--ease-standard),
        box-shadow var(--dur-med) var(--ease-standard);
    transition-delay: calc(var(--team-index, 0) * 90ms);
}

.team-showcase .pi-card[data-team-accent="moss"] { --team-accent: var(--accent-moss); }
.team-showcase .pi-card[data-team-accent="ink"] { --team-accent: var(--accent-ink); }
.team-showcase .pi-card[data-team-accent="ochre"] { --team-accent: var(--accent-ochre); }

.team-showcase.is-visible .pi-card,
.team-showcase.is-visible .staff-card {
    opacity: 1;
    transform: translateY(0);
}

.team-showcase .pi-card::before,
.team-showcase .pi-card::after {
    content: "";
    position: absolute;
    pointer-events: none;
}

.team-showcase .pi-card::before {
    display: none;
}

.team-showcase .pi-card::after {
    inset: 1.1rem 1.1rem auto auto;
    width: 7rem;
    height: 7rem;
    border: 1px solid color-mix(in srgb, var(--team-accent) 18%, transparent);
    border-radius: 50%;
    box-shadow: 0 0 0 22px color-mix(in srgb, var(--team-accent) 5%, transparent);
    opacity: 0.72;
    z-index: 0;
}

.team-showcase .pi-card:hover {
    transform: translateY(-6px);
    border-color: color-mix(in srgb, var(--team-accent) 54%, var(--paper-shadow));
    box-shadow:
        0 2px 4px rgba(58, 46, 34, 0.08),
        0 26px 66px rgba(58, 46, 34, 0.15),
        0 0 0 1px color-mix(in srgb, var(--team-accent) 13%, transparent),
        0 0 40px color-mix(in srgb, var(--team-accent) 12%, transparent),
        inset 0 1px 0 rgba(255, 249, 238, 0.95);
}

.team-showcase .pi-card__mark,
.team-showcase .pi-card__content,
.team-showcase .staff-card__mark,
.team-showcase .staff-card h3,
.team-showcase .staff-role,
.team-showcase .staff-affil {
    position: relative;
    z-index: 1;
}

.team-showcase .pi-card__mark {
    width: clamp(4rem, 7vw, 5.4rem);
    height: clamp(4rem, 7vw, 5.4rem);
    display: grid;
    place-items: center;
    border-radius: 24px;
    border: 1px solid color-mix(in srgb, var(--team-accent) 28%, var(--paper-shadow));
    background:
        radial-gradient(circle at 35% 24%, rgba(255, 249, 238, 0.86), transparent 48%),
        color-mix(in srgb, var(--team-accent) 14%, var(--paper-cream));
    box-shadow:
        inset 0 1px 0 rgba(255, 249, 238, 0.85),
        0 16px 34px color-mix(in srgb, var(--team-accent) 14%, transparent);
    font-family: var(--font-display);
    font-size: clamp(1.45rem, 3vw, 2rem);
    font-weight: 500;
    color: color-mix(in srgb, var(--team-accent) 64%, var(--ink-umber));
    transition: transform var(--dur-med) var(--ease-standard);
}

.team-showcase .pi-card:hover .pi-card__mark {
}

.team-showcase .pi-card__photo {
    padding: 0;
    background: var(--paper-cream);
}

.team-showcase .pi-card__photo img {
    object-position: center;
}

.team-showcase .pi-card__content {
    min-width: 0;
}

.team-showcase .pi-card__eyebrow {
    margin: 0 0 var(--sp-3);
    font-family: var(--font-mono);
    font-size: 0.66rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: color-mix(in srgb, var(--team-accent) 62%, var(--ink-walnut));
}

.team-showcase .pi-card h3 {
    font-size: clamp(1.45rem, 2.25vw, 2.05rem);
    font-weight: 500;
    line-height: 1.04;
}

.team-showcase .pi-affil {
    color: var(--ink-walnut);
    line-height: 1.5;
    margin-top: var(--sp-3);
}

.team-showcase .pi-role {
    display: inline-flex;
    width: fit-content;
    margin: var(--sp-4) 0 0;
    padding: 0.42rem 0.56rem;
    border: 1px solid color-mix(in srgb, var(--team-accent) 26%, var(--paper-shadow));
    border-radius: var(--radius-pill);
    background: rgba(245, 239, 225, 0.62);
    box-shadow: inset 0 1px 0 rgba(255, 249, 238, 0.78);
    color: color-mix(in srgb, var(--team-accent) 62%, var(--ink-walnut));
}

.team-showcase .pi-card__tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--sp-2);
    margin: var(--sp-4) 0 0;
    padding: 0;
}

.team-showcase .pi-card__tags span {
    font-family: var(--font-mono);
    font-size: 0.68rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--ink-mist);
}

.team-showcase .home-subsection-title {
    margin-top: clamp(3rem, 6vw, 5rem);
}

.team-showcase .staff-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--sp-3);
}

.team-showcase .staff-card {
    --staff-accent: var(--accent-moss);
    position: relative;
    min-height: 150px;
    padding: var(--sp-4);
    border: 1px solid rgba(107, 85, 60, 0.16);
    border-left: 1px solid rgba(107, 85, 60, 0.16);
    border-radius: 18px;
    background:
        radial-gradient(circle at 24% 18%, rgba(255, 249, 238, 0.66), transparent 36%),
        rgba(232, 220, 196, 0.38);
    box-shadow:
        inset 0 1px 0 rgba(255, 249, 238, 0.72),
        0 10px 24px rgba(58, 46, 34, 0.06);
    opacity: 0;
    transform: translateY(18px);
    transition:
        opacity 620ms var(--ease-standard),
        transform 620ms var(--ease-standard),
        border-color var(--dur-med) var(--ease-standard),
        box-shadow var(--dur-med) var(--ease-standard);
}

.team-showcase:not(.is-visible) .staff-card {
    transition-delay: calc(var(--staff-index, 0) * 70ms + 220ms);
}

.team-showcase .staff-card:hover {
    transform: translateY(-4px);
    border-color: rgba(107, 142, 78, 0.34);
    box-shadow:
        inset 0 1px 0 rgba(255, 249, 238, 0.86),
        0 16px 34px rgba(58, 46, 34, 0.10);
}

.team-showcase .staff-card--center {
    grid-column: 2;
}

.team-showcase .staff-card__mark {
    display: inline-grid;
    place-items: center;
    width: 2.2rem;
    height: 2.2rem;
    margin-bottom: var(--sp-3);
    border-radius: 12px;
    background: rgba(107, 142, 78, 0.12);
    border: 1px solid rgba(107, 142, 78, 0.22);
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    color: var(--accent-moss-deep);
}

.team-showcase .staff-card h3 {
    font-weight: 500;
    font-size: clamp(1.08rem, 1.5vw, 1.25rem);
}

.team-showcase .staff-role {
    color: var(--ink-walnut);
}

@media (max-width: 960px) {
    .team-showcase .pi-grid {
        grid-template-columns: 1fr 1fr;
    }

    .team-showcase .staff-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .team-showcase .staff-card--center {
        grid-column: auto;
    }
}

@media (max-width: 640px) {
    .team-showcase::before,
    .team-showcase::after,
    .team-showcase .pi-grid::before {
        display: none;
    }

    .team-showcase .pi-grid,
    .team-showcase .staff-grid {
        grid-template-columns: 1fr;
    }

    .team-showcase .pi-card {
        grid-template-columns: 1fr;
        min-height: auto;
        border-radius: 22px;
    }
}

@media (prefers-reduced-motion: reduce) {
    .team-showcase .pi-card,
    .team-showcase .staff-card,
    .team-showcase .pi-card__mark {
        transition: none;
    }
}

.home-subsection-title {
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--ink-walnut);
    margin: var(--sp-7) 0 var(--sp-5);
    padding-top: var(--sp-4);
    border-top: 1px solid var(--paper-shadow);
    font-weight: 500;
    max-width: 1240px;
}

.home-subsection-title:first-of-type {
    border-top: 0;
    padding-top: 0;
    margin-top: var(--sp-5);
}

#team .home-subsection-title,
#partners .home-subsection-title { margin-top: var(--sp-7); }

#partners {
    margin-top: var(--sp-8);
}

.partners-showcase {
    position: relative;
    max-width: min(1180px, 100%);
    margin-bottom: var(--sp-5);
    padding: clamp(2rem, 4vw, 3.5rem);
    overflow: hidden;
    isolation: isolate;
    border: 1px solid rgba(107, 85, 60, 0.16);
    border-radius: 32px;
    background:
        radial-gradient(circle at 12% 18%, rgba(31, 58, 95, 0.10), transparent 18rem),
        radial-gradient(circle at 82% 34%, rgba(181, 83, 60, 0.08), transparent 22rem),
        linear-gradient(135deg, rgba(255, 249, 238, 0.58), rgba(232, 220, 196, 0.36));
    box-shadow:
        inset 0 1px 0 rgba(255, 249, 238, 0.8),
        0 28px 70px rgba(58, 46, 34, 0.08);
}

.partners-showcase::before,
.partners-showcase::after {
    content: "";
    position: absolute;
    pointer-events: none;
    z-index: -1;
}

.partners-showcase::before {
    inset: 1.25rem;
    border: 1px solid rgba(107, 85, 60, 0.08);
    border-radius: 26px;
    background: radial-gradient(circle at 18% 76%, rgba(107, 142, 78, 0.09), transparent 16rem);
    opacity: 0.82;
}

.partners-showcase::after {
    right: clamp(1.5rem, 6vw, 5rem);
    top: clamp(2rem, 6vw, 4.5rem);
    width: 18rem;
    height: 18rem;
    border-radius: 50%;
    border: 1px solid rgba(31, 58, 95, 0.12);
    box-shadow:
        0 0 0 36px rgba(31, 58, 95, 0.025),
        -7rem 8rem 0 -6.9rem rgba(181, 83, 60, 0.18),
        4rem 12rem 0 -3.9rem rgba(107, 142, 78, 0.16);
    opacity: 0.55;
}

.partners-showcase .section-title {
    margin-bottom: var(--sp-3);
}

.partners-lede {
    max-width: 68ch;
    margin: 0 0 clamp(2rem, 5vw, 3.5rem);
    color: var(--ink-walnut);
    font-size: clamp(1rem, 1.4vw, 1.15rem);
    line-height: var(--leading-body);
}

.partners-network {
    display: none;
}

.partners-network svg {
    width: 100%;
    height: 100%;
    overflow: visible;
}

.partners-network path {
    fill: none;
    vector-effect: non-scaling-stroke;
}

.partners-network__track {
    stroke: rgba(107, 85, 60, 0.14);
    stroke-width: 1.2;
    stroke-dasharray: 7 12;
}

.partners-network__draw {
    stroke: color-mix(in srgb, var(--accent-ink) 62%, var(--accent-rust));
    stroke-width: 1.8;
    stroke-linecap: round;
    filter: drop-shadow(0 0 10px rgba(31, 58, 95, 0.16));
    stroke-dasharray: var(--partners-path-length, 1);
    stroke-dashoffset: var(--partners-path-length, 1);
    opacity: 0.62;
    transition: stroke-dashoffset 1400ms cubic-bezier(0.16, 1, 0.3, 1), opacity var(--dur-med) var(--ease-standard);
}

.partners-network__draw--secondary {
    stroke: color-mix(in srgb, var(--accent-moss) 64%, var(--accent-ochre));
    transition-delay: 180ms;
}

.partners-showcase.is-visible .partners-network__draw {
    stroke-dashoffset: 0;
}

.partners-showcase:has(.partner-card:hover) .partners-network__draw {
    opacity: 0.95;
}

.partners-showcase .home-subsection-title {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    gap: var(--sp-3);
    margin-top: clamp(2rem, 4vw, 3rem);
    margin-bottom: var(--sp-4);
    border-top-color: rgba(107, 85, 60, 0.16);
}

.partners-showcase .home-subsection-title::after {
    content: "";
    flex: 1;
    height: 1px;
    background: linear-gradient(90deg, rgba(107, 85, 60, 0.24), transparent);
}

.partners-showcase .home-subsection-title:nth-of-type(2) {
    border-top: 0;
    padding-top: 0;
}

.partners-showcase .partner-grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: clamp(0.85rem, 1.6vw, 1.15rem);
    border: 0;
}

.partners-showcase .partner-card {
    --partner-accent: var(--accent-ink);
    --partner-glow: rgba(31, 58, 95, 0.12);
    position: relative;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: var(--sp-3);
    grid-column: span 2;
    min-height: 210px;
    padding: clamp(1rem, 1.8vw, 1.35rem);
    overflow: hidden;
    border: 1px solid rgba(107, 85, 60, 0.18);
    border-radius: 22px;
    background:
        radial-gradient(circle at 14% 14%, rgba(255, 249, 238, 0.76), transparent 36%),
        linear-gradient(145deg, rgba(255, 249, 238, 0.72), rgba(232, 220, 196, 0.54));
    box-shadow:
        inset 0 1px 0 rgba(255, 249, 238, 0.78),
        0 14px 34px rgba(58, 46, 34, 0.06);
    opacity: 0;
    transform: translateY(18px);
    transition:
        opacity 680ms var(--ease-standard),
        transform 680ms var(--ease-standard),
        border-color var(--dur-med) var(--ease-standard),
        box-shadow var(--dur-med) var(--ease-standard),
        background-position var(--dur-med) var(--ease-standard);
}

.partners-showcase:not(.is-visible) .partner-card {
    transition-delay: calc(var(--partner-index, 0) * 75ms);
}

.partners-showcase.is-visible .partner-card {
    opacity: 1;
    transform: translateY(0);
}

.partners-showcase .partner-card:nth-child(4),
.partners-showcase .partner-card:nth-child(5) {
    grid-column: span 3;
}

.partners-showcase .partner-grid--research .partner-card {
    grid-column: span 3;
}

.partners-showcase .partner-card--startup {
    --partner-accent: var(--accent-rust);
    --partner-glow: rgba(181, 83, 60, 0.12);
    min-height: 190px;
}

.partners-showcase .partner-card::before,
.partners-showcase .partner-card::after {
    content: "";
    position: absolute;
    pointer-events: none;
}

.partners-showcase .partner-card::before {
    inset: 0;
    background-image:
        radial-gradient(rgba(58, 46, 34, 0.13) 0.55px, transparent 0.8px),
        linear-gradient(120deg, transparent 0 52%, color-mix(in srgb, var(--partner-accent) 12%, transparent) 53%, transparent 72%);
    background-size: 12px 12px, auto;
    opacity: 0.08;
    mix-blend-mode: multiply;
}

.partners-showcase .partner-card::after {
    right: 1rem;
    bottom: 1rem;
    width: 3.4rem;
    height: 3.4rem;
    border-radius: 50%;
    border: 1px solid color-mix(in srgb, var(--partner-accent) 22%, transparent);
    box-shadow: 0 0 0 12px color-mix(in srgb, var(--partner-accent) 5%, transparent);
    opacity: 0.64;
}

.partners-showcase .partner-card:hover {
    transform: translateY(-5px);
    border-color: color-mix(in srgb, var(--partner-accent) 38%, var(--paper-shadow));
    box-shadow:
        inset 0 1px 0 rgba(255, 249, 238, 0.9),
        0 22px 48px rgba(58, 46, 34, 0.11),
        0 0 34px color-mix(in srgb, var(--partner-accent) 10%, transparent);
}

.partners-showcase .partner-card__mark,
.partners-showcase .partner-card__body,
.partners-showcase .partner-card__meta,
.partners-showcase .partner-card h3,
.partners-showcase .partner-card p,
.partners-showcase .partner-card__tags {
    position: relative;
    z-index: 1;
}

.partners-showcase .partner-card__mark {
    display: grid;
    place-items: center;
    width: 3.2rem;
    height: 3.2rem;
    border: 1px solid color-mix(in srgb, var(--partner-accent) 30%, var(--paper-shadow));
    border-radius: 16px;
    background:
        radial-gradient(circle at 32% 24%, rgba(255, 249, 238, 0.86), transparent 48%),
        color-mix(in srgb, var(--partner-accent) 12%, var(--paper-cream));
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    letter-spacing: 0.1em;
    color: color-mix(in srgb, var(--partner-accent) 68%, var(--ink-umber));
}

.partners-showcase .partner-card:hover .partner-card__mark {
    animation: partnerNodePulse 1500ms ease-in-out infinite;
}

.partners-showcase .partner-card__logo {
    overflow: hidden;
    padding: 0.35rem;
    background: rgba(255, 249, 238, 0.72);
}

.partners-showcase .partner-card__logo img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: contain;
}

.partners-showcase .partner-card__body {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.partners-showcase .partner-card__meta {
    margin: 0 0 var(--sp-2);
    font-family: var(--font-mono);
    font-size: 0.65rem;
    letter-spacing: 0.13em;
    line-height: 1.35;
    text-transform: uppercase;
    color: color-mix(in srgb, var(--partner-accent) 56%, var(--ink-walnut));
}

.partners-showcase .partner-card h3 {
    font-size: clamp(1.18rem, 1.8vw, 1.55rem);
    font-weight: 500;
    line-height: 1.1;
    margin-bottom: var(--sp-3);
}

.partners-showcase .partner-card p:not(.partner-card__meta) {
    color: var(--ink-walnut);
    line-height: 1.55;
}

.partners-showcase .partner-card__tags {
    margin-top: auto;
    padding-top: var(--sp-4);
    color: var(--ink-walnut);
    line-height: 1.55;
}

.partners-oversight {
    position: relative;
    z-index: 1;
    margin-top: clamp(2rem, 4vw, 3rem);
    font-size: var(--text-sm);
    color: var(--ink-walnut);
    max-width: 76ch;
    line-height: var(--leading-body);
    padding: var(--sp-5) var(--sp-5) 0;
    border-top: 1px solid rgba(107, 85, 60, 0.18);
}

@keyframes partnerNodePulse {
    0%, 100% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--partner-accent) 0%, transparent); }
    50% { box-shadow: 0 0 0 8px color-mix(in srgb, var(--partner-accent) 8%, transparent); }
}

@media (max-width: 960px) {
    .partners-showcase {
        padding: clamp(1.25rem, 4vw, 2rem);
        border-radius: 26px;
    }

    .partners-showcase .partner-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .partners-showcase .partner-card,
    .partners-showcase .partner-grid--research .partner-card,
    .partners-showcase .partner-card:nth-child(4),
    .partners-showcase .partner-card:nth-child(5) {
        grid-column: span 1;
    }
}

@media (max-width: 640px) {
    .partners-network,
    .partners-showcase::after {
        display: none;
    }

    .partners-showcase .partner-grid {
        grid-template-columns: 1fr;
    }

    .partners-showcase .partner-card {
        grid-template-columns: 1fr;
        min-height: auto;
    }

    .partners-oversight {
        padding-left: 0;
        padding-right: 0;
    }
}

@media (prefers-reduced-motion: reduce) {
    .partners-showcase .partner-card,
    .partners-network__draw {
        transition: none;
        animation: none;
    }

    .partners-network__draw {
        stroke-dashoffset: 0;
    }

    .partners-showcase .partner-card:hover .partner-card__mark {
        animation: none;
    }
}
