:root {
    --bg: #050505;
    --surface: #111010;
    --surface-2: #181414;
    --text: #f6f0ea;
    --muted: #b8aea8;
    --faint: #7d7470;
    --line: rgba(246, 240, 234, 0.1);
    --line-strong: rgba(246, 240, 234, 0.18);
    --wine: #8f2029;
    --wine-dark: #61151b;
    --wine-glow: rgba(143, 32, 41, 0.24);
    --radius-xl: 28px;
    --radius-lg: 20px;
    --radius-md: 16px;
    --space-1: 8px;
    --space-2: 16px;
    --space-3: 24px;
    --space-4: 32px;
    --gutter: 16px;
    --safe-bottom: env(safe-area-inset-bottom, 0px);
    --safe-top: env(safe-area-inset-top, 0px);
    --shadow: 0 24px 70px rgba(0, 0, 0, 0.48);
    --shadow-soft: 0 14px 36px rgba(0, 0, 0, 0.28);
}

html,
body {
    width: 100%;
    max-width: 100%;
    overflow-x: clip;
    background: var(--bg);
}

body.modal-open {
    overflow: hidden;
}

.home-ref-main {
    width: 100%;
    max-width: 430px;
    margin: 0 auto;
    padding: calc(var(--space-2) + var(--safe-top)) 0 calc(104px + var(--safe-bottom));
    overflow-x: clip;
}

.product-home {
    display: grid;
    gap: var(--space-4);
    width: 100%;
    min-width: 0;
}

.home-hero,
.signal-strip,
.scenario-progression,
.focus,
.branches,
.why,
.process,
.system,
.final-cta {
    width: 100%;
    padding: 0 var(--gutter);
}

.eyebrow {
    margin: 0;
    color: rgba(246, 240, 234, 0.68);
    font-size: 11px;
    font-weight: 700;
    line-height: 1.3;
    letter-spacing: 0;
    text-transform: uppercase;
}

.section-heading {
    display: grid;
    gap: var(--space-1);
    margin-bottom: var(--space-2);
}

.section-heading--compact {
    margin-bottom: var(--space-2);
}

.section-heading h2,
.system h2,
.final-cta h2 {
    margin: 0;
    color: var(--text);
    font-family: "Cormorant Garamond", serif;
    font-size: 38px;
    font-weight: 600;
    line-height: 0.96;
    letter-spacing: -0.03em;
    text-wrap: balance;
}

.section-heading p,
.system p,
.final-cta p {
    max-width: 32ch;
    margin: 0;
    color: var(--muted);
    font-size: 14px;
    line-height: 1.55;
    text-wrap: pretty;
}

.home-hero {
    position: relative;
    min-height: min(720px, calc(100svh - 116px));
    display: grid;
    align-items: end;
    overflow: hidden;
    border-radius: var(--radius-xl);
    padding: var(--space-2);
    margin: 0 var(--gutter);
    width: calc(100% - (var(--gutter) * 2));
    box-shadow: var(--shadow);
    isolation: isolate;
}

.home-hero__video,
.home-hero__shade {
    position: absolute;
    inset: 0;
}

.home-hero__video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: -2;
}

.home-hero__shade {
    z-index: -1;
    background:
        linear-gradient(180deg, rgba(5, 5, 5, 0.22) 0%, rgba(5, 5, 5, 0.42) 42%, rgba(5, 5, 5, 0.9) 100%),
        linear-gradient(90deg, rgba(5, 5, 5, 0.72), rgba(5, 5, 5, 0.18));
}

.home-hero__topline {
    position: absolute;
    left: var(--space-2);
    right: var(--space-2);
    top: var(--space-2);
    display: flex;
    justify-content: space-between;
    color: rgba(246, 240, 234, 0.66);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.home-hero__content {
    display: grid;
    gap: var(--space-1);
    padding-top: 120px;
}

.home-hero__actions {
    display: grid;
    gap: var(--space-1);
}

.home-hero h1 {
    max-width: 7.8em;
    margin: 0;
    color: var(--text);
    font-family: "Cormorant Garamond", serif;
    font-size: 56px;
    font-weight: 600;
    line-height: 0.9;
    letter-spacing: -0.035em;
    text-wrap: balance;
}

.home-hero__text {
    max-width: 31ch;
    margin: var(--space-1) 0 0;
    color: var(--muted);
    font-size: 15px;
    line-height: 1.55;
}

.unlock-note {
    display: grid;
    gap: 4px;
    width: min(100%, 280px);
    margin-top: var(--space-2);
    padding: 12px 14px;
    border: 1px solid rgba(246, 240, 234, 0.14);
    border-left-color: rgba(255, 112, 120, 0.7);
    border-radius: 16px;
    background: rgba(8, 8, 8, 0.44);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.06), 0 16px 34px rgba(0,0,0,0.24);
    backdrop-filter: blur(14px);
}

.unlock-note span {
    color: rgba(246, 240, 234, 0.62);
    font-size: 10px;
    font-weight: 800;
    line-height: 1.2;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.unlock-note strong {
    color: var(--text);
    font-size: 14px;
    line-height: 1.25;
}

.btn {
    position: relative;
    min-height: 56px;
    width: 100%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: var(--space-2);
    padding: 0 var(--space-2);
    overflow: hidden;
    border: 1px solid var(--line);
    border-radius: 16px;
    color: var(--text);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    transition: transform 220ms ease, filter 220ms ease, border-color 220ms ease, box-shadow 220ms ease;
}

.btn:active {
    transform: scale(0.97);
}

.btn--primary {
    border-color: rgba(255, 255, 255, 0.12);
    background: linear-gradient(180deg, #a62b34, #761820);
    box-shadow: 0 18px 36px rgba(118, 24, 32, 0.34), inset 0 1px 0 rgba(255,255,255,0.14);
}

.btn--ghost {
    margin-top: var(--space-1);
    background: rgba(255,255,255,0.035);
}

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

.signal-strip article {
    min-width: 0;
    padding: 14px 10px;
    border: 1px solid var(--line);
    border-radius: 16px;
    background: rgba(255,255,255,0.025);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}

.signal-strip__label {
    display: block;
    color: var(--faint);
    font-size: 9px;
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.signal-strip strong {
    display: block;
    margin-top: 8px;
    color: var(--text);
    font-family: "Cormorant Garamond", serif;
    font-size: 22px;
    font-weight: 600;
    line-height: 0.95;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.focus-card,
.depth-card,
.artifact-inbox,
.system,
.final-cta {
    border: 1px solid var(--line);
    border-radius: var(--radius-xl);
    background:
        linear-gradient(180deg, rgba(20, 18, 18, 0.98), rgba(9, 9, 9, 0.98)),
        radial-gradient(circle at 88% 12%, var(--wine-glow), transparent 30%);
    box-shadow: var(--shadow-soft), inset 0 1px 0 rgba(255,255,255,0.05);
}

.focus-card {
    display: grid;
    gap: var(--space-2);
    padding: var(--space-3);
    overflow: hidden;
}

.depth-card,
.artifact-inbox {
    display: grid;
    gap: var(--space-2);
    margin: 0 var(--gutter);
    padding: var(--space-3);
    border: 1px solid var(--line);
    border-radius: var(--radius-xl);
    background:
        linear-gradient(180deg, rgba(18, 15, 15, 0.98), rgba(8, 8, 8, 0.98)),
        radial-gradient(circle at 86% 14%, rgba(143, 32, 41, 0.18), transparent 32%);
    box-shadow: var(--shadow-soft), inset 0 1px 0 rgba(255,255,255,0.05);
}

.depth-card h2,
.artifact-inbox h2 {
    margin: 0;
    color: var(--text);
    font-family: "Cormorant Garamond", serif;
    font-size: 36px;
    font-weight: 600;
    line-height: 0.96;
}

.depth-card p {
    max-width: 36ch;
    margin: var(--space-1) 0 0;
    color: var(--muted);
    font-size: 14px;
    line-height: 1.55;
}

.depth-card__meter {
    height: 3px;
    overflow: hidden;
    border-radius: 999px;
    background: rgba(255,255,255,0.08);
}

.depth-card__meter span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, rgba(255,255,255,0.72), #8f2029);
}

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

.depth-card__stats article {
    min-width: 0;
    padding: 13px 10px;
    border: 1px solid var(--line);
    border-radius: 14px;
    background: rgba(255,255,255,0.025);
}

.depth-card__stats strong {
    display: block;
    color: var(--text);
    font-family: "Cormorant Garamond", serif;
    font-size: 28px;
    line-height: .95;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.depth-card__stats span,
.artifact-chip small {
    display: block;
    margin-top: 6px;
    color: var(--faint);
    font-size: 10px;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.scenario-progression {
    display: grid;
    gap: var(--space-2);
}

.scenario-current,
.scenario-next {
    position: relative;
    overflow: hidden;
    border: 1px solid var(--line);
    border-radius: var(--radius-xl);
    background:
        linear-gradient(180deg, rgba(18, 15, 15, 0.96), rgba(7, 7, 7, 0.98)),
        radial-gradient(circle at 84% 12%, rgba(143, 32, 41, 0.2), transparent 34%),
        radial-gradient(circle at 16% 90%, rgba(201, 161, 108, 0.08), transparent 28%);
    box-shadow: var(--shadow-soft), inset 0 1px 0 rgba(255,255,255,0.05);
}

.scenario-current::before,
.scenario-next::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        linear-gradient(90deg, transparent 0 56%, rgba(255,255,255,0.025) 56% 56.3%, transparent 56.3%),
        linear-gradient(180deg, transparent 0 52%, rgba(255,255,255,0.018) 52% 52.3%, transparent 52.3%);
    opacity: 0.72;
}

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

.scenario-current__copy,
.scenario-depth,
.scenario-next > * {
    position: relative;
}

.scenario-current h2,
.scenario-next h3,
.scenario-level-card h3 {
    margin: 0;
    color: var(--text);
    font-family: "Cormorant Garamond", serif;
    font-weight: 600;
    line-height: 0.96;
    letter-spacing: 0;
}

.scenario-current h2 {
    margin-top: var(--space-1);
    font-size: 38px;
    text-wrap: balance;
}

.scenario-current p,
.scenario-next p,
.scenario-level-card p {
    margin: var(--space-1) 0 0;
    color: var(--muted);
    font-size: 14px;
    line-height: 1.55;
}

.scenario-depth {
    display: grid;
    gap: 10px;
}

.scenario-depth__top,
.scenario-depth__bottom {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: var(--space-1);
    color: rgba(246, 240, 234, 0.62);
    font-size: 12px;
    line-height: 1.3;
}

.scenario-depth__top strong,
.scenario-depth__bottom strong {
    color: var(--text);
    font-size: 14px;
    white-space: nowrap;
}

.scenario-depth__track {
    height: 4px;
    overflow: hidden;
    border-radius: 999px;
    background: rgba(255,255,255,0.07);
    box-shadow: inset 0 0 0 1px rgba(255,255,255,0.025);
}

.scenario-depth__track span {
    position: relative;
    display: block;
    height: 100%;
    min-width: 8px;
    border-radius: inherit;
    background: linear-gradient(90deg, rgba(120, 23, 31, 0.68), rgba(216, 86, 92, 0.92), rgba(246, 240, 234, 0.58));
    box-shadow: 0 0 18px rgba(143, 32, 41, 0.42);
    animation: scenario-meter-breathe 3.8s ease-in-out infinite;
}

.scenario-depth__track span::after {
    content: "";
    position: absolute;
    inset: 0;
    transform: translateX(-100%);
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.36), transparent);
    animation: scenario-meter-sweep 5.8s ease-in-out infinite;
}

.scenario-next {
    display: grid;
    gap: 6px;
    padding: 18px var(--space-3);
    border-color: rgba(201, 161, 108, 0.16);
    background:
        linear-gradient(180deg, rgba(15, 13, 13, 0.94), rgba(7, 7, 7, 0.98)),
        radial-gradient(circle at 86% 18%, rgba(201, 161, 108, 0.13), transparent 30%);
}

.scenario-next h3 {
    font-size: 30px;
}

.scenario-next p {
    margin-top: 0;
}

.scenario-next__shadow {
    display: block;
    margin-top: 4px;
    color: rgba(246, 240, 234, 0.48);
    font-size: 12px;
    line-height: 1.45;
}

.scenario-line {
    position: relative;
    display: grid;
    gap: 12px;
    padding: 4px 0 2px;
}

.scenario-line::before {
    content: "";
    position: absolute;
    left: 14px;
    top: 14px;
    bottom: 18px;
    width: 1px;
    background: linear-gradient(180deg, rgba(143, 32, 41, 0.62), rgba(201, 161, 108, 0.18), rgba(246, 240, 234, 0.035));
    box-shadow: 0 0 18px rgba(143, 32, 41, 0.18);
}

.scenario-level-card {
    position: relative;
    display: grid;
    grid-template-columns: 30px minmax(0, 1fr);
    gap: 12px;
}

.scenario-level-card__marker {
    position: relative;
    z-index: 1;
    width: 29px;
    height: 29px;
    margin-top: 14px;
    border: 1px solid rgba(246, 240, 234, 0.14);
    border-radius: 50%;
    background: radial-gradient(circle, rgba(143, 32, 41, 0.38), rgba(8, 8, 8, 0.98) 64%);
    box-shadow: 0 0 20px rgba(143, 32, 41, 0.2), inset 0 1px 0 rgba(255,255,255,0.06);
}

.scenario-level-card__body {
    position: relative;
    min-height: 126px;
    padding: 15px 16px 14px;
    overflow: hidden;
    border: 1px solid rgba(246, 240, 234, 0.09);
    border-radius: 18px;
    background:
        linear-gradient(180deg, rgba(16, 14, 14, 0.88), rgba(8, 8, 8, 0.94)),
        radial-gradient(circle at 92% 14%, rgba(143, 32, 41, 0.12), transparent 30%);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}

.scenario-level-card__meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-1);
    margin-bottom: 8px;
}

.scenario-level-card__meta span,
.scenario-level-card__meta em,
.scenario-level-card small {
    color: rgba(246, 240, 234, 0.52);
    font-size: 10px;
    font-style: normal;
    font-weight: 800;
    line-height: 1.2;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.scenario-level-card__meta em {
    color: rgba(188, 54, 62, 0.82);
}

.scenario-level-card h3 {
    font-size: 27px;
}

.scenario-level-card p {
    font-size: 13px;
}

.scenario-level-card small {
    display: block;
    margin-top: 12px;
    color: rgba(246, 240, 234, 0.42);
}

.scenario-level-card--opened .scenario-level-card__body {
    border-color: rgba(101, 21, 27, 0.42);
    box-shadow: 0 0 24px rgba(101, 21, 27, 0.12), inset 0 1px 0 rgba(255,255,255,0.04);
}

.scenario-level-card--opened .scenario-level-card__marker {
    border-color: rgba(143, 32, 41, 0.5);
    background: radial-gradient(circle, rgba(143, 32, 41, 0.6), rgba(12, 8, 8, 0.98) 68%);
}

.scenario-level-card--current .scenario-level-card__body {
    border-color: rgba(226, 78, 86, 0.54);
    background:
        linear-gradient(180deg, rgba(22, 16, 16, 0.94), rgba(8, 8, 8, 0.96)),
        radial-gradient(circle at 84% 14%, rgba(143, 32, 41, 0.28), transparent 34%);
    box-shadow: 0 0 34px rgba(143, 32, 41, 0.28), inset 0 1px 0 rgba(255,255,255,0.06);
    animation: scenario-current-border 4.2s ease-in-out infinite;
}

.scenario-level-card--current .scenario-level-card__marker {
    border-color: rgba(246, 240, 234, 0.46);
    background: radial-gradient(circle, rgba(255, 116, 124, 0.92), rgba(143, 32, 41, 0.46) 44%, rgba(8, 8, 8, 0.98) 72%);
    box-shadow: 0 0 30px rgba(143, 32, 41, 0.58), inset 0 1px 0 rgba(255,255,255,0.14);
    animation: scenario-current-pulse 3.2s ease-in-out infinite;
}

.scenario-level-card--current .scenario-level-card__meta em {
    color: #ff7c74;
}

.scenario-level-card--locked {
    opacity: 0.58;
}

.scenario-level-card--locked .scenario-level-card__body {
    max-height: 142px;
    border-color: rgba(246, 240, 234, 0.06);
    background:
        linear-gradient(180deg, rgba(14, 13, 13, 0.68), rgba(6, 6, 6, 0.9)),
        radial-gradient(circle at 88% 18%, rgba(255,255,255,0.035), transparent 30%);
    mask-image: linear-gradient(180deg, #000 0 78%, rgba(0,0,0,0.34) 100%);
}

.scenario-level-card--locked h3,
.scenario-level-card--locked p {
    filter: blur(0.24px);
}

.scenario-level-card--locked .scenario-level-card__marker {
    border-color: rgba(246, 240, 234, 0.09);
    background: radial-gradient(circle, rgba(246, 240, 234, 0.14), rgba(8, 8, 8, 0.98) 66%);
    box-shadow: none;
}

@keyframes scenario-meter-breathe {
    0%, 100% {
        filter: brightness(0.92);
    }
    50% {
        filter: brightness(1.15);
    }
}

@keyframes scenario-meter-sweep {
    0%, 58% {
        transform: translateX(-120%);
        opacity: 0;
    }
    72% {
        opacity: 1;
    }
    100% {
        transform: translateX(120%);
        opacity: 0;
    }
}

@keyframes scenario-current-pulse {
    0%, 100% {
        transform: scale(1);
        box-shadow: 0 0 24px rgba(143, 32, 41, 0.44), inset 0 1px 0 rgba(255,255,255,0.14);
    }
    50% {
        transform: scale(1.08);
        box-shadow: 0 0 42px rgba(190, 58, 66, 0.66), inset 0 1px 0 rgba(255,255,255,0.18);
    }
}

@keyframes scenario-current-border {
    0%, 100% {
        border-color: rgba(226, 78, 86, 0.42);
    }
    50% {
        border-color: rgba(246, 240, 234, 0.24);
    }
}

.artifact-inbox[hidden] {
    display: none !important;
}

.artifact-inbox__list {
    display: grid;
    gap: var(--space-1);
}

.artifact-chip {
    display: grid;
    gap: 2px;
    min-height: 58px;
    padding: 12px 14px;
    border: 1px solid rgba(246, 240, 234, 0.12);
    border-radius: 14px;
    background: rgba(255,255,255,0.035);
    color: var(--text);
    text-align: left;
}

.artifact-chip span {
    font-family: "Cormorant Garamond", serif;
    font-size: 22px;
    line-height: 1;
}

.focus-card__index {
    color: var(--wine);
    font-family: "Cormorant Garamond", serif;
    font-size: 56px;
    line-height: 0.9;
}

.focus-card h3 {
    max-width: 9em;
    margin: 0;
    color: var(--text);
    font-family: "Cormorant Garamond", serif;
    font-size: 42px;
    font-weight: 600;
    line-height: 0.94;
    letter-spacing: -0.03em;
}

.focus-card p {
    max-width: 33ch;
    margin: var(--space-1) 0 0;
    color: var(--muted);
    font-size: 14px;
    line-height: 1.56;
}

.tag-row {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-1);
    margin-top: var(--space-2);
}

.tag-row span {
    min-height: 32px;
    display: inline-flex;
    align-items: center;
    padding: 0 12px;
    border: 1px solid var(--line);
    border-radius: 999px;
    color: rgba(246, 240, 234, 0.82);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.focus-card__art {
    position: relative;
    min-height: 240px;
    overflow: hidden;
    border-radius: var(--radius-lg);
    border: 1px solid var(--line);
    background: #080808;
}

.focus-card__art::before {
    content: "";
    position: absolute;
    inset: 12%;
    border-radius: 50%;
    border: 1px solid rgba(246, 240, 234, 0.12);
}

.focus-card__art::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(transparent 49.8%, rgba(255,255,255,0.04) 50%, transparent 50.2%),
        linear-gradient(90deg, transparent 49.8%, rgba(255,255,255,0.03) 50%, transparent 50.2%);
}

.focus-card__art img {
    position: absolute;
    right: -16%;
    bottom: -12%;
    width: 88%;
    height: 88%;
    object-fit: cover;
    border-radius: 50%;
}

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

.branch-card {
    min-height: 128px;
    display: grid;
    align-content: space-between;
    gap: 8px;
    padding: var(--space-2);
    border: 1px solid var(--line);
    border-radius: 18px;
    background: rgba(255,255,255,0.025);
    color: inherit;
    text-decoration: none;
    text-align: left;
    transition: transform 220ms ease, border-color 220ms ease, box-shadow 220ms ease;
}

.branch-card__icon {
    width: 28px;
    height: 28px;
    color: rgba(246, 240, 234, 0.72);
}

.branch-card strong {
    display: block;
    color: var(--text);
    font-family: "Cormorant Garamond", serif;
    font-size: 25px;
    font-weight: 600;
    line-height: 0.98;
}

.branch-card span:last-child {
    color: var(--faint);
    font-size: 12px;
    line-height: 1.35;
}

.branch-card small {
    display: block;
    color: rgba(201, 161, 108, .88);
    font-size: 11px;
    line-height: 1.35;
}

.branch-card--level_locked {
    opacity: .72;
}

.branch-card--level_locked .branch-card__icon,
.branch-card--subscription_locked .branch-card__icon {
    color: rgba(201, 161, 108, .78);
}

.branch-card--level_locked {
    border-color: rgba(255, 255, 255, .08);
    background: rgba(255, 255, 255, .015);
}

.branch-card--subscription_locked {
    border-color: rgba(201, 161, 108, .18);
    background: rgba(201, 161, 108, .045);
}

.reason-list,
.process-list {
    display: grid;
    gap: var(--space-1);
}

.reason-list article,
.process-list article,
.system-metrics article {
    border: 1px solid var(--line);
    border-radius: 18px;
    background: rgba(255,255,255,0.025);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}

.reason-list article {
    display: grid;
    gap: 6px;
    padding: var(--space-2);
}

.reason-list span,
.process-list span {
    color: var(--wine);
    font-family: "Cormorant Garamond", serif;
    font-size: 24px;
    line-height: 1;
}

.reason-list strong {
    color: var(--text);
    font-size: 15px;
    line-height: 1.2;
}

.reason-list p {
    margin: 0;
    color: var(--muted);
    font-size: 13px;
    line-height: 1.5;
}

.process-list article {
    display: grid;
    grid-template-columns: 44px minmax(0, 1fr);
    align-items: center;
    gap: var(--space-1);
    padding: 14px var(--space-2);
}

.process-list p {
    margin: 0;
    color: var(--text);
    font-size: 14px;
    line-height: 1.35;
}

.system,
.final-cta {
    display: grid;
    gap: var(--space-2);
    padding: var(--space-3);
}

.system h2,
.final-cta h2 {
    font-size: 40px;
}

.system p,
.final-cta p {
    margin: 0;
}

.system-metrics {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-1);
}

.system-metrics article {
    padding: var(--space-2);
}

.system-metrics strong {
    display: block;
    color: var(--text);
    font-family: "Cormorant Garamond", serif;
    font-size: 30px;
    line-height: 0.95;
}

.system-metrics span {
    display: block;
    margin-top: 6px;
    color: var(--faint);
    font-size: 12px;
    line-height: 1.3;
    text-transform: uppercase;
}


.ref-modal {
    position: fixed;
    inset: 0;
    z-index: 40;
    display: none;
    align-items: center;
    justify-content: center;
    padding: var(--space-2);
}

.ref-modal.is-open {
    display: flex;
}

.ref-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(5,5,5,0.84);
    backdrop-filter: blur(14px);
}

.ref-modal__dialog {
    position: relative;
    z-index: 1;
    width: min(100%, 360px);
    padding: var(--space-3);
    border: 1px solid var(--line);
    border-radius: var(--radius-lg);
    background: linear-gradient(180deg, rgba(20,18,18,0.98), rgba(9,9,9,0.98));
    box-shadow: var(--shadow);
}

.ref-modal__dialog h2 {
    margin: var(--space-1) 0;
    color: var(--text);
    font-family: "Cormorant Garamond", serif;
    font-size: 38px;
    line-height: 0.95;
}

.ref-modal__dialog p {
    margin: 0;
    color: var(--muted);
    font-size: 14px;
    line-height: 1.55;
}

.ref-modal__close {
    position: absolute;
    right: var(--space-2);
    top: var(--space-2);
    width: 28px;
    height: 28px;
    color: rgba(246,240,234,0.7);
}

.ref-modal__close svg {
    width: 100%;
    height: 100%;
}

.button__ripple {
    position: absolute;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: rgba(255,255,255,0.16);
    transform: translate(-50%, -50%) scale(0);
    animation: ripple 650ms ease-out forwards;
    pointer-events: none;
}

.reveal {
    opacity: 0;
    transform: translateY(18px);
}

.is-visible {
    animation: fade-up 620ms cubic-bezier(0.2, 0.7, 0.2, 1) forwards;
}

@keyframes fade-up {
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes ripple {
    to {
        transform: translate(-50%, -50%) scale(12);
        opacity: 0;
    }
}

/* Compact cinematic progression */
.scenario-progression {
    gap: 14px;
}

.scenario-current {
    min-height: 278px;
    align-content: end;
    gap: 26px;
    padding: 24px 22px 22px;
    border-color: rgba(246, 240, 234, 0.13);
    background:
        linear-gradient(180deg, rgba(9, 8, 8, 0.18), rgba(7, 7, 7, 0.98) 72%),
        radial-gradient(circle at 50% 18%, rgba(143, 32, 41, 0.34), transparent 38%),
        radial-gradient(circle at 76% 22%, rgba(246, 240, 234, 0.1), transparent 24%),
        #060606;
    box-shadow: 0 24px 62px rgba(0, 0, 0, 0.46), 0 0 52px rgba(143, 32, 41, 0.14), inset 0 1px 0 rgba(255,255,255,0.06);
}

.scenario-current::after {
    content: "";
    position: absolute;
    left: 50%;
    top: 34px;
    width: 164px;
    aspect-ratio: 1;
    transform: translateX(-50%);
    border: 1px solid rgba(246, 240, 234, 0.12);
    border-radius: 50%;
    box-shadow: 0 0 54px rgba(143, 32, 41, 0.24);
    opacity: 0.9;
    pointer-events: none;
    animation: scenario-orbit-glow 5.4s ease-in-out infinite;
}

.scenario-current__copy {
    z-index: 1;
}

.scenario-current h2 {
    max-width: 8em;
    font-size: 48px;
    line-height: 0.9;
}

.scenario-current p {
    max-width: 25ch;
    color: rgba(246, 240, 234, 0.74);
    font-size: 15px;
}

.scenario-depth {
    z-index: 1;
    padding: 14px;
    border: 1px solid rgba(246, 240, 234, 0.1);
    border-radius: 18px;
    background: rgba(5, 5, 5, 0.46);
    backdrop-filter: blur(14px);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.045);
}

.scenario-depth__track {
    height: 3px;
}

.scenario-next {
    min-height: 160px;
    align-content: end;
    gap: 8px;
    padding: 20px;
    border-color: rgba(201, 161, 108, 0.14);
    background:
        linear-gradient(180deg, rgba(12, 11, 11, 0.66), rgba(7, 7, 7, 0.98)),
        radial-gradient(circle at 88% 18%, rgba(201, 161, 108, 0.16), transparent 34%),
        radial-gradient(circle at 20% 90%, rgba(143, 32, 41, 0.18), transparent 32%),
        #070707;
}

.scenario-next h3 {
    max-width: 10em;
    font-size: 34px;
}

.scenario-next p {
    max-width: 29ch;
    color: rgba(246, 240, 234, 0.72);
    font-size: 14px;
}

.scenario-next__shadow {
    width: max-content;
    max-width: 100%;
    margin-top: 6px;
    padding: 8px 10px;
    border: 1px solid rgba(246, 240, 234, 0.09);
    border-radius: 999px;
    background: rgba(255,255,255,0.03);
    color: rgba(246, 240, 234, 0.58);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.scenario-next__shadow b {
    color: rgba(246, 240, 234, 0.86);
}

.scenario-line {
    position: relative;
    display: grid;
    gap: 10px;
    max-height: min(620px, 72svh);
    margin-top: 2px;
    padding: 4px 0 8px;
    overflow-x: hidden;
    overflow-y: auto;
    overscroll-behavior: contain;
    scroll-snap-type: y proximity;
    -webkit-overflow-scrolling: touch;
}

.scenario-line::-webkit-scrollbar {
    width: 0;
}

.scenario-line::before {
    left: 13px;
    top: 20px;
    bottom: 28px;
    width: 1px;
    height: auto;
    background: linear-gradient(180deg, rgba(246, 240, 234, 0.08), rgba(185, 48, 58, 0.58), rgba(201, 161, 108, 0.16), rgba(246, 240, 234, 0.04));
    box-shadow: 0 0 22px rgba(143, 32, 41, 0.24);
}

.scenario-line-head {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 12px;
    padding: 4px 2px 0;
}

.scenario-line-head p {
    max-width: 17ch;
    margin: 0;
    color: rgba(246, 240, 234, 0.46);
    font-size: 12px;
    line-height: 1.35;
    text-align: right;
}

.scenario-line::after {
    content: "";
    position: sticky;
    left: 0;
    right: 0;
    bottom: -8px;
    z-index: 4;
    height: 42px;
    margin-top: -42px;
    background: linear-gradient(180deg, transparent, var(--bg) 82%);
    pointer-events: none;
}

.scenario-level-card {
    position: relative;
    display: grid;
    grid-template-columns: 28px minmax(0, 1fr);
    gap: 12px;
    scroll-snap-align: start;
}

.scenario-level-card__node {
    position: relative;
    z-index: 2;
    width: 27px;
    height: 27px;
    margin-top: 22px;
    border: 1px solid rgba(246, 240, 234, 0.14);
    border-radius: 50%;
    background: radial-gradient(circle, rgba(143, 32, 41, 0.32), rgba(7, 7, 7, 0.98) 68%);
    box-shadow: 0 0 18px rgba(143, 32, 41, 0.18), inset 0 1px 0 rgba(255,255,255,0.06);
}

.scenario-level-card__body {
    min-height: 82px;
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr);
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
    border-radius: 17px;
}

.scenario-level-card__roman {
    display: grid;
    place-items: center;
    grid-row: 1 / span 2;
    width: 38px;
    height: 38px;
    border: 1px solid rgba(246, 240, 234, 0.14);
    border-radius: 50%;
    color: rgba(246, 240, 234, 0.82);
    font-family: "Cormorant Garamond", serif;
    font-size: 20px;
    line-height: 1;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.06);
}

.scenario-level-card strong {
    display: block;
    min-height: 0;
    color: var(--text);
    font-family: "Cormorant Garamond", serif;
    font-size: 25px;
    font-weight: 600;
    line-height: 0.96;
}

.scenario-level-card small {
    margin: 0;
    color: rgba(246, 240, 234, 0.5);
    font-size: 10px;
}

.scenario-level-card--opened .scenario-level-card__body {
    border-color: rgba(246, 240, 234, 0.12);
    background:
        linear-gradient(180deg, rgba(25, 22, 22, 0.94), rgba(10, 10, 10, 0.96)),
        radial-gradient(circle at 78% 12%, rgba(143, 32, 41, 0.18), transparent 34%);
    box-shadow: 0 0 28px rgba(143, 32, 41, 0.14), inset 0 1px 0 rgba(255,255,255,0.05);
}

.scenario-level-card--opened .scenario-level-card__node {
    border-color: rgba(246, 240, 234, 0.2);
    background: radial-gradient(circle, rgba(246, 240, 234, 0.74), rgba(143, 32, 41, 0.44) 42%, rgba(7, 7, 7, 0.98) 72%);
    box-shadow: 0 0 26px rgba(143, 32, 41, 0.28), inset 0 1px 0 rgba(255,255,255,0.12);
}

.scenario-level-card--current .scenario-level-card__body {
    min-height: 104px;
    border-color: rgba(255, 110, 118, 0.56);
    background:
        linear-gradient(180deg, rgba(28, 18, 18, 0.98), rgba(8, 8, 8, 0.98)),
        radial-gradient(circle at 78% 14%, rgba(210, 62, 72, 0.26), transparent 36%);
    box-shadow: 0 0 42px rgba(143, 32, 41, 0.34), inset 0 1px 0 rgba(255,255,255,0.08);
    animation: scenario-current-border 4.2s ease-in-out infinite;
}

.scenario-level-card--current .scenario-level-card__node {
    border-color: rgba(255, 195, 198, 0.66);
    background: radial-gradient(circle, rgba(255, 155, 160, 0.96), rgba(190, 58, 66, 0.62) 42%, rgba(7, 7, 7, 0.98) 74%);
    box-shadow: 0 0 36px rgba(190, 58, 66, 0.68), inset 0 1px 0 rgba(255,255,255,0.16);
    animation: scenario-current-pulse 3.2s ease-in-out infinite;
}

.scenario-level-card--current .scenario-level-card__roman {
    border-color: rgba(255, 185, 188, 0.54);
    background: rgba(143, 32, 41, 0.38);
    box-shadow: 0 0 28px rgba(190, 58, 66, 0.56), inset 0 1px 0 rgba(255,255,255,0.14);
    animation: scenario-current-pulse 3.2s ease-in-out infinite;
}

.scenario-level-card--locked {
    opacity: 1;
}

.scenario-level-card--locked .scenario-level-card__body {
    border-color: rgba(246, 240, 234, 0.055);
    background:
        linear-gradient(180deg, rgba(12, 12, 12, 0.7), rgba(5, 5, 5, 0.94)),
        radial-gradient(circle at 80% 12%, rgba(246, 240, 234, 0.04), transparent 32%);
    box-shadow: none;
    mask-image: linear-gradient(180deg, #000 0 76%, rgba(0,0,0,0.44) 100%);
}

.scenario-level-card--locked .scenario-level-card__node {
    border-color: rgba(246, 240, 234, 0.08);
    background: radial-gradient(circle, rgba(246, 240, 234, 0.12), rgba(7, 7, 7, 0.98) 68%);
    box-shadow: none;
}

.scenario-level-card--locked .scenario-level-card__roman,
.scenario-level-card--locked strong {
    color: rgba(246, 240, 234, 0.38);
    filter: blur(0.18px);
}

@keyframes scenario-orbit-glow {
    0%, 100% {
        opacity: 0.68;
        transform: translateX(-50%) scale(0.98);
    }
    50% {
        opacity: 1;
        transform: translateX(-50%) scale(1.04);
    }
}

/* Visual path override: timeline is a map, not a list */
.scenario-line {
    grid-template-columns: minmax(0, 1fr) 34px minmax(0, 1fr);
    gap: 14px 0;
    max-height: min(650px, 74svh);
    padding: 10px 2px 54px;
}

.scenario-line::before {
    left: 50%;
    top: 18px;
    bottom: 34px;
    width: 1px;
    transform: translateX(-50%);
    background:
        linear-gradient(180deg,
            rgba(246, 240, 234, 0.08),
            rgba(185, 48, 58, 0.66) 32%,
            rgba(201, 161, 108, 0.18) 70%,
            rgba(246, 240, 234, 0.035));
    box-shadow: 0 0 22px rgba(143, 32, 41, 0.36), 0 0 54px rgba(143, 32, 41, 0.14);
}

.scenario-level-card {
    grid-template-columns: minmax(0, 1fr);
    gap: 0;
    min-width: 0;
}

.scenario-level-card:nth-child(odd) {
    grid-column: 1 / 2;
    padding-right: 12px;
}

.scenario-level-card:nth-child(even) {
    grid-column: 3 / 4;
    padding-left: 12px;
}

.scenario-level-card.is-current {
    grid-column: 1 / -1;
    width: calc(100% - 38px);
    margin: 3px auto;
    padding: 0;
}

.scenario-level-card__node {
    position: absolute;
    left: auto;
    right: -17px;
    top: 50%;
    width: 27px;
    height: 27px;
    margin: 0;
    transform: translate(50%, -50%);
}

.scenario-level-card:nth-child(even) .scenario-level-card__node {
    left: -17px;
    right: auto;
    transform: translate(-50%, -50%);
}

.scenario-level-card.is-current .scenario-level-card__node {
    left: 50%;
    right: auto;
    top: -15px;
    width: 34px;
    height: 34px;
    transform: translateX(-50%);
}

.scenario-level-card__body {
    position: relative;
    min-height: 104px;
    grid-template-columns: 1fr;
    align-content: space-between;
    align-items: stretch;
    gap: 8px;
    padding: 13px;
    overflow: hidden;
    isolation: isolate;
}

.scenario-level-card__body::before {
    content: "";
    position: absolute;
    inset: 10px;
    z-index: -1;
    border: 1px solid rgba(246, 240, 234, 0.055);
    border-radius: 13px;
    opacity: 0.9;
}

.scenario-level-card__veil {
    position: absolute;
    right: -14px;
    bottom: -22px;
    z-index: -1;
    color: rgba(246, 240, 234, 0.045);
    font-family: "Cormorant Garamond", serif;
    font-size: 92px;
    font-weight: 600;
    line-height: 0.8;
    pointer-events: none;
}

.scenario-level-card__veil::before {
    content: attr(data-veil);
}

.scenario-level-card__roman {
    width: 36px;
    height: 36px;
    grid-row: auto;
    color: rgba(246, 240, 234, 0.8);
    font-size: 21px;
}

.scenario-level-card__body .scenario-level-card__veil {
    display: block;
}

.scenario-level-card__body .scenario-level-card__veil + .scenario-level-card__roman + strong + small {
    position: relative;
}

.scenario-level-card strong {
    min-height: 34px;
    max-width: 8ch;
    font-size: 23px;
    text-wrap: balance;
}

.scenario-level-card small {
    width: max-content;
    max-width: 100%;
    padding: 5px 7px;
    border: 1px solid rgba(246, 240, 234, 0.065);
    border-radius: 999px;
    background: rgba(255,255,255,0.025);
    line-height: 1;
}

.scenario-level-card--opened .scenario-level-card__body::after {
    content: "";
    position: absolute;
    right: 12px;
    top: 12px;
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: rgba(246, 240, 234, 0.72);
    box-shadow: 0 0 16px rgba(143, 32, 41, 0.38);
}

.scenario-level-card--current .scenario-level-card__body {
    min-height: 126px;
    padding: 18px;
}

.scenario-level-card--current .scenario-level-card__roman {
    width: 44px;
    height: 44px;
    font-size: 25px;
}

.scenario-level-card--current strong {
    max-width: none;
    font-size: 32px;
}

.scenario-level-card--current small {
    color: rgba(255, 235, 235, 0.88);
    border-color: rgba(255, 120, 128, 0.2);
    background: rgba(143, 32, 41, 0.16);
}

.scenario-level-card--locked .scenario-level-card__body {
    opacity: 0.72;
    filter: saturate(0.72);
}

.scenario-level-card--locked .scenario-level-card__body::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 0 58%, rgba(5, 5, 5, 0.62) 100%);
    pointer-events: none;
}

.scenario-level-card--locked small {
    color: rgba(246, 240, 234, 0.34);
}

.scenario-level-card:active {
    transform: scale(0.985);
}

/* Final scenario-only progression shell */
.scenario-progression {
    width: calc(100% - (var(--gutter) * 2));
    margin: 0 var(--gutter);
    padding: 16px;
    overflow: hidden;
    border: 1px solid rgba(246, 240, 234, 0.1);
    border-radius: var(--radius-xl);
    background:
        linear-gradient(180deg, rgba(14, 12, 12, 0.86), rgba(5, 5, 5, 0.98)),
        radial-gradient(circle at 50% 0%, rgba(143, 32, 41, 0.18), transparent 34%),
        radial-gradient(circle at 88% 72%, rgba(201, 161, 108, 0.08), transparent 28%);
    box-shadow: 0 24px 70px rgba(0, 0, 0, 0.44), inset 0 1px 0 rgba(255,255,255,0.055);
}

.scenario-progression__header {
    position: relative;
    z-index: 1;
    display: grid;
    gap: 6px;
    padding: 2px 2px 4px;
}

.scenario-progression__header h2 {
    max-width: 9em;
    margin: 0;
    color: var(--text);
    font-family: "Cormorant Garamond", serif;
    font-size: 35px;
    font-weight: 600;
    line-height: 0.94;
    letter-spacing: 0;
}

.scenario-current,
.scenario-next {
    margin: 0;
}

.scenario-line-head {
    padding-top: 2px;
}

.scenario-line-head .eyebrow {
    color: rgba(246, 240, 234, 0.56);
}

.scenario-level-card__veil::before {
    content: "";
}

@media (hover: hover) and (pointer: fine) {
    .scenario-level-card {
        transition: transform 220ms ease;
    }

    .scenario-level-card:hover {
        transform: translateY(-2px);
    }
}

@media (hover: hover) and (pointer: fine) {
    .btn:hover,
    .branch-card:hover {
        transform: translateY(-2px);
    }

    .btn--primary:hover {
        filter: brightness(1.08);
    }

    .branch-card:hover {
        border-color: var(--line-strong);
        box-shadow: 0 14px 36px rgba(0,0,0,0.3), 0 0 0 1px rgba(143,32,41,0.12);
    }
}

@media (min-width: 520px) {
    .home-ref-main {
        max-width: 560px;
    }

    .home-hero {
        min-height: 640px;
    }

    .focus-card {
        grid-template-columns: minmax(0, 1fr) 230px;
        align-items: center;
    }

    .branch-grid,
    .reason-list,
    .system-metrics {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (min-width: 760px) {
    .home-ref-main {
        max-width: 860px;
    }

    .product-home {
        gap: 40px;
    }

    .home-hero {
        min-height: 700px;
    }

    .home-hero__content {
        max-width: 520px;
    }

    .home-hero h1 {
        font-size: 72px;
    }
}

@media (max-width: 390px) {
    :root {
        --gutter: 12px;
    }

    .home-hero {
        min-height: 620px;
        border-radius: 24px;
    }

    .home-hero h1 {
        font-size: 48px;
    }

    .home-hero__text {
        font-size: 14px;
    }

    .focus-card,
    .system,
    .final-cta {
        padding: var(--space-2);
    }

    .focus-card h3,
    .system h2,
    .final-cta h2 {
        font-size: 34px;
    }

    .signal-strip strong {
        font-size: 19px;
    }

    .scenario-current {
        min-height: 258px;
        padding: 22px 18px 18px;
    }

    .scenario-current h2 {
        font-size: 42px;
    }

    .scenario-next h3 {
        font-size: 30px;
    }

    .scenario-level-card {
        flex-basis: 108px;
    }

    .scenario-level-card--current {
        flex-basis: 124px;
    }

    .scenario-level-card strong {
        font-size: 21px;
    }
}

@media (max-width: 340px) {
    .signal-strip,
    .branch-grid,
    .reason-list,
    .system-metrics {
        grid-template-columns: 1fr;
    }
}

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

/* Scenario levels: final visual path layer */
.scenario-progression {
    position: relative;
    display: grid;
    gap: 16px;
    width: calc(100% - (var(--gutter) * 2));
    margin: 0 var(--gutter);
    padding: 18px;
    overflow: hidden;
    border: 1px solid rgba(246, 240, 234, 0.12);
    border-radius: var(--radius-xl);
    background:
        linear-gradient(180deg, rgba(16, 13, 13, 0.92), rgba(5, 5, 5, 0.98)),
        radial-gradient(circle at 50% 0%, rgba(143, 32, 41, 0.22), transparent 34%),
        radial-gradient(circle at 92% 74%, rgba(201, 161, 108, 0.08), transparent 30%);
    box-shadow: 0 28px 76px rgba(0, 0, 0, 0.48), inset 0 1px 0 rgba(255, 255, 255, 0.055);
}

.scenario-progression__header {
    display: grid;
    gap: 8px;
}

.scenario-progression__header h2 {
    max-width: 10em;
    margin: 0;
    color: var(--text);
    font-family: "Cormorant Garamond", serif;
    font-size: 38px;
    font-weight: 600;
    line-height: 0.94;
    letter-spacing: 0;
}

.scenario-current,
.scenario-next {
    position: relative;
    overflow: hidden;
    border: 1px solid rgba(246, 240, 234, 0.11);
    border-radius: 24px;
    box-shadow: 0 18px 48px rgba(0, 0, 0, 0.34), inset 0 1px 0 rgba(255, 255, 255, 0.055);
}

.scenario-current {
    min-height: 270px;
    display: grid;
    align-content: end;
    gap: 22px;
    padding: 24px 22px 22px;
    background:
        linear-gradient(180deg, rgba(10, 8, 8, 0.18), rgba(7, 7, 7, 0.98) 74%),
        radial-gradient(circle at 50% 18%, rgba(185, 48, 58, 0.3), transparent 36%),
        radial-gradient(circle at 76% 22%, rgba(246, 240, 234, 0.09), transparent 24%),
        #060606;
}

.scenario-current::after {
    content: "";
    position: absolute;
    left: 50%;
    top: 34px;
    width: 160px;
    aspect-ratio: 1;
    transform: translateX(-50%);
    border: 1px solid rgba(246, 240, 234, 0.12);
    border-radius: 50%;
    box-shadow: 0 0 54px rgba(143, 32, 41, 0.24);
    pointer-events: none;
    animation: scenario-orbit-glow 5.4s ease-in-out infinite;
}

.scenario-current__copy,
.scenario-depth,
.scenario-next > * {
    position: relative;
    z-index: 1;
}

.scenario-current h2,
.scenario-next h3 {
    margin: 0;
    color: var(--text);
    font-family: "Cormorant Garamond", serif;
    font-weight: 600;
    letter-spacing: 0;
}

.scenario-current h2 {
    max-width: 8em;
    margin-top: 8px;
    font-size: 48px;
    line-height: 0.9;
}

.scenario-current p,
.scenario-next p {
    max-width: 30ch;
    margin: 8px 0 0;
    color: rgba(246, 240, 234, 0.74);
    font-size: 15px;
    line-height: 1.48;
}

.scenario-depth {
    display: grid;
    gap: 10px;
    padding: 14px;
    border: 1px solid rgba(246, 240, 234, 0.1);
    border-radius: 18px;
    background: rgba(5, 5, 5, 0.48);
    backdrop-filter: blur(14px);
}

.scenario-depth__top,
.scenario-depth__bottom {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    color: rgba(246, 240, 234, 0.58);
    font-size: 12px;
}

.scenario-depth__top strong,
.scenario-depth__bottom strong {
    color: var(--text);
    white-space: nowrap;
}

.scenario-depth__track {
    height: 3px;
    overflow: hidden;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.075);
}

.scenario-depth__track span {
    display: block;
    height: 100%;
    min-width: 8px;
    border-radius: inherit;
    background: linear-gradient(90deg, rgba(120, 23, 31, 0.72), rgba(216, 86, 92, 0.95), rgba(246, 240, 234, 0.62));
    box-shadow: 0 0 18px rgba(143, 32, 41, 0.44);
    animation: scenario-meter-breathe 3.8s ease-in-out infinite;
}

.scenario-next {
    min-height: 158px;
    display: grid;
    align-content: end;
    gap: 8px;
    padding: 20px;
    background:
        linear-gradient(180deg, rgba(12, 11, 11, 0.66), rgba(7, 7, 7, 0.98)),
        radial-gradient(circle at 88% 18%, rgba(201, 161, 108, 0.16), transparent 34%),
        radial-gradient(circle at 20% 90%, rgba(143, 32, 41, 0.18), transparent 32%),
        #070707;
}

.scenario-next h3 {
    max-width: 10em;
    font-size: 34px;
    line-height: 0.96;
}

.scenario-next__shadow {
    width: max-content;
    max-width: 100%;
    margin-top: 6px;
    padding: 8px 10px;
    border: 1px solid rgba(246, 240, 234, 0.09);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.03);
    color: rgba(246, 240, 234, 0.58);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.scenario-next__shadow b {
    color: rgba(246, 240, 234, 0.88);
}

.scenario-line-head {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 12px;
    padding: 4px 2px 0;
}

.scenario-line-head p {
    max-width: 18ch;
    margin: 0;
    color: rgba(246, 240, 234, 0.46);
    font-size: 12px;
    line-height: 1.35;
    text-align: right;
}

.scenario-line {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 34px minmax(0, 1fr);
    gap: 16px 0;
    max-height: min(720px, 78svh);
    padding: 12px 2px 54px;
    overflow-x: hidden;
    overflow-y: auto;
    overscroll-behavior: contain;
    scroll-snap-type: y proximity;
    -webkit-overflow-scrolling: touch;
}

.scenario-line::-webkit-scrollbar {
    width: 0;
}

.scenario-line::before {
    content: "";
    position: absolute;
    left: 50%;
    top: 18px;
    bottom: 34px;
    width: 1px;
    transform: translateX(-50%);
    background: linear-gradient(180deg, rgba(246, 240, 234, 0.08), rgba(185, 48, 58, 0.66) 32%, rgba(201, 161, 108, 0.18) 70%, rgba(246, 240, 234, 0.035));
    box-shadow: 0 0 22px rgba(143, 32, 41, 0.36), 0 0 54px rgba(143, 32, 41, 0.14);
}

.scenario-line::after {
    content: "";
    position: sticky;
    left: 0;
    right: 0;
    bottom: -54px;
    z-index: 4;
    grid-column: 1 / -1;
    height: 48px;
    margin-top: -48px;
    background: linear-gradient(180deg, transparent, rgba(5, 5, 5, 0.98) 82%);
    pointer-events: none;
}

.scenario-level-card {
    position: relative;
    min-width: 0;
    scroll-snap-align: start;
    transition: transform 220ms ease;
}

.scenario-level-card:nth-child(odd) {
    grid-column: 1 / 2;
    padding-right: 12px;
}

.scenario-level-card:nth-child(even) {
    grid-column: 3 / 4;
    padding-left: 12px;
}

.scenario-level-card.is-current {
    grid-column: 1 / -1;
    width: calc(100% - 40px);
    margin: 4px auto;
    padding: 0;
}

.scenario-level-card__node {
    position: absolute;
    z-index: 3;
    right: -17px;
    top: 50%;
    width: 27px;
    height: 27px;
    border: 1px solid rgba(246, 240, 234, 0.14);
    border-radius: 50%;
    transform: translate(50%, -50%);
    background: radial-gradient(circle, rgba(143, 32, 41, 0.32), rgba(7, 7, 7, 0.98) 68%);
    box-shadow: 0 0 18px rgba(143, 32, 41, 0.18), inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.scenario-level-card:nth-child(even) .scenario-level-card__node {
    left: -17px;
    right: auto;
    transform: translate(-50%, -50%);
}

.scenario-level-card.is-current .scenario-level-card__node {
    left: 50%;
    right: auto;
    top: -16px;
    width: 34px;
    height: 34px;
    transform: translateX(-50%);
}

.scenario-level-card__body {
    position: relative;
    min-height: 138px;
    display: grid;
    align-content: space-between;
    gap: 8px;
    padding: 14px;
    overflow: hidden;
    isolation: isolate;
    border: 1px solid rgba(246, 240, 234, 0.09);
    border-radius: 18px;
    background:
        linear-gradient(180deg, rgba(18, 16, 16, 0.9), rgba(7, 7, 7, 0.96)),
        radial-gradient(circle at 82% 12%, rgba(143, 32, 41, 0.12), transparent 34%);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.045);
}

.scenario-level-card__veil {
    position: absolute;
    right: -12px;
    bottom: -20px;
    z-index: -1;
    color: rgba(246, 240, 234, 0.045);
    font-family: "Cormorant Garamond", serif;
    font-size: 92px;
    font-weight: 600;
    line-height: 0.8;
    pointer-events: none;
}

.scenario-level-card__roman {
    display: grid;
    place-items: center;
    width: 36px;
    height: 36px;
    border: 1px solid rgba(246, 240, 234, 0.14);
    border-radius: 50%;
    color: rgba(246, 240, 234, 0.82);
    font-family: "Cormorant Garamond", serif;
    font-size: 21px;
    line-height: 1;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.scenario-level-card strong {
    display: block;
    max-width: 8ch;
    color: var(--text);
    font-family: "Cormorant Garamond", serif;
    font-size: 23px;
    font-weight: 600;
    line-height: 0.96;
    text-wrap: balance;
}

.scenario-level-card p {
    margin: 0;
    color: rgba(246, 240, 234, 0.56);
    font-size: 11px;
    line-height: 1.35;
}

.scenario-level-card small {
    width: max-content;
    max-width: 100%;
    padding: 5px 7px;
    border: 1px solid rgba(246, 240, 234, 0.065);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.025);
    color: rgba(246, 240, 234, 0.5);
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.08em;
    line-height: 1;
    text-transform: uppercase;
}

.scenario-level-card--opened .scenario-level-card__body {
    border-color: rgba(246, 240, 234, 0.13);
    box-shadow: 0 0 28px rgba(143, 32, 41, 0.14), inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

.scenario-level-card--opened .scenario-level-card__body::after {
    content: "";
    position: absolute;
    right: 12px;
    top: 12px;
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: rgba(246, 240, 234, 0.72);
    box-shadow: 0 0 16px rgba(143, 32, 41, 0.38);
}

.scenario-level-card--opened .scenario-level-card__node {
    border-color: rgba(246, 240, 234, 0.2);
    background: radial-gradient(circle, rgba(246, 240, 234, 0.74), rgba(143, 32, 41, 0.44) 42%, rgba(7, 7, 7, 0.98) 72%);
    box-shadow: 0 0 26px rgba(143, 32, 41, 0.28), inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

.scenario-level-card--current .scenario-level-card__body {
    min-height: 168px;
    padding: 18px;
    border-color: rgba(255, 110, 118, 0.56);
    background:
        linear-gradient(180deg, rgba(28, 18, 18, 0.98), rgba(8, 8, 8, 0.98)),
        radial-gradient(circle at 78% 14%, rgba(210, 62, 72, 0.26), transparent 36%);
    box-shadow: 0 0 42px rgba(143, 32, 41, 0.34), inset 0 1px 0 rgba(255, 255, 255, 0.08);
    animation: scenario-current-border 4.2s ease-in-out infinite;
}

.scenario-level-card--current .scenario-level-card__node,
.scenario-level-card--current .scenario-level-card__roman {
    border-color: rgba(255, 195, 198, 0.66);
    background: radial-gradient(circle, rgba(255, 155, 160, 0.96), rgba(190, 58, 66, 0.62) 42%, rgba(7, 7, 7, 0.98) 74%);
    box-shadow: 0 0 36px rgba(190, 58, 66, 0.68), inset 0 1px 0 rgba(255, 255, 255, 0.16);
    animation: scenario-current-pulse 3.2s ease-in-out infinite;
}

.scenario-level-card--current .scenario-level-card__roman {
    width: 44px;
    height: 44px;
    font-size: 25px;
}

.scenario-level-card--current strong {
    max-width: none;
    font-size: 32px;
}

.scenario-level-card--current p {
    color: rgba(246, 240, 234, 0.72);
    font-size: 13px;
}

.scenario-level-card--current small {
    color: rgba(255, 235, 235, 0.88);
    border-color: rgba(255, 120, 128, 0.2);
    background: rgba(143, 32, 41, 0.16);
}

.scenario-level-card--locked .scenario-level-card__body {
    opacity: 0.68;
    filter: saturate(0.72);
    border-color: rgba(246, 240, 234, 0.055);
}

.scenario-level-card--locked .scenario-level-card__body::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 0 58%, rgba(5, 5, 5, 0.62) 100%);
    pointer-events: none;
}

.scenario-level-card--locked .scenario-level-card__node {
    border-color: rgba(246, 240, 234, 0.08);
    background: radial-gradient(circle, rgba(246, 240, 234, 0.12), rgba(7, 7, 7, 0.98) 68%);
    box-shadow: none;
}

.scenario-level-card--locked .scenario-level-card__roman,
.scenario-level-card--locked strong,
.scenario-level-card--locked p {
    color: rgba(246, 240, 234, 0.38);
    filter: blur(0.16px);
}

.scenario-level-card:active {
    transform: scale(0.985);
}

@media (hover: hover) and (pointer: fine) {
    .scenario-level-card:hover {
        transform: translateY(-2px);
    }
}

@media (max-width: 390px) {
    .scenario-progression {
        padding: 14px;
    }

    .scenario-current {
        min-height: 252px;
        padding: 22px 18px 18px;
    }

    .scenario-current h2 {
        font-size: 42px;
    }

    .scenario-next h3 {
        font-size: 30px;
    }

    .scenario-line {
        grid-template-columns: minmax(0, 1fr) 28px minmax(0, 1fr);
        gap: 14px 0;
    }

    .scenario-level-card:nth-child(odd) {
        padding-right: 8px;
    }

    .scenario-level-card:nth-child(even) {
        padding-left: 8px;
    }

    .scenario-level-card__body {
        min-height: 132px;
        padding: 12px;
    }

    .scenario-level-card strong {
        font-size: 21px;
    }
}

/* Timeline alignment polish */
.scenario-line {
    grid-template-columns: minmax(0, 1fr) 42px minmax(0, 1fr);
    gap: 22px 0;
    max-height: none;
    overflow: visible;
    padding: 14px 0 28px;
}

.scenario-line::before {
    top: 22px;
    bottom: 26px;
    width: 2px;
    border-radius: 999px;
    background:
        linear-gradient(180deg,
            rgba(246, 240, 234, 0.05),
            rgba(185, 48, 58, 0.62) 24%,
            rgba(185, 48, 58, 0.46) 48%,
            rgba(201, 161, 108, 0.14) 72%,
            rgba(246, 240, 234, 0.035));
    box-shadow:
        0 0 18px rgba(143, 32, 41, 0.32),
        0 0 48px rgba(143, 32, 41, 0.12);
}

.scenario-line::after {
    display: none;
}

.scenario-level-card {
    align-self: center;
}

.scenario-level-card:nth-child(odd) {
    grid-column: 1 / 2;
    padding: 0 18px 0 0;
}

.scenario-level-card:nth-child(even) {
    grid-column: 3 / 4;
    padding: 0 0 0 18px;
}

.scenario-level-card.is-current {
    grid-column: 1 / 2;
    width: auto;
    margin: 0;
    padding: 0 18px 0 0;
}

.scenario-level-card::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    width: 18px;
    height: 1px;
    transform: translateY(-50%);
    background: linear-gradient(90deg, rgba(185, 48, 58, 0.28), rgba(246, 240, 234, 0.14));
}

.scenario-level-card:nth-child(even)::before {
    left: 0;
    right: auto;
    background: linear-gradient(90deg, rgba(246, 240, 234, 0.14), rgba(185, 48, 58, 0.28));
}

.scenario-level-card__node {
    right: -21px;
    top: 50%;
    width: 26px;
    height: 26px;
    transform: translate(50%, -50%);
}

.scenario-level-card:nth-child(even) .scenario-level-card__node {
    left: -21px;
    right: auto;
    transform: translate(-50%, -50%);
}

.scenario-level-card.is-current .scenario-level-card__node {
    left: auto;
    right: -21px;
    top: 50%;
    width: 34px;
    height: 34px;
    transform: translate(50%, -50%);
}

.scenario-level-card__body {
    min-height: 150px;
    padding: 16px;
    border-radius: 20px;
}

.scenario-level-card--current .scenario-level-card__body {
    min-height: 190px;
    padding: 20px;
    transform: translateZ(0);
}

.scenario-level-card--current .scenario-level-card__body::before {
    content: "";
    position: absolute;
    inset: -1px;
    z-index: -1;
    border-radius: inherit;
    background:
        radial-gradient(circle at 76% 20%, rgba(255, 108, 116, 0.16), transparent 32%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.055), transparent 42%);
    pointer-events: none;
}

.scenario-level-card--locked .scenario-level-card__body {
    opacity: 0.5;
}

.scenario-level-card--locked:nth-child(n + 6) .scenario-level-card__body {
    opacity: 0.36;
}

.scenario-level-card--locked .scenario-level-card__node {
    opacity: 0.64;
}

.scenario-level-card--locked:nth-child(n + 6) .scenario-level-card__node {
    opacity: 0.38;
}

.scenario-level-card p {
    max-width: 30ch;
}

@media (max-width: 620px) {
    .scenario-line {
        grid-template-columns: 28px minmax(0, 1fr);
        gap: 14px;
        padding: 12px 0 22px;
    }

    .scenario-line::before {
        left: 13px;
        transform: none;
    }

    .scenario-level-card,
    .scenario-level-card:nth-child(odd),
    .scenario-level-card:nth-child(even),
    .scenario-level-card.is-current {
        grid-column: 2 / 3;
        padding: 0 0 0 14px;
    }

    .scenario-level-card::before,
    .scenario-level-card:nth-child(even)::before {
        left: 0;
        right: auto;
        width: 14px;
        background: linear-gradient(90deg, rgba(246, 240, 234, 0.14), rgba(185, 48, 58, 0.28));
    }

    .scenario-level-card__node,
    .scenario-level-card:nth-child(even) .scenario-level-card__node,
    .scenario-level-card.is-current .scenario-level-card__node {
        left: -14px;
        right: auto;
        top: 50%;
        transform: translate(-50%, -50%);
    }

    .scenario-level-card__body {
        min-height: 132px;
    }

    .scenario-level-card--current .scenario-level-card__body {
        min-height: 166px;
    }
}

/* Timeline readability and spine alignment polish */
.scenario-line {
    grid-template-columns: minmax(0, 1fr) 48px minmax(0, 1fr);
    gap: 20px 0;
}

.scenario-line::before {
    width: 2px;
    background:
        linear-gradient(180deg,
            rgba(246, 240, 234, 0.06),
            rgba(185, 48, 58, 0.72) 28%,
            rgba(185, 48, 58, 0.5) 54%,
            rgba(201, 161, 108, 0.18) 76%,
            rgba(246, 240, 234, 0.04));
}

.scenario-level-card:nth-child(odd),
.scenario-level-card.is-current {
    padding-right: 20px;
}

.scenario-level-card:nth-child(even) {
    padding-left: 20px;
}

.scenario-level-card::before {
    right: -24px;
    width: 24px;
    opacity: 0.85;
}

.scenario-level-card:nth-child(even)::before {
    left: -24px;
    width: 24px;
}

.scenario-level-card__node,
.scenario-level-card.is-current .scenario-level-card__node {
    right: -37px;
}

.scenario-level-card:nth-child(even) .scenario-level-card__node {
    left: -24px;
}

.scenario-level-card__body {
    border-color: rgba(246, 240, 234, 0.11);
}

.scenario-level-card--locked .scenario-level-card__body {
    opacity: 0.74;
    filter: saturate(0.9);
    border-color: rgba(246, 240, 234, 0.085);
    background:
        linear-gradient(180deg, rgba(17, 15, 15, 0.82), rgba(7, 7, 7, 0.96)),
        radial-gradient(circle at 82% 12%, rgba(143, 32, 41, 0.08), transparent 34%);
}

.scenario-level-card--locked:nth-child(n + 6) .scenario-level-card__body {
    opacity: 0.58;
}

.scenario-level-card--locked .scenario-level-card__body::after {
    background: linear-gradient(180deg, transparent 0 68%, rgba(5, 5, 5, 0.34) 100%);
}

.scenario-level-card--locked .scenario-level-card__roman,
.scenario-level-card--locked strong {
    color: rgba(246, 240, 234, 0.56);
    filter: none;
}

.scenario-level-card--locked p {
    color: rgba(246, 240, 234, 0.42);
    filter: none;
}

.scenario-level-card--locked small {
    color: rgba(246, 240, 234, 0.44);
}

.scenario-level-card--locked .scenario-level-card__node {
    opacity: 0.78;
    border-color: rgba(246, 240, 234, 0.12);
    background: radial-gradient(circle, rgba(246, 240, 234, 0.18), rgba(7, 7, 7, 0.98) 68%);
}

.scenario-level-card--locked:nth-child(n + 6) .scenario-level-card__node {
    opacity: 0.55;
}

@media (max-width: 620px) {
    .scenario-line {
        grid-template-columns: 30px minmax(0, 1fr);
        gap: 15px;
    }

    .scenario-level-card,
    .scenario-level-card:nth-child(odd),
    .scenario-level-card:nth-child(even),
    .scenario-level-card.is-current {
        padding: 0 0 0 16px;
    }

    .scenario-level-card::before,
    .scenario-level-card:nth-child(even)::before {
        left: 0;
        right: auto;
        width: 16px;
    }

    .scenario-level-card__node,
    .scenario-level-card:nth-child(even) .scenario-level-card__node,
    .scenario-level-card.is-current .scenario-level-card__node {
        left: -15px;
        right: auto;
        transform: translate(-50%, -50%);
    }
}

/* Timeline row fix: one scenario level per vertical step */
.scenario-line {
    grid-template-columns: minmax(0, 1fr) 54px minmax(0, 1fr);
    grid-auto-flow: row;
    grid-auto-rows: auto;
    gap: 18px 0;
    padding-bottom: 90px;
}

.scenario-level-card:nth-child(1) { grid-row: 1; }
.scenario-level-card:nth-child(2) { grid-row: 2; }
.scenario-level-card:nth-child(3) { grid-row: 3; }
.scenario-level-card:nth-child(4) { grid-row: 4; }
.scenario-level-card:nth-child(5) { grid-row: 5; }
.scenario-level-card:nth-child(6) { grid-row: 6; }
.scenario-level-card:nth-child(7) { grid-row: 7; }
.scenario-level-card:nth-child(8) { grid-row: 8; }

.scenario-level-card:nth-child(odd),
.scenario-level-card.is-current {
    grid-column: 1 / 2;
    padding-right: 18px;
}

.scenario-level-card:nth-child(even) {
    grid-column: 3 / 4;
    padding-left: 18px;
}

.scenario-level-card::before {
    right: -27px;
    width: 27px;
    background: linear-gradient(90deg, rgba(185, 48, 58, 0.12), rgba(185, 48, 58, 0.38), rgba(246, 240, 234, 0.14));
}

.scenario-level-card:nth-child(even)::before {
    left: -27px;
    right: auto;
    background: linear-gradient(90deg, rgba(246, 240, 234, 0.14), rgba(185, 48, 58, 0.38), rgba(185, 48, 58, 0.12));
}

.scenario-level-card__node,
.scenario-level-card.is-current .scenario-level-card__node {
    right: -27px;
    top: 50%;
    transform: translate(50%, -50%);
}

.scenario-level-card:nth-child(even) .scenario-level-card__node {
    left: -27px;
    right: auto;
    transform: translate(-50%, -50%);
}

.scenario-level-card__body {
    min-height: 132px;
}

.scenario-level-card--current .scenario-level-card__body {
    min-height: 172px;
}

.scenario-level-card--locked .scenario-level-card__body,
.scenario-level-card--locked:nth-child(n + 6) .scenario-level-card__body {
    opacity: 0.72;
    filter: saturate(0.92);
}

.scenario-level-card--locked .scenario-level-card__roman,
.scenario-level-card--locked strong,
.scenario-level-card--locked p,
.scenario-level-card--locked:nth-child(n + 6) .scenario-level-card__roman,
.scenario-level-card--locked:nth-child(n + 6) strong,
.scenario-level-card--locked:nth-child(n + 6) p {
    color: rgba(246, 240, 234, 0.54);
}

.scenario-level-card--locked small,
.scenario-level-card--locked:nth-child(n + 6) small {
    color: rgba(246, 240, 234, 0.46);
}

.scenario-level-card--locked .scenario-level-card__node,
.scenario-level-card--locked:nth-child(n + 6) .scenario-level-card__node {
    opacity: 0.72;
}

@media (max-width: 620px) {
    .scenario-line {
        grid-template-columns: 30px minmax(0, 1fr);
        gap: 15px;
        padding-bottom: 76px;
    }

    .scenario-level-card:nth-child(odd),
    .scenario-level-card:nth-child(even),
    .scenario-level-card.is-current {
        grid-column: 2 / 3;
        padding: 0 0 0 16px;
    }

    .scenario-level-card::before,
    .scenario-level-card:nth-child(even)::before {
        left: 0;
        right: auto;
        width: 16px;
    }

    .scenario-level-card__node,
    .scenario-level-card:nth-child(even) .scenario-level-card__node,
    .scenario-level-card.is-current .scenario-level-card__node {
        left: -15px;
        right: auto;
        transform: translate(-50%, -50%);
    }
}

.product-home > .home-hero {
    display: none;
}

.mystic-hero {
    padding: 0 var(--gutter);
}

.mystic-hero__frame {
    position: relative;
    min-height: min(760px, calc(100svh - 116px));
    padding: 18px 18px 22px;
    border: 1px solid rgba(246, 240, 234, 0.1);
    border-radius: 30px;
    overflow: hidden;
    background:
        linear-gradient(180deg, rgba(8, 8, 8, 0.94), rgba(6, 6, 6, 0.98)),
        radial-gradient(circle at 68% 24%, rgba(212, 152, 61, 0.16), transparent 26%),
        radial-gradient(circle at 72% 68%, rgba(143, 32, 41, 0.18), transparent 34%);
    box-shadow: 0 24px 72px rgba(0, 0, 0, 0.48), inset 0 1px 0 rgba(255, 255, 255, 0.04);
    isolation: isolate;
}

.mystic-hero__frame::before,
.mystic-hero__frame::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.mystic-hero__frame::before {
    border-radius: inherit;
    border: 1px solid rgba(255, 255, 255, 0.04);
}

.mystic-hero__frame::after {
    background:
        linear-gradient(90deg, rgba(255, 255, 255, 0.03), transparent 14%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.02), transparent 16%);
    mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.76), transparent 100%);
}

.mystic-hero__topline {
    position: relative;
    z-index: 3;
    display: flex;
    justify-content: space-between;
    gap: 12px;
    color: rgba(246, 240, 234, 0.64);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.mystic-hero__visual {
    position: absolute;
    inset: 74px 0 124px 38%;
    z-index: 1;
    pointer-events: none;
}

.mystic-hero__portrait {
    position: absolute;
    right: -84px;
    bottom: -40px;
    width: min(104%, 520px);
    max-width: none;
    height: auto;
    opacity: 0.88;
    filter: contrast(1.06) brightness(0.84);
    mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.95), rgba(0, 0, 0, 0.9) 72%, transparent 100%);
}

.mystic-hero__halo,
.mystic-hero__particle {
    position: absolute;
    border-radius: 999px;
}

.mystic-hero__halo {
    filter: blur(18px);
    opacity: 0.78;
    animation: mysticBreath 7.4s ease-in-out infinite;
}

.mystic-hero__halo--gold {
    top: 42px;
    right: 56px;
    width: 150px;
    height: 150px;
    background: radial-gradient(circle, rgba(255, 235, 186, 0.86) 0%, rgba(255, 187, 77, 0.42) 36%, rgba(255, 187, 77, 0) 72%);
}

.mystic-hero__halo--ember {
    right: 10px;
    bottom: 118px;
    width: 176px;
    height: 176px;
    background: radial-gradient(circle, rgba(194, 31, 48, 0.34) 0%, rgba(194, 31, 48, 0) 72%);
    animation-delay: -3.2s;
}

.mystic-hero__particle {
    background: rgba(255, 214, 153, 0.66);
    box-shadow: 0 0 18px rgba(255, 200, 116, 0.5);
    animation: mysticFloat 9s linear infinite;
}

.mystic-hero__particle--1 {
    top: 126px;
    right: 138px;
    width: 6px;
    height: 6px;
}

.mystic-hero__particle--2 {
    top: 214px;
    right: 92px;
    width: 4px;
    height: 4px;
    animation-delay: -2.6s;
}

.mystic-hero__particle--3 {
    right: 156px;
    bottom: 220px;
    width: 5px;
    height: 5px;
    animation-delay: -5.4s;
}

.mystic-hero__level {
    position: absolute;
    top: 130px;
    right: 18px;
    z-index: 3;
    display: grid;
    justify-items: center;
    gap: 4px;
    width: 82px;
    padding: 14px 10px;
    border: 1px solid rgba(246, 240, 234, 0.12);
    border-radius: 20px;
    background: rgba(18, 16, 16, 0.54);
    backdrop-filter: blur(16px);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

.mystic-hero__level strong {
    color: var(--text);
    font-family: "Cormorant Garamond", serif;
    font-size: 28px;
    line-height: 1;
}

.mystic-hero__level span {
    color: rgba(246, 240, 234, 0.7);
    font-size: 11px;
    line-height: 1.2;
    text-align: center;
}

.mystic-hero__rail {
    position: absolute;
    top: 232px;
    right: 56px;
    bottom: 180px;
    z-index: 3;
    display: grid;
    justify-items: center;
    align-content: space-between;
    width: 24px;
}

.mystic-hero__rail::before {
    content: "";
    position: absolute;
    top: 12px;
    bottom: 12px;
    left: 50%;
    width: 1px;
    transform: translateX(-50%);
    background: linear-gradient(180deg, rgba(255, 109, 109, 0.72), rgba(255, 255, 255, 0.06));
}

.mystic-rail__node {
    position: relative;
    z-index: 1;
    width: 16px;
    height: 16px;
    border-radius: 999px;
    border: 1px solid rgba(246, 240, 234, 0.16);
    background: rgba(20, 18, 18, 0.96);
    box-shadow: 0 0 0 5px rgba(8, 8, 8, 0.48);
}

.mystic-rail__node.is-opened {
    background: rgba(124, 34, 41, 0.88);
}

.mystic-rail__node.is-current {
    background: #ff665d;
    border-color: rgba(255, 226, 226, 0.74);
    box-shadow:
        0 0 0 5px rgba(8, 8, 8, 0.48),
        0 0 0 1px rgba(255, 226, 226, 0.44),
        0 0 24px rgba(255, 84, 74, 0.64);
}

.mystic-hero__content {
    position: relative;
    z-index: 3;
    display: grid;
    gap: 14px;
    width: min(74%, 280px);
    padding-top: 56px;
}

.mystic-hero__eyebrow {
    color: #ff665d;
}

.mystic-hero__content h1 {
    margin: 0;
    color: var(--text);
    font-family: "Cormorant Garamond", serif;
    font-size: clamp(50px, 14vw, 66px);
    font-weight: 600;
    line-height: 0.92;
    letter-spacing: -0.035em;
    text-wrap: balance;
}

.mystic-hero__description {
    margin: 0;
    color: rgba(246, 240, 234, 0.72);
    font-size: 15px;
    line-height: 1.55;
    max-width: 27ch;
}

.mystic-hero__status {
    display: grid;
    grid-template-columns: 44px 1fr;
    gap: 12px;
    align-items: center;
    width: min(100%, 308px);
    margin-top: 8px;
    padding: 14px 14px 14px 12px;
    border: 1px solid rgba(246, 240, 234, 0.12);
    border-radius: 20px;
    background:
        linear-gradient(180deg, rgba(17, 16, 16, 0.92), rgba(10, 10, 10, 0.98)),
        radial-gradient(circle at 18% 50%, rgba(143, 32, 41, 0.24), transparent 40%);
    backdrop-filter: blur(14px);
}

.mystic-hero__status-mark {
    position: relative;
    width: 44px;
    height: 44px;
    border-radius: 999px;
    border: 1px solid rgba(255, 117, 102, 0.34);
    background: radial-gradient(circle, rgba(255, 91, 83, 0.82) 0 18%, rgba(255, 91, 83, 0.08) 34%, transparent 66%);
    box-shadow: 0 0 32px rgba(194, 31, 48, 0.24);
}

.mystic-hero__status-mark::before,
.mystic-hero__status-mark::after {
    content: "";
    position: absolute;
    inset: 10px;
    border-radius: inherit;
    border: 1px solid rgba(255, 117, 102, 0.42);
}

.mystic-hero__status-mark::after {
    inset: 17px;
    background: rgba(255, 219, 213, 0.92);
}

.mystic-hero__status-copy {
    display: grid;
    gap: 4px;
}

.mystic-hero__status-copy strong {
    color: var(--text);
    font-size: 14px;
    line-height: 1.2;
}

.mystic-hero__status-copy span {
    color: rgba(246, 240, 234, 0.62);
    font-size: 12px;
    line-height: 1.4;
}

.dynamic-cta {
    --cta-shift-x: 0px;
    --cta-shift-y: 0px;
    --cta-pointer-x: 50%;
    --cta-pointer-y: 50%;
    position: relative;
    display: grid;
    grid-template-columns: 64px 1fr auto;
    gap: 14px;
    align-items: center;
    width: 100%;
    min-height: 96px;
    padding: 16px 18px 16px 14px;
    border: 1px solid rgba(255, 121, 107, 0.34);
    border-radius: 24px;
    color: var(--text);
    overflow: hidden;
    background:
        linear-gradient(180deg, rgba(126, 26, 34, 0.92), rgba(70, 15, 20, 0.96)),
        radial-gradient(circle at 78% 50%, rgba(255, 201, 150, 0.12), transparent 32%);
    box-shadow:
        0 24px 52px rgba(97, 21, 27, 0.34),
        inset 0 1px 0 rgba(255, 255, 255, 0.1),
        inset 0 -20px 34px rgba(8, 8, 8, 0.16);
    transform: translate3d(var(--cta-shift-x), calc(var(--cta-shift-y) * 0.42), 0);
    transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease, filter 180ms ease;
}

.dynamic-cta::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at var(--cta-pointer-x) var(--cta-pointer-y), rgba(255, 255, 255, 0.18), transparent 30%);
    opacity: 0.7;
    pointer-events: none;
}

.dynamic-cta.is-pressed {
    transform: scale(0.988);
}

.dynamic-cta[data-cta-glow="gold"] {
    border-color: rgba(220, 168, 91, 0.38);
    background:
        linear-gradient(180deg, rgba(104, 39, 23, 0.92), rgba(63, 22, 14, 0.96)),
        radial-gradient(circle at 78% 50%, rgba(255, 212, 150, 0.14), transparent 34%);
    box-shadow:
        0 24px 52px rgba(97, 57, 21, 0.28),
        inset 0 1px 0 rgba(255, 255, 255, 0.1),
        inset 0 -20px 34px rgba(8, 8, 8, 0.16);
}

.dynamic-cta[data-cta-glow="violet"] {
    border-color: rgba(155, 111, 196, 0.28);
    background:
        linear-gradient(180deg, rgba(64, 32, 77, 0.92), rgba(38, 18, 46, 0.96)),
        radial-gradient(circle at 78% 50%, rgba(197, 172, 235, 0.14), transparent 32%);
    box-shadow:
        0 24px 52px rgba(58, 28, 73, 0.34),
        inset 0 1px 0 rgba(255, 255, 255, 0.08),
        inset 0 -20px 34px rgba(8, 8, 8, 0.16);
}

.dynamic-cta__ambient {
    position: absolute;
    inset: -10% auto auto -4%;
    width: 52%;
    height: 140%;
    background: radial-gradient(circle, rgba(255, 127, 114, 0.2), transparent 66%);
    filter: blur(24px);
    animation: ctaBreath 5.8s ease-in-out infinite;
    pointer-events: none;
}

.dynamic-cta__icon {
    position: relative;
    z-index: 1;
    width: 52px;
    height: 52px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    color: rgba(255, 240, 221, 0.98);
    background: rgba(27, 18, 18, 0.42);
    border: 1px solid rgba(255, 215, 198, 0.16);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.dynamic-cta__icon svg {
    width: 24px;
    height: 24px;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.8px;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.dynamic-cta__copy {
    position: relative;
    z-index: 1;
    display: grid;
    gap: 4px;
    text-align: left;
}

.dynamic-cta__copy strong {
    color: var(--text);
    font-size: 18px;
    font-weight: 600;
    line-height: 1.16;
}

.dynamic-cta__copy small,
.dynamic-cta__hint {
    color: rgba(246, 240, 234, 0.72);
    font-size: 12px;
    line-height: 1.35;
}

.dynamic-cta__hint {
    position: relative;
    z-index: 1;
    max-width: 92px;
    text-align: left;
}

.dynamic-cta__arrow {
    position: relative;
    z-index: 1;
    width: 26px;
    height: 26px;
    color: rgba(255, 244, 236, 0.92);
}

.mystic-hero__signals {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.mystic-signal {
    display: inline-grid;
    gap: 2px;
    min-width: 0;
    padding: 10px 12px;
    border-radius: 18px;
    border: 1px solid rgba(246, 240, 234, 0.1);
    background: rgba(15, 13, 13, 0.78);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.mystic-signal strong {
    color: var(--text);
    font-size: 12px;
    font-weight: 600;
    line-height: 1.15;
}

.mystic-signal span {
    color: rgba(246, 240, 234, 0.62);
    font-size: 11px;
    line-height: 1.2;
}

.mystic-hero__footer {
    position: absolute;
    left: 18px;
    right: 18px;
    bottom: 18px;
    z-index: 3;
    display: grid;
    gap: 10px;
    padding: 14px 16px;
    border: 1px solid rgba(246, 240, 234, 0.1);
    border-radius: 22px;
    background: rgba(14, 13, 13, 0.84);
    backdrop-filter: blur(16px);
}

.mystic-metric {
    display: grid;
    gap: 2px;
}

.mystic-metric span {
    color: rgba(246, 240, 234, 0.5);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.mystic-metric strong {
    color: var(--text);
    font-size: 15px;
    font-weight: 500;
    line-height: 1.3;
}

.depth-entry-modal {
    position: fixed;
    inset: 0;
    z-index: 130;
    display: grid;
    place-items: end center;
    padding: 18px 14px calc(18px + var(--safe-bottom));
    opacity: 0;
    visibility: hidden;
    transition: opacity 220ms ease, visibility 220ms ease;
}

.depth-entry-modal.is-open {
    opacity: 1;
    visibility: visible;
}

.depth-entry-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(5, 5, 5, 0.74);
    backdrop-filter: blur(12px);
}

.depth-entry-modal__dialog {
    position: relative;
    z-index: 1;
    display: grid;
    gap: 14px;
    width: min(100%, 420px);
    padding: 24px 18px 18px;
    border: 1px solid rgba(246, 240, 234, 0.1);
    border-radius: 28px;
    background:
        linear-gradient(180deg, rgba(18, 16, 16, 0.98), rgba(8, 8, 8, 0.98)),
        radial-gradient(circle at 82% 14%, rgba(143, 32, 41, 0.16), transparent 32%);
    box-shadow: 0 24px 72px rgba(0, 0, 0, 0.42);
}

.depth-entry-modal__dialog h2,
.depth-entry-modal__dialog p {
    margin: 0;
}

.depth-entry-modal__dialog h2 {
    color: var(--text);
    font-family: "Cormorant Garamond", serif;
    font-size: 36px;
    line-height: 0.98;
}

.depth-entry-modal__dialog p {
    color: rgba(246, 240, 234, 0.72);
    font-size: 14px;
    line-height: 1.55;
}

.depth-entry-modal__chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.depth-entry-modal__chips span {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 0 12px;
    border-radius: 999px;
    border: 1px solid rgba(246, 240, 234, 0.1);
    background: rgba(255, 255, 255, 0.03);
    color: rgba(246, 240, 234, 0.74);
    font-size: 12px;
}

@keyframes mysticBreath {
    0%, 100% { transform: scale(0.94); opacity: 0.64; }
    50% { transform: scale(1.08); opacity: 0.88; }
}

@keyframes mysticFloat {
    0% { transform: translateY(0px) scale(0.98); opacity: 0; }
    10%, 85% { opacity: 0.9; }
    100% { transform: translateY(-34px) scale(1.08); opacity: 0; }
}

@keyframes ctaBreath {
    0%, 100% { transform: scale(0.96); opacity: 0.42; }
    50% { transform: scale(1.04); opacity: 0.72; }
}

@media (min-width: 640px) {
    .home-ref-main {
        max-width: 920px;
        padding-left: 0;
        padding-right: 0;
    }

    .mystic-hero__frame {
        min-height: 820px;
        padding: 28px 28px 28px;
    }

    .mystic-hero__visual {
        inset: 68px 0 148px 43%;
    }

    .mystic-hero__portrait {
        right: -24px;
        width: min(90%, 540px);
    }

    .mystic-hero__content {
        width: min(52%, 420px);
        padding-top: 76px;
    }

    .dynamic-cta {
        grid-template-columns: 72px 1fr 132px 28px;
        min-height: 102px;
        padding: 16px 22px 16px 16px;
    }

    .dynamic-cta__hint {
        max-width: none;
    }

    .mystic-hero__footer {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        align-items: center;
    }
}

@media (max-width: 430px) {
    .mystic-hero__content {
        width: min(76%, 276px);
    }

    .mystic-hero__visual {
        inset: 88px -14px 152px 34%;
    }

    .mystic-hero__level {
        width: 74px;
        right: 14px;
    }

    .mystic-hero__rail {
        right: 44px;
    }

    .dynamic-cta {
        grid-template-columns: 56px 1fr 24px;
        padding-right: 14px;
    }

    .dynamic-cta__hint {
        display: none;
    }
}

@media (prefers-reduced-motion: reduce) {
    .mystic-hero__halo,
    .mystic-hero__particle,
    .dynamic-cta__ambient {
        animation: none;
    }

    .dynamic-cta,
    .dynamic-cta::before {
        transition: none;
    }
}

/* Reference-aligned hero override */
.mystic-hero {
    margin: 0 var(--gutter);
    padding: 0;
}

.mystic-hero__frame {
    min-height: 1080px;
    padding: 28px 28px 26px;
    border-radius: 32px;
    background:
        radial-gradient(circle at 68% 22%, rgba(255, 179, 66, 0.18), transparent 18%),
        radial-gradient(circle at 70% 66%, rgba(133, 48, 22, 0.26), transparent 30%),
        linear-gradient(180deg, rgba(6, 6, 6, 0.98), rgba(8, 8, 8, 0.99));
}

.mystic-hero__topline {
    align-items: center;
}

.mystic-hero__topline span:first-child {
    position: relative;
    padding-right: 112px;
}

.mystic-hero__topline span:first-child::after {
    content: "";
    position: absolute;
    top: 50%;
    left: calc(100% - 92px);
    width: 72px;
    height: 1px;
    background: linear-gradient(90deg, rgba(246, 240, 234, 0.22), transparent);
}

.mystic-hero__visual {
    inset: 74px 84px 160px 52%;
    overflow: visible;
}

.mystic-hero__video,
.mystic-hero__video-shade {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border-radius: 0 0 30px 30px;
}

.mystic-hero__video {
    object-fit: cover;
    object-position: center center;
    filter: saturate(0.92) brightness(0.82) contrast(1.02);
    mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.96), rgba(0, 0, 0, 0.95) 72%, transparent 100%);
}

.mystic-hero__video-shade {
    background:
        radial-gradient(circle at 36% 18%, rgba(255, 195, 104, 0.16), transparent 20%),
        linear-gradient(90deg, rgba(8, 8, 8, 0.16), rgba(8, 8, 8, 0.04)),
        linear-gradient(180deg, rgba(8, 8, 8, 0.1), rgba(8, 8, 8, 0.42) 78%, rgba(8, 8, 8, 0.84));
}

.mystic-hero__star {
    position: absolute;
    top: 34px;
    left: 48%;
    width: 84px;
    height: 84px;
    transform: translateX(-50%);
    background:
        radial-gradient(circle, rgba(255, 250, 233, 0.98) 0 8%, rgba(255, 208, 104, 0.76) 18%, rgba(255, 208, 104, 0) 70%);
    filter: blur(0.4px);
    border-radius: 999px;
    box-shadow: 0 0 40px rgba(255, 187, 77, 0.54);
}

.mystic-hero__star::before,
.mystic-hero__star::after {
    content: "";
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    background: rgba(255, 231, 178, 0.98);
}

.mystic-hero__star::before {
    width: 2px;
    height: 74px;
}

.mystic-hero__star::after {
    width: 74px;
    height: 2px;
}

.mystic-hero__path-glow {
    position: absolute;
    left: 50%;
    bottom: 44px;
    width: 220px;
    height: 340px;
    transform: translateX(-50%);
    background: linear-gradient(180deg, rgba(255, 208, 104, 0.34), rgba(255, 208, 104, 0.02) 90%);
    clip-path: polygon(50% 0%, 68% 18%, 82% 100%, 18% 100%, 32% 18%);
    filter: blur(2px);
    opacity: 0.76;
}

.mystic-hero__level {
    top: 128px;
    right: 26px;
    width: 126px;
    min-height: 118px;
    align-content: center;
    padding: 18px 14px;
    border-radius: 22px;
    background: rgba(22, 20, 20, 0.82);
}

.mystic-hero__level strong {
    font-size: 52px;
}

.mystic-hero__level span {
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.mystic-hero__rail {
    top: 250px;
    right: 56px;
    bottom: 164px;
    width: 34px;
}

.mystic-hero__rail::before {
    width: 2px;
    background: linear-gradient(180deg, rgba(255, 92, 92, 0.94), rgba(246, 240, 234, 0.18) 26%, rgba(246, 240, 234, 0.08));
}

.mystic-rail__node {
    width: 18px;
    height: 18px;
    border-color: rgba(246, 240, 234, 0.26);
    background: rgba(28, 24, 24, 0.94);
}

.mystic-rail__node.is-current {
    width: 22px;
    height: 22px;
    background: #ff5c5c;
    box-shadow:
        0 0 0 5px rgba(8, 8, 8, 0.52),
        0 0 0 1px rgba(255, 240, 234, 0.68),
        0 0 28px rgba(255, 84, 74, 0.74);
}

.mystic-hero__content {
    width: min(47%, 520px);
    gap: 20px;
    padding-top: 86px;
}

.mystic-hero__eyebrow {
    font-size: 16px;
    letter-spacing: 0.08em;
}

.mystic-hero__content h1 {
    font-size: clamp(72px, 7.4vw, 96px);
    line-height: 0.92;
    max-width: 7.2ch;
}

.mystic-hero__description {
    max-width: 20ch;
    font-size: 18px;
    line-height: 1.5;
    color: rgba(246, 240, 234, 0.76);
}

.mystic-hero__status {
    width: min(100%, 448px);
    grid-template-columns: 64px 1fr;
    gap: 16px;
    padding: 18px 18px 18px 16px;
    border-radius: 22px;
    background:
        linear-gradient(180deg, rgba(19, 18, 18, 0.94), rgba(13, 12, 12, 0.98)),
        radial-gradient(circle at 12% 50%, rgba(143, 32, 41, 0.2), transparent 42%);
}

.mystic-hero__status-mark {
    width: 52px;
    height: 52px;
}

.mystic-hero__status-copy strong {
    font-size: 18px;
}

.mystic-hero__status-copy span {
    font-size: 14px;
}

.dynamic-cta {
    width: min(100%, 560px);
    grid-template-columns: 72px 1fr 40px;
    gap: 18px;
    min-height: 108px;
    padding: 18px 26px 18px 18px;
    border-radius: 26px;
}

.dynamic-cta__icon {
    width: 58px;
    height: 58px;
}

.dynamic-cta__copy strong {
    font-size: 24px;
}

.dynamic-cta__copy small {
    font-size: 0;
    line-height: 0;
}

.dynamic-cta__hint {
    display: none;
}

.dynamic-cta__arrow {
    width: 30px;
    height: 30px;
}

.mystic-hero__signals-shell {
    display: grid;
    gap: 14px;
    margin-top: 6px;
}

.mystic-hero__signals-label {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: rgba(246, 240, 234, 0.68);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.38em;
    text-transform: uppercase;
}

.mystic-hero__signals-label::after {
    content: "";
    width: 120px;
    height: 1px;
    background: linear-gradient(90deg, rgba(246, 240, 234, 0.16), transparent);
}

.mystic-hero__signals {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
    max-width: 820px;
}

.mystic-signal {
    min-height: 82px;
    padding: 14px 14px;
    align-content: center;
    border-radius: 20px;
    background: rgba(15, 13, 13, 0.86);
}

.mystic-signal strong {
    font-size: 14px;
}

.mystic-signal span {
    font-size: 12px;
}

.mystic-hero__footer {
    left: 28px;
    right: 28px;
    bottom: 26px;
    grid-template-columns: 1.2fr 1fr 1fr;
    gap: 18px;
    padding: 22px 26px;
    border-radius: 24px;
    background: rgba(13, 13, 13, 0.9);
}

.mystic-metric strong {
    font-size: 18px;
}

@media (max-width: 920px) {
    .mystic-hero__frame {
        min-height: 980px;
    }

    .mystic-hero__visual {
        inset: 96px 26px 190px 44%;
    }

    .mystic-hero__content {
        width: min(52%, 430px);
    }

    .mystic-hero__signals {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        max-width: 520px;
    }
}

@media (max-width: 640px) {
    .mystic-hero__frame {
        min-height: 860px;
        padding: 20px 18px 18px;
    }

    .mystic-hero__visual {
        inset: 210px -22px 210px 34%;
    }

    .mystic-hero__level {
        top: 112px;
        right: 18px;
        width: 90px;
        min-height: 90px;
        padding: 12px 8px;
    }

    .mystic-hero__level strong {
        font-size: 38px;
    }

    .mystic-hero__rail {
        top: 214px;
        right: 38px;
        bottom: 176px;
    }

    .mystic-hero__content {
        width: min(72%, 280px);
        padding-top: 78px;
        gap: 16px;
    }

    .mystic-hero__content h1 {
        font-size: clamp(54px, 15vw, 72px);
        max-width: 6.8ch;
    }

    .mystic-hero__description {
        font-size: 15px;
        max-width: 18ch;
    }

    .mystic-hero__status {
        width: 100%;
        grid-template-columns: 52px 1fr;
        padding: 14px;
    }

    .mystic-hero__status-copy strong {
        font-size: 16px;
    }

    .dynamic-cta {
        width: 100%;
        min-height: 92px;
        grid-template-columns: 58px 1fr 28px;
        padding: 16px 18px 16px 14px;
    }

    .dynamic-cta__copy strong {
        font-size: 18px;
    }

    .mystic-hero__signals {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
    }

    .mystic-signal {
        min-height: 70px;
        padding: 12px;
    }

    .mystic-hero__footer {
        left: 18px;
        right: 18px;
        bottom: 18px;
        grid-template-columns: 1fr;
        gap: 12px;
        padding: 16px;
    }
}

.mystic-hero__visual {
    overflow: hidden;
}

.mystic-hero__art {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 62% 52%;
    filter: saturate(0.92) contrast(1.04) brightness(0.92);
    transform: scale(1.03);
}

.mystic-hero__video-shade {
    background:
        linear-gradient(90deg, rgba(4, 4, 4, 0.98) 0%, rgba(4, 4, 4, 0.92) 32%, rgba(4, 4, 4, 0.38) 54%, rgba(4, 4, 4, 0.18) 100%),
        linear-gradient(180deg, rgba(4, 4, 4, 0.08) 0%, rgba(4, 4, 4, 0) 26%, rgba(4, 4, 4, 0.42) 100%);
}

.mystic-hero__visual::after {
    content: "";
    position: absolute;
    inset: auto 0 0 22%;
    height: 28%;
    background: radial-gradient(circle at center, rgba(255, 191, 94, 0.16), transparent 64%);
    pointer-events: none;
}

.mystic-hero__star,
.mystic-hero__path-glow {
    opacity: 0.22;
    filter: blur(0.5px);
}

.mystic-hero__content h1[data-hero-title]::after {
    content: ".";
    color: #ff5f52;
}

.mystic-hero__level {
    background: linear-gradient(180deg, rgba(20, 18, 18, 0.96), rgba(12, 11, 11, 0.98));
    border-color: rgba(255, 240, 234, 0.12);
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.34);
}

.mystic-hero__rail::before {
    content: "";
    position: absolute;
    left: 50%;
    top: 12px;
    bottom: 12px;
    width: 1px;
    transform: translateX(-50%);
    background: linear-gradient(180deg, rgba(255, 110, 96, 0.72), rgba(255, 240, 234, 0.22) 22%, rgba(255, 240, 234, 0.12) 100%);
}

.mystic-rail__node {
    position: relative;
    z-index: 1;
}

.mystic-rail__node.is-current::after {
    content: "";
    position: absolute;
    inset: 50% auto auto 50%;
    width: 46px;
    height: 2px;
    transform: translate(-50%, -50%);
    background: linear-gradient(90deg, transparent, rgba(255, 88, 88, 0.88), transparent);
    box-shadow: 0 0 18px rgba(255, 88, 88, 0.56);
}

.mystic-hero__status {
    backdrop-filter: blur(18px);
}

.dynamic-cta {
    border-color: rgba(255, 114, 95, 0.62);
    background:
        radial-gradient(circle at var(--cta-pointer-x, 28%) 50%, rgba(255, 168, 120, 0.18), transparent 32%),
        linear-gradient(180deg, rgba(160, 42, 42, 0.96) 0%, rgba(118, 29, 32, 0.96) 100%);
    box-shadow:
        0 24px 48px rgba(0, 0, 0, 0.42),
        inset 0 1px 0 rgba(255, 212, 176, 0.2),
        0 0 0 1px rgba(255, 92, 74, 0.14),
        0 0 30px rgba(184, 34, 36, 0.28);
}

.dynamic-cta__ambient {
    background:
        radial-gradient(circle at 18% 50%, rgba(255, 198, 148, 0.16), transparent 0 40%),
        linear-gradient(90deg, rgba(255, 255, 255, 0.08), transparent 38%);
}

.dynamic-cta__icon {
    background: linear-gradient(180deg, rgba(77, 26, 24, 0.98), rgba(56, 18, 17, 0.98));
    border-color: rgba(255, 178, 140, 0.28);
}

.dynamic-cta__copy strong {
    letter-spacing: 0;
}

.mystic-hero__signals {
    max-width: 860px;
}

.mystic-signal {
    display: inline-flex;
    align-items: center;
    gap: 12px;
}

.mystic-signal__badge {
    flex: 0 0 38px;
    width: 38px;
    height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.mystic-signal__badge svg {
    width: 18px;
    height: 18px;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.8;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.mystic-signal__copy {
    display: grid;
    gap: 2px;
}

.mystic-signal--ember .mystic-signal__badge {
    color: #ff6660;
    background: radial-gradient(circle, rgba(255, 81, 72, 0.24), rgba(255, 81, 72, 0.08));
    box-shadow: 0 0 16px rgba(255, 81, 72, 0.18);
}

.mystic-signal--gold .mystic-signal__badge {
    color: #f6c15b;
    background: radial-gradient(circle, rgba(246, 193, 91, 0.2), rgba(246, 193, 91, 0.06));
    box-shadow: 0 0 16px rgba(246, 193, 91, 0.14);
}

.mystic-signal--violet .mystic-signal__badge {
    color: #b674ff;
    background: radial-gradient(circle, rgba(182, 116, 255, 0.22), rgba(182, 116, 255, 0.08));
    box-shadow: 0 0 16px rgba(182, 116, 255, 0.16);
}

.mystic-signal--soft .mystic-signal__badge {
    color: #f3e8dd;
}

.mystic-metric {
    position: relative;
    display: grid;
    grid-template-columns: 52px 1fr;
    align-items: center;
    gap: 14px;
}

.mystic-metric::before {
    content: "";
    width: 42px;
    height: 42px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.03);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.mystic-metric:nth-child(1)::before {
    background:
        radial-gradient(circle, rgba(255, 85, 80, 0.16) 0 34%, transparent 35%),
        radial-gradient(circle, transparent 0 55%, rgba(255, 85, 80, 0.9) 56% 61%, transparent 62%),
        rgba(255, 255, 255, 0.03);
    box-shadow: 0 0 18px rgba(255, 85, 80, 0.12), inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.mystic-metric:nth-child(2)::before {
    background:
        linear-gradient(135deg, transparent 0 20%, rgba(255, 85, 80, 0.92) 21% 29%, transparent 30% 40%, rgba(255, 85, 80, 0.92) 41% 49%, transparent 50% 100%),
        rgba(255, 255, 255, 0.03);
}

.mystic-metric:nth-child(3)::before {
    background:
        linear-gradient(135deg, transparent 42%, rgba(246, 193, 91, 0.92) 43% 57%, transparent 58%),
        rgba(255, 255, 255, 0.03);
}

@media (max-width: 920px) {
    .mystic-hero__art {
        object-position: 60% 50%;
    }
}

@media (max-width: 640px) {
    .mystic-hero__art {
        object-position: 59% 50%;
        transform: scale(1.08);
    }

    .mystic-hero__signals {
        max-width: none;
    }

    .mystic-signal__badge {
        flex-basis: 34px;
        width: 34px;
        height: 34px;
    }

    .mystic-metric {
        grid-template-columns: 44px 1fr;
        gap: 12px;
    }

    .mystic-metric::before {
        width: 36px;
        height: 36px;
    }
}

/* Final reference lock for the first hero block */
.home-ref-main {
    max-width: 100%;
}

.product-home {
    width: min(100%, 1400px);
    margin: 0 auto;
}

.mystic-hero {
    width: 100%;
    padding: 0 8px;
}

.mystic-hero__frame {
    min-height: 1120px;
    padding: 28px 28px 220px;
    background: #050505;
}

.mystic-hero__visual {
    inset: 0;
}

.mystic-hero__video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 82% center;
    opacity: 0.98;
    transform: scale(1.06);
    filter: brightness(0.62) saturate(0.86) contrast(1.06);
}

.mystic-hero__video-shade {
    background:
        linear-gradient(90deg, rgba(5, 5, 5, 0.995) 0%, rgba(5, 5, 5, 0.97) 34%, rgba(5, 5, 5, 0.78) 46%, rgba(5, 5, 5, 0.28) 60%, rgba(5, 5, 5, 0.26) 100%),
        radial-gradient(circle at 76% 20%, rgba(255, 202, 120, 0.14), transparent 20%),
        linear-gradient(180deg, rgba(5, 5, 5, 0.12) 0%, rgba(5, 5, 5, 0) 24%, rgba(5, 5, 5, 0.58) 100%);
}

.mystic-hero__content {
    width: min(48%, 640px);
    padding-top: 84px;
    gap: 18px;
}

.mystic-hero__content h1 {
    max-width: 8.8ch;
    font-size: clamp(66px, 6.6vw, 94px);
    line-height: 0.94;
    text-wrap: initial;
}

.mystic-hero__title-dot {
    color: #ff6053;
}

.mystic-hero__description {
    max-width: 23ch;
    font-size: 18px;
    line-height: 1.5;
}

.mystic-hero__status {
    width: min(100%, 444px);
    margin-top: 10px;
    padding: 18px 18px 18px 16px;
    grid-template-columns: 60px 1fr;
}

.mystic-hero__status-mark {
    width: 52px;
    height: 52px;
}

.dynamic-cta {
    width: min(100%, 700px);
    min-height: 102px;
    grid-template-columns: 74px 1fr 40px;
    gap: 18px;
    padding: 16px 24px 16px 18px;
    border-radius: 26px;
}

.dynamic-cta__copy strong {
    font-size: 22px;
}

.dynamic-cta__hint,
.dynamic-cta__copy small {
    font-size: 0;
    line-height: 0;
}

.mystic-hero__signals-shell {
    margin-top: 6px;
}

.mystic-hero__signals {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
    max-width: 840px;
}

.mystic-signal {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    min-height: 78px;
    padding: 12px 14px;
    border-radius: 18px;
    background: rgba(15, 13, 13, 0.82);
}

.mystic-signal__copy strong {
    font-size: 13px;
}

.mystic-signal__copy span {
    font-size: 11px;
}

.mystic-hero__level {
    top: 118px;
    right: 22px;
    width: 132px;
    min-height: 150px;
    padding: 18px 12px;
    border-radius: 24px;
}

.mystic-hero__level strong {
    font-size: 52px;
}

.mystic-hero__level span {
    font-size: 18px;
    line-height: 1.1;
}

.mystic-hero__rail {
    top: 290px;
    right: 78px;
    bottom: 166px;
    width: 22px;
}

.mystic-rail__node {
    width: 18px;
    height: 18px;
}

.mystic-hero__footer {
    left: 24px;
    right: 24px;
    bottom: 24px;
    grid-template-columns: 1.1fr 1fr 1.15fr;
    gap: 20px;
    padding: 22px 24px;
    border-radius: 24px;
}

.mystic-metric strong {
    font-size: 18px;
    line-height: 1.25;
}

@media (min-width: 640px) {
    .home-ref-main {
        max-width: 1360px;
        padding-left: 0;
        padding-right: 0;
    }
}

@media (max-width: 920px) {
    .mystic-hero__frame {
        min-height: 1040px;
        padding: 24px 22px 210px;
    }

    .mystic-hero__video {
        object-position: 76% center;
    }

    .mystic-hero__content {
        width: min(56%, 500px);
        padding-top: 82px;
    }

    .mystic-hero__content h1 {
        max-width: 8ch;
        font-size: clamp(58px, 7.8vw, 80px);
    }

    .mystic-hero__signals {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        max-width: 560px;
    }
}

@media (max-width: 640px) {
    .mystic-hero {
        padding: 0;
    }

    .mystic-hero__frame {
        min-height: 920px;
        padding: 20px 18px 190px;
    }

    .mystic-hero__video {
        object-position: 72% center;
    }

    .mystic-hero__content {
        width: min(74%, 306px);
        padding-top: 72px;
        gap: 16px;
    }

    .mystic-hero__content h1 {
        max-width: 6.8ch;
        font-size: clamp(52px, 14vw, 70px);
        line-height: 0.95;
    }

    .mystic-hero__description {
        max-width: 15ch;
        font-size: 15px;
    }

    .mystic-hero__status {
        width: 100%;
        padding: 14px;
        grid-template-columns: 52px 1fr;
    }

    .dynamic-cta {
        width: 100%;
        min-height: 92px;
        grid-template-columns: 58px 1fr 30px;
        padding: 14px 18px 14px 14px;
    }

    .dynamic-cta__copy strong {
        font-size: 18px;
    }

    .mystic-hero__level {
        top: 116px;
        right: 18px;
        width: 90px;
        min-height: 90px;
        padding: 12px 8px;
    }

    .mystic-hero__level strong {
        font-size: 38px;
    }

    .mystic-hero__level span {
        font-size: 12px;
    }

    .mystic-hero__rail {
        top: 220px;
        right: 38px;
        bottom: 156px;
    }

    .mystic-hero__signals {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
    }

    .mystic-signal {
        min-height: 70px;
        padding: 12px;
    }

    .mystic-hero__footer {
        left: 18px;
        right: 18px;
        bottom: 18px;
        grid-template-columns: 1fr;
        gap: 12px;
        padding: 16px;
    }
}

/* Strict hero reference pass: only the first block */
.product-home > .mystic-hero .mystic-hero__frame {
    min-height: 1110px;
    padding: 26px 26px 198px;
    overflow: hidden;
}

.product-home > .mystic-hero .mystic-hero__topline {
    z-index: 5;
}

.product-home > .mystic-hero .mystic-hero__visual {
    inset: 88px 94px 176px 49.5%;
    overflow: hidden;
    border-radius: 0;
}

.product-home > .mystic-hero .mystic-hero__video {
    object-position: 88% 50%;
    transform: scale(1.14);
    filter: brightness(0.68) saturate(0.84) contrast(1.06);
    mask-image: linear-gradient(180deg, rgba(0, 0, 0, 1), rgba(0, 0, 0, 0.98) 78%, transparent 100%);
}

.product-home > .mystic-hero .mystic-hero__video-shade {
    background:
        linear-gradient(90deg, rgba(6, 6, 6, 0.08), rgba(6, 6, 6, 0.14) 24%, rgba(6, 6, 6, 0.28) 100%),
        radial-gradient(circle at 64% 14%, rgba(255, 205, 108, 0.18), transparent 10%),
        linear-gradient(180deg, rgba(6, 6, 6, 0.06), rgba(6, 6, 6, 0.22) 62%, rgba(6, 6, 6, 0.66) 100%);
}

.product-home > .mystic-hero .mystic-hero__visual::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(5, 5, 5, 0.24), transparent 16%, transparent 84%, rgba(5, 5, 5, 0.18)),
        radial-gradient(circle at 58% 28%, rgba(255, 191, 96, 0.08), transparent 22%);
    pointer-events: none;
}

.product-home > .mystic-hero .mystic-hero__visual::after {
    content: "";
    position: absolute;
    inset: auto 14% 6% 20%;
    height: 26%;
    background: radial-gradient(circle at center, rgba(255, 189, 86, 0.12), transparent 62%);
    pointer-events: none;
}

.product-home > .mystic-hero .mystic-hero__star {
    top: 58px;
    left: 71%;
    width: 88px;
    height: 88px;
    transform: translateX(-50%);
    border-radius: 999px;
    background:
        radial-gradient(circle, rgba(255, 248, 228, 1) 0 9%, rgba(255, 219, 140, 0.82) 20%, rgba(255, 219, 140, 0) 72%);
    box-shadow: 0 0 54px rgba(255, 187, 77, 0.46);
    opacity: 0.92;
}

.product-home > .mystic-hero .mystic-hero__star::before {
    width: 2px;
    height: 92px;
}

.product-home > .mystic-hero .mystic-hero__star::after {
    width: 92px;
    height: 2px;
}

.product-home > .mystic-hero .mystic-hero__path-glow {
    left: 69%;
    bottom: 44px;
    width: 180px;
    height: 338px;
    background: linear-gradient(180deg, rgba(255, 204, 103, 0.22), rgba(255, 204, 103, 0.02) 86%);
    clip-path: polygon(50% 0%, 66% 18%, 82% 100%, 18% 100%, 34% 18%);
    opacity: 0.72;
}

.product-home > .mystic-hero .mystic-hero__content {
    width: min(42%, 560px);
    padding-top: 90px;
    gap: 16px;
}

.product-home > .mystic-hero .mystic-hero__content h1 {
    max-width: 8.4ch;
    font-size: clamp(76px, 6.8vw, 100px);
    line-height: 0.94;
}

.product-home > .mystic-hero .mystic-hero__description {
    max-width: 18ch;
    font-size: 18px;
}

.product-home > .mystic-hero .mystic-hero__status {
    width: min(100%, 450px);
}

.product-home > .mystic-hero .dynamic-cta {
    width: min(100%, 690px);
    min-height: 104px;
}

.product-home > .mystic-hero .mystic-hero__signals {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.product-home > .mystic-hero .mystic-hero__level {
    top: 122px;
    right: 20px;
    width: 126px;
    min-height: 138px;
}

.product-home > .mystic-hero .mystic-hero__rail {
    top: 270px;
    right: 72px;
    bottom: 172px;
}

.product-home > .mystic-hero .mystic-hero__footer {
    left: 24px;
    right: 24px;
    bottom: 22px;
}

@media (max-width: 920px) {
    .product-home > .mystic-hero .mystic-hero__visual {
        inset: 106px 34px 184px 44%;
    }

    .product-home > .mystic-hero .mystic-hero__video {
        object-position: 82% 50%;
        transform: scale(1.1);
    }

    .product-home > .mystic-hero .mystic-hero__content {
        width: min(50%, 440px);
    }

    .product-home > .mystic-hero .mystic-hero__content h1 {
        font-size: clamp(62px, 8vw, 84px);
    }
}

@media (max-width: 640px) {
    .product-home > .mystic-hero .mystic-hero__frame {
        min-height: 930px;
        padding: 20px 18px 186px;
    }

    .product-home > .mystic-hero .mystic-hero__visual {
        inset: 180px -10px 190px 35%;
    }

    .product-home > .mystic-hero .mystic-hero__video {
        object-position: 78% 50%;
        transform: scale(1.08);
    }

    .product-home > .mystic-hero .mystic-hero__star {
        top: 86px;
        left: 67%;
        width: 64px;
        height: 64px;
    }

    .product-home > .mystic-hero .mystic-hero__star::before {
        height: 66px;
    }

    .product-home > .mystic-hero .mystic-hero__star::after {
        width: 66px;
    }

    .product-home > .mystic-hero .mystic-hero__content {
        width: min(72%, 300px);
        padding-top: 78px;
    }

    .product-home > .mystic-hero .mystic-hero__content h1 {
        max-width: 6.6ch;
        font-size: clamp(54px, 14.2vw, 72px);
    }

    .product-home > .mystic-hero .mystic-hero__description {
        max-width: 15ch;
        font-size: 15px;
    }

    .product-home > .mystic-hero .mystic-hero__level {
        top: 116px;
        right: 18px;
        width: 90px;
        min-height: 92px;
    }

    .product-home > .mystic-hero .mystic-hero__rail {
        top: 210px;
        right: 38px;
        bottom: 168px;
    }

    .product-home > .mystic-hero .mystic-hero__signals {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* Hero polish locked to the first screen only */
.product-home > .mystic-hero .mystic-hero__frame {
    min-height: max(860px, calc(100svh - 8px));
    padding-bottom: 162px;
}

.product-home > .mystic-hero .mystic-hero__visual {
    inset: 96px 68px 154px 48%;
}

.product-home > .mystic-hero .mystic-hero__video {
    object-position: 62% 50%;
    transform: scale(1.08);
    filter: brightness(0.82) saturate(0.9) contrast(1.02);
}

.product-home > .mystic-hero .mystic-hero__video-shade {
    background:
        linear-gradient(90deg, rgba(5, 5, 5, 0.96) 0%, rgba(5, 5, 5, 0.9) 12%, rgba(5, 5, 5, 0.56) 28%, rgba(5, 5, 5, 0.2) 44%, rgba(5, 5, 5, 0.16) 100%),
        radial-gradient(circle at 52% 10%, rgba(255, 208, 116, 0.14), transparent 14%),
        linear-gradient(180deg, rgba(5, 5, 5, 0.04), rgba(5, 5, 5, 0.14) 62%, rgba(5, 5, 5, 0.44) 100%);
}

.product-home > .mystic-hero .mystic-hero__star {
    top: 38px;
    left: 54%;
    width: 108px;
    height: 108px;
    background:
        radial-gradient(circle, rgba(255, 252, 240, 1) 0 6%, rgba(255, 212, 108, 0.92) 15%, rgba(255, 212, 108, 0.22) 28%, rgba(255, 212, 108, 0) 72%);
    box-shadow: 0 0 64px rgba(255, 188, 72, 0.44);
    opacity: 1;
}

.product-home > .mystic-hero .mystic-hero__star::before {
    width: 2px;
    height: 118px;
    background: rgba(255, 236, 190, 0.94);
}

.product-home > .mystic-hero .mystic-hero__star::after {
    width: 118px;
    height: 2px;
    background: rgba(255, 236, 190, 0.92);
}

.product-home > .mystic-hero .mystic-hero__path-glow {
    left: 51.5%;
    bottom: 28px;
    width: 210px;
    height: 388px;
    background: linear-gradient(180deg, rgba(255, 214, 120, 0.28), rgba(255, 214, 120, 0.06) 56%, rgba(255, 214, 120, 0.01) 100%);
    clip-path: polygon(50% 0%, 68% 15%, 88% 100%, 12% 100%, 32% 15%);
    filter: blur(1.2px);
}

.product-home > .mystic-hero .mystic-hero__content {
    width: min(46%, 620px);
    padding-top: 112px;
    gap: 20px;
}

.product-home > .mystic-hero .mystic-hero__content h1 {
    max-width: 8.9ch;
    font-size: clamp(66px, 6vw, 92px);
    line-height: 0.95;
}

.product-home > .mystic-hero .mystic-hero__description {
    max-width: 21ch;
    font-size: 17px;
    line-height: 1.55;
    color: rgba(246, 240, 234, 0.78);
}

.product-home > .mystic-hero .mystic-hero__subscription-badge {
    width: min(100%, 420px);
    display: grid;
    grid-template-columns: 12px minmax(0, 1fr);
    align-items: start;
    gap: 12px;
    padding: 14px 16px;
    border: 1px solid rgba(216, 167, 95, 0.14);
    border-radius: 20px;
    background:
        linear-gradient(180deg, rgba(18, 17, 17, 0.78), rgba(10, 10, 10, 0.88)),
        radial-gradient(circle at 12% 50%, rgba(166, 38, 44, 0.16), transparent 34%);
    box-shadow:
        0 14px 34px rgba(0, 0, 0, 0.2),
        inset 0 1px 0 rgba(255, 255, 255, 0.04);
    backdrop-filter: blur(14px);
}

.product-home > .mystic-hero .mystic-hero__subscription-dot {
    width: 10px;
    height: 10px;
    margin-top: 7px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(246, 240, 234, 0.94), rgba(216, 167, 95, 0.72) 42%, rgba(178, 58, 59, 0.28) 70%);
    box-shadow: 0 0 18px rgba(216, 167, 95, 0.26);
}

.product-home > .mystic-hero .mystic-hero__subscription-copy {
    display: grid;
    gap: 4px;
}

.product-home > .mystic-hero .mystic-hero__subscription-copy small {
    color: rgba(246, 240, 234, 0.56);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.14em;
    line-height: 1.2;
    text-transform: uppercase;
}

.product-home > .mystic-hero .mystic-hero__subscription-copy strong {
    color: #f6f0ea;
    font-size: 15px;
    font-weight: 600;
    line-height: 1.28;
}

.product-home > .mystic-hero .mystic-hero__subscription-copy span {
    color: rgba(246, 240, 234, 0.7);
    font-size: 12px;
    line-height: 1.45;
}

.product-home > .mystic-hero .mystic-hero__status {
    width: min(100%, 494px);
    padding: 16px 18px 16px 16px;
    border-radius: 24px;
    background:
        linear-gradient(180deg, rgba(18, 17, 17, 0.82), rgba(10, 10, 10, 0.9)),
        radial-gradient(circle at 12% 50%, rgba(166, 38, 44, 0.18), transparent 34%);
    border-color: rgba(255, 255, 255, 0.09);
}

.product-home > .mystic-hero .mystic-hero__status-copy {
    gap: 6px;
}

.product-home > .mystic-hero .mystic-hero__status-kicker {
    display: block;
    color: rgba(246, 240, 234, 0.58);
    font-size: 11px;
    font-weight: 600;
    line-height: 1.2;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.product-home > .mystic-hero .mystic-hero__status-copy strong {
    font-size: 18px;
}

.product-home > .mystic-hero .mystic-hero__status-copy span {
    font-size: 13px;
    color: rgba(246, 240, 234, 0.74);
}

.product-home > .mystic-hero .dynamic-cta {
    width: min(100%, 540px);
    min-height: 84px;
    grid-template-columns: 58px 1fr 24px;
    padding: 12px 18px 12px 12px;
    gap: 16px;
}

.product-home > .mystic-hero .dynamic-cta__icon {
    width: 44px;
    height: 44px;
}

.product-home > .mystic-hero .dynamic-cta__copy strong {
    font-size: 18px;
    font-weight: 600;
    letter-spacing: 0.01em;
}

.product-home > .mystic-hero .dynamic-cta__copy small,
.product-home > .mystic-hero .dynamic-cta__hint {
    display: none;
}

.product-home > .mystic-hero .mystic-hero__signals-shell {
    display: none;
}

.product-home > .mystic-hero .mystic-hero__footer {
    left: 24px;
    right: 24px;
    bottom: 22px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
    padding: 18px 20px;
    background: rgba(12, 11, 11, 0.74);
    border-color: rgba(255, 255, 255, 0.08);
    backdrop-filter: blur(18px);
}

.product-home > .mystic-hero .mystic-metric {
    grid-template-columns: 48px 1fr;
    gap: 12px;
    align-items: center;
}

.product-home > .mystic-hero .mystic-metric::before {
    display: none;
}

.product-home > .mystic-hero .mystic-metric__icon {
    width: 40px;
    height: 40px;
    display: block;
    object-fit: contain;
    opacity: 0.98;
    filter: drop-shadow(0 0 12px rgba(255, 132, 92, 0.18));
}

.product-home > .mystic-hero .mystic-metric__copy {
    display: grid;
    gap: 2px;
}

.product-home > .mystic-hero .mystic-metric__copy > span {
    color: rgba(246, 240, 234, 0.52);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0;
    text-transform: uppercase;
}

.product-home > .mystic-hero .mystic-metric__copy strong {
    font-size: 16px;
    line-height: 1.2;
}

@media (max-width: 920px) {
    .product-home > .mystic-hero .mystic-hero__visual {
        inset: 108px 14px 148px 42%;
    }

    .product-home > .mystic-hero .mystic-hero__video {
        object-position: 58% 50%;
    }

    .product-home > .mystic-hero .mystic-hero__content {
        width: min(52%, 430px);
        padding-top: 96px;
    }

    .product-home > .mystic-hero .mystic-hero__content h1 {
        max-width: 8.2ch;
        font-size: clamp(58px, 7.2vw, 78px);
    }

    .product-home > .mystic-hero .mystic-hero__subscription-badge {
        width: min(100%, 360px);
    }

    .product-home > .mystic-hero .mystic-hero__footer {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 640px) {
    .product-home > .mystic-hero .mystic-hero__frame {
        min-height: max(820px, calc(100svh - 6px));
        padding-bottom: 168px;
    }

    .product-home > .mystic-hero .mystic-hero__visual {
        inset: 176px -18px 170px 31%;
    }

    .product-home > .mystic-hero .mystic-hero__video {
        object-position: 61% 50%;
        transform: scale(1.04);
    }

    .product-home > .mystic-hero .mystic-hero__star {
        top: 76px;
        left: 58%;
        width: 74px;
        height: 74px;
    }

    .product-home > .mystic-hero .mystic-hero__star::before {
        height: 78px;
    }

    .product-home > .mystic-hero .mystic-hero__star::after {
        width: 78px;
    }

    .product-home > .mystic-hero .mystic-hero__path-glow {
        left: 53%;
        width: 132px;
        height: 250px;
        bottom: 20px;
    }

    .product-home > .mystic-hero .mystic-hero__content {
        width: min(74%, 320px);
        padding-top: 78px;
        gap: 16px;
    }

    .product-home > .mystic-hero .mystic-hero__content h1 {
        max-width: 6.8ch;
        font-size: clamp(50px, 13.8vw, 70px);
    }

    .product-home > .mystic-hero .mystic-hero__description {
        max-width: 15ch;
        font-size: 15px;
    }

    .product-home > .mystic-hero .mystic-hero__subscription-badge {
        width: min(100%, 320px);
        padding: 12px 14px;
        border-radius: 18px;
        gap: 10px;
    }

    .product-home > .mystic-hero .mystic-hero__subscription-copy strong {
        font-size: 14px;
    }

    .product-home > .mystic-hero .mystic-hero__subscription-copy span {
        font-size: 11px;
    }

    .product-home > .mystic-hero .mystic-hero__status {
        width: 100%;
        padding: 14px;
    }

    .product-home > .mystic-hero .dynamic-cta {
        width: 100%;
        min-height: 80px;
    }

    .product-home > .mystic-hero .mystic-hero__footer {
        left: 18px;
        right: 18px;
        bottom: 18px;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
        padding: 14px 14px calc(14px + var(--safe-bottom));
    }

    .product-home > .mystic-hero .mystic-metric {
        grid-template-columns: 40px 1fr;
        gap: 10px;
    }

    .product-home > .mystic-hero .mystic-metric__icon {
        width: 34px;
        height: 34px;
    }

.product-home > .mystic-hero .mystic-metric__copy strong {
        font-size: 14px;
    }
}

/* Scenario levels redesign */
.scenario-progression {
    gap: 14px;
    padding: 16px;
    border-color: rgba(246, 240, 234, 0.1);
    background:
        linear-gradient(180deg, rgba(14, 11, 11, 0.96), rgba(5, 5, 5, 0.985)),
        radial-gradient(circle at 50% 0%, rgba(112, 20, 28, 0.16), transparent 30%),
        radial-gradient(circle at 84% 82%, rgba(181, 138, 80, 0.07), transparent 24%),
        radial-gradient(circle at 18% 72%, rgba(136, 102, 63, 0.05), transparent 24%);
    box-shadow: 0 30px 72px rgba(0, 0, 0, 0.46), inset 0 1px 0 rgba(255, 255, 255, 0.045);
}

.scenario-progression::before,
.scenario-progression::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.scenario-progression::before {
    background:
        linear-gradient(90deg, rgba(255, 255, 255, 0.022), transparent 10%, transparent 90%, rgba(255, 255, 255, 0.016)),
        repeating-linear-gradient(90deg, transparent 0 74px, rgba(255, 255, 255, 0.012) 74px 75px);
    opacity: 0.12;
    mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.36), transparent 100%);
}

.scenario-progression::after {
    border-radius: inherit;
    border: 1px solid rgba(255, 255, 255, 0.022);
}

.scenario-progression__header {
    gap: 8px;
}

.scenario-progression__header h2 {
    max-width: 7.8em;
    font-size: clamp(32px, 6.8vw, 52px);
    line-height: 0.92;
}

.scenario-current,
.scenario-next {
    border-radius: 26px;
    border-color: rgba(246, 240, 234, 0.09);
    background:
        linear-gradient(180deg, rgba(10, 10, 10, 0.92), rgba(6, 6, 6, 0.985)),
        radial-gradient(circle at 50% 0%, rgba(143, 32, 41, 0.12), transparent 36%);
}

.scenario-current {
    min-height: 248px;
    grid-template-columns: minmax(0, 1fr);
    gap: 16px;
    padding: 18px 16px 16px;
    background:
        linear-gradient(180deg, rgba(12, 10, 10, 0.76), rgba(6, 6, 6, 0.98) 76%),
        radial-gradient(circle at 50% 22%, rgba(172, 41, 51, 0.22), transparent 32%),
        radial-gradient(circle at 50% 26%, rgba(214, 173, 123, 0.06), transparent 20%),
        #070707;
}

.scenario-current::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, transparent calc(50% - 1px), rgba(171, 48, 56, 0.15) calc(50% - 1px), rgba(171, 48, 56, 0.15) calc(50% + 1px), transparent calc(50% + 1px)),
        linear-gradient(180deg, transparent 22px, rgba(171, 48, 56, 0.06) 22px 56%, transparent 56%),
        radial-gradient(circle at 50% 28%, rgba(255, 223, 223, 0.06) 0 1px, transparent 1px),
        repeating-radial-gradient(circle at 50% 28%, rgba(171, 48, 56, 0.05) 0 1px, transparent 1px 38px);
    opacity: 0.34;
    pointer-events: none;
}

.scenario-current::after {
    top: 10px;
    width: 156px;
    border-color: rgba(169, 57, 63, 0.34);
    background:
        radial-gradient(circle, rgba(171, 48, 56, 0.14), transparent 62%),
        radial-gradient(circle at center, rgba(255, 214, 214, 0.05), transparent 54%);
    box-shadow:
        0 0 34px rgba(143, 32, 41, 0.3),
        0 0 88px rgba(143, 32, 41, 0.12);
}

.scenario-current__copy {
    max-width: 18rem;
}

.scenario-current h2 {
    max-width: none;
    margin-top: 8px;
    font-size: clamp(40px, 7.4vw, 54px);
    line-height: 0.9;
}

.scenario-current p {
    max-width: 18ch;
    margin-top: 8px;
    color: rgba(246, 240, 234, 0.76);
    font-size: 15px;
    line-height: 1.4;
    overflow-wrap: anywhere;
}

.scenario-current__sigil {
    position: absolute;
    left: 50%;
    top: 20px;
    z-index: 0;
    display: grid;
    place-items: center;
    width: 156px;
    height: 156px;
    transform: translateX(-50%);
    border-radius: 50%;
    color: rgba(255, 216, 216, 0.96);
    font-family: "Cormorant Garamond", serif;
    font-size: 62px;
    font-weight: 600;
    line-height: 1;
    text-shadow: 0 0 18px rgba(191, 70, 78, 0.38);
    pointer-events: none;
}

.scenario-current__sigil::before,
.scenario-current__sigil::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
}

.scenario-current__sigil::before {
    border: 1px solid rgba(185, 58, 66, 0.28);
    box-shadow: inset 0 0 24px rgba(143, 32, 41, 0.14), 0 0 42px rgba(143, 32, 41, 0.12);
    background:
        linear-gradient(90deg, transparent calc(50% - 0.5px), rgba(190, 64, 71, 0.18) calc(50% - 0.5px), rgba(190, 64, 71, 0.18) calc(50% + 0.5px), transparent calc(50% + 0.5px)),
        linear-gradient(180deg, transparent calc(50% - 0.5px), rgba(190, 64, 71, 0.18) calc(50% - 0.5px), rgba(190, 64, 71, 0.18) calc(50% + 0.5px), transparent calc(50% + 0.5px));
}

.scenario-current__sigil::after {
    inset: 16px;
    border: 1px solid rgba(246, 240, 234, 0.08);
}

.scenario-current__aside,
.scenario-current__aside::before {
    display: none;
}

.scenario-current__aside strong {
    color: #f4dec0;
    font-family: "Cormorant Garamond", serif;
    font-size: 17px;
    font-weight: 600;
    line-height: 1.05;
}

.scenario-current__aside span:last-child {
    max-width: 13ch;
    color: rgba(246, 240, 234, 0.6);
    font-size: 12px;
    line-height: 1.35;
}

.scenario-current__aside-icon,
.scenario-icon,
.scenario-unlock-tile__icon {
    display: grid;
    place-items: center;
    width: 32px;
    height: 32px;
    border: 1px solid rgba(201, 161, 108, 0.22);
    border-radius: 12px;
    background: linear-gradient(180deg, rgba(38, 28, 22, 0.86), rgba(11, 10, 10, 0.96));
    color: rgba(244, 206, 157, 0.94);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05), 0 0 18px rgba(175, 124, 69, 0.08);
}

.scenario-current__aside-icon svg,
.scenario-icon svg,
.scenario-unlock-tile__icon svg {
    width: 17px;
    height: 17px;
    stroke: currentColor;
    stroke-width: 1.6;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.scenario-depth {
    gap: 10px;
    padding: 12px 12px 14px;
    border-color: rgba(246, 240, 234, 0.08);
    border-radius: 20px;
    background: rgba(4, 4, 4, 0.62);
    backdrop-filter: blur(18px);
}

.scenario-depth__top,
.scenario-depth__bottom {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.scenario-depth__top strong,
.scenario-depth__bottom strong {
    font-size: 14px;
    font-weight: 600;
}

.scenario-depth__track {
    height: 4px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.09);
    box-shadow: inset 0 1px 1px rgba(255, 255, 255, 0.04);
}

.scenario-depth__track span {
    background: linear-gradient(90deg, rgba(148, 42, 52, 0.92), rgba(204, 120, 126, 0.96), rgba(236, 220, 214, 0.74));
    box-shadow: 0 0 18px rgba(184, 62, 70, 0.24), 0 0 8px rgba(255, 215, 215, 0.14);
}

.scenario-next {
    min-height: 178px;
    display: grid;
    gap: 14px;
    padding: 17px 16px;
    background:
        linear-gradient(180deg, rgba(11, 11, 11, 0.82), rgba(7, 7, 7, 0.985)),
        radial-gradient(circle at 76% 26%, rgba(185, 141, 86, 0.08), transparent 32%),
        radial-gradient(circle at 20% 72%, rgba(143, 32, 41, 0.14), transparent 28%);
}

.scenario-next::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, transparent 57%, rgba(255, 255, 255, 0.03) 57%, rgba(255, 255, 255, 0.03) calc(57% + 1px), transparent calc(57% + 1px)),
        radial-gradient(circle at 57% 50%, rgba(171, 48, 56, 0.05), transparent 34%);
    pointer-events: none;
}

.scenario-next__copy {
    display: grid;
    gap: 6px;
}

.scenario-next h3 {
    max-width: 8.6em;
    font-size: clamp(32px, 6.5vw, 42px);
    line-height: 0.92;
}

.scenario-next p {
    max-width: 22ch;
    color: rgba(246, 240, 234, 0.76);
    font-size: 15px;
    line-height: 1.38;
}

.scenario-next__preview {
    display: grid;
    gap: 8px;
    align-content: start;
    justify-items: start;
}

.scenario-unlock-tile {
    display: grid;
    grid-template-columns: 50px minmax(0, 1fr);
    gap: 12px;
    align-items: center;
    padding: 12px;
    border: 1px solid rgba(246, 240, 234, 0.08);
    border-radius: 18px;
    background:
        linear-gradient(180deg, rgba(22, 16, 15, 0.94), rgba(10, 10, 10, 0.96)),
        radial-gradient(circle at 82% 18%, rgba(185, 58, 66, 0.08), transparent 28%);
}

.scenario-unlock-tile strong {
    display: block;
    color: var(--text);
    font-family: "Cormorant Garamond", serif;
    font-size: 24px;
    font-weight: 600;
    line-height: 0.96;
}

.scenario-unlock-tile p {
    max-width: none;
    margin: 4px 0 0;
    color: rgba(246, 240, 234, 0.58);
    font-size: 12px;
    line-height: 1.36;
}

.scenario-next__shadow {
    padding: 10px 12px;
    border-color: rgba(246, 240, 234, 0.08);
    background: rgba(255, 255, 255, 0.025);
    color: rgba(246, 240, 234, 0.62);
    font-size: 10px;
    letter-spacing: 0;
}

.scenario-line-head {
    align-items: start;
    padding: 0 2px;
}

.scenario-line-head p {
    max-width: 15ch;
    color: rgba(246, 240, 234, 0.52);
    font-size: 13px;
    line-height: 1.34;
}

.scenario-line {
    display: grid;
    gap: 12px;
    padding: 2px 0 2px;
    grid-template-columns: minmax(0, 1fr);
    overflow: visible;
}

.scenario-line::before,
.scenario-line::after {
    content: "";
    position: absolute;
    pointer-events: none;
}

.scenario-line::before {
    left: 13px;
    top: 12px;
    bottom: 12px;
    width: 2px;
    border-radius: 999px;
    background: linear-gradient(180deg, rgba(246, 240, 234, 0.1), rgba(174, 133, 86, 0.3) 24%, rgba(174, 133, 86, 0.24) 50%, rgba(246, 240, 234, 0.08));
    box-shadow: 0 0 20px rgba(174, 133, 86, 0.14);
}

.scenario-line::after {
    left: 12px;
    top: 12px;
    bottom: 12px;
    width: 6px;
    background: linear-gradient(180deg, rgba(174, 133, 86, 0.12), rgba(174, 133, 86, 0.12) 42%, rgba(174, 133, 86, 0.08));
    filter: blur(10px);
    opacity: 0.72;
}

.scenario-level-row {
    position: relative;
    display: grid;
    grid-template-columns: 28px minmax(0, 1fr);
    gap: 0 14px;
}

.scenario-level-row::before {
    display: none;
}

.scenario-level-card,
.scenario-level-unlocks {
    min-width: 0;
    grid-column: 2 / 3;
}

.scenario-level-card {
    position: relative;
    padding-left: 0;
    padding-right: 0;
}

.scenario-level-card::before {
    content: "";
    position: absolute;
    left: -14px;
    top: 50%;
    width: 14px;
    height: 1px;
    transform: translateY(-50%);
    background: linear-gradient(90deg, rgba(246, 240, 234, 0.14), rgba(246, 240, 234, 0.05));
}

.scenario-level-card__node {
    left: -15px;
    right: auto;
    top: 50%;
    width: 24px;
    height: 24px;
    transform: translate(-50%, -50%);
    border-color: rgba(246, 240, 234, 0.12);
    background: radial-gradient(circle, rgba(72, 76, 80, 0.22), rgba(8, 8, 8, 0.98) 68%);
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.16);
}

.scenario-level-card__node::before,
.scenario-level-card__node::after {
    content: "";
    position: absolute;
    inset: 50% auto auto 50%;
    border-radius: 50%;
    transform: translate(-50%, -50%);
    pointer-events: none;
}

.scenario-level-card__node::before {
    width: 34px;
    height: 34px;
    border: 1px solid rgba(246, 240, 234, 0.06);
}

.scenario-level-card__node::after {
    width: 12px;
    height: 12px;
    background: radial-gradient(circle, rgba(246, 240, 234, 0.34), rgba(26, 23, 20, 0.8) 72%);
}

.scenario-level-card__body {
    min-height: 128px;
    gap: 8px;
    padding: 13px 13px 12px;
    border-radius: 20px;
    border-color: rgba(246, 240, 234, 0.08);
    background:
        linear-gradient(180deg, rgba(18, 16, 16, 0.95), rgba(8, 8, 8, 0.98)),
        radial-gradient(circle at 86% 14%, rgba(143, 32, 41, 0.08), transparent 34%);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

.scenario-level-card__veil {
    right: -10px;
    bottom: -14px;
    color: rgba(246, 240, 234, 0.05);
    font-size: 78px;
}

.scenario-level-card__roman {
    width: 44px;
    height: 44px;
    border-color: rgba(246, 240, 234, 0.12);
    color: rgba(246, 240, 234, 0.84);
    font-size: 28px;
}

.scenario-level-card strong {
    max-width: 10ch;
    font-size: 22px;
    line-height: 0.94;
    overflow-wrap: anywhere;
}

.scenario-level-card p {
    max-width: 28ch;
    color: rgba(246, 240, 234, 0.64);
    font-size: 13px;
    line-height: 1.34;
    overflow-wrap: anywhere;
}

.scenario-level-card small {
    justify-self: start;
    padding: 6px 9px;
    border-color: rgba(246, 240, 234, 0.06);
    background: rgba(255, 255, 255, 0.022);
    color: rgba(246, 240, 234, 0.54);
    font-size: 10px;
    letter-spacing: 0.12em;
}

.scenario-level-unlocks {
    display: grid;
    position: relative;
    gap: 8px;
    margin-top: 8px;
    padding: 12px;
    min-height: 128px;
    border: 1px solid rgba(246, 240, 234, 0.06);
    border-radius: 20px;
    background:
        linear-gradient(180deg, rgba(14, 14, 14, 0.72), rgba(8, 8, 8, 0.92)),
        radial-gradient(circle at 8% 24%, rgba(201, 161, 108, 0.035), transparent 24%),
        radial-gradient(circle at 82% 60%, rgba(255, 255, 255, 0.02), transparent 20%);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.025);
    backdrop-filter: blur(10px);
}

.scenario-level-unlocks::before {
    content: "";
    position: absolute;
    left: -14px;
    top: 24px;
    width: 14px;
    height: 1px;
    background: linear-gradient(90deg, rgba(246, 240, 234, 0.12), rgba(246, 240, 234, 0.03));
}

.scenario-level-unlocks::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.018), transparent 36%);
    pointer-events: none;
}

.scenario-level-unlocks__label {
    color: rgba(246, 240, 234, 0.52);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.scenario-level-unlocks__items {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.scenario-unlock-chip {
    min-width: 0;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 10px;
    border: 1px solid rgba(246, 240, 234, 0.07);
    border-radius: 13px;
    background:
        linear-gradient(180deg, rgba(28, 22, 20, 0.6), rgba(10, 10, 10, 0.84)),
        rgba(255, 255, 255, 0.016);
    color: rgba(246, 240, 234, 0.76);
    font-size: 12px;
    line-height: 1.25;
    transition: transform 160ms ease, border-color 160ms ease, background-color 160ms ease, box-shadow 160ms ease;
    overflow: hidden;
}

.scenario-unlock-chip span:last-child {
    min-width: 0;
    overflow-wrap: anywhere;
}

.scenario-icon {
    width: 28px;
    height: 28px;
    flex: 0 0 auto;
    border-radius: 10px;
}

.scenario-level-row--opened .scenario-level-card__body,
.scenario-level-unlocks--opened {
    border-color: rgba(90, 118, 84, 0.16);
    background:
        linear-gradient(180deg, rgba(15, 18, 15, 0.94), rgba(8, 10, 8, 0.98)),
        radial-gradient(circle at 12% 24%, rgba(82, 110, 78, 0.08), transparent 30%);
    box-shadow: 0 0 14px rgba(82, 110, 78, 0.05), inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.scenario-level-row--opened .scenario-level-card__roman,
.scenario-level-row--opened .scenario-level-card__node {
    border-color: rgba(102, 132, 95, 0.22);
    color: rgba(204, 220, 191, 0.86);
    background: radial-gradient(circle, rgba(90, 122, 83, 0.24), rgba(10, 12, 9, 0.96) 72%);
    box-shadow: 0 0 12px rgba(90, 122, 83, 0.12);
}

.scenario-level-row--opened .scenario-level-card::before,
.scenario-level-row--opened .scenario-level-unlocks::before {
    background: linear-gradient(90deg, rgba(90, 122, 83, 0.22), rgba(246, 240, 234, 0.1));
}

.scenario-level-row--opened .scenario-unlock-chip {
    border-color: rgba(90, 122, 83, 0.12);
    color: rgba(219, 228, 214, 0.82);
}

.scenario-level-row--current .scenario-level-card__body,
.scenario-level-row.is-current .scenario-level-card__body,
.scenario-level-unlocks--current {
    border-color: rgba(114, 166, 96, 0.24);
    background:
        linear-gradient(180deg, rgba(16, 20, 16, 0.96), rgba(9, 10, 9, 0.98)),
        radial-gradient(circle at 82% 18%, rgba(114, 166, 96, 0.12), transparent 34%),
        radial-gradient(circle at 18% 22%, rgba(170, 124, 80, 0.03), transparent 32%);
    box-shadow: 0 0 18px rgba(114, 166, 96, 0.08), inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

.scenario-level-row--current .scenario-level-card__roman,
.scenario-level-row--current .scenario-level-card__node,
.scenario-level-row.is-current .scenario-level-card__roman,
.scenario-level-row.is-current .scenario-level-card__node {
    border-color: rgba(144, 198, 118, 0.28);
    color: rgba(226, 240, 205, 0.94);
    background: radial-gradient(circle, rgba(126, 182, 102, 0.52), rgba(54, 82, 42, 0.44) 42%, rgba(8, 8, 8, 0.96) 74%);
    box-shadow: 0 0 18px rgba(118, 176, 94, 0.18);
}

.scenario-level-row--current .scenario-level-card::before,
.scenario-level-row--current .scenario-level-unlocks::before,
.scenario-level-row.is-current .scenario-level-card::before,
.scenario-level-row.is-current .scenario-level-unlocks::before {
    background: linear-gradient(90deg, rgba(114, 166, 96, 0.24), rgba(246, 240, 234, 0.12));
}

.scenario-level-row--current .scenario-unlock-chip,
.scenario-level-row.is-current .scenario-unlock-chip {
    border-color: rgba(114, 166, 96, 0.14);
}

.scenario-level-row--locked .scenario-level-card__body,
.scenario-level-unlocks--locked {
    border-color: rgba(122, 72, 69, 0.12);
    background:
        linear-gradient(180deg, rgba(17, 14, 14, 0.92), rgba(8, 8, 8, 0.97)),
        radial-gradient(circle at 82% 14%, rgba(122, 72, 69, 0.06), transparent 28%),
        radial-gradient(circle at 18% 68%, rgba(255, 255, 255, 0.015), transparent 22%);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.02);
}

.scenario-level-row--locked .scenario-level-card__body {
    opacity: 0.96;
}

.scenario-level-row--locked .scenario-level-card__node,
.scenario-level-row--locked .scenario-level-card__roman {
    color: rgba(191, 162, 158, 0.66);
    border-color: rgba(122, 72, 69, 0.16);
    background: radial-gradient(circle, rgba(112, 68, 66, 0.2), rgba(8, 8, 8, 0.96) 70%);
}

.scenario-level-row--locked .scenario-level-card strong,
.scenario-level-row--locked .scenario-unlock-chip {
    color: rgba(196, 176, 171, 0.78);
}

.scenario-level-row--locked .scenario-level-card p,
.scenario-level-row--locked .scenario-level-unlocks__label {
    color: rgba(184, 164, 160, 0.54);
}

.scenario-level-row--locked .scenario-unlock-chip {
    border-color: rgba(122, 72, 69, 0.1);
    background: linear-gradient(180deg, rgba(26, 20, 20, 0.72), rgba(10, 10, 10, 0.88));
}

.scenario-level-row--locked .scenario-level-card::before,
.scenario-level-row--locked .scenario-level-unlocks::before {
    background: linear-gradient(90deg, rgba(122, 72, 69, 0.12), rgba(246, 240, 234, 0.05));
}

@media (hover: hover) and (pointer: fine) {
    .scenario-unlock-chip:hover {
        transform: translateY(-1px);
        border-color: rgba(201, 161, 108, 0.16);
        color: rgba(246, 240, 234, 0.9);
        box-shadow: 0 0 18px rgba(201, 161, 108, 0.05);
    }
}

@media (min-width: 760px) {
    .scenario-current {
        min-height: 224px;
        grid-template-columns: minmax(0, 1fr);
        align-items: end;
        padding: 22px 22px 18px;
    }

    .scenario-current__copy {
        max-width: 23rem;
    }

    .scenario-current p {
        max-width: 19ch;
    }

    .scenario-depth {
        grid-column: 1 / -1;
    }

    .scenario-next {
        min-height: 166px;
        grid-template-columns: minmax(0, 1fr) 354px;
        align-items: center;
        gap: 20px;
        padding: 20px 22px;
    }

    .scenario-next__preview {
        padding-left: 18px;
        border-left: 1px solid rgba(246, 240, 234, 0.07);
    }

    .scenario-line {
        gap: 12px;
    }

    .scenario-level-row {
        grid-template-columns: minmax(0, 1fr) 56px minmax(0, 1fr);
        align-items: center;
        gap: 0;
    }

    .scenario-line::before {
        left: 50%;
        transform: translateX(-50%);
    }

    .scenario-line::after {
        left: calc(50% - 1px);
        transform: translateX(-50%);
    }

    .scenario-level-card {
        grid-column: 1 / 2;
        padding-right: 28px;
        justify-self: start;
        width: min(100%, 470px);
    }

    .scenario-level-card::before {
        left: auto;
        right: -28px;
        width: 28px;
        background: linear-gradient(90deg, rgba(185, 48, 58, 0.14), rgba(246, 240, 234, 0.12));
    }

    .scenario-level-card__node {
        left: auto;
        right: -28px;
        transform: translate(50%, -50%);
    }

    .scenario-level-card__body {
        min-height: 128px;
        padding: 15px 16px 14px;
    }

    .scenario-level-card strong {
        font-size: 24px;
    }

    .scenario-level-card p {
        font-size: 13px;
        line-height: 1.36;
    }

    .scenario-level-unlocks {
        grid-column: 3 / 4;
        margin-top: 0;
        min-height: 128px;
        align-content: center;
        justify-self: start;
        width: min(100%, 430px);
        max-width: 430px;
        padding: 12px 14px 13px;
    }

    .scenario-level-unlocks::before {
        left: -28px;
        width: 28px;
        background: linear-gradient(90deg, rgba(246, 240, 234, 0.12), rgba(185, 48, 58, 0.14));
    }

    .scenario-level-unlocks__items {
        max-width: none;
    }

    .scenario-level-unlocks--opened,
    .scenario-level-unlocks--current {
        max-width: 430px;
    }

    .scenario-level-unlocks--locked {
        max-width: 430px;
    }

    .scenario-level-row--opened .scenario-level-unlocks,
    .scenario-level-row--current .scenario-level-unlocks {
        margin-top: 2px;
    }

    .scenario-level-row--locked .scenario-level-unlocks {
        margin-top: 8px;
    }
}

@media (max-width: 620px) {
    .scenario-progression {
        padding: 14px 12px;
        border-radius: 24px;
    }

    .scenario-current,
    .scenario-next {
        border-radius: 22px;
    }

    .scenario-current {
        min-height: 276px;
        padding-top: 124px;
    }

    .scenario-current::after,
    .scenario-current__sigil {
        top: 12px;
    }

    .scenario-current__aside {
        top: 16px;
        left: 16px;
        right: auto;
        width: auto;
        transform: none;
    }

    .scenario-current__aside::before {
        display: none;
    }

    .scenario-current h2 {
        font-size: 36px;
    }

    .scenario-current p,
    .scenario-next p {
        font-size: 14px;
    }

    .scenario-next h3 {
        font-size: 30px;
    }

    .scenario-unlock-tile strong {
        font-size: 22px;
    }

    .scenario-line-head {
        gap: 8px;
    }

    .scenario-line-head p {
        font-size: 11px;
        text-align: right;
    }

    .scenario-level-card__body {
        min-height: 116px;
        padding: 12px;
    }

    .scenario-level-card strong {
        font-size: 21px;
    }

    .scenario-level-card p {
        font-size: 12px;
    }

    .scenario-unlock-chip {
        width: 100%;
    }
}

/* Scenario progression: pixel pass toward the reference */
.scenario-progression {
    position: relative;
    overflow: hidden;
    display: grid;
    gap: 18px;
    padding: 22px 22px 28px;
    border: 1px solid rgba(201, 161, 108, 0.24);
    border-radius: 34px;
    background:
        linear-gradient(180deg, rgba(41, 18, 21, 0.94), rgba(7, 6, 6, 0.995)),
        radial-gradient(circle at 50% 0%, rgba(143, 32, 41, 0.26), transparent 32%),
        radial-gradient(circle at 86% 74%, rgba(201, 161, 108, 0.13), transparent 28%),
        radial-gradient(circle at 16% 70%, rgba(160, 76, 53, 0.08), transparent 26%);
    box-shadow:
        0 38px 96px rgba(0, 0, 0, 0.54),
        0 0 52px rgba(143, 32, 41, 0.14),
        inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.scenario-progression::before {
    background:
        linear-gradient(90deg, rgba(255, 255, 255, 0.02), transparent 10%, transparent 90%, rgba(255, 255, 255, 0.015)),
        repeating-linear-gradient(90deg, transparent 0 78px, rgba(255, 255, 255, 0.012) 78px 79px);
    opacity: 0.14;
    mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.48), transparent 100%);
}

.scenario-progression::after {
    border: 1px solid rgba(255, 255, 255, 0.018);
}

.scenario-progression__header {
    position: relative;
    z-index: 1;
    display: grid;
    gap: 12px;
    padding: 2px 0 6px;
}

.scenario-progression__header h2 {
    max-width: 6.4ch;
    font-size: clamp(52px, 6vw, 86px);
    line-height: 0.88;
    color: rgba(248, 242, 235, 0.98);
}

.scenario-current,
.scenario-next {
    position: relative;
    z-index: 1;
    overflow: hidden;
    border: 1px solid rgba(194, 121, 69, 0.14);
    border-radius: 28px;
}

.scenario-current {
    display: grid;
    grid-template-columns: minmax(0, 1.12fr) minmax(190px, 0.82fr) minmax(210px, 0.62fr);
    grid-template-areas:
        "copy sigil aside"
        "depth depth depth";
    gap: 26px 24px;
    min-height: 338px;
    padding: 30px 28px 24px;
    align-items: center;
    background:
        linear-gradient(180deg, rgba(15, 10, 10, 0.94), rgba(6, 6, 6, 0.985) 78%),
        radial-gradient(circle at 50% 28%, rgba(126, 28, 36, 0.28), transparent 30%),
        radial-gradient(circle at 50% 28%, rgba(255, 224, 224, 0.055), transparent 12%),
        #060606;
    box-shadow:
        0 26px 62px rgba(0, 0, 0, 0.36),
        0 0 42px rgba(117, 24, 31, 0.12),
        inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.scenario-current::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, transparent calc(50% - 0.5px), rgba(154, 44, 52, 0.16) calc(50% - 0.5px), rgba(154, 44, 52, 0.16) calc(50% + 0.5px), transparent calc(50% + 0.5px)),
        linear-gradient(180deg, transparent calc(50% - 0.5px), rgba(154, 44, 52, 0.06) calc(50% - 0.5px), rgba(154, 44, 52, 0.06) calc(50% + 0.5px), transparent calc(50% + 0.5px)),
        repeating-radial-gradient(circle at 50% 28%, rgba(171, 48, 56, 0.055) 0 1px, transparent 1px 38px);
    opacity: 0.44;
    pointer-events: none;
}

.scenario-current::after {
    top: 18px;
    width: 204px;
    border-color: rgba(170, 52, 60, 0.24);
    background:
        radial-gradient(circle, rgba(171, 48, 56, 0.16), transparent 62%),
        radial-gradient(circle at center, rgba(255, 232, 232, 0.045), transparent 54%);
    box-shadow:
        0 0 42px rgba(143, 32, 41, 0.32),
        0 0 96px rgba(143, 32, 41, 0.12);
}

.scenario-current__copy {
    grid-area: copy;
    max-width: 500px;
    align-self: start;
}

.scenario-current h2 {
    margin-top: 10px;
    font-size: clamp(48px, 5.2vw, 66px);
    line-height: 0.9;
}

.scenario-current p {
    max-width: 18ch;
    margin-top: 10px;
    color: rgba(246, 240, 234, 0.76);
    font-size: 15px;
    line-height: 1.5;
}

.scenario-current__sigil {
    grid-area: sigil;
    position: relative;
    left: auto;
    top: auto;
    justify-self: center;
    width: 194px;
    height: 194px;
    transform: none;
    border: 1px solid rgba(167, 52, 60, 0.2);
    background:
        radial-gradient(circle, rgba(117, 24, 31, 0.22), rgba(12, 8, 8, 0.82) 56%, rgba(8, 8, 8, 0.96) 76%);
    box-shadow:
        0 0 64px rgba(145, 30, 38, 0.24),
        inset 0 0 34px rgba(255, 225, 225, 0.04);
}

.scenario-current__sigil span {
    position: relative;
    z-index: 2;
}

.scenario-current__sigil::before {
    inset: -18px;
    border: 1px solid rgba(167, 52, 60, 0.18);
    box-shadow: 0 0 42px rgba(143, 32, 41, 0.18);
}

.scenario-current__sigil::after {
    inset: 18px;
    border: 1px solid rgba(246, 240, 234, 0.08);
    background:
        linear-gradient(90deg, transparent calc(50% - 0.5px), rgba(246, 220, 220, 0.1) calc(50% - 0.5px), rgba(246, 220, 220, 0.1) calc(50% + 0.5px), transparent calc(50% + 0.5px)),
        linear-gradient(180deg, transparent calc(50% - 0.5px), rgba(246, 220, 220, 0.1) calc(50% - 0.5px), rgba(246, 220, 220, 0.1) calc(50% + 0.5px), transparent calc(50% + 0.5px));
}

.scenario-current__aside {
    grid-area: aside;
    position: relative;
    display: grid;
    grid-template-columns: 40px minmax(0, 1fr);
    gap: 12px;
    align-items: center;
    justify-self: end;
    min-width: 214px;
    padding: 18px 18px 16px;
    border: 1px solid rgba(194, 121, 69, 0.16);
    border-radius: 20px;
    background:
        linear-gradient(180deg, rgba(19, 15, 14, 0.92), rgba(8, 8, 8, 0.96)),
        radial-gradient(circle at 16% 22%, rgba(178, 121, 74, 0.08), transparent 28%);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.scenario-current__aside::before {
    content: "";
    display: block;
    position: absolute;
    left: -24px;
    top: 50%;
    width: 24px;
    height: 1px;
    transform: translateY(-50%);
    background: linear-gradient(90deg, rgba(194, 121, 69, 0.06), rgba(194, 121, 69, 0.24));
}

.scenario-current__aside-copy {
    display: grid;
    gap: 4px;
}

.scenario-current__aside strong {
    font-size: 20px;
}

.scenario-current__aside span:last-child {
    color: rgba(246, 240, 234, 0.58);
    font-size: 12px;
    line-height: 1.35;
}

.scenario-current__aside-icon {
    width: 38px;
    height: 38px;
    border-radius: 14px;
}

.scenario-depth {
    grid-area: depth;
    gap: 12px;
    padding: 16px 16px 18px;
    border-color: rgba(194, 121, 69, 0.12);
    border-radius: 22px;
    background:
        linear-gradient(180deg, rgba(5, 5, 5, 0.84), rgba(2, 2, 2, 0.92)),
        radial-gradient(circle at 18% 50%, rgba(144, 34, 42, 0.08), transparent 30%);
    backdrop-filter: blur(18px);
}

.scenario-depth__top,
.scenario-depth__bottom {
    color: rgba(246, 240, 234, 0.58);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.scenario-depth__top strong,
.scenario-depth__bottom strong {
    color: rgba(248, 243, 236, 0.96);
    font-size: 15px;
    font-weight: 600;
}

.scenario-depth__track {
    height: 5px;
    border-radius: 999px;
    background: linear-gradient(90deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.08));
    box-shadow:
        inset 0 1px 1px rgba(255, 255, 255, 0.045),
        0 0 0 1px rgba(255, 255, 255, 0.02);
}

.scenario-depth__track span {
    background: linear-gradient(90deg, rgba(153, 40, 50, 0.96), rgba(213, 124, 130, 0.98), rgba(235, 220, 214, 0.84));
    box-shadow:
        0 0 18px rgba(184, 62, 70, 0.3),
        0 0 8px rgba(255, 221, 221, 0.16);
}

.scenario-next {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 0.82fr);
    gap: 28px;
    min-height: 220px;
    padding: 26px 28px;
    background:
        linear-gradient(180deg, rgba(12, 11, 11, 0.86), rgba(7, 7, 7, 0.99)),
        radial-gradient(circle at 74% 26%, rgba(175, 126, 79, 0.08), transparent 32%),
        radial-gradient(circle at 16% 74%, rgba(103, 26, 33, 0.12), transparent 28%);
}

.scenario-next::before {
    background:
        linear-gradient(90deg, transparent 57%, rgba(255, 255, 255, 0.035) 57%, rgba(255, 255, 255, 0.035) calc(57% + 1px), transparent calc(57% + 1px)),
        radial-gradient(circle at 57% 50%, rgba(171, 48, 56, 0.05), transparent 34%);
}

.scenario-next__copy {
    display: grid;
    gap: 8px;
    align-content: center;
    max-width: 520px;
}

.scenario-next h3 {
    max-width: 8.6ch;
    font-size: clamp(40px, 4.8vw, 58px);
    line-height: 0.9;
}

.scenario-next p {
    max-width: 24ch;
    color: rgba(246, 240, 234, 0.74);
    font-size: 15px;
    line-height: 1.48;
}

.scenario-next__shadow {
    width: max-content;
    max-width: 100%;
    padding: 10px 14px;
    border: 1px solid rgba(246, 240, 234, 0.08);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.025);
    color: rgba(246, 240, 234, 0.62);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.scenario-next__preview {
    display: grid;
    gap: 12px;
    align-content: center;
    justify-items: start;
    min-width: 0;
    padding-left: 26px;
    border-left: 1px solid rgba(246, 240, 234, 0.07);
}

.scenario-next__preview .eyebrow {
    color: rgba(217, 90, 96, 0.92);
}

.scenario-unlock-tile {
    width: 100%;
    max-width: 364px;
    grid-template-columns: 64px minmax(0, 1fr);
    gap: 16px;
    padding: 16px 18px;
    border: 1px solid rgba(194, 121, 69, 0.16);
    border-radius: 22px;
    background:
        linear-gradient(180deg, rgba(23, 16, 15, 0.94), rgba(9, 9, 9, 0.97)),
        radial-gradient(circle at 82% 18%, rgba(162, 54, 62, 0.12), transparent 28%);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.scenario-unlock-tile__icon {
    width: 58px;
    height: 58px;
    border-radius: 18px;
    color: rgba(250, 151, 139, 0.96);
    border-color: rgba(194, 121, 69, 0.18);
    background:
        linear-gradient(180deg, rgba(51, 24, 23, 0.92), rgba(17, 13, 13, 0.98)),
        radial-gradient(circle at 50% 50%, rgba(188, 58, 67, 0.14), transparent 54%);
}

.scenario-unlock-tile strong {
    font-size: 26px;
}

.scenario-unlock-tile p {
    color: rgba(246, 240, 234, 0.62);
    font-size: 13px;
}

.scenario-line-head {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 18px;
    padding: 2px 2px 8px;
}

.scenario-line-head p {
    max-width: 15ch;
    margin: 0;
    color: rgba(246, 240, 234, 0.5);
    font-size: 13px;
    line-height: 1.35;
    text-align: right;
}

.scenario-line {
    position: relative;
    z-index: 1;
    display: grid;
    gap: 22px;
    padding: 8px 0 6px;
    grid-template-columns: minmax(0, 1fr);
    overflow: visible;
}

.scenario-line::before {
    left: 50%;
    top: 28px;
    bottom: 28px;
    width: 1px;
    transform: translateX(-50%);
    background: linear-gradient(180deg, rgba(246, 240, 234, 0.08), rgba(182, 61, 70, 0.42) 22%, rgba(201, 161, 108, 0.3) 55%, rgba(246, 240, 234, 0.08));
    box-shadow: 0 0 28px rgba(166, 57, 65, 0.18);
}

.scenario-line::after {
    left: 50%;
    top: 28px;
    bottom: 28px;
    width: 10px;
    transform: translateX(-50%);
    background: linear-gradient(180deg, rgba(194, 121, 69, 0.08), rgba(194, 121, 69, 0.16) 46%, rgba(194, 121, 69, 0.06));
    filter: blur(12px);
    opacity: 0.8;
}

.scenario-level-row {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1.16fr) 96px minmax(300px, 0.92fr);
    align-items: center;
    gap: 0;
}

.scenario-level-card {
    grid-column: 1 / 2;
    position: relative;
    justify-self: start;
    width: min(100%, 568px);
    padding-right: 48px;
}

.scenario-level-card::before {
    left: auto;
    right: 0;
    top: 50%;
    width: 48px;
    height: 1px;
    transform: translateY(-50%);
    background: linear-gradient(90deg, rgba(194, 121, 69, 0.1), rgba(246, 240, 234, 0.14));
}

.scenario-level-card__node {
    left: auto;
    right: -48px;
    top: 50%;
    width: 30px;
    height: 30px;
    transform: translate(50%, -50%);
    border-color: rgba(194, 121, 69, 0.18);
    background: radial-gradient(circle, rgba(82, 63, 49, 0.34), rgba(7, 7, 7, 0.98) 70%);
    box-shadow: 0 0 18px rgba(0, 0, 0, 0.22);
}

.scenario-level-card__node::before {
    width: 46px;
    height: 46px;
    border-color: rgba(246, 240, 234, 0.08);
}

.scenario-level-card__node::after {
    width: 14px;
    height: 14px;
    background: radial-gradient(circle, rgba(246, 240, 234, 0.42), rgba(33, 27, 23, 0.8) 72%);
}

.scenario-level-card__body {
    min-height: 154px;
    padding: 18px 18px 16px;
    border-radius: 24px;
    border-color: rgba(194, 121, 69, 0.12);
    background:
        linear-gradient(180deg, rgba(18, 16, 16, 0.96), rgba(8, 8, 8, 0.985)),
        radial-gradient(circle at 86% 14%, rgba(143, 32, 41, 0.09), transparent 34%);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.03),
        0 12px 28px rgba(0, 0, 0, 0.12);
}

.scenario-level-card__veil {
    right: -8px;
    bottom: -18px;
    color: rgba(246, 240, 234, 0.045);
    font-size: 112px;
    line-height: 1;
}

.scenario-level-card__roman {
    width: 52px;
    height: 52px;
    border-color: rgba(194, 121, 69, 0.16);
    color: rgba(246, 240, 234, 0.84);
    font-size: 32px;
}

.scenario-level-card strong {
    max-width: 10ch;
    font-size: 27px;
    line-height: 0.94;
}

.scenario-level-card p {
    max-width: 31ch;
    color: rgba(246, 240, 234, 0.66);
    font-size: 14px;
    line-height: 1.42;
}

.scenario-level-card small {
    padding: 7px 10px;
    border: 1px solid rgba(194, 121, 69, 0.12);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.02);
    color: rgba(246, 240, 234, 0.56);
    font-size: 10px;
}

.scenario-level-unlocks {
    grid-column: 3 / 4;
    position: relative;
    justify-self: start;
    width: min(100%, 520px);
    min-height: 148px;
    margin-top: 0;
    padding: 18px 18px 16px;
    border: 1px solid rgba(194, 121, 69, 0.11);
    border-radius: 24px;
    background:
        linear-gradient(180deg, rgba(14, 13, 13, 0.76), rgba(7, 7, 7, 0.94)),
        radial-gradient(circle at 12% 22%, rgba(194, 121, 69, 0.035), transparent 24%),
        radial-gradient(circle at 82% 62%, rgba(255, 255, 255, 0.018), transparent 20%);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.024);
}

.scenario-level-unlocks::before {
    left: -48px;
    top: 50%;
    width: 48px;
    height: 1px;
    transform: translateY(-50%);
    background: linear-gradient(90deg, rgba(246, 240, 234, 0.12), rgba(194, 121, 69, 0.14));
}

.scenario-level-unlocks__label {
    color: rgba(246, 240, 234, 0.52);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.scenario-level-unlocks__items {
    gap: 10px;
}

.scenario-unlock-chip {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    min-height: 48px;
    padding: 10px 14px 10px 10px;
    border: 1px solid rgba(194, 121, 69, 0.1);
    border-radius: 16px;
    background:
        linear-gradient(180deg, rgba(28, 22, 20, 0.72), rgba(10, 10, 10, 0.86)),
        rgba(255, 255, 255, 0.016);
    color: rgba(246, 240, 234, 0.78);
    font-size: 14px;
    line-height: 1.25;
}

.scenario-icon {
    width: 32px;
    height: 32px;
    border-radius: 11px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    overflow: hidden;
}

.scenario-icon__image {
    width: 18px;
    height: 18px;
    display: block;
    object-fit: contain;
}

.scenario-level-row--opened .scenario-level-card__body,
.scenario-level-row--opened .scenario-level-unlocks {
    border-color: rgba(95, 136, 88, 0.18);
    background:
        linear-gradient(180deg, rgba(14, 18, 14, 0.96), rgba(8, 10, 8, 0.985)),
        radial-gradient(circle at 12% 22%, rgba(88, 132, 84, 0.09), transparent 30%);
    box-shadow: 0 0 24px rgba(88, 132, 84, 0.06), inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.scenario-level-row--opened .scenario-level-card__roman,
.scenario-level-row--opened .scenario-level-card__node {
    border-color: rgba(112, 156, 105, 0.24);
    color: rgba(215, 228, 205, 0.92);
    background: radial-gradient(circle, rgba(79, 120, 74, 0.38), rgba(12, 14, 12, 0.96) 72%);
    box-shadow: 0 0 16px rgba(88, 132, 84, 0.14);
}

.scenario-level-row--opened .scenario-level-card::before,
.scenario-level-row--opened .scenario-level-unlocks::before {
    background: linear-gradient(90deg, rgba(86, 126, 80, 0.24), rgba(246, 240, 234, 0.1));
}

.scenario-level-row--opened .scenario-unlock-chip {
    border-color: rgba(95, 136, 88, 0.12);
    color: rgba(219, 228, 214, 0.84);
}

.scenario-level-row.is-current .scenario-level-card__body,
.scenario-level-row.is-current .scenario-level-unlocks {
    border-color: rgba(177, 70, 77, 0.28);
    background:
        linear-gradient(180deg, rgba(24, 15, 16, 0.98), rgba(8, 8, 8, 0.985)),
        radial-gradient(circle at 78% 16%, rgba(165, 47, 57, 0.18), transparent 34%),
        radial-gradient(circle at 16% 24%, rgba(183, 120, 75, 0.04), transparent 30%);
    box-shadow:
        0 0 34px rgba(143, 32, 41, 0.12),
        inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

.scenario-level-row.is-current .scenario-level-card__roman,
.scenario-level-row.is-current .scenario-level-card__node {
    border-color: rgba(221, 121, 128, 0.34);
    color: rgba(255, 233, 233, 0.96);
    background: radial-gradient(circle, rgba(182, 63, 72, 0.56), rgba(87, 28, 33, 0.46) 42%, rgba(8, 8, 8, 0.96) 74%);
    box-shadow: 0 0 20px rgba(177, 70, 77, 0.24);
}

.scenario-level-row.is-current .scenario-level-card::before,
.scenario-level-row.is-current .scenario-level-unlocks::before {
    background: linear-gradient(90deg, rgba(177, 70, 77, 0.28), rgba(246, 240, 234, 0.12));
}

.scenario-level-row.is-current .scenario-unlock-chip {
    border-color: rgba(177, 70, 77, 0.14);
    color: rgba(246, 237, 236, 0.86);
}

.scenario-level-row--locked .scenario-level-card__body,
.scenario-level-row--locked .scenario-level-unlocks {
    border-color: rgba(129, 85, 62, 0.11);
    background:
        linear-gradient(180deg, rgba(17, 14, 14, 0.94), rgba(8, 8, 8, 0.975)),
        radial-gradient(circle at 82% 16%, rgba(123, 78, 57, 0.07), transparent 30%),
        radial-gradient(circle at 18% 72%, rgba(255, 255, 255, 0.014), transparent 20%);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.02);
}

.scenario-level-row--locked .scenario-level-card__node,
.scenario-level-row--locked .scenario-level-card__roman {
    color: rgba(201, 178, 168, 0.74);
    border-color: rgba(139, 93, 67, 0.16);
    background: radial-gradient(circle, rgba(114, 74, 58, 0.28), rgba(8, 8, 8, 0.96) 70%);
}

.scenario-level-row--locked .scenario-level-card strong,
.scenario-level-row--locked .scenario-unlock-chip {
    color: rgba(208, 190, 182, 0.82);
}

.scenario-level-row--locked .scenario-level-card p,
.scenario-level-row--locked .scenario-level-unlocks__label {
    color: rgba(188, 168, 161, 0.58);
}

.scenario-level-row--locked .scenario-level-card::before,
.scenario-level-row--locked .scenario-level-unlocks::before {
    background: linear-gradient(90deg, rgba(139, 93, 67, 0.14), rgba(246, 240, 234, 0.06));
}

@media (min-width: 761px) and (max-width: 1040px) {
    .scenario-current {
        grid-template-columns: minmax(0, 1fr) 190px;
        grid-template-areas:
            "copy aside"
            "sigil sigil"
            "depth depth";
        min-height: 0;
    }

    .scenario-next {
        grid-template-columns: minmax(0, 1fr);
        min-height: 0;
    }

    .scenario-next__preview {
        padding-left: 0;
        padding-top: 18px;
        border-left: 0;
        border-top: 1px solid rgba(246, 240, 234, 0.07);
    }

    .scenario-level-row {
        grid-template-columns: minmax(0, 1fr) 72px minmax(280px, 0.9fr);
    }

    .scenario-level-card {
        width: min(100%, 484px);
        padding-right: 36px;
    }

    .scenario-level-card::before {
        right: 0;
        width: 36px;
    }

    .scenario-level-card__node {
        right: -36px;
    }

    .scenario-level-unlocks {
        width: min(100%, 420px);
    }

    .scenario-level-unlocks::before {
        left: -36px;
        width: 36px;
    }
}

@media (max-width: 760px) {
    .scenario-progression {
        gap: 16px;
        padding: 18px 16px 22px;
        border-radius: 28px;
    }

    .scenario-progression__header h2 {
        max-width: 6.1ch;
        font-size: clamp(46px, 12vw, 62px);
    }

    .scenario-current {
        grid-template-columns: minmax(0, 1fr);
        grid-template-areas:
            "sigil"
            "copy"
            "aside"
            "depth";
        gap: 18px;
        min-height: 0;
        padding: 18px 16px 18px;
    }

    .scenario-current::after {
        display: none;
    }

    .scenario-current__copy {
        max-width: none;
    }

    .scenario-current h2 {
        font-size: clamp(38px, 10vw, 48px);
    }

    .scenario-current p {
        max-width: 20ch;
        font-size: 14px;
    }

    .scenario-current__sigil {
        width: 156px;
        height: 156px;
    }

    .scenario-current__sigil::before {
        inset: -14px;
    }

    .scenario-current__aside {
        justify-self: start;
        min-width: 0;
        width: 100%;
        max-width: 262px;
    }

    .scenario-current__aside::before {
        display: none;
    }

    .scenario-depth {
        padding: 14px;
    }

    .scenario-next {
        grid-template-columns: minmax(0, 1fr);
        gap: 18px;
        min-height: 0;
        padding: 18px 16px 18px;
    }

    .scenario-next h3 {
        font-size: clamp(34px, 9vw, 42px);
    }

    .scenario-next p {
        font-size: 14px;
    }

    .scenario-next__preview {
        width: 100%;
        padding-left: 0;
        padding-top: 16px;
        border-left: 0;
        border-top: 1px solid rgba(246, 240, 234, 0.07);
    }

    .scenario-unlock-tile {
        max-width: none;
        grid-template-columns: 54px minmax(0, 1fr);
        gap: 14px;
        padding: 14px;
    }

    .scenario-unlock-tile__icon {
        width: 50px;
        height: 50px;
        border-radius: 16px;
    }

    .scenario-unlock-tile strong {
        font-size: 22px;
    }

    .scenario-line-head {
        align-items: start;
    }

    .scenario-line-head p {
        max-width: 14ch;
        font-size: 12px;
    }

    .scenario-line {
        gap: 16px;
        padding: 4px 0 0;
    }

    .scenario-line::before {
        left: 18px;
        top: 20px;
        bottom: 20px;
        transform: none;
    }

    .scenario-line::after {
        left: 15px;
        top: 20px;
        bottom: 20px;
        transform: none;
    }

    .scenario-level-row {
        grid-template-columns: 36px minmax(0, 1fr);
        gap: 0 12px;
    }

    .scenario-level-card,
    .scenario-level-unlocks {
        grid-column: 2 / 3;
        width: 100%;
        max-width: none;
    }

    .scenario-level-card {
        padding-right: 0;
    }

    .scenario-level-card::before {
        left: -18px;
        right: auto;
        width: 18px;
    }

    .scenario-level-card__node {
        left: -18px;
        right: auto;
        width: 26px;
        height: 26px;
        transform: translate(-50%, -50%);
    }

    .scenario-level-card__body {
        min-height: 138px;
        padding: 16px 14px 14px;
        grid-template-columns: 48px minmax(0, 1fr);
    }

    .scenario-level-card__roman {
        width: 46px;
        height: 46px;
        font-size: 28px;
    }

    .scenario-level-card strong {
        font-size: 23px;
    }

    .scenario-level-card p {
        font-size: 13px;
    }

    .scenario-level-card__veil {
        font-size: 88px;
    }

    .scenario-level-unlocks {
        min-height: 0;
        margin-top: 8px;
        padding: 14px;
    }

    .scenario-level-unlocks::before {
        left: -18px;
        width: 18px;
    }

    .scenario-unlock-chip {
        min-height: 46px;
        font-size: 13px;
    }
}

/* Scenario progression: correction pass */
.scenario-unlock-tile {
    max-width: 430px;
    min-height: 108px;
    grid-template-columns: 72px minmax(0, 1fr);
    gap: 18px;
    padding: 20px 22px;
}

.scenario-unlock-tile__icon {
    width: 64px;
    height: 64px;
    border-radius: 20px;
}

.scenario-unlock-tile strong {
    font-size: 30px;
}

.scenario-unlock-tile p {
    font-size: 14px;
    line-height: 1.42;
}

.scenario-line::before {
    z-index: 0;
    width: 2px;
    background:
        linear-gradient(180deg,
            rgba(246, 240, 234, 0.1),
            rgba(181, 60, 69, 0.52) 18%,
            rgba(201, 161, 108, 0.38) 52%,
            rgba(246, 240, 234, 0.09));
    box-shadow:
        0 0 18px rgba(181, 60, 69, 0.18),
        0 0 42px rgba(194, 121, 69, 0.1);
}

.scenario-line::after {
    z-index: 0;
    width: 14px;
    background: linear-gradient(180deg, rgba(194, 121, 69, 0.12), rgba(194, 121, 69, 0.2) 46%, rgba(194, 121, 69, 0.08));
    filter: blur(14px);
    opacity: 0.95;
}

.scenario-level-row::before,
.scenario-level-row::after {
    content: "";
    position: absolute;
    top: 50%;
    left: calc(50% + 1px);
    transform: translate(-50%, -50%);
    border-radius: 50%;
    pointer-events: none;
}

.scenario-level-row::before {
    z-index: 1;
    width: 30px;
    height: 30px;
    border: 1px solid rgba(194, 121, 69, 0.22);
    background: radial-gradient(circle, rgba(248, 242, 235, 0.22), rgba(68, 46, 35, 0.52) 42%, rgba(10, 10, 10, 0.96) 74%);
    box-shadow:
        0 0 16px rgba(194, 121, 69, 0.16),
        inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.scenario-level-row::after {
    z-index: 0;
    width: 56px;
    height: 56px;
    border: 1px solid rgba(246, 240, 234, 0.06);
    box-shadow: 0 0 26px rgba(194, 121, 69, 0.08);
}

.scenario-level-card,
.scenario-level-card--opened,
.scenario-level-card--current,
.scenario-level-card--locked {
    width: min(100%, 568px);
}

.scenario-level-card__body,
.scenario-level-card--current .scenario-level-card__body,
.scenario-level-row.is-current .scenario-level-card__body,
.scenario-level-row--current .scenario-level-card__body {
    min-height: 154px;
}

.scenario-level-card__body,
.scenario-level-card--locked .scenario-level-card__body,
.scenario-level-row--locked .scenario-level-card__body {
    mask-image: none;
    -webkit-mask-image: none;
    max-height: none;
}

.scenario-level-card strong,
.scenario-level-card p,
.scenario-level-card small,
.scenario-unlock-chip span:last-child,
.scenario-unlock-tile strong,
.scenario-unlock-tile p {
    overflow: visible;
    text-overflow: clip;
    white-space: normal;
    word-break: normal;
    overflow-wrap: anywhere;
}

.scenario-level-card p {
    max-width: 34ch;
}

.scenario-level-row--opened::before {
    border-color: rgba(112, 156, 105, 0.3);
    background: radial-gradient(circle, rgba(196, 224, 183, 0.34), rgba(78, 119, 73, 0.5) 42%, rgba(8, 10, 8, 0.96) 74%);
    box-shadow: 0 0 18px rgba(88, 132, 84, 0.2);
}

.scenario-level-row--opened::after {
    border-color: rgba(112, 156, 105, 0.1);
    box-shadow: 0 0 28px rgba(88, 132, 84, 0.08);
}

.scenario-level-row.is-current::before,
.scenario-level-row--current::before {
    border-color: rgba(232, 137, 142, 0.46);
    background: radial-gradient(circle, rgba(255, 229, 230, 0.58), rgba(188, 64, 73, 0.76) 38%, rgba(86, 28, 33, 0.54) 58%, rgba(8, 8, 8, 0.96) 76%);
    box-shadow:
        0 0 20px rgba(188, 64, 73, 0.34),
        0 0 40px rgba(188, 64, 73, 0.14);
}

.scenario-level-row.is-current::after,
.scenario-level-row--current::after {
    border-color: rgba(232, 137, 142, 0.12);
    box-shadow: 0 0 32px rgba(188, 64, 73, 0.12);
}

.scenario-level-row--locked::before {
    border-color: rgba(164, 121, 97, 0.2);
    background: radial-gradient(circle, rgba(228, 210, 200, 0.18), rgba(95, 68, 53, 0.42) 42%, rgba(8, 8, 8, 0.96) 76%);
}

.scenario-level-row--locked::after {
    border-color: rgba(164, 121, 97, 0.08);
}

@media (max-width: 760px) {
    .scenario-unlock-tile {
        max-width: none;
        min-height: 96px;
        grid-template-columns: 58px minmax(0, 1fr);
        gap: 14px;
        padding: 16px;
    }

    .scenario-unlock-tile__icon {
        width: 54px;
        height: 54px;
        border-radius: 18px;
    }

    .scenario-unlock-tile strong {
        font-size: 24px;
    }

    .scenario-unlock-tile p {
        font-size: 13px;
    }

    .scenario-level-row::before {
        left: 18px;
        width: 26px;
        height: 26px;
    }

    .scenario-level-row::after {
        left: 18px;
        width: 46px;
        height: 46px;
    }
}

/* Scenario progression: alignment and width corrections */
.scenario-line {
    --scenario-axis-x: 50%;
}

.scenario-next__copy {
    max-width: 560px;
}

.scenario-next p {
    max-width: 34ch;
}

.scenario-line::before,
.scenario-line::after {
    left: var(--scenario-axis-x);
}

.scenario-level-row {
    grid-template-columns: 568px 96px 520px;
    justify-content: space-between;
}

.scenario-level-row::before,
.scenario-level-row::after {
    left: var(--scenario-axis-x);
}

.scenario-level-card,
.scenario-level-card--opened,
.scenario-level-card--current,
.scenario-level-card--locked {
    width: 100%;
    max-width: none;
}

.scenario-level-card__body {
    width: 100%;
}

@media (min-width: 761px) and (max-width: 1240px) {
    .scenario-level-row {
        grid-template-columns: minmax(420px, 1fr) 82px minmax(300px, 0.92fr);
        justify-content: stretch;
    }

    .scenario-level-card,
    .scenario-level-unlocks {
        width: 100%;
    }
}

@media (max-width: 760px) {
    .scenario-line {
        --scenario-axis-x: 18px;
    }

    .scenario-next p {
        max-width: 26ch;
    }

    .scenario-level-row {
        grid-template-columns: 36px minmax(0, 1fr);
        justify-content: stretch;
    }
}

/* Scenario progression: hard desktop alignment override */
body[data-page="vybor-home"] .scenario-next {
    grid-template-columns: minmax(0, 1.14fr) minmax(280px, 0.86fr) !important;
}

body[data-page="vybor-home"] .scenario-next__copy {
    max-width: none !important;
}

body[data-page="vybor-home"] .scenario-next p {
    width: min(100%, 34ch) !important;
    max-width: none !important;
}

body[data-page="vybor-home"] .scenario-line {
    --scenario-axis-x: 50%;
}

body[data-page="vybor-home"] .scenario-level-row {
    grid-template-columns: minmax(0, 1fr) 88px minmax(0, 1fr) !important;
    justify-content: stretch !important;
}

body[data-page="vybor-home"] .scenario-line::before,
body[data-page="vybor-home"] .scenario-line::after,
body[data-page="vybor-home"] .scenario-level-row::before,
body[data-page="vybor-home"] .scenario-level-row::after {
    left: var(--scenario-axis-x) !important;
}

body[data-page="vybor-home"] .scenario-level-card {
    width: 100% !important;
    max-width: none !important;
    justify-self: stretch !important;
    padding-right: 44px !important;
}

body[data-page="vybor-home"] .scenario-level-card::before {
    right: 0 !important;
    width: 44px !important;
}

body[data-page="vybor-home"] .scenario-level-card__node {
    right: -44px !important;
}

body[data-page="vybor-home"] .scenario-level-card__body {
    width: 100% !important;
    min-height: 154px !important;
}

body[data-page="vybor-home"] .scenario-level-unlocks {
    width: 100% !important;
    max-width: 430px !important;
    justify-self: start !important;
}

body[data-page="vybor-home"] .scenario-level-unlocks::before {
    left: -44px !important;
    width: 44px !important;
}

@media (max-width: 760px) {
    body[data-page="vybor-home"] .scenario-next {
        grid-template-columns: minmax(0, 1fr) !important;
    }

    body[data-page="vybor-home"] .scenario-next p {
        width: min(100%, 26ch) !important;
    }

    body[data-page="vybor-home"] .scenario-line {
        --scenario-axis-x: 18px;
    }

    body[data-page="vybor-home"] .scenario-level-row {
        grid-template-columns: 36px minmax(0, 1fr) !important;
    }

    body[data-page="vybor-home"] .scenario-level-card {
        padding-right: 0 !important;
    }

    body[data-page="vybor-home"] .scenario-level-card::before {
        left: -18px !important;
        right: auto !important;
        width: 18px !important;
    }

    body[data-page="vybor-home"] .scenario-level-card__node {
        left: -18px !important;
        right: auto !important;
    }

    body[data-page="vybor-home"] .scenario-level-unlocks::before {
        left: -18px !important;
        width: 18px !important;
    }
}

/* Scenario progression: screenshot-based final corrections */
body[data-page="vybor-home"] .scenario-next {
    grid-template-columns: minmax(0, 1.32fr) minmax(320px, 0.68fr) !important;
}

body[data-page="vybor-home"] .scenario-next h3 {
    max-width: 11ch !important;
}

body[data-page="vybor-home"] .scenario-next p {
    width: min(100%, 42ch) !important;
    max-width: none !important;
}

body[data-page="vybor-home"] .scenario-next::before {
    background:
        linear-gradient(90deg, transparent 63%, rgba(255, 255, 255, 0.035) 63%, rgba(255, 255, 255, 0.035) calc(63% + 1px), transparent calc(63% + 1px)),
        radial-gradient(circle at 63% 50%, rgba(171, 48, 56, 0.05), transparent 34%) !important;
}

body[data-page="vybor-home"] .scenario-next__preview {
    padding-left: 30px !important;
}

body[data-page="vybor-home"] .scenario-level-card__node {
    opacity: 0 !important;
    border-color: transparent !important;
    background: transparent !important;
    box-shadow: none !important;
}

body[data-page="vybor-home"] .scenario-level-card__node::before,
body[data-page="vybor-home"] .scenario-level-card__node::after {
    opacity: 0 !important;
}

@media (max-width: 760px) {
    body[data-page="vybor-home"] .scenario-next {
        grid-template-columns: minmax(0, 1fr) !important;
    }

    body[data-page="vybor-home"] .scenario-next h3 {
        max-width: 9.5ch !important;
    }

    body[data-page="vybor-home"] .scenario-next p {
        width: min(100%, 28ch) !important;
    }

    body[data-page="vybor-home"] .scenario-next::before {
        background:
            linear-gradient(90deg, transparent 100%, transparent 100%),
            radial-gradient(circle at 50% 50%, rgba(171, 48, 56, 0.05), transparent 34%) !important;
    }
}

/* Scenario progression: wider next-level copy + visible centered spheres */
body[data-page="vybor-home"] .scenario-next {
    grid-template-columns: minmax(0, 1.44fr) minmax(292px, 0.56fr) !important;
}

body[data-page="vybor-home"] .scenario-next h3 {
    max-width: 12ch !important;
}

body[data-page="vybor-home"] .scenario-next p {
    width: min(100%, 48ch) !important;
}

body[data-page="vybor-home"] .scenario-level-row {
    position: relative;
}

body[data-page="vybor-home"] .scenario-line::before,
body[data-page="vybor-home"] .scenario-line::after {
    z-index: 1 !important;
}

body[data-page="vybor-home"] .scenario-level-card,
body[data-page="vybor-home"] .scenario-level-unlocks {
    position: relative;
    z-index: 2;
}

body[data-page="vybor-home"] .scenario-level-row::before,
body[data-page="vybor-home"] .scenario-level-row::after {
    content: "";
    position: absolute;
    left: var(--scenario-axis-x) !important;
    top: 50%;
    transform: translate(-50%, -50%);
    border-radius: 50%;
    pointer-events: none;
}

body[data-page="vybor-home"] .scenario-level-row::before {
    z-index: 4;
    width: 28px;
    height: 28px;
    border: 1px solid rgba(194, 121, 69, 0.24);
    background: radial-gradient(circle, rgba(247, 240, 232, 0.42), rgba(74, 54, 42, 0.56) 36%, rgba(9, 9, 9, 0.98) 72%);
    box-shadow:
        0 0 18px rgba(194, 121, 69, 0.16),
        inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

body[data-page="vybor-home"] .scenario-level-row::after {
    z-index: 3;
    width: 52px;
    height: 52px;
    border: 1px solid rgba(246, 240, 234, 0.08);
    box-shadow: 0 0 24px rgba(194, 121, 69, 0.08);
}

body[data-page="vybor-home"] .scenario-level-row--opened::before {
    border-color: rgba(112, 156, 105, 0.32);
    background: radial-gradient(circle, rgba(213, 232, 201, 0.52), rgba(83, 126, 77, 0.58) 38%, rgba(9, 10, 9, 0.98) 72%);
    box-shadow: 0 0 18px rgba(88, 132, 84, 0.22);
}

body[data-page="vybor-home"] .scenario-level-row--opened::after {
    border-color: rgba(112, 156, 105, 0.1);
    box-shadow: 0 0 28px rgba(88, 132, 84, 0.08);
}

body[data-page="vybor-home"] .scenario-level-row.is-current::before,
body[data-page="vybor-home"] .scenario-level-row--current::before {
    border-color: rgba(232, 137, 142, 0.46);
    background: radial-gradient(circle, rgba(255, 239, 240, 0.72), rgba(194, 68, 78, 0.82) 34%, rgba(96, 29, 35, 0.56) 56%, rgba(9, 9, 9, 0.98) 74%);
    box-shadow:
        0 0 20px rgba(188, 64, 73, 0.34),
        0 0 42px rgba(188, 64, 73, 0.14);
}

body[data-page="vybor-home"] .scenario-level-row.is-current::after,
body[data-page="vybor-home"] .scenario-level-row--current::after {
    border-color: rgba(232, 137, 142, 0.12);
    box-shadow: 0 0 32px rgba(188, 64, 73, 0.12);
}

body[data-page="vybor-home"] .scenario-level-row--locked::before {
    border-color: rgba(164, 121, 97, 0.22);
    background: radial-gradient(circle, rgba(228, 210, 200, 0.24), rgba(95, 68, 53, 0.46) 38%, rgba(9, 9, 9, 0.98) 72%);
}

body[data-page="vybor-home"] .scenario-level-row--locked::after {
    border-color: rgba(164, 121, 97, 0.08);
}

@media (max-width: 760px) {
    body[data-page="vybor-home"] .scenario-next {
        grid-template-columns: minmax(0, 1fr) !important;
    }

    body[data-page="vybor-home"] .scenario-next p {
        width: min(100%, 30ch) !important;
    }

    body[data-page="vybor-home"] .scenario-level-row::before {
        width: 24px;
        height: 24px;
    }

    body[data-page="vybor-home"] .scenario-level-row::after {
        width: 42px;
        height: 42px;
    }
}

.choice-modes {
    position: relative;
    width: 100%;
    padding: 0 var(--gutter);
    display: grid;
    gap: 28px;
}

.choice-modes__header {
    display: grid;
    gap: 8px;
    max-width: 38ch;
}

.choice-modes__header h2 {
    margin: 0;
    color: var(--text);
    font-family: "Cormorant Garamond", serif;
    font-size: clamp(42px, 5.4vw, 68px);
    font-weight: 600;
    line-height: 0.92;
    letter-spacing: 0;
}

.choice-modes__header p {
    margin: 0;
    color: rgba(246, 240, 234, 0.7);
    font-size: 17px;
    line-height: 1.5;
}

.choice-modes__group {
    display: grid;
    gap: 18px;
}

.choice-modes__group-head {
    display: flex;
    align-items: flex-start;
    gap: 14px;
}

.choice-modes__group-head h3,
.choice-modes__footer-copy strong {
    margin: 0;
    font-size: 15px;
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.choice-modes__group-head p,
.choice-modes__footer-copy p {
    margin: 6px 0 0;
    color: rgba(246, 240, 234, 0.56);
    font-size: 15px;
    line-height: 1.45;
}

.choice-modes__group-mark,
.choice-modes__footer-mark {
    flex: 0 0 auto;
    width: 28px;
    height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.choice-modes__group-mark svg,
.choice-modes__footer-mark svg {
    width: 100%;
    height: 100%;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 1.25;
}

.choice-modes__group-mark--open {
    color: #8fb47f;
    filter: drop-shadow(0 0 12px rgba(118, 166, 107, 0.26));
}

.choice-modes__group-mark--locked {
    color: #d6a66e;
    filter: drop-shadow(0 0 14px rgba(184, 126, 63, 0.24));
}

.choice-modes__group-head--locked {
    padding-top: 2px;
    border-top: 1px solid rgba(177, 130, 77, 0.28);
}

.choice-modes__group-head--locked > div {
    padding-top: 14px;
}

.choice-modes__group-title-line {
    display: flex;
    align-items: center;
    gap: 10px;
}

.choice-modes__inline-lock {
    width: 18px;
    height: 18px;
    color: rgba(214, 166, 110, 0.88);
}

.choice-modes__inline-lock svg,
.choice-journey__lock svg,
.choice-journey__unlock-icon svg,
.choice-open-card__sigil svg {
    width: 100%;
    height: 100%;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 1.5;
}

.choice-open-card__sigil-image {
    width: 100%;
    height: 100%;
    padding: 11px;
    box-sizing: border-box;
    display: block;
    object-fit: contain;
    filter: drop-shadow(0 0 10px rgba(88, 132, 84, 0.18));
}

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

.choice-open-card {
    position: relative;
    min-height: 168px;
    display: grid;
    gap: 14px;
    align-content: start;
    padding: 22px 18px 18px;
    overflow: hidden;
    border: 1px solid rgba(112, 156, 105, 0.28);
    border-radius: 22px;
    background:
        radial-gradient(circle at 18% 18%, rgba(95, 137, 88, 0.16), transparent 24%),
        radial-gradient(circle at 88% 82%, rgba(95, 137, 88, 0.08), transparent 22%),
        linear-gradient(180deg, rgba(12, 17, 12, 0.98), rgba(7, 10, 8, 0.98));
    box-shadow:
        inset 0 1px 0 rgba(215, 239, 206, 0.06),
        0 14px 42px rgba(0, 0, 0, 0.28),
        0 0 22px rgba(88, 132, 84, 0.08);
    color: inherit;
    text-decoration: none;
    isolation: isolate;
    transition: transform 220ms ease, border-color 220ms ease, box-shadow 220ms ease;
}

.choice-open-card::before,
.choice-open-card::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.choice-open-card::before {
    background:
        radial-gradient(circle at 84% 78%, rgba(112, 156, 105, 0.12), transparent 0 34px, rgba(112, 156, 105, 0.08) 34px 35px, transparent 35px),
        radial-gradient(circle at 84% 78%, transparent 0 8px, rgba(112, 156, 105, 0.1) 8px 9px, transparent 9px),
        linear-gradient(135deg, rgba(255, 255, 255, 0.025), transparent 35%);
    opacity: 0.72;
}

.choice-open-card::after {
    inset: auto 14px 14px auto;
    width: 110px;
    height: 110px;
    background:
        radial-gradient(circle at center, rgba(112, 156, 105, 0.06), transparent 56%),
        linear-gradient(90deg, transparent 49.4%, rgba(112, 156, 105, 0.08) 49.4% 50.6%, transparent 50.6%),
        linear-gradient(180deg, transparent 49.4%, rgba(112, 156, 105, 0.08) 49.4% 50.6%, transparent 50.6%);
    opacity: 0.6;
}

.choice-open-card__sigil {
    position: relative;
    width: 54px;
    height: 54px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    flex-shrink: 0;
    border: 1px solid rgba(122, 170, 114, 0.3);
    border-radius: 50%;
    color: #a6d592;
    background: radial-gradient(circle, rgba(112, 156, 105, 0.16), rgba(7, 10, 8, 0.98) 68%);
    box-shadow: inset 0 1px 0 rgba(216, 241, 208, 0.08), 0 0 24px rgba(88, 132, 84, 0.14);
}

.choice-open-card strong,
.choice-journey__copy strong,
.choice-journey__unlock-copy strong {
    display: block;
    margin: 0;
    color: var(--text);
    font-family: "Cormorant Garamond", serif;
    font-weight: 600;
    line-height: 0.98;
    letter-spacing: 0;
}

.choice-open-card strong {
    font-size: 27px;
}

.choice-open-card p,
.choice-journey__copy p,
.choice-journey__unlock-copy p {
    margin: 0;
    color: rgba(246, 240, 234, 0.76);
    font-size: 14px;
    line-height: 1.45;
}

.choice-open-card__state {
    position: relative;
    z-index: 1;
    width: max-content;
    min-height: 34px;
    display: inline-flex;
    align-items: center;
    padding: 0 14px;
    margin-top: 4px;
    border: 1px solid rgba(111, 161, 99, 0.28);
    border-radius: 999px;
    background: rgba(41, 58, 39, 0.44);
    color: #92c77f;
    font-size: 13px;
    font-weight: 600;
    line-height: 1;
}

.choice-journey {
    position: relative;
    display: grid;
    gap: 12px;
    padding-left: 42px;
}

.choice-journey::before {
    content: "";
    position: absolute;
    left: 13px;
    top: 10px;
    bottom: 10px;
    width: 1px;
    background: linear-gradient(180deg, rgba(214, 166, 110, 0.72), rgba(214, 166, 110, 0.16));
    box-shadow: 0 0 18px rgba(214, 166, 110, 0.18);
}

.choice-journey__row {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(0, 1fr) 150px 68px;
    align-items: center;
    gap: 22px;
    padding: 20px 22px 20px 24px;
    overflow: hidden;
    border: 1px solid rgba(161, 118, 69, 0.2);
    border-radius: 24px;
    background:
        radial-gradient(circle at 14% 50%, rgba(115, 70, 38, 0.12), transparent 20%),
        radial-gradient(circle at 84% 20%, rgba(173, 125, 74, 0.08), transparent 26%),
        linear-gradient(180deg, rgba(18, 14, 12, 0.98), rgba(12, 10, 9, 0.98));
    box-shadow:
        inset 0 1px 0 rgba(255, 240, 222, 0.05),
        0 18px 38px rgba(0, 0, 0, 0.24);
}

.choice-journey__row::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: linear-gradient(90deg, transparent 39%, rgba(214, 166, 110, 0.08) 39% 39.2%, transparent 39.2%);
    opacity: 0.72;
}

.choice-journey__row--multi {
    align-items: start;
}

.choice-journey__node {
    position: absolute;
    left: -42px;
    top: 50%;
    transform: translateY(-50%);
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1;
}

.choice-journey__node span {
    position: relative;
    width: 28px;
    height: 28px;
    display: block;
    border: 1px solid rgba(214, 166, 110, 0.42);
    border-radius: 50%;
    background: radial-gradient(circle, rgba(255, 238, 215, 0.68), rgba(161, 118, 69, 0.56) 34%, rgba(10, 9, 8, 0.98) 72%);
    box-shadow: 0 0 16px rgba(184, 126, 63, 0.22);
}

.choice-journey__node span::before {
    content: "";
    position: absolute;
    inset: 50% auto auto 50%;
    width: 52px;
    height: 52px;
    border: 1px solid rgba(214, 166, 110, 0.14);
    border-radius: 50%;
    transform: translate(-50%, -50%);
}

.choice-journey__level {
    display: grid;
    grid-template-columns: 74px minmax(0, 1fr);
    gap: 18px;
    align-items: center;
    min-width: 0;
}

.choice-level-pill {
    width: 62px;
    height: 62px;
    display: grid;
    place-items: center;
    border: 1px solid rgba(168, 124, 72, 0.42);
    border-radius: 50%;
    color: #e0b274;
    font-family: "Cormorant Garamond", serif;
    font-size: 28px;
    font-weight: 600;
    line-height: 1;
    background: radial-gradient(circle, rgba(93, 61, 35, 0.28), rgba(12, 10, 9, 0.98) 72%);
    box-shadow: inset 0 1px 0 rgba(255, 240, 222, 0.06);
}

.choice-journey__copy strong,
.choice-journey__unlock-copy strong {
    font-size: 22px;
}

.choice-journey__copy p,
.choice-journey__unlock-copy p {
    margin-top: 6px;
    color: rgba(246, 240, 234, 0.66);
    font-size: 14px;
}

.choice-journey__unlock {
    min-width: 0;
    display: grid;
    grid-template-columns: 64px minmax(0, 1fr);
    gap: 18px;
    align-items: center;
    padding-left: 26px;
    border-left: 1px solid rgba(214, 166, 110, 0.18);
}

.choice-journey__unlock--multi {
    align-items: start;
}

.choice-journey__unlock-stack {
    display: grid;
    gap: 14px;
    min-width: 0;
}

.choice-journey__unlock-icon {
    width: 52px;
    height: 52px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(176, 130, 77, 0.38);
    border-radius: 50%;
    color: #d9a868;
    background: radial-gradient(circle, rgba(132, 91, 51, 0.2), rgba(12, 10, 9, 0.98) 70%);
}

.choice-journey__unlock-image {
    width: 28px;
    height: 28px;
    display: block;
    object-fit: contain;
    filter: drop-shadow(0 0 10px rgba(217, 168, 104, 0.16));
}

.choice-journey__extras {
    display: grid;
    gap: 10px;
    padding-top: 12px;
    border-top: 1px solid rgba(176, 130, 77, 0.16);
}

.choice-journey__extras-label {
    color: rgba(214, 166, 110, 0.68);
    font-size: 10px;
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.choice-journey__meta {
    justify-self: end;
    display: grid;
    gap: 6px;
    text-align: left;
}

.choice-journey__meta span {
    color: rgba(214, 166, 110, 0.7);
    font-size: 11px;
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.choice-open-card--activation {
    border-color: rgba(198, 146, 92, 0.28);
    background:
        linear-gradient(180deg, rgba(31, 18, 14, 0.92), rgba(16, 12, 11, 0.94)),
        radial-gradient(circle at 84% 20%, rgba(192, 120, 64, 0.12), transparent 48%);
    box-shadow:
        inset 0 1px 0 rgba(255, 240, 222, 0.04),
        0 18px 48px rgba(0, 0, 0, 0.3),
        0 0 24px rgba(180, 111, 58, 0.08);
}

.choice-open-card--activation::before {
    background:
        radial-gradient(circle at 84% 78%, rgba(214, 166, 110, 0.1), transparent 0 34px, rgba(214, 166, 110, 0.08) 34px 35px, transparent 35px),
        radial-gradient(circle at 84% 78%, transparent 0 8px, rgba(214, 166, 110, 0.09) 8px 9px, transparent 9px),
        linear-gradient(135deg, rgba(255, 255, 255, 0.02), transparent 35%);
}

.choice-open-card--activation::after {
    background:
        radial-gradient(circle at center, rgba(214, 166, 110, 0.08), transparent 56%),
        linear-gradient(90deg, transparent 49.4%, rgba(214, 166, 110, 0.08) 49.4% 50.6%, transparent 50.6%),
        linear-gradient(0deg, transparent 49.4%, rgba(214, 166, 110, 0.08) 49.4% 50.6%, transparent 50.6%);
}

.choice-open-card__state--activation {
    border-color: rgba(214, 166, 110, 0.28);
    background: rgba(40, 26, 19, 0.82);
    color: rgba(233, 191, 135, 0.96);
}

.choice-journey__meta strong {
    color: rgba(246, 240, 234, 0.92);
    font-size: 16px;
    font-weight: 600;
    line-height: 1.25;
}

.choice-journey__lock {
    width: 56px;
    height: 56px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(176, 130, 77, 0.24);
    border-radius: 16px;
    color: #d7a260;
    background: rgba(13, 10, 8, 0.64);
}

.choice-journey__row--multi .choice-journey__meta,
.choice-journey__row--multi .choice-journey__lock {
    align-self: start;
    margin-top: 2px;
}

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

.choice-journey__badges span {
    min-height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 14px;
    border: 1px solid rgba(176, 130, 77, 0.22);
    border-radius: 14px;
    background:
        radial-gradient(circle at 50% 0%, rgba(176, 130, 77, 0.09), transparent 60%),
        rgba(82, 54, 28, 0.22);
    color: rgba(240, 198, 145, 0.9);
    font-size: 12px;
    font-weight: 600;
    line-height: 1.1;
    text-align: center;
}

.choice-modes__footer {
    display: grid;
    grid-template-columns: 54px minmax(0, 1fr) minmax(240px, 320px);
    align-items: center;
    gap: 18px;
    padding: 18px 20px;
    border: 1px solid rgba(132, 32, 37, 0.7);
    border-radius: 22px;
    background:
        radial-gradient(circle at 12% 50%, rgba(177, 38, 48, 0.18), transparent 16%),
        linear-gradient(180deg, rgba(36, 11, 12, 0.98), rgba(26, 8, 8, 0.98));
    box-shadow: inset 0 1px 0 rgba(255, 236, 232, 0.06), 0 18px 42px rgba(0, 0, 0, 0.28);
}

.choice-modes__footer-mark {
    width: 38px;
    height: 38px;
    color: #ff726a;
    filter: drop-shadow(0 0 18px rgba(177, 38, 48, 0.32));
}

.choice-modes__footer-copy strong {
    color: rgba(246, 240, 234, 0.96);
    font-size: 14px;
}

.choice-modes__footer-action {
    min-height: 58px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 0 22px;
    border: 1px solid rgba(255, 164, 154, 0.24);
    border-radius: 16px;
    background: linear-gradient(180deg, #d04d4f, #ae2e34);
    box-shadow: 0 18px 34px rgba(160, 33, 40, 0.28), inset 0 1px 0 rgba(255, 238, 234, 0.16);
    color: #fff8f4;
    font-size: 15px;
    font-weight: 600;
    line-height: 1;
    text-decoration: none;
}

@media (hover: hover) and (pointer: fine) {
    .choice-open-card:hover,
    .choice-open-card:focus-visible {
        transform: translateY(-2px);
        border-color: rgba(132, 185, 122, 0.38);
        box-shadow:
            inset 0 1px 0 rgba(215, 239, 206, 0.07),
            0 18px 48px rgba(0, 0, 0, 0.3),
            0 0 28px rgba(88, 132, 84, 0.14);
    }
}

@media (min-width: 980px) {
    .choice-modes__open-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 1080px) {
    .choice-journey__row {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) 132px 64px;
        gap: 18px;
    }

    .choice-journey__copy strong,
    .choice-journey__unlock-copy strong {
        font-size: 20px;
    }
}

@media (max-width: 920px) {
    .choice-modes__footer {
        grid-template-columns: 54px minmax(0, 1fr);
    }

    .choice-modes__footer-action {
        grid-column: 1 / -1;
    }
}

@media (max-width: 760px) {
    .choice-modes {
        gap: 24px;
    }

    .choice-modes__header h2 {
        font-size: 54px;
    }

    .choice-modes__header p {
        font-size: 15px;
    }

    .choice-journey {
        padding-left: 34px;
    }

    .choice-journey::before {
        left: 10px;
    }

    .choice-journey__row {
        grid-template-columns: minmax(0, 1fr);
        gap: 14px;
        padding: 18px 18px 18px 20px;
    }

    .choice-journey__row::before {
        display: none;
    }

    .choice-journey__node {
        left: -34px;
        width: 22px;
        height: 22px;
    }

    .choice-journey__node span {
        width: 22px;
        height: 22px;
    }

    .choice-journey__node span::before {
        width: 40px;
        height: 40px;
    }

    .choice-journey__level,
    .choice-journey__unlock {
        grid-template-columns: 58px minmax(0, 1fr);
        gap: 14px;
    }

    .choice-level-pill,
    .choice-journey__unlock-icon {
        width: 52px;
        height: 52px;
    }

    .choice-level-pill {
        font-size: 24px;
    }

    .choice-journey__unlock {
        padding-left: 0;
        border-left: 0;
    }

    .choice-journey__badges {
        grid-template-columns: minmax(0, 1fr);
    }

    .choice-journey__meta {
        justify-self: start;
        padding-left: 72px;
    }

    .choice-journey__lock {
        position: absolute;
        top: 18px;
        right: 18px;
        width: 48px;
        height: 48px;
    }
}

@media (max-width: 560px) {
    .choice-modes__open-grid {
        grid-template-columns: minmax(0, 1fr);
    }

    .choice-modes__footer {
        grid-template-columns: 1fr;
        justify-items: start;
    }

    .choice-modes__footer-action {
        width: 100%;
    }
}

.final-scenario-signal {
    width: 100%;
    padding: 0 var(--gutter);
}

.final-scenario-signal__inner {
    position: relative;
    display: grid;
    grid-template-rows: minmax(0, 1fr) auto;
    gap: clamp(28px, 4vw, 40px);
    overflow: hidden;
    min-height: 660px;
    padding: clamp(36px, 5vw, 72px);
    border: 1px solid rgba(211, 124, 75, 0.18);
    border-radius: 34px;
    background:
        radial-gradient(circle at 76% 42%, rgba(126, 24, 24, 0.28), transparent 30%),
        radial-gradient(circle at 70% 78%, rgba(110, 40, 24, 0.14), transparent 24%),
        radial-gradient(circle at 26% 18%, rgba(70, 26, 18, 0.14), transparent 24%),
        linear-gradient(180deg, #080505 0%, #050505 100%);
    box-shadow:
        inset 0 0 0 1px rgba(255, 255, 255, 0.03),
        inset 0 -90px 140px rgba(145, 28, 28, 0.09),
        inset 180px 0 180px rgba(0, 0, 0, 0.08),
        inset -120px -40px 180px rgba(122, 30, 24, 0.06),
        0 28px 80px rgba(0, 0, 0, 0.45);
    isolation: isolate;
}

.final-scenario-signal__inner::before,
.final-scenario-signal__inner::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.final-scenario-signal__inner::before {
    background:
        linear-gradient(90deg, rgba(255, 255, 255, 0.035), transparent 15%, transparent 84%, rgba(255, 255, 255, 0.02)),
        radial-gradient(circle at 80% 48%, rgba(207, 52, 66, 0.1), transparent 22%),
        radial-gradient(circle at 4% 0%, rgba(211, 124, 75, 0.08), transparent 18%);
    mix-blend-mode: screen;
    opacity: 0.62;
}

.final-scenario-signal__inner::after {
    background:
        radial-gradient(circle at 0% 100%, rgba(116, 34, 24, 0.16), transparent 18%),
        radial-gradient(circle at 100% 100%, rgba(116, 34, 24, 0.16), transparent 18%),
        radial-gradient(circle at 50% 120%, rgba(0, 0, 0, 0.52), transparent 40%),
        linear-gradient(180deg, rgba(5, 5, 5, 0), rgba(5, 5, 5, 0.84));
    opacity: 0.95;
}

.final-scenario-signal__grid {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: minmax(0, 0.42fr) minmax(0, 0.58fr);
    grid-template-areas:
        "copy visual"
        "markers visual";
    align-items: stretch;
    gap: clamp(28px, 4vw, 56px);
}

.final-scenario-signal__copy {
    grid-area: copy;
    display: grid;
    gap: 28px;
    align-self: start;
    padding-top: 4px;
}

.final-scenario-signal__label,
.final-scenario-signal__copy h2,
.final-scenario-signal__copy > p,
.final-scenario-signal__marker {
    opacity: 0;
    transform: translateY(12px);
    transition:
        opacity 780ms cubic-bezier(.22, 1, .36, 1),
        transform 780ms cubic-bezier(.22, 1, .36, 1);
}

.final-scenario-signal.is-visible .final-scenario-signal__label {
    opacity: 1;
    transform: translateY(0);
    transition-delay: 80ms;
}

.final-scenario-signal.is-visible .final-scenario-signal__copy h2 {
    opacity: 1;
    transform: translateY(0);
    transition-delay: 180ms;
}

.final-scenario-signal.is-visible .final-scenario-signal__copy > p {
    opacity: 1;
    transform: translateY(0);
    transition-delay: 280ms;
}

.final-scenario-signal.is-visible .final-scenario-signal__marker:nth-child(1) {
    opacity: 1;
    transform: translateY(0);
    transition-delay: 380ms;
}

.final-scenario-signal.is-visible .final-scenario-signal__marker:nth-child(2) {
    opacity: 1;
    transform: translateY(0);
    transition-delay: 460ms;
}

.final-scenario-signal.is-visible .final-scenario-signal__marker:nth-child(3) {
    opacity: 1;
    transform: translateY(0);
    transition-delay: 540ms;
}

.final-scenario-signal__label {
    color: rgba(224, 171, 132, 0.82);
    font-size: 12px;
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}

.final-scenario-signal__copy h2 {
    margin: 0;
    display: grid;
    gap: 4px;
    color: #f4eee6;
    font-family: "Cormorant Garamond", serif;
    font-size: clamp(47px, 5.95vw, 72px);
    font-weight: 500;
    line-height: 0.98;
    letter-spacing: -0.03em;
    max-width: 6.9ch;
    text-wrap: balance;
}

.final-scenario-signal__copy > p {
    max-width: 23ch;
    margin: 0;
    color: rgba(244, 238, 230, 0.62);
    font-size: clamp(18px, 2.1vw, 20px);
    line-height: 1.58;
}

.final-scenario-signal__markers {
    grid-area: markers;
    align-self: end;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    position: relative;
}

.final-scenario-signal__markers::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: -12px;
    height: 1px;
    background: linear-gradient(90deg, rgba(211, 124, 75, 0), rgba(211, 124, 75, 0.16), rgba(211, 124, 75, 0));
    opacity: 0.8;
}

.final-scenario-signal__marker {
    position: relative;
    display: grid;
    gap: 14px;
    min-width: 0;
    padding: 18px 18px 16px;
    border: 1px solid rgba(211, 124, 75, 0.09);
    border-radius: 18px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.012), rgba(255, 255, 255, 0.004)),
        radial-gradient(circle at 12% 18%, rgba(216, 167, 95, 0.05), transparent 34%);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.03),
        inset 0 0 34px rgba(155, 54, 40, 0.045);
    backdrop-filter: blur(10px);
}

.final-scenario-signal__marker:not(:last-child)::after {
    content: "";
    position: absolute;
    left: 18px;
    right: 18px;
    bottom: -8px;
    height: 1px;
    background: linear-gradient(90deg, rgba(216, 167, 95, 0), rgba(216, 167, 95, 0.08), rgba(216, 167, 95, 0));
    opacity: 0;
}

.final-scenario-signal__marker-glyph {
    position: relative;
    width: 32px;
    height: 32px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #e5a571;
    opacity: 0.9;
}

.final-scenario-signal__marker-glyph--asset::before,
.final-scenario-signal__marker-glyph--asset::after {
    display: none;
}

.final-scenario-signal__marker-image {
    width: 20px;
    height: 20px;
    display: block;
    object-fit: contain;
    filter: drop-shadow(0 0 10px rgba(229, 133, 93, 0.14));
}

.final-scenario-signal__marker-glyph::before,
.final-scenario-signal__marker-glyph::after {
    content: "";
    position: absolute;
    inset: 50% auto auto 50%;
    transform: translate(-50%, -50%);
}

.final-scenario-signal__marker-glyph--trace::before {
    width: 24px;
    height: 1px;
    background: linear-gradient(90deg, rgba(233, 110, 82, 0), rgba(255, 243, 224, 0.9), rgba(233, 110, 82, 0));
    box-shadow: 0 0 14px rgba(233, 110, 82, 0.24);
}

.final-scenario-signal__marker-glyph--trace::after {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(255, 248, 240, 0.96), rgba(233, 110, 82, 0.14) 72%);
}

.final-scenario-signal__marker-glyph--contour::before {
    width: 22px;
    height: 22px;
    border-radius: 50%;
    border: 1px solid rgba(216, 167, 95, 0.62);
}

.final-scenario-signal__marker-glyph--contour::after {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(255, 248, 240, 0.86), rgba(194, 62, 50, 0.22) 72%);
    box-shadow: 0 0 14px rgba(194, 62, 50, 0.28);
}

.final-scenario-signal__marker-glyph--scenario::before {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    border: 1px solid rgba(216, 167, 95, 0.52);
    box-shadow: 0 0 0 5px rgba(216, 167, 95, 0.07);
}

.final-scenario-signal__marker-glyph--scenario::after {
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: #fff5ea;
    box-shadow: 0 0 0 4px rgba(229, 133, 93, 0.16), 0 0 16px rgba(229, 133, 93, 0.34);
}

.final-scenario-signal__marker strong {
    color: rgba(232, 178, 136, 0.88);
    font-size: 12px;
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.final-scenario-signal__marker p {
    max-width: 16ch;
    margin: 0;
    color: rgba(244, 238, 230, 0.58);
    font-size: 14px;
    line-height: 1.45;
}

.final-scenario-signal__visual {
    grid-area: visual;
    position: relative;
    min-height: 460px;
    overflow: hidden;
    border-radius: 28px;
    background:
        radial-gradient(circle at 56% 52%, rgba(130, 22, 22, 0.22), transparent 30%),
        radial-gradient(circle at 74% 24%, rgba(216, 167, 95, 0.08), transparent 20%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.015), rgba(255, 255, 255, 0.005));
    border: 1px solid rgba(211, 124, 75, 0.1);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

.final-scenario-signal__visual::before,
.final-scenario-signal__visual::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 0;
}

.final-scenario-signal__visual::before {
    background:
        radial-gradient(circle at 54% 50%, rgba(129, 22, 20, 0.22), transparent 22%),
        radial-gradient(circle at 68% 28%, rgba(188, 118, 71, 0.1), transparent 15%),
        radial-gradient(circle at 18% 82%, rgba(58, 16, 14, 0.22), transparent 18%);
    filter: blur(18px);
    opacity: 0.95;
}

.final-scenario-signal__visual::after {
    background:
        radial-gradient(circle at 50% 50%, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.38) 72%),
        linear-gradient(90deg, rgba(0, 0, 0, 0.22), rgba(0, 0, 0, 0) 24%, rgba(0, 0, 0, 0.14) 100%);
}

.final-scenario-signal__haze,
.final-scenario-signal__grain,
.final-scenario-signal__particles,
.final-scenario-signal__streaks,
.final-scenario-signal__svg {
    position: absolute;
    inset: 0;
}

.final-scenario-signal__haze {
    background:
        radial-gradient(circle at 62% 52%, rgba(126, 20, 20, 0.28), transparent 26%),
        radial-gradient(circle at 74% 66%, rgba(155, 106, 61, 0.11), transparent 14%),
        radial-gradient(circle at 34% 30%, rgba(72, 22, 16, 0.18), transparent 22%),
        radial-gradient(circle at 52% 88%, rgba(96, 24, 18, 0.14), transparent 22%),
        linear-gradient(90deg, rgba(5, 5, 5, 0.2), rgba(5, 5, 5, 0));
    filter: blur(12px);
    opacity: 0.96;
}

.final-scenario-signal__grain {
    opacity: 0.05;
    mix-blend-mode: screen;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160' viewBox='0 0 160 160'%3E%3Cg fill='%23ffffff' fill-opacity='.28'%3E%3Ccircle cx='12' cy='16' r='1'/%3E%3Ccircle cx='44' cy='28' r='.8'/%3E%3Ccircle cx='78' cy='18' r='.9'/%3E%3Ccircle cx='102' cy='44' r='1'/%3E%3Ccircle cx='142' cy='22' r='.9'/%3E%3Ccircle cx='18' cy='62' r='.8'/%3E%3Ccircle cx='56' cy='88' r='1'/%3E%3Ccircle cx='84' cy='70' r='.8'/%3E%3Ccircle cx='130' cy='78' r='1'/%3E%3Ccircle cx='148' cy='108' r='.8'/%3E%3Ccircle cx='24' cy='122' r='1'/%3E%3Ccircle cx='66' cy='128' r='.8'/%3E%3Ccircle cx='94' cy='144' r='.9'/%3E%3Ccircle cx='124' cy='132' r='1'/%3E%3Ccircle cx='148' cy='148' r='.7'/%3E%3C/g%3E%3C/svg%3E");
    background-size: 140px 140px;
}

.final-scenario-signal__particles {
    z-index: 1;
    pointer-events: none;
    mix-blend-mode: screen;
}

.final-scenario-signal__particle {
    position: absolute;
    left: var(--x);
    top: var(--y);
    width: var(--size);
    height: var(--size);
    border-radius: 50%;
    background:
        radial-gradient(circle, rgba(255, 247, 235, 0.95), rgba(216, 103, 77, 0.42) 42%, rgba(216, 103, 77, 0) 76%);
    opacity: var(--opacity);
    transform: translate3d(0, 0, 0);
    animation:
        finalSignalParticle var(--duration) ease-in-out var(--delay) infinite alternate,
        finalSignalFlicker calc(var(--duration) * 0.92) ease-in-out var(--delay) infinite;
}

.final-scenario-signal__streaks {
    z-index: 1;
    pointer-events: none;
}

.final-scenario-signal__streaks span {
    position: absolute;
    top: -14%;
    bottom: -8%;
    width: 1px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0), rgba(237, 140, 103, 0.5) 34%, rgba(216, 167, 95, 0.18) 62%, rgba(255, 255, 255, 0));
    box-shadow: 0 0 18px rgba(213, 85, 66, 0.16);
    opacity: 0.12;
    animation: finalSignalStreak 16s ease-in-out infinite;
}

.final-scenario-signal__streaks span:nth-child(1) {
    left: 37%;
    animation-delay: -4s;
}

.final-scenario-signal__streaks span:nth-child(2) {
    left: 53%;
    height: 132%;
    animation-delay: -1.8s;
}

.final-scenario-signal__streaks span:nth-child(3) {
    left: 69%;
    width: 2px;
    animation-delay: -6.2s;
}

.final-scenario-signal__streaks span:nth-child(4) {
    left: 82%;
    animation-delay: -2.4s;
}

.final-scenario-signal__streaks span:nth-child(5) {
    left: 92%;
    animation-delay: -7s;
}

.final-scenario-signal__svg {
    z-index: 2;
    width: 100%;
    height: 100%;
    overflow: visible;
    transform: scale(1.02);
    opacity: 1;
}

.final-scenario-signal__path {
    fill: none;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.final-scenario-signal__path--back {
    stroke: rgba(136, 44, 34, 0.22);
    stroke-width: 1.26;
    stroke-dasharray: 7 18 10 20;
    opacity: 0.22;
    filter: blur(0.8px);
    animation: finalSignalLineFloat 42s linear infinite;
}

.final-scenario-signal__paths--back .final-scenario-signal__path:nth-child(2) {
    stroke-width: 1.34;
    opacity: 0.18;
}

.final-scenario-signal__paths--back .final-scenario-signal__path:nth-child(4) {
    opacity: 0.14;
    filter: blur(1.1px);
}

.final-scenario-signal__paths--mid {
    filter: drop-shadow(0 0 8px rgba(163, 74, 52, 0.12));
}

.final-scenario-signal__path--mid {
    stroke: url(#finalSignalPathWarm);
    stroke-width: 1.56;
    stroke-dasharray: 440 26 28 42;
    opacity: 0.34;
    animation: finalSignalLineFloat 32s linear infinite;
}

.final-scenario-signal__paths--mid .final-scenario-signal__path:nth-child(1) {
    stroke-width: 1.7;
    opacity: 0.42;
}

.final-scenario-signal__paths--mid .final-scenario-signal__path:nth-child(2) {
    stroke-width: 1.42;
    opacity: 0.3;
}

.final-scenario-signal__paths--mid .final-scenario-signal__path:nth-child(3) {
    stroke-width: 1.64;
    opacity: 0.38;
}

.final-scenario-signal__paths--mid .final-scenario-signal__path:nth-child(4) {
    stroke-width: 1.34;
    opacity: 0.27;
}

.final-scenario-signal__paths--mid .final-scenario-signal__path:nth-child(5) {
    stroke-width: 1.62;
    opacity: 0.4;
}

.final-scenario-signal__paths--mid .final-scenario-signal__path:nth-child(6) {
    stroke-width: 1.46;
    opacity: 0.34;
}

.final-scenario-signal__paths--mid .final-scenario-signal__path:nth-child(7) {
    stroke-width: 1.42;
    opacity: 0.31;
}

.final-scenario-signal__path--pulse {
    stroke: url(#finalSignalPulse);
    stroke-width: 2.1;
    stroke-dasharray: 16 380;
    opacity: 0;
    filter: drop-shadow(0 0 10px rgba(255, 128, 92, 0.22));
}

.final-scenario-signal__path--pulse-a {
    animation: finalSignalPulseFlow 18s linear infinite;
}

.final-scenario-signal__path--pulse-b {
    animation: finalSignalPulseFlow 21s linear -7s infinite;
}

.final-scenario-signal__path--pulse-c {
    animation: finalSignalPulseFlow 19.5s linear -12s infinite;
}

.final-scenario-signal__path--pulse-d {
    animation: finalSignalPulseFlow 22s linear -10s infinite;
}

.final-scenario-signal__path--pulse-e {
    animation: finalSignalPulseFlow 24s linear -15s infinite;
}

.final-scenario-signal__node {
    fill: url(#finalSignalNode);
    transform-origin: center;
}

.final-scenario-signal__node--static {
    opacity: 0.42;
    animation: finalSignalNodeGlow 12s ease-in-out infinite;
}

.final-scenario-signal__node--static.is-active {
    opacity: 0.78;
    animation-duration: 8.8s;
}

.final-scenario-signal__node--moving {
    opacity: 0.68;
    animation: finalSignalMovingNode 10.5s ease-in-out infinite;
}

.final-scenario-signal__node--moving-b {
    animation-delay: -2.4s;
}

.final-scenario-signal__node--moving-c {
    animation-delay: -4.8s;
}

.final-scenario-signal__node--moving-d {
    animation-delay: -1.2s;
}

.final-scenario-signal__node--moving-e {
    animation-delay: -3.2s;
}

.final-scenario-signal__node--moving-f {
    animation-delay: -5.8s;
}

.final-scenario-signal__node--moving-g {
    animation-delay: -2.2s;
}

.final-scenario-signal__system-label {
    position: absolute;
    z-index: 3;
    display: grid;
    gap: 7px;
    min-width: 132px;
    color: rgba(244, 238, 230, 0.66);
    font-size: 11px;
    line-height: 1.2;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    opacity: 0.58;
    text-shadow: 0 0 18px rgba(155, 74, 55, 0.08);
    animation: finalSignalLabelFlicker 11s ease-in-out infinite;
}

.final-scenario-signal__system-label::before {
    content: "";
    position: absolute;
    top: 12px;
    right: calc(100% + 16px);
    width: clamp(32px, 5vw, 60px);
    height: 1px;
    background: linear-gradient(90deg, rgba(216, 167, 95, 0.16), rgba(216, 167, 95, 0.02));
    transform-origin: right center;
    animation: finalSignalConnector 12s ease-in-out infinite;
}

.final-scenario-signal__system-label::after {
    content: "";
    position: absolute;
    top: 9px;
    right: calc(100% + 12px);
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(255, 248, 240, 0.9), rgba(231, 118, 90, 0.18) 72%);
    box-shadow: 0 0 12px rgba(231, 118, 90, 0.24);
}

.final-scenario-signal__system-label strong {
    color: rgba(218, 168, 123, 0.84);
    font-size: 12px;
    font-weight: 700;
    line-height: 1.1;
}

.final-scenario-signal__system-label span {
    color: rgba(244, 238, 230, 0.52);
    font-size: 13px;
    letter-spacing: 0;
    text-transform: none;
}

.final-scenario-signal__system-label--signal {
    top: 15%;
    right: 6%;
    animation-delay: 0.4s;
}

.final-scenario-signal__system-label--pattern {
    top: 35%;
    right: 0;
    animation-delay: 1.4s;
}

.final-scenario-signal__system-label--direction {
    top: 60%;
    right: 3%;
    animation-delay: 2.1s;
}

.final-scenario-signal__system-label--stability {
    top: 82%;
    right: 8%;
    animation-delay: 2.8s;
}

.final-scenario-signal__footer {
    position: relative;
    z-index: 4;
    display: grid;
    gap: 14px;
    margin-top: 0;
}

.final-scenario-signal__cta {
    position: relative;
    min-height: 80px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 14px;
    width: 100%;
    overflow: hidden;
    padding: 0 28px;
    border: 1px solid rgba(220, 104, 81, 0.44);
    border-radius: 20px;
    background:
        linear-gradient(180deg, rgba(118, 24, 24, 0.96), rgba(88, 15, 15, 0.98) 52%, rgba(64, 12, 12, 0.98)),
        radial-gradient(circle at 50% 112%, rgba(232, 110, 85, 0.26), transparent 42%);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.12),
        inset 0 14px 28px rgba(255, 212, 188, 0.03),
        inset 0 -18px 40px rgba(49, 8, 8, 0.34),
        inset 0 0 42px rgba(196, 43, 45, 0.13),
        0 20px 40px rgba(89, 17, 17, 0.34),
        0 0 0 1px rgba(255, 255, 255, 0.025);
    color: #f7f0e8;
    text-decoration: none;
    transition:
        transform 220ms ease,
        border-color 240ms ease,
        box-shadow 240ms ease,
        background-color 240ms ease;
}

.final-scenario-signal__cta::before,
.final-scenario-signal__cta::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.final-scenario-signal__cta::before {
    background:
        radial-gradient(circle at 50% 100%, rgba(255, 176, 104, 0.16), transparent 44%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.015) 16%, rgba(255, 255, 255, 0) 40%),
        linear-gradient(90deg, rgba(255, 255, 255, 0), rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0));
    opacity: 0.84;
    mix-blend-mode: screen;
}

.final-scenario-signal__cta::after {
    width: 32%;
    inset: -18% auto -18% -36%;
    transform: skewX(-22deg);
    background: linear-gradient(90deg, rgba(255, 255, 255, 0), rgba(255, 227, 198, 0.16), rgba(255, 255, 255, 0));
    animation: finalSignalCtaSweep 7.8s ease-in-out infinite;
}

.final-scenario-signal__cta:active {
    transform: scale(0.985);
}

.final-scenario-signal__cta-copy,
.final-scenario-signal__cta-arrow {
    position: relative;
    z-index: 1;
}

.final-scenario-signal__cta-copy {
    font-size: clamp(19px, 2.1vw, 21px);
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    text-align: center;
}

.final-scenario-signal__cta-arrow {
    font-size: 26px;
    line-height: 1;
    transition: transform 220ms ease;
}

.final-scenario-signal__lock-note {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    margin: 0;
    color: rgba(244, 238, 230, 0.45);
    font-size: 14px;
    line-height: 1.4;
    text-align: center;
    opacity: 0.9;
}

.final-scenario-signal__lock-note::before {
    content: "";
    width: 13px;
    height: 13px;
    border: 1px solid rgba(216, 167, 95, 0.34);
    border-radius: 3px;
    box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.26);
    clip-path: polygon(18% 46%, 18% 100%, 82% 100%, 82% 46%, 74% 46%, 74% 32%, 68% 20%, 57% 12%, 43% 12%, 32% 20%, 26% 32%, 26% 46%);
}

@keyframes finalSignalParticle {
    0% {
        transform: translate3d(0, 0, 0) scale(0.92);
    }
    50% {
        transform: translate3d(var(--drift-x), calc(var(--drift-y) * -0.48), 0) scale(1);
    }
    100% {
        transform: translate3d(calc(var(--drift-x) * -0.45), var(--drift-y), 0) scale(0.88);
    }
}

@keyframes finalSignalFlicker {
    0%,
    100% {
        opacity: var(--opacity);
    }
    45% {
        opacity: calc(var(--opacity) + 0.05);
    }
    70% {
        opacity: calc(var(--opacity) - 0.03);
    }
}

@keyframes finalSignalStreak {
    0%,
    100% {
        opacity: 0.04;
        transform: translateY(-6px) scaleY(0.94);
    }
    45% {
        opacity: 0.2;
        transform: translateY(0) scaleY(1.03);
    }
    70% {
        opacity: 0.08;
    }
}

@keyframes finalSignalLineFloat {
    0% {
        stroke-dashoffset: 0;
    }
    100% {
        stroke-dashoffset: -380;
    }
}

@keyframes finalSignalPulseFlow {
    0% {
        opacity: 0;
        stroke-dashoffset: 460;
    }
    14%,
    22% {
        opacity: 0.5;
    }
    34%,
    100% {
        opacity: 0;
        stroke-dashoffset: 0;
    }
}

@keyframes finalSignalNodeGlow {
    0%,
    100% {
        opacity: 0.28;
        transform: scale(0.92);
    }
    44%,
    52% {
        opacity: 0.78;
        transform: scale(1.1);
    }
}

@keyframes finalSignalMovingNode {
    0%,
    100% {
        opacity: 0.3;
        transform: scale(0.88);
    }
    40%,
    56% {
        opacity: 0.88;
        transform: scale(1.16);
    }
}

@keyframes finalSignalLabelFlicker {
    0%,
    100% {
        opacity: 0.52;
    }
    46%,
    52% {
        opacity: 0.82;
    }
    62% {
        opacity: 0.6;
    }
}

@keyframes finalSignalConnector {
    0%,
    100% {
        opacity: 0.45;
        transform: scaleX(0.92);
    }
    48% {
        opacity: 0.8;
        transform: scaleX(1);
    }
}

@keyframes finalSignalCtaSweep {
    0%,
    74%,
    100% {
        transform: translateX(0) skewX(-22deg);
        opacity: 0;
    }
    79% {
        opacity: 0.24;
    }
    91% {
        transform: translateX(440%) skewX(-22deg);
        opacity: 0.16;
    }
}

@media (hover: hover) and (pointer: fine) {
    .final-scenario-signal__cta:hover {
        border-color: rgba(232, 135, 118, 0.7);
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, 0.14),
            inset 0 16px 28px rgba(255, 212, 188, 0.04),
            inset 0 -18px 40px rgba(49, 8, 8, 0.34),
            inset 0 0 48px rgba(214, 63, 66, 0.16),
            0 24px 48px rgba(95, 18, 18, 0.42);
        transform: translateY(-1px);
    }

    .final-scenario-signal__cta:hover .final-scenario-signal__cta-arrow {
        transform: translateX(4px);
    }
}

@media (max-width: 980px) {
    .final-scenario-signal__grid {
        grid-template-columns: minmax(0, 1fr);
        grid-template-areas:
            "copy"
            "visual"
            "markers";
        gap: 30px;
    }

    .final-scenario-signal__copy > p {
        max-width: 32ch;
    }

    .final-scenario-signal__visual {
        min-height: 360px;
    }

    .final-scenario-signal__system-label--signal {
        top: 12%;
        right: 4%;
    }

    .final-scenario-signal__system-label--pattern {
        top: 33%;
        right: 1%;
    }

    .final-scenario-signal__system-label--direction {
        top: 58%;
        right: 3%;
    }

    .final-scenario-signal__system-label--stability {
        top: 79%;
        right: 6%;
    }
}

@media (max-width: 760px) {
    .final-scenario-signal__inner {
        min-height: 0;
        padding: 28px 22px 24px;
        border-radius: 28px;
    }

    .final-scenario-signal__grid {
        gap: 22px;
    }

    .final-scenario-signal__copy {
        gap: 22px;
    }

    .final-scenario-signal__copy h2 {
        font-size: clamp(40px, 11vw, 54px);
    }

    .final-scenario-signal__copy > p {
        font-size: 17px;
    }

    .final-scenario-signal__visual {
        min-height: 300px;
        border-radius: 22px;
    }

    .final-scenario-signal__markers {
        grid-template-columns: minmax(0, 1fr);
        gap: 10px;
        margin-top: 4px;
    }

    .final-scenario-signal__marker {
        padding: 16px 16px 14px;
        gap: 12px;
    }

    .final-scenario-signal__marker:not(:last-child)::after {
        display: none;
    }

    .final-scenario-signal__marker p {
        max-width: none;
    }

    .final-scenario-signal__system-label {
        min-width: 0;
        gap: 6px;
        font-size: 10px;
    }

    .final-scenario-signal__system-label strong {
        font-size: 11px;
    }

    .final-scenario-signal__system-label span {
        font-size: 11px;
    }

    .final-scenario-signal__system-label::before {
        width: 24px;
        right: calc(100% + 10px);
    }

    .final-scenario-signal__system-label::after {
        right: calc(100% + 8px);
    }

    .final-scenario-signal__cta {
        min-height: 72px;
        padding: 0 18px;
        border-radius: 18px;
    }

    .final-scenario-signal__cta-copy {
        font-size: 17px;
        letter-spacing: 0.12em;
    }

    .final-scenario-signal__lock-note {
        font-size: 13px;
    }
}

@media (max-width: 560px) {
    .final-scenario-signal__visual {
        min-height: 272px;
    }

    .final-scenario-signal__svg {
        inset: 4px -8px 0 -18px;
        width: calc(100% + 26px);
    }

    .final-scenario-signal__system-label--signal {
        top: 8%;
        right: 2%;
    }

    .final-scenario-signal__system-label--pattern {
        top: 32%;
        right: 0;
    }

    .final-scenario-signal__system-label--direction {
        top: 58%;
        right: 0;
    }

    .final-scenario-signal__system-label--stability {
        top: 81%;
        right: 3%;
    }
}

@media (prefers-reduced-motion: reduce) {
    .final-scenario-signal__system-label::before,
    .final-scenario-signal__particle,
    .final-scenario-signal__streaks span,
    .final-scenario-signal__path--back,
    .final-scenario-signal__path--mid,
    .final-scenario-signal__path--pulse,
    .final-scenario-signal__node--static,
    .final-scenario-signal__node--moving,
    .final-scenario-signal__system-label,
    .final-scenario-signal__cta::after,
    .final-scenario-signal__label,
    .final-scenario-signal__copy h2,
    .final-scenario-signal__copy > p,
    .final-scenario-signal__marker {
        animation: none !important;
        transition: none !important;
    }

    .final-scenario-signal__label,
    .final-scenario-signal__copy h2,
    .final-scenario-signal__copy > p,
    .final-scenario-signal__marker {
        opacity: 1 !important;
        transform: none !important;
    }
}

@media (min-width: 431px) {
    .home-ref-main {
        width: min(100%, var(--miniapp-max-width, 430px)) !important;
        max-width: var(--miniapp-max-width, 430px) !important;
        padding-left: 10px !important;
        padding-right: 10px !important;
    }

    .product-home .signal-strip {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    .product-home .system-metrics,
    .product-home .choice-modes__open-grid,
    .product-home .final-scenario-signal__markers {
        grid-template-columns: 1fr !important;
    }

    .product-home > .mystic-hero .mystic-hero__frame {
        min-height: max(820px, calc(var(--app-stable-height, 100vh) - 6px)) !important;
        padding-bottom: 168px !important;
    }

    .product-home > .mystic-hero .mystic-hero__visual {
        inset: 176px -18px 170px 31% !important;
    }

    .product-home > .mystic-hero .mystic-hero__video {
        object-position: 61% 50% !important;
        transform: scale(1.04) !important;
    }

    .product-home > .mystic-hero .mystic-hero__star {
        top: 76px !important;
        left: 58% !important;
        width: 74px !important;
        height: 74px !important;
    }

    .product-home > .mystic-hero .mystic-hero__star::before {
        height: 78px !important;
    }

    .product-home > .mystic-hero .mystic-hero__star::after {
        width: 78px !important;
    }

    .product-home > .mystic-hero .mystic-hero__path-glow {
        left: 53% !important;
        width: 132px !important;
        height: 250px !important;
        bottom: 20px !important;
    }

    .product-home > .mystic-hero .mystic-hero__content {
        width: min(74%, 320px) !important;
        padding-top: 78px !important;
        gap: 16px !important;
    }

    .product-home > .mystic-hero .mystic-hero__content h1 {
        max-width: 6.8ch !important;
        font-size: clamp(50px, 13.8vw, 70px) !important;
    }

    .product-home > .mystic-hero .mystic-hero__description {
        max-width: 15ch !important;
        font-size: 15px !important;
    }

    .product-home > .mystic-hero .mystic-hero__subscription-badge {
        width: min(100%, 320px) !important;
        padding: 12px 14px !important;
        border-radius: 18px !important;
        gap: 10px !important;
    }

    .product-home > .mystic-hero .mystic-hero__subscription-copy strong {
        font-size: 14px !important;
    }

    .product-home > .mystic-hero .mystic-hero__subscription-copy span {
        font-size: 11px !important;
    }

    .product-home > .mystic-hero .mystic-hero__status {
        width: 100% !important;
        padding: 14px !important;
    }

    .product-home > .mystic-hero .dynamic-cta {
        width: 100% !important;
        min-height: 80px !important;
    }

    .product-home > .mystic-hero .mystic-hero__footer {
        left: 18px !important;
        right: 18px !important;
        bottom: 18px !important;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 10px !important;
        padding: 14px 14px calc(14px + var(--safe-bottom)) !important;
    }

    .product-home > .mystic-hero .mystic-metric {
        grid-template-columns: 40px 1fr !important;
        gap: 10px !important;
    }

    .product-home > .mystic-hero .mystic-metric__icon {
        width: 34px !important;
        height: 34px !important;
    }

    .product-home > .mystic-hero .mystic-metric__copy strong {
        font-size: 14px !important;
    }

    .product-home .scenario-current {
        grid-template-columns: minmax(0, 1fr) !important;
        grid-template-areas:
            "sigil"
            "copy"
            "aside"
            "depth" !important;
        gap: 18px !important;
        min-height: 0 !important;
        padding: 18px 16px 18px !important;
    }

    .product-home .scenario-current::after {
        display: none !important;
    }

    .product-home .scenario-current__copy {
        max-width: none !important;
    }

    .product-home .scenario-current h2 {
        font-size: clamp(38px, 10vw, 48px) !important;
    }

    .product-home .scenario-current p {
        max-width: 20ch !important;
        font-size: 14px !important;
    }

    .product-home .scenario-current__sigil {
        width: 156px !important;
        height: 156px !important;
    }

    .product-home .scenario-current__sigil::before {
        inset: -14px !important;
    }

    .product-home .scenario-current__aside {
        justify-self: start !important;
        min-width: 0 !important;
        width: 100% !important;
        max-width: 262px !important;
        top: auto !important;
        left: auto !important;
        right: auto !important;
        transform: none !important;
    }

    .product-home .scenario-current__aside::before {
        display: none !important;
    }

    .product-home .scenario-depth {
        padding: 14px !important;
    }

    .product-home .scenario-next {
        grid-template-columns: minmax(0, 1fr) !important;
        gap: 18px !important;
        min-height: 0 !important;
        padding: 18px 16px 18px !important;
    }

    .product-home .scenario-next h3 {
        max-width: 9.5ch !important;
        font-size: clamp(34px, 9vw, 42px) !important;
    }

    .product-home .scenario-next p {
        width: auto !important;
        max-width: 26ch !important;
        font-size: 14px !important;
    }

    .product-home .scenario-next::before {
        background:
            linear-gradient(90deg, transparent 100%, transparent 100%),
            radial-gradient(circle at 50% 50%, rgba(171, 48, 56, 0.05), transparent 34%) !important;
    }

    .product-home .scenario-next__preview {
        width: 100% !important;
        padding-left: 0 !important;
        padding-top: 16px !important;
        border-left: 0 !important;
        border-top: 1px solid rgba(246, 240, 234, 0.07) !important;
    }

    .product-home .scenario-line {
        --scenario-axis-x: 18px !important;
    }

    .product-home .scenario-level-row {
        grid-template-columns: 36px minmax(0, 1fr) !important;
        gap: 14px !important;
    }

    .product-home .scenario-level-card,
    .product-home .scenario-level-unlocks {
        grid-column: 2 / 3 !important;
        width: 100% !important;
        max-width: none !important;
        justify-self: stretch !important;
        padding-right: 0 !important;
    }

    .product-home .scenario-level-card::before {
        left: -18px !important;
        right: auto !important;
        width: 18px !important;
    }

    .product-home .scenario-level-card__node {
        left: -18px !important;
        right: auto !important;
    }

    .product-home .scenario-level-unlocks::before {
        left: -18px !important;
        width: 18px !important;
    }

    .product-home .scenario-level-axis {
        grid-column: 1 / 2 !important;
        min-height: 0 !important;
        width: 36px !important;
    }

    .product-home .choice-modes__footer {
        grid-template-columns: 54px minmax(0, 1fr) !important;
        gap: 14px !important;
        padding: 16px !important;
    }

    .product-home .choice-modes__footer-action {
        grid-column: 1 / -1 !important;
        width: 100% !important;
    }

    .product-home .final-scenario-signal__markers {
        gap: 10px !important;
        margin-top: 4px !important;
    }

    .product-home .final-scenario-signal__marker {
        padding: 16px 16px 14px !important;
        gap: 12px !important;
    }

    .product-home .final-scenario-signal__marker:not(:last-child)::after {
        display: none !important;
    }

    .product-home .final-scenario-signal__marker p {
        max-width: none !important;
    }
}

/* Mobile-native Telegram Mini App home */
body[data-page="vybor-home"] .product-home {
    display: grid;
    gap: 18px;
}

body[data-page="vybor-home"] .mystic-hero {
    order: 1;
}

body[data-page="vybor-home"] .signal-welcome {
    order: 4;
}

body[data-page="vybor-home"] .scenario-progression {
    order: 5;
}

body[data-page="vybor-home"] .choice-modes {
    order: 6;
}

body[data-page="vybor-home"] .choice-club {
    order: 7;
}

body[data-page="vybor-home"] .product-home > .scenario-orbit-system {
    order: 2;
    margin: 0 var(--gutter) !important;
    padding: 0 !important;
    width: auto !important;
    max-width: none !important;
    height: 320px !important;
    max-height: 320px !important;
    overflow: hidden !important;
}

body[data-page="vybor-home"] .product-home > .scenario-orbit-system .scenario-orbit-system__shell {
    width: 100% !important;
    border-radius: 32px !important;
    padding: 0 !important;
    min-height: 320px !important;
    max-height: 320px !important;
    height: 320px !important;
    overflow: hidden !important;
}

body[data-page="vybor-home"] .product-home > .scenario-orbit-system .scenario-orbit-system__visual {
    height: 300px !important;
    min-height: 300px !important;
    max-height: 300px !important;
}

body[data-page="vybor-home"] .final-scenario-signal {
    order: 8;
}

body[data-page="vybor-home"] .home-hero {
    display: none !important;
}

body[data-page="vybor-home"] .mystic-hero__frame,
body[data-page="vybor-home"] .scenario-progression,
body[data-page="vybor-home"] .choice-modes,
body[data-page="vybor-home"] .scenario-orbit-system__shell,
body[data-page="vybor-home"] .signal-welcome,
body[data-page="vybor-home"] .artifact-inbox,
body[data-page="vybor-home"] .final-scenario-signal__inner {
    border-radius: 28px !important;
}

body[data-page="vybor-home"] .mystic-hero__frame {
    min-height: 0 !important;
    padding: 18px 18px 20px !important;
    display: grid !important;
    gap: 16px !important;
    background:
        linear-gradient(180deg, rgba(14, 14, 14, 0.98), rgba(8, 8, 8, 0.98)),
        radial-gradient(circle at top right, rgba(151, 36, 42, 0.22), transparent 34%) !important;
}

body[data-page="vybor-home"] .mystic-hero__topline,
body[data-page="vybor-home"] .mystic-hero__level,
body[data-page="vybor-home"] .mystic-hero__rail,
body[data-page="vybor-home"] .mystic-hero__content,
body[data-page="vybor-home"] .mystic-hero__footer {
    position: relative !important;
    inset: auto !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    top: auto !important;
    width: 100% !important;
}

body[data-page="vybor-home"] .mystic-hero__visual {
    position: relative !important;
    inset: auto !important;
    width: 100% !important;
    min-height: 236px !important;
    aspect-ratio: 1 / 1.04;
    border-radius: 24px !important;
    overflow: hidden !important;
}

body[data-page="vybor-home"] .mystic-hero__video {
    object-fit: cover;
    object-position: center;
}

body[data-page="vybor-home"] .mystic-hero__level {
    display: inline-grid !important;
    justify-self: start;
    gap: 2px;
    width: auto !important;
    padding: 10px 12px !important;
    border-radius: 16px !important;
    background: rgba(9, 9, 9, 0.72);
    backdrop-filter: blur(12px);
}

body[data-page="vybor-home"] .mystic-hero__level strong {
    font-size: 20px !important;
}

body[data-page="vybor-home"] .mystic-hero__rail {
    display: grid !important;
    grid-auto-flow: column;
    grid-auto-columns: 1fr;
    gap: 8px;
    padding: 0 !important;
}

body[data-page="vybor-home"] .mystic-rail__node {
    min-height: 8px;
    border-radius: 999px;
}

body[data-page="vybor-home"] .mystic-hero__content {
    display: grid !important;
    gap: 14px !important;
    padding-top: 0 !important;
}

body[data-page="vybor-home"] .mystic-hero__content h1 {
    max-width: 8ch !important;
    font-size: clamp(38px, 11vw, 46px) !important;
    line-height: 0.94 !important;
}

body[data-page="vybor-home"] .mystic-hero__description {
    max-width: 28ch !important;
    font-size: 15px !important;
    line-height: 1.58 !important;
}

body[data-page="vybor-home"] .mystic-hero__status {
    padding: 14px 16px !important;
    border-radius: 18px !important;
}

body[data-page="vybor-home"] .dynamic-cta {
    width: 100% !important;
    min-height: 58px !important;
    grid-template-columns: 44px minmax(0, 1fr) 22px !important;
    padding: 12px 14px !important;
    border-radius: 18px !important;
}

body[data-page="vybor-home"] .dynamic-cta__hint {
    display: none !important;
}

body[data-page="vybor-home"] .mystic-hero__signals-shell {
    gap: 10px !important;
}

body[data-page="vybor-home"] .mystic-hero__signals {
    display: flex !important;
    gap: 8px;
    overflow-x: auto;
    padding-bottom: 2px;
    scroll-snap-type: x proximity;
}

body[data-page="vybor-home"] .mystic-hero__signals > * {
    flex: 0 0 auto;
    scroll-snap-align: start;
}

body[data-page="vybor-home"] .mystic-hero__footer {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
    padding: 0 !important;
    background: none !important;
    border: 0 !important;
}

body[data-page="vybor-home"] .mystic-metric {
    min-width: 0;
    padding: 14px 14px 13px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.04);
}

body[data-page="vybor-home"] .mystic-metric__copy strong {
    font-size: 14px !important;
    line-height: 1.35 !important;
}

body[data-page="vybor-home"] .signal-welcome,
body[data-page="vybor-home"] .artifact-inbox,
body[data-page="vybor-home"] .scenario-progression,
body[data-page="vybor-home"] .choice-modes,
body[data-page="vybor-home"] .scenario-orbit-system__shell,
body[data-page="vybor-home"] .final-scenario-signal__inner {
    padding: 18px !important;
}

body[data-page="vybor-home"] .signal-welcome h2,
body[data-page="vybor-home"] .scenario-progression__header h2,
body[data-page="vybor-home"] .choice-modes__header h2,
body[data-page="vybor-home"] .final-scenario-signal__copy h2 {
    font-size: clamp(30px, 9vw, 40px) !important;
    line-height: 0.98 !important;
}

body[data-page="vybor-home"] .signal-strip,
body[data-page="vybor-home"] .system-metrics {
    grid-template-columns: 1fr 1fr !important;
}

body[data-page="vybor-home"] .scenario-current,
body[data-page="vybor-home"] .scenario-next {
    min-height: 0 !important;
    padding: 18px 16px !important;
    border-radius: 22px !important;
}

body[data-page="vybor-home"] .scenario-line {
    display: grid;
    gap: 12px;
}

body[data-page="vybor-home"] .scenario-level-row {
    align-items: start !important;
}

body[data-page="vybor-home"] .scenario-level-unlocks__items {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    padding-bottom: 2px;
}

body[data-page="vybor-home"] .scenario-unlock-chip {
    flex: 0 0 auto;
}

body[data-page="vybor-home"] .choice-modes__open-grid {
    display: grid !important;
    grid-auto-flow: column;
    grid-auto-columns: minmax(82%, 1fr);
    gap: 12px !important;
    overflow-x: auto;
    padding-bottom: 4px;
    scroll-snap-type: x mandatory;
}

body[data-page="vybor-home"] .choice-modes__open-grid > * {
    scroll-snap-align: start;
}

body[data-page="vybor-home"] .choice-open-card {
    min-height: 0 !important;
    padding: 18px !important;
    border-radius: 22px !important;
}

body[data-page="vybor-home"] .choice-modes__group--locked {
    display: grid;
    gap: 12px;
}

body[data-page="vybor-home"] .choice-modes__footer {
    margin-top: 4px;
}

body[data-page="vybor-home"] .scenario-orbit-system__shell {
    overflow: hidden;
    padding: 0 !important;
}

body[data-page="vybor-home"] .scenario-orbit-system__visual {
    min-height: 260px;
    border-radius: 22px;
}

body[data-page="vybor-home"] .scenario-orbit-system__signal {
    left: auto !important;
    right: auto !important;
    top: auto !important;
    bottom: auto !important;
    padding: 0 !important;
    border-radius: 0 !important;
}

body[data-page="vybor-home"] .final-scenario-signal__grid {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
}

body[data-page="vybor-home"] .final-scenario-signal__copy {
    gap: 14px !important;
}

body[data-page="vybor-home"] .final-scenario-signal__copy > p {
    max-width: none !important;
    font-size: 15px !important;
}

body[data-page="vybor-home"] .final-scenario-signal__visual {
    min-height: 250px !important;
    border-radius: 22px !important;
}

body[data-page="vybor-home"] .final-scenario-signal__system-label {
    display: none !important;
}

body[data-page="vybor-home"] .final-scenario-signal__markers {
    display: grid !important;
    grid-template-columns: 1fr !important;
}

body[data-page="vybor-home"] .final-scenario-signal__footer {
    display: grid;
    gap: 12px;
}

body[data-page="vybor-home"] .final-scenario-signal__cta {
    width: 100%;
}

/* Restore the original first-screen visual language for Telegram Mini App */
body[data-page="vybor-home"] {
    --miniapp-max-width: 390px;
    --gutter: 16px;
}

body[data-page="vybor-home"] .home-ref-main {
    width: min(100%, 390px) !important;
    max-width: 390px !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

body[data-page="vybor-home"] .product-home {
    gap: 24px !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero {
    width: calc(100% - (var(--gutter) * 2)) !important;
    margin: 0 var(--gutter) !important;
    padding: 0 !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__frame {
    min-height: auto !important;
    padding: 18px 18px 18px !important;
    display: grid !important;
    gap: 16px !important;
    border-radius: 32px !important;
    background:
        radial-gradient(circle at 78% 9%, rgba(255, 198, 93, 0.1), transparent 13%),
        radial-gradient(circle at 83% 88%, rgba(120, 18, 26, 0.18), transparent 34%),
        linear-gradient(180deg, rgba(10, 10, 10, 0.985), rgba(6, 6, 6, 0.99)) !important;
    box-shadow:
        0 30px 80px rgba(0, 0, 0, 0.54),
        inset 0 1px 0 rgba(255, 255, 255, 0.04) !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__topline {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    grid-template-rows: auto auto !important;
    align-items: start !important;
    row-gap: 14px !important;
    padding: 2px 2px 0 !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__topline > span:first-child {
    color: #ff655c !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: 0.22em !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__topline > span:last-child {
    color: rgba(243, 239, 232, 0.72) !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    letter-spacing: 0.06em !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__topline::after {
    content: "";
    grid-column: 1 / 2;
    width: 154px;
    height: 12px;
    justify-self: start;
    background:
        radial-gradient(circle, rgba(255, 105, 99, 0.94) 0 3px, transparent 3.5px) 0 50% / 28px 12px no-repeat,
        radial-gradient(circle, rgba(255, 105, 99, 0.94) 0 3px, transparent 3.5px) 28px 50% / 28px 12px no-repeat,
        radial-gradient(circle, rgba(255, 105, 99, 0.94) 0 3px, transparent 3.5px) 56px 50% / 28px 12px no-repeat,
        linear-gradient(90deg, rgba(255, 108, 101, 0.3), rgba(255, 108, 101, 0.08) 68%, transparent 100%) 0 50% / 154px 1px no-repeat;
    opacity: 0.96;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__visual {
    position: relative !important;
    inset: auto !important;
    width: 100% !important;
    min-height: 236px !important;
    aspect-ratio: 1.56 / 1 !important;
    border-radius: 26px !important;
    overflow: hidden !important;
    background: #080808 !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__video {
    object-fit: cover !important;
    object-position: 74% 50% !important;
    transform: scale(1.04) !important;
    filter: none !important;
    mask-image: none !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__video-shade,
body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__path-glow,
body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__visual::before,
body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__visual::after {
    display: none !important;
    content: none !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__star {
    display: none !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__level {
    position: absolute !important;
    left: 14px !important;
    right: auto !important;
    top: auto !important;
    bottom: 18px !important;
    z-index: 3 !important;
    width: min(54%, 172px) !important;
    min-height: 116px !important;
    justify-items: start !important;
    align-content: center !important;
    gap: 6px !important;
    padding: 18px 16px !important;
    border-radius: 22px !important;
    border: 1px solid rgba(246, 240, 234, 0.12) !important;
    background: rgba(10, 10, 10, 0.82) !important;
    box-shadow:
        0 18px 42px rgba(0, 0, 0, 0.36),
        inset 0 1px 0 rgba(255, 255, 255, 0.04) !important;
    backdrop-filter: blur(14px) !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__level strong {
    font-size: 28px !important;
    line-height: 0.92 !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__level span {
    color: rgba(243, 239, 232, 0.82) !important;
    font-size: 10px !important;
    font-weight: 500 !important;
    line-height: 1.15 !important;
    letter-spacing: 0.04em !important;
    text-transform: uppercase !important;
    text-align: left !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__rail {
    position: relative !important;
    inset: auto !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    bottom: auto !important;
    z-index: 2 !important;
    display: grid !important;
    grid-auto-flow: column !important;
    grid-auto-columns: 1fr !important;
    align-items: center !important;
    gap: 6px !important;
    width: 100% !important;
    padding: 2px 8px 0 !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__rail::before {
    content: none !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-rail__node {
    width: 18px !important;
    height: 18px !important;
    margin: 0 auto !important;
    border-radius: 999px !important;
    border: 1px solid rgba(255, 126, 118, 0.44) !important;
    background: linear-gradient(180deg, rgba(129, 28, 33, 0.96), rgba(102, 22, 28, 0.96)) !important;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.08),
        0 0 0 1px rgba(255, 98, 92, 0.06) !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-rail__node.is-current {
    width: 24px !important;
    height: 24px !important;
    border-color: rgba(255, 200, 196, 0.72) !important;
    background: radial-gradient(circle, rgba(255, 112, 103, 0.98) 0 44%, rgba(193, 41, 51, 0.96) 70%, rgba(109, 18, 25, 0.98) 100%) !important;
    box-shadow:
        0 0 0 5px rgba(14, 14, 14, 0.7),
        0 0 22px rgba(255, 73, 70, 0.72),
        0 0 42px rgba(132, 18, 27, 0.34) !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__content {
    position: relative !important;
    inset: auto !important;
    width: 100% !important;
    display: grid !important;
    gap: 16px !important;
    padding-top: 2px !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__eyebrow,
body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__signals-shell {
    display: none !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__subscription-badge {
    width: 100% !important;
    padding: 16px 18px !important;
    border-radius: 20px !important;
    border-color: rgba(185, 137, 85, 0.22) !important;
    background:
        linear-gradient(180deg, rgba(17, 16, 16, 0.96), rgba(11, 11, 11, 0.98)),
        radial-gradient(circle at 10% 50%, rgba(184, 128, 72, 0.14), transparent 36%) !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__subscription-copy small {
    color: #ff6a61 !important;
    letter-spacing: 0.12em !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__subscription-copy strong {
    font-size: 15px !important;
    line-height: 1.28 !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__subscription-copy span {
    font-size: 11px !important;
    line-height: 1.4 !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__content h1 {
    margin: 0 !important;
    max-width: 6.8ch !important;
    font-size: clamp(50px, 15vw, 64px) !important;
    font-weight: 600 !important;
    line-height: 0.92 !important;
    letter-spacing: -0.035em !important;
    text-wrap: balance !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__description {
    max-width: 18ch !important;
    margin-top: -4px !important;
    color: rgba(243, 239, 232, 0.72) !important;
    font-size: 14px !important;
    line-height: 1.46 !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__status {
    width: 100% !important;
    grid-template-columns: 46px 1fr !important;
    gap: 12px !important;
    padding: 14px 16px 14px 14px !important;
    border-radius: 20px !important;
    border-color: rgba(246, 240, 234, 0.1) !important;
    background:
        linear-gradient(180deg, rgba(17, 16, 16, 0.96), rgba(11, 11, 11, 0.98)),
        radial-gradient(circle at 8% 50%, rgba(151, 33, 40, 0.18), transparent 38%) !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__status-mark {
    width: 38px !important;
    height: 38px !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__status-mark::before {
    inset: 8px !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__status-mark::after {
    inset: 13px !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__status-copy {
    gap: 3px !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__status-kicker {
    color: #ff6a61 !important;
    font-size: 10px !important;
    letter-spacing: 0.12em !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__status-copy strong {
    font-size: 14px !important;
    line-height: 1.22 !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__status-copy span {
    font-size: 11px !important;
    line-height: 1.42 !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .dynamic-cta {
    width: 100% !important;
    min-height: 80px !important;
    grid-template-columns: 48px minmax(0, 1fr) 24px !important;
    gap: 14px !important;
    padding: 14px 16px !important;
    border-radius: 20px !important;
    border-color: rgba(214, 98, 92, 0.42) !important;
    background:
        linear-gradient(180deg, rgba(158, 44, 45, 0.98), rgba(132, 31, 35, 0.98)),
        radial-gradient(circle at 16% 40%, rgba(255, 222, 215, 0.12), transparent 28%) !important;
    box-shadow:
        0 18px 40px rgba(89, 18, 22, 0.34),
        inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
    transform: none !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .dynamic-cta::before,
body[data-page="vybor-home"] .product-home > .mystic-hero .dynamic-cta__hint {
    display: none !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .dynamic-cta__ambient {
    inset: -20% auto auto -8% !important;
    width: 44% !important;
    background: radial-gradient(circle, rgba(255, 161, 145, 0.18), transparent 68%) !important;
    filter: blur(28px) !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .dynamic-cta__icon {
    width: 40px !important;
    height: 40px !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .dynamic-cta__icon svg {
    width: 20px !important;
    height: 20px !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .dynamic-cta__copy {
    gap: 4px !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .dynamic-cta__copy strong {
    font-size: 16px !important;
    line-height: 1.16 !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .dynamic-cta__copy small {
    font-size: 11px !important;
    line-height: 1.36 !important;
    color: rgba(255, 238, 236, 0.74) !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .dynamic-cta__arrow {
    width: 22px !important;
    height: 22px !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__footer {
    position: relative !important;
    inset: auto !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px !important;
    padding: 0 !important;
    background: none !important;
    border: 0 !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-metric {
    min-width: 0 !important;
    display: grid !important;
    grid-template-columns: 40px minmax(0, 1fr) !important;
    gap: 10px !important;
    align-items: center !important;
    padding: 14px 14px 13px !important;
    border-radius: 18px !important;
    border: 1px solid rgba(246, 240, 234, 0.08) !important;
    background:
        linear-gradient(180deg, rgba(17, 17, 17, 0.96), rgba(11, 11, 11, 0.98)),
        radial-gradient(circle at 14% 50%, rgba(163, 82, 35, 0.1), transparent 34%) !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-metric__icon {
    width: 34px !important;
    height: 34px !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-metric__copy {
    min-width: 0 !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-metric__copy span {
    font-size: 10px !important;
    letter-spacing: 0.08em !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-metric__copy strong {
    font-size: 14px !important;
    line-height: 1.28 !important;
}

/* ═══════════════════════════════════════════════════════════════
   ОДИНАКОВАЯ ШИРИНА ВСЕХ БЛОКОВ — как первый блок (.mystic-hero)

   .mystic-hero section получает margin: 0 24px (строка ~9732),
   его frame заполняет оставшиеся 342px.

   .scenario-progression и .artifact-inbox уже имеют
   margin: 0 var(--gutter) в базовом CSS — трогать их не нужно.

   .choice-modes и .signal-welcome (class="system") имеют
   width:100% без margin — добавляем margin без перебивания padding.

   .final-scenario-signal — обёртка; обнуляем горизонтальный
   padding на обёртке, inner-элемент сам имеет padding:18px.
   ═══════════════════════════════════════════════════════════════ */

/* choice-modes и signal-welcome: добавляем те же margin что у mystic-hero */
body[data-page="vybor-home"] .product-home > .choice-modes,
body[data-page="vybor-home"] .product-home > .choice-club,
body[data-page="vybor-home"] .product-home > .signal-welcome {
    width: calc(100% - (var(--gutter) * 2)) !important;
    margin-left: var(--gutter) !important;
    margin-right: var(--gutter) !important;
    box-sizing: border-box !important;
}

/* final-scenario-signal: обёртка, padding на sides не нужен — inner сам имеет padding */
body[data-page="vybor-home"] .product-home > .final-scenario-signal {
    width: calc(100% - (var(--gutter) * 2)) !important;
    margin-left: var(--gutter) !important;
    margin-right: var(--gutter) !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    box-sizing: border-box !important;
}

/* ═══════════════════════════════════════════════════════════════
   REFERENCE FIRST BLOCK — точная доработка под дизайн референса
   ═══════════════════════════════════════════════════════════════ */

/* ── 1. Видео: край-в-край без скруглений ─────────────────────── */
body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__visual {
    width: calc(100% + 36px) !important;
    margin-left: -18px !important;
    border-radius: 0 !important;
    min-height: 210px !important;
    aspect-ratio: 1.68 / 1 !important;
    overflow: hidden !important;
    background: #080808 !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__video {
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center 30% !important;
    transform: none !important;
}

/* ── 2. Level-badge: скрыть (в стекинге не нужен) ─────────────── */
body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__level {
    display: none !important;
}

/* ── 3. Прогресс-трек под лейблом: сегменты + узлы ───────────── */
body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__topline::after {
    width: 172px !important;
    height: 10px !important;
    background:
        /* Основная линия с угасанием */
        linear-gradient(90deg,
            rgba(200, 48, 58, 0.88) 0%,
            rgba(200, 48, 58, 0.65) 28%,
            rgba(200, 48, 58, 0.28) 60%,
            rgba(200, 48, 58, 0.10) 100%
        ) 0 50% / 172px 2px no-repeat,
        /* Янтарный узел */
        radial-gradient(circle, rgba(215, 128, 32, 1) 0 3.5px, rgba(215, 128, 32, 0.4) 4.5px, transparent 6px) 42px 50% / 12px 12px no-repeat,
        /* Красный узел */
        radial-gradient(circle, rgba(200, 52, 58, 1) 0 2.5px, rgba(200, 52, 58, 0.36) 3.5px, transparent 5px) 84px 50% / 10px 10px no-repeat !important;
    opacity: 1 !important;
}

/* ── 4. Rail-ноды: мелкие точки как в референсе ──────────────── */
body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__rail {
    gap: 7px !important;
    padding: 4px 0 2px !important;
    justify-content: center !important;
    grid-auto-columns: auto !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-rail__node {
    width: 8px !important;
    height: 8px !important;
    margin: 0 !important;
    border-radius: 50% !important;
    border: 1px solid rgba(255, 80, 72, 0.28) !important;
    background: linear-gradient(180deg, rgba(118, 22, 28, 0.88), rgba(90, 16, 22, 0.92)) !important;
    box-shadow: none !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-rail__node.is-opened {
    border-color: rgba(255, 80, 72, 0.3) !important;
    background: linear-gradient(180deg, rgba(140, 28, 34, 0.88), rgba(110, 20, 26, 0.92)) !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-rail__node.is-current {
    width: 14px !important;
    height: 14px !important;
    border-color: rgba(255, 195, 190, 0.68) !important;
    background: radial-gradient(circle at 38% 35%, rgba(255, 108, 100, 0.98), rgba(190, 42, 52, 0.97) 60%, rgba(108, 18, 26, 0.99) 100%) !important;
    box-shadow:
        0 0 0 3px rgba(12, 12, 12, 0.72),
        0 0 16px rgba(255, 72, 66, 0.70),
        0 0 32px rgba(132, 20, 28, 0.32) !important;
}

/* ── 5. Headline: h1 слева + description справа ──────────────── */
body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__headline {
    display: grid !important;
    grid-template-columns: 54% 1fr !important;
    column-gap: 12px !important;
    row-gap: 0 !important;
    align-items: start !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__headline h1,
body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__content .mystic-hero__headline h1 {
    grid-column: 1 !important;
    max-width: none !important;
    width: 100% !important;
    font-size: clamp(24px, 7vw, 30px) !important;
    font-weight: 600 !important;
    line-height: 0.96 !important;
    letter-spacing: -0.025em !important;
    text-wrap: wrap !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__headline .mystic-hero__description {
    grid-column: 2 !important;
    max-width: none !important;
    margin-top: 4px !important;
    font-size: 12.5px !important;
    line-height: 1.46 !important;
    color: rgba(243, 239, 232, 0.70) !important;
}

/* ── 6. Subscription badge: dot оранжевый + crown иконка ─────── */
body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__subscription-badge {
    grid-template-columns: 10px minmax(0, 1fr) 28px !important;
    align-items: center !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__subscription-dot {
    width: 9px !important;
    height: 9px !important;
    margin-top: 0 !important;
    background: radial-gradient(circle, #ff9a44 0%, #e07020 55%, rgba(224, 112, 32, 0.3) 80%) !important;
    box-shadow: 0 0 10px rgba(224, 120, 32, 0.5) !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__subscription-copy small {
    color: #ff7a54 !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__subscription-crown {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    color: rgba(215, 168, 60, 0.86) !important;
    flex-shrink: 0 !important;
}

/* ── 7. Статус-карточка: оранжевый кикер ─────────────────────── */
body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__status-kicker {
    color: #ff7a54 !important;
    font-size: 10px !important;
    font-weight: 700 !important;
    letter-spacing: 0.14em !important;
}

/* ── Адаптив ≤ 360px ──────────────────────────────────────────── */
@media (max-width: 360px) {
    body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__visual {
        min-height: 180px !important;
        aspect-ratio: 1.5 / 1 !important;
    }

    body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__headline h1 {
        font-size: 40px !important;
    }

    body[data-page="vybor-home"] .product-home > .mystic-hero .mystic-hero__headline .mystic-hero__description {
        font-size: 12px !important;
    }
}

/* ═══════════════════════════════════════════════════════════════════
   SCENARIO PROGRESSION — CINEMATIC SYSTEM REBUILD
   Premium atmosphere · Mobile-first · 3-col timeline · Apple/Linear quality
   ═══════════════════════════════════════════════════════════════════ */

/* ── Container ──────────────────────────────────────────────────── */
body[data-page="vybor-home"] #scenario-progression {
    padding: 20px !important;
    gap: 18px !important;
    border-radius: 28px !important;
    border: 1px solid rgba(246, 240, 234, 0.08) !important;
    background:
        linear-gradient(180deg, rgba(11, 9, 9, 0.97), rgba(5, 5, 5, 0.99)),
        radial-gradient(circle at 50% 0%, rgba(120, 20, 28, 0.18), transparent 32%),
        radial-gradient(circle at 82% 84%, rgba(185, 141, 80, 0.06), transparent 22%) !important;
    box-shadow:
        0 28px 68px rgba(0, 0, 0, 0.48),
        inset 0 1px 0 rgba(255, 255, 255, 0.042) !important;
    overflow: visible !important;
}

/* ── Section header ─────────────────────────────────────────────── */
body[data-page="vybor-home"] #scenario-progression .scenario-progression__header {
    gap: 10px !important;
    padding-bottom: 4px !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-progression__header h2 {
    max-width: 8.4em !important;
    font-size: clamp(28px, 8.5vw, 38px) !important;
    line-height: 0.94 !important;
    letter-spacing: -0.02em !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-progression__header p {
    max-width: 520px !important;
    margin: 0 !important;
    color: rgba(246, 240, 234, 0.54) !important;
    font-size: 13.5px !important;
    line-height: 1.58 !important;
}

/* ── Current level card ─────────────────────────────────────────── */
body[data-page="vybor-home"] #scenario-progression .scenario-current {
    min-height: 220px !important;
    gap: 14px !important;
    padding: 20px 18px 18px !important;
    border-radius: 24px !important;
    border: 1px solid rgba(246, 240, 234, 0.1) !important;
    background:
        linear-gradient(180deg, rgba(12, 9, 9, 0.72), rgba(6, 6, 6, 0.98) 74%),
        radial-gradient(circle at 50% 18%, rgba(158, 38, 48, 0.26), transparent 36%),
        radial-gradient(circle at 76% 20%, rgba(246, 240, 234, 0.08), transparent 22%),
        #070707 !important;
    box-shadow:
        0 22px 58px rgba(0, 0, 0, 0.44),
        0 0 48px rgba(143, 32, 41, 0.12),
        inset 0 1px 0 rgba(255, 255, 255, 0.055) !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-current__copy {
    max-width: 60% !important;
    z-index: 1 !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-current h2 {
    max-width: none !important;
    margin-top: 6px !important;
    font-size: clamp(34px, 9vw, 48px) !important;
    line-height: 0.91 !important;
    letter-spacing: -0.02em !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-current p {
    max-width: 20ch !important;
    margin-top: 7px !important;
    color: rgba(246, 240, 234, 0.72) !important;
    font-size: 13.5px !important;
    line-height: 1.42 !important;
}

/* Sigil – right-side cinematic orb */
body[data-page="vybor-home"] #scenario-progression .scenario-current__sigil {
    position: absolute !important;
    left: auto !important;
    right: 14px !important;
    top: 16px !important;
    transform: none !important;
    width: 128px !important;
    height: 128px !important;
    font-size: 52px !important;
    text-shadow: 0 0 22px rgba(204, 68, 78, 0.52) !important;
    z-index: 0 !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-current__sigil::before {
    border-color: rgba(190, 60, 68, 0.26) !important;
    box-shadow:
        inset 0 0 28px rgba(143, 32, 41, 0.16),
        0 0 48px rgba(143, 32, 41, 0.14) !important;
}

/* Depth block */
body[data-page="vybor-home"] #scenario-progression .scenario-depth {
    z-index: 1 !important;
    padding: 12px 14px 13px !important;
    border-radius: 18px !important;
    border: 1px solid rgba(246, 240, 234, 0.07) !important;
    background: rgba(4, 4, 4, 0.56) !important;
    backdrop-filter: blur(16px) !important;
    gap: 8px !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-depth__top,
body[data-page="vybor-home"] #scenario-progression .scenario-depth__bottom {
    font-size: 10px !important;
    letter-spacing: 0.11em !important;
    color: rgba(246, 240, 234, 0.48) !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-depth__top strong,
body[data-page="vybor-home"] #scenario-progression .scenario-depth__bottom strong {
    color: rgba(246, 240, 234, 0.88) !important;
    font-size: 13px !important;
    font-weight: 600 !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-depth__track {
    height: 3px !important;
    background: rgba(255, 255, 255, 0.07) !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-depth__track span {
    background: linear-gradient(90deg, rgba(142, 38, 48, 0.9), rgba(208, 118, 124, 0.96), rgba(238, 218, 212, 0.72)) !important;
    box-shadow: 0 0 16px rgba(180, 58, 68, 0.22) !important;
}

/* ── Next level card ────────────────────────────────────────────── */
body[data-page="vybor-home"] #scenario-progression .scenario-next {
    min-height: 0 !important;
    padding: 18px 16px !important;
    border-radius: 24px !important;
    border: 1px solid rgba(201, 161, 108, 0.12) !important;
    background:
        linear-gradient(180deg, rgba(11, 10, 10, 0.82), rgba(7, 7, 7, 0.99)),
        radial-gradient(circle at 80% 22%, rgba(185, 141, 86, 0.09), transparent 34%),
        radial-gradient(circle at 18% 78%, rgba(143, 32, 41, 0.14), transparent 30%) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03) !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-next h3 {
    margin-top: 6px !important;
    font-size: clamp(26px, 7vw, 36px) !important;
    line-height: 0.93 !important;
    letter-spacing: -0.015em !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-next p {
    max-width: none !important;
    color: rgba(246, 240, 234, 0.7) !important;
    font-size: 13.5px !important;
    line-height: 1.4 !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-next__shadow {
    margin-top: 10px !important;
    padding: 8px 12px !important;
    border-radius: 999px !important;
    border: 1px solid rgba(246, 240, 234, 0.1) !important;
    background: rgba(255, 255, 255, 0.028) !important;
    color: rgba(246, 240, 234, 0.58) !important;
    font-size: 10.5px !important;
    letter-spacing: 0.11em !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-next__shadow b {
    color: rgba(246, 240, 234, 0.84) !important;
}

/* ── Path header ────────────────────────────────────────────────── */
body[data-page="vybor-home"] #scenario-progression .scenario-line-head {
    padding: 0 !important;
    margin-bottom: 4px !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-line-head .eyebrow {
    font-size: 10px !important;
    letter-spacing: 0.16em !important;
    color: rgba(246, 240, 234, 0.48) !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-line-head p {
    font-size: 10px !important;
    letter-spacing: 0.1em !important;
    text-transform: uppercase !important;
    color: rgba(246, 240, 234, 0.36) !important;
    text-align: right !important;
    max-width: 15ch !important;
}

/* ── Scenario line ──────────────────────────────────────────────── */
body[data-page="vybor-home"] #scenario-progression .scenario-line {
    gap: 14px !important;
    max-height: none !important;
    overflow: visible !important;
    padding: 0 !important;
}

/* ── Level row ──────────────────────────────────────────────────── */
body[data-page="vybor-home"] #scenario-progression .scenario-level-row {
    align-items: stretch !important;
}

/* ── Level card body ────────────────────────────────────────────── */
body[data-page="vybor-home"] #scenario-progression .scenario-level-card__body {
    display: grid !important;
    grid-template-columns: 38px minmax(0, 1fr) !important;
    grid-template-rows: auto auto auto auto !important;
    gap: 4px 8px !important;
    padding: 12px 11px 11px !important;
    border-radius: 18px !important;
    border: 1px solid rgba(246, 240, 234, 0.08) !important;
    background:
        linear-gradient(180deg, rgba(18, 15, 15, 0.96), rgba(8, 8, 8, 0.99)),
        radial-gradient(circle at 88% 12%, rgba(143, 32, 41, 0.07), transparent 34%) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03) !important;
    transition: border-color 0.3s ease, box-shadow 0.3s ease !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-level-card__roman {
    width: 36px !important;
    height: 36px !important;
    border-radius: 12px !important;
    font-size: 18px !important;
    align-self: start !important;
    grid-row: 1 / 2 !important;
    grid-column: 1 / 2 !important;
    border: 1px solid rgba(246, 240, 234, 0.11) !important;
    background: linear-gradient(180deg, rgba(32, 26, 26, 0.94), rgba(12, 10, 10, 0.98)) !important;
    color: rgba(246, 240, 234, 0.82) !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-level-card strong {
    grid-column: 2 / 3 !important;
    grid-row: 1 / 2 !important;
    align-self: center !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    line-height: 1.05 !important;
    color: rgba(246, 240, 234, 0.94) !important;
    overflow-wrap: anywhere !important;
    max-width: none !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-level-card p {
    grid-column: 1 / 3 !important;
    grid-row: 2 / 3 !important;
    margin-top: 4px !important;
    color: rgba(246, 240, 234, 0.58) !important;
    font-size: 11px !important;
    line-height: 1.38 !important;
    overflow-wrap: anywhere !important;
    max-width: none !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-level-card small {
    grid-column: 1 / 3 !important;
    grid-row: 3 / 4 !important;
    margin-top: 6px !important;
    padding: 5px 10px !important;
    border-radius: 999px !important;
    border: 1px solid rgba(246, 240, 234, 0.09) !important;
    background: rgba(255, 255, 255, 0.025) !important;
    color: rgba(246, 240, 234, 0.48) !important;
    font-size: 9.5px !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
    justify-self: start !important;
    line-height: 1.3 !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-level-card__veil {
    display: none !important;
}

/* Opened card */
body[data-page="vybor-home"] #scenario-progression .scenario-level-card--opened .scenario-level-card__body {
    border-color: rgba(88, 130, 82, 0.18) !important;
    background:
        linear-gradient(180deg, rgba(14, 18, 14, 0.97), rgba(8, 10, 8, 0.99)),
        radial-gradient(circle at 14% 22%, rgba(80, 124, 76, 0.08), transparent 30%) !important;
    box-shadow: 0 0 22px rgba(80, 124, 76, 0.06), inset 0 1px 0 rgba(255, 255, 255, 0.04) !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-level-card--opened .scenario-level-card__roman {
    border-color: rgba(112, 156, 105, 0.22) !important;
    color: rgba(210, 228, 200, 0.92) !important;
    background: linear-gradient(180deg, rgba(36, 56, 34, 0.84), rgba(10, 14, 10, 0.98)) !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-level-card--opened small {
    border-color: rgba(88, 130, 82, 0.16) !important;
    background: rgba(80, 124, 76, 0.08) !important;
    color: rgba(200, 224, 190, 0.68) !important;
}

/* Current card */
body[data-page="vybor-home"] #scenario-progression .scenario-level-card--current .scenario-level-card__body,
body[data-page="vybor-home"] #scenario-progression .scenario-level-card.is-current .scenario-level-card__body {
    border-color: rgba(192, 72, 80, 0.38) !important;
    background:
        linear-gradient(180deg, rgba(22, 14, 15, 0.98), rgba(8, 6, 6, 0.99)),
        radial-gradient(circle at 80% 14%, rgba(196, 62, 72, 0.22), transparent 38%) !important;
    box-shadow:
        0 0 36px rgba(143, 32, 41, 0.16),
        inset 0 1px 0 rgba(255, 255, 255, 0.06) !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-level-card--current .scenario-level-card__roman,
body[data-page="vybor-home"] #scenario-progression .scenario-level-card.is-current .scenario-level-card__roman {
    border-color: rgba(224, 118, 124, 0.34) !important;
    color: rgba(255, 230, 230, 0.96) !important;
    background: radial-gradient(circle, rgba(176, 58, 68, 0.52), rgba(82, 24, 28, 0.44) 42%, rgba(8, 6, 6, 0.97) 74%) !important;
    box-shadow: 0 0 18px rgba(176, 58, 68, 0.22) !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-level-card--current strong,
body[data-page="vybor-home"] #scenario-progression .scenario-level-card.is-current strong {
    color: rgba(255, 235, 234, 0.96) !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-level-card--current small,
body[data-page="vybor-home"] #scenario-progression .scenario-level-card.is-current small {
    border-color: rgba(192, 72, 80, 0.22) !important;
    background: rgba(192, 72, 80, 0.08) !important;
    color: rgba(248, 198, 200, 0.76) !important;
}

/* Locked card */
body[data-page="vybor-home"] #scenario-progression .scenario-level-card--locked .scenario-level-card__body {
    border-color: rgba(130, 88, 66, 0.1) !important;
    background:
        linear-gradient(180deg, rgba(16, 13, 13, 0.95), rgba(7, 7, 7, 0.98)) !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-level-card--locked .scenario-level-card__roman {
    color: rgba(200, 178, 168, 0.62) !important;
    border-color: rgba(136, 92, 68, 0.14) !important;
    background: linear-gradient(180deg, rgba(26, 20, 18, 0.82), rgba(10, 8, 8, 0.96)) !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-level-card--locked strong {
    color: rgba(200, 188, 180, 0.74) !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-level-card--locked p {
    color: rgba(186, 170, 162, 0.5) !important;
}

/* ── Axis axis-dot states ────────────────────────────────────────── */
body[data-page="vybor-home"] #scenario-progression .scenario-level-axis {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    align-self: stretch !important;
}

/* ── Unlock chips (right column) ────────────────────────────────── */
body[data-page="vybor-home"] #scenario-progression .scenario-level-unlocks {
    display: grid !important;
    gap: 6px !important;
    min-height: 0 !important;
    padding: 10px 9px !important;
    border-radius: 18px !important;
    border: 1px solid rgba(246, 240, 234, 0.06) !important;
    background:
        linear-gradient(180deg, rgba(14, 13, 13, 0.72), rgba(7, 7, 7, 0.94)) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.022) !important;
    align-content: start !important;
    overflow: visible !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-level-unlocks__label {
    font-size: 9px !important;
    font-weight: 800 !important;
    letter-spacing: 0.14em !important;
    text-transform: uppercase !important;
    color: rgba(246, 240, 234, 0.4) !important;
    margin-bottom: 2px !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-level-unlocks__items {
    display: flex !important;
    flex-direction: column !important;
    gap: 5px !important;
    overflow: visible !important;
    overflow-x: unset !important;
    padding-bottom: 0 !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-practice-card {
    display: grid !important;
    gap: 5px !important;
    margin-top: 4px !important;
    padding: 9px 9px 10px !important;
    border-radius: 12px !important;
    border: 1px solid rgba(232, 168, 73, 0.13) !important;
    background:
        linear-gradient(145deg, rgba(38, 20, 12, 0.62), rgba(9, 8, 8, 0.9)),
        radial-gradient(ellipse at 100% 0%, rgba(232, 168, 73, 0.08), transparent 50%) !important;
    color: rgba(246, 240, 234, 0.68) !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-practice-card__tag {
    font-size: 8.5px !important;
    font-weight: 800 !important;
    letter-spacing: 0.13em !important;
    text-transform: uppercase !important;
    color: rgba(232, 168, 73, 0.62) !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-practice-card strong {
    font-size: 11.5px !important;
    line-height: 1.2 !important;
    color: rgba(246, 240, 234, 0.9) !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-practice-card p {
    margin: 0 !important;
    font-size: 10.5px !important;
    line-height: 1.42 !important;
    color: rgba(246, 240, 234, 0.56) !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-practice-card small {
    font-size: 9.5px !important;
    line-height: 1.25 !important;
    color: rgba(232, 168, 73, 0.46) !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-unlock-chip {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 6px !important;
    flex: none !important;
    min-height: 0 !important;
    padding: 5px 7px 5px 5px !important;
    border-radius: 10px !important;
    border: 1px solid rgba(194, 121, 69, 0.1) !important;
    background: linear-gradient(180deg, rgba(28, 22, 20, 0.64), rgba(10, 9, 9, 0.82)) !important;
    color: rgba(246, 240, 234, 0.72) !important;
    font-size: 10.5px !important;
    line-height: 1.2 !important;
    transition: background 0.25s ease, border-color 0.25s ease !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-unlock-chip:hover {
    border-color: rgba(194, 121, 69, 0.18) !important;
    background: linear-gradient(180deg, rgba(36, 28, 24, 0.72), rgba(14, 12, 12, 0.9)) !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-icon {
    width: 22px !important;
    height: 22px !important;
    border-radius: 7px !important;
    flex-shrink: 0 !important;
    border: 1px solid rgba(194, 121, 69, 0.14) !important;
    background: linear-gradient(180deg, rgba(42, 32, 24, 0.86), rgba(14, 12, 10, 0.96)) !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-icon__image {
    width: 14px !important;
    height: 14px !important;
}

/* Opened row unlocks */
body[data-page="vybor-home"] #scenario-progression .scenario-level-row--opened .scenario-level-unlocks {
    border-color: rgba(88, 130, 82, 0.14) !important;
    background:
        linear-gradient(180deg, rgba(12, 16, 12, 0.74), rgba(6, 8, 6, 0.95)) !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-level-row--opened .scenario-unlock-chip {
    border-color: rgba(88, 130, 82, 0.11) !important;
    color: rgba(218, 228, 210, 0.78) !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-level-row--opened .scenario-level-unlocks__label {
    color: rgba(188, 216, 178, 0.44) !important;
}

/* Current row unlocks */
body[data-page="vybor-home"] #scenario-progression .scenario-level-row.is-current .scenario-level-unlocks,
body[data-page="vybor-home"] #scenario-progression .scenario-level-row--current .scenario-level-unlocks {
    border-color: rgba(176, 68, 76, 0.2) !important;
    background:
        linear-gradient(180deg, rgba(18, 11, 11, 0.78), rgba(6, 5, 5, 0.96)) !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-level-row.is-current .scenario-unlock-chip,
body[data-page="vybor-home"] #scenario-progression .scenario-level-row--current .scenario-unlock-chip {
    border-color: rgba(176, 68, 76, 0.12) !important;
    color: rgba(248, 236, 234, 0.76) !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-level-row.is-current .scenario-level-unlocks__label,
body[data-page="vybor-home"] #scenario-progression .scenario-level-row--current .scenario-level-unlocks__label {
    color: rgba(248, 196, 198, 0.44) !important;
}

/* Locked row unlocks */
body[data-page="vybor-home"] #scenario-progression .scenario-level-row--locked .scenario-level-unlocks {
    border-color: rgba(120, 82, 60, 0.09) !important;
    background: linear-gradient(180deg, rgba(14, 11, 11, 0.68), rgba(6, 5, 5, 0.93)) !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-level-row--locked .scenario-unlock-chip {
    color: rgba(202, 184, 174, 0.62) !important;
    border-color: rgba(136, 96, 74, 0.09) !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-level-row--locked .scenario-level-unlocks__label {
    color: rgba(196, 172, 162, 0.38) !important;
}

/* ── Hide legacy connector artifacts ─────────────────────────────── */
body[data-page="vybor-home"] #scenario-progression .scenario-level-card::before,
body[data-page="vybor-home"] #scenario-progression .scenario-level-unlocks::before {
    display: none !important;
    content: none !important;
}

/* ── Cinematic ambient glow on current level row ─────────────────── */
body[data-page="vybor-home"] #scenario-progression .scenario-level-row.is-current,
body[data-page="vybor-home"] #scenario-progression .scenario-level-row--current {
    position: relative !important;
}

body[data-page="vybor-home"] #scenario-progression .scenario-level-row.is-current::before,
body[data-page="vybor-home"] #scenario-progression .scenario-level-row--current::before {
    display: none !important;
}

/* ── Mobile refinements ─────────────────────────────────────────── */
@media (max-width: 760px) {
    body[data-page="vybor-home"] #scenario-progression {
        padding: 16px !important;
        gap: 14px !important;
        border-radius: 24px !important;
    }

    body[data-page="vybor-home"] #scenario-progression .scenario-current {
        min-height: 190px !important;
        padding: 16px 14px 14px !important;
    }

    body[data-page="vybor-home"] #scenario-progression .scenario-current__sigil {
        right: 10px !important;
        top: 12px !important;
        width: 108px !important;
        height: 108px !important;
        font-size: 44px !important;
    }

    body[data-page="vybor-home"] #scenario-progression .scenario-current h2 {
        font-size: clamp(28px, 8vw, 40px) !important;
    }

    body[data-page="vybor-home"] #scenario-progression .scenario-next {
        padding: 14px 13px !important;
    }

    body[data-page="vybor-home"] #scenario-progression .scenario-next h3 {
        font-size: clamp(22px, 6.5vw, 30px) !important;
    }

    body[data-page="vybor-home"] #scenario-progression .scenario-level-card__body {
        gap: 3px 7px !important;
        padding: 10px 9px !important;
        border-radius: 14px !important;
    }

    body[data-page="vybor-home"] #scenario-progression .scenario-level-card__roman {
        width: 30px !important;
        height: 30px !important;
        font-size: 15px !important;
        border-radius: 9px !important;
    }

    body[data-page="vybor-home"] #scenario-progression .scenario-level-card strong {
        font-size: 13.5px !important;
    }

    body[data-page="vybor-home"] #scenario-progression .scenario-level-card p {
        font-size: 10px !important;
        margin-top: 3px !important;
    }

    body[data-page="vybor-home"] #scenario-progression .scenario-level-card small {
        font-size: 8.5px !important;
        padding: 4px 8px !important;
        margin-top: 5px !important;
    }

    body[data-page="vybor-home"] #scenario-progression .scenario-level-unlocks {
        padding: 8px 7px !important;
        border-radius: 14px !important;
        gap: 5px !important;
    }

    body[data-page="vybor-home"] #scenario-progression .scenario-level-unlocks__label {
        font-size: 8px !important;
        margin-bottom: 1px !important;
    }

    body[data-page="vybor-home"] #scenario-progression .scenario-unlock-chip {
        font-size: 9.5px !important;
        padding: 4px 6px 4px 4px !important;
        gap: 5px !important;
        border-radius: 8px !important;
    }

    body[data-page="vybor-home"] #scenario-progression .scenario-icon {
        width: 18px !important;
        height: 18px !important;
        border-radius: 5px !important;
    }

    body[data-page="vybor-home"] #scenario-progression .scenario-icon__image {
        width: 11px !important;
        height: 11px !important;
    }

    body[data-page="vybor-home"] #scenario-progression .scenario-line {
        gap: 12px !important;
    }
}

/* ── Motion: subtle hover + breathing glow ──────────────────────── */
@media (hover: hover) {
    body[data-page="vybor-home"] #scenario-progression .scenario-level-card__body:hover {
        border-color: rgba(246, 240, 234, 0.14) !important;
        box-shadow:
            0 0 28px rgba(0, 0, 0, 0.12),
            inset 0 1px 0 rgba(255, 255, 255, 0.05) !important;
        transition: border-color 0.3s ease, box-shadow 0.3s ease !important;
    }

    body[data-page="vybor-home"] #scenario-progression .scenario-level-card--opened .scenario-level-card__body:hover {
        border-color: rgba(88, 130, 82, 0.28) !important;
        box-shadow: 0 0 28px rgba(80, 124, 76, 0.1) !important;
    }

    body[data-page="vybor-home"] #scenario-progression .scenario-level-card--current .scenario-level-card__body:hover,
    body[data-page="vybor-home"] #scenario-progression .scenario-level-card.is-current .scenario-level-card__body:hover {
        border-color: rgba(200, 78, 86, 0.52) !important;
        box-shadow: 0 0 42px rgba(143, 32, 41, 0.22) !important;
    }
}

/* Breathing animation for current dot */
@keyframes spBreatheDot {
    0%, 100% { box-shadow: 0 0 18px rgba(188, 64, 73, 0.32), 0 0 38px rgba(188, 64, 73, 0.12); }
    50%       { box-shadow: 0 0 28px rgba(188, 64, 73, 0.48), 0 0 56px rgba(188, 64, 73, 0.18); }
}

body[data-page="vybor-home"] #scenario-progression .scenario-level-axis.is-current .scenario-axis-dot {
    animation: spBreatheDot 3.4s ease-in-out infinite !important;
}

/* Subtle glow pulse on scenario-current sigil */
@keyframes spSigilPulse {
    0%, 100% { opacity: 0.92; text-shadow: 0 0 22px rgba(204, 68, 78, 0.52); }
    50%       { opacity: 1;    text-shadow: 0 0 34px rgba(204, 68, 78, 0.72); }
}

body[data-page="vybor-home"] #scenario-progression .scenario-current__sigil {
    animation: spSigilPulse 4.8s ease-in-out infinite !important;
}

/* =====================================================
   CHOICE MODES — CINEMATIC PREMIUM REBUILD (cm-*)
   ===================================================== */

/* Override base layout for the section */
.choice-modes {
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
    padding: 0 var(--gutter) !important;
}

/* ── HEADER ──────────────────────────────────────── */
.cm-header {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding-bottom: 28px;
}

.cm-eyebrow {
    display: block;
    font-size: 10.5px;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: rgba(246, 240, 234, 0.44);
}

.cm-headline {
    margin: 0;
    font-family: "Cormorant Garamond", serif;
    font-size: clamp(40px, 11vw, 56px);
    font-weight: 600;
    line-height: 0.92;
    letter-spacing: -0.01em;
    color: var(--text);
}

.cm-subhead {
    margin: 0;
    font-size: 14px;
    line-height: 1.55;
    color: rgba(246, 240, 234, 0.52);
}

/* ── OPEN STATUS LABEL ───────────────────────────── */
.cm-open-label {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 0 16px;
}

.cm-open-label__dot {
    flex: 0 0 auto;
    width: 20px;
    height: 20px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #7fb472;
    filter: drop-shadow(0 0 7px rgba(100, 158, 92, 0.7));
}

.cm-open-label__dot svg {
    width: 100%;
    height: 100%;
}

.cm-open-label__copy strong {
    display: block;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #7fb472;
    line-height: 1.3;
}

.cm-open-label__copy span {
    font-size: 12.5px;
    color: rgba(246, 240, 234, 0.44);
    line-height: 1.4;
}

/* ── CARD LIST ───────────────────────────────────── */
.cm-list,
.cm-locked-list {
    display: flex;
    flex-direction: column;
    gap: 9px;
    width: 100%;
}

/* ── BASE CARD ───────────────────────────────────── */
.cm-card {
    position: relative;
    display: flex;
    align-items: center;
    gap: 14px;
    width: 100%;
    box-sizing: border-box;
    padding: 14px 14px 14px 14px;
    border: 1px solid rgba(112, 156, 105, 0.2);
    border-radius: 16px;
    background:
        radial-gradient(ellipse at 8% 50%, rgba(78, 120, 72, 0.13) 0%, transparent 52%),
        linear-gradient(160deg, rgba(11, 16, 11, 0.98) 0%, rgba(6, 9, 7, 0.99) 100%);
    box-shadow:
        inset 0 1px 0 rgba(200, 232, 192, 0.04),
        0 3px 18px rgba(0, 0, 0, 0.38);
    color: inherit;
    text-decoration: none;
    isolation: isolate;
    overflow: hidden;
    transition: border-color 220ms ease, box-shadow 220ms ease, transform 200ms ease;
}

.cm-card--open:hover,
.cm-card--open:active {
    border-color: rgba(112, 156, 105, 0.38);
    box-shadow:
        inset 0 1px 0 rgba(200, 232, 192, 0.06),
        0 6px 28px rgba(0, 0, 0, 0.42),
        0 0 22px rgba(78, 132, 72, 0.1);
    transform: translateY(-1px);
}

/* Ambient glow trace on the card background */
.cm-card--open::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: radial-gradient(ellipse at 96% 50%, rgba(112, 156, 105, 0.07) 0%, transparent 50%);
    opacity: 0.8;
    transition: opacity 220ms;
}

.cm-card--open:hover::after {
    opacity: 1;
}

/* ── ICON CIRCLE ─────────────────────────────────── */
.cm-card__icon {
    flex: 0 0 auto;
    width: 44px;
    height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(122, 170, 114, 0.26);
    border-radius: 50%;
    background: radial-gradient(circle at 38% 32%, rgba(112, 156, 105, 0.22) 0%, rgba(7, 11, 8, 0.98) 72%);
    box-shadow:
        0 0 18px rgba(78, 132, 72, 0.18),
        inset 0 1px 0 rgba(200, 240, 192, 0.06);
    overflow: hidden;
}

.cm-card__icon img {
    width: 100%;
    height: 100%;
    padding: 9px;
    box-sizing: border-box;
    object-fit: contain;
    display: block;
    filter: drop-shadow(0 0 7px rgba(78, 132, 72, 0.32));
}

.cm-card__icon svg {
    width: 20px;
    height: 20px;
    stroke: #9dd48a;
    stroke-width: 1.4;
    stroke-linecap: round;
    stroke-linejoin: round;
    fill: none;
    filter: drop-shadow(0 0 5px rgba(78, 132, 72, 0.4));
}

/* ── CARD BODY ───────────────────────────────────── */
.cm-card__body {
    flex: 1 1 auto;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.cm-card__title {
    display: block;
    margin: 0;
    font-family: "Cormorant Garamond", serif;
    font-size: clamp(19px, 4.6vw, 23px);
    font-weight: 600;
    line-height: 1.0;
    color: rgba(246, 240, 234, 0.96);
    letter-spacing: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.cm-card__desc {
    margin: 0;
    font-size: 12.5px;
    line-height: 1.42;
    color: rgba(246, 240, 234, 0.54);
}

/* ── BADGE (status pill) ─────────────────────────── */
.cm-card__badge {
    display: inline-flex;
    align-items: center;
    width: max-content;
    padding: 3px 11px;
    margin-top: 5px;
    border: 1px solid rgba(108, 158, 97, 0.28);
    border-radius: 999px;
    background: rgba(36, 52, 34, 0.48);
    color: #8dce7a;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.03em;
    line-height: 1;
    box-shadow: 0 0 10px rgba(78, 132, 72, 0.1);
}

.cm-card__badge--activation {
    border-color: rgba(196, 158, 90, 0.3);
    background: rgba(52, 38, 18, 0.48);
    color: #d9a85a;
    box-shadow: 0 0 10px rgba(184, 126, 63, 0.1);
}

.cm-card__badge--locked {
    border-color: rgba(168, 124, 72, 0.26);
    background: rgba(44, 32, 16, 0.44);
    color: rgba(214, 166, 110, 0.8);
    box-shadow: none;
}

/* ── ARROW BUTTON ────────────────────────────────── */
.cm-card__arrow {
    flex: 0 0 auto;
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(122, 170, 114, 0.18);
    border-radius: 50%;
    background: rgba(78, 132, 72, 0.06);
    color: rgba(246, 240, 234, 0.44);
    transition: border-color 200ms, background 200ms, color 200ms, box-shadow 200ms;
}

.cm-card__arrow svg {
    width: 15px;
    height: 15px;
    stroke: currentColor;
    stroke-width: 1.6;
    stroke-linecap: round;
    stroke-linejoin: round;
    fill: none;
}

.cm-card--open:hover .cm-card__arrow {
    border-color: rgba(122, 170, 114, 0.42);
    background: rgba(78, 132, 72, 0.14);
    color: rgba(246, 240, 234, 0.88);
    box-shadow: 0 0 12px rgba(78, 132, 72, 0.18);
}

/* ── LOCKED CARD VARIANT ─────────────────────────── */
.cm-card--locked {
    border-color: rgba(148, 108, 62, 0.16);
    background:
        radial-gradient(ellipse at 8% 50%, rgba(100, 68, 34, 0.1) 0%, transparent 52%),
        linear-gradient(160deg, rgba(13, 10, 8, 0.98) 0%, rgba(8, 7, 6, 0.99) 100%);
    opacity: 0.78;
    cursor: default;
    pointer-events: none;
}

.cm-card--locked .cm-card__icon {
    border-color: rgba(168, 124, 72, 0.22);
    background: radial-gradient(circle, rgba(100, 68, 34, 0.18) 0%, rgba(12, 10, 8, 0.98) 72%);
    box-shadow: 0 0 14px rgba(148, 100, 48, 0.12);
}

.cm-card--locked .cm-card__icon img {
    filter: drop-shadow(0 0 5px rgba(148, 100, 48, 0.22)) brightness(0.82) saturate(0.6);
}

.cm-card__lock {
    flex: 0 0 auto;
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(148, 108, 62, 0.16);
    border-radius: 50%;
    background: rgba(100, 68, 34, 0.06);
    color: rgba(214, 166, 110, 0.4);
}

.cm-card__lock svg {
    width: 15px;
    height: 15px;
    stroke: currentColor;
    stroke-width: 1.5;
    stroke-linecap: round;
    stroke-linejoin: round;
    fill: none;
}

/* ── LOCKED SECTION LABEL ────────────────────────── */
.cm-locked-label {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 22px 0 16px;
    margin-top: 12px;
    border-top: 1px solid rgba(148, 108, 62, 0.16);
}

.cm-locked-label__dot {
    flex: 0 0 auto;
    width: 20px;
    height: 20px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: rgba(214, 166, 110, 0.72);
    filter: drop-shadow(0 0 5px rgba(184, 126, 63, 0.28));
}

.cm-locked-label__dot svg {
    width: 100%;
    height: 100%;
}

.cm-locked-label__copy strong {
    display: block;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: rgba(214, 166, 110, 0.78);
    line-height: 1.3;
}

.cm-locked-label__copy span {
    font-size: 12.5px;
    color: rgba(246, 240, 234, 0.38);
    line-height: 1.4;
}

/* ── FOOTER CTA BAR ──────────────────────────────── */
.cm-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    margin-top: 22px;
    padding: 16px 18px;
    border-radius: 18px;
    background:
        radial-gradient(ellipse at 6% 50%, rgba(148, 36, 44, 0.14) 0%, transparent 54%),
        linear-gradient(135deg, rgba(14, 8, 9, 0.98) 0%, rgba(8, 6, 6, 0.99) 100%);
    border: 1px solid rgba(168, 52, 60, 0.2);
    box-shadow:
        inset 0 1px 0 rgba(255, 180, 180, 0.04),
        0 0 28px rgba(148, 36, 44, 0.08);
}

.cm-footer__left {
    display: flex;
    align-items: center;
    gap: 12px;
    flex: 1 1 auto;
    min-width: 0;
}

.cm-footer__star {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: rgba(232, 120, 128, 0.9);
    filter: drop-shadow(0 0 7px rgba(188, 56, 68, 0.56));
}

.cm-footer__copy strong {
    display: block;
    font-size: 10.5px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: rgba(246, 240, 234, 0.84);
    line-height: 1.3;
}

.cm-footer__copy p {
    margin: 3px 0 0;
    font-size: 12px;
    color: rgba(246, 240, 234, 0.44);
    line-height: 1.4;
}

.cm-footer__btn {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 11px 16px;
    border-radius: 12px;
    background: linear-gradient(135deg, #c03e46 0%, #8e2830 100%);
    border: 1px solid rgba(220, 100, 110, 0.22);
    color: rgba(255, 242, 242, 0.96);
    font-size: 12.5px;
    font-weight: 600;
    text-decoration: none;
    white-space: nowrap;
    box-shadow:
        0 0 18px rgba(168, 44, 54, 0.28),
        inset 0 1px 0 rgba(255, 190, 190, 0.1);
    transition: background 200ms ease, box-shadow 200ms ease, transform 180ms ease;
    letter-spacing: 0.01em;
}

.cm-footer__btn:hover {
    background: linear-gradient(135deg, #d04850 0%, #9e3038 100%);
    box-shadow:
        0 0 26px rgba(168, 44, 54, 0.42),
        inset 0 1px 0 rgba(255, 190, 190, 0.14);
    transform: translateY(-1px);
}

/* ── RESPONSIVE ──────────────────────────────────── */
@media (max-width: 480px) {
    .cm-headline {
        font-size: clamp(36px, 10vw, 44px);
    }

    .cm-card {
        padding: 13px 12px;
        gap: 12px;
    }

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

    .cm-card__icon img {
        padding: 8px;
    }

    .cm-card__title {
        font-size: clamp(17px, 4.4vw, 21px);
    }

    .cm-card__arrow,
    .cm-card__lock {
        width: 30px;
        height: 30px;
    }

    .cm-card__arrow svg,
    .cm-card__lock svg {
        width: 13px;
        height: 13px;
    }

    .cm-footer {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
        padding: 14px 16px;
    }

    .cm-footer__btn {
        width: 100%;
        justify-content: center;
    }
}

/* ================================================================
   FINAL SIGNAL — CINEMATIC REFERENCE REBUILD (1:1)
   Layout: full-width visual scene, copy overlays top-left,
           3-col markers row below, volumetric CTA footer
   ================================================================ */

/* 1 · Inner card — vertical rhythm, cinematic depth */
.final-scenario-signal__inner {
    grid-template-rows: auto auto;
    min-height: 0;
    padding: clamp(22px, 4.5vw, 56px);
    border-radius: clamp(22px, 4vw, 36px);
    background:
        radial-gradient(circle at 64% 40%, rgba(140, 20, 20, 0.40), transparent 34%),
        radial-gradient(circle at 80% 72%, rgba(112, 38, 22, 0.18), transparent 26%),
        radial-gradient(circle at 20% 14%, rgba(68, 24, 16, 0.18), transparent 22%),
        linear-gradient(180deg, #070404 0%, #050505 100%);
    box-shadow:
        inset 0 0 0 1px rgba(255, 255, 255, 0.03),
        inset 0 -80px 140px rgba(148, 26, 26, 0.14),
        0 32px 80px rgba(0, 0, 0, 0.52);
}

/* 2 · Grid → flex column; visual fills full width */
.final-scenario-signal__grid {
    display: flex;
    flex-direction: column;
    grid-template-columns: unset;
    grid-template-areas: unset;
    align-items: unset;
    gap: clamp(14px, 2.8vw, 22px);
}

/* 3 · Copy: absolutely overlays visual, anchored top-left
   Note: __copy is now a child of __visual (position:relative, overflow:hidden)
   so text is naturally clipped at the visual's bottom edge. */
.final-scenario-signal__copy {
    grid-area: unset;
    align-self: unset;
    position: absolute;
    top: 0;
    left: 0;
    right: 50%;
    z-index: 5;
    padding: 0;
    gap: clamp(14px, 2.4vw, 24px);
    pointer-events: none;
}

/* 4 · Visual: full-width, tall cinematic scene */
.final-scenario-signal__visual {
    grid-area: unset;
    flex: 0 0 auto;
    order: 0;
    width: 100%;
    min-height: clamp(400px, 90vw, 600px);
    border-radius: clamp(16px, 2.8vw, 22px);
    background:
        radial-gradient(circle at 62% 46%, rgba(142, 22, 22, 0.42), transparent 32%),
        radial-gradient(circle at 80% 24%, rgba(214, 162, 90, 0.10), transparent 20%),
        radial-gradient(circle at 28% 74%, rgba(58, 16, 14, 0.26), transparent 22%),
        linear-gradient(180deg, rgba(11, 4, 4, 0.96), rgba(4, 3, 3, 0.99));
}

/* 5 · Markers: 3-column row, never stacked */
.final-scenario-signal__markers {
    grid-area: unset;
    align-self: unset;
    order: 1;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(8px, 1.8vw, 14px);
    margin-top: 0;
}

/* Remove old separator line (was for 2-col layout) */
.final-scenario-signal__markers::before {
    display: none;
}

/* 6 · Marker cards — compact with depth */
.final-scenario-signal__marker {
    padding: clamp(14px, 2.4vw, 20px) clamp(12px, 2vw, 18px) clamp(12px, 2vw, 18px);
    gap: clamp(10px, 1.6vw, 14px);
    border-radius: clamp(14px, 2vw, 20px);
}

/* 7 · Signal labels — calibrated for full-width visual */
.final-scenario-signal__system-label--signal {
    top: 16%;
    right: 4%;
}

.final-scenario-signal__system-label--pattern {
    top: 36%;
    right: 1%;
}

.final-scenario-signal__system-label--direction {
    top: 57%;
    right: 3%;
}

.final-scenario-signal__system-label--stability {
    top: 76%;
    right: 6%;
}

/* 8 · Eyebrow color — warm red, matches reference */
.final-scenario-signal__label {
    color: rgba(218, 100, 85, 0.90);
    font-size: 11px;
    letter-spacing: 0.20em;
}

/* 9 · Headline — large cinematic serif */
.final-scenario-signal__copy h2 {
    font-size: clamp(44px, 12vw, 70px);
    line-height: 0.95;
    max-width: 7.2ch;
    gap: 1px;
    letter-spacing: -0.035em;
}

/* 10 · Body text — refined, compact */
.final-scenario-signal__copy > p {
    font-size: clamp(14px, 3.8vw, 18px);
    line-height: 1.55;
    max-width: 20ch;
    color: rgba(244, 238, 230, 0.60);
}

/* 11 · CTA — premium red volumetric button */
.final-scenario-signal__cta {
    min-height: clamp(68px, 11vw, 86px);
    border-radius: clamp(16px, 2.8vw, 22px);
    border-color: rgba(218, 78, 68, 0.54);
    background:
        linear-gradient(160deg, rgba(136, 24, 24, 0.98) 0%, rgba(94, 14, 14, 0.98) 55%, rgba(70, 10, 10, 0.98)),
        radial-gradient(circle at 50% 114%, rgba(238, 98, 78, 0.32), transparent 48%);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.15),
        inset 0 10px 22px rgba(255, 198, 166, 0.04),
        inset 0 -16px 32px rgba(58, 8, 8, 0.40),
        inset 0 0 52px rgba(198, 38, 38, 0.18),
        0 16px 40px rgba(98, 16, 16, 0.44),
        0 4px 14px rgba(196, 48, 48, 0.20);
}

/* 12 · CTA typography balance */
.final-scenario-signal__cta-copy {
    font-size: clamp(17px, 4.4vw, 21px);
    letter-spacing: 0.14em;
}

/* ====================================================
   CENTRAL CORE SYSTEM — keyframe animations
   ==================================================== */
.final-scenario-signal__core-ambient {
    animation: coreAmbiencePulse 6.2s ease-in-out infinite;
    transform-box: fill-box;
    transform-origin: center;
}

.final-scenario-signal__core-orbit--lg {
    animation: coreOrbitBreath 11s ease-in-out infinite;
}

.final-scenario-signal__core-orbit--md {
    animation: coreOrbitBreath 8.5s ease-in-out -3.2s infinite;
}

.final-scenario-signal__core-orbit--sm {
    animation: coreOrbitBreath 6.2s ease-in-out -1.6s infinite;
}

.final-scenario-signal__core-dot {
    animation: coreGlowPulse 3.8s ease-in-out infinite;
    transform-box: fill-box;
    transform-origin: center;
}

.final-scenario-signal__core-center {
    animation: coreCenterFlash 3.8s ease-in-out -0.95s infinite;
}

@keyframes coreAmbiencePulse {
    0%, 100% { opacity: 0.26; transform: scale(0.88); }
    50%       { opacity: 0.52; transform: scale(1.12); }
}

@keyframes coreOrbitBreath {
    0%, 100% { opacity: 0.20; }
    50%       { opacity: 0.54; }
}

@keyframes coreGlowPulse {
    0%, 100% { opacity: 0.65; transform: scale(0.88); }
    50%       { opacity: 1.00; transform: scale(1.14); }
}

@keyframes coreCenterFlash {
    0%, 100%  { opacity: 0.70; }
    46%, 54%  { opacity: 1.00; }
}

/* ====================================================
   MOBILE OVERRIDES — cinematic on small screens
   ==================================================== */
@media (max-width: 760px) {
    .final-scenario-signal__inner {
        padding: 18px 16px 22px;
        border-radius: 24px;
    }

    .final-scenario-signal__grid {
        gap: 12px;
    }

    .final-scenario-signal__visual {
        min-height: clamp(360px, 98vw, 470px);
        border-radius: 18px;
    }

    .final-scenario-signal__copy {
        right: 48%;
        gap: 14px;
    }

    .final-scenario-signal__copy h2 {
        font-size: clamp(38px, 11vw, 52px);
        max-width: 7.8ch;
    }

    .final-scenario-signal__copy > p {
        font-size: clamp(13px, 3.5vw, 16px);
        line-height: 1.50;
    }

    /* Force 3-column markers even on narrow screens */
    .final-scenario-signal__markers {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        gap: 7px;
        margin-top: 0 !important;
    }

    .final-scenario-signal__marker {
        padding: 12px 10px 12px;
        gap: 9px;
        border-radius: 14px;
    }

    .final-scenario-signal__marker strong {
        font-size: 10px;
        letter-spacing: 0.12em;
    }

    .final-scenario-signal__marker p {
        font-size: 11px;
        line-height: 1.38;
        max-width: none;
    }

    .final-scenario-signal__system-label {
        min-width: 0;
        gap: 5px;
        font-size: 9px;
    }

    .final-scenario-signal__system-label strong {
        font-size: 10px;
    }

    .final-scenario-signal__system-label span {
        font-size: 10px;
    }

    .final-scenario-signal__system-label::before {
        width: 20px;
        right: calc(100% + 8px);
    }

    .final-scenario-signal__system-label::after {
        right: calc(100% + 6px);
        width: 6px;
        height: 6px;
    }

    .final-scenario-signal__cta {
        min-height: 64px;
        border-radius: 16px;
        padding: 0 16px;
    }

    .final-scenario-signal__cta-copy {
        font-size: clamp(15px, 4.2vw, 18px);
        letter-spacing: 0.12em;
    }

    .final-scenario-signal__lock-note {
        font-size: 12px;
    }
}

/* ================================================================
   FINAL SIGNAL — VISUAL BALANCE v2
   Fixes: ambient glow conflict, orbit scale, CTA weight, cards
   ================================================================ */

/* Inner card — calibrated atmosphere, no aggressive glow */
.final-scenario-signal__inner {
    background:
        radial-gradient(circle at 64% 40%, rgba(114, 17, 17, 0.22), transparent 28%),
        radial-gradient(circle at 80% 72%, rgba(90, 28, 15, 0.08), transparent 20%),
        radial-gradient(circle at 20% 14%, rgba(50, 17, 11, 0.08), transparent 18%),
        linear-gradient(180deg, #070404 0%, #050505 100%);
    box-shadow:
        inset 0 0 0 1px rgba(255, 255, 255, 0.03),
        inset 0 -52px 90px rgba(128, 20, 20, 0.07),
        0 22px 52px rgba(0, 0, 0, 0.44);
}

/* Visual panel — clean dark, CSS radial handles the atmospheric center glow */
.final-scenario-signal__visual {
    background:
        radial-gradient(circle at 60% 46%, rgba(118, 19, 19, 0.26), transparent 24%),
        radial-gradient(circle at 78% 22%, rgba(174, 128, 70, 0.05), transparent 14%),
        radial-gradient(circle at 26% 74%, rgba(40, 11, 9, 0.16), transparent 16%),
        linear-gradient(180deg, rgba(8, 3, 3, 0.97), rgba(3, 2, 2, 0.99));
}

/* Copy — breathing top offset, refined gap */
.final-scenario-signal__copy {
    padding-top: clamp(4px, 0.8vw, 8px);
    gap: clamp(12px, 2vw, 18px);
}

/* Headline — cinematic serif, clean rhythm */
.final-scenario-signal__copy h2 {
    font-size: clamp(42px, 11.4vw, 64px);
    line-height: 0.96;
    max-width: 7.4ch;
    gap: 2px;
    letter-spacing: -0.03em;
}

/* Body text — legible and airy */
.final-scenario-signal__copy > p {
    font-size: clamp(13px, 3.5vw, 16px);
    line-height: 1.52;
    max-width: 20ch;
    color: rgba(244, 238, 230, 0.54);
}

/* Eyebrow — warm red, reference-accurate */
.final-scenario-signal__label {
    color: rgba(212, 94, 80, 0.88);
    font-size: 11px;
    letter-spacing: 0.19em;
}

/* Marker cards — tight, proportional for 3-col narrow layout */
.final-scenario-signal__markers {
    gap: clamp(7px, 1.6vw, 12px);
}

.final-scenario-signal__marker {
    padding: clamp(12px, 1.8vw, 16px) clamp(10px, 1.5vw, 13px) clamp(12px, 1.8vw, 16px);
    gap: clamp(8px, 1.4vw, 12px);
    border-radius: clamp(12px, 1.8vw, 16px);
    border-color: rgba(196, 110, 64, 0.07);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.024),
        inset 0 0 26px rgba(142, 48, 34, 0.04);
}

.final-scenario-signal__marker-image {
    width: 18px;
    height: 18px;
}

.final-scenario-signal__marker strong {
    font-size: clamp(9px, 2.3vw, 11px);
    letter-spacing: 0.15em;
    color: rgba(226, 172, 128, 0.84);
}

.final-scenario-signal__marker p {
    font-size: clamp(10px, 2.6vw, 12px);
    line-height: 1.40;
    max-width: none;
    color: rgba(244, 238, 230, 0.50);
}

/* CTA — elegant proportions, premium red, not aggressive */
.final-scenario-signal__cta {
    min-height: clamp(58px, 8vw, 68px);
    border-radius: clamp(14px, 2vw, 18px);
    border-color: rgba(206, 68, 58, 0.44);
    background:
        linear-gradient(165deg, rgba(126, 21, 21, 0.98) 0%, rgba(88, 13, 13, 0.98) 56%, rgba(66, 10, 10, 0.98)),
        radial-gradient(circle at 50% 114%, rgba(224, 90, 70, 0.22), transparent 42%);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.11),
        inset 0 -10px 24px rgba(48, 7, 7, 0.28),
        inset 0 0 40px rgba(182, 34, 34, 0.09),
        0 10px 28px rgba(84, 13, 13, 0.32),
        0 2px 8px rgba(172, 40, 40, 0.10);
}

.final-scenario-signal__cta-copy {
    font-size: clamp(16px, 4.1vw, 19px);
    letter-spacing: 0.13em;
}

/* Lock note — very subtle */
.final-scenario-signal__lock-note {
    color: rgba(244, 238, 230, 0.36);
    font-size: clamp(11px, 2.8vw, 13px);
}

.final-scenario-signal__lock-note::before {
    display: none;
}

/* Core system — remove animation on --md which was removed from SVG */
.final-scenario-signal__core-orbit--md {
    display: none;
}

/* Mobile calibration v2 */
@media (max-width: 760px) {
    .final-scenario-signal__inner {
        padding: 18px 16px 20px;
    }

    .final-scenario-signal__copy h2 {
        font-size: clamp(36px, 10.5vw, 48px);
        max-width: 8ch;
    }

    .final-scenario-signal__copy > p {
        font-size: clamp(12px, 3.2vw, 15px);
    }

    .final-scenario-signal__cta {
        min-height: 58px;
        padding: 0 14px;
    }

    .final-scenario-signal__cta-copy {
        font-size: clamp(14px, 3.9vw, 17px);
        letter-spacing: 0.11em;
    }

    .final-scenario-signal__lock-note {
        font-size: 11px;
    }
}

/* ================================================================
   FINAL SIGNAL — HIERARCHY CORRECTION v3
   Root fixes: signal label positions, headline breathing,
   restrained dark atmosphere, card/CTA proportions
   ================================================================ */

/* ── 1. SIGNAL LABEL POSITIONS ──
   Reference: labels are in the RIGHT-CENTER area of the visual,
   starting roughly where the headline ENDS, cascading down.
   Core (cy=240, rendered ~48% height) sits between СИГНАЛ and ПАТТЕРН.
   Old values were 16/36/57/76% — way too high, colliding with headline. */
.final-scenario-signal__system-label--signal {
    top: 39%;
    right: 4%;
}

.final-scenario-signal__system-label--pattern {
    top: 52%;
    right: 0%;
}

.final-scenario-signal__system-label--direction {
    top: 66%;
    right: 3%;
}

.final-scenario-signal__system-label--stability {
    top: 80%;
    right: 6%;
}

/* ── 2. HEADLINE — line-height was 0.96 (crushing lines)
   Reference shows clear breathing between each word-line.
   1.06 restores the cinematic editorial spacing. */
.final-scenario-signal__copy h2 {
    font-size: clamp(38px, 10vw, 58px);
    line-height: 1.06;
    letter-spacing: -0.022em;
    max-width: 9ch;
    gap: 0;
}

/* ── 3. COPY — generous breathing between eyebrow / h2 / body */
.final-scenario-signal__copy {
    right: 48%;
    gap: clamp(14px, 2.6vw, 22px);
}

/* Extra separation above body text to distinguish from headline */
.final-scenario-signal__copy > p {
    margin-top: clamp(4px, 0.8vw, 8px);
    font-size: clamp(12px, 3.2vw, 14px);
    line-height: 1.56;
    color: rgba(244, 238, 230, 0.48);
    max-width: 22ch;
}

/* ── 4. VISUAL — taller for signal labels to reach 80% gracefully */
.final-scenario-signal__visual {
    min-height: clamp(440px, 96vw, 580px);
}

/* ── 5. ATMOSPHERE — near-black, very restrained red */
.final-scenario-signal__inner {
    background:
        radial-gradient(circle at 62% 40%, rgba(96, 13, 13, 0.15), transparent 22%),
        linear-gradient(180deg, #060404 0%, #050404 100%);
    box-shadow:
        inset 0 0 0 1px rgba(255, 255, 255, 0.025),
        0 16px 44px rgba(0, 0, 0, 0.40);
}

.final-scenario-signal__visual {
    background:
        radial-gradient(circle at 60% 46%, rgba(106, 15, 15, 0.18), transparent 20%),
        linear-gradient(180deg, rgba(7, 3, 3, 0.98), rgba(3, 1, 1, 1));
}

/* ── 6. EYEBROW — tiny, restrained */
.final-scenario-signal__label {
    font-size: 10px;
    color: rgba(196, 72, 58, 0.80);
    letter-spacing: 0.20em;
}

/* ── 7. CARDS — compact, structural, not empty containers */
.final-scenario-signal__markers {
    gap: clamp(6px, 1.4vw, 10px);
}

.final-scenario-signal__marker {
    padding: clamp(13px, 1.9vw, 17px) clamp(11px, 1.6vw, 14px);
    gap: clamp(9px, 1.4vw, 11px);
    border-radius: clamp(13px, 1.9vw, 17px);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.007), rgba(255, 255, 255, 0.002));
    border-color: rgba(172, 90, 48, 0.06);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.016),
        inset 0 0 18px rgba(124, 40, 26, 0.025);
    backdrop-filter: blur(8px);
}

.final-scenario-signal__marker strong {
    font-size: clamp(9px, 2.2vw, 11px);
    letter-spacing: 0.14em;
    color: rgba(215, 158, 112, 0.80);
}

.final-scenario-signal__marker p {
    font-size: clamp(10px, 2.5vw, 12px);
    line-height: 1.42;
    color: rgba(244, 238, 230, 0.46);
    max-width: none;
    margin: 0;
}

.final-scenario-signal__marker-image {
    width: 17px;
    height: 17px;
    filter: drop-shadow(0 0 7px rgba(218, 125, 84, 0.10));
}

/* ── 8. CTA — proportional, premium but restrained */
.final-scenario-signal__cta {
    min-height: clamp(54px, 7vw, 62px);
    border-radius: clamp(13px, 1.9vw, 17px);
    border-color: rgba(190, 55, 46, 0.36);
    background:
        linear-gradient(180deg, rgba(114, 16, 16, 0.98) 0%, rgba(82, 10, 10, 0.98) 64%, rgba(60, 7, 7, 0.98)),
        radial-gradient(circle at 50% 100%, rgba(198, 74, 56, 0.12), transparent 34%);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.08),
        inset 0 -8px 18px rgba(42, 5, 5, 0.22),
        0 5px 18px rgba(72, 10, 10, 0.20),
        0 1px 4px rgba(155, 30, 30, 0.06);
}

.final-scenario-signal__cta-copy {
    font-size: clamp(14px, 3.7vw, 17px);
    letter-spacing: 0.12em;
}

.final-scenario-signal__cta-arrow {
    font-size: clamp(18px, 4vw, 22px);
}

.final-scenario-signal__lock-note {
    color: rgba(244, 238, 230, 0.30);
    font-size: clamp(11px, 2.5vw, 12px);
}

.final-scenario-signal__footer {
    gap: 10px;
}

/* ── 9. MOBILE ── */
@media (max-width: 760px) {
    .final-scenario-signal__copy h2 {
        font-size: clamp(33px, 9.6vw, 42px);
        line-height: 1.05;
        max-width: 10ch;
    }

    .final-scenario-signal__copy {
        right: 46%;
    }

    .final-scenario-signal__visual {
        min-height: clamp(420px, 100vw, 480px);
        border-radius: 17px;
    }

    .final-scenario-signal__cta {
        min-height: 54px;
        padding: 0 14px;
    }

    .final-scenario-signal__cta-copy {
        font-size: clamp(13px, 3.6vw, 16px);
    }
}

/* ================================================================
   FINAL SIGNAL — GRID OVERLAP LAYOUT (text never clipped)
   Copy and Visual share the same grid cell.
   Row height = max(copy natural height, visual min-height).
   Copy sits on top (z-index 5), visual stretches behind.
   No overflow:hidden clipping on text possible.
   ================================================================ */

/* Grid: single column, copy+visual in row 1, markers in row 2 */
.final-scenario-signal__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: clamp(14px, 2.5vw, 20px);
    align-items: unset;
}

/* Copy: relative, in row 1, left side via padding-right */
.final-scenario-signal__copy {
    position: relative;
    grid-row: 1;
    grid-column: 1;
    z-index: 5;
    align-self: start;
    /* Right padding reserves space for the network scene */
    padding-right: 52%;
    padding-top: clamp(4px, 0.8vw, 8px);
    padding-left: 0;
    padding-bottom: clamp(24px, 4vw, 40px);
    /* Clear all previous absolute positioning */
    top: unset;
    left: unset;
    right: unset;
    bottom: unset;
    pointer-events: auto;
}

/* Visual: in the same row 1 cell, stretches full height */
.final-scenario-signal__visual {
    grid-row: 1;
    grid-column: 1;
    align-self: stretch;
    z-index: 2;
    order: unset;
    flex: unset;
    width: 100%;
    min-height: clamp(400px, 88vw, 560px);
}

/* Markers: row 2 */
.final-scenario-signal__markers {
    grid-row: 2;
    grid-column: 1;
    order: unset;
}

/* Headline within relative-flow copy */
.final-scenario-signal__copy h2 {
    font-size: clamp(38px, 10vw, 58px);
    line-height: 1.06;
    max-width: none;
    gap: 0;
    letter-spacing: -0.022em;
}

/* Body text */
.final-scenario-signal__copy > p {
    max-width: none;
    margin-top: clamp(4px, 0.8vw, 8px);
}

/* Mobile */
@media (max-width: 760px) {
    .final-scenario-signal__copy {
        padding-right: 50%;
        padding-bottom: clamp(20px, 4vw, 32px);
    }

    .final-scenario-signal__copy h2 {
        font-size: clamp(33px, 9.6vw, 42px);
        line-height: 1.05;
    }

    .final-scenario-signal__visual {
        min-height: clamp(380px, 92vw, 460px);
    }
}

/* =====================================================
   CHOICE ASSISTANTS - three internal modes
   ===================================================== */

.choice-assistants {
    width: 100%;
    padding: 0 var(--gutter);
}

body[data-page="vybor-home"] .product-home > .choice-assistants {
    order: 3;
}

.choice-assistants__shell {
    position: relative;
    overflow: hidden;
    padding: clamp(18px, 5vw, 26px);
    border: 1px solid rgba(201, 161, 108, 0.12);
    border-radius: 28px;
    background:
        radial-gradient(circle at 16% 0%, rgba(201, 161, 108, 0.13), transparent 32%),
        radial-gradient(circle at 86% 18%, rgba(143, 32, 41, 0.20), transparent 34%),
        linear-gradient(180deg, rgba(14, 12, 12, 0.98) 0%, rgba(6, 6, 7, 0.99) 100%);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.05),
        0 24px 70px rgba(0, 0, 0, 0.44);
    isolation: isolate;
}

.choice-assistants__shell::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    background:
        linear-gradient(90deg, transparent 0 14px, rgba(255, 255, 255, 0.028) 14px 15px, transparent 15px 100%),
        linear-gradient(180deg, transparent 0 14px, rgba(255, 255, 255, 0.022) 14px 15px, transparent 15px 100%);
    background-size: 30px 30px;
    mask-image: radial-gradient(circle at 50% 18%, black, transparent 74%);
    opacity: 0.45;
}

.choice-assistants__halo {
    position: absolute;
    right: -62px;
    top: -62px;
    width: 190px;
    height: 190px;
    border: 1px solid rgba(201, 161, 108, 0.12);
    border-radius: 50%;
    background: radial-gradient(circle, rgba(201, 161, 108, 0.10), transparent 64%);
    filter: blur(0.2px);
    pointer-events: none;
}

.choice-assistants__header {
    position: relative;
    display: grid;
    gap: 9px;
    margin-bottom: 18px;
}

.choice-assistants__eyebrow {
    color: rgba(201, 161, 108, 0.72);
    font-size: 10px;
    font-weight: 800;
    line-height: 1;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}

.choice-assistants__header h2 {
    max-width: 8.5em;
    margin: 0;
    color: var(--text);
    font-family: "Cormorant Garamond", serif;
    font-size: clamp(38px, 10.8vw, 54px);
    font-weight: 600;
    line-height: 0.92;
    letter-spacing: -0.028em;
    text-wrap: balance;
}

.choice-assistants__header p {
    max-width: 34ch;
    margin: 0;
    color: rgba(246, 240, 234, 0.58);
    font-size: 14px;
    line-height: 1.55;
}

.choice-assistants__cards {
    display: grid;
    gap: 12px;
}

.choice-assistant-card {
    --assistant-accent: #c9a16c;
    --assistant-accent-rgb: 201, 161, 108;
    position: relative;
    display: grid;
    gap: 13px;
    overflow: hidden;
    padding: 16px;
    border: 1px solid rgba(var(--assistant-accent-rgb), 0.20);
    border-radius: 22px;
    background:
        radial-gradient(circle at 14% 8%, rgba(var(--assistant-accent-rgb), 0.16), transparent 36%),
        radial-gradient(circle at 96% 100%, rgba(255, 255, 255, 0.035), transparent 34%),
        linear-gradient(160deg, rgba(22, 20, 20, 0.98) 0%, rgba(9, 9, 10, 0.99) 100%);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.045),
        0 12px 34px rgba(0, 0, 0, 0.30);
}

.choice-assistant-card::before {
    content: "";
    position: absolute;
    left: 18px;
    right: 18px;
    top: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(var(--assistant-accent-rgb), 0.34), transparent);
    pointer-events: none;
}

.choice-assistant-card--gold {
    --assistant-accent: #e8a849;
    --assistant-accent-rgb: 232, 168, 73;
}

.choice-assistant-card--ember {
    --assistant-accent: #e0563f;
    --assistant-accent-rgb: 224, 86, 63;
}

.choice-assistant-card--ruby {
    --assistant-accent: #c8341f;
    --assistant-accent-rgb: 200, 52, 31;
}

.choice-assistant-card__head {
    position: relative;
    display: grid;
    grid-template-columns: 52px minmax(0, 1fr) auto;
    align-items: center;
    gap: 12px;
}

.choice-assistant-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    border: 1px solid rgba(var(--assistant-accent-rgb), 0.22);
    border-radius: 18px;
    background:
        radial-gradient(circle at 40% 32%, rgba(var(--assistant-accent-rgb), 0.23), transparent 56%),
        linear-gradient(180deg, rgba(42, 28, 18, 0.88), rgba(12, 10, 9, 0.96));
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.05),
        0 0 18px rgba(var(--assistant-accent-rgb), 0.13);
}

.choice-assistant-card__icon img {
    display: block;
    width: 34px;
    height: 34px;
    object-fit: contain;
    filter: drop-shadow(0 0 8px rgba(var(--assistant-accent-rgb), 0.30));
}

.choice-assistant-card__titlebox {
    min-width: 0;
}

.choice-assistant-card__titlebox h3 {
    margin: 0;
    color: rgba(246, 240, 234, 0.97);
    font-family: "Cormorant Garamond", serif;
    font-size: clamp(24px, 6vw, 31px);
    font-weight: 600;
    line-height: 0.98;
    letter-spacing: -0.018em;
}

.choice-assistant-card__titlebox p {
    margin: 4px 0 0;
    color: rgba(246, 240, 234, 0.54);
    font-size: 13px;
    line-height: 1.32;
}

.choice-assistant-card__tag {
    align-self: start;
    margin-top: 4px;
    padding: 5px 9px;
    border: 1px solid rgba(var(--assistant-accent-rgb), 0.35);
    border-radius: 999px;
    color: var(--assistant-accent);
    background: rgba(var(--assistant-accent-rgb), 0.065);
    font-size: 10px;
    font-weight: 700;
    line-height: 1;
    white-space: nowrap;
}

.choice-assistant-card__result {
    margin: 0;
    color: rgba(246, 240, 234, 0.76);
    font-size: 14px;
    font-weight: 600;
    line-height: 1.52;
}

.choice-assistant-card__example {
    display: grid;
    gap: 7px;
    padding: 13px 14px;
    border: 1px solid rgba(246, 240, 234, 0.045);
    border-radius: 16px;
    background:
        radial-gradient(circle at 92% 14%, rgba(var(--assistant-accent-rgb), 0.08), transparent 30%),
        rgba(0, 0, 0, 0.34);
}

.choice-assistant-card__example span {
    color: rgba(246, 240, 234, 0.34);
    font-size: 10px;
    font-weight: 800;
    line-height: 1;
    letter-spacing: 0.13em;
    text-transform: uppercase;
}

.choice-assistant-card__example strong {
    color: rgba(246, 240, 234, 0.94);
    font-size: 14px;
    font-weight: 700;
    line-height: 1.42;
}

.choice-assistant-card__example p {
    margin: 0;
    color: rgba(246, 240, 234, 0.66);
    font-size: 13px;
    line-height: 1.48;
}

.choice-assistant-card__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 48px;
    padding: 0 16px;
    border: 1px solid rgba(var(--assistant-accent-rgb), 0.38);
    border-radius: 15px;
    color: rgba(255, 238, 202, 0.96);
    background:
        linear-gradient(180deg, rgba(var(--assistant-accent-rgb), 0.22), rgba(var(--assistant-accent-rgb), 0.10)),
        rgba(20, 11, 5, 0.78);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.06),
        0 0 18px rgba(var(--assistant-accent-rgb), 0.10);
    font-size: 14px;
    font-weight: 800;
    text-decoration: none;
    transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}

.choice-assistant-card__button:active {
    transform: scale(0.985);
}

@media (hover: hover) {
    .choice-assistant-card__button:hover {
        border-color: rgba(var(--assistant-accent-rgb), 0.60);
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, 0.08),
            0 0 26px rgba(var(--assistant-accent-rgb), 0.18);
        transform: translateY(-1px);
    }
}

@media (max-width: 380px) {
    .choice-assistants__shell {
        padding: 15px;
        border-radius: 24px;
    }

    .choice-assistant-card {
        padding: 14px;
        border-radius: 20px;
    }

    .choice-assistant-card__head {
        grid-template-columns: 46px minmax(0, 1fr);
        gap: 10px;
    }

    .choice-assistant-card__icon {
        width: 46px;
        height: 46px;
        border-radius: 16px;
    }

    .choice-assistant-card__icon img {
        width: 30px;
        height: 30px;
    }

    .choice-assistant-card__tag {
        grid-column: 2 / 3;
        justify-self: start;
        margin-top: -2px;
    }
}

/* =====================================================
   CHOICE CLUB / intensive promo
   ===================================================== */

.choice-club {
    width: 100%;
}

.choice-club__shell {
    position: relative;
    display: grid;
    gap: 18px;
    overflow: hidden;
    padding: 24px 20px;
    border: 1px solid rgba(216, 173, 101, 0.34);
    border-radius: 24px;
    background:
        radial-gradient(circle at 86% 0%, rgba(216, 173, 101, 0.20), transparent 36%),
        radial-gradient(circle at 8% 16%, rgba(173, 39, 50, 0.30), transparent 42%),
        linear-gradient(160deg, rgba(35, 14, 15, 0.98) 0%, rgba(18, 8, 8, 0.99) 56%, rgba(8, 6, 6, 0.99) 100%);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.06),
        inset 0 0 54px rgba(200, 52, 31, 0.05),
        0 24px 64px rgba(0, 0, 0, 0.44);
    isolation: isolate;
}

.choice-club__shell::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    background:
        linear-gradient(90deg, transparent 0 18px, rgba(245, 217, 168, 0.035) 18px 19px, transparent 19px 100%),
        linear-gradient(180deg, transparent 0 18px, rgba(245, 217, 168, 0.024) 18px 19px, transparent 19px 100%);
    background-size: 38px 38px;
    mask-image: radial-gradient(circle at 46% 18%, black, transparent 76%);
    opacity: 0.34;
}

.choice-club__shell::after {
    content: "";
    position: absolute;
    left: 22px;
    right: 22px;
    top: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(245, 217, 168, 0.42), rgba(200, 52, 31, 0.40), transparent);
    pointer-events: none;
}

.choice-club__glow {
    position: absolute;
    z-index: -1;
    border-radius: 999px;
    pointer-events: none;
}

.choice-club__glow--top {
    top: -72px;
    right: -72px;
    width: 190px;
    height: 190px;
    background: radial-gradient(circle, rgba(200, 52, 31, 0.25), transparent 67%);
    filter: blur(4px);
}

.choice-club__glow--bottom {
    left: -56px;
    bottom: 80px;
    width: 150px;
    height: 150px;
    border: 1px solid rgba(232, 168, 73, 0.12);
    background: radial-gradient(circle, rgba(232, 168, 73, 0.10), transparent 68%);
}

.choice-club__header {
    position: relative;
    display: grid;
    gap: 13px;
}

.choice-club__eyebrow,
.choice-club__sale-label {
    width: fit-content;
    max-width: 100%;
    padding: 6px 10px;
    border: 1px solid rgba(216, 173, 101, 0.30);
    border-radius: 999px;
    background: rgba(216, 173, 101, 0.08);
    color: rgba(232, 168, 73, 0.88);
    font-size: 10px;
    font-weight: 800;
    line-height: 1;
    letter-spacing: 0;
    text-transform: uppercase;
}

.choice-club__title-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 18px;
    align-items: end;
}

.choice-club__header h2 {
    margin: 0;
    color: rgba(245, 217, 168, 0.98);
    font-family: "Cormorant Garamond", serif;
    font-size: clamp(44px, 10.5vw, 50px);
    font-weight: 600;
    line-height: 0.94;
    letter-spacing: 0;
    text-shadow: 0 0 24px rgba(232, 168, 73, 0.12);
    text-wrap: balance;
}

.choice-club__date-badge {
    display: grid;
    gap: 4px;
    min-width: 100px;
    padding: 10px 11px;
    border: 1px solid rgba(216, 173, 101, 0.30);
    border-radius: 16px;
    background:
        radial-gradient(circle at 50% 0%, rgba(216, 173, 101, 0.16), transparent 62%),
        rgba(216, 173, 101, 0.08);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05);
    text-align: center;
}

.choice-club__date-badge span {
    color: rgba(246, 240, 234, 0.56);
    font-size: 9px;
    font-weight: 800;
    letter-spacing: 0;
    line-height: 1;
    text-transform: uppercase;
}

.choice-club__date-badge strong {
    color: rgba(245, 217, 168, 0.98);
    font-size: 14px;
    font-weight: 900;
    line-height: 1.05;
}

.choice-club__header p {
    max-width: 37ch;
    margin: 0;
    color: rgba(246, 240, 234, 0.82);
    font-size: 15px;
    font-weight: 600;
    line-height: 1.54;
}

.choice-club__header p strong {
    color: rgba(245, 217, 168, 0.98);
    font-weight: 800;
}

.choice-club__features {
    display: grid;
    gap: 0;
}

.choice-club__program {
    display: grid;
    gap: 12px;
    padding: 16px;
    border: 1px solid rgba(245, 217, 168, 0.10);
    border-radius: 18px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.022)),
        rgba(255, 255, 255, 0.02);
}

.choice-club__program > span {
    color: rgba(245, 217, 168, 0.96);
    font-size: 10px;
    font-weight: 900;
    letter-spacing: 0;
    line-height: 1;
    text-transform: uppercase;
}

.choice-club__program ul {
    display: grid;
    gap: 10px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.choice-club__program li {
    position: relative;
    margin: 0;
    padding-left: 18px;
    color: rgba(246, 240, 234, 0.72);
    font-size: 13px;
    font-weight: 500;
    line-height: 1.42;
}

.choice-club__program li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.62em;
    width: 7px;
    height: 7px;
    border-radius: 999px;
    background: #b42b45;
    box-shadow: 0 0 12px rgba(180, 43, 69, 0.62);
}

.choice-club-feature {
    position: relative;
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr);
    gap: 12px;
    align-items: center;
    padding: 14px 0;
    border-top: 1px solid rgba(245, 217, 168, 0.08);
}

.choice-club-feature:first-child {
    border-top-color: rgba(245, 217, 168, 0.12);
}

.choice-club-feature__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border: 1px solid rgba(232, 168, 73, 0.16);
    border-radius: 15px;
    background:
        radial-gradient(circle at 44% 34%, rgba(232, 168, 73, 0.22), transparent 58%),
        linear-gradient(180deg, rgba(45, 22, 14, 0.94), rgba(16, 8, 7, 0.96));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.045);
}

.choice-club-feature__icon img {
    display: block;
    width: 26px;
    height: 26px;
    object-fit: contain;
    filter: sepia(0.25) saturate(1.12) drop-shadow(0 0 8px rgba(232, 168, 73, 0.22));
}

.choice-club-feature__copy {
    min-width: 0;
    display: grid;
    gap: 3px;
}

.choice-club-feature__copy strong {
    color: rgba(246, 240, 234, 0.96);
    font-family: "Cormorant Garamond", serif;
    font-size: clamp(22px, 5.5vw, 27px);
    font-weight: 600;
    line-height: 0.98;
    letter-spacing: -0.018em;
}

.choice-club-feature__copy span {
    color: rgba(246, 240, 234, 0.50);
    font-size: 13px;
    line-height: 1.34;
}

.choice-club__sale {
    position: relative;
    display: grid;
    gap: 10px;
    overflow: hidden;
    padding: 18px;
    border: 1px solid rgba(232, 168, 73, 0.30);
    border-radius: 20px;
    background:
        radial-gradient(circle at 86% 0%, rgba(232, 168, 73, 0.12), transparent 34%),
        linear-gradient(180deg, rgba(27, 12, 9, 0.95), rgba(15, 7, 7, 0.98));
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.04),
        0 14px 32px rgba(0, 0, 0, 0.25);
}

.choice-club__sale strong {
    color: rgba(245, 217, 168, 0.98);
    font-family: "Cormorant Garamond", serif;
    font-size: 30px;
    font-weight: 600;
    line-height: 0.95;
}

.choice-club__cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 56px;
    width: 100%;
    margin-top: 2px;
    padding: 0 18px;
    border: 1px solid rgba(255, 116, 92, 0.30);
    border-radius: 16px;
    color: #fff;
    background:
        linear-gradient(180deg, rgba(218, 55, 35, 0.98), rgba(180, 38, 25, 0.98)),
        radial-gradient(circle at 50% 100%, rgba(255, 188, 118, 0.22), transparent 38%);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.14),
        0 12px 28px rgba(158, 34, 24, 0.32);
    font-size: 16px;
    font-weight: 800;
    line-height: 1;
    text-decoration: none;
    transition: transform 180ms ease, filter 180ms ease, box-shadow 180ms ease;
}

.choice-club__cta:active {
    transform: scale(0.985);
}

.choice-club__sale p {
    margin: 0;
    color: rgba(246, 240, 234, 0.48);
    font-size: 12px;
    line-height: 1.42;
    text-align: center;
}

.choice-club__sale--cta {
    padding: 0;
    border: 0;
    border-radius: 18px;
    background: transparent;
    box-shadow: none;
}

@media (hover: hover) {
    .choice-club__cta:hover {
        filter: brightness(1.06);
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, 0.16),
            0 16px 34px rgba(158, 34, 24, 0.42);
        transform: translateY(-1px);
    }
}

@media (max-width: 380px) {
    .choice-club__shell {
        gap: 18px;
        padding: 19px 16px;
        border-radius: 24px;
    }

    .choice-club__title-row {
        grid-template-columns: 1fr;
        align-items: start;
    }

    .choice-club__header h2 {
        font-size: 42px;
    }

    .choice-club__date-badge {
        min-width: 112px;
        text-align: left;
    }

    .choice-club-feature {
        grid-template-columns: 38px minmax(0, 1fr);
        gap: 10px;
        padding: 12px 0;
    }

    .choice-club-feature__icon {
        width: 38px;
        height: 38px;
        border-radius: 14px;
    }

    .choice-club-feature__icon img {
        width: 23px;
        height: 23px;
    }

    .choice-club-feature__copy strong {
        font-size: 21px;
    }

    .choice-club__sale {
        padding: 16px;
        border-radius: 18px;
    }
}

body[data-page="vybor-home"] .product-home > .mystic-hero .dynamic-cta {
    cursor: pointer !important;
    border: 1px solid rgba(255, 167, 150, 0.58) !important;
    background:
        linear-gradient(180deg, rgba(234, 75, 62, 0.98), rgba(164, 34, 38, 0.99)),
        radial-gradient(circle at var(--cta-pointer-x, 50%) var(--cta-pointer-y, 50%), rgba(255, 223, 190, 0.24), transparent 34%) !important;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.18),
        inset 0 -18px 34px rgba(80, 10, 14, 0.22),
        0 18px 42px rgba(104, 20, 24, 0.42),
        0 0 0 1px rgba(255, 212, 190, 0.08) !important;
    filter: saturate(1.06) !important;
    transition:
        transform 180ms ease,
        filter 180ms ease,
        border-color 180ms ease,
        box-shadow 180ms ease,
        background 180ms ease !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .dynamic-cta__icon,
body[data-page="vybor-home"] .product-home > .mystic-hero .dynamic-cta__arrow {
    transition: transform 180ms ease, background 180ms ease, box-shadow 180ms ease !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .dynamic-cta:focus-visible {
    outline: 2px solid rgba(255, 223, 190, 0.72) !important;
    outline-offset: 4px !important;
}

body[data-page="vybor-home"] .product-home > .mystic-hero .dynamic-cta.is-pressed,
body[data-page="vybor-home"] .product-home > .mystic-hero .dynamic-cta:active {
    transform: translateY(1px) scale(0.992) !important;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.12),
        inset 0 10px 24px rgba(72, 8, 12, 0.22),
        0 10px 24px rgba(104, 20, 24, 0.34) !important;
}

@media (hover: hover) and (pointer: fine) {
    body[data-page="vybor-home"] .product-home > .mystic-hero .dynamic-cta:hover {
        border-color: rgba(255, 216, 190, 0.84) !important;
        filter: brightness(1.08) saturate(1.14) !important;
        transform: translateY(-2px) scale(1.01) !important;
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, 0.24),
            inset 0 -18px 34px rgba(80, 10, 14, 0.16),
            0 24px 52px rgba(125, 25, 26, 0.5),
            0 0 0 1px rgba(255, 230, 204, 0.18) !important;
    }

    body[data-page="vybor-home"] .product-home > .mystic-hero .dynamic-cta:hover .dynamic-cta__icon {
        transform: translateX(2px) rotate(4deg) scale(1.06) !important;
        box-shadow: 0 0 22px rgba(255, 210, 170, 0.2) !important;
    }

    body[data-page="vybor-home"] .product-home > .mystic-hero .dynamic-cta:hover .dynamic-cta__arrow {
        transform: translateX(4px) !important;
    }
}
