:root {
    --page-bg: #fff;
    --ink: #101116;
    --muted: #70747d;
    --soft: rgba(16, 17, 22, 0.54);
    --line: rgba(16, 17, 22, 0.14);
    --media-line: rgba(16, 17, 22, 0.18);
    --ease: cubic-bezier(.2, .8, .2, 1);
}

* { box-sizing: border-box; }

html,
body {
    width: 100%;
    height: 100%;
    margin: 0;
    overflow: hidden;
    background: var(--page-bg);
    color: var(--ink);
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

button,
input { font: inherit; }
button { cursor: pointer; }

.app-shell {
    position: fixed;
    inset: 0;
    display: grid;
    grid-template-rows: auto minmax(0, 1fr) auto;
    background: #fff;
    overflow: hidden;
}

.top-bar {
    min-height: 128px;
    padding: max(16px, env(safe-area-inset-top)) clamp(46px, 5.4vw, 102px) 8px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 22px;
    z-index: 20;
}

.brand-lockup { display: flex; align-items: center; gap: 16px; min-width: 0; }
.brand-logo-video { width: clamp(258px, 24vw, 414px); height: clamp(102px, 10.2vw, 156px); object-fit: contain; object-position: left center; display: block; background: #fff; }
.brand-text { min-width: 0; }
.brand-name { font-size: clamp(1rem, 1.18vw, 1.16rem); font-weight: 860; letter-spacing: -0.052em; line-height: 1.04; white-space: nowrap; }
.brand-subtitle { margin-top: 4px; color: var(--muted); font-size: .82rem; white-space: nowrap; }
.status-pill { color: var(--soft); font-size: .86rem; white-space: nowrap; }

.dynamic-stage {
    position: relative;
    min-height: 0;
    padding: clamp(28px, 4vh, 58px) clamp(64px, 6vw, 112px) clamp(28px, 4vh, 58px);
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    grid-template-rows: repeat(10, minmax(0, 1fr));
    column-gap: clamp(84px, 8vw, 170px);
    row-gap: clamp(22px, 2.6vh, 38px);
    align-items: stretch;
    overflow: hidden;
}

.stage-idle { display: grid; }

.welcome-card {
    grid-column: 1 / span 9;
    grid-row: 2 / span 7;
    align-self: center;
    justify-self: start;
    max-width: min(1200px, 82vw);
    padding: 0;
    text-align: left;
    animation: riseIn 420ms var(--ease) both;
}

.welcome-eyebrow,
.eyebrow {
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: .18em;
    font-size: clamp(.7rem, .92vw, .84rem);
    font-weight: 860;
}

.welcome-card h1,
.block-headline h1 {
    margin: 12px 0 20px;
    font-size: clamp(4.15rem, min(6.8vw, 10.4vh), 7.45rem);
    line-height: .88;
    letter-spacing: -.068em;
    font-weight: 900;
    text-wrap: balance;
    max-width: 10.8ch;
    overflow: visible;
}

.welcome-card p,
.block-headline p,
.content-block p {
    color: var(--muted);
    font-size: clamp(1.06rem, 1.32vw, 1.28rem);
    line-height: 1.42;
    margin: 0;
    max-width: 43ch;
    text-wrap: pretty;
}

.welcome-hint { margin-top: 30px; color: var(--muted); font-size: clamp(.98rem, 1.15vw, 1.08rem); }
.welcome-hint span { color: var(--ink); font-weight: 780; }

.thinking-card {
    grid-column: 2 / span 10;
    grid-row: 3 / span 5;
    align-self: center;
    justify-self: center;
    width: min(920px, 86vw);
    text-align: center;
    padding: 0;
    animation: riseIn 180ms var(--ease) both;
}
.thinking-eyebrow { color: var(--muted); text-transform: uppercase; letter-spacing: .18em; font-size: clamp(.7rem, .92vw, .84rem); font-weight: 860; }
.thinking-line { margin-top: 18px; color: var(--ink); font-size: clamp(2.1rem, 4.2vw, 5rem); line-height: .96; letter-spacing: -.06em; font-weight: 890; text-wrap: balance; }
.stage-thinking::after { content: ""; position: absolute; left: clamp(64px, 6vw, 112px); right: clamp(64px, 6vw, 112px); bottom: 12px; height: 2px; border-radius: 999px; background: linear-gradient(90deg, transparent, rgba(16, 17, 22, .20), transparent); animation: thinkingSweep .95s infinite var(--ease); }

.content-block {
    min-width: 0;
    min-height: 0;
    overflow: visible;
    padding: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: clamp(10px, 1.25vw, 20px);
    background: transparent;
    border: 0;
    opacity: 0;
    transform: translateY(14px) scale(.99);
    filter: blur(4px);
    animation: blockIn 520ms var(--ease) both;
    animation-delay: var(--delay, 0ms);
    transition: opacity var(--fade-out-ms, 220ms) var(--ease), transform var(--fade-out-ms, 220ms) var(--ease), filter var(--fade-out-ms, 220ms) var(--ease);
}
.content-block.leaving { opacity: 0; transform: translateY(8px) scale(.99); filter: blur(5px); }

.block-headline {
    grid-column: 1 / span 6;
    grid-row: 1 / span 10;
    align-self: center;
    justify-self: stretch;
}

.dynamic-stage[data-layout="single-focus"] .block-headline {
    grid-column: 1 / span 10;
    grid-row: 2 / span 7;
    align-self: center;
}
.dynamic-stage[data-layout="single-focus"] .block-headline h1 { max-width: 13ch; }
.dynamic-stage[data-layout="single-focus"] .block-headline p { max-width: 56ch; }


/* Adaptive scene layouts - v5.3 */
.dynamic-stage[data-layout="visual-light"] .block-headline {
    grid-column: 1 / span 6;
    grid-row: 1 / span 10;
    align-self: center;
}
.dynamic-stage[data-layout="visual-light"] .content-block:nth-child(2) {
    grid-column: 8 / span 5;
    grid-row: 2 / span 7;
    align-self: center;
}
.dynamic-stage[data-layout="visual-light"] .content-block:nth-child(3) {
    grid-column: 8 / span 5;
    grid-row: 8 / span 2;
    align-self: start;
}
.dynamic-stage[data-layout="visual-light"] .media-frame {
    min-height: clamp(280px, 42vh, 520px);
}

.dynamic-stage[data-layout="visual-split"] .block-headline {
    grid-column: 1 / span 6;
    grid-row: 1 / span 10;
    align-self: center;
}
.dynamic-stage[data-layout="visual-split"] .content-block:nth-child(2) {
    grid-column: 8 / span 5;
    grid-row: 1 / span 5;
    align-self: stretch;
}
.dynamic-stage[data-layout="visual-split"] .content-block:nth-child(3) {
    grid-column: 8 / span 5;
    grid-row: 6 / span 4;
    align-self: start;
}
.dynamic-stage[data-layout="visual-split"] .content-block:nth-child(4) {
    grid-column: 1 / span 12;
    grid-row: 10 / span 1;
    align-self: end;
}

.dynamic-stage[data-layout="content-heavy"] {
    column-gap: clamp(42px, 4.8vw, 92px);
    row-gap: clamp(20px, 2.2vh, 34px);
}
.dynamic-stage[data-layout="content-heavy"] .block-headline {
    grid-column: 1 / span 5;
    grid-row: 1 / span 10;
    align-self: center;
}
.dynamic-stage[data-layout="content-heavy"] .block-headline h1 {
    max-width: 10.5ch;
    font-size: clamp(3.55rem, min(5.4vw, 8.2vh), 6.35rem);
}
.dynamic-stage[data-layout="content-heavy"] .block-headline p {
    max-width: 38ch;
}
.dynamic-stage[data-layout="content-heavy"] .content-block:nth-child(2) {
    grid-column: 6 / span 3;
    grid-row: 1 / span 5;
    align-self: start;
}
.dynamic-stage[data-layout="content-heavy"] .content-block:nth-child(3) {
    grid-column: 9 / span 4;
    grid-row: 1 / span 5;
    align-self: start;
}
.dynamic-stage[data-layout="content-heavy"] .content-block:nth-child(4) {
    grid-column: 6 / span 7;
    grid-row: 6 / span 4;
    align-self: start;
}
.dynamic-stage[data-density="heavy"] .content-block h2 {
    font-size: clamp(1.14rem, 1.45vw, 1.58rem);
    line-height: 1.05;
    max-width: 24ch;
}
.dynamic-stage[data-density="heavy"] .content-block p {
    font-size: clamp(.9rem, .98vw, 1.03rem);
    line-height: 1.32;
    max-width: 44ch;
}
.dynamic-stage[data-density="heavy"] .mini-card,
.dynamic-stage[data-density="heavy"] .process-list li {
    font-size: clamp(.88rem, .98vw, 1rem);
    line-height: 1.2;
}
.dynamic-stage[data-density="light"] .block-headline h1 {
    max-width: 11.5ch;
}
.dynamic-stage[data-density="light"] .content-block h2 {
    font-size: clamp(1.55rem, 2.2vw, 2.35rem);
}

@media (max-width: 900px) {
    .dynamic-stage[data-layout="visual-light"] .block-headline,
    .dynamic-stage[data-layout="visual-split"] .block-headline,
    .dynamic-stage[data-layout="content-heavy"] .block-headline {
        grid-column: 1 / span 6;
        grid-row: 1 / span 5;
    }
    .dynamic-stage[data-layout="visual-light"] .content-block:nth-child(2),
    .dynamic-stage[data-layout="visual-split"] .content-block:nth-child(2),
    .dynamic-stage[data-layout="content-heavy"] .content-block:nth-child(2) {
        grid-column: 1 / span 3;
        grid-row: 6 / span 4;
    }
    .dynamic-stage[data-layout="visual-light"] .content-block:nth-child(3),
    .dynamic-stage[data-layout="visual-split"] .content-block:nth-child(3),
    .dynamic-stage[data-layout="content-heavy"] .content-block:nth-child(3) {
        grid-column: 4 / span 3;
        grid-row: 6 / span 4;
    }
    .dynamic-stage[data-layout="visual-split"] .content-block:nth-child(4),
    .dynamic-stage[data-layout="content-heavy"] .content-block:nth-child(4) {
        grid-column: 1 / span 6;
        grid-row: 9 / span 2;
    }
    .dynamic-stage[data-layout="visual-light"] .media-frame {
        min-height: 140px;
    }
}

.dynamic-stage[data-block-count="2"] .block-headline,
.dynamic-stage[data-block-count="3"] .block-headline,
.dynamic-stage[data-block-count="4"] .block-headline { grid-column: 1 / span 6; grid-row: 1 / span 10; }

.dynamic-stage[data-block-count="2"] .content-block:nth-child(2) { grid-column: 8 / span 5; grid-row: 3 / span 5; align-self: center; }

.dynamic-stage[data-block-count="3"] .content-block:nth-child(2) { grid-column: 8 / span 5; grid-row: 2 / span 4; align-self: start; }
.dynamic-stage[data-block-count="3"] .content-block:nth-child(3) { grid-column: 8 / span 5; grid-row: 6 / span 4; align-self: start; }

.dynamic-stage[data-block-count="4"] .content-block:nth-child(2) { grid-column: 8 / span 5; grid-row: 1 / span 3; align-self: center; }
.dynamic-stage[data-block-count="4"] .content-block:nth-child(3) { grid-column: 8 / span 5; grid-row: 4 / span 3; align-self: center; }
.dynamic-stage[data-block-count="4"] .content-block:nth-child(4) { grid-column: 8 / span 5; grid-row: 7 / span 3; align-self: center; }

.content-block h2 {
    margin: 0;
    font-size: clamp(1.24rem, 1.7vw, 1.72rem);
    line-height: 1;
    letter-spacing: -.058em;
    font-weight: 880;
    text-wrap: balance;
    max-width: 20ch;
}

.block-text p { max-width: 40ch; }

.reveal-word { display: inline-block; opacity: 0; transform: translateY(.34em); filter: blur(3px); animation: wordReveal 420ms var(--ease) forwards; animation-delay: calc(var(--delay, 0ms) + var(--word-delay, 0ms)); }

.media-frame { position: relative; flex: 1 1 auto; min-height: 210px; display: grid; place-items: center; border: 1px solid var(--media-line); border-radius: 22px; background: #fff; overflow: hidden; opacity: 0; transform: translateY(8px); filter: blur(3px); animation: itemReveal 520ms var(--ease) forwards; animation-delay: calc(var(--delay, 0ms) + var(--item-delay, 0ms)); }
.media-frame img,
.media-frame video { width: 100%; height: 100%; object-fit: contain; display: block; }
.video-frame video { object-fit: cover; }

.mini-card-grid { width: 100%; display: grid; grid-template-columns: 1fr; gap: clamp(10px, 1.35vw, 18px); }
.mini-card { min-width: 0; display: flex; align-items: flex-start; gap: 14px; padding: 0; text-align: left; font-weight: 790; font-size: clamp(.94rem, 1.08vw, 1.02rem); line-height: 1.18; letter-spacing: -.027em; opacity: 0; transform: translateY(8px); filter: blur(3px); animation: itemReveal 520ms var(--ease) forwards; animation-delay: calc(var(--delay, 0ms) + var(--item-delay, 0ms)); }
.mini-card::before { content: ""; width: clamp(24px, 2.6vw, 42px); height: 1px; flex: 0 0 auto; margin-top: .67em; background: var(--line); }
.mini-card span { min-width: 0; text-wrap: pretty; }

.process-list { counter-reset: item; list-style: none; padding: 0; margin: 0; display: grid; gap: clamp(10px, 1.35vw, 18px); }
.process-list li { counter-increment: item; display: grid; grid-template-columns: clamp(32px, 3vw, 44px) 1fr; align-items: baseline; gap: 14px; color: var(--muted); font-weight: 750; font-size: clamp(.94rem, 1.08vw, 1.02rem); line-height: 1.18; letter-spacing: -.018em; opacity: 0; transform: translateY(8px); filter: blur(3px); animation: itemReveal 520ms var(--ease) forwards; animation-delay: calc(var(--delay, 0ms) + var(--item-delay, 0ms)); }
.process-list li::before { content: counter(item, decimal-leading-zero); color: var(--ink); font-size: .82rem; font-weight: 890; letter-spacing: -.02em; }
.process-list span { min-width: 0; text-wrap: pretty; }

blockquote { margin: 0; font-size: clamp(1.7rem, 2.55vw, 3.15rem); line-height: 1; letter-spacing: -.06em; font-weight: 880; text-wrap: balance; max-width: 18ch; }

.voice-hint { position: fixed; right: clamp(28px, 5vw, 84px); bottom: calc(78px + env(safe-area-inset-bottom)); z-index: 20; color: var(--muted); font-size: .88rem; animation: riseIn 220ms var(--ease) both; }
.voice-hint strong { color: var(--ink); }

.command-bar { position: relative; min-height: 78px; padding: 12px clamp(28px, 5vw, 84px) max(16px, env(safe-area-inset-bottom)); display: grid; grid-template-columns: auto minmax(220px, 620px) auto; align-items: center; justify-content: center; gap: 14px; z-index: 30; }
.icon-button,
.more-button,
.question-form button { border: 0; border-radius: 999px; background: transparent; color: var(--ink); }
.icon-button { width: 78px; height: 38px; display: grid; place-items: center; color: var(--muted); font-size: .78rem; }
.icon-button .voice-on { display: none; }
.icon-button.is-on .voice-on { display: inline; }
.icon-button.is-on .voice-off { display: none; }
.icon-button.is-on { color: var(--ink); }
.icon-button.is-listening .voice-on::after { content: ""; display: inline-block; width: 5px; height: 5px; margin-left: 6px; border-radius: 50%; background: currentColor; transform: translateY(-1px); }
.question-form { min-width: 0; width: min(620px, 58vw); display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 8px; padding: 0; border: 0; background: transparent; }
.question-form input { min-width: 0; width: 100%; height: 36px; border: 0; outline: 0; background: transparent; padding: 0 10px 0 0; color: var(--ink); }
.question-form input::placeholder { color: rgba(107, 111, 120, .78); }
.question-form button,
.more-button { height: 36px; padding: 0 10px; font-size: .84rem; font-weight: 790; }
.more-button { opacity: .68; }
.more-button:hover,
.question-form button:hover,
.icon-button:hover { opacity: 1; transform: translateY(-1px); text-decoration: underline; text-underline-offset: 4px; }
.voice-disclosure { position: absolute; right: clamp(28px, 5vw, 84px); bottom: max(8px, env(safe-area-inset-bottom)); color: rgba(107, 111, 120, .55); font-size: .64rem; letter-spacing: .02em; pointer-events: none; }
.hidden { display: none !important; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; }

@keyframes thinkingSweep { 0% { transform: translateX(-55%); opacity: 0; } 35% { opacity: 1; } 100% { transform: translateX(55%); opacity: 0; } }
@keyframes blockIn { from { opacity: 0; transform: translateY(14px) scale(.99); filter: blur(4px); } to { opacity: 1; transform: translateY(0) scale(1); filter: blur(0); } }
@keyframes wordReveal { from { opacity: 0; transform: translateY(.34em); filter: blur(3px); } to { opacity: 1; transform: translateY(0); filter: blur(0); } }
@keyframes itemReveal { from { opacity: 0; transform: translateY(8px); filter: blur(3px); } to { opacity: 1; transform: translateY(0); filter: blur(0); } }
@keyframes riseIn { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }

@media (max-height: 800px) and (min-width: 901px) {
    .top-bar { min-height: 106px; padding-top: 10px; padding-bottom: 3px; }
    .command-bar { min-height: 62px; padding-top: 6px; padding-bottom: 8px; }
    .dynamic-stage { padding-top: 16px; padding-bottom: 14px; row-gap: 16px; column-gap: clamp(52px, 5.4vw, 105px); }
    .welcome-card h1,
    .block-headline h1 { font-size: clamp(3.85rem, min(6.2vw, 9.5vh), 6.5rem); }
    .content-block h2 { font-size: clamp(1.3rem, 1.76vw, 1.92rem); }
    .mini-card { font-size: clamp(.94rem, 1.02vw, 1.04rem); line-height: 1.2; }
    .process-list li { font-size: clamp(.94rem, 1.02vw, 1.04rem); line-height: 1.2; }
    .block-headline p,
    .content-block p { font-size: clamp(.92rem, .98vw, 1.02rem); }
}

@media (max-width: 1180px) {
    .top-bar { min-height: 116px; padding-inline: clamp(26px, 4vw, 56px); }
    .dynamic-stage { padding-inline: clamp(32px, 4.6vw, 62px); column-gap: 42px; }
    .block-headline,
    .dynamic-stage[data-block-count="2"] .block-headline,
    .dynamic-stage[data-block-count="3"] .block-headline,
    .dynamic-stage[data-block-count="4"] .block-headline { grid-column: 1 / span 6; }
    .dynamic-stage[data-block-count="2"] .content-block:nth-child(2),
    .dynamic-stage[data-block-count="3"] .content-block:nth-child(2),
    .dynamic-stage[data-block-count="3"] .content-block:nth-child(3),
    .dynamic-stage[data-block-count="4"] .content-block:nth-child(2),
    .dynamic-stage[data-block-count="4"] .content-block:nth-child(3),
    .dynamic-stage[data-block-count="4"] .content-block:nth-child(4) { grid-column: 7 / span 6; }
    .welcome-card h1,
    .block-headline h1 { font-size: clamp(3.5rem, 7vw, 5.9rem); }
}

@media (max-width: 900px) {
    .top-bar { min-height: 76px; padding-inline: 18px; }
    .brand-subtitle { display: none; }
    .brand-logo-video { width: 150px; height: 60px; }
    .dynamic-stage { padding: 12px 22px 14px; gap: 14px; grid-template-columns: repeat(6, minmax(0, 1fr)); grid-template-rows: repeat(10, minmax(0, 1fr)); }
    .welcome-card { grid-column: 1 / span 6; grid-row: 1 / span 7; max-width: 100%; }
    .block-headline,
    .dynamic-stage[data-block-count="2"] .block-headline,
    .dynamic-stage[data-block-count="3"] .block-headline,
    .dynamic-stage[data-block-count="4"] .block-headline { grid-column: 1 / span 6; grid-row: 1 / span 5; }
    .dynamic-stage[data-block-count="2"] .content-block:nth-child(2) { grid-column: 1 / span 6; grid-row: 6 / span 5; }
    .dynamic-stage[data-block-count="3"] .content-block:nth-child(2) { grid-column: 1 / span 3; grid-row: 6 / span 5; }
    .dynamic-stage[data-block-count="3"] .content-block:nth-child(3) { grid-column: 4 / span 3; grid-row: 6 / span 5; }
    .dynamic-stage[data-block-count="4"] .content-block:nth-child(2) { grid-column: 1 / span 3; grid-row: 6 / span 2; }
    .dynamic-stage[data-block-count="4"] .content-block:nth-child(3) { grid-column: 4 / span 3; grid-row: 6 / span 2; }
    .dynamic-stage[data-block-count="4"] .content-block:nth-child(4) { grid-column: 1 / span 6; grid-row: 8 / span 3; }
    .welcome-card h1,
    .block-headline h1 { font-size: clamp(2.35rem, 10.5vw, 3.9rem); max-width: 11ch; }
    .welcome-card p,
    .block-headline p,
    .content-block p { font-size: .95rem; line-height: 1.28; }
    .content-block h2 { font-size: clamp(1.08rem, 4.7vw, 1.58rem); }
    .mini-card-grid { gap: 7px; }
    .mini-card { font-size: .86rem; gap: 8px; line-height: 1.12; }
    .mini-card::before { width: 14px; }
    .process-list { gap: 7px; }
    .process-list li { font-size: .86rem; grid-template-columns: 24px 1fr; gap: 8px; line-height: 1.12; }
    .media-frame { min-height: 110px; }
    .command-bar { min-height: 72px; grid-template-columns: auto 1fr auto; gap: 8px; padding-inline: 12px; }
    .question-form { width: 100%; gap: 5px; }
    .question-form input { padding-inline: 8px; }
    .question-form button,
    .more-button { padding-inline: 10px; }
    .icon-button { width: 66px; font-size: .7rem; }
    .voice-hint { right: 18px; bottom: calc(76px + env(safe-area-inset-bottom)); font-size: .78rem; }
    .voice-disclosure { display: none; }
}

@media (prefers-reduced-motion: reduce) {
    .content-block,
    .reveal-word,
    .media-frame,
    .mini-card,
    .process-list li,
    .welcome-card,
    .voice-hint { animation-duration: 1ms !important; animation-delay: 0ms !important; transition-duration: 1ms !important; }
}

/* Visual presentation upgrade - v5.4
   Keeps the pure white style, but gives the rendered scene a richer visual hierarchy. */
.dynamic-stage[data-layout="visual-light"],
.dynamic-stage[data-layout="visual-split"],
.dynamic-stage[data-layout="content-heavy"] {
    column-gap: clamp(78px, 7.6vw, 158px);
}

.dynamic-stage[data-layout="visual-light"] .block-headline,
.dynamic-stage[data-layout="visual-split"] .block-headline {
    grid-column: 1 / span 5;
    grid-row: 1 / span 10;
    align-self: center;
}
.dynamic-stage[data-layout="visual-light"] .block-headline h1,
.dynamic-stage[data-layout="visual-split"] .block-headline h1 {
    max-width: 10.8ch;
}
.dynamic-stage[data-layout="visual-light"] .block-headline p,
.dynamic-stage[data-layout="visual-split"] .block-headline p {
    max-width: 39ch;
}

.dynamic-stage[data-layout="visual-light"] .content-block:nth-child(2),
.dynamic-stage[data-layout="visual-split"] .content-block:nth-child(2) {
    grid-column: 7 / span 6;
    grid-row: 1 / span 8;
    align-self: stretch;
    justify-content: stretch;
}
.dynamic-stage[data-layout="visual-light"] .content-block:nth-child(3),
.dynamic-stage[data-layout="visual-split"] .content-block:nth-child(3) {
    grid-column: 7 / span 6;
    grid-row: 9 / span 2;
    align-self: start;
}
.dynamic-stage[data-layout="visual-split"] .content-block:nth-child(4) {
    grid-column: 1 / span 12;
    grid-row: 10 / span 1;
    align-self: end;
}

.dynamic-stage[data-layout="content-heavy"] .block-headline {
    grid-column: 1 / span 5;
    grid-row: 1 / span 10;
    align-self: center;
}
.dynamic-stage[data-layout="content-heavy"] .content-block:nth-child(2) {
    grid-column: 6 / span 4;
    grid-row: 1 / span 5;
    align-self: start;
}
.dynamic-stage[data-layout="content-heavy"] .content-block:nth-child(3) {
    grid-column: 10 / span 3;
    grid-row: 1 / span 5;
    align-self: start;
}
.dynamic-stage[data-layout="content-heavy"] .content-block:nth-child(4) {
    grid-column: 6 / span 7;
    grid-row: 6 / span 4;
    align-self: start;
}

.block-image,
.block-graphic {
    justify-content: stretch;
}
.block-image h2,
.block-graphic h2 {
    font-size: clamp(1.08rem, 1.22vw, 1.36rem);
    line-height: 1.05;
    max-width: 28ch;
}
.block-image .caption,
.block-graphic .caption {
    color: rgba(112, 116, 125, .82);
    font-size: clamp(.82rem, .9vw, .96rem);
    line-height: 1.35;
    max-width: 48ch;
}
.media-frame {
    width: 100%;
    min-height: clamp(300px, 43vh, 560px);
    border-radius: clamp(22px, 2vw, 34px);
    border-color: rgba(16, 17, 22, .16);
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.6);
}
.media-frame::before {
    content: "";
    position: absolute;
    inset: 8%;
    border-radius: 40px;
    border: 1px solid rgba(16, 17, 22, .05);
    pointer-events: none;
}
.media-frame img {
    width: 96%;
    height: 96%;
    object-fit: contain;
    transform: translateY(1px);
}
.dynamic-stage[data-layout="visual-light"] .media-frame,
.dynamic-stage[data-layout="visual-split"] .media-frame {
    min-height: clamp(360px, 52vh, 620px);
}

.block-cards .mini-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(12px, 1.5vw, 22px) clamp(22px, 2.6vw, 42px);
}
.dynamic-stage[data-layout="content-heavy"] .block-cards .mini-card-grid,
.dynamic-stage[data-layout="visual-light"] .content-block:nth-child(3) .mini-card-grid,
.dynamic-stage[data-layout="visual-split"] .content-block:nth-child(3) .mini-card-grid {
    grid-template-columns: 1fr;
}
.mini-card::before {
    width: clamp(34px, 3vw, 54px);
    background: linear-gradient(90deg, rgba(16,17,22,.34), rgba(16,17,22,.05));
}
.process-list li::before {
    color: rgba(16,17,22,.78);
}

@media (max-height: 800px) and (min-width: 901px) {
    .dynamic-stage[data-layout="visual-light"] .media-frame,
    .dynamic-stage[data-layout="visual-split"] .media-frame {
        min-height: clamp(260px, 40vh, 430px);
    }
    .media-frame { min-height: clamp(220px, 32vh, 360px); }
}

@media (max-width: 1180px) and (min-width: 901px) {
    .dynamic-stage[data-layout="visual-light"] .block-headline,
    .dynamic-stage[data-layout="visual-split"] .block-headline,
    .dynamic-stage[data-layout="content-heavy"] .block-headline {
        grid-column: 1 / span 5;
    }
    .dynamic-stage[data-layout="visual-light"] .content-block:nth-child(2),
    .dynamic-stage[data-layout="visual-split"] .content-block:nth-child(2) {
        grid-column: 7 / span 6;
    }
    .dynamic-stage[data-layout="visual-light"] .content-block:nth-child(3),
    .dynamic-stage[data-layout="visual-split"] .content-block:nth-child(3) {
        grid-column: 7 / span 6;
    }
}

@media (max-width: 900px) {
    .dynamic-stage[data-layout="visual-light"] .block-headline,
    .dynamic-stage[data-layout="visual-split"] .block-headline,
    .dynamic-stage[data-layout="content-heavy"] .block-headline {
        grid-column: 1 / span 6;
        grid-row: 1 / span 5;
    }
    .dynamic-stage[data-layout="visual-light"] .content-block:nth-child(2),
    .dynamic-stage[data-layout="visual-split"] .content-block:nth-child(2),
    .dynamic-stage[data-layout="content-heavy"] .content-block:nth-child(2) {
        grid-column: 1 / span 6;
        grid-row: 6 / span 3;
    }
    .dynamic-stage[data-layout="visual-light"] .content-block:nth-child(3),
    .dynamic-stage[data-layout="visual-split"] .content-block:nth-child(3),
    .dynamic-stage[data-layout="content-heavy"] .content-block:nth-child(3) {
        grid-column: 1 / span 6;
        grid-row: 9 / span 2;
    }
    .dynamic-stage[data-layout="visual-split"] .content-block:nth-child(4),
    .dynamic-stage[data-layout="content-heavy"] .content-block:nth-child(4) {
        display: none;
    }
    .media-frame,
    .dynamic-stage[data-layout="visual-light"] .media-frame,
    .dynamic-stage[data-layout="visual-split"] .media-frame {
        min-height: 150px;
    }
    .block-cards .mini-card-grid { grid-template-columns: 1fr; }
}
