html:has(> body.page-matching) {
    overflow-x: clip;
}

.page-matching {
    --matching-hero-bg: var(--color-bg);
    --matching-hero-text: var(--color-text);
    --matching-hero-muted: var(--color-subtext);
    --matching-hero-line: var(--color-line);
    --matching-surface: var(--color-surface);
    --matching-soft-panel: linear-gradient(180deg, var(--color-surface-strong), var(--color-surface));
    --matching-nav-ink: var(--color-text);
    --matching-scene-glow: oklch(0.96 0.02 82 / 0.7);

    background:
        radial-gradient(circle at top left, oklab(0.995 0.001 0.002 / 0.95), transparent 28%),
        radial-gradient(circle at top right, oklab(0.965 0.006 0.012 / 0.22), transparent 24%),
        linear-gradient(180deg, var(--color-bg) 0%, var(--color-bg-2) 100%);
}

html[data-website-theme="rosewater_arcade"] .page-matching {
    --matching-hero-bg: oklch(0.992 0.005 29);
    --matching-hero-text: oklch(0.27 0.032 18);
    --matching-hero-muted: oklch(0.235 0.028 17 / 0.94);
    --matching-hero-line: oklch(0.57 0.035 28 / 0.34);
    --matching-surface: oklch(0.998 0.003 29 / 0.62);
    --matching-nav-ink: oklch(0.18 0.02 16 / 0.98);
}

.page-matching .nav-wrap {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 100;
    background: transparent;
    backdrop-filter: blur(calc(var(--spacing) * 2));
    -webkit-backdrop-filter: blur(calc(var(--spacing) * 2));
    transition:
        background-color 0.35s ease,
        backdrop-filter 0.35s ease,
        -webkit-backdrop-filter 0.35s ease;
}

.page-matching .nav-wrap.nav-wrap--past-hero {
    background: oklch(1 0 0 / 0.82);
    backdrop-filter: blur(calc(var(--spacing) * 5));
    -webkit-backdrop-filter: blur(calc(var(--spacing) * 5));
}

html[data-website-theme="rosewater_arcade"] .page-matching .nav-wrap:not(.nav-wrap--past-hero) {
    background: oklch(0.998 0.002 28 / 0.72);
    backdrop-filter: blur(calc(var(--spacing) * 5));
    -webkit-backdrop-filter: blur(calc(var(--spacing) * 5));
}

html[data-website-theme="rosewater_arcade"] .page-matching .nav-wrap.nav-wrap--past-hero {
    background: oklch(0.998 0.002 28 / 0.92);
}

.page-matching .nav-wrap:not(.nav-wrap--past-hero) .brand,
.page-matching .nav-wrap:not(.nav-wrap--past-hero) .nav-links,
.page-matching .nav-wrap:not(.nav-wrap--past-hero) .nav-actions .btn-glass {
    color: var(--matching-nav-ink);
}

.page-matching .nav-wrap:not(.nav-wrap--past-hero) .nav-actions .btn-primary {
    background: var(--color-text);
    color: var(--color-white);
    border-color: transparent;
    box-shadow: 0 14px 30px rgba(23, 23, 25, 0.12);
}

.page-matching .nav-wrap:not(.nav-wrap--past-hero) .btn-light {
    background: oklch(1 0 0 / 0.96);
    color: var(--color-text);
    border-color: oklch(1 0 0 / 0.22);
    box-shadow: 0 10px 32px rgba(0, 0, 0, 0.18);
}

.page-matching .brand-wordmark img,
html[data-website-theme="rosewater_arcade"] .page-matching .brand-wordmark img,
.page-matching .nav-wrap.nav-wrap--past-hero .brand-wordmark img {
    filter: none;
}

.page-matching .reveal {
    opacity: 0;
    transform: translateY(calc(var(--spacing) * 4.5));
    transition: opacity 0.7s ease, transform 0.7s ease;
}

.page-matching .reveal.is-visible {
    opacity: 1;
    transform: translateY(0);
}

.page-matching .section {
    scroll-margin-top: calc(var(--nav-min-height) + var(--spacing) * 4);
}

.page-matching .matching-hero {
    position: relative;
    min-height: 100svh;
    padding: 0;
    overflow: clip;
    color: var(--matching-hero-text);
    background: var(--matching-hero-bg);
    --hero-image-src: url("../../images/bg_matching_hero_bg.webp");
    --hero-image-position: 80% center;
}

.page-matching .matching-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    background: linear-gradient(
        90deg,
        oklch(1 0 0 / 0.8) 0%,
        oklch(1 0 0 / 0.68) 34%,
        oklch(1 0 0 / 0.32) 62%,
        oklch(1 0 0 / 0.08) 100%
    );
}

.page-matching .matching-hero__glow,
.page-matching .matching-hero__grid {
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
}

.page-matching .matching-hero__glow {
    opacity: 0;
    background:
        radial-gradient(circle at 74% 22%, oklch(0.96 0.034 76 / 0.34), transparent 18%),
        radial-gradient(circle at 88% 74%, oklch(1 0 0 / 0.18), transparent 24%);
    filter: blur(18px);
    transform: scale(1.04);
    transition: opacity 0.9s ease, filter 0.9s ease, transform 0.9s ease;
}

.page-matching .matching-hero--visual-ready .matching-hero__glow {
    opacity: 1;
    filter: blur(0);
    transform: scale(1);
}

.page-matching .matching-hero__grid {
    opacity: 0;
    background-image: var(--hero-image-src);
    background-position: var(--hero-image-position, center center);
    background-size: cover;
    background-repeat: no-repeat;
    mix-blend-mode: normal;
    mask-image: linear-gradient(90deg, transparent 0%, transparent 44%, oklch(0 0 0 / 0.52) 62%, oklch(0 0 0 / 0.92) 78%, oklch(0 0 0 / 1) 100%);
    -webkit-mask-image: linear-gradient(90deg, transparent 0%, transparent 44%, rgba(0, 0, 0, 0.52) 62%, rgba(0, 0, 0, 0.92) 78%, rgba(0, 0, 0, 1) 100%);
    transform: scale(1.02);
    transition: opacity 0.9s ease, transform 0.9s ease;
}

.page-matching .matching-hero--visual-ready .matching-hero__grid {
    opacity: 0.88;
    transform: scale(1);
}

.page-matching .matching-hero__shell {
    position: relative;
    z-index: 2;
    min-height: 85svh;
    display: grid;
    align-items: end;
    padding-top: calc(var(--nav-min-height) + var(--spacing) * 12);
    padding-bottom: clamp(132px, 18vh, 240px);
}

.page-matching .matching-hero__copy {
    position: relative;
    isolation: isolate;
    max-width: calc(var(--font-size) * 45);
}

.page-matching .matching-hero__copy::before {
    content: "";
    position: absolute;
    inset: -172px -360px -184px -240px;
    z-index: 0;
    border-radius: calc(var(--spacing) * 24);
    background: linear-gradient(180deg, oklch(1 0 0 / 0.66), oklch(1 0 0 / 0.22));
    backdrop-filter: blur(14px) saturate(0.92);
    -webkit-backdrop-filter: blur(14px) saturate(0.92);
    mask-image:
        radial-gradient(ellipse at 32% 50%, oklch(0 0 0 / 0.96) 0%, oklch(0 0 0 / 0) 66%, oklch(0 0 0 / 0) 100%);
    -webkit-mask-image:
        radial-gradient(ellipse at 32% 50%, rgba(0, 0, 0, 0.96) 0%, rgba(0, 0, 0, 0) 66%, rgba(0, 0, 0, 0) 100%);
    pointer-events: none;
}

.page-matching .matching-hero__copy > * {
    position: relative;
    z-index: 1;
}

.page-matching .matching-hero__title {
    margin: 0;
    color: var(--matching-hero-text);
    text-wrap: balance;
    font-weight: 600;
    font-size: clamp(42px, 6.5vw, 80px);
    line-height: 0.92;
    letter-spacing: -0.035em;
}

.page-matching .matching-hero__story-band {
    position: relative;
    z-index: 3;
    margin-top: clamp(-170px, -10vw, -72px);
    margin-bottom: clamp(40px, 6vw, 88px);
}

.page-matching .matching-hero__story {
    width: 100%;
}

.page-matching .matching-hero__story-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    gap: clamp(16px, 1.6vw, 48px);
    align-items: stretch;
    width: 100%;
    padding: clamp(24px, 2vw, 36px);
    border: 1px solid oklch(1 0 0 / 0.42);
    border-radius: calc(var(--spacing) * 8);
    background: linear-gradient(180deg, oklch(1 0 0 / 0.72), oklch(1 0 0 / 0.48));
    box-shadow: 0 30px 72px oklch(0 0 0 / 0.12);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(calc(var(--spacing) * 4));
}

.page-matching .matching-hero__story-panel {
    min-width: 0;
    display: grid;
    align-content: start;
    gap: calc(var(--spacing) * 2.5);
}

.page-matching .matching-hero__story-title {
    margin: 0;
    color: var(--color-text);
    font-family: var(--font-serif);
    font-size: clamp(32px, 3.2vw, 38px);
    margin-bottom: calc(var(--spacing) * 4);
    line-height: 1.02;
    letter-spacing: -0.04em;
}

.page-matching .matching-hero__story-arrow {
    display: grid;
    place-items: center;
    align-self: center;
    width: clamp(88px, 9vw, 132px);
    height: clamp(88px, 9vw, 132px);
    color: var(--color-accent);
    flex-shrink: 0;
}

.page-matching .matching-hero__story-arrow .lucide {
    width: clamp(46px, 4.8vw, 72px);
    height: clamp(46px, 4.8vw, 72px);
    stroke-width: 2.2;
}

.page-matching .matching-hero__story-text {
    margin: 0;
    color: var(--color-text);
    font-size: calc(var(--font-size-body) * 1.05);
    line-height: 1.6;
    text-wrap: pretty;
}

.page-matching .matching-hero__actions {
    margin-top: calc(var(--spacing) * 7);
}

.page-matching .matching-issue-grid,
.page-matching .matching-pillars {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: calc(var(--spacing) * 4.5);
}

.page-matching .matching-issue-card,
.page-matching .matching-pillar,
.page-matching .matching-demo__legend-item {
    height: 100%;
    padding: calc(var(--spacing) * 6);
    border-radius: calc(var(--spacing) * 7.5);
    background:
        radial-gradient(circle at top right, oklch(0.88 0.03 78 / 0.18), transparent 34%),
        var(--matching-soft-panel);
    border: 1px solid var(--color-line);
    box-shadow: var(--shadow-lg);
}

.page-matching .matching-issue-card h3,
.page-matching .matching-pillar h3,
.page-matching .matching-demo__legend-item h4,
.page-matching .matching-demo__overview h3,
.page-matching .matching-demo__card h3,
.page-matching .matching-final-benefit h3 {
    margin: 0 0 calc(var(--spacing) * 3);
    color: var(--color-text);
    line-height: 1;
    letter-spacing: -0.04em;
}

.page-matching .matching-issue-card h3,
.page-matching .matching-pillar h3 {
    font-size: clamp(26px, 2.3vw, 36px);
}

.page-matching .matching-issue-card p,
.page-matching .matching-pillar p,
.page-matching .matching-demo__legend-item p,
.page-matching .matching-demo__overview p,
.page-matching .matching-demo__card-panel p,
.page-matching .matching-final-benefit p {
    color: var(--color-subtext);
    line-height: var(--line-height-relaxed);
}

.page-matching .matching-issue-card p + p {
    margin-top: calc(var(--spacing) * 3);
}

.page-matching .matching-issue-card .step-number {
    margin-bottom: calc(var(--spacing) * 5);
    color: var(--color-accent);
    font-size: calc(var(--font-size) * 2.5);
    line-height: 1;
    letter-spacing: 0;
}

.page-matching .matching-issue-summary {
    margin-top: calc(var(--spacing) * 5);
}

.page-matching .matching-issue-summary,
.page-matching .matching-issue-summary.lead {
    color: var(--color-text);
    font-size: calc(var(--font-size-body) * 1.2);
    line-height: var(--line-height-relaxed);
    text-wrap: balance;
}

.page-matching .matching-audience-section {
    --matching-audience-visual-top: clamp(180px, 20svh, 300px);
    --matching-audience-visual-height: min(108svh, 1080px);
    position: relative;
    isolation: isolate;
    overflow: hidden;
}

.page-matching .matching-audience-section::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.page-matching .matching-audience-section > .container {
    position: relative;
    z-index: 3;
}

.page-matching .matching-audience-backdrop {
    position: absolute;
    top: var(--matching-audience-visual-top);
    right: 0;
    left: 0;
    bottom: auto;
    height: var(--matching-audience-visual-height);
    z-index: 0;
    pointer-events: none;
}

.page-matching .matching-audience-scene {
    --matching-audience-sticky-top: calc(var(--nav-min-height) + 20px);
    position: relative;
}

.page-matching .matching-audience__sticky {
    position: sticky;
    top: var(--matching-audience-sticky-top);
    display: grid;
    align-items: center;
}

.page-matching .matching-audience__heading {
    position: relative;
    z-index: 3;
    margin-bottom: clamp(28px, 5svh, 60px);
}

.page-matching .matching-audience__grid {
    position: relative;
    min-height: clamp(280px, 42svh, 400px);
    display: grid;
    align-items: center;
}

.page-matching .matching-audience__copy {
    position: relative;
    z-index: 2;
    width: min(100%, calc(var(--font-size) * 41));
    max-width: min(100%, calc(var(--font-size) * 41));
    padding: 0;
    min-height: inherit;
    display: grid;
    align-items: center;
    overflow: clip;
}

.page-matching .matching-audience__copy::before {
    content: "";
    position: absolute;
    z-index: 0;
    pointer-events: none;
    inset: 0 0 0 0;
    z-index: 0;
    border-radius: calc(var(--spacing) * 24);
    background: linear-gradient(180deg, oklch(1 0 0 / 0.46), oklch(1 0 0 / 0.22));
    backdrop-filter: blur(8px) saturate(0.92);
    -webkit-backdrop-filter: blur(14px) saturate(0.92);
    mask-image: radial-gradient(ellipse at 50% 50%, rgba(0, 0, 0, 0.96) 0%, rgba(0, 0, 0, 0.76) 30%, rgba(0, 0, 0, 0.66) 55%, rgba(0, 0, 0, 0) 70%, rgba(0, 0, 0, 0) 100%);
    -webkit-mask-image: radial-gradient(ellipse at 50% 50%, rgba(0, 0, 0, 0.96) 0%, rgba(0, 0, 0, 0.76) 30%, rgba(0, 0, 0, 0.66) 55%, rgba(0, 0, 0, 0) 70%, rgba(0, 0, 0, 0) 100%);
}

.page-matching .matching-audience__copy > * {
    position: relative;
    z-index: 1;
}

.page-matching .matching-audience__stage {
    position: relative;
    width: 100%;
    overflow: clip;
    min-height: inherit;
}

.page-matching .matching-audience-card {
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    width: 100%;
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    transform-origin: 50% 50%;
    will-change: transform, opacity;
    border: 0;
    border-radius: 0;
    background: none;
    box-shadow: none;
    opacity: 0;
    pointer-events: none;
    transform: translate3d(0, 18%, 0);
    transition:
        transform 0.56s cubic-bezier(0.22, 1, 0.36, 1),
        opacity 0.38s ease;
}

.page-matching .matching-audience-card.is-current {
    opacity: 1;
    pointer-events: auto;
    transform: translate3d(0, 0, 0);
    z-index: 3;
}

.page-matching .matching-audience-card.is-before {
    opacity: 0;
    transform: translate3d(0, -18%, 0);
    z-index: 2;
}

.page-matching .matching-audience-card.is-after {
    opacity: 0;
    transform: translate3d(0, 18%, 0);
    z-index: 1;
}

.page-matching .matching-audience-card__eyebrow,
.page-matching .matching-pillar span {
    display: inline-flex;
    margin-bottom: calc(var(--spacing) * 4);
    color: var(--color-accent);
    font-size: var(--font-size-14);
    font-weight: 800;
    line-height: 1;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.page-matching .matching-audience-card__eyebrow {
    font-size: calc(var(--font-size-body) * 1.2);
}

.page-matching .matching-audience-card h3 {
    margin: 0 0 calc(var(--spacing) * 3.5);
    font-family: var(--font-serif);
    font-size: clamp(36px, 3.8vw, 56px);
    line-height: 0.96;
    letter-spacing: -0.04em;
    color: var(--color-text);
}

.page-matching .matching-audience-card p {
    color: var(--color-text);
    font-size: calc(var(--font-size-body) * 1.02);
    line-height: 1.58;
}

.page-matching .matching-audience-card .bullets {
    margin-top: calc(var(--spacing) * 4);
}

.page-matching .matching-audience-card .bullets li {
    color: var(--color-text);
    line-height: 1.45;
}

.page-matching .matching-audience-figure {
    --matching-audience-bg-scale: 1;
    --matching-audience-person-shift: 0%;
    --matching-audience-person-scale: 1;
    position: absolute;
    inset: 0;
    overflow: hidden;
    background: var(--color-bg);
    opacity: 0;
    transition: opacity 0.5s ease;
    pointer-events: none;
}

.page-matching .matching-audience-figure::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 2;
    pointer-events: none;
    background:
        linear-gradient(180deg, oklch(from var(--color-bg) l c h / 0.96) 0%, oklch(from var(--color-bg) l c h / 0.88) 12%, oklch(from var(--color-bg) l c h / 0.56) 34%, oklch(from var(--color-bg) l c h / 0.48) 100%),
        linear-gradient(
            90deg,
            oklch(from var(--color-bg) l c h / 0.34) 0%,
            oklch(from var(--color-bg) l c h / 0.18) 18%,
            transparent 42%,
            transparent 100%
        );
}

.page-matching .matching-audience-figure__bg,
.page-matching .matching-audience-figure__person {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 68% top;
}

.page-matching .matching-audience-figure__bg {
    z-index: 1;
    transform: scale(var(--matching-audience-bg-scale));
    opacity: 0;
    transition: opacity 0.5s ease, transform 0.5s ease;
    filter: brightness(1.06) saturate(0.72) contrast(0.92);
    mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.98) 18%, rgba(0, 0, 0, 1) 34%, rgba(0, 0, 0, 1) 100%);
    -webkit-mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.98) 18%, rgba(0, 0, 0, 1) 34%, rgba(0, 0, 0, 1) 100%);
}

.page-matching .matching-audience-figure__person {
    z-index: 3;
    transform: translate3d(var(--matching-audience-person-shift), 0, 0) scale(var(--matching-audience-person-scale));
    opacity: 0;
    transition: opacity 0.5s ease, transform 0.56s cubic-bezier(0.22, 1, 0.36, 1);
    filter: brightness(1) saturate(0.965) contrast(0.945);
}

.page-matching .matching-audience-figure.is-current {
    opacity: 1;
}

.page-matching .matching-audience-figure.is-current .matching-audience-figure__bg {
    opacity: 1;
    transform: scale(1);
}

.page-matching .matching-audience-figure.is-current .matching-audience-figure__person {
    opacity: 1;
    transform: translate3d(5%, 0, 0) scale(1);
}

.page-matching .matching-audience-figure.is-before .matching-audience-figure__bg {
    opacity: 0;
    transform: scale(1.01);
}

.page-matching .matching-audience-figure.is-after .matching-audience-figure__bg {
    opacity: 0;
    transform: scale(1.01);
}

.page-matching .matching-audience-figure.is-before .matching-audience-figure__person {
    opacity: 0;
    transform: translate3d(-3%, 0, 0) scale(1);
}

.page-matching .matching-audience-figure.is-after .matching-audience-figure__person {
    opacity: 0;
    transform: translate3d(13%, 0, 0) scale(1);
}

.page-matching .matching-surface,
.page-matching .matching-get-started {
    padding: calc(var(--spacing) * 8);
    border-radius: calc(var(--spacing) * 8);
    border: 1px solid var(--color-line);
    background:
        radial-gradient(circle at top right, oklch(0.96 0.015 92 / 0.72), transparent 30%),
        linear-gradient(180deg, oklch(0.997 0.002 95), oklch(0.982 0.004 92));
    box-shadow: var(--shadow-lg);
}

.page-matching .matching-technology__heading {
    margin-bottom: calc(var(--spacing) * 5);
}

.page-matching .matching-technology__copy {
    width: 100%;
    max-width: none;
}

.page-matching .matching-technology__text {
    color: var(--color-text);
    font-size: var(--font-size-lead);
    line-height: var(--line-height-relaxed);
}

.page-matching .matching-technology__image {
    display: block;
    margin-left: auto;
    margin-right: auto;
    margin-top: calc(var(--spacing) * 8);
    margin-bottom: calc(var(--spacing) * 8);
}

.page-matching .matching-vision {
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
    gap: calc(var(--spacing) * 6);
    align-items: start;
}

.page-matching .matching-vision__heading {
    margin-bottom: 0;
}

.page-matching .matching-vision__copy {
    justify-self: end;
    width: 100%;
    max-width: calc(var(--font-size) * 50);
}

.page-matching .matching-vision__text {
    color: var(--color-text);
    font-size: var(--font-size-lead);
    line-height: var(--line-height-relaxed);
}

.page-matching .matching-matrix-copy p + p,
.page-matching .matching-vision-copy p + p {
    margin-top: calc(var(--spacing) * 4);
}

.page-matching .matching-demo {
    display: grid;
    grid-template-columns: minmax(0, 0.94fr) minmax(320px, 1.06fr);
    gap: calc(var(--spacing) * 5.5);
    align-items: start;
}

.page-matching .matching-demo__overview h3 {
    font-family: var(--font-serif);
    font-size: clamp(34px, 3vw, 46px);
}

.page-matching .matching-demo__legend {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: calc(var(--spacing) * 3.5);
    margin-top: calc(var(--spacing) * 5);
}

.page-matching .matching-demo__card {
    padding: calc(var(--spacing) * 8);
    border-radius: calc(var(--spacing) * 8);
    background:
        radial-gradient(circle at top right, oklch(0.87 0.065 145 / 0.16), transparent 30%),
        linear-gradient(180deg, oklch(0.995 0.006 145), oklch(0.982 0.008 142));
    border: 1px solid var(--color-line);
    box-shadow: var(--shadow-lg);
}

.page-matching .matching-demo__grade {
    display: inline-flex;
    margin-bottom: calc(var(--spacing) * 4);
    padding: calc(var(--spacing) * 2) calc(var(--spacing) * 3);
    border-radius: var(--radius-pill);
    background: oklch(0.93 0.06 145 / 0.48);
    color: oklch(0.38 0.09 145);
    font-size: var(--font-size-xs);
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.page-matching .matching-demo__card h3 {
    font-family: var(--font-serif);
    font-size: clamp(34px, 3vw, 44px);
}

.page-matching .matching-demo__card-grid {
    display: grid;
    gap: calc(var(--spacing) * 3.5);
    margin-top: calc(var(--spacing) * 5);
}

.page-matching .matching-demo__card-panel {
    padding: calc(var(--spacing) * 5);
    border-radius: calc(var(--spacing) * 6);
    background: oklch(1 0 0 / 0.44);
    border: 1px solid oklch(0.74 0.04 145 / 0.22);
}

.page-matching .matching-demo__card-panel h4 {
    margin: 0 0 calc(var(--spacing) * 0);
    color: var(--color-text);
    font-size: var(--font-size-body);
    line-height: 1.2;
    letter-spacing: 0.01em;
}

.page-matching .matching-demo__card-heading {
    display: inline-flex;
    align-items: center;
    gap: calc(var(--spacing) * 2);
}

.page-matching .matching-demo__card-heading .lucide {
    width: calc(var(--spacing) * 4.5);
    height: calc(var(--spacing) * 4.5);
    flex-shrink: 0;
    stroke-width: 2.15;
}

.page-matching .matching-demo__card-heading--success .lucide {
    color: oklch(0.63 0.16 150);
}

.page-matching .matching-demo__card-heading--warning .lucide {
    color: oklch(0.72 0.16 75);
}

.page-matching .matching-demo__callout {
    margin-top: calc(var(--spacing) * 4);
    padding: calc(var(--spacing) * 4.5);
    border-radius: calc(var(--spacing) * 5);
    background: oklch(0.16 0.01 250 / 0.92);
    color: oklch(1 0 0 / 0.88);
    display: flex;
    align-items: flex-start;
    gap: calc(var(--spacing) * 2.5);
    line-height: var(--line-height-body);
    box-shadow: 0 20px 48px oklch(0 0 0 / 0.16);
}

.page-matching .matching-demo__callout .lucide {
    width: calc(var(--spacing) * 4.5);
    height: calc(var(--spacing) * 4.5);
    margin-top: 0.08em;
    flex-shrink: 0;
    color: oklch(0.78 0.15 150);
    stroke-width: 2.1;
}

.page-matching .matching-get-started {
    position: relative;
    overflow: hidden;
    display: grid;
    gap: calc(var(--spacing) * 7);
    color: var(--color-white);
    background:
        radial-gradient(circle at top right, oklch(0.84 0.058 64 / 0.24), transparent 28%),
        var(--dark-panel-bg);
    border-color: oklch(1 0 0 / 0.16);
}

.page-matching .matching-get-started::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(to right, oklch(1 0 0 / 0.04) 1px, transparent 1px),
        linear-gradient(to bottom, oklch(1 0 0 / 0.04) 1px, transparent 1px);
    background-size: 68px 68px;
    pointer-events: none;
}

.page-matching .matching-get-started > * {
    position: relative;
    z-index: 1;
}

.page-matching .matching-get-started__header {
    display: grid;
    grid-template-columns: 1fr;
    gap: calc(var(--spacing) * 4.5);
    align-items: start;
}

.page-matching .matching-get-started__header > div,
.page-matching .matching-get-started__header .lead {
    width: 100%;
    max-width: none;
}

.page-matching .matching-get-started .kicker {
    width: fit-content;
    margin-bottom: calc(var(--spacing) * 4.5);
    padding-bottom: calc(var(--spacing) * 1.5);
    border-bottom: 3px solid var(--color-accent);
    color: oklch(1 0 0 / 0.72);
    font-weight: 700;
    letter-spacing: 0;
}

.page-matching .matching-get-started .kicker::before {
    content: none;
}

.page-matching .matching-get-started h2 {
    margin: 0;
    color: var(--color-white);
    font-size: clamp(44px, 5vw, 72px);
    line-height: 0.95;
    letter-spacing: -0.055em;
}

.page-matching .matching-get-started .lead,
.page-matching .matching-get-started p {
    margin: 0;
    color: oklch(1 0 0 / 0.72);
}

.page-matching .matching-get-started__flow {
    position: relative;
    aspect-ratio: 1200 / 420;
    padding: calc(var(--spacing) * 7);
    border: 1px solid oklch(1 0 0 / 0.12);
    border-radius: calc(var(--spacing) * 8);
    background: linear-gradient(180deg, oklch(1 0 0 / 0.09), oklch(1 0 0 / 0.03));
    box-shadow:
        inset 0 1px 0 oklch(1 0 0 / 0.08),
        0 24px 60px oklch(0 0 0 / 0.14);
    isolation: isolate;
}

.page-matching .matching-get-started__flow::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    background:
        radial-gradient(circle at 20% 84%, oklch(0.74 0.158 48 / 0.24), transparent 18%),
        radial-gradient(circle at 78% 16%, oklch(1 0 0 / 0.08), transparent 24%);
    pointer-events: none;
}

.page-matching .matching-get-started__flow-path {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    pointer-events: none;
}

.page-matching .matching-get-started__flow-path path {
    fill: none;
    stroke: oklch(0.74 0.158 48);
    stroke-width: 4.5;
    stroke-linecap: round;
    stroke-linejoin: round;
    filter: drop-shadow(0 12px 28px oklch(0 0 0 / 0.2));
}

.page-matching .matching-get-started__flow-endpoint,
.page-matching .matching-get-started__flow-arrow {
    position: absolute;
    z-index: 1;
    pointer-events: none;
}

.page-matching .matching-get-started__flow-endpoint {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: oklch(0.74 0.158 48);
    box-shadow:
        0 0 0 4px oklch(1 0 0 / 0.08),
        0 8px 18px oklch(0 0 0 / 0.2);
    transform: translate(-50%, -50%);
}

.page-matching .matching-get-started__flow-endpoint--start {
    left: 9.17%;
    top: 70.48%;
}

.page-matching .matching-get-started__flow-endpoint--end {
    left: 90.83%;
    top: 70.48%;
}

.page-matching .matching-get-started__flow-arrow {
    width: 14px;
    height: 14px;
    border-top: 3px solid oklch(0.74 0.158 48);
    border-right: 3px solid oklch(0.74 0.158 48);
    transform: translate(-50%, -50%) rotate(45deg);
    filter: drop-shadow(0 6px 12px oklch(0 0 0 / 0.16));
}

.page-matching .matching-get-started__flow-arrow--one {
    left: 21%;
    top: 19.52%;
}

.page-matching .matching-get-started__flow-arrow--two {
    left: 47.67%;
    top: 80%;
}

.page-matching .matching-get-started__flow-arrow--three {
    left: 77.33%;
    top: 19.52%;
}

.page-matching .matching-get-started__step {
    position: absolute;
    z-index: 1;
    width: min(100%, clamp(208px, 19vw, 250px));
    padding: calc(var(--spacing) * 3.5) calc(var(--spacing) * 3.75);
    border: 1px solid oklch(1 0 0 / 0.12);
    border-radius: calc(var(--spacing) * 6);
    background: linear-gradient(180deg, oklch(1 0 0 / 0.16), oklch(1 0 0 / 0.07));
    box-shadow:
        inset 0 1px 0 oklch(1 0 0 / 0.08),
        0 18px 40px oklch(0 0 0 / 0.16);
    backdrop-filter: blur(calc(var(--spacing) * 2.5));
    -webkit-backdrop-filter: blur(calc(var(--spacing) * 2.5));
    text-align: center;
}

.page-matching .matching-get-started__step--one {
    left: 23%;
    top: 52%;
    transform: translate(-50%, -50%);
}

.page-matching .matching-get-started__step--two {
    left: 48.5%;
    top: 35%;
    transform: translate(-50%, -50%);
}

.page-matching .matching-get-started__step--three {
    left: 78%;
    top: 52%;
    transform: translate(-50%, -50%);
}

.page-matching .matching-get-started__step h3 {
    margin: 0;
    color: var(--color-white);
    font-size: clamp(18px, 1.45vw, 24px);
    line-height: 1.18;
    letter-spacing: -0.03em;
}

.page-matching .matching-get-started__step p {
    margin: calc(var(--spacing) * 2) 0 0;
    color: oklch(1 0 0 / 0.76);
    font-size: clamp(13px, 0.95vw, 15px);
    line-height: 1.4;
    text-wrap: balance;
}

.page-matching .matching-get-started__actions {
    justify-content: flex-start;
}

.page-matching .matching-get-started__actions {
    justify-content: center;
    margin-top: calc(var(--spacing) * 6);
}

.page-matching .matching-final-cta__support {
    font-size: calc(var(--font-size-body) * 1.2);
    margin-top: calc(var(--spacing) * 0);
    color: var(--color-subtext);
}

.page-matching .matching-final-cta__benefits {
    margin-top: calc(var(--spacing) * 5);
}

.page-matching .matching-final-benefit {
    height: 100%;
}

.page-matching .matching-final-benefit .step-number {
    margin-bottom: calc(var(--spacing) * 5);
    color: var(--color-accent);
    font-size: calc(var(--font-size) * 2.5);
    line-height: 1;
    letter-spacing: 0;
}

.page-matching .matching-final-benefit h4 {
    margin: 0 0 calc(var(--spacing) * 3);
    color: var(--color-text);
    font-size: clamp(24px, 2.1vw, 30px);
    line-height: 1;
    letter-spacing: -0.03em;
}

.page-matching .matching-final-benefit p {
    color: var(--color-subtext);
    line-height: var(--line-height-relaxed);
}

.page-matching .matching-final-cta__actions {
    margin-top: calc(var(--spacing) * 6);
}

.page-matching .matching-final-cta__actions a {
    transform: scale(1.1);
    transform-origin: left center;
    background: var(--color-accent);
    color: var(--color-white);
    border-color: oklab(from var(--color-accent) l a b / 0.34);
    box-shadow: 0 16px 34px oklab(from var(--color-accent) calc(l - 0.25) a b / 0.28);
}

@media (prefers-reduced-motion: reduce) {
    .page-matching .reveal,
    .page-matching .matching-hero__glow,
    .page-matching .matching-hero__grid,
    .page-matching .matching-audience-figure,
    .page-matching .matching-audience-figure__bg,
    .page-matching .matching-audience-figure__person {
        transition: none;
        transform: none;
    }

    .page-matching .matching-hero__glow {
        filter: none;
    }

    .page-matching .matching-audience__sticky {
        position: relative;
        top: auto;
    }

    .page-matching .matching-audience__stage {
        perspective: none;
        transform-style: flat;
        min-height: 0 !important;
    }

    .page-matching .matching-audience-card {
        position: relative;
        top: auto;
        right: auto;
        left: auto;
        transform: none !important;
        opacity: 1 !important;
        z-index: auto !important;
        margin-bottom: calc(var(--spacing) * 4.5);
    }

    .page-matching .matching-audience-card:last-child {
        margin-bottom: 0;
    }
}

@media (max-width: 560px) {
    .page-matching .matching-issue-grid,
    .page-matching .matching-pillars,
    .page-matching .matching-demo,
    .page-matching .matching-final-cta {
        grid-template-columns: 1fr;
    }

    .page-matching .matching-demo__legend {
        grid-template-columns: 1fr;
    }

    .page-matching .matching-audience__sticky {
        position: relative;
        top: auto;
    }

    .page-matching .matching-audience-scene {
        height: auto !important;
    }

    .page-matching .matching-audience__stage {
        min-height: 0 !important;
    }

    .page-matching .matching-audience-card {
        position: relative;
        top: auto;
        right: auto;
        left: auto;
        transform: none !important;
        opacity: 1 !important;
        z-index: auto !important;
        margin-bottom: calc(var(--spacing) * 4.5);
    }

    .page-matching .matching-audience-card:last-child {
        margin-bottom: 0;
    }
}

@media (max-width: 820px) {
    .page-matching .matching-hero,
    .page-matching .matching-hero__shell {
        min-height: auto;
    }

    .page-matching .matching-hero__shell {
        padding-top: calc(var(--nav-min-height) + var(--spacing) * 10);
        padding-bottom: calc(var(--spacing) * 12);
    }

    .page-matching .matching-hero__title {
        font-size: clamp(46px, 14vw, 72px);
        max-width: 100%;
    }

    .page-matching .matching-hero__story-band {
        margin-top: calc(var(--spacing) * -7);
        margin-bottom: calc(var(--spacing) * 8);
    }

    .page-matching .matching-hero__story-card {
        grid-template-columns: 1fr;
        gap: calc(var(--spacing) * 3.5);
        padding: calc(var(--spacing) * 4.5);
    }

    .page-matching .matching-hero__story-arrow {
        width: clamp(84px, 24vw, 104px);
        height: clamp(84px, 24vw, 104px);
        justify-self: center;
    }

    .page-matching .matching-hero__story-arrow .lucide {
        transform: rotate(90deg);
    }

    .page-matching .matching-vision {
        grid-template-columns: 1fr;
        gap: calc(var(--spacing) * 4.5);
    }

    .page-matching .matching-vision__copy {
        justify-self: stretch;
        max-width: 100%;
    }

    .page-matching .matching-hero__story-block,
    .page-matching .matching-surface,
    .page-matching .matching-get-started,
    .page-matching .matching-demo__overview,
    .page-matching .matching-demo__card,
    .page-matching .matching-final-cta {
        padding: calc(var(--spacing) * 6);
    }

    .page-matching .matching-issue-card,
    .page-matching .matching-pillar,
    .page-matching .matching-demo__legend-item,
    .page-matching .matching-final-benefit {
        padding: calc(var(--spacing) * 5);
    }

    .page-matching .matching-audience__copy {
        width: min(100%, calc(var(--font-size) * 34));
        max-width: min(100%, calc(var(--font-size) * 34));
    }

    .page-matching .matching-audience-card h3 {
        font-size: clamp(32px, 7vw, 46px);
    }

    .page-matching .matching-get-started__actions {
        align-items: center;
    }

    .page-matching .matching-get-started__flow {
        aspect-ratio: auto;
        display: grid;
        gap: calc(var(--spacing) * 4);
        padding: calc(var(--spacing) * 5);
    }

    .page-matching .matching-get-started__flow-path,
    .page-matching .matching-get-started__flow-endpoint,
    .page-matching .matching-get-started__flow-arrow {
        display: none;
    }

    .page-matching .matching-get-started__step {
        position: relative;
        width: 100%;
        max-width: none;
        left: auto;
        right: auto;
        top: auto;
        bottom: auto;
        transform: none;
    }
}

@media (max-width: 760px) {
    .page-matching .nav-actions .btn-glass {
        display: none;
    }

    .page-matching .matching-issue-grid,
    .page-matching .matching-pillars {
        grid-template-columns: 1fr;
    }

    .page-matching .matching-audience-figure::after {
        background:
            linear-gradient(180deg, oklch(from var(--color-bg) l c h / 1) 0%, oklch(from var(--color-bg) l c h / 0.96) 22%, oklch(from var(--color-bg) l c h / 0.84) 100%),
            linear-gradient(180deg, oklch(from var(--color-bg) l c h / 0.6) 0%, transparent 56%);
    }

    .page-matching .matching-audience-backdrop {
        top: clamp(140px, 26svh, 220px);
        bottom: auto;
        height: min(96svh, 920px);
    }

    .page-matching .matching-audience__copy {
        width: 100%;
        max-width: 100%;
    }

    .page-matching .matching-audience__copy::before {
        inset: -40px -24px -56px -24px;
        background: linear-gradient(180deg, oklch(1 0 0 / 0.64) 0%, oklch(1 0 0 / 0.42) 42%, oklch(1 0 0 / 0.08) 100%);
    }
}

#solution {
    margin-top: calc(var(--spacing) * -50);
}
