/* Hallmark · pre-emit critique: P5 H4 E4 S5 R4 V5 */
/* Hallmark · genre: product-led sardonic · macrostructure: Deal Desk Narrative · tone: irreverent agent-practical · theme: Clear Casa retained palette */
@import url("/tokens.css");

/* Self-hosted variable fonts — eliminates render-blocking Google Fonts request */
@font-face {
    font-family: 'DM Sans';
    font-style: normal;
    font-weight: 400 800;
    font-display: swap;
    src: url('/assets/fonts/dm-sans-latin.woff2') format('woff2');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
    font-family: 'Quicksand';
    font-style: normal;
    font-weight: 600 700;
    font-display: swap;
    src: url('/assets/fonts/quicksand-latin.woff2') format('woff2');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

:root {
    --color-paper: var(--cc-cream);
    --color-paper-raised: var(--cc-warm-white);
    --color-paper-warm: var(--cc-cream-dark);
    --color-ink: var(--cc-ink);
    --color-muted: var(--cc-muted);
    --color-rule: var(--cc-line);
    --color-primary: var(--cc-primary);
    --color-primary-dark: var(--cc-primary-dark);
    --color-primary-light: var(--cc-primary-light);
    --color-accent: var(--cc-accent);
    --color-accent-dark: var(--cc-accent-dark);
    --color-accent-light: var(--cc-accent-light);
    --color-critical: var(--cc-critical);
    --color-moderate: var(--cc-moderate);
    --color-minor: var(--cc-minor);
    --color-success: var(--cc-success);
    --color-logo: var(--cc-primary-dark);
    --color-white: var(--cc-warm-white);
    --color-focus: var(--color-primary-dark);
    --color-workspace-surface: color-mix(in oklab, var(--color-white) 82%, var(--color-paper));
    --color-transparent: transparent;
    --type-body: var(--font-body);
    --type-display: var(--font-display);
    --space-1: 0.25rem;
    --space-2: 0.5rem;
    --space-3: 0.75rem;
    --space-4: 1rem;
    --space-5: 1.25rem;
    --space-6: 1.5rem;
    --space-7: 1.75rem;
    --space-8: 2rem;
    --space-10: 2.5rem;
    --space-12: 3rem;
    --space-16: 4rem;
    --space-20: 5rem;
    --radius-sm: 0.375rem;
    --radius-md: 0.625rem;
    --radius-lg: 0.75rem;
    --radius-xl: 1rem;
    --radius-pill: 999px;
    --shadow-soft: var(--cc-shadow-soft);
    --shadow-lifted: var(--cc-shadow-lifted);
    --container: 1160px;
}

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

html,
body {
    min-width: 320px;
    overflow-x: clip;
    scroll-behavior: smooth;
}

body {
    margin: 0;
    background:
        linear-gradient(90deg, color-mix(in oklab, var(--color-rule) 40%, var(--color-transparent)) 1px, var(--color-transparent) 1px),
        linear-gradient(180deg, color-mix(in oklab, var(--color-rule) 40%, var(--color-transparent)) 1px, var(--color-transparent) 1px),
        var(--color-paper);
    background-size: 52px 52px;
    color: var(--color-ink);
    font-family: var(--type-body);
    font-size: 1rem;
    line-height: 1.55;
    letter-spacing: 0;
}

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

button {
    cursor: pointer;
}

a {
    color: inherit;
}

svg {
    display: block;
}

#clearcasa-landing {
    color: var(--color-ink);
}

.icon-sprite,
.visual-file-input,
.hidden-field {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    white-space: nowrap;
}

h1,
h2,
h3,
h4,
p {
    margin: 0;
}

h1,
h2,
h3,
strong {
    overflow-wrap: anywhere;
}

h1,
h2,
h3 {
    font-family: var(--type-display);
    letter-spacing: 0;
    line-height: 1;
}

.nav {
    position: sticky;
    top: 0;
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: var(--space-3) clamp(1rem, calc((100% - var(--container)) / 2 + 1rem), 48vw);
    background: color-mix(in oklab, var(--color-paper) 88%, var(--color-transparent));
    backdrop-filter: blur(14px);
}

.brand,
.nav-actions,
.hero-actions,
.footer,
.footer nav,
.success-icon {
    display: flex;
    align-items: center;
}

.brand {
    gap: var(--space-3);
    color: var(--color-ink);
    font-family: var(--type-display);
    font-size: 1.05rem;
    font-weight: 700;
    text-decoration: none;
    white-space: nowrap;
}

.nav-actions {
    gap: var(--space-4);
}

.nav-link,
.text-link {
    color: var(--color-ink);
    font-size: 0.9rem;
    font-weight: 800;
    text-decoration: none;
}

.text-link {
    position: relative;
    display: inline-flex;
    min-height: 44px;
    align-items: center;
}

.nav-link:hover,
.text-link:hover {
    color: var(--color-primary-dark);
}

.button {
    display: inline-flex;
    min-height: 46px;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--color-primary-dark);
    border-radius: var(--radius-md);
    padding: 0.78rem 1rem;
    background: var(--color-primary-dark);
    color: var(--color-white);
    font-weight: 800;
    line-height: 1;
    text-align: center;
    text-decoration: none;
    transition: transform var(--dur-micro) var(--ease-out), background var(--dur-micro) var(--ease-out), border-color var(--dur-micro) var(--ease-out);
}

.button:hover {
    border-color: var(--color-primary);
    background: var(--color-primary);
    transform: translateY(-1px);
}

.button-small {
    min-height: 40px;
    padding: 0.65rem 0.85rem;
    font-size: 0.9rem;
}

.button:focus-visible,
a:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
.pdf-dropzone:focus-visible {
    outline: 3px solid var(--color-focus);
    outline-offset: 4px;
}

.hero,
.mess,
.receipt,
.workflow,
.outcome,
.footer {
    width: min(var(--container), calc(100% - 2rem));
    margin: 0 auto;
}

.hero {
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(420px, 1.1fr);
    gap: clamp(2rem, 5vw, 4rem);
    align-items: start;
    padding: var(--space-12) 0 var(--space-16);
}

.hero-copy {
    min-width: 0;
    max-width: 680px;
}

.kicker {
    display: inline-flex;
    width: fit-content;
    margin-bottom: var(--space-5);
    border: 1px solid var(--color-rule);
    border-radius: var(--radius-md);
    padding: 0.35rem 0.55rem;
    background: var(--color-paper-raised);
    color: var(--color-primary-dark);
    font-size: 0.74rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    line-height: 1;
    text-transform: uppercase;
}

.hero h1 {
    max-width: 680px;
    font-size: clamp(2.35rem, 4vw, 3.7rem);
}

.pdf-quote {
    display: inline;
    font-family: "Courier New", Courier, monospace;
    font-size: 0.78em;
    font-weight: 600;
    letter-spacing: -0.01em;
    color: var(--color-muted);
    background: color-mix(in oklab, var(--color-rule) 38%, var(--color-paper));
    border: 1px solid color-mix(in oklab, var(--color-rule) 70%, var(--color-transparent));
    border-radius: var(--radius-sm);
    padding: 0.08em 0.38em 0.12em;
    vertical-align: baseline;
    box-decoration-break: clone;
    -webkit-box-decoration-break: clone;
}

.hero-lede {
    max-width: 590px;
    margin-top: var(--space-6);
    color: var(--color-muted);
    font-size: clamp(1.1rem, 2vw, 1.35rem);
    font-weight: 600;
}

.hero-actions {
    flex-wrap: wrap;
    gap: var(--space-4);
    margin-top: var(--space-8);
}

.hero-micro {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-2) var(--space-5);
    margin-top: var(--space-5);
    color: var(--color-muted);
    font-size: 0.78rem;
    font-weight: 600;
}

.hero-micro span {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
}

.hero-micro span::before {
    content: "";
    display: block;
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: var(--color-accent);
    flex: none;
}

.hero-desk {
    position: relative;
    min-width: 0;
}

.deal-table {
    position: relative;
    min-height: 760px;
    overflow: hidden;
    border: 1px solid var(--color-rule);
    border-radius: var(--radius-xl);
    padding: clamp(1rem, 2vw, 1.5rem);
    background:
        radial-gradient(circle at top left, color-mix(in oklab, var(--color-accent-light) 48%, var(--color-transparent)), var(--color-transparent) 34%),
        var(--color-paper-raised);
    box-shadow: var(--shadow-lifted);
}

.story-stage {
    --story-dur: 9.4s;
    --workspace-top: 60px;
    isolation: isolate;
}

.story-paper-front,
.binsr-drawer,
.story-upload-card,
.hero-details-panel,
.hero-success-panel,
.mess-card,
.product-tile,
.workflow-track article,
.contact-form {
    border: 1px solid var(--color-rule);
    border-radius: var(--radius-lg);
    background: var(--color-paper-raised);
    box-shadow: var(--shadow-soft);
}

.story-stage::before {
    position: absolute;
    inset: 56px clamp(0.75rem, 3vw, 1.25rem) 24px;
    z-index: 0;
    border: 1px solid color-mix(in oklab, var(--color-rule) 74%, var(--color-transparent));
    border-radius: 1.45rem;
    background:
        linear-gradient(180deg, color-mix(in oklab, var(--color-white) 76%, var(--color-transparent)), var(--color-transparent) 34%),
        var(--color-workspace-surface);
    box-shadow: inset 0 1px 0 color-mix(in oklab, var(--color-white) 82%, var(--color-transparent));
    content: "";
}

.story-workspace-header {
    position: absolute;
    top: 20px;
    left: clamp(1.25rem, 3vw, 2rem);
    right: clamp(1.25rem, 3vw, 2rem);
    z-index: 8;
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: var(--space-3);
    min-width: 0;
    border-bottom: 1px solid color-mix(in oklab, var(--color-rule) 76%, var(--color-transparent));
    padding-bottom: var(--space-3);
}

.story-workspace-header .workspace-brand {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    min-width: 0;
    color: var(--color-muted);
    font-size: 0.78rem;
    font-weight: 850;
    line-height: 1;
}

.workspace-logo {
    width: 18px;
    height: 24px;
    flex: 0 0 auto;
}

.story-workspace-header strong {
    min-width: 0;
    color: var(--color-ink);
    font-size: 0.96rem;
    line-height: 1;
    text-align: center;
}

.story-upload-bay {
    position: absolute;
    top: var(--workspace-top);
    left: 50%;
    z-index: 3;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: var(--space-4);
    align-content: center;
    align-items: center;
    width: min(300px, calc(100% - 4rem));
    min-height: 312px;
    border: 2px dashed color-mix(in oklab, var(--color-primary-dark) 38%, var(--color-rule));
    border-radius: var(--radius-lg);
    padding: var(--space-5);
    background:
        radial-gradient(circle at 50% 34%, color-mix(in oklab, var(--color-accent-light) 28%, var(--color-transparent)), var(--color-transparent) 42%),
        color-mix(in oklab, var(--color-primary-light) 12%, var(--color-paper-raised));
    box-shadow: var(--shadow-soft);
    opacity: 1;
    transform: translate(-50%, 132px) scale(1);
    transform-origin: top center;
    animation: storyUploadBaySequence var(--story-dur) linear 160ms forwards;
    will-change: opacity, transform;
    isolation: isolate;
}

.upload-bay-brand {
    grid-column: 1 / -1;
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    color: var(--color-muted);
    font-size: 0.78rem;
    font-weight: 900;
    line-height: 1;
}

.upload-bay-brand .workspace-logo {
    width: 16px;
    height: 22px;
}

.story-upload-bay::before {
    position: absolute;
    inset: var(--space-3);
    z-index: -1;
    border: 1px solid color-mix(in oklab, var(--color-white) 78%, var(--color-transparent));
    border-radius: calc(var(--radius-lg) - 0.2rem);
    background: color-mix(in oklab, var(--color-white) 54%, var(--color-transparent));
    content: "";
}

.dropzone-upload-icon {
    grid-column: 1;
    grid-row: 2 / span 2;
    width: 44px;
    height: 44px;
    border-radius: var(--radius-pill);
    padding: 0.58rem;
    background: var(--color-primary-dark);
    color: var(--color-white);
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
}

.story-upload-bay span {
    align-self: end;
    color: var(--color-primary-dark);
    font-size: 0.68rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    line-height: 1;
    text-transform: uppercase;
}

.upload-bay-brand span {
    color: var(--color-muted);
    font-size: 0.78rem;
    letter-spacing: 0;
    text-transform: none;
}

.story-upload-bay strong {
    grid-column: 2;
    grid-row: 2;
    align-self: end;
    color: var(--color-ink);
    font-size: 1.08rem;
    line-height: 1;
}

.upload-progress {
    grid-column: 2;
    grid-row: 3;
    height: 8px;
    margin-top: var(--space-2);
    overflow: hidden;
    border-radius: var(--radius-pill);
    background: color-mix(in oklab, var(--color-primary-dark) 10%, var(--color-paper-raised));
}

.upload-progress i {
    display: block;
    width: 100%;
    height: 100%;
    border-radius: inherit;
    background: var(--color-accent);
    transform: scaleX(0);
    transform-origin: left center;
    animation: uploadProgressFill var(--story-dur) linear 160ms forwards;
}

.story-pdf {
    position: absolute;
    top: var(--workspace-top);
    left: 50%;
    z-index: 4;
    width: min(330px, calc(100% - 4rem));
    min-height: 430px;
    opacity: 1;
    filter: none;
    transform: translate(calc(-50% - 188px), 170px) rotate(-3deg) scale(0.34);
    transform-origin: top center;
    animation: storyPdfSequence var(--story-dur) linear 160ms forwards;
    will-change: opacity, transform, filter;
}

.story-paper {
    position: absolute;
    inset: 0;
    border: 1px solid var(--color-rule);
    border-radius: var(--radius-lg);
    background: var(--color-paper-raised);
}

.story-paper-back {
    transform: rotate(-7deg) translate(-18px, 16px);
}

.story-paper-mid {
    transform: rotate(5deg) translate(16px, 12px);
}

.story-paper-front {
    position: relative;
    display: grid;
    min-height: 430px;
    align-content: start;
    gap: var(--space-3);
    padding: var(--space-6);
}

.report-topline > span,
.drawer-tab span,
.mini-card span,
.story-upload-card span {
    color: var(--color-primary-dark);
    font-size: 0.73rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.story-paper-front strong {
    font-family: var(--type-display);
    font-size: 2.05rem;
    line-height: 1;
}

.report-topline {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
}

.report-topline b {
    border: 1px solid var(--color-rule);
    border-radius: var(--radius-sm);
    padding: 0.24rem 0.38rem;
    background: var(--color-paper-warm);
    color: var(--color-primary-dark);
    font-size: 0.64rem;
    line-height: 1;
}

.report-meta {
    display: grid;
    gap: var(--space-1);
    margin-top: calc(var(--space-2) * -1);
    color: var(--color-muted);
    font-size: 0.74rem;
    font-weight: 800;
    line-height: 1.15;
}

.report-lines {
    display: grid;
    gap: var(--space-2);
}

.report-lines i,
.cost-row i {
    display: block;
    height: 8px;
    border-radius: var(--radius-pill);
    background: var(--color-paper-warm);
}

.report-lines i:nth-child(1) {
    width: 90%;
}

.report-lines i:nth-child(2) {
    width: 74%;
}

.report-lines i:nth-child(3) {
    width: 52%;
}

.report-section {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: var(--space-3);
    align-items: center;
    margin-top: var(--space-1);
}

.report-section b {
    color: var(--color-muted);
    font-size: 0.72rem;
    line-height: 1;
    text-transform: uppercase;
}

.report-section i {
    display: block;
    height: 1px;
    background: var(--color-rule);
}

.report-note {
    border-left: 4px solid var(--color-accent);
    border-radius: var(--radius-sm);
    padding: 0.72rem 0.82rem;
    background: color-mix(in oklab, var(--color-accent-light) 18%, var(--color-paper-raised));
    font-size: 0.82rem;
    font-weight: 800;
    line-height: 1.25;
}

.report-note.muted {
    border-left-color: var(--color-primary);
    color: var(--color-muted);
}

.report-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-2);
    margin-top: var(--space-1);
}

.report-grid span {
    border: 1px solid var(--color-rule);
    border-radius: var(--radius-sm);
    padding: 0.45rem 0.5rem;
    background: color-mix(in oklab, var(--color-paper-raised) 70%, var(--color-paper-warm));
    color: var(--color-muted);
    font-size: 0.68rem;
    font-weight: 850;
    line-height: 1;
}

.mess-card span,
.product-tile span,
.workflow-track span {
    display: block;
    color: var(--color-primary-dark);
    font-size: 0.73rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.mess-card p,
.receipt-copy p,
.product-tile p,
.workflow-track p,
.contact-copy p,
.form-note,
.input-hint {
    color: var(--color-muted);
}

.binsr-drawer {
    position: absolute;
    top: var(--workspace-top);
    left: 50%;
    right: auto;
    bottom: auto;
    z-index: 5;
    display: grid;
    gap: var(--space-4);
    width: min(560px, calc(100% - 4rem));
    padding: var(--space-5);
    opacity: 0;
    filter: none;
    transform: translate(-50%, 260px) scale(0.92);
    transform-origin: top center;
    animation: storyDashboardSequence var(--story-dur) linear 160ms forwards;
    will-change: opacity, transform, filter;
}

.drawer-tab {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    min-width: 0;
}

.drawer-tab strong {
    color: var(--color-accent-dark);
    font-family: var(--type-display);
    font-size: 1.15rem;
    line-height: 1;
}

.dashboard-mini {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--space-3);
}

.mini-card {
    min-width: 0;
    border: 1px solid var(--color-rule);
    border-radius: var(--radius-md);
    padding: var(--space-4);
    background: color-mix(in oklab, var(--color-paper-raised) 86%, var(--color-paper-warm));
    opacity: 0;
    transform: translateY(14px);
    animation: storyCardIn 520ms var(--ease-out) 5200ms forwards;
}

.mini-card:nth-child(2) {
    animation-delay: 5340ms;
}

.mini-card:nth-child(3) {
    animation-delay: 5480ms;
}

.mini-card:nth-child(4) {
    animation-delay: 5620ms;
}

.mini-assessment,
.mini-severity,
.mini-negotiation,
.mini-client {
    grid-column: span 2;
}

.mini-card strong {
    display: block;
    margin-top: var(--space-2);
    font-size: 0.98rem;
    line-height: 1.1;
}

.mini-card p {
    margin-top: var(--space-2);
    color: var(--color-muted);
    font-size: 0.82rem;
    font-weight: 650;
    line-height: 1.3;
}

.mini-chips {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    margin-top: var(--space-3);
}

.mini-chips b {
    border-radius: var(--radius-pill);
    padding: 0.3rem 0.45rem;
    background: var(--color-paper-warm);
    color: var(--color-ink);
    font-size: 0.68rem;
    line-height: 1;
}

.mini-assessment strong {
    color: var(--color-accent-dark);
}

.mini-ring {
    width: 54px;
    height: 54px;
    margin-top: var(--space-3);
    border-radius: var(--radius-pill);
    background: conic-gradient(var(--color-critical) 0 18%, var(--color-moderate) 18% 48%, var(--color-minor) 48% 100%);
    box-shadow: inset 0 0 0 14px var(--color-paper-raised);
}

.mini-counts {
    display: flex;
    gap: var(--space-2);
    margin-top: var(--space-3);
}

.mini-counts b {
    font-size: 1rem;
    line-height: 1;
}

.mini-counts small {
    display: block;
    margin-top: var(--space-1);
    color: var(--color-muted);
    font-size: 0.58rem;
    font-weight: 900;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.cost-row {
    display: grid;
    grid-template-columns: 4.4rem minmax(0, 1fr) 2.4rem;
    gap: var(--space-2);
    align-items: center;
    margin-top: var(--space-2);
}

.cost-row b,
.cost-row em {
    color: var(--color-muted);
    font-size: 0.72rem;
    font-style: normal;
    font-weight: 800;
}

.cost-row i {
    height: 7px;
    background: var(--color-accent);
}

.cost-row .bar-lg {
    width: 90%;
}

.cost-row .bar-md {
    width: 58%;
}

.cost-row .bar-sm {
    width: 42%;
}

.mini-action {
    grid-column: 1 / -1;
    border-radius: var(--radius-md);
    padding: var(--space-3) var(--space-4);
    background: var(--color-accent);
    color: var(--color-white);
    font-size: 0.9rem;
    font-weight: 900;
    opacity: 0;
    transform: translateY(12px);
    animation: storyCardIn 520ms var(--ease-out) 5800ms forwards;
}

.story-upload-card {
    position: absolute;
    top: var(--workspace-top);
    left: 50%;
    right: auto;
    bottom: auto;
    z-index: 6;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: var(--space-3) var(--space-4);
    align-items: center;
    align-content: center;
    width: min(470px, calc(100% - 4rem));
    min-height: 220px;
    border: 2px dashed color-mix(in oklab, var(--color-primary-dark) 42%, var(--color-rule));
    border-radius: var(--radius-lg);
    padding: var(--space-5);
    background:
        radial-gradient(circle at 50% 34%, color-mix(in oklab, var(--color-accent-light) 28%, var(--color-transparent)), var(--color-transparent) 42%),
        color-mix(in oklab, var(--color-primary-light) 12%, var(--color-paper-raised));
    color: var(--color-ink);
    opacity: 0;
    filter: none;
    transform: translate(-50%, 170px) scale(0.96);
    transform-origin: top center;
    animation: storyUploadSequence var(--story-dur) linear 160ms forwards;
    will-change: opacity, transform, filter;
    isolation: isolate;
}

.pdf-dropzone.story-upload-card {
    border-style: dashed;
    background:
        radial-gradient(circle at 50% 34%, color-mix(in oklab, var(--color-accent-light) 28%, var(--color-transparent)), var(--color-transparent) 42%),
        color-mix(in oklab, var(--color-primary-light) 12%, var(--color-paper-raised));
    color: var(--color-ink);
}

.story-upload-card::before {
    position: absolute;
    inset: var(--space-3);
    z-index: -1;
    border: 1px solid color-mix(in oklab, var(--color-white) 78%, var(--color-transparent));
    border-radius: calc(var(--radius-lg) - 0.2rem);
    background: color-mix(in oklab, var(--color-white) 54%, var(--color-transparent));
    content: "";
}

.story-upload-card span,
.story-upload-card small {
    color: var(--color-muted);
}

.story-upload-card span {
    grid-column: 2;
    grid-row: 1;
    align-self: end;
    color: var(--color-primary-dark);
}

.story-upload-card svg {
    grid-row: span 2;
    width: 44px;
    height: 44px;
    border-radius: var(--radius-pill);
    padding: 0.58rem;
    background: var(--color-primary-dark);
    color: var(--color-white);
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
}

.story-upload-card strong {
    grid-column: 2;
    grid-row: 1;
    font-family: var(--type-display);
    font-size: 1.42rem;
    line-height: 1;
}

.story-upload-card small {
    grid-column: 2;
    grid-row: 2;
    font-weight: 750;
}

.story-upload-card:hover,
.story-upload-card.is-dragging,
.hero-desk.has-file .story-upload-card {
    border-color: var(--color-accent-light);
    background:
        radial-gradient(circle at 50% 34%, color-mix(in oklab, var(--color-accent-light) 36%, var(--color-transparent)), var(--color-transparent) 42%),
        color-mix(in oklab, var(--color-primary-light) 18%, var(--color-paper-raised));
}

.hero-details-panel,
.hero-success-panel {
    display: none;
    padding: var(--space-5);
}

/* When file selected: hide the story visual, show the contact form in its place */
.hero-desk.has-file .deal-table.story-stage {
    display: none;
}

.hero-desk.has-file .hero-details-panel {
    display: block;
}

/* After submit: hide form, keep visual hidden, show success panel */
.hero-desk.is-confirming .deal-table.story-stage {
    display: none;
}

.hero-desk.is-confirming .hero-details-panel,
.hero-desk.is-submitted .hero-details-panel {
    display: none;
}

/* Restore the visual after the success confirmation fades out */
.hero-desk.is-submitted .deal-table.story-stage {
    display: block;
}

.panel-copy strong,
.hero-success-panel strong {
    display: block;
    font-size: 1.1rem;
    line-height: 1.2;
}

.panel-copy span,
.hero-success-panel span {
    display: block;
    margin-top: var(--space-1);
    color: var(--color-muted);
    font-weight: 600;
}

.mini-form-grid,
.form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-4);
    margin-top: var(--space-4);
}

.form-full {
    grid-column: 1 / -1;
}

.form-group {
    display: grid;
    gap: var(--space-2);
    min-width: 0;
}

.form-group label,
.checkbox-line {
    color: var(--color-ink);
    font-size: 0.84rem;
    font-weight: 900;
}

input,
select,
textarea {
    width: 100%;
    min-width: 0;
    border: 1px solid var(--color-rule);
    border-radius: var(--radius-md);
    padding: 0.8rem 0.85rem;
    background: var(--color-paper-raised);
    color: var(--color-ink);
}

textarea {
    resize: vertical;
}

.checkbox-line {
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
    line-height: 1.35;
}

.checkbox-line input {
    width: 18px;
    min-width: 18px;
    height: 18px;
    margin-top: var(--space-1);
}

.hero-upload-submit,
.contact-submit {
    width: 100%;
    margin-top: var(--space-4);
}

.form-status {
    min-height: 1.5rem;
    margin-top: var(--space-3);
    color: var(--color-muted);
    font-size: 0.9rem;
    font-weight: 800;
}

.form-status[data-state="success"] {
    color: var(--color-success);
}

.form-status[data-state="error"] {
    color: var(--color-critical);
}

.hero-success-panel {
    align-items: center;
    gap: var(--space-4);
}

.hero-desk.is-confirming .hero-success-panel {
    display: flex;
}

.success-icon {
    width: 42px;
    height: 42px;
    flex: 0 0 auto;
    justify-content: center;
    border-radius: var(--radius-md);
    background: color-mix(in oklab, var(--color-success) 18%, var(--color-paper-raised));
    color: var(--color-success);
}

.success-icon svg {
    width: 24px;
    height: 24px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2.4;
}

.mess,
.receipt,
.workflow,
.outcome {
    padding: var(--space-16) 0;
}

.section-head {
    display: grid;
    grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
    gap: var(--space-8);
    align-items: end;
    margin-bottom: var(--space-8);
}

.section-head.compact {
    max-width: 760px;
    display: block;
}

.section-head h2,
.receipt-copy h2,
.contact-copy h2 {
    font-size: clamp(2.35rem, 4vw, 3.7rem);
}

.mess .section-head {
    display: block;
    max-width: 940px;
    margin-bottom: var(--space-6);
}

.mess .section-head .kicker {
    width: fit-content;
    margin-bottom: var(--space-5);
}

.mess .section-head h2 {
    max-width: 880px;
}

.mess-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--space-4);
}

.mess-card {
    min-height: 250px;
    padding: var(--space-6);
}

.mess-card strong {
    display: block;
    margin-top: var(--space-4);
    font-family: var(--type-display);
    font-size: clamp(1.55rem, 3vw, 2.2rem);
    line-height: 1;
}

.mess-card p {
    margin-top: var(--space-4);
    font-weight: 650;
}

.text-bubble {
    background: var(--color-primary-dark);
    color: var(--color-white);
}

.text-bubble span,
.text-bubble p {
    color: color-mix(in oklab, var(--color-white) 82%, var(--color-transparent));
}

.finding-card {
    background: color-mix(in oklab, var(--color-accent-light) 24%, var(--color-paper-raised));
}

.receipt {
    display: grid;
    grid-template-columns: minmax(280px, 0.75fr) minmax(0, 1.25fr);
    gap: var(--space-8);
    align-items: start;
}

.receipt-copy {
    position: sticky;
    top: 92px;
}

.receipt-copy h2 {
    overflow-wrap: normal;
}

.receipt-copy p:not(.kicker) {
    margin-top: var(--space-5);
    font-size: 1.08rem;
    font-weight: 650;
}

.product-board {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: var(--space-4);
    align-items: stretch;
}

.product-tile {
    position: relative;
    overflow: hidden;
    display: grid;
    gap: var(--space-4);
    align-content: start;
    min-height: 300px;
    padding: var(--space-6);
}

.concept-card {
    grid-column: span 3;
}

.conversation-card,
.buyer-view-card {
    grid-column: span 6;
    grid-template-columns: minmax(240px, 0.95fr) minmax(0, 1fr);
    align-items: center;
    min-height: 260px;
    row-gap: var(--space-2);
}

.conversation-card .concept-visual,
.buyer-view-card .concept-visual {
    grid-column: 1;
    grid-row: 1 / span 3;
    min-height: 210px;
}

.conversation-card > span,
.conversation-card > strong,
.conversation-card > p,
.buyer-view-card > span,
.buyer-view-card > strong,
.buyer-view-card > p {
    grid-column: 2;
}

.concept-visual {
    position: relative;
    display: grid;
    min-height: 158px;
    overflow: hidden;
    border: 1px solid color-mix(in oklab, var(--color-rule) 82%, var(--color-transparent));
    border-radius: var(--radius-lg);
    background:
        radial-gradient(circle at 20% 15%, color-mix(in oklab, var(--color-accent-light) 28%, var(--color-transparent)), var(--color-transparent) 34%),
        color-mix(in oklab, var(--color-white) 84%, var(--color-paper));
    box-shadow: inset 0 1px 0 color-mix(in oklab, var(--color-white) 74%, var(--color-transparent));
    isolation: isolate;
}

.concept-visual::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, color-mix(in oklab, var(--color-rule) 38%, var(--color-transparent)) 1px, var(--color-transparent) 1px),
        linear-gradient(180deg, color-mix(in oklab, var(--color-rule) 38%, var(--color-transparent)) 1px, var(--color-transparent) 1px);
    background-size: 26px 26px;
    opacity: 0.46;
}

.conversation-visual {
    place-items: center;
    gap: var(--space-4);
    padding: var(--space-5);
}

.prep-phone,
.prep-buyer-question {
    position: relative;
    z-index: 2;
    display: grid;
    place-items: center;
    border: 1px solid color-mix(in oklab, var(--color-primary-dark) 22%, var(--color-rule));
    border-radius: var(--radius-pill);
    background: var(--color-paper-raised);
    color: var(--color-primary-dark);
    box-shadow: var(--shadow-soft);
}

.prep-phone {
    width: 66px;
    height: 66px;
}

.prep-phone svg {
    width: 28px;
    height: 28px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
}

.prep-sheet {
    position: relative;
    z-index: 2;
    display: grid;
    gap: var(--space-2);
    border: 1px solid color-mix(in oklab, var(--color-rule) 80%, var(--color-transparent));
    border-radius: var(--radius-md);
    padding: var(--space-4);
    background: color-mix(in oklab, var(--color-white) 88%, var(--color-paper));
    box-shadow: var(--shadow-soft);
}

.prep-sheet::before,
.prep-sheet::after {
    display: none;
}

.prep-sheet span {
    color: var(--color-primary-dark);
    font-size: 0.62rem;
    font-weight: 950;
    letter-spacing: 0.08em;
    line-height: 1;
    text-transform: uppercase;
}

.prep-sheet b {
    border-radius: var(--radius-sm);
    padding: 0.42rem 0.55rem;
    background: color-mix(in oklab, var(--color-primary-dark) 9%, var(--color-paper-raised));
    color: var(--color-ink);
    font-size: 0.78rem;
    font-weight: 900;
    line-height: 1;
}

.prep-sheet b:nth-child(3) {
    background: color-mix(in oklab, var(--color-accent) 22%, var(--color-paper-raised));
}

.prep-sheet b:nth-child(4) {
    background: color-mix(in oklab, var(--color-success) 18%, var(--color-paper-raised));
}

/* Chat thread visual */
.chat-thread {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-2);
    width: 100%;
    max-width: 240px;
}

.chat-meta {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.1em;
}

.chat-sender {
    color: var(--color-ink);
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0;
    line-height: 1.2;
}

.chat-time {
    color: color-mix(in oklab, var(--color-ink) 44%, var(--color-transparent));
    font-size: 0.66rem;
    font-weight: 400;
    line-height: 1.2;
}

.chat-bubble {
    align-self: flex-start;
    background: color-mix(in oklab, var(--color-primary-dark) 10%, var(--color-paper-raised));
    border-radius: 1.1rem 1.1rem 1.1rem 0.28rem;
    padding: 0.6rem 0.9rem;
    color: var(--color-ink);
    font-size: 0.9rem;
    font-weight: 500;
    line-height: 1.35;
}

.chat-typing {
    align-self: flex-start;
    display: flex;
    align-items: center;
    gap: 0.28rem;
    background: color-mix(in oklab, var(--color-primary-dark) 10%, var(--color-paper-raised));
    border-radius: 1.1rem 1.1rem 1.1rem 0.28rem;
    padding: 0.52rem 0.72rem;
}

.chat-typing span {
    display: block;
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: color-mix(in oklab, var(--color-ink) 38%, var(--color-transparent));
}

.prep-buyer-question {
    width: 54px;
    height: 54px;
    border-color: color-mix(in oklab, var(--color-accent) 32%, var(--color-rule));
    color: var(--color-accent-dark);
    font-family: var(--type-display);
    font-size: 1.5rem;
    font-weight: 900;
    line-height: 1;
}

.priority-key i,
.builder-column i,
.output-doc span,
.dashboard-panel i {
    display: block;
    border-radius: var(--radius-pill);
}

.priority-visual {
    align-items: center;
    justify-items: start;
    padding: var(--space-4);
}

.priority-orbit {
    position: relative;
    display: grid;
    width: 130px;
    height: 130px;
    place-items: center;
    border-radius: var(--radius-pill);
    background: conic-gradient(
        var(--color-critical) 0 18%,
        var(--color-moderate) 18% 48%,
        var(--color-minor) 48% 100%
    );
    box-shadow:
        inset 0 0 0 17px color-mix(in oklab, var(--color-white) 84%, var(--color-paper)),
        var(--shadow-soft);
}

.priority-orbit::before {
    content: "";
    position: absolute;
    inset: 34px;
    border-radius: var(--radius-pill);
    background: color-mix(in oklab, var(--color-white) 86%, var(--color-paper));
}

.priority-orbit strong {
    position: relative;
    max-width: none;
    color: var(--color-primary-dark);
    font-size: 2rem;
    line-height: 1;
}

.priority-dot {
    display: none;
}

.dot-one {
    top: 14px;
    right: 18px;
    background: var(--color-critical);
}

.dot-two {
    right: 7px;
    bottom: 34px;
    background: var(--color-moderate);
}

.dot-three {
    bottom: 13px;
    left: 27px;
    background: var(--color-minor);
}

.priority-key {
    position: absolute;
    right: var(--space-4);
    top: 50%;
    transform: translateY(-50%);
    display: grid;
    width: 118px;
    gap: var(--space-1);
}

.priority-key b {
    display: grid;
    grid-template-columns: 1.35rem minmax(0, 1fr) auto;
    gap: var(--space-1);
    align-items: center;
    min-width: 0;
    color: var(--color-muted);
    font-size: 0.58rem;
    font-style: normal;
    font-weight: 900;
    letter-spacing: 0.04em;
    line-height: 1;
    text-transform: uppercase;
}

.priority-key span {
    display: grid;
    width: 1.35rem;
    height: 1.35rem;
    place-items: center;
    border-radius: var(--radius-pill);
    background: var(--color-paper-raised);
    color: var(--color-ink);
    font-family: var(--type-display);
    font-size: 0.78rem;
    letter-spacing: 0;
    box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--color-rule) 88%, var(--color-transparent));
}

.priority-key em {
    font-style: normal;
}

.priority-key i {
    height: 7px;
}

.priority-key b:nth-child(1) i {
    width: 100%;
    background: var(--color-critical);
}

.priority-key b:nth-child(2) i {
    width: 76%;
    background: var(--color-moderate);
}

.priority-key b:nth-child(3) i {
    width: 54%;
    background: var(--color-minor);
}

.builder-visual {
    grid-template-columns: minmax(58px, 1fr) 32px minmax(70px, 1.08fr);
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-5);
}

.builder-column {
    display: grid;
    min-height: 112px;
    align-content: center;
    gap: var(--space-3);
    border: 1px solid color-mix(in oklab, var(--color-rule) 84%, var(--color-transparent));
    border-radius: var(--radius-md);
    padding: var(--space-4);
    background: color-mix(in oklab, var(--color-white) 72%, var(--color-paper));
}

.source-items i {
    height: 13px;
    background: color-mix(in oklab, var(--color-muted) 58%, var(--color-rule));
}

.source-items i:nth-child(2) {
    width: 72%;
    background: color-mix(in oklab, var(--color-accent) 62%, var(--color-rule));
}

.source-items i:nth-child(3) {
    width: 46%;
    background: color-mix(in oklab, var(--color-minor) 64%, var(--color-rule));
}

.builder-arrow {
    position: relative;
    height: 3px;
    border-radius: var(--radius-pill);
    background: color-mix(in oklab, var(--color-primary-dark) 76%, var(--color-rule));
}

.builder-arrow::after {
    content: "";
    position: absolute;
    top: 50%;
    right: -1px;
    width: 12px;
    height: 12px;
    border-top: 3px solid color-mix(in oklab, var(--color-primary-dark) 76%, var(--color-rule));
    border-right: 3px solid color-mix(in oklab, var(--color-primary-dark) 76%, var(--color-rule));
    transform: translateY(-50%) rotate(45deg);
}

.output-doc {
    border-color: color-mix(in oklab, var(--color-primary-dark) 24%, var(--color-rule));
    background: var(--color-paper-raised);
}

.output-doc span {
    height: 9px;
    background: color-mix(in oklab, var(--color-primary-dark) 38%, var(--color-rule));
}

.output-doc span:nth-child(2) {
    width: 68%;
}

.output-doc b {
    width: fit-content;
    border-radius: var(--radius-sm);
    padding: 0.28rem 0.44rem;
    background: var(--color-primary-dark);
    color: var(--color-white);
    font-size: 0.64rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    line-height: 1;
}

.buyer-visual {
    grid-template-columns: 0.9fr 36px 1.1fr;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-5);
}

.dashboard-panel {
    display: grid;
    min-height: 126px;
    align-content: center;
    gap: var(--space-2);
    min-width: 0;
    border: 1px solid color-mix(in oklab, var(--color-rule) 84%, var(--color-transparent));
    border-radius: var(--radius-md);
    padding: var(--space-4);
    background: color-mix(in oklab, var(--color-white) 78%, var(--color-paper));
}

.dashboard-panel span {
    display: block;
    color: var(--color-primary-dark);
    font-size: 0.6rem;
    font-weight: 950;
    letter-spacing: 0.08em;
    line-height: 1;
    text-transform: uppercase;
}

.mini-donut {
    width: 42px;
    height: 42px;
    border-radius: var(--radius-pill);
    background: conic-gradient(var(--color-critical) 0 18%, var(--color-moderate) 18% 48%, var(--color-minor) 48% 100%);
    box-shadow: inset 0 0 0 10px color-mix(in oklab, var(--color-white) 88%, var(--color-paper));
}

.dashboard-panel i {
    height: 8px;
    background: color-mix(in oklab, var(--color-primary-dark) 34%, var(--color-rule));
}

.dashboard-panel i:nth-of-type(2) {
    width: 72%;
}

.buyer-panel {
    position: relative;
    background:
        radial-gradient(circle at 82% 16%, color-mix(in oklab, var(--color-accent-light) 22%, var(--color-transparent)), var(--color-transparent) 38%),
        var(--color-paper-raised);
}

.buyer-summary {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--space-1);
}

.buyer-summary b {
    display: block;
    height: 38px;
    border-radius: var(--radius-sm);
    background: color-mix(in oklab, var(--color-primary-dark) 13%, var(--color-paper-raised));
}

.buyer-summary b:nth-child(2) {
    background: color-mix(in oklab, var(--color-accent) 24%, var(--color-paper-raised));
}

.buyer-summary b:nth-child(3) {
    background: color-mix(in oklab, var(--color-success) 20%, var(--color-paper-raised));
}

.share-line {
    position: relative;
    display: grid;
    width: 100%;
    height: 3px;
    place-items: center;
    border-radius: var(--radius-pill);
    background: color-mix(in oklab, var(--color-success) 80%, var(--color-rule));
}

.share-line::before,
.share-line::after {
    content: "";
    position: absolute;
    top: 50%;
    width: 9px;
    height: 9px;
    border-radius: var(--radius-pill);
    background: var(--color-success);
    transform: translateY(-50%);
}

.share-line::before {
    left: -2px;
}

.share-line::after {
    right: -2px;
}

.share-line svg {
    position: relative;
    z-index: 2;
    display: grid;
    width: 28px;
    height: 28px;
    border: 2px solid var(--color-paper-raised);
    border-radius: var(--radius-pill);
    padding: 0.34rem;
    background: var(--color-success);
    color: var(--color-white);
    fill: none;
    stroke: currentColor;
    stroke-width: 3;
    box-shadow: 0 14px 26px -18px var(--color-ink);
}

.product-tile strong {
    display: block;
    max-width: 680px;
    margin-top: 0;
    font-family: var(--type-display);
    font-size: clamp(1.24rem, 2vw, 1.75rem);
    line-height: 1;
}

.product-tile p {
    margin-top: 0;
    font-size: 0.96rem;
    font-weight: 650;
    line-height: 1.42;
}

.workflow-simplified {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(300px, 0.85fr);
    gap: var(--space-6);
    align-items: stretch;
    margin-top: var(--space-8);
}

.workflow-animation {
    --workflow-pdf-travel: 205px;
    position: relative;
    min-height: 360px;
    overflow: hidden;
    border: 1px solid var(--color-rule);
    border-radius: var(--radius-xl);
    background:
        radial-gradient(circle at 20% 20%, color-mix(in oklab, var(--color-accent-light) 30%, var(--color-transparent)), var(--color-transparent) 34%),
        color-mix(in oklab, var(--color-white) 84%, var(--color-paper));
    box-shadow: var(--shadow-soft);
}

.workflow-animation::before {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, color-mix(in oklab, var(--color-rule) 38%, var(--color-transparent)) 1px, var(--color-transparent) 1px),
        linear-gradient(180deg, color-mix(in oklab, var(--color-rule) 38%, var(--color-transparent)) 1px, var(--color-transparent) 1px);
    background-size: 34px 34px;
    content: "";
    opacity: 0.5;
}

.workflow-animation::after {
    display: none;
}

.workflow-pdf-card,
.workflow-upload-node,
.workflow-binsr-card {
    position: absolute;
    z-index: 1;
}

.workflow-pdf-card {
    top: 72px;
    left: 8%;
    display: grid;
    width: min(188px, 32%);
    min-height: 230px;
    gap: var(--space-3);
    align-content: start;
    border: 1px solid var(--color-rule);
    border-radius: var(--radius-lg);
    padding: var(--space-5);
    background: var(--color-paper-raised);
    box-shadow: var(--shadow-lifted);
    transform: rotate(-4deg);
    animation: workflowPdfIn 7.2s var(--ease-in-out) infinite;
}

.workflow-pdf-card .report-topline > span {
    font-size: 0.58rem;
}

.workflow-pdf-card strong {
    font-family: var(--type-display);
    font-size: 1.75rem;
    line-height: 1;
}

.workflow-pdf-card .report-note {
    padding: 0.55rem 0.62rem;
    font-size: 0.68rem;
}

.workflow-upload-node {
    top: 50%;
    left: 50%;
    display: grid;
    width: 190px;
    min-height: 132px;
    place-items: center;
    gap: var(--space-2);
    border: 2px dashed color-mix(in oklab, var(--color-primary-dark) 45%, var(--color-rule));
    border-radius: var(--radius-lg);
    padding: var(--space-4);
    background: color-mix(in oklab, var(--color-white) 82%, var(--color-paper-raised));
    box-shadow: var(--shadow-soft);
    transform: translate(-50%, -50%);
    animation: workflowUploadNode 7.2s var(--ease-in-out) infinite;
}

.workflow-upload-node svg {
    width: 42px;
    height: 42px;
    border-radius: var(--radius-pill);
    padding: 0.62rem;
    background: var(--color-primary-dark);
    color: var(--color-white);
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
}

.workflow-upload-node span {
    color: var(--color-primary-dark);
    font-size: 0.72rem;
    font-weight: 950;
    letter-spacing: 0.08em;
    line-height: 1;
    text-transform: uppercase;
}

.workflow-upload-node i {
    display: block;
    width: 118px;
    height: 8px;
    overflow: hidden;
    border-radius: var(--radius-pill);
    background: color-mix(in oklab, var(--color-primary-dark) 12%, var(--color-paper-raised));
}

.workflow-upload-node b {
    display: block;
    width: 100%;
    height: 100%;
    border-radius: inherit;
    background: var(--color-accent);
    transform: scaleX(0);
    transform-origin: left center;
    animation: workflowUploadFill 7.2s var(--ease-in-out) infinite;
}

.workflow-binsr-card {
    top: 54px;
    right: 7%;
    display: grid;
    width: min(260px, 40%);
    gap: var(--space-3);
    border: 1px solid var(--color-rule);
    border-radius: var(--radius-lg);
    padding: var(--space-4);
    background: var(--color-paper-raised);
    box-shadow: var(--shadow-lifted);
    opacity: 0;
    transform: translateY(22px) scale(0.94);
    animation: workflowBinsrOut 7.2s var(--ease-in-out) infinite;
}

.workflow-binsr-card h3 {
    font-size: 1.35rem;
}

.workflow-result-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--space-2);
}

.workflow-result-grid span {
    min-height: 54px;
    border-radius: var(--radius-sm);
    padding: var(--space-3);
    background: color-mix(in oklab, var(--color-primary-dark) 9%, var(--color-paper-raised));
    color: var(--color-primary-dark);
    font-size: 0.62rem;
    font-weight: 950;
    letter-spacing: 0.06em;
    line-height: 1.1;
    text-transform: uppercase;
}

.workflow-result-grid span:nth-child(2) {
    background: color-mix(in oklab, var(--color-accent) 22%, var(--color-paper-raised));
}

.workflow-result-grid span:nth-child(3) {
    background: color-mix(in oklab, var(--color-success) 18%, var(--color-paper-raised));
}

.workflow-track {
    display: grid;
    gap: var(--space-4);
}

.workflow-track article {
    padding: var(--space-5);
}

.workflow-track strong {
    display: block;
    margin-top: var(--space-4);
    font-family: var(--type-display);
    font-size: 1.35rem;
    line-height: 1.05;
}

.workflow-track p {
    margin-top: var(--space-4);
    font-weight: 650;
}

.outcome {
    display: grid;
    gap: var(--space-8);
    align-items: stretch;
}

.outcome-copy {
    display: grid;
    max-width: 62ch;
}

.outcome-copy h2 {
    margin-top: var(--space-5);
    font-size: clamp(2.35rem, 4vw, 3.7rem);
    line-height: 0.96;
}

.outcome-copy p:not(.kicker) {
    max-width: 44ch;
    margin-top: var(--space-5);
    color: var(--color-muted);
    font-size: 1.08rem;
    font-weight: 700;
}

/* ── Outcome split board: chaos (dark) → product (light) ─────── */
.outcome-board {
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: stretch;
    border: 1px solid var(--color-rule);
    border-radius: var(--radius-xl);
    overflow: hidden;
    background: var(--color-paper-raised);
    box-shadow: var(--shadow-lifted);
}

.split-before {
    position: relative;
    display: grid;
    align-content: start;
    gap: var(--space-5);
    padding: var(--space-6);
    overflow: hidden;
    background:
        radial-gradient(circle at 12% 6%, color-mix(in oklab, var(--color-primary) 55%, var(--color-transparent)), var(--color-transparent) 52%),
        radial-gradient(circle at 92% 96%, color-mix(in oklab, var(--color-accent) 30%, var(--color-transparent)), var(--color-transparent) 46%),
        linear-gradient(158deg, var(--color-primary-dark), color-mix(in oklab, var(--color-primary-dark) 72%, #0b1417));
    color: var(--color-white);
}

.split-after {
    display: grid;
    align-content: start;
    gap: var(--space-5);
    padding: var(--space-6);
    background:
        radial-gradient(circle at 88% 10%, color-mix(in oklab, var(--color-accent-light) 26%, var(--color-transparent)), var(--color-transparent) 42%),
        color-mix(in oklab, var(--color-white) 72%, var(--color-paper));
}

.split-tag {
    display: inline-flex;
    align-items: center;
    gap: 0.45em;
    width: fit-content;
    border-radius: var(--radius-pill);
    padding: 0.34rem 0.72rem;
    font-size: 0.66rem;
    font-weight: 950;
    letter-spacing: 0.08em;
    line-height: 1;
    text-transform: uppercase;
}

.split-tag::before {
    content: "";
    width: 7px;
    height: 7px;
    border-radius: 50%;
}

.split-tag--before {
    border: 1px solid color-mix(in oklab, var(--color-white) 30%, var(--color-transparent));
    background: color-mix(in oklab, var(--color-white) 12%, var(--color-transparent));
    color: color-mix(in oklab, var(--color-white) 90%, var(--color-transparent));
}

.split-tag--before::before {
    background: var(--color-accent);
}

.split-tag--after {
    border: 1px solid color-mix(in oklab, var(--color-success) 48%, var(--color-rule));
    background: color-mix(in oklab, var(--color-success) 16%, var(--color-paper-raised));
    color: color-mix(in oklab, var(--color-ink) 76%, var(--color-success));
}

.split-tag--after::before {
    background: var(--color-success);
}

/* Left: messy stacked report sheets with buyer texts piling on top */
.panic-stage {
    position: relative;
    min-height: 500px;
}

/* the dense inspection report — the agony of 47 pages of jargon */
.report-stack {
    position: absolute;
    z-index: 1;
    top: 44%;
    left: 10%;
    width: 210px;
    transform: translateY(-52%) rotate(-5deg);
}

.report-page {
    border-radius: var(--radius-md);
    background:
        linear-gradient(180deg, var(--color-white) 0 30px, var(--color-paper-raised) 30px),
        var(--color-paper-raised);
    box-shadow: 0 30px 60px -30px #000;
}

.report-page--c,
.report-page--b,
.report-page--d,
.report-page--e {
    position: absolute;
    inset: 0;
}

.report-page--e {
    transform: rotate(10deg) translate(20px, 16px);
    background: color-mix(in oklab, var(--color-white) 70%, var(--color-paper));
    opacity: 0.7;
}

.report-page--d {
    transform: rotate(-7deg) translate(-15px, 11px);
    background: color-mix(in oklab, var(--color-white) 76%, var(--color-paper));
    opacity: 0.78;
}

.report-page--c {
    transform: rotate(7deg) translate(12px, 10px);
    background: color-mix(in oklab, var(--color-white) 80%, var(--color-paper));
    opacity: 0.85;
}

.report-page--b {
    transform: rotate(-3.5deg) translate(-8px, 5px);
    background: color-mix(in oklab, var(--color-white) 90%, var(--color-paper));
    opacity: 0.92;
}

.report-page--a {
    position: relative;
    z-index: 2;
    display: grid;
    gap: 0.45rem;
    align-content: start;
    padding: 0.6rem 0.65rem 0.5rem;
    border: 1px solid color-mix(in oklab, var(--color-ink) 8%, var(--color-transparent));
}

.rp-titlebar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.4rem;
    margin-bottom: 0.1rem;
    padding-bottom: 0.4rem;
    border-bottom: 1.5px solid color-mix(in oklab, var(--color-ink) 14%, var(--color-paper));
}

.rp-doc {
    font-size: 0.56rem;
    font-weight: 950;
    letter-spacing: 0.01em;
    color: var(--color-ink);
}

.rp-pages {
    flex-shrink: 0;
    border-radius: var(--radius-sm);
    padding: 0.1rem 0.34rem;
    background: color-mix(in oklab, var(--color-ink) 12%, var(--color-paper));
    color: var(--color-muted);
    font-size: 0.48rem;
    font-weight: 900;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.rp-block {
    display: grid;
    gap: 0.28rem;
}

.rp-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.4rem;
}

.rp-head--sub {
    margin-top: 0.2rem;
    padding-top: 0.4rem;
    border-top: 1px solid var(--color-rule);
}

.rp-section {
    color: var(--color-primary-dark);
    font-size: 0.54rem;
    font-weight: 950;
    letter-spacing: 0.04em;
    line-height: 1;
    text-transform: uppercase;
}

.rp-flag {
    border-radius: var(--radius-sm);
    padding: 0.14rem 0.36rem;
    background: color-mix(in oklab, var(--color-critical) 18%, var(--color-paper-raised));
    color: color-mix(in oklab, var(--color-critical) 72%, var(--color-ink));
    font-size: 0.46rem;
    font-weight: 950;
    letter-spacing: 0.05em;
    line-height: 1;
    text-transform: uppercase;
}

.rp-flag--safety {
    background: color-mix(in oklab, var(--color-moderate) 22%, var(--color-paper-raised));
    color: color-mix(in oklab, var(--color-moderate) 70%, var(--color-ink));
}

.rp-line {
    margin: 0;
    color: color-mix(in oklab, var(--color-ink) 80%, var(--color-transparent));
    font-size: 0.6rem;
    font-weight: 600;
    line-height: 1.4;
}

.rp-line mark {
    background: color-mix(in oklab, var(--color-critical) 24%, var(--color-paper-raised));
    color: inherit;
    border-radius: 0.2em;
    padding: 0 0.16em;
}

.rp-bar {
    height: 5px;
    border-radius: 3px;
    background: color-mix(in oklab, var(--color-ink) 11%, var(--color-paper));
}

.rp-bar--short {
    width: 56%;
}

.rp-foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.4rem;
    margin-top: 0.3rem;
    padding-top: 0.4rem;
    border-top: 1px solid var(--color-rule);
}

.rp-page {
    font-size: 0.5rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--color-muted);
}

/* Manual-triage scribbles — the agent's "which of these matters?" burden */
.triage-notes {
    position: absolute;
    inset: 0;
    z-index: 5;
    pointer-events: none;
}

.tnote {
    position: absolute;
    padding: 0.2rem 0.55rem;
    border-radius: 3px 8px 6px 4px;
    background: var(--color-accent);
    color: var(--color-primary-dark);
    font-family: var(--type-display);
    font-size: 0.62rem;
    font-weight: 700;
    line-height: 1;
    box-shadow: 0 4px 10px -4px rgba(0, 0, 0, 0.5);
}

/* Straddling the fanned page edges — half inside front page, half on the visible back-page edge */
.tnote--1 {
    top: 16%;
    left: -20px;
    transform: rotate(-5deg);
}

.tnote--2 {
    top: 48%;
    left: -20px;
    background: color-mix(in oklab, var(--color-critical) 78%, var(--color-white));
    color: var(--color-white);
    transform: rotate(4deg);
}

.tnote--3 {
    bottom: 20%;
    left: -20px;
    transform: rotate(-3deg);
}

/* iPhone — the client's panic, blowing up on top of the report */
.phone {
    position: absolute;
    z-index: 3;
    top: 50%;
    right: 3%;
    transform: translateY(-50%) rotate(3.5deg) scale(0.9);
    width: min(50%, 206px);
    padding: 9px;
    border-radius: 42px;
    background: linear-gradient(160deg, #1c1c1e, #0a0a0b);
    border: 1px solid rgba(255,255,255,0.12);
    box-shadow:
        0 56px 100px -36px rgba(0,0,0,0.9),
        inset 0 1px 0 rgba(255,255,255,0.15),
        inset 0 -1px 0 rgba(0,0,0,0.6);
}

.phone-island {
    position: absolute;
    top: 10px;
    left: 50%;
    transform: translateX(-50%);
    width: 76px;
    height: 22px;
    border-radius: 20px;
    background: #000;
    z-index: 10;
}

.phone-screen {
    border-radius: 34px;
    overflow: hidden;
    background: #fff;
    display: flex;
    flex-direction: column;
}

/* iOS status bar */
.ios-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 9px 14px 5px;
    background: #fff;
    font-family: -apple-system, 'SF Pro Text', sans-serif;
}

.ios-time {
    font-size: 0.82rem;
    font-weight: 700;
    color: #000;
    letter-spacing: -0.01em;
}

.ios-status {
    display: flex;
    align-items: center;
    gap: 5px;
    color: #000;
}

.ios-battery {
    display: inline-flex;
    align-items: center;
    width: 22px;
    height: 11px;
    border: 1.5px solid rgba(0,0,0,0.35);
    border-radius: 2.5px;
    padding: 1.5px;
    position: relative;
}

.ios-battery::after {
    content: '';
    position: absolute;
    right: -4px;
    top: 50%;
    transform: translateY(-50%);
    width: 2px;
    height: 5px;
    background: rgba(0,0,0,0.35);
    border-radius: 0 1px 1px 0;
}

.ios-battery-fill {
    display: block;
    width: 72%;
    height: 100%;
    border-radius: 1px;
    background: #30d158;
}

/* iMessage header */
.imsg-header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 4px 12px 7px;
    background: #fff;
    border-bottom: 1px solid #e5e5ea;
}

.imsg-back {
    color: #007aff;
    display: flex;
    align-items: center;
    flex-shrink: 0;
}

.imsg-contact {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    flex: 1;
    min-width: 0;
}

.imsg-avatar {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: linear-gradient(135deg, #5e5ce6, #007aff);
    color: #fff;
    font-size: 0.56rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-family: -apple-system, 'SF Pro Text', sans-serif;
}

.imsg-name-wrap {
    display: grid;
    gap: 0.08rem;
    min-width: 0;
}

.imsg-name {
    font-size: 0.78rem;
    font-weight: 700;
    color: #000;
    font-family: -apple-system, 'SF Pro Text', sans-serif;
    line-height: 1;
}

.imsg-online {
    font-size: 0.52rem;
    font-weight: 500;
    color: #8e8e93;
    font-family: -apple-system, 'SF Pro Text', sans-serif;
}

.imsg-actions {
    color: #007aff;
    flex-shrink: 0;
}

/* message thread */
.imsg-body {
    display: grid;
    justify-items: start;
    gap: 0.3rem;
    padding: 0.5rem 0.75rem 0.55rem;
    background: #f2f2f7;
}

.imsg-time-sep {
    justify-self: center;
    font-size: 0.52rem;
    font-weight: 600;
    color: #8e8e93;
    font-family: -apple-system, 'SF Pro Text', sans-serif;
    margin-bottom: 0.1rem;
}

.imsg-row {
    display: grid;
    justify-items: start;
}

.ibubble {
    max-width: 88%;
    border-radius: 18px 18px 18px 4px;
    padding: 0.42rem 0.65rem;
    background: #e9e9eb;
    color: #000;
    font-size: 0.65rem;
    font-weight: 400;
    line-height: 1.3;
    font-family: -apple-system, 'SF Pro Text', sans-serif;
}

.ibubble--urgent {
    background: #e9e9eb;
    color: #000;
    font-weight: 500;
}

.ibubble--file {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    max-width: 94%;
    padding: 0.4rem 0.55rem;
}

.ifile-ic {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 34px;
    flex-shrink: 0;
    border-radius: 5px;
    background: #ff3b30;
    color: #fff;
    font-size: 0.44rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    font-family: -apple-system, 'SF Pro Text', sans-serif;
}

.ifile-meta {
    display: grid;
    gap: 0.1rem;
    font-size: 0.58rem;
    font-weight: 500;
    line-height: 1.2;
    color: #8e8e93;
    font-family: -apple-system, 'SF Pro Text', sans-serif;
}

.ifile-meta b {
    font-size: 0.68rem;
    font-weight: 700;
    color: #000;
}

/* missed calls system line */
.isys-call {
    justify-self: center;
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    margin: 0.1rem 0;
    padding: 0.18rem 0.55rem;
    border-radius: var(--radius-pill);
    background: rgba(255, 59, 48, 0.1);
    color: #ff3b30;
    font-size: 0.56rem;
    font-weight: 700;
    font-family: -apple-system, 'SF Pro Text', sans-serif;
}

/* typing indicator */
.ityping {
    display: inline-flex;
    gap: 3px;
    padding: 0.5rem 0.6rem;
    border-radius: 18px 18px 18px 4px;
    background: #e9e9eb;
}

.ityping span {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #8e8e93;
    animation: imsg-bounce 1.2s infinite ease-in-out;
}

.ityping span:nth-child(2) { animation-delay: 0.18s; }
.ityping span:nth-child(3) { animation-delay: 0.36s; }

@keyframes imsg-bounce {
    0%, 60%, 100% { transform: translateY(0); opacity: 0.4; }
    30% { transform: translateY(-3px); opacity: 1; }
}

@media (prefers-reduced-motion: reduce) {
    .ityping span { animation: none; }
}

/* iMessage input bar */
.imsg-input {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.45rem 0.6rem 0.55rem;
    background: #f2f2f7;
    border-top: 1px solid #e5e5ea;
}

.imsg-input-field {
    flex: 1;
    border-radius: 18px;
    padding: 0.36rem 0.65rem;
    background: #fff;
    border: 1px solid #e5e5ea;
    font-size: 0.68rem;
    font-weight: 400;
    color: #c7c7cc;
    font-family: -apple-system, 'SF Pro Text', sans-serif;
}

.imsg-send {
    width: 26px;
    height: 26px;
    border-radius: 50%;
    background: #007aff;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

/* iPhone home indicator */
.phone-home-bar {
    width: 80px;
    height: 3px;
    border-radius: 2px;
    background: rgba(255,255,255,0.3);
    margin: 3px auto 0;
}

/* Right: the Clear Casa dashboard, condensed into an app window */
.app-window {
    border: 1px solid var(--color-rule);
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: color-mix(in oklab, var(--color-paper) 55%, var(--color-white));
    box-shadow: var(--shadow-soft);
}

.app-bar {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: 0.5rem 0.75rem;
    border-bottom: 1px solid var(--color-rule);
    background: var(--color-white);
}

.app-brand {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    font-family: var(--type-display);
    font-size: 0.76rem;
    font-weight: 700;
    color: var(--color-primary-dark);
}

.app-brand-logo {
    width: 15px;
    height: auto;
}

.app-bar-title {
    font-family: var(--type-display);
    font-size: 0.78rem;
    font-weight: 800;
    color: var(--color-primary-dark);
    letter-spacing: -0.01em;
}

.app-address {
    margin-left: auto;
    font-size: 0.62rem;
    font-weight: 600;
    color: var(--color-muted);
}

.app-body {
    display: grid;
    gap: var(--space-2);
    padding: var(--space-3);
}

.app-row--top {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-2);
}

.app-card-title {
    font-size: 0.58rem;
    font-weight: 900;
    letter-spacing: 0.04em;
    line-height: 1.1;
    text-transform: uppercase;
    color: var(--color-muted);
}

/* Three product zones: prioritized issues, BINSR candidates, buyer prep */
.zone {
    display: grid;
    gap: 0.5rem;
    border: 1px solid var(--color-rule);
    border-radius: var(--radius-md);
    padding: 0.7rem 0.8rem;
    background: var(--color-white);
}

.zone-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
}

.zone-meta {
    font-size: 0.58rem;
    font-weight: 900;
    letter-spacing: 0.02em;
    color: var(--color-muted);
}

.zone-meta--accent {
    border-radius: var(--radius-pill);
    padding: 0.12rem 0.45rem;
    background: color-mix(in oklab, var(--color-success) 16%, var(--color-paper-raised));
    color: color-mix(in oklab, var(--color-success) 62%, var(--color-ink));
}

/* Zone 1 — prioritized issues severity bar */
.sev-bar {
    display: flex;
    height: 9px;
    border-radius: var(--radius-pill);
    overflow: hidden;
    background: color-mix(in oklab, var(--color-ink) 8%, var(--color-paper));
}

.sev-seg--critical { background: var(--color-critical); }
.sev-seg--moderate { background: var(--color-moderate); }
.sev-seg--minor { background: var(--color-minor); }

.sev-keys {
    display: flex;
    flex-wrap: wrap;
    gap: 0.3rem 0.8rem;
}

.sev-key {
    display: inline-flex;
    align-items: center;
    gap: 0.32rem;
    font-size: 0.62rem;
    font-weight: 700;
    color: var(--color-muted);
}

.sev-key b {
    color: var(--color-ink);
    font-weight: 900;
}

.sev-key::before {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 2px;
}

.sev-key--critical::before { background: var(--color-critical); }
.sev-key--moderate::before { background: var(--color-moderate); }
.sev-key--minor::before { background: var(--color-minor); }

/* Zone 2 — BINSR candidate rows with add/added state */
.binsr-list {
    display: grid;
    gap: 0.4rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.binsr-item {
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: center;
    column-gap: 0.55rem;
    row-gap: 0.1rem;
    padding: 0.4rem 0.45rem;
    border: 1px solid var(--color-rule);
    border-radius: var(--radius-sm);
    background: var(--color-paper-raised);
}

.binsr-item--added {
    border-color: color-mix(in oklab, var(--color-success) 40%, var(--color-rule));
    background: color-mix(in oklab, var(--color-success) 8%, var(--color-white));
}

.binsr-state {
    grid-row: span 2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 44px;
    padding: 0.22rem 0.4rem;
    border-radius: var(--radius-pill);
    background: var(--color-success);
    color: var(--color-white);
    font-size: 0.54rem;
    font-weight: 900;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.binsr-state--add {
    background: color-mix(in oklab, var(--color-ink) 10%, var(--color-paper));
    color: color-mix(in oklab, var(--color-ink) 70%, var(--color-muted));
}

.binsr-name {
    font-size: 0.7rem;
    font-weight: 800;
    line-height: 1.15;
    color: var(--color-ink);
}

.binsr-meta {
    font-size: 0.6rem;
    font-weight: 700;
    color: var(--color-muted);
}

.binsr-meta .bsafety {
    font-style: normal;
    font-weight: 900;
    color: color-mix(in oklab, var(--color-moderate) 72%, var(--color-ink));
}

/* Zone 3 — buyer call prep talking points + reassurance */
.prep-points {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
}

.prep-chip {
    border-radius: var(--radius-pill);
    padding: 0.26rem 0.55rem;
    background: color-mix(in oklab, var(--color-accent) 14%, var(--color-paper-raised));
    color: color-mix(in oklab, var(--color-accent-dark) 88%, var(--color-ink));
    font-size: 0.62rem;
    font-weight: 800;
}

.prep-reassure {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    margin: 0;
    padding-top: 0.55rem;
    border-top: 1px solid var(--color-rule);
    font-size: 0.66rem;
    font-weight: 700;
    color: color-mix(in oklab, var(--color-success) 50%, var(--color-ink));
}

.prep-check {
    flex-shrink: 0;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--color-success);
    position: relative;
}

.prep-check::after {
    content: "";
    position: absolute;
    left: 4.5px;
    top: 2.5px;
    width: 3px;
    height: 6px;
    border: solid var(--color-white);
    border-width: 0 1.8px 1.8px 0;
    transform: rotate(45deg);
}

/* Value-prop status strip */
.value-strip {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
}

.value-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    border-radius: var(--radius-pill);
    padding: 0.3rem 0.6rem;
    background: color-mix(in oklab, var(--color-success) 12%, var(--color-paper-raised));
    color: color-mix(in oklab, var(--color-success) 60%, var(--color-ink));
    font-size: 0.6rem;
    font-weight: 800;
    letter-spacing: 0.02em;
}

.value-chip .check {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: var(--color-success);
    position: relative;
    flex-shrink: 0;
}

.value-chip .check::after {
    content: "";
    position: absolute;
    left: 3.5px;
    top: 2px;
    width: 3px;
    height: 5px;
    border: solid var(--color-white);
    border-width: 0 1.6px 1.6px 0;
    transform: rotate(45deg);
}

/* ============================================================
   CONTACT — full-bleed dark band with a welcoming stepped form
   ============================================================ */
.contact {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    padding: clamp(3rem, 7vw, 5.5rem) 0;
    color: var(--color-white);
    background:
        radial-gradient(circle at 10% 0%, color-mix(in oklab, var(--color-primary) 42%, var(--color-transparent)), var(--color-transparent) 46%),
        radial-gradient(circle at 92% 100%, color-mix(in oklab, var(--color-accent) 24%, var(--color-transparent)), var(--color-transparent) 44%),
        linear-gradient(160deg, var(--color-primary-dark), color-mix(in oklab, var(--color-primary-dark) 68%, #0a141a));
}

.contact-inner {
    width: min(var(--container), calc(100% - 2rem));
    margin: 0 auto;
    display: grid;
    grid-template-columns: minmax(260px, 0.82fr) minmax(0, 1.18fr);
    gap: clamp(2rem, 5vw, 4rem);
    align-items: start;
}

.contact-copy {
    position: sticky;
    top: 92px;
}

.contact .kicker {
    border-color: color-mix(in oklab, var(--color-white) 22%, var(--color-transparent));
    background: color-mix(in oklab, var(--color-white) 10%, var(--color-transparent));
    color: var(--color-white);
}

.contact-copy h2 {
    line-height: 1.04;
}

.contact-copy p:not(.kicker) {
    margin-top: var(--space-5);
    max-width: 38ch;
    color: color-mix(in oklab, var(--color-white) 78%, var(--color-transparent));
    font-size: 1.08rem;
    font-weight: 600;
}

.contact-assurances {
    list-style: none;
    margin: var(--space-7) 0 0;
    padding: 0;
    display: grid;
    gap: var(--space-3);
}

.contact-assurances li {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    color: color-mix(in oklab, var(--color-white) 86%, var(--color-transparent));
    font-size: 0.95rem;
    font-weight: 600;
}

.contact-assurances svg {
    flex: none;
    color: var(--color-accent);
}

/* The form sits as a bright, inviting card on the dark band */
.contact-form {
    display: grid;
    gap: var(--space-5);
    padding: clamp(1.35rem, 3vw, 2.1rem);
    border: 1px solid color-mix(in oklab, var(--color-white) 14%, var(--color-transparent));
    border-radius: var(--radius-xl);
    background: var(--color-paper-raised);
    box-shadow: 0 40px 90px -45px rgba(0, 0, 0, 0.85);
    color: var(--color-ink);
}

/* Each step is a clearly-chunked group so the brain reads 3, not 11 */
.form-step {
    display: grid;
    gap: var(--space-3);
}

.form-step + .form-step {
    padding-top: var(--space-5);
    border-top: 1px solid var(--color-rule);
}

.form-step-title {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: 0;
    font-family: var(--type-display);
    font-size: 1.04rem;
    font-weight: 800;
    color: var(--color-ink);
}

.step-badge {
    display: inline-grid;
    place-items: center;
    width: 26px;
    height: 26px;
    flex: none;
    border-radius: 50%;
    background: var(--color-primary-dark);
    color: var(--color-white);
    font-family: var(--type-body);
    font-size: 0.82rem;
    font-weight: 800;
}

.form-step--optional .step-badge {
    background: color-mix(in oklab, var(--color-muted) 70%, var(--color-paper));
    color: var(--color-white);
}

.step-optional,
.field-optional {
    font-family: var(--type-body);
    font-size: 0.66rem;
    font-weight: 800;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--color-muted);
}

.step-optional {
    margin-left: auto;
    padding: 0.16rem 0.55rem;
    border: 1px solid var(--color-rule);
    border-radius: var(--radius-pill);
    background: var(--color-paper);
}

.form-step-hint {
    margin: calc(-1 * var(--space-1)) 0 0;
    color: var(--color-muted);
    font-size: 0.86rem;
    font-weight: 600;
}

.form-step .form-grid {
    margin-top: 0;
    gap: var(--space-4) var(--space-4);
}

/* Friendlier fields: bigger targets, soft surfaces, clear focus */
.contact-form input:not([type="checkbox"]),
.contact-form select,
.contact-form textarea {
    min-height: 50px;
    border-radius: var(--radius-md);
    background: var(--color-white);
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.contact-form textarea {
    min-height: 88px;
}

.contact-form input::placeholder,
.contact-form textarea::placeholder {
    color: color-mix(in oklab, var(--color-muted) 70%, var(--color-paper));
}

.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus {
    outline: none;
    border-color: var(--color-primary-dark);
    box-shadow: 0 0 0 3px color-mix(in oklab, var(--color-primary) 26%, var(--color-transparent));
}

.contact-form .checkbox-line {
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-3) var(--space-4);
    border: 1px solid var(--color-rule);
    border-radius: var(--radius-md);
    background: var(--color-paper);
    font-size: 0.82rem;
    font-weight: 700;
}

.contact-form .checkbox-line input {
    margin-top: 0;
}

.contact-submit {
    width: 100%;
    margin-top: 0;
    min-height: 54px;
    font-size: 1.05rem;
}

/* Friendly drag-and-drop tile for the PDF */
.contact-dropzone {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    padding: var(--space-5);
    border: 1.5px dashed color-mix(in oklab, var(--color-primary) 45%, var(--color-rule));
    border-radius: var(--radius-lg);
    background:
        radial-gradient(circle at 18% 0%, color-mix(in oklab, var(--color-accent-light) 50%, var(--color-transparent)), var(--color-transparent) 60%),
        var(--color-paper);
    color: var(--color-ink);
    cursor: pointer;
    transition: border-color 0.15s ease, background 0.15s ease, transform 0.15s ease;
}

.contact-dropzone:hover,
.contact-dropzone.is-dragging {
    border-color: var(--color-primary-dark);
    background: color-mix(in oklab, var(--color-accent-light) 60%, var(--color-paper));
}

.contact-dropzone-icon {
    display: grid;
    place-items: center;
    width: 46px;
    height: 46px;
    flex: none;
    border-radius: var(--radius-md);
    background: var(--color-primary-dark);
    color: var(--color-white);
}

.contact-dropzone-text {
    display: grid;
    gap: 0.18rem;
    min-width: 0;
}

.contact-dropzone-text strong {
    font-family: var(--type-display);
    font-size: 0.98rem;
    font-weight: 800;
    color: var(--color-ink);
}

.contact-dropzone-meta {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--color-muted);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.contact-form.has-file .contact-dropzone {
    border-style: solid;
    border-color: var(--color-success);
    background: color-mix(in oklab, var(--color-success) 12%, var(--color-paper));
}

.contact-form.has-file .contact-dropzone-icon {
    background: var(--color-success);
}

.input-hint,
.form-note {
    font-size: 0.9rem;
    font-weight: 650;
}

.contact .form-note {
    margin-top: 0;
    color: var(--color-muted);
}

.contact .form-status {
    margin-top: 0;
    min-height: 0;
}

/* Contact form inline success state */
.contact-form .contact-success-panel {
    display: none;
}

.contact-form.is-submitted .form-step,
.contact-form.is-submitted .checkbox-line,
.contact-form.is-submitted .contact-submit,
.contact-form.is-submitted .form-note,
.contact-form.is-submitted .form-status {
    display: none;
}

.contact-form.is-submitted .contact-success-panel {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    padding: var(--space-6) var(--space-2);
}

.footer {
    justify-content: space-between;
    align-items: center;
    gap: var(--space-5);
    border-top: 1px solid var(--color-rule);
    padding: var(--space-4) 0 var(--space-5);
}

.footer-brand {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    flex: none;
    text-decoration: none;
    color: var(--color-ink);
}

.footer-brand svg {
    flex: none;
}

.footer-brand span {
    font-family: var(--type-display);
    font-size: 1rem;
    font-weight: 800;
    color: var(--color-ink);
}

.footer-tagline {
    flex: 1;
    min-width: 0;
    padding: 0 var(--space-4);
    font-size: 0.82rem;
    color: var(--color-muted);
    font-weight: 500;
}

.footer nav {
    gap: var(--space-4);
    flex: none;
}

.footer a {
    color: var(--color-muted);
    font-weight: 700;
    text-decoration: none;
}

.fade-in {
    opacity: 0;
    transform: translateY(12px);
    transition: opacity var(--dur-long) var(--ease-out), transform var(--dur-long) var(--ease-out);
}

.fade-in.visible {
    opacity: 1;
    transform: translateY(0);
}

@keyframes storyPdfSequence {
    0% {
        opacity: 1;
        filter: saturate(0.92);
        transform: translate(calc(-50% - 188px), 170px) rotate(-3deg) scale(0.34);
    }

    24% {
        opacity: 1;
        filter: saturate(0.92);
        transform: translate(calc(-50% - 188px), 170px) rotate(-3deg) scale(0.34);
    }

    40%,
    56% {
        opacity: 0.82;
        filter: saturate(0.78);
        transform: translate(-50%, 168px) rotate(0deg) scale(0.18);
    }

    66%,
    100% {
        opacity: 0;
        filter: saturate(0.72);
        transform: translate(-50%, 168px) rotate(0deg) scale(0.14);
    }
}

@keyframes storyUploadBaySequence {
    0%,
    56% {
        opacity: 1;
        transform: translate(-50%, 132px) scale(1);
    }

    66%,
    100% {
        opacity: 0;
        transform: translate(-50%, 132px) scale(0.96);
    }
}

@keyframes uploadProgressFill {
    0%,
    32% {
        transform: scaleX(0);
    }

    56%,
    100% {
        transform: scaleX(1);
    }
}

@keyframes storyDashboardSequence {
    0%,
    66% {
        opacity: 0;
        filter: none;
        transform: translate(-50%, 260px) scale(0.9);
    }

    74%,
    82% {
        opacity: 1;
        filter: none;
        transform: translate(-50%, 112px) scale(1);
    }

    90%,
    100% {
        opacity: 0.32;
        filter: saturate(0.78);
        transform: translate(-50%, 96px) scale(0.72);
    }
}

@keyframes storyUploadSequence {
    0% {
        opacity: 0;
        filter: none;
        transform: translate(-50%, 170px) scale(0.96);
    }

    82% {
        opacity: 0;
        filter: none;
        transform: translate(-50%, 170px) scale(0.96);
    }

    92%,
    100% {
        opacity: 1;
        filter: none;
        transform: translate(-50%, 170px) scale(1);
    }
}

@keyframes storyCardIn {
    0% {
        opacity: 0;
        transform: translateY(14px);
    }

    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes workflowPdfIn {
    0%,
    22% {
        opacity: 1;
        transform: translate(0, 0) rotate(-4deg) scale(1);
    }

    42%,
    54% {
        opacity: 0.7;
        transform: translate(var(--workflow-pdf-travel), 8px) rotate(0deg) scale(0.58);
    }

    68%,
    100% {
        opacity: 0;
        transform: translate(var(--workflow-pdf-travel), 8px) rotate(0deg) scale(0.46);
    }
}

@keyframes workflowUploadFill {
    0%,
    28% {
        transform: scaleX(0);
    }

    54%,
    100% {
        transform: scaleX(1);
    }
}

@keyframes workflowUploadNode {
    0%,
    58% {
        opacity: 1;
    }

    72%,
    100% {
        opacity: 0.34;
    }
}

@keyframes workflowBinsrOut {
    0%,
    58% {
        opacity: 0;
        transform: translateY(22px) scale(0.94);
    }

    72%,
    88% {
        opacity: 1;
        transform: translateY(0) scale(1);
    }

    100% {
        opacity: 0.92;
        transform: translateY(0) scale(1);
    }
}

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-delay: 0ms !important;
        scroll-behavior: auto !important;
        transition-duration: 1ms !important;
        animation-duration: 1ms !important;
    }

    .story-pdf,
    .story-upload-bay {
        opacity: 0 !important;
    }

    .story-upload-card,
    .binsr-drawer,
    .mini-card,
    .mini-action {
        opacity: 1 !important;
    }

    .story-pdf {
        transform: translate(calc(-50% + 76px), 224px) rotate(0deg) scale(0.2) !important;
    }

    .binsr-drawer {
        transform: translate(-50%, 96px) scale(0.72) !important;
    }

    .story-upload-card {
        transform: translate(-50%, 170px) !important;
    }

    .workflow-pdf-card,
    .workflow-upload-node,
    .workflow-upload-node b,
    .workflow-binsr-card {
        animation: none !important;
    }

    .workflow-pdf-card {
        opacity: 1 !important;
        transform: rotate(-4deg) scale(0.92) !important;
    }

    .workflow-upload-node b {
        transform: scaleX(1) !important;
    }

    .workflow-upload-node {
        opacity: 0.38 !important;
    }

    .workflow-binsr-card {
        opacity: 1 !important;
        transform: none !important;
    }
}

@media (max-width: 980px) {
    .hero,
    .receipt,
    .outcome,
    .contact-inner {
        grid-template-columns: 1fr;
    }

    .hero {
        min-height: auto;
        padding-top: var(--space-8);
    }

    .hero h1 {
        max-width: 100%;
    }
    .receipt-copy,
    .contact-copy {
        position: static;
    }

    .section-head,
    .mess-grid,
    .workflow-track,
    .workflow-simplified,
    .outcome-board {
        grid-template-columns: 1fr;
    }

    .outcome-copy p:not(.kicker) {
        max-width: 42ch;
    }

    .concept-card,
    .conversation-card,
    .issue-priority-card,
    .binsr-builder-card,
    .buyer-view-card {
        grid-column: span 6;
    }

    .conversation-card,
    .buyer-view-card {
        grid-template-columns: 1fr;
    }

    .conversation-card .concept-visual,
    .buyer-view-card .concept-visual,
    .conversation-card > span,
    .conversation-card > strong,
    .conversation-card > p,
    .buyer-view-card > span,
    .buyer-view-card > strong,
    .buyer-view-card > p {
        grid-column: 1;
        grid-row: auto;
    }
}

@media (max-width: 700px) {
    .nav {
        padding-inline: 0.75rem;
    }

    .nav-link {
        display: none;
    }

    .nav-actions {
        display: none;
    }

    .brand span {
        font-size: 1rem;
    }

    .hero,
    .mess,
    .receipt,
    .workflow,
    .outcome,
    .contact-inner,
    .footer {
        width: min(var(--container), calc(100% - 1.5rem));
    }

    .hero {
        padding-bottom: var(--space-12);
    }

    .hero h1 {
        font-size: clamp(1.92rem, 8.1vw, 2.26rem);
    }

    .hero-lede {
        max-width: 34ch;
        font-size: 1rem;
    }

    .mess .section-head h2,
    .receipt-copy h2,
    .workflow .section-head h2,
    .outcome-copy h2 {
        max-width: 100%;
        overflow-wrap: anywhere;
    }

    .receipt-copy p:not(.kicker),
    .outcome-copy p:not(.kicker) {
        max-width: 34ch;
    }

    .outcome-board {
        padding: 0;
    }

    .panic-stage {
        min-height: 470px;
    }

    .report-stack {
        left: 3%;
        width: 188px;
    }

    .phone {
        right: 2%;
        width: min(60%, 232px);
    }

    .workflow-animation {
        --workflow-pdf-travel: 112px;
        min-height: 310px;
    }

    .workflow-pdf-card {
        top: 54px;
        left: var(--space-4);
        width: 112px;
        min-height: 166px;
        gap: var(--space-2);
        padding: var(--space-3);
    }

    .workflow-pdf-card .report-topline > span {
        font-size: 0.42rem;
    }

    .workflow-pdf-card .report-topline b {
        font-size: 0.4rem;
    }

    .workflow-pdf-card strong {
        font-size: 1rem;
    }

    .workflow-pdf-card .report-lines i {
        height: 4px;
    }

    .workflow-pdf-card .report-note {
        padding: 0.38rem 0.42rem;
        font-size: 0.48rem;
    }

    .workflow-upload-node {
        width: 138px;
        min-height: 108px;
        padding: var(--space-3);
    }

    .workflow-upload-node svg {
        width: 34px;
        height: 34px;
    }

    .workflow-upload-node span {
        font-size: 0.62rem;
    }

    .workflow-upload-node i {
        width: 92px;
    }

    .workflow-binsr-card {
        top: 52px;
        right: var(--space-4);
        width: 148px;
        gap: var(--space-2);
        padding: var(--space-3);
    }

    .workflow-binsr-card h3 {
        font-size: 0.98rem;
    }

    .workflow-result-grid {
        grid-template-columns: 1fr;
        gap: var(--space-1);
    }

    .workflow-result-grid span {
        min-height: 0;
        padding: 0.42rem 0.5rem;
        font-size: 0.48rem;
    }

    .mess-grid,
    .product-board {
        min-width: 0;
    }

    .mess-card,
    .product-tile {
        width: 100%;
        max-width: 100%;
        min-width: 0;
    }

    .mess-card strong,
    .product-tile strong {
        max-width: 100%;
        overflow-wrap: anywhere;
    }

    .mess-card p,
    .product-tile p {
        max-width: 34ch;
        overflow-wrap: anywhere;
    }

    .product-tile {
        min-height: 0;
        padding: var(--space-5);
    }

    .concept-visual {
        min-height: 150px;
    }

    .conversation-card .concept-visual,
    .buyer-view-card .concept-visual {
        min-height: 182px;
    }

    .conversation-visual {
        grid-template-columns: 1fr;
        place-items: center;
        gap: var(--space-3);
    }

    .prep-phone {
        width: 54px;
        height: 54px;
    }

    .prep-buyer-question {
        width: 46px;
        height: 46px;
        font-size: 1.28rem;
    }

    .prep-sheet {
        padding: var(--space-3);
    }

    .prep-sheet b {
        padding: 0.34rem 0.46rem;
        font-size: 0.7rem;
    }

    .priority-orbit {
        width: 118px;
        height: 118px;
        box-shadow:
            inset 0 0 0 15px color-mix(in oklab, var(--color-white) 84%, var(--color-paper)),
            var(--shadow-soft);
    }

    .priority-orbit::before {
        inset: 31px;
    }

    .priority-key {
        width: 106px;
    }

    .builder-visual,
    .buyer-visual,
    .priority-visual,
    .conversation-visual {
        padding: var(--space-4);
    }

    .buyer-visual {
        grid-template-columns: minmax(72px, 0.9fr) 32px minmax(86px, 1.1fr);
        gap: var(--space-2);
    }

    .dashboard-panel {
        min-height: 108px;
        padding: var(--space-3);
    }

    .deal-table {
        --workspace-top: 54px;
        display: block;
        min-height: 640px;
        overflow: hidden;
        padding: var(--space-4);
    }

    .story-stage::before {
        inset: 52px 0.7rem 16px;
        border-radius: 1.15rem;
    }

    .story-workspace-header {
        top: 15px;
        left: 1rem;
        right: 1rem;
        gap: var(--space-2);
        padding-bottom: var(--space-2);
    }

    .story-workspace-header .workspace-brand {
        font-size: 0.68rem;
    }

    .workspace-logo {
        width: 16px;
        height: 22px;
    }

    .story-workspace-header strong {
        font-size: 0.84rem;
    }

    .story-upload-bay {
        width: min(184px, calc(100% - 6rem));
        grid-template-columns: auto minmax(0, 1fr);
        gap: var(--space-2);
        min-height: 242px;
        padding: var(--space-3);
        transform: translate(-50%, 150px) scale(1);
    }

    .upload-bay-brand {
        gap: var(--space-1);
        font-size: 0.66rem;
    }

    .upload-bay-brand .workspace-logo {
        width: 13px;
        height: 18px;
    }

    .upload-bay-brand span {
        font-size: 0.66rem;
    }

    .dropzone-upload-icon {
        width: 32px;
        height: 32px;
        padding: 0.46rem;
    }

    .story-upload-bay strong {
        font-size: 0.82rem;
    }

    .story-pdf {
        width: min(284px, calc(100% - 2rem));
        min-height: 332px;
        transform: translate(calc(-50% - 112px), 186px) rotate(-3deg) scale(0.23);
    }

    .story-paper-front {
        min-height: 332px;
        gap: var(--space-2);
        padding: var(--space-4);
    }

    .story-paper-front strong {
        font-size: 1.68rem;
    }

    .report-meta,
    .report-note {
        font-size: 0.68rem;
    }

    .report-grid {
        gap: var(--space-1);
    }

    .report-grid span {
        padding: 0.34rem 0.4rem;
        font-size: 0.58rem;
    }

    .story-paper-back {
        transform: rotate(-5deg) translate(-10px, 12px);
    }

    .story-paper-mid {
        transform: rotate(4deg) translate(10px, 10px);
    }

    .binsr-drawer {
        width: min(342px, calc(100% - 1rem));
        gap: var(--space-3);
        padding: var(--space-3);
    }

    @keyframes storyPdfSequence {
        0% {
            opacity: 1;
            filter: saturate(0.92);
            transform: translate(calc(-50% - 112px), 186px) rotate(-3deg) scale(0.23);
        }

        24% {
            opacity: 1;
            filter: saturate(0.92);
            transform: translate(calc(-50% - 112px), 186px) rotate(-3deg) scale(0.23);
        }

        40%,
        56% {
            opacity: 0.74;
            filter: saturate(0.78);
            transform: translate(-50%, 188px) rotate(0deg) scale(0.13);
        }

        66%,
        100% {
            opacity: 0;
            filter: saturate(0.72);
            transform: translate(-50%, 188px) rotate(0deg) scale(0.11);
        }
    }

    @keyframes storyUploadBaySequence {
        0%,
        56% {
            opacity: 1;
            transform: translate(-50%, 150px) scale(1);
        }

        66%,
        100% {
            opacity: 0;
            transform: translate(-50%, 150px) scale(0.96);
        }
    }

    @keyframes uploadProgressFill {
        0%,
        32% {
            transform: scaleX(0);
        }

        56%,
        100% {
            transform: scaleX(1);
        }
    }

    @keyframes storyDashboardSequence {
        0%,
        66% {
            opacity: 0;
            filter: none;
            transform: translate(-50%, 238px) scale(0.88);
        }

        74%,
        82% {
            opacity: 1;
            filter: none;
            transform: translate(-50%, 88px) scale(0.76);
        }

        90%,
        100% {
            opacity: 0.24;
            filter: saturate(0.78);
            transform: translate(-50%, 72px) scale(0.56);
        }
    }

    @keyframes storyUploadSequence {
        0% {
            opacity: 0;
            filter: none;
            transform: translate(-50%, 150px) scale(0.96);
        }

        84% {
            opacity: 0;
            filter: none;
            transform: translate(-50%, 150px) scale(0.96);
        }

        92%,
        100% {
            opacity: 1;
            filter: none;
            transform: translate(-50%, 150px) scale(1);
        }
    }

    .story-pdf,
    .story-upload-bay,
    .binsr-drawer,
    .story-upload-card {
        overflow: clip;
    }

    .drawer-tab {
        align-items: center;
        flex-direction: row;
        gap: var(--space-2);
    }

    .dashboard-mini {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: var(--space-2);
    }

    .mini-assessment,
    .mini-severity,
    .mini-negotiation,
    .mini-client,
    .mini-action {
        grid-column: auto;
    }

    .mini-card {
        padding: var(--space-3);
    }

    .mini-card span {
        font-size: 0.62rem;
    }

    .mini-card strong {
        font-size: 0.82rem;
    }

    .mini-card p {
        font-size: 0.68rem;
        line-height: 1.22;
    }

    .mini-ring {
        width: 42px;
        height: 42px;
        box-shadow: inset 0 0 0 10px var(--color-paper-raised);
    }

    .mini-counts {
        gap: var(--space-1);
    }

    .mini-counts b {
        font-size: 0.82rem;
    }

    .mini-counts small {
        font-size: 0.48rem;
    }

    .cost-row {
        grid-template-columns: 3.45rem minmax(0, 1fr) 1.8rem;
        gap: var(--space-1);
    }

    .cost-row b,
    .cost-row em {
        font-size: 0.58rem;
    }

    .mini-chips b {
        font-size: 0.58rem;
    }

    .mini-action {
        padding: var(--space-2) var(--space-3);
        font-size: 0.78rem;
    }

    .story-upload-card {
        grid-template-columns: auto minmax(0, 1fr);
        width: min(338px, calc(100% - 1rem));
        min-height: 168px;
        gap: var(--space-2) var(--space-3);
        padding: var(--space-4);
    }

    .story-upload-card svg {
        grid-row: span 2;
        width: 38px;
        height: 38px;
    }

    .story-upload-card strong,
    .story-upload-card small {
        grid-column: 2;
    }

    .story-upload-card strong {
        font-size: 1.15rem;
    }

    .hero-details-panel,
    .hero-success-panel {
        max-width: calc(100vw - 3rem);
        width: calc(100vw - 3rem);
    }

    .hero-details-panel,
    .hero-success-panel {
        order: 5;
    }

    .mini-form-grid,
    .form-grid {
        grid-template-columns: 1fr;
    }

    .section-head h2,
    .receipt-copy h2,
    .contact-copy h2,
    .outcome-copy h2 {
        font-size: clamp(1.92rem, 8.1vw, 2.26rem);
    }

    .mess,
    .receipt,
    .workflow,
    .outcome,
    .contact {
        padding: var(--space-12) 0;
    }

    .contact-form {
        padding: var(--space-5);
    }

    .footer {
        align-items: flex-start;
        flex-direction: column;
        gap: var(--space-4);
    }

    .footer-tagline {
        padding: 0;
    }
}

@media (max-width: 380px) {
    .hero-lede {
        max-width: 24ch;
    }

    .story-pdf,
    .binsr-drawer,
    .story-upload-card,
    .hero-details-panel,
    .hero-success-panel {
        max-width: calc(100vw - 2rem);
        width: calc(100vw - 2rem);
    }

    .button {
        width: 100%;
        min-height: 44px;
        padding-inline: 0.75rem;
    }

    .hero-actions,
    .nav-actions {
        gap: var(--space-2);
    }

    .hero-actions {
        display: grid;
        grid-template-columns: 1fr;
        width: 100%;
    }

    .hero-actions .text-link {
        width: 100%;
        justify-content: center;
    }

    .nav-actions .button {
        width: auto;
    }

    .builder-visual,
    .buyer-visual {
        gap: var(--space-2);
    }

    .builder-column,
    .dashboard-panel {
        padding: var(--space-3);
    }

    .buyer-visual {
        grid-template-columns: minmax(72px, 0.9fr) 32px minmax(86px, 1.1fr);
    }

    .dashboard-panel {
        min-height: 108px;
    }

    .cost-row {
        grid-template-columns: 3.2rem minmax(0, 1fr) 1.7rem;
    }
}

/* Static hero process visual */
.deal-table.story-stage {
    display: grid;
    min-height: 640px;
    align-content: start;
}

.story-flow {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(96px, 0.68fr) minmax(20px, 0.14fr) minmax(150px, 1fr) minmax(20px, 0.14fr) minmax(214px, 1.38fr);
    gap: clamp(0.45rem, 1vw, 0.85rem);
    align-items: center;
    margin-top: 6.35rem;
}

.story-flow > * {
    min-width: 0;
}

.story-flow .story-pdf,
.story-flow .story-upload-bay,
.story-flow .binsr-drawer,
.story-upload-card {
    position: relative;
    top: auto;
    right: auto;
    bottom: auto;
    left: auto;
    opacity: 1;
    filter: none;
    transform: none;
    animation: none;
    will-change: auto;
}

.story-flow .story-pdf {
    grid-column: 1;
    grid-row: 1;
    z-index: 2;
    justify-self: center;
    width: min(132px, 100%);
    min-height: 176px;
    transform: rotate(-3deg);
}

.story-flow .story-upload-bay {
    grid-column: 3;
    grid-row: 1;
    grid-template-columns: 1fr;
    justify-items: center;
    width: 100%;
    min-height: 214px;
    padding: var(--space-4);
    text-align: center;
    transform: none;
}

.story-flow .binsr-drawer {
    grid-column: 5;
    grid-row: 1;
    z-index: 2;
    width: 100%;
    gap: var(--space-3);
    padding: var(--space-3);
}

.flow-arrow {
    position: relative;
    grid-row: 1;
    justify-self: stretch;
    height: 2px;
    border-radius: var(--radius-pill);
    background: color-mix(in oklab, var(--color-primary-dark) 42%, var(--color-rule));
}

.flow-arrow::after {
    position: absolute;
    top: 50%;
    right: -1px;
    width: 0.48rem;
    height: 0.48rem;
    border-top: 2px solid color-mix(in oklab, var(--color-primary-dark) 54%, var(--color-rule));
    border-right: 2px solid color-mix(in oklab, var(--color-primary-dark) 54%, var(--color-rule));
    content: "";
    transform: translateY(-50%) rotate(45deg);
}

.flow-arrow-upload {
    grid-column: 2;
}

.flow-arrow-output {
    grid-column: 4;
}

.story-flow .story-paper-front {
    min-height: 176px;
    gap: 0.42rem;
    padding: 0.7rem;
}

.story-flow .story-paper-front strong {
    font-size: 1.08rem;
}

.story-flow .report-topline > span {
    font-size: 0.46rem;
}

.story-flow .report-topline b {
    padding: 0.16rem 0.24rem;
    font-size: 0.42rem;
}

.story-flow .report-meta,
.story-flow .report-section,
.story-flow .report-grid {
    display: none;
}

.story-flow .report-lines {
    gap: 0.28rem;
}

.story-flow .report-lines i {
    height: 4px;
}

.story-flow .report-note {
    border-left-width: 2px;
    padding: 0.38rem 0.44rem;
    font-size: 0.52rem;
}

.story-flow .story-paper-back {
    transform: rotate(-6deg) translate(-8px, 8px);
}

.story-flow .story-paper-mid {
    transform: rotate(4deg) translate(8px, 7px);
}

.story-flow .upload-bay-brand span {
    font-size: 0.72rem;
}

.story-flow .dropzone-upload-icon {
    grid-column: 1;
    grid-row: auto;
    width: 38px;
    height: 38px;
    padding: 0.5rem;
}

.story-flow .story-upload-bay strong {
    grid-column: 1;
    grid-row: auto;
    font-size: 0.98rem;
    overflow-wrap: normal;
    text-align: center;
}

.story-flow .upload-progress {
    grid-column: 1;
    grid-row: auto;
    width: min(132px, 100%);
    margin-top: 0;
}

.story-flow .upload-progress i {
    transform: scaleX(0.62);
    animation: none;
}

.story-flow .dashboard-mini {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-2);
}

.story-flow .mini-card,
.story-flow .mini-action {
    opacity: 1;
    transform: none;
    animation: none;
}

.story-flow .mini-card {
    padding: var(--space-2);
}

.story-flow .mini-assessment,
.story-flow .mini-severity,
.story-flow .mini-negotiation,
.story-flow .mini-client,
.story-flow .mini-action {
    grid-column: auto;
}

.story-flow .mini-card span {
    font-size: 0.52rem;
}

.story-flow .mini-card strong {
    margin-top: var(--space-1);
    font-size: 0.68rem;
}

.story-flow .mini-card p {
    margin-top: var(--space-1);
    font-size: 0.56rem;
    line-height: 1.22;
}

.story-flow .mini-ring {
    width: 32px;
    height: 32px;
    margin-top: var(--space-2);
    box-shadow: inset 0 0 0 8px var(--color-paper-raised);
}

.story-flow .mini-counts {
    gap: var(--space-1);
    margin-top: var(--space-2);
}

.story-flow .mini-counts b {
    font-size: 0.68rem;
}

.story-flow .mini-counts small {
    font-size: 0.42rem;
}

.story-flow .cost-row {
    grid-template-columns: 2.9rem minmax(0, 1fr) 1.55rem;
    gap: var(--space-1);
    margin-top: 0.3rem;
}

.story-flow .cost-row b,
.story-flow .cost-row em {
    font-size: 0.5rem;
}

.story-flow .cost-row i {
    height: 5px;
}

.story-flow .mini-chips {
    gap: var(--space-1);
    margin-top: var(--space-2);
}

.story-flow .mini-chips b {
    padding: 0.2rem 0.3rem;
    font-size: 0.48rem;
}

.story-flow .mini-action {
    grid-column: 1 / -1;
    padding: 0.48rem 0.6rem;
    font-size: 0.62rem;
}

.story-upload-card {
    z-index: 2;
    width: min(520px, 100%);
    min-height: 132px;
    margin: var(--space-8) auto 0;
    transform: none;
}

.story-upload-card strong {
    font-size: 1.22rem;
}

.story-upload-card small {
    line-height: 1.25;
}

@media (max-width: 700px) {
    .deal-table.story-stage {
        display: grid;
        min-height: auto;
        overflow: hidden;
        padding: var(--space-4);
    }

    .story-flow {
        grid-template-columns: minmax(0, 1fr);
        gap: var(--space-3);
        justify-items: center;
        margin-top: 4.8rem;
    }

    .story-flow .story-pdf {
        grid-column: 1;
        grid-row: 1;
        width: 118px;
        min-height: 158px;
    }

    .flow-arrow-upload {
        grid-column: 1;
        grid-row: 2;
    }

    .story-flow .story-upload-bay {
        grid-column: 1;
        grid-row: 3;
        width: min(248px, 100%);
        min-height: 188px;
    }

    .flow-arrow-output {
        grid-column: 1;
        grid-row: 4;
    }

    .story-flow .binsr-drawer {
        grid-column: 1;
        grid-row: 5;
        width: min(304px, 100%);
    }

    .flow-arrow {
        width: 2px;
        height: 28px;
        justify-self: center;
    }

    .flow-arrow::after {
        top: auto;
        right: auto;
        bottom: -1px;
        left: 50%;
        border-top: 0;
        border-right: 2px solid color-mix(in oklab, var(--color-primary-dark) 54%, var(--color-rule));
        border-bottom: 2px solid color-mix(in oklab, var(--color-primary-dark) 54%, var(--color-rule));
        transform: translateX(-50%) rotate(45deg);
    }

    .story-flow .story-paper-front {
        min-height: 158px;
    }

    .story-flow .story-upload-bay strong {
        font-size: 0.92rem;
    }

    .story-flow .binsr-drawer {
        gap: var(--space-2);
        padding: var(--space-3);
    }

    .story-upload-card {
        width: min(338px, 100%);
        min-height: 148px;
        margin-top: var(--space-5);
        padding: var(--space-4);
    }
}

@media (max-width: 380px) {
    .story-flow .story-upload-bay,
    .story-flow .binsr-drawer,
    .story-upload-card {
        width: 100%;
    }
}

@media (prefers-reduced-motion: reduce) {
    .story-flow .story-pdf,
    .story-flow .story-upload-bay,
    .story-flow .binsr-drawer,
    .story-flow .mini-card,
    .story-flow .mini-action,
    .story-upload-card {
        opacity: 1 !important;
        animation: none !important;
    }

    .story-flow .story-pdf {
        transform: rotate(-3deg) !important;
    }

    .story-flow .story-upload-bay,
    .story-flow .binsr-drawer,
    .story-upload-card {
        transform: none !important;
    }
}

/* Clear conversion hero visual */
.deal-table.story-stage {
    min-height: 610px;
    overflow: hidden;
}

.story-flow {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(118px, 0.72fr) 36px minmax(300px, 1.65fr);
    gap: var(--space-4);
    align-items: center;
    margin-top: 3rem;
    pointer-events: none;
}

.story-flow .story-upload-bay,
.story-flow .flow-arrow-output {
    display: none;
}

.story-flow .story-pdf,
.story-flow .binsr-drawer {
    position: relative;
    top: auto;
    right: auto;
    bottom: auto;
    left: auto;
    opacity: 1;
    filter: none;
    transform: none;
}

.story-flow .story-pdf {
    grid-column: 1;
    grid-row: 1;
    z-index: 2;
    width: min(150px, 100%);
    justify-self: end;
    transform: rotate(-3deg);
    filter: drop-shadow(0 18px 24px color-mix(in oklab, var(--color-ink) 12%, var(--color-transparent)));
}

.story-flow .story-paper-front {
    min-height: 202px;
    gap: 0.46rem;
    padding: 0.78rem;
}

.story-flow .story-paper-front strong {
    font-size: 1.18rem;
}

.story-flow .report-note {
    font-size: 0.56rem;
}

.story-flow .flow-arrow-upload {
    position: relative;
    grid-column: 2;
    grid-row: 1;
    display: block;
    width: 100%;
    height: 2px;
    border-top: 2px solid color-mix(in oklab, var(--color-primary-dark) 42%, var(--color-rule));
}

.story-flow .flow-arrow-upload::after {
    position: absolute;
    top: 50%;
    right: -1px;
    width: 10px;
    height: 10px;
    border-top: 2px solid color-mix(in oklab, var(--color-primary-dark) 42%, var(--color-rule));
    border-right: 2px solid color-mix(in oklab, var(--color-primary-dark) 42%, var(--color-rule));
    content: "";
    transform: translateY(-55%) rotate(45deg);
}

.story-flow .binsr-drawer {
    grid-column: 3;
    grid-row: 1;
    z-index: 1;
    width: 100%;
    gap: var(--space-3);
    padding: var(--space-4);
    box-shadow: var(--shadow-lifted);
}

.story-flow .dashboard-mini {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-3);
}

.story-flow .mini-assessment,
.story-flow .mini-severity,
.story-flow .mini-negotiation,
.story-flow .mini-client {
    grid-column: auto;
}

.story-flow .mini-card {
    padding: var(--space-3);
}

.story-flow .mini-card span {
    font-size: 0.58rem;
}

.story-flow .mini-card strong {
    font-size: 0.82rem;
}

.story-flow .mini-card p {
    font-size: 0.66rem;
}

.story-flow .mini-action {
    grid-column: 1 / -1;
    padding: var(--space-3);
    font-size: 0.78rem;
}

.story-upload-card {
    position: relative;
    top: auto;
    right: auto;
    bottom: auto;
    left: auto;
    z-index: 3;
    width: min(520px, 100%);
    min-height: 122px;
    margin: var(--space-5) auto 0;
    transform: none;
    cursor: pointer;
    border-width: 2.5px;
    border-color: color-mix(in oklab, var(--color-primary-dark) 58%, var(--color-rule));
    background:
        radial-gradient(circle at 14% 50%, color-mix(in oklab, var(--color-primary-light) 18%, var(--color-transparent)), var(--color-transparent) 36%),
        color-mix(in oklab, var(--color-white) 82%, var(--color-paper-raised));
    box-shadow:
        0 20px 34px color-mix(in oklab, var(--color-ink) 12%, var(--color-transparent)),
        0 0 0 7px color-mix(in oklab, var(--color-white) 72%, var(--color-transparent));
}

.story-upload-card strong {
    font-size: 1.18rem;
}

.story-upload-card small {
    font-size: 0.88rem;
}

.story-upload-card .dropzone-affordance {
    grid-column: 2;
    grid-row: 3;
    color: var(--color-primary-dark);
    font-size: 0.72rem;
    font-style: normal;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.dropzone-footnote {
    grid-column: 1 / -1;
    margin-top: var(--space-2);
    color: var(--color-muted);
    font-size: 0.72rem;
    font-weight: 500;
    letter-spacing: 0;
    text-align: center;
    opacity: 0.8;
}

.story-upload-card:hover,
.story-upload-card:focus-visible,
.story-upload-card.is-dragging {
    border-color: var(--color-accent);
    background:
        radial-gradient(circle at 14% 50%, color-mix(in oklab, var(--color-accent-light) 30%, var(--color-transparent)), var(--color-transparent) 38%),
        color-mix(in oklab, var(--color-white) 88%, var(--color-paper-raised));
}

.hero-desk.has-file .story-upload-card .dropzone-affordance {
    display: none;
}

@media (max-width: 700px) {
    .deal-table.story-stage {
        min-height: 500px;
        padding: var(--space-4);
    }

    .story-flow {
        grid-template-columns: minmax(72px, 0.68fr) 22px minmax(0, 1.55fr);
        gap: var(--space-2);
        margin-top: 2.25rem;
    }

    .story-flow .story-pdf {
        width: min(92px, 100%);
        transform: rotate(-3deg);
    }

    .story-flow .story-paper-front {
        min-height: 132px;
        gap: 0.28rem;
        padding: 0.52rem;
    }

    .story-flow .story-paper-front strong {
        font-size: 0.8rem;
    }

    .story-flow .report-topline > span,
    .story-flow .report-note {
        font-size: 0.38rem;
    }

    .story-flow .report-meta,
    .story-flow .report-section,
    .story-flow .report-grid {
        display: none;
    }

    .story-flow .report-lines i {
        height: 3px;
    }

    .story-flow .binsr-drawer {
        padding: var(--space-3);
        gap: var(--space-2);
    }

    .story-flow .drawer-tab {
        gap: var(--space-2);
    }

    .story-flow .drawer-tab span {
        font-size: 0.58rem;
    }

    .story-flow .drawer-tab strong {
        font-size: 0.92rem;
    }

    .story-flow .dashboard-mini {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: var(--space-2);
    }

    .story-flow .mini-negotiation,
    .story-flow .mini-client {
        display: none;
    }

    .story-flow .mini-card {
        padding: var(--space-2);
    }

    .story-flow .mini-card span {
        font-size: 0.46rem;
    }

    .story-flow .mini-card strong {
        font-size: 0.58rem;
    }

    .story-flow .mini-card p {
        font-size: 0.5rem;
        line-height: 1.16;
    }

    .story-flow .mini-ring {
        width: 28px;
        height: 28px;
        box-shadow: inset 0 0 0 7px var(--color-paper-raised);
    }

    .story-flow .mini-counts b {
        font-size: 0.58rem;
    }

    .story-flow .mini-counts small {
        font-size: 0.36rem;
    }

    .story-flow .cost-row {
        grid-template-columns: 2.4rem minmax(0, 1fr) 1.35rem;
    }

    .story-flow .cost-row b,
    .story-flow .cost-row em,
    .story-flow .mini-chips b {
        font-size: 0.42rem;
    }

    .story-flow .mini-action {
        grid-column: 1 / -1;
        font-size: 0.54rem;
        padding: var(--space-2);
    }

    .story-upload-card {
        width: 100%;
        min-height: 128px;
        margin-top: var(--space-4);
        padding: var(--space-4);
    }

    .story-upload-card strong {
        font-size: 1.02rem;
    }

    .story-upload-card small {
        font-size: 0.78rem;
    }

    .story-upload-card .dropzone-affordance {
        font-size: 0.64rem;
    }
}

@media (max-width: 380px) {
    .deal-table.story-stage {
        min-height: 500px;
    }

    .story-flow {
        grid-template-columns: 68px 18px minmax(0, 1fr);
        gap: 0.38rem;
    }

    .story-flow .story-paper-front {
        min-height: 124px;
        padding: 0.48rem;
    }

    .story-flow .story-paper-front strong {
        font-size: 0.76rem;
    }

    .story-flow .binsr-drawer {
        padding: var(--space-2);
    }

    .story-flow .dashboard-mini {
        grid-template-columns: minmax(0, 1fr);
    }

    .story-flow .mini-severity {
        display: none;
    }

    .story-upload-card {
        min-height: 130px;
    }
}

/* ─────────────────────────────────────────────────────────────
   Hero visual v2 – static side-by-side redesign
   ───────────────────────────────────────────────────────────── */

/* Outer card: content-driven height; no header bar → shrink ::before top inset */
.deal-table.story-stage {
    min-height: auto;
}

.deal-table.story-stage::before {
    inset: clamp(0.5rem, 1.5vw, 0.75rem) clamp(0.5rem, 1.5vw, 0.75rem);
}

/* Side-by-side layout: top-align columns, tighter top margin without header */
.story-flow {
    align-items: start;
    margin-top: var(--space-5);
}

/* Deadline badge – now inside flex row */
.workspace-deadline {
    display: inline-flex;
    align-items: center;
    gap: 0.3em;
    color: var(--color-accent-dark);
    font-size: 0.74rem;
    font-weight: 800;
    line-height: 1;
}

.workspace-deadline svg {
    width: 13px;
    height: 13px;
    display: block;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
}

/* BINSR card header row: brand only */
.binsr-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-2);
    padding-bottom: var(--space-2);
    border-bottom: 1px solid var(--color-rule);
    margin-bottom: calc(-1 * var(--space-1));
}

.binsr-brand {
    display: inline-flex;
    align-items: center;
    gap: 0.4em;
    font-family: var(--type-display);
    font-size: 0.76rem;
    font-weight: 700;
    line-height: 1;
    color: var(--color-ink);
}

.binsr-brand .workspace-logo {
    width: 12px;
    height: auto;
    flex: 0 0 12px;
}

/* Arrow connector between PDF and BINSR card */
.flow-connector {
    display: flex;
    align-items: center;
    justify-content: center;
    padding-top: 2.5rem;
}

.flow-connector svg {
    width: 22px;
    height: 22px;
    color: var(--color-muted);
}

/* BINSR output card */
.binsr-output {
    grid-column: 3;
    position: relative;
    border: 1px solid var(--color-rule);
    border-radius: var(--radius-lg);
    background: var(--color-paper-raised);
    box-shadow: var(--shadow-lifted);
    overflow: hidden;
    display: grid;
    gap: var(--space-2);
    padding: var(--space-3);
}

.binsr-address {
    color: var(--color-muted);
    font-size: 0.64rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin: 0;
    line-height: 1;
}

.binsr-section-title {
    font-family: var(--type-display);
    font-size: 0.98rem;
    line-height: 1.1;
    margin: 0;
}

/* Overview 2-column grid: assessment (left) + severity (right) */
.binsr-overview-grid {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: var(--space-3);
    align-items: center;
}

/* Assessment column */
.binsr-assessment {
    min-width: 0;
    display: grid;
    gap: var(--space-2);
}

.mini-label {
    display: block;
    color: var(--color-muted);
    font-size: 0.62rem;
    font-weight: 900;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    line-height: 1;
}

.assessment-row {
    display: flex;
    align-items: flex-start;
    gap: var(--space-2);
}

.status-dot {
    display: inline-block;
    width: 8px;
    height: 8px;
    flex: 0 0 8px;
    margin-top: 0.28em;
    border-radius: var(--radius-pill);
    background: var(--color-accent);
}

.assessment-row strong {
    color: var(--color-accent-dark);
    font-size: 0.82rem;
    line-height: 1.2;
}

.binsr-ask {
    padding-top: var(--space-2);
    border-top: 1px solid var(--color-rule);
    display: grid;
    gap: var(--space-1);
}

.ask-amount {
    display: block;
    color: var(--color-accent-dark);
    font-family: var(--type-display);
    font-size: 0.94rem;
    line-height: 1;
}

/* Severity panel (right column) */
.binsr-severity-panel {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-3);
    min-width: 72px;
}

/* Donut chart with number in center */
.severity-donut {
    position: relative;
    width: 56px;
    height: 56px;
    flex: 0 0 56px;
    border-radius: 50%;
    background: conic-gradient(
        var(--color-critical) 0deg 65deg,
        var(--color-moderate) 65deg 173deg,
        var(--color-minor) 173deg 360deg
    );
    display: flex;
    align-items: center;
    justify-content: center;
}

.severity-donut::before {
    content: "";
    position: absolute;
    inset: 12px;
    border-radius: 50%;
    background: var(--color-paper-raised);
}

.donut-score {
    position: relative;
    z-index: 1;
    font-family: var(--type-display);
    font-size: 1.05rem;
    font-weight: 700;
    line-height: 1;
    color: var(--color-ink);
}

.severity-legend {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 0.32rem;
}

.severity-legend li {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    font-size: 0.74rem;
    line-height: 1;
}

.severity-legend b {
    color: var(--color-ink);
    font-weight: 900;
    font-size: 0.8rem;
}

.severity-legend small {
    color: var(--color-muted);
    font-size: 0.58rem;
    font-weight: 900;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.sev-dot {
    display: inline-block;
    width: 8px;
    height: 8px;
    flex: 0 0 8px;
    border-radius: 50%;
}

.sev-critical { background: var(--color-critical); }
.sev-moderate { background: var(--color-moderate); }
.sev-minor    { background: var(--color-minor); }

/* Drop zone: full-width, sits below the visual panel */
.story-upload-card {
    width: min(540px, 100%);
    margin-inline: auto;
}

/* Mobile hero visual: fit the report-to-dashboard story inside the viewport. */

@media (max-width: 700px) {
    .hero h1 {
        font-size: clamp(1.78rem, 7.2vw, 2.08rem);
    }

    .pdf-quote {
        display: inline-block;
        max-width: 100%;
    }

    .story-flow {
        grid-template-columns: minmax(74px, 0.7fr) 20px minmax(0, 1.45fr);
        gap: var(--space-2);
        margin-top: var(--space-4);
    }

    .story-flow .story-pdf {
        width: min(104px, 100%);
        overflow: hidden;
        border-radius: var(--radius-lg);
    }

    .story-flow .story-paper-front {
        min-height: 146px;
        gap: 0.3rem;
        padding: 0.56rem;
    }

    .story-flow .story-paper-front strong {
        font-size: 0.86rem;
    }

    .story-flow .report-note {
        font-size: 0.4rem;
    }

    .binsr-output {
        padding: var(--space-2);
        gap: var(--space-1);
    }

    .binsr-brand {
        font-size: 0.56rem;
    }

    .binsr-brand .workspace-logo {
        width: 9px;
        flex-basis: 9px;
    }

    .binsr-address,
    .mini-label {
        font-size: 0.44rem;
    }

    .binsr-section-title {
        font-size: 0.72rem;
    }

    .binsr-overview-grid {
        grid-template-columns: 1fr;
        gap: var(--space-1);
    }

    .binsr-severity-panel {
        display: none;
    }

    .assessment-row strong,
    .ask-amount {
        font-size: 0.62rem;
    }

    .story-upload-card {
        min-height: 112px;
    }

    .story-upload-card strong {
        font-size: 0.96rem;
    }

    .dropzone-footnote {
        font-size: 0.62rem;
    }
}

@media (max-width: 420px) {
    .hero h1 {
        font-size: clamp(1.72rem, 7vw, 1.94rem);
    }
}

@media (max-width: 520px) {
    .hero,
    .mess,
    .receipt,
    .workflow,
    .outcome,
    .contact-inner,
    .footer {
        width: min(var(--container), calc(100% - 1.5rem), 366px);
    }

    .hero-copy {
        max-width: 100%;
    }

    .hero h1 {
        max-width: 100%;
        font-size: clamp(1.64rem, 6.6vw, 1.86rem);
    }

    .hero-micro {
        display: grid;
        grid-template-columns: 1fr;
        gap: var(--space-2);
    }

    .story-flow {
        grid-template-columns: 70px 18px minmax(0, 1fr);
        gap: 0.4rem;
    }
}
