:root {
    --cream: #f4f4f2;
    --white: #ffffff;
    --black: #141414;
    --dark: #181818;
    --g1: #e8e8e8;
    --g2: #c0c0c0;
    --g3: #777777;
    --g4: #444444;
    --stone: #9a8f84;
    --serif: "Cormorant Garamond", Georgia, serif;
    --sans: "DM Sans", system-ui, sans-serif;
    --max: 1320px;
    --pad: clamp(20px, 3vw, 48px);
}

* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    scroll-behavior: smooth;
}

body.resource-page {
    background: var(--cream);
    color: var(--black);
    font-family: var(--sans);
    font-size: 15px;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
}

a {
    color: inherit;
}

.inner {
    width: 100%;
    max-width: var(--max);
    margin: 0 auto;
    padding-left: var(--pad);
    padding-right: var(--pad);
}

.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.media-slot {
    position: absolute;
    inset: 0;
    background: var(--slot-bg, #9a9a9a);
    overflow: hidden;
}

.media-slot img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.media-slot.has-image {
    background: transparent;
}

.rc-hero {
    background: var(--dark);
    color: var(--cream);
    border-bottom: 1px solid rgba(244, 244, 242, 0.12);
}

.rc-hero-grid {
    min-height: calc(100vh - 64px);
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(360px, 0.72fr);
    gap: 56px;
    align-items: center;
    padding-top: 68px;
    padding-bottom: 54px;
}

.rc-eyebrow,
.rc-kicker,
.rc-card-type,
.rc-meta,
.rc-section-kicker,
.topic-stage-label,
.rc-stat-label {
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}

.rc-eyebrow,
.rc-kicker,
.rc-section-kicker,
.topic-stage-label {
    color: var(--stone);
}

.rc-hero h1,
.topic-hero h1 {
    max-width: 10.5ch;
    margin-top: 18px;
    font-family: var(--serif);
    font-size: 74px;
    font-weight: 300;
    line-height: 0.95;
}

.rc-hero h1 em,
.topic-hero h1 em {
    color: var(--stone);
    font-style: italic;
}

.rc-hero-copy {
    max-width: 760px;
}

.rc-hero-copy p,
.topic-hero-copy p {
    max-width: 64ch;
    margin-top: 24px;
    color: rgba(244, 244, 242, 0.62);
    font-size: 17px;
    font-weight: 300;
    line-height: 1.8;
}

.rc-hero-actions,
.rc-card-actions,
.rc-cta-actions,
.topic-stage-nav {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
}

.rc-hero-actions {
    margin-top: 32px;
}

.rc-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0 20px;
    border-radius: 999px;
    border: 1px solid transparent;
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.13em;
    text-transform: uppercase;
    text-decoration: none;
    white-space: nowrap;
    cursor: pointer;
}

.rc-button-dark {
    background: var(--black);
    color: var(--cream);
}

.rc-button-cream {
    background: var(--cream);
    color: var(--black);
}

.rc-button-stone {
    background: var(--stone);
    color: var(--white);
}

.rc-button-outline {
    border-color: rgba(20, 20, 20, 0.18);
    color: var(--black);
}

.rc-button-outline-light {
    border-color: rgba(244, 244, 242, 0.28);
    color: var(--cream);
}

.rc-hero-visual {
    position: relative;
    min-height: 560px;
    border-left: 1px solid rgba(244, 244, 242, 0.12);
    padding-left: 32px;
}

.rc-hero-feature {
    position: relative;
    min-height: 520px;
    overflow: hidden;
    background: #2f302e;
}

.rc-hero-feature::after,
.rc-image-card::after,
.topic-proof-media::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(20, 20, 20, 0.76), rgba(20, 20, 20, 0.1) 58%, transparent);
}

.rc-hero-feature-copy {
    position: absolute;
    left: 24px;
    right: 24px;
    bottom: 24px;
    z-index: 1;
}

.rc-feature-label {
    color: rgba(244, 244, 242, 0.72);
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    margin-bottom: 10px;
}

.rc-feature-title {
    max-width: 12ch;
    font-family: var(--serif);
    font-size: 44px;
    font-weight: 300;
    font-style: italic;
    line-height: 0.98;
}

.rc-hero-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1px;
    margin-top: 1px;
    background: rgba(244, 244, 242, 0.12);
}

.rc-stat {
    background: var(--dark);
    padding: 18px 16px;
}

.rc-stat-number {
    display: block;
    font-family: var(--serif);
    font-size: 32px;
    font-weight: 300;
    line-height: 1;
    color: var(--cream);
}

.rc-stat-label {
    display: block;
    margin-top: 8px;
    color: rgba(244, 244, 242, 0.36);
    line-height: 1.45;
}

.rc-filter-band {
    position: sticky;
    top: var(--nav-offset, 64px);
    z-index: 90;
    background: rgba(244, 244, 242, 0.96);
    border-bottom: 1px solid var(--g1);
    backdrop-filter: blur(12px);
}

body.nav-hidden .rc-filter-band {
    top: 0;
}

.rc-filter-inner {
    display: grid;
    grid-template-columns: minmax(260px, 1fr) auto;
    gap: 18px;
    align-items: center;
    padding-top: 16px;
    padding-bottom: 16px;
}

.rc-search {
    width: 100%;
    min-height: 46px;
    border: 1px solid var(--g1);
    border-radius: 999px;
    background: var(--white);
    color: var(--black);
    padding: 0 18px;
    font: inherit;
    font-weight: 300;
    outline: none;
}

.rc-search:focus {
    border-color: rgba(20, 20, 20, 0.35);
}

.rc-filter-controls {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 8px;
}

.rc-select,
.rc-reset {
    min-height: 42px;
    border-radius: 999px;
    border: 1px solid var(--g1);
    background: var(--white);
    color: var(--black);
    padding: 0 13px;
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.09em;
    text-transform: uppercase;
}

.rc-reset {
    cursor: pointer;
}

.rc-results-line {
    grid-column: 1 / -1;
    display: flex;
    justify-content: space-between;
    gap: 16px;
    color: var(--g3);
    font-size: 12px;
    font-weight: 300;
    line-height: 1.6;
}

.rc-section {
    padding: 72px 0;
}

.rc-section + .rc-section {
    border-top: 1px solid var(--g1);
}

.rc-section-head {
    display: grid;
    grid-template-columns: minmax(0, 0.7fr) minmax(0, 1fr);
    gap: 40px;
    align-items: end;
    margin-bottom: 32px;
}

.rc-section-title {
    max-width: 15ch;
    margin-top: 10px;
    font-family: var(--serif);
    font-size: 48px;
    font-weight: 300;
    line-height: 1;
}

.rc-section-copy {
    max-width: 58ch;
    color: var(--g3);
    font-size: 15px;
    font-weight: 300;
    line-height: 1.8;
}

.rc-feature-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(320px, 0.6fr);
    gap: 1px;
    background: var(--g1);
}

.rc-feature-main,
.rc-feature-side,
.rc-resource-card,
.rc-topic-card,
.rc-legacy-card,
.topic-stage-card,
.topic-faq details,
.topic-commerce-card {
    background: var(--white);
}

.rc-feature-main {
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(0, 1fr);
    min-height: 420px;
}

.rc-feature-media,
.topic-pillar-media,
.topic-proof-media,
.topic-commerce-media {
    position: relative;
    min-height: 100%;
    overflow: hidden;
    background: #8f8a84;
}

.rc-feature-content {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 36px;
}

.rc-card-type {
    color: var(--stone);
}

.rc-card-title {
    margin-top: 12px;
    font-size: 25px;
    font-weight: 400;
    line-height: 1.12;
}

.rc-feature-main .rc-card-title {
    max-width: 16ch;
    font-family: var(--serif);
    font-size: 42px;
    font-weight: 300;
    line-height: 1;
}

.rc-card-copy {
    margin-top: 14px;
    color: var(--g3);
    font-size: 14px;
    font-weight: 300;
    line-height: 1.8;
}

.rc-card-meta-row,
.rc-thread-meta,
.topic-proof-facts {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 18px;
}

.rc-meta-pill {
    display: inline-flex;
    align-items: center;
    min-height: 26px;
    padding: 0 10px;
    border-radius: 999px;
    border: 1px solid var(--g1);
    color: var(--g4);
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.rc-card-actions {
    margin-top: 24px;
}

.rc-feature-side {
    display: grid;
    gap: 1px;
    background: var(--g1);
}

.rc-mini-card {
    background: var(--white);
    padding: 28px;
}

.rc-topic-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1px;
    background: var(--g1);
}

.rc-topic-card {
    min-height: 260px;
    padding: 28px;
    text-decoration: none;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    transition:
        background-color 0.2s ease,
        color 0.2s ease;
}

.rc-topic-card:hover {
    background: var(--black);
    color: var(--cream);
}

.rc-topic-card:hover .rc-card-copy,
.rc-topic-card:hover .rc-topic-stat {
    color: rgba(244, 244, 242, 0.56);
}

.rc-topic-number {
    color: var(--stone);
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.rc-topic-stat {
    margin-top: 16px;
    color: var(--g3);
    font-size: 12px;
    font-weight: 300;
    line-height: 1.6;
}

.rc-resource-grid,
.topic-resource-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1px;
    background: var(--g1);
}

.rc-resource-card,
.topic-stage-card {
    min-height: 320px;
    padding: 28px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.rc-resource-card[hidden],
.topic-stage-card[hidden],
.rc-feature-main[hidden],
.rc-mini-card[hidden] {
    display: none;
}

.rc-resource-link {
    display: inline-flex;
    width: fit-content;
    margin-top: 22px;
    color: var(--black);
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.13em;
    text-transform: uppercase;
    text-decoration: none;
    border-bottom: 1px solid rgba(20, 20, 20, 0.3);
    padding-bottom: 3px;
}

.rc-empty {
    display: none;
    padding: 40px;
    background: var(--white);
    border: 1px solid var(--g1);
    text-align: center;
}

.rc-empty.is-visible {
    display: block;
}

.rc-empty h3 {
    font-family: var(--serif);
    font-size: 34px;
    font-weight: 300;
    margin-bottom: 10px;
}

.rc-empty p {
    color: var(--g3);
    font-weight: 300;
    line-height: 1.7;
}

.rc-thread {
    background: #ededeb;
}

.rc-legacy-grid {
    display: grid;
    grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
    gap: 1px;
    background: var(--g1);
}

.rc-legacy-intro {
    background: var(--black);
    color: var(--cream);
    padding: 36px;
}

.rc-legacy-intro h2 {
    max-width: 13ch;
    margin-top: 12px;
    font-family: var(--serif);
    font-size: 46px;
    font-weight: 300;
    line-height: 1;
}

.rc-legacy-intro p {
    margin-top: 18px;
    color: rgba(244, 244, 242, 0.56);
    font-weight: 300;
    line-height: 1.8;
}

.rc-legacy-list {
    display: grid;
    gap: 1px;
    background: var(--g1);
}

.rc-legacy-card {
    padding: 28px;
}

.rc-cta {
    background: var(--black);
    color: var(--cream);
    padding: 76px 0;
}

.rc-cta-grid {
    display: grid;
    grid-template-columns: minmax(0, 0.8fr) minmax(0, 1fr);
    gap: 52px;
    align-items: end;
}

.rc-cta h2 {
    font-family: var(--serif);
    font-size: 56px;
    font-weight: 300;
    line-height: 1;
}

.rc-cta p {
    color: rgba(244, 244, 242, 0.56);
    font-size: 16px;
    font-weight: 300;
    line-height: 1.8;
}

.rc-cta-actions {
    margin-top: 24px;
}

.topic-breadcrumb {
    background: var(--cream);
    border-bottom: 1px solid var(--g1);
}

.topic-breadcrumb-inner {
    min-height: 54px;
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--g3);
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.topic-breadcrumb a {
    text-decoration: none;
    color: var(--black);
}

.topic-hero {
    background: var(--dark);
    color: var(--cream);
}

.topic-hero-grid {
    min-height: 560px;
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(340px, 0.7fr);
    gap: 54px;
    align-items: stretch;
    padding-top: 62px;
    padding-bottom: 62px;
}

.topic-hero-copy {
    align-self: center;
}

.topic-hero h1 {
    max-width: 12ch;
}

.topic-hero-panel {
    display: grid;
    align-content: end;
    background: rgba(244, 244, 242, 0.04);
    border: 1px solid rgba(244, 244, 242, 0.12);
    padding: 28px;
}

.topic-panel-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1px;
    background: rgba(244, 244, 242, 0.12);
}

.topic-panel-cell {
    min-height: 140px;
    background: var(--dark);
    padding: 18px;
}

.topic-panel-cell strong {
    display: block;
    font-size: 22px;
    font-weight: 400;
    color: var(--cream);
}

.topic-panel-cell span {
    display: block;
    margin-top: 8px;
    color: rgba(244, 244, 242, 0.42);
    font-size: 12px;
    line-height: 1.5;
}

.topic-stage-nav {
    margin-top: 28px;
}

.topic-stage-nav a {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 0 12px;
    border: 1px solid rgba(244, 244, 242, 0.2);
    border-radius: 999px;
    color: var(--cream);
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    text-decoration: none;
}

.topic-pillar {
    display: grid;
    grid-template-columns: minmax(0, 0.72fr) minmax(0, 1fr);
    min-height: 460px;
    background: var(--white);
    border: 1px solid var(--g1);
}

.topic-pillar-content {
    padding: 38px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.topic-pillar h2 {
    max-width: 14ch;
    margin-top: 12px;
    font-family: var(--serif);
    font-size: 48px;
    font-weight: 300;
    line-height: 1;
}

.topic-pillar p {
    margin-top: 18px;
    color: var(--g3);
    font-weight: 300;
    line-height: 1.8;
}

.topic-section-anchor {
    scroll-margin-top: 150px;
}

.topic-stage-head {
    padding: 26px 0 18px;
    border-top: 1px solid var(--g1);
}

.topic-stage-head h3 {
    font-family: var(--serif);
    font-size: 38px;
    font-weight: 300;
    line-height: 1;
}

.topic-commerce-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1px;
    background: var(--g1);
}

.topic-commerce-card {
    text-decoration: none;
    min-height: 390px;
    display: grid;
    grid-template-rows: 220px 1fr;
}

.topic-commerce-media {
    min-height: 220px;
}

.topic-commerce-body {
    padding: 24px;
}

.topic-commerce-body h3 {
    font-size: 22px;
    font-weight: 400;
    line-height: 1.16;
}

.topic-commerce-body p {
    margin-top: 10px;
    color: var(--g3);
    font-size: 14px;
    font-weight: 300;
    line-height: 1.75;
}

.topic-proof {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 0.9fr);
    min-height: 520px;
    background: var(--black);
    color: var(--cream);
}

.topic-proof-copy {
    padding: 44px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.topic-proof-copy h2 {
    max-width: 13ch;
    font-family: var(--serif);
    font-size: 50px;
    font-weight: 300;
    line-height: 1;
}

.topic-proof-copy p {
    margin-top: 18px;
    color: rgba(244, 244, 242, 0.56);
    font-weight: 300;
    line-height: 1.8;
}

.topic-proof-facts .rc-meta-pill {
    border-color: rgba(244, 244, 242, 0.18);
    color: rgba(244, 244, 242, 0.72);
}

.topic-faq {
    display: grid;
    gap: 1px;
    background: var(--g1);
}

.topic-faq details {
    padding: 24px 28px;
}

.topic-faq summary {
    cursor: pointer;
    font-size: 17px;
    font-weight: 400;
    line-height: 1.35;
}

.topic-faq p {
    margin-top: 14px;
    color: var(--g3);
    font-weight: 300;
    line-height: 1.8;
}

.guide-hero {
    background: var(--dark);
    color: var(--cream);
    border-bottom: 1px solid rgba(244, 244, 242, 0.12);
}

.guide-hero-grid {
    min-height: 650px;
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(360px, 0.76fr);
    gap: 58px;
    align-items: center;
    padding-top: 68px;
    padding-bottom: 64px;
}

.guide-hero h1 {
    max-width: 12ch;
    margin-top: 18px;
    font-family: var(--serif);
    font-size: 70px;
    font-weight: 300;
    line-height: 0.96;
}

.guide-hero-copy p {
    max-width: 66ch;
    margin-top: 24px;
    color: rgba(244, 244, 242, 0.62);
    font-size: 17px;
    font-weight: 300;
    line-height: 1.8;
}

.guide-meta-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 24px;
}

.guide-hero .rc-meta-pill {
    border-color: rgba(244, 244, 242, 0.2);
    color: rgba(244, 244, 242, 0.76);
}

.guide-hero-media {
    position: relative;
    min-height: 540px;
    overflow: hidden;
    background: #2f302e;
}

.guide-hero-media::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(20, 20, 20, 0.72), rgba(20, 20, 20, 0.06) 62%, transparent);
}

.guide-hero-card {
    position: absolute;
    left: 24px;
    right: 24px;
    bottom: 24px;
    z-index: 1;
    padding: 22px;
    background: rgba(20, 20, 20, 0.72);
    border: 1px solid rgba(244, 244, 242, 0.16);
    backdrop-filter: blur(12px);
}

.guide-hero-card-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1px;
    margin-top: 14px;
    background: rgba(244, 244, 242, 0.12);
}

.guide-hero-card-grid span {
    min-height: 58px;
    display: flex;
    align-items: center;
    padding: 14px;
    background: rgba(20, 20, 20, 0.82);
    color: rgba(244, 244, 242, 0.78);
    font-size: 12px;
    font-weight: 300;
    line-height: 1.45;
}

.guide-shell {
    padding: 72px 0;
}

.guide-layout {
    display: grid;
    grid-template-columns: minmax(220px, 280px) minmax(0, 1fr);
    gap: 40px;
    align-items: start;
}

.guide-layout > * {
    min-width: 0;
}

.guide-toc {
    position: sticky;
    top: calc(var(--nav-offset, 64px) + 32px);
    min-width: 0;
}

body.nav-hidden .guide-toc {
    top: 32px;
}

.guide-toc-card {
    background: var(--white);
    border: 1px solid var(--g1);
    padding: 24px;
    min-width: 0;
}

.guide-toc nav {
    display: grid;
    gap: 1px;
    margin: 18px 0 24px;
    background: var(--g1);
}

.guide-toc nav a {
    display: block;
    background: var(--white);
    color: var(--black);
    padding: 12px 0;
    font-size: 12px;
    font-weight: 400;
    line-height: 1.4;
    text-decoration: none;
}

.guide-toc nav a:hover {
    color: var(--stone);
}

.guide-article {
    max-width: 920px;
    background: var(--white);
    border: 1px solid var(--g1);
    min-width: 0;
}

.guide-intro,
.guide-section {
    padding: 48px;
}

.guide-section {
    border-top: 1px solid var(--g1);
    scroll-margin-top: 130px;
}

.guide-intro h2,
.guide-section h2,
.guide-module h2,
.guide-image-band h2 {
    max-width: 15ch;
    margin-top: 12px;
    font-family: var(--serif);
    font-size: 48px;
    font-weight: 300;
    line-height: 1;
}

.guide-section h2 {
    max-width: 17ch;
}

.guide-intro p,
.guide-section p {
    margin-top: 18px;
    color: var(--g3);
    font-size: 16px;
    font-weight: 300;
    line-height: 1.85;
}

.guide-lede {
    color: var(--g4) !important;
    font-size: 19px !important;
    line-height: 1.75 !important;
}

.guide-keyline-grid,
.guide-decision-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1px;
    margin-top: 34px;
    background: var(--g1);
}

.guide-keyline-grid > div,
.guide-decision-card {
    background: #f8f8f6;
    padding: 24px;
}

.guide-keyline-number {
    display: block;
    color: var(--stone);
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    margin-bottom: 18px;
}

.guide-keyline-grid strong {
    display: block;
    font-size: 18px;
    font-weight: 400;
    line-height: 1.25;
}

.guide-keyline-grid p,
.guide-decision-card p {
    margin-top: 10px;
    color: var(--g3);
    font-size: 13px;
    font-weight: 300;
    line-height: 1.7;
}

.guide-module {
    display: grid;
    grid-template-columns: minmax(0, 0.75fr) minmax(0, 1fr);
    gap: 32px;
    align-items: start;
    padding: 38px 48px;
    border-top: 1px solid var(--g1);
}

.guide-checklist {
    background: var(--black);
    color: var(--cream);
}

.guide-checklist h2 {
    color: var(--cream);
}

.guide-module ul {
    list-style: none;
    display: grid;
    gap: 12px;
}

.guide-module li {
    position: relative;
    padding-left: 22px;
    color: rgba(244, 244, 242, 0.62);
    font-weight: 300;
    line-height: 1.7;
}

.guide-module li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.72em;
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--stone);
}

.guide-split-module {
    margin-top: 28px;
    padding: 28px;
    border: 1px solid var(--g1);
    background: #f8f8f6;
}

.guide-split-module h3 {
    max-width: 12ch;
    margin-top: 10px;
    font-family: var(--serif);
    font-size: 34px;
    font-weight: 300;
    line-height: 1;
}

.guide-split-module li {
    color: var(--g3);
}

.guide-callout {
    margin-top: 28px;
    padding: 28px;
    background: #f8f8f6;
    border-left: 3px solid var(--stone);
}

.guide-callout p {
    margin-top: 10px;
    color: var(--black);
    font-family: var(--serif);
    font-size: 28px;
    font-style: italic;
    line-height: 1.18;
}

.guide-table-wrap {
    width: 100%;
    max-width: 100%;
    overflow-x: auto;
    margin-top: 30px;
    border: 1px solid var(--g1);
}

.guide-table {
    width: 100%;
    min-width: 720px;
    border-collapse: collapse;
    background: var(--white);
}

.guide-table th,
.guide-table td {
    padding: 18px;
    border-bottom: 1px solid var(--g1);
    border-right: 1px solid var(--g1);
    text-align: left;
    vertical-align: top;
}

.guide-table th {
    color: var(--stone);
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.guide-table td {
    color: var(--g3);
    font-size: 13px;
    font-weight: 300;
    line-height: 1.7;
}

.guide-table td:first-child {
    color: var(--black);
    font-weight: 400;
}

.guide-quote {
    margin: 32px 0;
    padding: 34px;
    background: var(--black);
    color: var(--cream);
}

.guide-quote p {
    margin: 0;
    max-width: 17ch;
    color: var(--cream);
    font-family: var(--serif);
    font-size: 38px;
    font-weight: 300;
    font-style: italic;
    line-height: 1.06;
}

.guide-image-band {
    position: relative;
    min-height: 430px;
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(0, 1fr);
    align-items: end;
    gap: 1px;
    border-top: 1px solid var(--g1);
    background: var(--black);
    color: var(--cream);
    overflow: hidden;
}

.guide-image-band > .media-slot {
    position: relative;
    min-height: 430px;
}

.guide-image-band > div {
    padding: 40px;
}

.guide-image-band p {
    margin-top: 16px;
    color: rgba(244, 244, 242, 0.58);
    font-weight: 300;
    line-height: 1.8;
}

.guide-related-card {
    color: var(--black);
    text-decoration: none;
}

.guide-faq {
    margin-top: 26px;
}

.resource-detail-hero {
    background: var(--dark);
    color: var(--cream);
    border-bottom: 1px solid rgba(244, 244, 242, 0.12);
}

.detail-hero-grid {
    min-height: 610px;
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(360px, 0.72fr);
    gap: 56px;
    align-items: center;
    padding-top: 64px;
    padding-bottom: 60px;
}

.detail-hero-copy h1 {
    max-width: 12ch;
    margin-top: 18px;
    font-family: var(--serif);
    font-size: 68px;
    font-weight: 300;
    line-height: 0.96;
}

.detail-hero-copy p {
    max-width: 66ch;
    margin-top: 22px;
    color: rgba(244, 244, 242, 0.62);
    font-size: 17px;
    font-weight: 300;
    line-height: 1.8;
}

.detail-meta-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 24px;
}

.resource-detail-hero .rc-meta-pill {
    border-color: rgba(244, 244, 242, 0.2);
    color: rgba(244, 244, 242, 0.76);
}

.detail-hero-media {
    position: relative;
    min-height: 500px;
    overflow: hidden;
    background: #2f302e;
}

.detail-hero-media::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(20, 20, 20, 0.76), rgba(20, 20, 20, 0.08) 62%, transparent);
}

.detail-hero-card {
    position: absolute;
    left: 24px;
    right: 24px;
    bottom: 24px;
    z-index: 1;
    padding: 22px;
    background: rgba(20, 20, 20, 0.76);
    border: 1px solid rgba(244, 244, 242, 0.16);
    backdrop-filter: blur(12px);
}

.detail-hero-card strong {
    display: block;
    margin-top: 10px;
    font-family: var(--serif);
    font-size: 30px;
    font-weight: 300;
    line-height: 1.05;
}

.detail-shell {
    padding: 72px 0;
}

.detail-layout {
    display: grid;
    grid-template-columns: minmax(220px, 280px) minmax(0, 1fr);
    gap: 40px;
    align-items: start;
}

.detail-layout > * {
    min-width: 0;
}

.detail-sidebar {
    position: sticky;
    top: calc(var(--nav-offset, 64px) + 32px);
    min-width: 0;
}

body.nav-hidden .detail-sidebar {
    top: 32px;
}

.detail-panel,
.detail-main,
.detail-section,
.detail-related-card,
.template-example-card {
    background: var(--white);
}

.detail-panel {
    border: 1px solid var(--g1);
    padding: 24px;
}

.detail-panel + .detail-panel {
    margin-top: 16px;
}

.detail-panel p,
.detail-panel li {
    color: var(--g3);
    font-size: 13px;
    font-weight: 300;
    line-height: 1.7;
}

.detail-panel ul {
    list-style: none;
    display: grid;
    gap: 10px;
    margin-top: 16px;
}

.detail-panel li {
    padding-bottom: 10px;
    border-bottom: 1px solid var(--g1);
}

.detail-main {
    border: 1px solid var(--g1);
    min-width: 0;
}

.detail-section {
    padding: 46px 48px;
}

.detail-section + .detail-section {
    border-top: 1px solid var(--g1);
}

.detail-section h2 {
    max-width: 16ch;
    margin-top: 12px;
    font-family: var(--serif);
    font-size: 46px;
    font-weight: 300;
    line-height: 1;
}

.detail-section h3 {
    margin-top: 22px;
    font-size: 24px;
    font-weight: 400;
    line-height: 1.16;
}

.detail-section p {
    margin-top: 16px;
    color: var(--g3);
    font-size: 16px;
    font-weight: 300;
    line-height: 1.85;
}

.detail-lede {
    color: var(--g4) !important;
    font-size: 19px !important;
    line-height: 1.75 !important;
}

.detail-card-grid,
.detail-stat-grid,
.template-example-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1px;
    background: var(--g1);
}

.detail-card,
.detail-stat,
.template-example-card {
    background: #f8f8f6;
    padding: 24px;
}

.detail-card h3,
.template-example-card h3 {
    margin-top: 12px;
    font-size: 22px;
    font-weight: 400;
    line-height: 1.14;
}

.detail-card p,
.template-example-card p {
    margin-top: 10px;
    color: var(--g3);
    font-size: 13px;
    font-weight: 300;
    line-height: 1.7;
}

.detail-stat strong {
    display: block;
    font-family: var(--serif);
    font-size: 42px;
    font-weight: 300;
    line-height: 1;
}

.detail-stat span {
    display: block;
    margin-top: 8px;
    color: var(--g3);
    font-size: 12px;
    font-weight: 300;
    line-height: 1.55;
}

.detail-steps {
    display: grid;
    gap: 1px;
    margin-top: 30px;
    background: var(--g1);
}

.detail-step {
    display: grid;
    grid-template-columns: 92px minmax(0, 1fr);
    gap: 24px;
    background: #f8f8f6;
    padding: 24px;
}

.detail-step-number {
    color: var(--stone);
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}

.detail-step h3 {
    margin-top: 0;
}

.detail-step p {
    margin-top: 8px;
    font-size: 14px;
}

.detail-table-wrap {
    width: 100%;
    max-width: 100%;
    overflow-x: auto;
    margin-top: 30px;
    border: 1px solid var(--g1);
}

.detail-table {
    width: 100%;
    min-width: 720px;
    border-collapse: collapse;
    background: var(--white);
}

.detail-table th,
.detail-table td {
    padding: 18px;
    border-bottom: 1px solid var(--g1);
    border-right: 1px solid var(--g1);
    text-align: left;
    vertical-align: top;
}

.detail-table th {
    color: var(--stone);
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.detail-table td {
    color: var(--g3);
    font-size: 13px;
    font-weight: 300;
    line-height: 1.7;
}

.detail-table td:first-child {
    color: var(--black);
    font-weight: 400;
}

.checklist-group {
    border-top: 1px solid var(--g1);
    padding-top: 30px;
    margin-top: 30px;
}

.checklist-group h3 {
    margin-top: 0;
    font-family: var(--serif);
    font-size: 34px;
    font-weight: 300;
    line-height: 1;
}

.checklist-items {
    display: grid;
    gap: 1px;
    margin-top: 20px;
    background: var(--g1);
}

.checklist-item {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) minmax(110px, 0.24fr);
    gap: 16px;
    align-items: start;
    background: #f8f8f6;
    padding: 18px;
}

.checklist-item input {
    width: 18px;
    height: 18px;
    margin-top: 2px;
    accent-color: var(--stone);
}

.checklist-item strong {
    display: block;
    font-size: 15px;
    font-weight: 400;
    line-height: 1.35;
}

.checklist-item span {
    color: var(--g3);
    font-size: 12px;
    font-weight: 300;
    line-height: 1.6;
}

.checklist-status {
    justify-self: end;
    color: var(--stone) !important;
    font-size: 10px !important;
    font-weight: 500 !important;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.detail-quote {
    margin-top: 30px;
    padding: 34px;
    background: var(--black);
    color: var(--cream);
}

.detail-quote p {
    margin: 0;
    max-width: 19ch;
    color: var(--cream);
    font-family: var(--serif);
    font-size: 38px;
    font-weight: 300;
    font-style: italic;
    line-height: 1.06;
}

.case-story-grid {
    display: grid;
    grid-template-columns: minmax(0, 0.8fr) minmax(0, 1fr);
    gap: 1px;
    background: var(--g1);
}

.case-story-panel {
    background: #f8f8f6;
    padding: 28px;
}

.case-story-panel h3 {
    margin-top: 12px;
}

.case-story-panel p {
    font-size: 14px;
}

.template-example-card {
    min-height: 270px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    color: var(--black);
    text-decoration: none;
    transition:
        background-color 0.2s ease,
        color 0.2s ease;
}

.template-example-card:hover {
    background: var(--black);
    color: var(--cream);
}

.template-example-card:hover p,
.template-example-card:hover .rc-topic-stat {
    color: rgba(244, 244, 242, 0.56);
}

.template-example-card .rc-resource-link {
    margin-top: 22px;
}

.footer {
    background: #111111;
}

.footer-inner {
    padding: 52px 0 44px;
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 44px;
    border-bottom: 1px solid #222222;
    margin-bottom: 24px;
}

.ft-logo {
    display: inline-flex;
    align-items: center;
    margin-bottom: 18px;
}

.ft-logo img {
    display: block;
    height: 34px;
    width: auto;
}

.ft-tag {
    font-family: var(--serif);
    font-size: 16px;
    font-weight: 300;
    font-style: italic;
    color: #555555;
    line-height: 1.6;
    max-width: 220px;
    margin-bottom: 20px;
}

.footer-newsletter-title,
.ft-col-h {
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--stone);
    margin-bottom: 14px;
}

.footer-newsletter-copy {
    font-size: 13px;
    font-weight: 300;
    line-height: 1.65;
    color: #666666;
    max-width: 260px;
    margin-bottom: 14px;
}

.footer-newsletter-form {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    align-items: center;
    max-width: 320px;
}

.footer-newsletter-input {
    width: 100%;
    min-height: 44px;
    padding: 0 14px;
    border: 1px solid #2b2b2b;
    background: #151515;
    color: var(--cream);
    border-radius: 999px;
    font-size: 13px;
    font-weight: 300;
    outline: none;
}

.footer-newsletter-input::placeholder {
    color: #5f5f5f;
}

.footer-newsletter-btn {
    min-height: 44px;
    padding: 0 16px;
    border: 0;
    border-radius: 999px;
    background: var(--cream);
    color: var(--black);
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    cursor: pointer;
}

.ft-links {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.ft-links a {
    font-size: 13px;
    font-weight: 300;
    color: #555555;
    text-decoration: none;
}

.ft-links a:hover {
    color: var(--cream);
}

.ft-bot {
    display: flex;
    justify-content: space-between;
    font-size: 11px;
    font-weight: 300;
    color: #2a2a2a;
    padding-bottom: 24px;
}

@media (max-width: 1080px) {
    .rc-hero-grid,
    .topic-hero-grid,
    .guide-hero-grid,
    .rc-section-head,
    .rc-feature-grid,
    .rc-feature-main,
    .rc-legacy-grid,
    .rc-cta-grid,
    .topic-pillar,
    .topic-proof,
    .guide-layout,
    .guide-module,
    .guide-image-band,
    .detail-hero-grid,
    .detail-layout,
    .case-story-grid {
        grid-template-columns: 1fr;
    }

    .rc-hero-grid,
    .guide-hero-grid,
    .detail-hero-grid {
        min-height: auto;
    }

    .rc-hero-visual {
        min-height: auto;
        border-left: 0;
        padding-left: 0;
    }

    .rc-feature-media,
    .topic-pillar-media,
    .topic-proof-media,
    .guide-hero-media,
    .guide-image-band > .media-slot,
    .detail-hero-media {
        min-height: 360px;
    }

    .rc-topic-grid,
    .rc-resource-grid,
    .topic-resource-grid,
    .topic-commerce-grid,
    .detail-card-grid,
    .detail-stat-grid,
    .template-example-grid,
    .footer-inner {
        grid-template-columns: 1fr 1fr;
    }

    .guide-toc,
    .detail-sidebar {
        position: static;
    }

    .guide-article {
        max-width: none;
    }
}

@media (max-width: 760px) {
    .rc-hero h1,
    .topic-hero h1,
    .guide-hero h1,
    .detail-hero-copy h1 {
        font-size: 52px;
    }

    .rc-section-title,
    .topic-pillar h2,
    .topic-proof-copy h2,
    .rc-legacy-intro h2,
    .rc-cta h2,
    .guide-intro h2,
    .guide-section h2,
    .guide-module h2,
    .guide-image-band h2,
    .detail-section h2 {
        font-size: 38px;
    }

    .rc-filter-inner,
    .rc-topic-grid,
    .rc-resource-grid,
    .topic-resource-grid,
    .topic-commerce-grid,
    .guide-keyline-grid,
    .guide-decision-grid,
    .guide-hero-card-grid,
    .detail-card-grid,
    .detail-stat-grid,
    .template-example-grid,
    .detail-step,
    .checklist-item,
    .footer-inner {
        grid-template-columns: 1fr;
    }

    .rc-filter-controls {
        justify-content: flex-start;
    }

    .rc-select,
    .rc-reset,
    .rc-button,
    .footer-newsletter-btn {
        width: 100%;
    }

    .rc-results-line,
    .ft-bot,
    .footer-newsletter-form {
        display: flex;
        flex-direction: column;
        align-items: stretch;
    }

    .rc-hero-stats,
    .topic-panel-grid {
        grid-template-columns: 1fr;
    }

    .guide-shell {
        padding: 44px 0;
    }

    .guide-hero-grid {
        gap: 34px;
        padding-top: 48px;
        padding-bottom: 48px;
    }

    .guide-hero-media {
        min-height: 460px;
    }

    .guide-hero-card {
        left: 16px;
        right: 16px;
        bottom: 16px;
        padding: 18px;
    }

    .guide-intro,
    .guide-section,
    .guide-module,
    .guide-image-band > div {
        padding: 28px;
    }

    .guide-callout p,
    .guide-quote p {
        font-size: 30px;
    }

    .guide-split-module {
        padding: 24px;
    }

    .detail-shell {
        padding: 44px 0;
    }

    .detail-hero-grid {
        gap: 34px;
        padding-top: 48px;
        padding-bottom: 48px;
    }

    .detail-hero-media {
        min-height: 430px;
    }

    .detail-hero-card {
        left: 16px;
        right: 16px;
        bottom: 16px;
        padding: 18px;
    }

    .detail-section,
    .detail-panel {
        padding: 28px;
    }

    .detail-quote p {
        font-size: 30px;
    }

    .checklist-status {
        justify-self: start;
    }
}
