:root {
    --kw-body-font: "Roboto", Arial, sans-serif;
    --kw-display-font: "Nimbus Sans", "Nimbus Sans L", "Arial Narrow", "Helvetica Neue", Arial, sans-serif;
    --bg: #f3eee7;
    --surface: #fffdf9;
    --surface-strong: #ffffff;
    --surface-soft: #f7f2ea;
    --ink: #20262c;
    --muted: #606972;
    --muted-strong: #4a535d;
    --line: rgba(30, 38, 44, 0.1);
    --line-strong: rgba(30, 38, 44, 0.18);
    --accent: #b40101;
    --accent-dark: #7d0000;
    --accent-soft: #f6e0dc;
    --platinum: #9ba5ad;
    --platinum-dark: #57616a;
    --gold: #ad8b57;
    --shadow-lg: 0 28px 80px rgba(18, 24, 28, 0.1);
    --shadow-md: 0 20px 44px rgba(18, 24, 28, 0.08);
    --radius-xl: 34px;
    --radius-lg: 26px;
    --radius-md: 20px;
    --radius-sm: 14px;
    --max-width: 1480px;
    --rail-width: 286px;
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
    background:
        radial-gradient(circle at top left, rgba(180, 1, 1, 0.08), transparent 30%),
        radial-gradient(circle at top right, rgba(155, 165, 173, 0.2), transparent 32%),
        linear-gradient(180deg, #f5f1ea 0%, #efe8de 100%);
}

body {
    margin: 0;
    color: var(--ink);
    font-family: var(--kw-body-font);
    background: transparent;
}

img {
    max-width: 100%;
    display: block;
}

a {
    color: inherit;
}

button,
input,
textarea,
select {
    font: inherit;
}

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

.skip-link {
    position: absolute;
    left: 16px;
    top: -48px;
    z-index: 100;
    padding: 12px 16px;
    border-radius: 999px;
    background: var(--ink);
    color: #ffffff;
    text-decoration: none;
    transition: top 0.2s ease;
}

.skip-link:focus {
    top: 16px;
}

.roadmap-body {
    min-height: 100vh;
}

.roadmap-page {
    padding-bottom: 56px;
}

.topbar {
    position: sticky;
    top: 0;
    z-index: 50;
    padding: 14px 18px;
    backdrop-filter: blur(14px);
    background: rgba(243, 238, 231, 0.82);
    border-bottom: 1px solid rgba(30, 38, 44, 0.08);
}

.topbar__inner {
    max-width: var(--max-width);
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
}

.brand-lockup {
    display: flex;
    align-items: center;
    gap: 18px;
    min-width: 0;
}

.brand-lockup__logos {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.brand-lockup__logos img {
    height: 28px;
    width: auto;
    object-fit: contain;
}

.brand-lockup__text {
    min-width: 0;
}

.brand-lockup__eyebrow {
    margin: 0 0 2px;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--accent);
}

.brand-lockup__title {
    margin: 0;
    font-size: 0.96rem;
    font-weight: 700;
    color: var(--ink);
}

.brand-lockup__sub {
    margin: 4px 0 0;
    font-size: 0.8rem;
    color: var(--muted);
}

.topbar__actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 44px;
    padding: 0 18px;
    border-radius: 999px;
    border: 1px solid transparent;
    text-decoration: none;
    font-size: 0.92rem;
    font-weight: 700;
    position: relative;
    overflow: hidden;
    isolation: isolate;
    transition:
        transform 0.2s ease,
        box-shadow 0.2s ease,
        background 0.2s ease,
        border-color 0.2s ease;
}

.button:hover,
.button:focus-visible {
    transform: translateY(-1px);
}

.button:focus-visible {
    outline: 3px solid rgba(180, 1, 1, 0.18);
    outline-offset: 2px;
}

.button--primary {
    color: #ffffff;
    border-color: rgba(255, 255, 255, 0.16);
    background: linear-gradient(180deg, rgba(200, 28, 28, 0.82) 0%, rgba(151, 0, 0, 0.74) 100%);
    box-shadow:
        inset 0 0 0 1px rgba(109, 0, 0, 0.18),
        0 14px 28px rgba(112, 0, 0, 0.18);
    backdrop-filter: blur(16px) saturate(155%);
    -webkit-backdrop-filter: blur(16px) saturate(155%);
}

.button--ghost {
    color: #ffffff;
    border-color: rgba(255, 255, 255, 0.16);
    background: linear-gradient(180deg, rgba(214, 54, 54, 0.78) 0%, rgba(167, 6, 6, 0.7) 100%);
    box-shadow:
        inset 0 0 0 1px rgba(109, 0, 0, 0.14),
        0 12px 24px rgba(112, 0, 0, 0.15);
    backdrop-filter: blur(16px) saturate(155%);
    -webkit-backdrop-filter: blur(16px) saturate(155%);
}

.button::before,
.deck-arrow::before,
.page-notes__close::before,
.mobile-sheet__head button::before,
.mobile-drawer__head button::before,
.micro-nav__button::before,
.mobile-scroll-indicator::before {
    content: none;
}

.button::after,
.deck-arrow::after,
.page-notes__close::after,
.mobile-sheet__head button::after,
.mobile-drawer__head button::after,
.micro-nav__button::after,
.mobile-scroll-indicator::after {
    content: none;
}

.button > * {
    position: relative;
    z-index: 1;
}

.roadmap-shell {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 24px 20px 40px;
    display: grid;
    grid-template-columns: minmax(0, var(--rail-width)) minmax(0, 1fr);
    gap: 24px;
    align-items: start;
}

.roadmap-rail {
    position: sticky;
    top: 96px;
    align-self: start;
    display: grid;
    gap: 18px;
    height: var(--deck-height);
    min-height: 0;
}

.rail-card {
    padding: 22px 18px;
    border: 1px solid rgba(30, 38, 44, 0.08);
    border-radius: 28px;
    background: rgba(255, 255, 255, 0.8);
    box-shadow: var(--shadow-md);
}

.rail-card__label {
    margin: 0 0 10px;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--accent);
}

.rail-progress {
    display: grid;
    gap: 8px;
}

.rail-progress__count {
    margin: 0;
    font-size: 2rem;
    font-weight: 800;
    letter-spacing: -0.04em;
}

.rail-progress__title {
    margin: 0;
    font-size: 0.95rem;
    color: var(--muted);
}

.rail-card--outline {
    display: grid;
    grid-template-rows: auto minmax(0, 1fr) auto;
    min-height: 0;
    height: 100%;
    overflow: hidden;
}

.rail-card--outline .outline-list {
    min-height: 0;
    overflow: auto;
    padding-right: 8px;
    scrollbar-width: thin;
    scrollbar-color: rgba(180, 1, 1, 0.48) rgba(30, 38, 44, 0.08);
}

.rail-card--outline .outline-list::-webkit-scrollbar {
    width: 9px;
}

.rail-card--outline .outline-list::-webkit-scrollbar-track {
    background: rgba(30, 38, 44, 0.06);
    border-radius: 999px;
}

.rail-card--outline .outline-list::-webkit-scrollbar-thumb {
    background: linear-gradient(180deg, rgba(205, 34, 34, 0.72) 0%, rgba(151, 0, 0, 0.62) 100%);
    border-radius: 999px;
    border: 2px solid rgba(255, 255, 255, 0.72);
}

.rail-card__footer {
    padding-top: 14px;
    margin-top: 14px;
    border-top: 1px solid rgba(30, 38, 44, 0.08);
}

.rail-card__footer-button {
    width: 100%;
}

.outline-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 7px;
}

.outline-link {
    display: grid;
    grid-template-columns: 40px minmax(0, 1fr);
    gap: 12px;
    align-items: center;
    padding: 10px 12px;
    border-radius: 16px;
    text-decoration: none;
    color: var(--muted-strong);
    transition:
        background 0.2s ease,
        color 0.2s ease,
        transform 0.2s ease;
}

.outline-link:hover,
.outline-link:focus-visible {
    background: rgba(180, 1, 1, 0.08);
    color: var(--ink);
}

.outline-link:focus-visible {
    outline: 3px solid rgba(180, 1, 1, 0.14);
    outline-offset: 2px;
}

.outline-link.is-active {
    background: linear-gradient(135deg, rgba(180, 1, 1, 0.12), rgba(180, 1, 1, 0.04));
    color: var(--ink);
}

.outline-link__number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 999px;
    background: rgba(30, 38, 44, 0.06);
    font-size: 0.82rem;
    font-weight: 800;
    letter-spacing: 0.08em;
}

.outline-link.is-active .outline-link__number {
    color: #ffffff;
    background: linear-gradient(135deg, var(--accent) 0%, #d22f2f 100%);
}

.outline-link__title {
    font-size: 0.86rem;
    line-height: 1.25;
}

.mobile-outline {
    display: none;
    margin: 0 20px 20px;
    padding: 0;
    border: 0;
}

.mobile-only-action {
    display: none;
}

.mobile-outline__card {
    border: 1px solid rgba(30, 38, 44, 0.08);
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.82);
    box-shadow: var(--shadow-md);
    overflow: hidden;
}

.mobile-outline summary {
    list-style: none;
    cursor: pointer;
    padding: 18px 20px;
    font-weight: 800;
}

.mobile-outline summary::-webkit-details-marker {
    display: none;
}

.mobile-outline__body {
    padding: 0 14px 14px;
}

.roadmap-main {
    display: grid;
    gap: 28px;
}

.slide {
    scroll-margin-top: 92px;
}

.slide__surface {
    position: relative;
    overflow: hidden;
    min-height: clamp(720px, 92svh, 940px);
    padding: clamp(20px, 2.8vw, 38px);
    border-radius: var(--radius-xl);
    border: 1px solid rgba(30, 38, 44, 0.08);
    background:
        radial-gradient(circle at 112% 118%, rgba(180, 1, 1, 0.08), transparent 24%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.92) 0%, rgba(255, 255, 255, 0.98) 100%);
    box-shadow: var(--shadow-lg);
}

.slide__surface::before {
    content: none;
}

.slide__surface--image {
    color: #ffffff;
    background: #11181d;
}

.slide__surface--image::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 0;
    background-image: var(--slide-image);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    opacity: 0.96;
    pointer-events: none;
}

.slide__surface--image::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(135deg, rgba(13, 18, 22, 0.9), rgba(13, 18, 22, 0.5) 42%, rgba(13, 18, 22, 0.22) 100%),
        radial-gradient(circle at top right, rgba(180, 1, 1, 0.22), transparent 32%);
}

.slide__inner {
    --mobile-scale: 1;
    position: relative;
    z-index: 1;
    display: grid;
    align-content: start;
    grid-auto-rows: min-content;
    gap: 22px;
    width: calc(100% / var(--mobile-scale));
    transform: scale(var(--mobile-scale));
    transform-origin: top left;
}

.slide__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 20px;
}

.slide__meta {
    display: grid;
    gap: 10px;
}

.slide__index {
    margin: 0;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--accent);
}

.slide__surface--image .slide__index {
    color: #f1d4d4;
}

.slide__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    width: fit-content;
    padding: 8px 12px;
    border-radius: 999px;
    background: rgba(30, 38, 44, 0.06);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--muted-strong);
}

.slide__surface--image .slide__eyebrow {
    color: #ffffff;
    background: rgba(255, 255, 255, 0.1);
}

.slide__title {
    margin: 0;
    font-family: var(--kw-display-font);
    font-weight: 900;
    font-size: clamp(2.4rem, 4vw, 5.2rem);
    line-height: 0.94;
    letter-spacing: -0.05em;
    overflow-wrap: anywhere;
}

.slide__title--medium {
    font-size: clamp(2.1rem, 3.2vw, 4.2rem);
}

.slide__title--small {
    font-size: clamp(1.9rem, 2.8vw, 3.5rem);
}

.slide__lede {
    max-width: 840px;
    margin: 0;
    font-size: clamp(1.02rem, 1.4vw, 1.32rem);
    line-height: 1.6;
    color: var(--muted-strong);
}

.slide__surface--image .slide__lede {
    color: rgba(255, 255, 255, 0.88);
}

.slide__note {
    margin: 0;
    font-size: 0.82rem;
    line-height: 1.55;
    color: var(--muted);
}

.slide__surface--image .slide__note {
    color: rgba(255, 255, 255, 0.72);
}

.slide__takeaway {
    padding: 16px 18px;
    border-left: 4px solid var(--accent);
    border-radius: 0 18px 18px 0;
    background: rgba(255, 255, 255, 0.7);
    max-width: 760px;
}

.slide__takeaway strong {
    display: block;
    margin-bottom: 6px;
    font-size: 0.88rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.slide__takeaway p {
    margin: 0;
}

.loan-abbrev-copy {
    margin-top: 10px !important;
    color: var(--muted-strong);
    line-height: 1.55;
}

.loan-abbrev-term {
    font-weight: 800;
    color: var(--ink);
}

.slide__surface--image .slide__takeaway {
    background: rgba(255, 255, 255, 0.08);
    border-left-color: #ffffff;
}

.chip-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    border-radius: 999px;
    border: 1px solid rgba(30, 38, 44, 0.1);
    background: rgba(255, 255, 255, 0.78);
    font-size: 0.86rem;
    font-weight: 700;
    color: var(--muted-strong);
}

.slide__surface--image .chip {
    color: #ffffff;
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.16);
}

.stats-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}

.stat-card {
    padding: 18px;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.8);
    border: 1px solid rgba(30, 38, 44, 0.08);
    box-shadow: 0 10px 24px rgba(18, 24, 28, 0.06);
}

.slide__surface--image .stat-card {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.14);
}

.stat-card__value {
    display: block;
    margin-bottom: 8px;
    font-size: 1.5rem;
    font-weight: 800;
    letter-spacing: -0.04em;
}

.stat-card__label {
    margin: 0;
    font-size: 0.88rem;
    line-height: 1.5;
    color: inherit;
}

.glass-card,
.info-card,
.loan-card,
.state-card,
.contingency-card,
.timeline-node,
.week-card,
.contact-card,
.photo-callout {
    position: relative;
    overflow: hidden;
    padding: 22px;
    border-radius: 24px;
    border: 1px solid rgba(30, 38, 44, 0.08);
    background: rgba(255, 255, 255, 0.84);
    box-shadow: 0 14px 30px rgba(18, 24, 28, 0.06);
}

.glass-card {
    padding: 24px;
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.16);
    backdrop-filter: blur(14px);
}

.glass-card h3,
.info-card h3,
.loan-card h3,
.state-card h3,
.contingency-card h3,
.timeline-node h3,
.week-card h3,
.contact-card h3,
.photo-callout h3 {
    margin: 0 0 12px;
    font-size: 1.1rem;
}

.glass-card p,
.info-card p,
.loan-card p,
.state-card p,
.contingency-card p,
.timeline-node p,
.week-card p,
.contact-card p,
.photo-callout p {
    margin: 0;
    line-height: 1.6;
    color: inherit;
}

.info-card--dark {
    color: #ffffff;
    background: linear-gradient(135deg, #1f252b 0%, #36404a 100%);
    border-color: rgba(255, 255, 255, 0.08);
}

.info-card--soft {
    background: linear-gradient(135deg, #fff5f3 0%, #fbf5ed 100%);
}

.layout-cover {
    display: grid;
    grid-template-columns: minmax(0, 1.22fr) minmax(320px, 0.78fr);
    gap: 22px;
    align-items: end;
    flex: 1;
}

.layout-split {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
    gap: 20px;
    align-items: stretch;
}

.layout-split--top {
    align-items: start;
}

.layout-balanced {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 20px;
}

.layout-sidebar {
    display: grid;
    grid-template-columns: minmax(0, 1.24fr) minmax(300px, 0.76fr);
    gap: 20px;
}

.layout-sidebar--top {
    align-items: start;
}

.layout-stack {
    display: grid;
    gap: 16px;
}

.layout-stack--tight {
    gap: 12px;
}

.card-grid-2,
.card-grid-3,
.card-grid-4,
.loan-columns,
.bucket-grid,
.contingency-grid,
.action-plan,
.process-strip,
.timeline-track,
.risk-grid,
.payment-grid,
.self-check,
.state-grid {
    display: grid;
    gap: 14px;
}

.card-grid-2,
.self-check,
.risk-grid,
.state-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.card-grid-3,
.bucket-grid,
.contingency-grid,
.timeline-track {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.card-grid-4,
.loan-columns,
.action-plan,
.process-strip {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.loan-columns--two {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.loan-columns--three {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.payment-grid {
    grid-template-columns: repeat(6, minmax(0, 1fr));
}

.icon-title {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 12px;
}

.icon-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border-radius: 14px;
    color: var(--accent);
    background: rgba(180, 1, 1, 0.09);
    flex-shrink: 0;
}

.icon-badge svg {
    width: 22px;
    height: 22px;
}

.info-card--dark .icon-badge,
.glass-card .icon-badge,
.slide__surface--image .icon-badge {
    color: #ffffff;
    background: rgba(255, 255, 255, 0.12);
}

.kpi {
    display: grid;
    gap: 8px;
}

.kpi strong,
.metric strong,
.score-band,
.big-number {
    font-size: 1.48rem;
    font-weight: 800;
    letter-spacing: -0.04em;
}

.muted-label {
    display: inline-block;
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--muted);
}

.slide__surface--image .muted-label {
    color: rgba(255, 255, 255, 0.7);
}

.checklist,
.metric-list,
.stack-list,
.timeline-list,
.source-list,
.stock-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 12px;
}

.checklist li,
.stack-list li,
.stock-list li,
.source-list li {
    position: relative;
    padding-left: 22px;
    line-height: 1.55;
}

.checklist li::before,
.stack-list li::before,
.stock-list li::before,
.source-list li::before {
    content: "";
    position: absolute;
    top: 0.62em;
    left: 0;
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--accent) 0%, #d93838 100%);
    transform: translateY(-50%);
}

.metric {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 18px;
    padding-bottom: 12px;
    border-bottom: 1px solid rgba(30, 38, 44, 0.08);
}

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

.comparison-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 20px;
}

.comparison-card {
    padding: 26px;
    border-radius: 28px;
    border: 1px solid rgba(30, 38, 44, 0.08);
    background: rgba(255, 255, 255, 0.88);
    box-shadow: 0 16px 32px rgba(18, 24, 28, 0.06);
}

.comparison-card--rent {
    background: linear-gradient(180deg, #fffefe 0%, #f7f1eb 100%);
}

.comparison-card--buy {
    background: linear-gradient(180deg, #fff4f4 0%, #fffdf9 100%);
    border-color: rgba(180, 1, 1, 0.14);
}

.comparison-card h3 {
    margin: 0 0 16px;
    font-size: 1.32rem;
}

.comparison-summary {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(280px, 0.8fr);
    gap: 16px;
}

.equity-chart {
    padding: 20px;
    border-radius: 26px;
    border: 1px solid rgba(30, 38, 44, 0.08);
    background: linear-gradient(180deg, #ffffff 0%, #fbf6ee 100%);
}

.equity-chart svg {
    width: 100%;
    height: auto;
    display: block;
}

.equity-legend {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    margin-top: 16px;
}

.legend-item {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 0.86rem;
    color: var(--muted-strong);
}

.legend-swatch {
    width: 14px;
    height: 14px;
    border-radius: 999px;
}

.legend-swatch--value {
    background: #d7908d;
}

.legend-swatch--loan {
    background: #45505a;
}

.legend-swatch--equity {
    background: #b40101;
}

.formula-card {
    padding: 24px;
    border-radius: 28px;
    border: 1px solid rgba(30, 38, 44, 0.08);
    background: linear-gradient(180deg, #ffffff 0%, #fbf7f1 100%);
}

.formula-band {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    flex-wrap: wrap;
    margin: 18px 0;
}

.formula-token {
    padding: 12px 16px;
    border-radius: 16px;
    border: 1px solid rgba(30, 38, 44, 0.08);
    background: rgba(255, 255, 255, 0.92);
    font-weight: 700;
}

.formula-operator {
    font-size: 1.3rem;
    font-weight: 800;
    color: var(--accent);
}

.example-line {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
}

.example-chip {
    padding: 10px 12px;
    border-radius: 999px;
    background: rgba(30, 38, 44, 0.06);
    font-size: 0.86rem;
    font-weight: 700;
}

.payment-piece {
    min-height: 162px;
    padding: 18px;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid rgba(30, 38, 44, 0.08);
    display: grid;
    align-content: start;
    gap: 10px;
}

.payment-piece--dark {
    color: #ffffff;
    background: linear-gradient(135deg, #20262c 0%, #39434d 100%);
}

.timing-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 20px;
}

.timing-card {
    padding: 24px;
    border-radius: 28px;
    border: 1px solid rgba(30, 38, 44, 0.08);
    background: linear-gradient(180deg, #ffffff 0%, #fbf6ee 100%);
}

.timeline-list li {
    position: relative;
    padding-left: 20px;
    line-height: 1.55;
}

.timeline-list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.55em;
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: var(--accent);
}

.loan-card {
    display: grid;
    gap: 14px;
}

.score-band {
    display: inline-block;
}

.loan-card__note {
    font-size: 0.84rem;
    line-height: 1.55;
    color: var(--muted);
}

.loan-card__note strong {
    color: var(--ink);
}

.state-card--ri {
    background: linear-gradient(180deg, #fffdf9 0%, #f9f1ea 100%);
}

.state-card--ma {
    background: linear-gradient(180deg, #fffdfb 0%, #f4f6f8 100%);
}

.state-card__tag {
    display: inline-flex;
    width: fit-content;
    margin-bottom: 12px;
    padding: 7px 10px;
    border-radius: 999px;
    background: rgba(30, 38, 44, 0.06);
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.slide--assistance .state-grid {
    align-items: start;
}

.slide--assistance .state-card {
    display: grid;
    align-content: start;
    gap: 14px;
    min-width: 0;
}

.slide--assistance .state-card h3 {
    margin-bottom: 0;
}

.slide--assistance .state-card .stack-list {
    gap: 14px;
    min-width: 0;
}

.slide--assistance .state-card .stack-list li {
    min-width: 0;
    overflow-wrap: anywhere;
}

.slide--assistance .state-card .stack-list li strong {
    display: block;
    margin-bottom: 4px;
    font-size: 0.98rem;
    line-height: 1.28;
    color: var(--ink);
}

.slide--assistance .comparison-summary > * {
    min-width: 0;
}

.photo-card {
    position: relative;
    overflow: hidden;
    border-radius: 30px;
    min-height: 100%;
    border: 1px solid rgba(30, 38, 44, 0.08);
    box-shadow: var(--shadow-md);
}

.photo-card--short {
    min-height: 208px;
}

.photo-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.photo-card__overlay {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    gap: 14px;
    padding: 24px;
    color: #ffffff;
    background: linear-gradient(180deg, rgba(12, 16, 20, 0.12), rgba(12, 16, 20, 0.84));
}

.photo-card__overlay p {
    margin: 0;
    line-height: 1.55;
}

.process-strip {
    grid-template-columns: repeat(6, minmax(0, 1fr));
}

.process-step {
    position: relative;
    padding: 18px;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.88);
    border: 1px solid rgba(30, 38, 44, 0.08);
}

.process-step::after {
    content: "";
    position: absolute;
    top: 50%;
    right: -9px;
    width: 18px;
    height: 2px;
    background: rgba(30, 38, 44, 0.18);
}

.process-step:last-child::after {
    display: none;
}

.process-step strong {
    display: block;
    margin-bottom: 10px;
    font-size: 0.84rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--accent);
}

.process-step p {
    margin: 0;
    line-height: 1.5;
}

.contingency-card {
    display: grid;
    gap: 12px;
}

.contingency-card__pill {
    display: inline-flex;
    width: fit-content;
    padding: 8px 10px;
    border-radius: 999px;
    background: rgba(180, 1, 1, 0.09);
    color: var(--accent);
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.risk-item {
    padding: 20px;
    border-radius: 22px;
    border-left: 4px solid #d1a04f;
    background: linear-gradient(180deg, #ffffff 0%, #fbf7ef 100%);
    box-shadow: 0 12px 24px rgba(18, 24, 28, 0.05);
}

.risk-item h3 {
    margin: 0 0 10px;
    font-size: 1rem;
}

.risk-item p {
    margin: 0;
    line-height: 1.55;
}

.timeline-track {
    grid-template-columns: repeat(6, minmax(0, 1fr));
}

.timeline-node {
    display: grid;
    gap: 10px;
    min-height: 196px;
}

.timeline-node__day {
    display: inline-flex;
    width: fit-content;
    padding: 7px 10px;
    border-radius: 999px;
    background: rgba(30, 38, 44, 0.06);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.week-card {
    display: grid;
    gap: 12px;
}

.week-card__week {
    display: inline-flex;
    width: fit-content;
    padding: 8px 10px;
    border-radius: 999px;
    background: rgba(180, 1, 1, 0.09);
    color: var(--accent);
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.contact-panel {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr);
    gap: 24px;
    align-items: stretch;
}

.contact-links {
    display: grid;
    gap: 14px;
    margin-top: 18px;
}

.contact-link {
    display: grid;
    gap: 6px;
    align-items: start;
    justify-items: start;
    padding: 16px 18px;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid rgba(30, 38, 44, 0.1);
    box-shadow: 0 10px 22px rgba(18, 24, 28, 0.08);
    text-decoration: none;
}

.contact-link strong {
    font-size: 0.98rem;
    line-height: 1.3;
    color: var(--ink);
}

.contact-link span {
    color: var(--muted-strong);
    font-size: 0.95rem;
    line-height: 1.45;
}

.contact-link:hover,
.contact-link:focus-visible {
    transform: translateY(-1px);
    border-color: rgba(180, 1, 1, 0.16);
    box-shadow: 0 14px 26px rgba(18, 24, 28, 0.1);
}

.slide__surface--image .contact-link strong,
.slide__surface--image .contact-link span {
    color: var(--ink);
}

.cover-brandbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    flex-wrap: wrap;
}

.cover-brandbar__logos {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
}

.cover-brandbar__logos img {
    height: 34px;
    width: auto;
    object-fit: contain;
}

.cover-brandbar__text {
    font-size: 0.86rem;
    line-height: 1.5;
    color: rgba(255, 255, 255, 0.8);
}

.page-notes {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 0 20px 24px;
    display: grid;
    gap: 18px;
}

.notes-card {
    padding: 24px;
    border-radius: 28px;
    border: 1px solid rgba(30, 38, 44, 0.08);
    background: rgba(255, 255, 255, 0.84);
    box-shadow: var(--shadow-md);
}

.notes-card h2 {
    margin: 0 0 14px;
    font-family: var(--kw-display-font);
    font-weight: 900;
    font-size: clamp(2rem, 2.8vw, 3rem);
    letter-spacing: -0.05em;
}

.notes-card p {
    margin: 0 0 12px;
    line-height: 1.6;
    color: var(--muted-strong);
}

.notes-card details {
    border-top: 1px solid rgba(30, 38, 44, 0.08);
}

.notes-card details:first-of-type {
    margin-top: 14px;
}

.notes-card summary {
    cursor: pointer;
    list-style: none;
    padding: 16px 0;
    font-weight: 800;
}

.notes-card summary::-webkit-details-marker {
    display: none;
}

.notes-card details[open] summary {
    color: var(--accent);
}

.notes-card__content {
    padding: 0 0 18px;
}

.notes-card__content a {
    color: var(--accent-dark);
}

.deck-footer {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 0 20px;
}

.deck-footer__card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    flex-wrap: wrap;
    padding: 24px;
    border-radius: 28px;
    border: 1px solid rgba(30, 38, 44, 0.08);
    background: rgba(255, 255, 255, 0.82);
    box-shadow: var(--shadow-md);
}

.footer-brand {
    display: grid;
    gap: 10px;
}

.footer-brand__logos {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
}

.footer-brand__logos img {
    height: 36px;
    width: auto;
    object-fit: contain;
}

.logo--invert-on-dark {
    filter: brightness(0) invert(1);
}

.footer-brand__text {
    margin: 0;
    font-size: 0.92rem;
    line-height: 1.55;
    color: var(--muted-strong);
}

.footer-disclaimer {
    max-width: 560px;
    margin: 0;
    font-size: 0.84rem;
    line-height: 1.6;
    color: var(--muted);
}

@media (max-width: 1180px) {
    .roadmap-shell {
        grid-template-columns: 1fr;
    }

    .roadmap-rail {
        display: none;
    }

    .mobile-outline {
        display: block;
    }

    .slide__surface {
        min-height: auto;
    }

    .slide--assistance .state-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 980px) {
    .mobile-only-action {
        display: inline-flex;
    }

    .topbar__inner,
    .topbar__actions,
    .brand-lockup,
    .cover-brandbar,
    .deck-footer__card {
        align-items: flex-start;
    }

    .topbar__inner,
    .layout-cover,
    .layout-split,
    .layout-balanced,
    .layout-sidebar,
    .comparison-grid,
    .comparison-summary,
    .timing-grid,
    .state-grid,
    .contact-panel {
        grid-template-columns: 1fr;
    }

    .stats-grid,
    .payment-grid,
    .card-grid-4,
    .loan-columns,
    .action-plan,
    .process-strip,
    .timeline-track {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .card-grid-3,
    .bucket-grid,
    .contingency-grid,
    .risk-grid,
    .self-check {
        grid-template-columns: 1fr;
    }

    .process-step::after {
        display: none;
    }
}

@media (max-width: 760px) {
    .topbar {
        padding: 12px;
    }

    .topbar__inner {
        gap: 14px;
    }

    .roadmap-shell,
    .page-notes,
    .deck-footer {
        padding-left: 14px;
        padding-right: 14px;
    }

    .mobile-outline {
        margin-left: 14px;
        margin-right: 14px;
    }

    .slide__surface {
        padding: 22px 18px;
        border-radius: 26px;
    }

    .slide__header {
        gap: 14px;
    }

    .slide__title {
        font-size: clamp(2.2rem, 10vw, 3.5rem);
    }

    .stats-grid,
    .card-grid-2,
    .card-grid-3,
    .card-grid-4,
    .loan-columns,
    .bucket-grid,
    .contingency-grid,
    .action-plan,
    .process-strip,
    .timeline-track,
    .payment-grid,
    .self-check,
    .risk-grid {
        grid-template-columns: 1fr;
    }

    .brand-lockup__logos img,
    .cover-brandbar__logos img,
    .footer-brand__logos img {
        height: 28px;
    }

    .button {
        width: 100%;
    }

    .topbar__actions {
        width: 100%;
    }
}

:root {
    --deck-height: clamp(720px, calc(100svh - 150px), 980px);
    --deck-arrow-gutter: clamp(56px, 4vw, 68px);
}

.micro-nav,
.mobile-drawer,
.mobile-sheet,
.overlay-backdrop,
.deck-story {
    display: none;
}

.roadmap-deck {
    display: grid;
    gap: 18px;
    min-width: 0;
}

.roadmap-main {
    display: block;
    position: relative;
    height: var(--deck-height);
    min-height: var(--deck-height);
    overflow: visible;
}

.slide {
    position: absolute;
    inset: 0 var(--deck-arrow-gutter);
    opacity: 0;
    pointer-events: none;
    transform: translateX(36px) scale(0.985);
    transition:
        opacity 0.28s ease,
        transform 0.32s ease;
}

.slide.is-active {
    opacity: 1;
    pointer-events: auto;
    transform: translateX(0) scale(1);
    z-index: 2;
}

.slide__surface {
    height: 100%;
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
    overscroll-behavior: contain;
    scrollbar-gutter: stable;
}

.slide.is-dense .slide__surface {
    padding: clamp(18px, 2.35vw, 30px);
}

.slide.is-dense .slide__inner {
    gap: 18px;
}

.slide.is-dense .slide__meta {
    gap: 8px;
}

.slide.is-dense .layout-cover,
.slide.is-dense .layout-split,
.slide.is-dense .layout-balanced,
.slide.is-dense .layout-sidebar {
    gap: 16px;
}

.slide.is-dense .layout-stack,
.slide.is-dense .chip-row {
    gap: 10px;
}

.slide.is-dense .card-grid-2,
.slide.is-dense .card-grid-3,
.slide.is-dense .card-grid-4,
.slide.is-dense .loan-columns,
.slide.is-dense .bucket-grid,
.slide.is-dense .contingency-grid,
.slide.is-dense .action-plan,
.slide.is-dense .process-strip,
.slide.is-dense .timeline-track,
.slide.is-dense .risk-grid,
.slide.is-dense .payment-grid,
.slide.is-dense .self-check,
.slide.is-dense .state-grid,
.slide.is-dense .stats-grid {
    gap: 12px;
}

.slide.is-dense .slide__takeaway,
.slide.is-dense .stat-card,
.slide.is-dense .info-card,
.slide.is-dense .glass-card {
    padding: 14px 16px;
}

.slide.is-dense .chip {
    padding: 8px 12px;
    font-size: 0.82rem;
}

.slide.is-compact .slide__surface {
    padding: 14px 16px;
}

.slide.is-compact .slide__inner {
    gap: 13px;
}

.slide.is-compact .slide__meta {
    gap: 7px;
}

.slide.is-compact .slide__index {
    font-size: 0.66rem;
    letter-spacing: 0.16em;
}

.slide.is-compact .slide__eyebrow {
    padding: 6px 10px;
    font-size: 0.72rem;
}

.slide.is-compact .slide__takeaway,
.slide.is-compact .stat-card,
.slide.is-compact .info-card,
.slide.is-compact .glass-card,
.slide.is-compact .loan-card,
.slide.is-compact .state-card,
.slide.is-compact .contingency-card,
.slide.is-compact .timeline-node,
.slide.is-compact .week-card,
.slide.is-compact .contact-card,
.slide.is-compact .photo-callout {
    padding: 16px;
    border-radius: 20px;
}

.slide.is-compact .info-card h3,
.slide.is-compact .glass-card h3,
.slide.is-compact .loan-card h3,
.slide.is-compact .state-card h3,
.slide.is-compact .contingency-card h3,
.slide.is-compact .timeline-node h3,
.slide.is-compact .week-card h3,
.slide.is-compact .contact-card h3,
.slide.is-compact .photo-callout h3 {
    margin-bottom: 8px;
    font-size: 1rem;
}

.slide.is-compact .info-card p,
.slide.is-compact .glass-card p,
.slide.is-compact .loan-card p,
.slide.is-compact .state-card p,
.slide.is-compact .contingency-card p,
.slide.is-compact .timeline-node p,
.slide.is-compact .week-card p,
.slide.is-compact .contact-card p,
.slide.is-compact .photo-callout p {
    font-size: 0.94rem;
    line-height: 1.48;
}

.slide.is-compact .slide__title {
    font-size: clamp(1.82rem, 2.95vw, 3.5rem);
}

.slide.is-compact .slide__title--medium {
    font-size: clamp(1.58rem, 2.25vw, 2.85rem);
}

.slide.is-compact .slide__title--small {
    font-size: clamp(1.42rem, 1.9vw, 2.35rem);
}

.slide.is-compact .slide__lede {
    font-size: clamp(0.9rem, 0.98vw, 1rem);
    line-height: 1.46;
}

.slide.is-tight .slide__surface {
    padding: 12px 14px;
}

.slide.is-tight .slide__inner {
    gap: 11px;
}

.slide.is-tight .slide__meta {
    gap: 6px;
}

.slide.is-tight .slide__index {
    font-size: 0.62rem;
    letter-spacing: 0.14em;
}

.slide.is-tight .slide__eyebrow {
    padding: 5px 9px;
    font-size: 0.68rem;
}

.slide.is-tight .slide__title {
    font-size: clamp(1.7rem, 2.55vw, 3rem);
}

.slide.is-tight .slide__title--medium {
    font-size: clamp(1.42rem, 1.95vw, 2.45rem);
}

.slide.is-tight .slide__title--small {
    font-size: clamp(1.28rem, 1.65vw, 2rem);
}

.slide.is-tight .slide__lede {
    font-size: clamp(0.84rem, 0.9vw, 0.94rem);
    line-height: 1.4;
}

.slide.is-tight .layout-cover,
.slide.is-tight .layout-split,
.slide.is-tight .layout-balanced,
.slide.is-tight .layout-sidebar {
    gap: 12px;
}

.slide.is-tight .layout-stack,
.slide.is-tight .chip-row {
    gap: 8px;
}

.slide.is-tight .card-grid-2,
.slide.is-tight .card-grid-3,
.slide.is-tight .card-grid-4,
.slide.is-tight .loan-columns,
.slide.is-tight .bucket-grid,
.slide.is-tight .contingency-grid,
.slide.is-tight .action-plan,
.slide.is-tight .process-strip,
.slide.is-tight .timeline-track,
.slide.is-tight .risk-grid,
.slide.is-tight .payment-grid,
.slide.is-tight .self-check,
.slide.is-tight .state-grid,
.slide.is-tight .stats-grid {
    gap: 10px;
}

.slide.is-tight .slide__takeaway,
.slide.is-tight .stat-card,
.slide.is-tight .info-card,
.slide.is-tight .glass-card,
.slide.is-tight .loan-card,
.slide.is-tight .state-card,
.slide.is-tight .contingency-card,
.slide.is-tight .timeline-node,
.slide.is-tight .week-card,
.slide.is-tight .contact-card,
.slide.is-tight .photo-callout {
    padding: 14px;
    border-radius: 18px;
}

.slide.is-tight .info-card h3,
.slide.is-tight .glass-card h3,
.slide.is-tight .loan-card h3,
.slide.is-tight .state-card h3,
.slide.is-tight .contingency-card h3,
.slide.is-tight .timeline-node h3,
.slide.is-tight .week-card h3,
.slide.is-tight .contact-card h3,
.slide.is-tight .photo-callout h3 {
    margin-bottom: 6px;
    font-size: 0.94rem;
}

.slide.is-tight .info-card p,
.slide.is-tight .glass-card p,
.slide.is-tight .loan-card p,
.slide.is-tight .state-card p,
.slide.is-tight .contingency-card p,
.slide.is-tight .timeline-node p,
.slide.is-tight .week-card p,
.slide.is-tight .contact-card p,
.slide.is-tight .photo-callout p {
    font-size: 0.9rem;
    line-height: 1.38;
}

.slide.is-tight .chip {
    padding: 6px 10px;
    font-size: 0.76rem;
}

.slide.is-tight .icon-title {
    gap: 10px;
    margin-bottom: 10px;
}

.slide.is-tight .icon-badge {
    width: 36px;
    height: 36px;
    border-radius: 12px;
}

.slide__inner,
.slide__meta,
.layout-cover > *,
.layout-split > *,
.layout-balanced > *,
.layout-sidebar > *,
.card-grid-2 > *,
.card-grid-3 > *,
.card-grid-4 > *,
.loan-columns > *,
.bucket-grid > *,
.contingency-grid > *,
.action-plan > *,
.process-strip > *,
.timeline-track > *,
.risk-grid > *,
.payment-grid > *,
.self-check > *,
.state-grid > *,
.stats-grid > * {
    min-width: 0;
}

.desktop-scroll-indicator {
    position: absolute;
    left: 50%;
    z-index: 5;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 42px;
    padding: 0 14px;
    overflow: hidden;
    isolation: isolate;
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 999px;
    background: linear-gradient(180deg, rgba(205, 34, 34, 0.8) 0%, rgba(151, 0, 0, 0.72) 100%);
    color: #ffffff;
    box-shadow:
        inset 0 0 0 1px rgba(109, 0, 0, 0.16),
        0 14px 26px rgba(112, 0, 0, 0.18);
    backdrop-filter: blur(16px) saturate(155%);
    -webkit-backdrop-filter: blur(16px) saturate(155%);
    transform: translateX(-50%);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.desktop-scroll-indicator.is-visible {
    opacity: 1;
    pointer-events: auto;
}

.desktop-scroll-indicator--up {
    top: 18px;
}

.desktop-scroll-indicator--down {
    bottom: 18px;
    animation: mobile-scroll-bob 1.45s ease-in-out infinite;
}

.desktop-scroll-indicator--up.is-visible {
    animation: mobile-scroll-bob-up 1.45s ease-in-out infinite;
}

.desktop-scroll-indicator .mobile-scroll-indicator__arrow {
    font-size: 1rem;
    line-height: 1;
    font-weight: 800;
    color: #ffffff;
}

.desktop-scroll-indicator .mobile-scroll-indicator__label {
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    white-space: nowrap;
}

.deck-arrow {
    position: absolute;
    top: 50%;
    z-index: 4;
    width: 56px;
    height: 56px;
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 999px;
    overflow: hidden;
    isolation: isolate;
    background: linear-gradient(180deg, rgba(203, 34, 34, 0.84) 0%, rgba(151, 0, 0, 0.75) 100%);
    color: #ffffff;
    box-shadow:
        inset 0 0 0 1px rgba(109, 0, 0, 0.16),
        0 10px 20px rgba(112, 0, 0, 0.12),
        0 2px 8px rgba(112, 0, 0, 0.08);
    backdrop-filter: blur(16px) saturate(155%);
    -webkit-backdrop-filter: blur(16px) saturate(155%);
    transform: translateY(-50%);
    cursor: pointer;
    transition:
        transform 0.2s ease,
        opacity 0.2s ease,
        background 0.2s ease;
}

.deck-arrow:hover,
.deck-arrow:focus-visible {
    background: linear-gradient(180deg, rgba(214, 46, 46, 0.86) 0%, rgba(160, 0, 0, 0.78) 100%);
    box-shadow:
        inset 0 0 0 1px rgba(109, 0, 0, 0.16),
        0 12px 24px rgba(112, 0, 0, 0.14),
        0 4px 10px rgba(112, 0, 0, 0.09);
    transform: translateY(-50%) scale(1.03);
}

.deck-arrow:focus-visible {
    outline: 3px solid rgba(180, 1, 1, 0.16);
    outline-offset: 2px;
}

.deck-arrow:disabled {
    opacity: 0.38;
    cursor: not-allowed;
    transform: translateY(-50%);
}

.deck-arrow--prev {
    left: calc((var(--deck-arrow-gutter) - 56px) / 2);
}

.deck-arrow--next {
    right: calc((var(--deck-arrow-gutter) - 56px) / 2);
}

.deck-controls {
    display: grid;
    grid-template-columns: minmax(0, 240px) minmax(0, 1fr);
    gap: 16px;
    align-items: center;
}

.deck-controls__summary {
    padding: 18px 20px;
    border-radius: 24px;
    border: 1px solid rgba(30, 38, 44, 0.08);
    background: rgba(255, 255, 255, 0.82);
    box-shadow: var(--shadow-md);
}

.deck-controls__eyebrow {
    margin: 0 0 8px;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--accent);
}

.deck-controls__count {
    margin: 0;
    font-size: 1.5rem;
    font-weight: 800;
    letter-spacing: -0.04em;
}

.deck-controls__title {
    margin: 6px 0 0;
    font-size: 0.95rem;
    color: var(--muted);
}

.deck-controls__actions {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
}

.page-notes {
    position: fixed;
    inset: 0;
    z-index: 120;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    background: rgba(16, 22, 27, 0.58);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease;
}

.contact-modal {
    position: fixed;
    inset: 0;
    z-index: 125;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    background: rgba(16, 22, 27, 0.58);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease;
}

body.is-menu-open,
body.is-slides-open,
body.is-sources-open,
body.is-contact-open {
    overflow: hidden;
}

.page-notes[aria-hidden="false"] {
    opacity: 1;
    pointer-events: auto;
}

.contact-modal[aria-hidden="false"] {
    opacity: 1;
    pointer-events: auto;
}

.page-notes .notes-card {
    width: min(920px, 100%);
    max-height: min(82vh, 920px);
    overflow: auto;
    margin: 0;
    border-radius: 30px;
    background: rgb(255, 253, 249);
    box-shadow: 0 28px 80px rgba(18, 24, 28, 0.32);
}

.contact-modal__card {
    width: min(920px, 100%);
    display: grid;
    grid-template-columns: minmax(280px, 0.88fr) minmax(0, 1.12fr);
    overflow: hidden;
    margin: 0;
    border-radius: 32px;
    background: rgb(255, 253, 249);
    box-shadow: 0 28px 80px rgba(18, 24, 28, 0.32);
}

.contact-modal__media {
    min-height: 100%;
    background: linear-gradient(180deg, #f1e2d8 0%, #e8d2c3 100%);
}

.contact-modal__photo {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.contact-modal__body {
    display: grid;
    gap: 18px;
    padding: 30px;
}

.contact-modal__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
}

.contact-modal__head h2 {
    margin: 0;
}

.contact-modal__logo {
    width: min(100%, 360px);
    height: auto;
    display: block;
}

.contact-modal__lede {
    margin: 0;
    font-size: 0.98rem;
    font-weight: 700;
    color: var(--ink);
}

.contact-modal__copy {
    margin: 0;
    line-height: 1.65;
    color: var(--muted-strong);
}

.page-notes__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 20px;
    margin-bottom: 18px;
}

.page-notes__eyebrow {
    margin: 0 0 6px;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--accent);
}

.page-notes__head h2 {
    margin: 0;
}

.page-notes__close {
    min-height: 42px;
    padding: 0 16px;
    position: relative;
    overflow: hidden;
    isolation: isolate;
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 999px;
    background: linear-gradient(180deg, rgba(205, 34, 34, 0.8) 0%, rgba(151, 0, 0, 0.72) 100%);
    color: #ffffff;
    font-weight: 700;
    box-shadow:
        inset 0 0 0 1px rgba(109, 0, 0, 0.16),
        0 12px 24px rgba(112, 0, 0, 0.16);
    backdrop-filter: blur(16px) saturate(155%);
    -webkit-backdrop-filter: blur(16px) saturate(155%);
    cursor: pointer;
}

.overlay-backdrop {
    position: fixed;
    inset: 0;
    z-index: 109;
    background: rgba(16, 22, 27, 0.42);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease;
}

body.is-menu-open .overlay-backdrop,
body.is-slides-open .overlay-backdrop,
body.is-contact-open .overlay-backdrop {
    display: block;
    opacity: 1;
    pointer-events: auto;
}

.mobile-drawer {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    z-index: 121;
    width: min(92vw, 420px);
    padding: 18px;
    background: rgba(255, 253, 249, 0.98);
    box-shadow: 20px 0 50px rgba(18, 24, 28, 0.22);
    transform: translateX(-100%);
    transition: transform 0.24s ease;
}

body.is-menu-open .mobile-drawer {
    display: block;
    transform: translateX(0);
}

.mobile-drawer__nav {
    display: grid;
    gap: 10px;
}

.mobile-drawer__nav a {
    display: block;
    padding: 14px 16px;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.78);
    text-decoration: none;
    font-weight: 700;
    color: var(--ink);
}

.mobile-drawer__nav a[aria-current="page"] {
    background: linear-gradient(135deg, rgba(180, 1, 1, 0.12), rgba(180, 1, 1, 0.04));
    color: var(--accent-dark);
}

.mobile-sheet {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 122;
    padding: 18px 14px calc(18px + env(safe-area-inset-bottom, 0px));
    background: rgba(255, 253, 249, 0.98);
    border-radius: 28px 28px 0 0;
    box-shadow: 0 -20px 48px rgba(18, 24, 28, 0.18);
    transform: translateY(100%);
    transition: transform 0.24s ease;
    max-height: min(76vh, 720px);
}

body.is-slides-open .mobile-sheet {
    display: block;
    transform: translateY(0);
}

.mobile-sheet__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 16px;
}

.mobile-sheet__head strong {
    font-size: 1.02rem;
    letter-spacing: -0.02em;
}

.mobile-sheet__head button {
    min-height: 40px;
    padding: 0 14px;
    position: relative;
    overflow: hidden;
    isolation: isolate;
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 999px;
    background: linear-gradient(180deg, rgba(205, 34, 34, 0.8) 0%, rgba(151, 0, 0, 0.72) 100%);
    color: #ffffff;
    box-shadow:
        inset 0 0 0 1px rgba(109, 0, 0, 0.16),
        0 12px 24px rgba(112, 0, 0, 0.16);
    backdrop-filter: blur(16px) saturate(155%);
    -webkit-backdrop-filter: blur(16px) saturate(155%);
    cursor: pointer;
}

.mobile-sheet__body {
    max-height: calc(min(76vh, 720px) - 74px);
    overflow: auto;
    padding-right: 4px;
}

.mobile-sheet .outline-list {
    gap: 10px;
}

.mobile-sheet .outline-link {
    padding: 12px 14px;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.72);
}

.mobile-drawer__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 18px;
}

.mobile-drawer__head strong {
    font-size: 1.02rem;
    letter-spacing: -0.02em;
}

.mobile-drawer__head button {
    min-height: 40px;
    padding: 0 14px;
    position: relative;
    overflow: hidden;
    isolation: isolate;
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 999px;
    background: linear-gradient(180deg, rgba(205, 34, 34, 0.8) 0%, rgba(151, 0, 0, 0.72) 100%);
    color: #ffffff;
    box-shadow:
        inset 0 0 0 1px rgba(109, 0, 0, 0.16),
        0 12px 24px rgba(112, 0, 0, 0.16);
    backdrop-filter: blur(16px) saturate(155%);
    -webkit-backdrop-filter: blur(16px) saturate(155%);
    cursor: pointer;
}

.mobile-drawer__body {
    display: grid;
    gap: 18px;
    max-height: calc(100vh - 92px);
    overflow: auto;
    padding-right: 4px;
}

.mobile-drawer__actions {
    display: grid;
    gap: 10px;
}

@media (min-width: 981px) {
    .mobile-drawer__actions {
        display: none;
    }
}

@media (max-width: 1180px) {
    .roadmap-shell {
        grid-template-columns: 1fr;
    }

    .roadmap-rail {
        display: none;
    }

    .roadmap-main {
        min-height: calc(100svh - 250px);
    }

    .deck-controls {
        grid-template-columns: 1fr;
    }

    .deck-controls__actions {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .contact-modal__card {
        grid-template-columns: 1fr;
        max-height: min(86vh, 920px);
        overflow: auto;
    }

    .contact-modal__media {
        min-height: 260px;
        max-height: 320px;
    }
}

@media (max-width: 980px) {
    html,
    body {
        height: 100%;
        overflow: hidden;
    }

    .roadmap-body {
        height: 100svh;
        overflow: hidden;
        overscroll-behavior: none;
    }

    .roadmap-page {
        display: grid;
        grid-template-rows: auto 1fr;
        height: 100svh;
        padding-bottom: 0;
        overflow: hidden;
    }

    .topbar {
        display: none;
    }

    .micro-nav {
        display: block;
        position: relative;
        z-index: 90;
        padding: 12px 14px 0;
    }

    .micro-nav__inner {
        display: grid;
        grid-template-columns: auto minmax(0, 1fr) auto;
        align-items: center;
        gap: 12px;
        padding: 12px 14px;
        border-radius: 22px;
        border: 1px solid rgba(30, 38, 44, 0.08);
        background: rgba(255, 255, 255, 0.9);
        box-shadow: var(--shadow-md);
        min-width: 0;
    }

    .micro-nav__button {
        min-height: 40px;
        min-width: 0;
        padding: 0 14px;
        position: relative;
        overflow: hidden;
        isolation: isolate;
        border: 1px solid rgba(255, 255, 255, 0.16);
        border-radius: 999px;
        background: linear-gradient(180deg, rgba(205, 34, 34, 0.8) 0%, rgba(151, 0, 0, 0.72) 100%);
        color: #ffffff;
        font-weight: 700;
        box-shadow:
            inset 0 0 0 1px rgba(109, 0, 0, 0.16),
            0 12px 24px rgba(112, 0, 0, 0.16);
        backdrop-filter: blur(16px) saturate(155%);
        -webkit-backdrop-filter: blur(16px) saturate(155%);
        cursor: pointer;
    }

    .micro-nav__button--quiet {
        background: linear-gradient(180deg, rgba(217, 52, 52, 0.78) 0%, rgba(167, 6, 6, 0.7) 100%);
        border-color: rgba(255, 255, 255, 0.16);
        box-shadow:
            inset 0 0 0 1px rgba(109, 0, 0, 0.14),
            0 14px 26px rgba(112, 0, 0, 0.17);
    }

    .micro-nav__logos {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 10px;
        min-width: 0;
        flex: 1;
        overflow: hidden;
    }

    .micro-nav__logos img {
        height: 26px;
        max-width: 100%;
        width: auto;
        object-fit: contain;
        min-width: 0;
    }

    .deck-story {
        display: grid;
        gap: 12px;
        padding: 16px 18px;
        border-radius: 24px;
        border: 1px solid rgba(30, 38, 44, 0.08);
        background: rgba(255, 255, 255, 0.86);
        box-shadow: var(--shadow-md);
        min-width: 0;
    }

    .deck-story__progress {
        display: grid;
        grid-template-columns: repeat(28, minmax(0, 1fr));
        gap: 6px;
    }

    .deck-story__progress span {
        display: block;
        height: 4px;
        border-radius: 999px;
        background: rgba(30, 38, 44, 0.12);
    }

    .deck-story__progress span.is-complete,
    .deck-story__progress span.is-active {
        background: rgba(180, 1, 1, 0.42);
    }

    .deck-story__progress span.is-active {
        background: linear-gradient(135deg, var(--accent) 0%, #d22f2f 100%);
    }

    .deck-story__meta {
        min-width: 0;
    }

    .deck-story__summary {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 14px;
        width: 100%;
        padding: 0;
        border: 0;
        background: transparent;
        color: inherit;
        text-align: left;
        cursor: pointer;
        min-width: 0;
    }

    .deck-story__summary:focus-visible {
        outline: 3px solid rgba(180, 1, 1, 0.16);
        outline-offset: 3px;
        border-radius: 16px;
    }

    .deck-story__copy {
        display: grid;
        gap: 3px;
        min-width: 0;
    }

    .deck-story__copy p {
        margin: 0;
        font-size: 0.96rem;
        font-weight: 800;
        color: var(--ink);
    }

    .deck-story__copy span {
        font-size: 0.82rem;
        color: var(--muted);
    }

    .deck-story__chevron {
        flex: 0 0 auto;
        display: grid;
        place-items: center;
        width: 36px;
        height: 36px;
        border: 1px solid rgba(30, 38, 44, 0.12);
        border-radius: 999px;
        background: rgba(255, 255, 255, 0.82);
        color: var(--accent-dark);
        font-size: 1.35rem;
        line-height: 1;
    }

    .roadmap-shell {
        width: 100%;
        max-width: none;
        height: 100%;
        min-height: 0;
        padding: 12px 14px 14px;
    }

    .roadmap-deck {
        width: 100%;
        height: 100%;
        min-height: 0;
        grid-template-rows: auto 1fr;
        gap: 12px;
    }

    .roadmap-main {
        width: 100%;
        height: 100%;
        min-height: 0;
    }

    .slide,
    .slide__surface {
        width: 100%;
    }

    .slide {
        inset: 0;
    }

    .slide__surface {
        overflow: hidden;
        padding: 18px 16px 76px;
        padding-bottom: 92px;
        border-radius: 24px;
    }

    .slide__inner {
        gap: 20px;
    }

    .deck-controls,
    .deck-footer,
    .desktop-scroll-indicator {
        display: none;
    }

    .deck-arrow {
        top: auto;
        bottom: 14px;
        width: 48px;
        height: 48px;
        transform: none;
    }

    .deck-arrow:hover,
    .deck-arrow:focus-visible,
    .deck-arrow:disabled {
        transform: none;
    }

    .deck-arrow--prev {
        left: 14px;
    }

    .deck-arrow--next {
        right: 14px;
    }
}

@media (max-width: 760px) {
    .micro-nav {
        padding: 10px 10px 0;
    }

    .micro-nav__inner {
        gap: 10px;
    }

    .micro-nav__button {
        min-width: 68px;
        padding: 0 12px;
    }

    .micro-nav__logos img {
        height: 22px;
    }

    .roadmap-shell {
        width: 100%;
        padding: 10px 10px 12px;
    }

    .deck-story {
        padding: 12px;
    }

    .deck-story__summary {
        gap: 10px;
    }

    .roadmap-deck {
        gap: 10px;
    }

    .roadmap-main {
        height: 100%;
        min-height: 0;
    }

    .slide__surface {
        padding: 14px 14px 72px;
        border-radius: 22px;
    }

    .slide__inner {
        gap: 16px;
    }

    .page-notes {
        align-items: flex-end;
        padding: 14px;
    }

    .contact-modal {
        align-items: flex-end;
        padding: 14px;
    }

    .page-notes .notes-card {
        max-height: 84svh;
        border-radius: 28px 28px 22px 22px;
    }

    .contact-modal__card {
        border-radius: 28px 28px 22px 22px;
    }

    .contact-modal__body {
        padding: 22px 18px 20px;
    }

    .contact-modal__head {
        align-items: flex-start;
        flex-direction: column;
    }

    .contact-modal__head .page-notes__close {
        width: 100%;
    }

    .page-notes__head {
        align-items: flex-start;
        flex-direction: column;
    }

    .page-notes__close {
        width: 100%;
    }
}

@media (max-width: 380px) {
    .micro-nav {
        padding: 8px 8px 0;
    }

    .micro-nav__inner {
        gap: 8px;
        padding: 10px;
    }

    .micro-nav__button {
        min-height: 36px;
        min-width: 56px;
        padding: 0 10px;
        font-size: 0.84rem;
    }

    .micro-nav__logos {
        gap: 6px;
    }

    .micro-nav__logos img {
        height: 18px;
    }

    .roadmap-shell {
        padding: 8px;
    }

    .deck-story {
        gap: 8px;
        padding: 10px;
    }

    .deck-story__copy p {
        font-size: 0.88rem;
    }

    .deck-story__copy span {
        font-size: 0.66rem;
    }

    .deck-story__chevron {
        width: 34px;
        height: 34px;
        font-size: 1.15rem;
    }

    .mobile-page__surface {
        padding: 12px 10px 98px;
    }
}

.mobile-story-stage {
    display: none;
}

.mobile-scroll-indicator {
    display: none;
}

.story-hero {
    display: grid;
    gap: 12px;
}

.story-hero__index,
.story-hero__eyebrow,
.story-card__eyebrow {
    margin: 0;
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.story-hero__index {
    color: var(--accent);
}

.story-hero__eyebrow,
.story-card__eyebrow {
    color: var(--platinum-dark);
}

.story-hero__title {
    margin: 0;
    font-family: var(--kw-display-font);
    font-weight: 900;
    font-size: clamp(2rem, 7.4vw, 3rem);
    line-height: 0.94;
    letter-spacing: -0.05em;
    overflow-wrap: anywhere;
}

.story-hero__body,
.story-hero__note {
    margin: 0;
    font-size: 0.98rem;
    line-height: 1.6;
    color: var(--muted-strong);
}

.story-hero__note {
    font-size: 0.84rem;
    color: var(--muted);
}

.story-chip-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.story-chip {
    display: inline-flex;
    align-items: center;
    min-height: 32px;
    padding: 0 12px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.14);
    border: 1px solid rgba(255, 255, 255, 0.18);
    color: inherit;
    font-size: 0.78rem;
    font-weight: 700;
}

.story-card__media {
    margin: -2px -2px 2px;
    border-radius: 16px;
    overflow: hidden;
    aspect-ratio: 16 / 9;
}

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

.story-card {
    display: grid;
    gap: 10px;
    padding: 16px;
    border-radius: 20px;
    border: 1px solid rgba(30, 38, 44, 0.08);
    background: rgba(255, 255, 255, 0.9);
    box-shadow: 0 16px 34px rgba(18, 24, 28, 0.08);
    min-width: 0;
}

.story-card--takeaway {
    border-left: 3px solid var(--accent);
}

.story-card__head {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 12px;
    align-items: start;
}

.story-card__heading {
    display: grid;
    gap: 4px;
    min-width: 0;
}

.story-card__icon,
.story-scene__icon,
.story-scene__orb {
    display: grid;
    place-items: center;
    border-radius: 999px;
    color: var(--accent-dark);
    background: linear-gradient(145deg, rgba(180, 1, 1, 0.12), rgba(255, 255, 255, 0.95));
    border: 1px solid rgba(180, 1, 1, 0.12);
}

.story-card__icon {
    width: 40px;
    height: 40px;
}

.story-card__icon svg,
.story-scene__icon svg,
.story-scene__orb svg {
    width: 18px;
    height: 18px;
}

.story-card__title {
    margin: 0;
    font-size: 1.08rem;
    line-height: 1.22;
    letter-spacing: -0.02em;
    overflow-wrap: anywhere;
}

.story-card__value {
    margin: 0;
    font-size: 1.2rem;
    font-weight: 800;
    letter-spacing: -0.03em;
    color: var(--ink);
}

.story-card__body {
    margin: 0;
    font-size: 0.92rem;
    line-height: 1.58;
    color: var(--muted-strong);
    overflow-wrap: anywhere;
}

.story-card__list {
    margin: 0;
    padding-left: 1.05rem;
    display: grid;
    gap: 8px;
    color: var(--muted-strong);
}

.story-card__list li {
    font-size: 0.9rem;
    line-height: 1.48;
    overflow-wrap: anywhere;
}

.story-scene {
    --scene-a: rgba(180, 1, 1, 0.14);
    --scene-b: rgba(213, 193, 168, 0.24);
    position: relative;
    display: grid;
    gap: 12px;
    padding: 16px;
    border-radius: 22px;
    overflow: hidden;
    border: 1px solid rgba(30, 38, 44, 0.08);
    background: linear-gradient(165deg, rgba(255, 255, 255, 0.96), rgba(250, 245, 239, 0.96));
    box-shadow: 0 18px 34px rgba(18, 24, 28, 0.08);
    min-width: 0;
}

.story-scene::before {
    content: "";
    position: absolute;
    inset: -18% -5% auto auto;
    width: 170px;
    height: 170px;
    border-radius: 50%;
    background:
        radial-gradient(circle, var(--scene-a), transparent 64%);
    pointer-events: none;
}

.story-scene[data-tone="sand"] {
    --scene-a: rgba(198, 161, 109, 0.22);
    --scene-b: rgba(226, 213, 190, 0.34);
}

.story-scene[data-tone="sage"] {
    --scene-a: rgba(92, 125, 114, 0.22);
    --scene-b: rgba(211, 225, 221, 0.34);
}

.story-scene[data-tone="slate"] {
    --scene-a: rgba(78, 91, 108, 0.2);
    --scene-b: rgba(212, 220, 230, 0.34);
}

.story-scene > * {
    position: relative;
    z-index: 1;
}

.story-scene__eyebrow {
    margin: 0;
    font-size: 0.66rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--accent);
}

.story-scene__title {
    margin: 0;
    font-size: 1rem;
    line-height: 1.18;
    letter-spacing: -0.02em;
    overflow-wrap: anywhere;
}

.story-scene__body {
    margin: 0;
    font-size: 0.82rem;
    line-height: 1.45;
    color: var(--muted-strong);
    overflow-wrap: anywhere;
}

.story-scene__chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.story-scene__chip {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 10px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.7);
    border: 1px solid rgba(30, 38, 44, 0.08);
    font-size: 0.76rem;
    font-weight: 700;
    color: var(--ink);
}

.story-scene--photo {
    min-height: 180px;
    padding: 0;
    background: #141b20;
}

.story-scene--photo::before {
    display: none;
}

.story-scene__image {
    display: block;
    width: 100%;
    height: 100%;
    min-height: 180px;
    object-fit: cover;
}

.story-scene__caption {
    position: absolute;
    inset: auto 0 0 0;
    display: grid;
    gap: 8px;
    padding: 18px;
    color: #ffffff;
    background: linear-gradient(180deg, rgba(13, 18, 22, 0.04), rgba(13, 18, 22, 0.76));
}

.story-scene--photo .story-scene__eyebrow,
.story-scene--photo .story-scene__title,
.story-scene--photo .story-scene__body,
.story-scene--photo .story-scene__chip {
    color: #ffffff;
}

.story-scene--photo .story-scene__chip {
    background: rgba(255, 255, 255, 0.12);
    border-color: rgba(255, 255, 255, 0.14);
}

.story-scene--chart .story-scene__svg {
    border-radius: 18px;
    overflow: hidden;
    background: rgba(255, 255, 255, 0.76);
}

.story-scene__svg svg {
    display: block;
    width: 100%;
    height: auto;
}

.story-scene__compare,
.story-scene__grid {
    display: grid;
    gap: 10px;
}

.story-scene__compare {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.story-scene__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.story-scene__panel,
.story-scene__tile {
    display: grid;
    gap: 8px;
    padding: 12px;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(30, 38, 44, 0.06);
    min-width: 0;
}

.story-scene__timeline {
    display: grid;
    gap: 10px;
}

.story-scene__step {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 10px;
    align-items: start;
}

.story-scene__dot {
    display: grid;
    place-items: center;
    width: 28px;
    height: 28px;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--accent) 0%, #d22f2f 100%);
    color: #ffffff;
    font-size: 0.72rem;
    font-weight: 800;
}

.story-scene__stepcopy {
    display: grid;
    gap: 4px;
    min-width: 0;
}

.story-scene--pills {
    justify-items: center;
    text-align: center;
}

.story-scene__orb {
    width: 68px;
    height: 68px;
    font-size: 1.1rem;
    font-weight: 800;
}

@media (max-width: 980px) {
    html,
    body {
        height: 100%;
        overflow: hidden;
    }

    .roadmap-body {
        height: 100dvh;
        overflow: hidden;
        overscroll-behavior: none;
    }

    .roadmap-page {
        display: grid;
        grid-template-rows: auto 1fr;
        height: 100dvh;
        padding-bottom: 0;
        overflow: hidden;
    }

    .topbar,
    .roadmap-rail,
    .roadmap-main,
    .deck-controls,
    .deck-footer {
        display: none;
    }

    .micro-nav {
        display: block;
        position: relative;
        z-index: 90;
        padding: 12px 12px 0;
    }

    .micro-nav__inner {
        min-height: 60px;
    }

    .micro-nav__logos img {
        height: 24px;
    }

    .roadmap-shell {
        width: 100%;
        max-width: none;
        height: 100%;
        min-height: 0;
        padding: 10px 12px 12px;
    }

    .roadmap-deck {
        width: 100%;
        height: 100%;
        min-height: 0;
        grid-template-rows: auto minmax(0, 1fr);
        gap: 10px;
    }

    .deck-story {
        display: grid;
        gap: 8px;
        padding: 10px 12px;
        border-radius: 18px;
        background: rgba(255, 255, 255, 0.9);
        box-shadow: var(--shadow-md);
    }

    .deck-story__progress {
        display: grid;
        grid-auto-flow: column;
        grid-auto-columns: 1fr;
        gap: 6px;
    }

    .deck-story__progress span {
        display: block;
        height: 4px;
        border-radius: 999px;
        background: rgba(30, 38, 44, 0.1);
    }

    .deck-story__progress span.is-complete,
    .deck-story__progress span.is-active {
        background: rgba(180, 1, 1, 0.4);
    }

    .deck-story__progress span.is-active {
        background: linear-gradient(135deg, var(--accent) 0%, #d22f2f 100%);
    }

    .deck-story__meta {
        min-width: 0;
    }

    .deck-story__summary {
        gap: 12px;
    }

    .deck-story__copy {
        display: grid;
        gap: 2px;
        min-width: 0;
    }

    .deck-story__copy p {
        margin: 0;
        font-size: 0.96rem;
        font-weight: 800;
        line-height: 1.2;
        overflow-wrap: anywhere;
    }

    .deck-story__copy span {
        font-size: 0.74rem;
        letter-spacing: 0.06em;
        text-transform: uppercase;
        color: var(--muted);
        overflow-wrap: anywhere;
    }

    .deck-story__chevron {
        width: 38px;
        height: 38px;
    }

    .mobile-story-stage {
        display: block;
        position: relative;
        width: 100%;
        height: 100%;
        min-height: 0;
        min-width: 0;
    }

    .mobile-story-viewport {
        position: relative;
        width: 100%;
        height: 100%;
        min-height: 0;
        min-width: 0;
        overflow: hidden;
    }

    .mobile-page {
        position: absolute;
        inset: 0;
        opacity: 0;
        pointer-events: none;
        transform: translateX(20px);
        transition:
            opacity 0.24s ease,
            transform 0.26s ease;
    }

    .mobile-page.is-active {
        opacity: 1;
        pointer-events: auto;
        transform: translateX(0);
        z-index: 2;
    }

    .mobile-page__surface {
        position: relative;
        height: 100%;
        overflow-x: hidden;
        overflow-y: auto;
        overscroll-behavior: contain;
        scrollbar-width: none;
        -ms-overflow-style: none;
        scroll-behavior: smooth;
        padding: 16px 14px 104px;
        border-radius: 24px;
        border: 1px solid rgba(30, 38, 44, 0.08);
        background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(255, 255, 255, 0.99));
        box-shadow: var(--shadow-lg);
        min-width: 0;
    }

    .mobile-page__surface::-webkit-scrollbar {
        display: none;
    }

    .mobile-page__surface--image {
        color: #ffffff;
        background: #11181d;
    }

    .mobile-page__surface--image::before {
        content: "";
        position: absolute;
        inset: 0;
        background-image: var(--page-image);
        background-size: cover;
        background-position: center;
        opacity: 0.95;
    }

    .mobile-page__surface--image::after {
        content: "";
        position: absolute;
        inset: 0;
        background:
            linear-gradient(180deg, rgba(11, 17, 21, 0.88), rgba(11, 17, 21, 0.36) 44%, rgba(11, 17, 21, 0.2) 100%),
            radial-gradient(circle at top right, rgba(180, 1, 1, 0.22), transparent 32%);
    }

    .mobile-page__inner {
        position: relative;
        z-index: 1;
        display: grid;
        align-content: start;
        grid-auto-rows: min-content;
        gap: 12px;
        min-height: 100%;
        min-width: 0;
    }

    .mobile-scroll-indicator {
        position: absolute;
        left: 50%;
        z-index: 5;
        display: inline-flex;
        align-items: center;
        gap: 8px;
        min-height: 42px;
        padding: 0 14px;
        overflow: hidden;
        isolation: isolate;
        border: 1px solid rgba(255, 255, 255, 0.16);
        border-radius: 999px;
        background: linear-gradient(180deg, rgba(205, 34, 34, 0.8) 0%, rgba(151, 0, 0, 0.72) 100%);
        color: #ffffff;
        box-shadow:
            inset 0 0 0 1px rgba(109, 0, 0, 0.16),
            0 14px 26px rgba(112, 0, 0, 0.18);
        backdrop-filter: blur(16px) saturate(155%);
        -webkit-backdrop-filter: blur(16px) saturate(155%);
        transform: translateX(-50%);
        opacity: 0;
        pointer-events: none;
        transition: opacity 0.2s ease, transform 0.2s ease;
    }

    .mobile-scroll-indicator.is-visible {
        opacity: 1;
        pointer-events: auto;
    }

    .mobile-scroll-indicator--up {
        top: 14px;
    }

    .mobile-scroll-indicator--down {
        bottom: 14px;
        animation: mobile-scroll-bob 1.45s ease-in-out infinite;
    }

    .mobile-scroll-indicator--up.is-visible {
        animation: mobile-scroll-bob-up 1.45s ease-in-out infinite;
    }

    .mobile-scroll-indicator__arrow {
        font-size: 1rem;
        line-height: 1;
        font-weight: 800;
        color: #ffffff;
    }

    .mobile-scroll-indicator__label {
        font-size: 0.76rem;
        font-weight: 700;
        letter-spacing: 0.04em;
        text-transform: uppercase;
        white-space: nowrap;
    }

    .mobile-page--compact .mobile-page__surface {
        padding: 14px 12px 96px;
    }

    .mobile-page--compact .mobile-page__inner,
    .mobile-page--compact .story-hero {
        gap: 10px;
    }

    .mobile-page--compact .story-hero__title {
        font-size: clamp(1.75rem, 6.6vw, 2.4rem);
    }

    .mobile-page--compact .story-hero__body,
    .mobile-page--compact .story-hero__note {
        font-size: 0.9rem;
        line-height: 1.48;
    }

    .mobile-page--compact .story-card {
        gap: 8px;
        padding: 13px;
    }

    .mobile-page--compact .story-card__icon {
        width: 36px;
        height: 36px;
    }

    .mobile-page--compact .story-card__title {
        font-size: 0.98rem;
    }

    .mobile-page--compact .story-card__body,
    .mobile-page--compact .story-card__list li {
        font-size: 0.84rem;
        line-height: 1.42;
    }

    .mobile-page--compact .story-card__list {
        gap: 6px;
    }

    .mobile-page--compact .story-chip {
        min-height: 28px;
        padding: 0 10px;
        font-size: 0.72rem;
    }

    .mobile-page--compact .story-scene {
        gap: 10px;
        padding: 14px;
    }

    .mobile-page--compact .story-scene__panel,
    .mobile-page--compact .story-scene__tile {
        gap: 6px;
        padding: 10px;
    }

    .mobile-page--compact .story-scene__title {
        font-size: 0.9rem;
    }

    .mobile-page--compact .story-scene__body,
    .mobile-page--compact .story-scene__chip {
        font-size: 0.74rem;
    }

    .mobile-page--compact .story-scene__orb {
        width: 58px;
        height: 58px;
    }

    .mobile-page--micro .mobile-page__surface {
        padding: 12px 11px 92px;
    }

    .mobile-page--micro .mobile-page__inner,
    .mobile-page--micro .story-hero {
        gap: 8px;
    }

    .mobile-page--micro .story-hero__index,
    .mobile-page--micro .story-hero__eyebrow,
    .mobile-page--micro .story-card__eyebrow {
        font-size: 0.62rem;
    }

    .mobile-page--micro .story-hero__title {
        font-size: clamp(1.55rem, 6vw, 2.1rem);
    }

    .mobile-page--micro .story-hero__body,
    .mobile-page--micro .story-hero__note {
        font-size: 0.84rem;
        line-height: 1.4;
    }

    .mobile-page--micro .story-card {
        gap: 7px;
        padding: 11px;
        border-radius: 16px;
    }

    .mobile-page--micro .story-card__icon {
        width: 32px;
        height: 32px;
    }

    .mobile-page--micro .story-card__title {
        font-size: 0.92rem;
    }

    .mobile-page--micro .story-card__value {
        font-size: 1.05rem;
    }

    .mobile-page--micro .story-card__body,
    .mobile-page--micro .story-card__list li {
        font-size: 0.8rem;
        line-height: 1.36;
    }

    .mobile-page--micro .story-card__list {
        gap: 5px;
        padding-left: 0.95rem;
    }

    .mobile-page--micro .story-chip {
        min-height: 26px;
        padding: 0 9px;
        font-size: 0.68rem;
    }

    .mobile-page--micro .story-scene {
        gap: 8px;
        padding: 12px;
        border-radius: 18px;
    }

    .mobile-page--micro .story-scene__compare,
    .mobile-page--micro .story-scene__grid {
        gap: 8px;
    }

    .mobile-page--micro .story-scene__panel,
    .mobile-page--micro .story-scene__tile {
        gap: 5px;
        padding: 9px;
        border-radius: 14px;
    }

    .mobile-page--micro .story-scene__title {
        font-size: 0.84rem;
    }

    .mobile-page--micro .story-scene__body,
    .mobile-page--micro .story-scene__chip,
    .mobile-page--micro .story-scene__dot {
        font-size: 0.68rem;
    }

    .mobile-page--micro .story-scene__orb {
        width: 50px;
        height: 50px;
        font-size: 0.95rem;
    }

    .mobile-page__surface--image .story-hero__eyebrow,
    .mobile-page__surface--image .story-card__eyebrow {
        color: rgba(255, 255, 255, 0.78);
    }

    .mobile-page__surface--image .story-hero__body,
    .mobile-page__surface--image .story-hero__note,
    .mobile-page__surface--image .story-card__body,
    .mobile-page__surface--image .story-card__list {
        color: rgba(255, 255, 255, 0.82);
    }

    .mobile-page__surface--image .story-card {
        background: rgba(16, 22, 27, 0.54);
        border-color: rgba(255, 255, 255, 0.12);
        color: #ffffff;
        box-shadow: none;
    }

    .mobile-page__surface--image .story-chip {
        background: rgba(255, 255, 255, 0.12);
        border-color: rgba(255, 255, 255, 0.16);
    }

    .mobile-page__surface--image .story-scene {
        background: rgba(16, 22, 27, 0.46);
        border-color: rgba(255, 255, 255, 0.12);
        box-shadow: none;
    }

    .mobile-page__surface--image .story-scene__panel,
    .mobile-page__surface--image .story-scene__tile,
    .mobile-page__surface--image .story-scene__chip {
        background: rgba(255, 255, 255, 0.1);
        border-color: rgba(255, 255, 255, 0.12);
        color: #ffffff;
    }

    .mobile-page__surface--image .story-scene__body,
    .mobile-page__surface--image .story-scene__eyebrow,
    .mobile-page__surface--image .story-scene__title {
        color: rgba(255, 255, 255, 0.88);
    }

    .mobile-story-stage__arrow {
        position: absolute;
        bottom: 14px;
        top: auto;
        z-index: 4;
        width: 50px;
        height: 50px;
        transform: none;
    }

    .mobile-story-stage__arrow:hover,
    .mobile-story-stage__arrow:focus-visible,
    .mobile-story-stage__arrow:disabled {
        transform: none;
    }

    .mobile-story-stage__arrow.deck-arrow--prev {
        left: 12px;
    }

.mobile-story-stage__arrow.deck-arrow--next {
    right: 12px;
}
}

@media (min-width: 981px) and (max-width: 1180px) {
    .roadmap-shell {
        grid-template-columns: 1fr;
        gap: 16px;
        padding-top: 18px;
    }

    .roadmap-rail {
        display: none;
    }

    .roadmap-deck {
        gap: 14px;
    }

    .roadmap-main {
        height: clamp(620px, calc(100svh - 250px), 860px);
        min-height: clamp(620px, calc(100svh - 250px), 860px);
    }

    .slide {
        scroll-margin-top: 188px;
    }

    .deck-story {
        display: grid;
        gap: 12px;
        padding: 16px 18px;
        border-radius: 26px;
        border: 1px solid rgba(30, 38, 44, 0.08);
        background:
            linear-gradient(180deg, rgba(255, 255, 255, 0.94) 0%, rgba(255, 252, 248, 0.88) 100%);
        box-shadow: var(--shadow-md);
    }

    .deck-story__progress {
        display: grid;
        grid-template-columns: repeat(28, minmax(0, 1fr));
        gap: 5px;
    }

    .deck-story__progress span {
        display: block;
        height: 4px;
        border-radius: 999px;
        background: rgba(30, 38, 44, 0.12);
    }

    .deck-story__progress span.is-complete,
    .deck-story__progress span.is-active {
        background: rgba(180, 1, 1, 0.34);
    }

    .deck-story__progress span.is-active {
        background: linear-gradient(135deg, var(--accent) 0%, #d22f2f 100%);
    }

    .deck-story__meta {
        min-width: 0;
    }

    .deck-story__summary {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 16px;
        width: 100%;
        padding: 0;
        border: 0;
        background: transparent;
        color: inherit;
        text-align: left;
        cursor: pointer;
        min-width: 0;
    }

    .deck-story__summary:focus-visible {
        outline: 3px solid rgba(180, 1, 1, 0.16);
        outline-offset: 3px;
        border-radius: 18px;
    }

    .deck-story__copy {
        display: grid;
        gap: 3px;
        min-width: 0;
    }

    .deck-story__copy p {
        margin: 0;
        font-size: 1rem;
        font-weight: 900;
        line-height: 1.15;
        color: var(--ink);
        overflow-wrap: anywhere;
    }

    .deck-story__copy span {
        font-size: 0.76rem;
        font-weight: 700;
        letter-spacing: 0.08em;
        text-transform: uppercase;
        color: var(--muted);
        overflow-wrap: anywhere;
    }

    .deck-story__chevron {
        flex: 0 0 auto;
        display: grid;
        place-items: center;
        width: 42px;
        height: 42px;
        border: 1px solid rgba(30, 38, 44, 0.12);
        border-radius: 999px;
        background: rgba(255, 255, 255, 0.86);
        color: var(--accent-dark);
        font-size: 1.4rem;
        line-height: 1;
    }

    .mobile-sheet {
        top: 50%;
        left: 50%;
        right: auto;
        bottom: auto;
        width: min(760px, calc(100vw - 56px));
        max-height: min(80svh, 780px);
        padding: 22px 20px 20px;
        border-radius: 32px;
        box-shadow: 0 28px 80px rgba(18, 24, 28, 0.26);
        transform: translate(-50%, calc(-50% + 36px)) scale(0.98);
    }

    body.is-slides-open .mobile-sheet {
        transform: translate(-50%, -50%) scale(1);
    }

    .mobile-sheet__body {
        max-height: calc(min(80svh, 780px) - 88px);
    }

    .mobile-sheet .outline-list {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 12px;
    }

    .mobile-sheet .outline-link {
        min-height: 100%;
        padding: 14px 16px;
    }
}

@keyframes mobile-scroll-bob {
    0%, 100% {
        transform: translateX(-50%) translateY(0);
    }
    50% {
        transform: translateX(-50%) translateY(6px);
    }
}

@keyframes mobile-scroll-bob-up {
    0%, 100% {
        transform: translateX(-50%) translateY(0);
    }
    50% {
        transform: translateX(-50%) translateY(-6px);
    }
}

@media (max-width: 720px) {
    .micro-nav {
        padding: 10px 10px 0;
    }

    .roadmap-shell {
        padding: 10px;
    }

    .deck-story {
        padding: 12px;
    }

    .deck-story__summary {
        gap: 10px;
    }

    .mobile-page__surface {
        padding: 14px 12px 98px;
        border-radius: 22px;
    }

    .story-hero {
        gap: 10px;
    }

    .story-hero__title {
        max-width: none;
        font-size: clamp(1.9rem, 8.4vw, 2.6rem);
    }

    .story-card {
        padding: 14px;
        border-radius: 18px;
    }

    .story-card__title {
        font-size: 1rem;
    }

    .story-card__body,
    .story-card__list li {
        font-size: 0.88rem;
    }

    .page-notes {
        align-items: flex-end;
        padding: 14px;
    }

    .page-notes .notes-card {
        max-height: 84svh;
        border-radius: 28px 28px 22px 22px;
    }

    .page-notes__head {
        align-items: flex-start;
        flex-direction: column;
    }

    .page-notes__close {
        width: 100%;
    }
}

@media (prefers-reduced-motion: reduce) {
    .slide,
    .mobile-page,
    .deck-arrow,
    .desktop-scroll-indicator,
    .mobile-scroll-indicator,
    .mobile-drawer,
    .overlay-backdrop,
    .page-notes,
    .contact-modal {
        transition: none;
        animation: none;
    }
}
