:root {
    --pointer-x: 0;
    --pointer-y: 0;
    --bg-void: #040916;
    --bg-deep: #081121;
    --panel: rgba(10, 20, 41, 0.86);
    --panel-strong: rgba(13, 27, 52, 0.94);
    --panel-light: rgba(246, 250, 255, 0.94);
    --text-main: #f4f8ff;
    --text-soft: #dbe7fb;
    --text-muted: #abc0df;
    --text-dark: #0b1830;
    --text-dark-soft: #48607f;
    --border-soft: rgba(255, 255, 255, 0.08);
    --border-strong: rgba(128, 189, 255, 0.22);
    --accent-blue: #59c9ff;
    --accent-cobalt: #2f7cff;
    --accent-amber: #ffbd6b;
    --accent-mint: #54f0d5;
    --accent-violet: #8ea0ff;
    --shadow-deep: 0 40px 120px rgba(0, 0, 0, 0.42);
    --shadow-soft: 0 24px 80px rgba(5, 15, 34, 0.18);
    --radius-xl: 36px;
    --radius-lg: 28px;
    --radius-md: 22px;
}

/* FineCon OS device showcase system */
html,
body {
    overflow-x: hidden;
}

.phone-stage-shell {
    align-items: center;
    justify-items: center;
}

.phone-showcase-board {
    position: relative;
    width: min(100%, 408px) !important;
    margin: clamp(0.2rem, 1vw, 0.9rem) auto 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    overflow: visible !important;
    transform: none !important;
}

.phone-showcase-board::before,
.phone-showcase-board::after {
    display: none !important;
}

.device-frame {
    position: relative;
    width: min(100%, 374px);
    margin-inline: auto;
    padding-bottom: 18px;
    filter: drop-shadow(0 16px 30px rgba(0, 0, 0, 0.2));
}

.device-frame--pocket {
    width: min(100%, 392px);
}

.device-frame--pocketDetail {
    width: min(100%, 356px);
}

.device-frame::before {
    content: "";
    position: absolute;
    left: 9%;
    right: 9%;
    bottom: 2px;
    height: 44px;
    border-radius: 999px;
    background: radial-gradient(ellipse at center, rgba(0, 0, 0, 0.54), rgba(0, 0, 0, 0.14) 54%, transparent 78%);
    filter: blur(14px);
    opacity: 0.78;
    pointer-events: none;
}

.device-frame::after {
    content: "";
    position: absolute;
    left: 16%;
    right: 16%;
    bottom: 16px;
    height: 18px;
    border-radius: 999px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.08), transparent);
    opacity: 0.12;
    pointer-events: none;
}

.device-frame__buttons {
    position: absolute;
    top: 0;
    bottom: 24px;
    z-index: 1;
    pointer-events: none;
}

.device-frame__buttons--left {
    left: -3px;
}

.device-frame__buttons--right {
    right: -3px;
}

.device-frame__button {
    position: absolute;
    display: block;
    border-radius: 999px;
    background: linear-gradient(180deg, rgba(43, 52, 66, 0.96), rgba(10, 14, 22, 0.98));
    box-shadow:
        inset 1px 0 0 rgba(255, 255, 255, 0.08),
        inset -1px 0 0 rgba(0, 0, 0, 0.5);
    opacity: 0.88;
}

.device-frame__button--action {
    top: 88px;
    width: 5px;
    height: 24px;
}

.device-frame__button--volume-up {
    top: 136px;
    width: 5px;
    height: 44px;
}

.device-frame__button--volume-down {
    top: 190px;
    width: 5px;
    height: 44px;
}

.device-frame__button--power {
    top: 154px;
    right: 0;
    width: 5px;
    height: 70px;
}

.device-frame__shell {
    position: relative;
    padding: 10px;
    border-radius: 46px;
    background:
        linear-gradient(180deg, rgba(28, 35, 48, 0.94), rgba(7, 11, 18, 1)),
        linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.01));
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.08),
        inset 0 -16px 28px rgba(0, 0, 0, 0.36),
        0 8px 18px rgba(0, 0, 0, 0.24),
        0 0 0 1px rgba(255, 255, 255, 0.03);
}

.device-frame__shell::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: linear-gradient(118deg, rgba(255, 255, 255, 0.16), transparent 24%, transparent 70%, rgba(255, 255, 255, 0.04));
    pointer-events: none;
}

.device-frame__shell::after {
    content: "";
    position: absolute;
    inset: 1px;
    border-radius: inherit;
    border: 1px solid rgba(255, 255, 255, 0.03);
    opacity: 0.9;
    pointer-events: none;
}

.device-frame__glass {
    position: relative;
    padding: 2px;
    border-radius: 37px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.14), rgba(255, 255, 255, 0.03) 18%, rgba(255, 255, 255, 0.02) 82%, rgba(0, 0, 0, 0.22)),
        linear-gradient(180deg, rgba(6, 9, 16, 0.96), rgba(5, 8, 14, 1));
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.08),
        inset 0 -1px 0 rgba(0, 0, 0, 0.42);
    overflow: hidden;
}

.device-frame__glass::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: linear-gradient(126deg, rgba(255, 255, 255, 0.12), transparent 18%, transparent 82%, rgba(255, 255, 255, 0.05));
    opacity: 0.58;
    pointer-events: none;
}

.device-frame__speaker {
    position: absolute;
    top: 12px;
    left: 50%;
    z-index: 4;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    width: 31%;
    height: 28px;
    transform: translateX(-50%);
    border-radius: 999px;
    background: linear-gradient(180deg, rgba(5, 8, 14, 0.96), rgba(9, 13, 21, 1));
    border: 1px solid rgba(255, 255, 255, 0.04);
    box-shadow:
        inset 0 -1px 0 rgba(255, 255, 255, 0.03),
        0 8px 18px rgba(0, 0, 0, 0.34);
}

.device-frame__speaker-slot {
    display: block;
    width: 40%;
    height: 6px;
    border-radius: 999px;
    background: linear-gradient(90deg, rgba(41, 46, 54, 0.96), rgba(17, 22, 31, 1));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

.device-frame__speaker-lens {
    display: block;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: radial-gradient(circle at 34% 34%, rgba(102, 152, 255, 0.28), rgba(7, 10, 16, 0.98) 74%);
    box-shadow:
        inset 0 1px 1px rgba(255, 255, 255, 0.14),
        0 0 0 1px rgba(255, 255, 255, 0.04);
}

.device-frame__reflection {
    position: absolute;
    top: 18px;
    left: 18px;
    z-index: 4;
    width: 34%;
    height: 14px;
    border-radius: 999px;
    background: linear-gradient(102deg, rgba(255, 255, 255, 0.22), rgba(255, 255, 255, 0.06) 46%, rgba(255, 255, 255, 0));
    opacity: 0.34;
    pointer-events: none;
    transform: rotate(-10deg);
}

.device-screen {
    --device-accent-rgb: 89, 201, 255;
    --device-accent: rgb(var(--device-accent-rgb));
    --device-accent-soft: rgba(var(--device-accent-rgb), 0.12);
    --device-accent-strong: rgba(var(--device-accent-rgb), 0.26);
    --device-accent-surface: rgba(var(--device-accent-rgb), 0.14);
    position: relative;
    overflow: hidden;
    min-height: 626px;
    border-radius: 30px;
    background:
        radial-gradient(circle at 16% 10%, rgba(88, 201, 255, 0.18), transparent 24%),
        radial-gradient(circle at 82% 14%, rgba(255, 196, 112, 0.12), transparent 22%),
        linear-gradient(180deg, rgba(8, 17, 31, 1), rgba(5, 10, 20, 1));
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.07),
        inset 0 -18px 44px rgba(0, 0, 0, 0.2),
        0 20px 44px rgba(0, 0, 0, 0.28);
    transition: background 520ms cubic-bezier(0.22, 1, 0.36, 1), box-shadow 520ms cubic-bezier(0.22, 1, 0.36, 1);
}

.device-screen[data-tone="blue"] {
    --device-accent-rgb: 118, 153, 255;
}

.device-screen[data-tone="emerald"] {
    --device-accent-rgb: 91, 241, 204;
}

.device-screen[data-tone="gold"] {
    --device-accent-rgb: 255, 196, 112;
}

.device-screen[data-tone="violet"] {
    --device-accent-rgb: 157, 167, 255;
}

.device-screen::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(transparent 97%, rgba(255, 255, 255, 0.035) 100%),
        linear-gradient(90deg, transparent 97%, rgba(255, 255, 255, 0.03) 100%);
    background-size: 100% 34px, 34px 100%;
    opacity: 0.18;
    pointer-events: none;
}

.device-screen::after {
    content: "";
    position: absolute;
    inset: auto -20% -18% -20%;
    height: 220px;
    background: radial-gradient(circle, rgba(var(--device-accent-rgb), 0.22), transparent 62%);
    filter: blur(20px);
    opacity: 0.52;
    pointer-events: none;
    transition: opacity 420ms ease, filter 420ms ease, background 420ms ease;
}

.device-screen.is-resetting::after {
    opacity: 0.3;
}

.device-screen__content {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    gap: 0.58rem;
    min-height: 626px;
    padding: 2.68rem 0.9rem 0.82rem;
}

.device-frame--pocket .device-screen,
.device-frame--pocket .device-screen__content {
    min-height: 590px;
}

.device-frame--pocketDetail .device-screen,
.device-frame--pocketDetail .device-screen__content {
    min-height: 548px;
}

.device-status-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    color: rgba(234, 242, 255, 0.88);
    font-size: 0.72rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.device-status-icons {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.device-status-icons i {
    display: block;
    height: 8px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.52);
}

.device-status-icons .is-signal {
    width: 9px;
}

.device-status-icons .is-wifi {
    width: 11px;
}

.device-status-icons .is-battery {
    width: 18px;
    background: linear-gradient(90deg, #6ce0ff, #ffc36a);
}

.device-screen__ticker {
    position: absolute;
    left: -26%;
    right: -26%;
    display: flex;
    gap: 1.6rem;
    width: 152%;
    white-space: nowrap;
    color: rgba(125, 153, 190, 0.16);
    font-size: 0.63rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    pointer-events: none;
}

.device-screen__ticker span {
    display: inline-flex;
    gap: 1.6rem;
    padding-right: 1.6rem;
}

.device-screen__ticker--a {
    top: 33%;
    transform: rotate(-10deg);
    animation: deviceTickerForward 18s linear infinite;
}

.device-screen__ticker--b {
    top: 61%;
    transform: rotate(-6deg);
    animation: deviceTickerBackward 21s linear infinite;
}

.device-screen__header {
    display: grid;
    gap: 0.24rem;
}

.screen-badge {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    min-height: 30px;
    padding: 0.34rem 0.68rem;
    border-radius: 999px;
    background: rgba(89, 201, 255, 0.1);
    border: 1px solid rgba(89, 201, 255, 0.18);
    color: #8ddfff;
    font-size: 0.66rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.device-screen__eyebrow {
    color: rgba(167, 194, 228, 0.74);
    font-size: 0.7rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.device-screen__header strong {
    color: var(--text-white);
    font-size: 0.96rem;
    line-height: 1.08;
    letter-spacing: -0.04em;
}

.device-screen__header strong br {
    display: block;
    content: "";
    margin-top: 0.08em;
}

.device-screen__header p {
    color: rgba(192, 210, 233, 0.8);
    font-size: 0.7rem;
    line-height: 1.48;
}

.device-motion-layer {
    position: relative;
    display: grid;
    gap: 0.42rem;
    padding: 0.62rem 0.7rem;
    border-radius: 17px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: linear-gradient(180deg, rgba(17, 31, 54, 0.74), rgba(8, 16, 29, 0.92));
    overflow: hidden;
    isolation: isolate;
}

.device-motion-layer::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(120deg, rgba(var(--device-accent-rgb), 0.16), transparent 30%, transparent 72%, rgba(var(--device-accent-rgb), 0.1));
    opacity: 0.68;
    pointer-events: none;
}

.device-motion-layer__status {
    position: relative;
    z-index: 1;
    display: grid;
    gap: 0.58rem;
}

.device-live-cluster {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.device-live-pill {
    display: inline-flex;
    align-items: center;
    min-height: 27px;
    padding: 0.22rem 0.56rem;
    border-radius: 999px;
    border: 1px solid var(--device-accent-strong);
    background: var(--device-accent-surface);
    color: #f7fbff;
    font-size: 0.61rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    white-space: nowrap;
    transition: border-color 320ms ease, background-color 320ms ease, transform 320ms ease;
}

.device-live-dots {
    display: inline-flex;
    align-items: center;
    gap: 0.28rem;
}

.device-live-dot {
    display: block;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.2);
    box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.06);
    transition: background-color 260ms ease, box-shadow 260ms ease, transform 260ms ease, opacity 260ms ease;
    opacity: 0.75;
}

.device-live-dot.is-active {
    background: rgba(var(--device-accent-rgb), 0.92);
    box-shadow: 0 0 0 1px rgba(var(--device-accent-rgb), 0.28), 0 0 12px rgba(var(--device-accent-rgb), 0.28);
    opacity: 1;
}

.device-live-dot.is-pulse {
    animation: deviceDotPulse 2.4s ease-in-out infinite;
}

.device-live-copy {
    color: rgba(224, 234, 246, 0.9);
    font-size: 0.68rem;
    line-height: 1.48;
}

.device-progress {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.6rem;
}

.device-progress__track {
    position: relative;
    display: block;
    height: 7px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    overflow: hidden;
}

.device-progress__track i {
    position: relative;
    display: block;
    width: 0;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, rgba(var(--device-accent-rgb), 0.88), rgba(var(--device-accent-rgb), 0.52));
    box-shadow: 0 0 18px rgba(var(--device-accent-rgb), 0.22);
    transition: width 840ms cubic-bezier(0.22, 1, 0.36, 1), background 360ms ease, box-shadow 360ms ease;
    overflow: hidden;
}

.device-progress__track i::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(120deg, transparent 0%, rgba(255, 255, 255, 0.28) 48%, transparent 100%);
    transform: translateX(-130%);
    animation: deviceProgressSweep 2.9s linear infinite;
}

.device-progress__value {
    color: rgba(244, 249, 255, 0.92);
    font-size: 0.66rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    white-space: nowrap;
}

.device-decision-pills {
    position: relative;
    z-index: 1;
    display: flex;
    flex-wrap: wrap;
    gap: 0.38rem;
}

.device-decision-pill {
    display: inline-flex;
    align-items: center;
    min-height: 24px;
    padding: 0.16rem 0.48rem;
    border-radius: 999px;
    border: 1px solid rgba(var(--device-accent-rgb), 0.22);
    background: rgba(var(--device-accent-rgb), 0.1);
    color: rgba(242, 248, 255, 0.96);
    font-size: 0.56rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    animation: deviceCardRise 520ms cubic-bezier(0.22, 1, 0.36, 1) both;
    animation-delay: calc(var(--device-chip-order, 0) * 80ms);
}

.device-decision-pills.is-hidden,
.device-outcome-line.is-hidden {
    display: none;
}

.device-outcome-line {
    position: relative;
    z-index: 1;
    color: rgba(230, 239, 248, 0.88);
    font-size: 0.64rem;
    line-height: 1.52;
}

.device-motion-layer__veil {
    position: absolute;
    inset: 0;
    z-index: 3;
    background: linear-gradient(180deg, rgba(9, 16, 28, 0.04), rgba(9, 16, 28, 0.22));
    opacity: 0;
    pointer-events: none;
    transition: opacity 260ms ease;
}

.device-screen.is-transitioning .device-motion-layer__veil {
    opacity: 1;
}

.device-screen.is-paused .device-screen__ticker--a,
.device-screen.is-paused .device-screen__ticker--b,
.device-screen.is-paused .device-live-dot.is-pulse,
.device-screen.is-paused .device-progress__track i::after,
.device-screen.is-paused .screen-card__signal i::after {
    animation-play-state: paused;
}

.device-screen__rail {
    display: none;
}

.screen-chip,
.screen-footer-chip {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0.28rem 0.58rem;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.07);
    background: rgba(255, 255, 255, 0.045);
    color: rgba(214, 225, 243, 0.82);
    font-size: 0.64rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    transition: transform 320ms ease, border-color 320ms ease, background-color 320ms ease, color 320ms ease, opacity 320ms ease;
}

.screen-chip.is-complete {
    border-color: rgba(255, 255, 255, 0.1);
    color: rgba(234, 242, 252, 0.86);
}

.screen-chip.is-active {
    border-color: var(--device-accent-strong);
    background: var(--device-accent-surface);
    color: #f3fbff;
    transform: translateY(-1px);
}

.screen-footer-chip.is-active {
    border-color: var(--device-accent-strong);
    background: var(--device-accent-surface);
    color: #f3fbff;
    transform: translateY(-1px);
}

.device-screen__metrics {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 1fr;
    gap: 0.4rem;
}

.screen-metric {
    display: grid;
    gap: 0.16rem;
    padding: 0.58rem 0.6rem;
    border-radius: 15px;
    border: 1px solid rgba(255, 255, 255, 0.06);
    background: linear-gradient(180deg, rgba(18, 33, 56, 0.78), rgba(10, 18, 31, 0.92));
    transition: border-color 320ms ease, transform 320ms ease, background 320ms ease, box-shadow 320ms ease;
}

.screen-metric strong {
    color: #f6fbff;
    font-size: 0.86rem;
    font-weight: 800;
    letter-spacing: -0.04em;
    transition: color 260ms ease;
}

.screen-metric span {
    color: rgba(187, 206, 231, 0.76);
    font-size: 0.52rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.screen-metric.is-live {
    border-color: var(--device-accent-strong);
    box-shadow: inset 0 0 0 1px rgba(var(--device-accent-rgb), 0.08), 0 14px 26px rgba(0, 0, 0, 0.14);
    transform: translateY(-1px);
}

.screen-metric--cyan {
    box-shadow: inset 0 0 0 1px rgba(89, 201, 255, 0.05);
}

.screen-metric--blue {
    box-shadow: inset 0 0 0 1px rgba(118, 153, 255, 0.05);
}

.screen-metric--emerald {
    box-shadow: inset 0 0 0 1px rgba(91, 241, 204, 0.05);
}

.screen-metric--gold {
    box-shadow: inset 0 0 0 1px rgba(255, 196, 112, 0.05);
}

.screen-metric--violet {
    box-shadow: inset 0 0 0 1px rgba(157, 167, 255, 0.05);
}

.device-screen__primary {
    display: grid;
}

.device-screen__cards {
    position: relative;
    display: grid;
    gap: 0.34rem;
    flex: 0 0 auto;
    align-content: start;
    min-height: 0;
    padding-bottom: 0.12rem;
    overflow: hidden;
}

.device-screen__cards.is-empty {
    display: none;
}

.device-screen__metrics.is-hidden,
.device-screen__cards.is-hidden,
.device-screen__footer.is-hidden {
    display: none;
}

.device-screen__header--compact {
    gap: 0.34rem;
}

.device-screen__header--compact strong {
    font-size: 0.88rem;
    line-height: 1.06;
}

.device-screen__header--compact p {
    max-width: 84%;
    font-size: 0.64rem;
    line-height: 1.48;
}

.screen-card {
    --device-card-translate: 0px;
    --device-card-scale: 1;
    position: relative;
    display: grid;
    gap: 0.36rem;
    padding: 0.74rem;
    border-radius: 17px;
    border: 1px solid rgba(255, 255, 255, 0.06);
    background: linear-gradient(180deg, rgba(15, 28, 49, 0.95), rgba(6, 12, 22, 0.96));
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.04),
        0 14px 28px rgba(0, 0, 0, 0.22);
    opacity: 0.9;
    transform: translateY(var(--device-card-translate)) scale(var(--device-card-scale));
    transition: transform 360ms cubic-bezier(0.22, 1, 0.36, 1), border-color 320ms ease, background 320ms ease, opacity 320ms ease, box-shadow 320ms ease;
}

.screen-card.is-primary {
    padding: 0.86rem 0.9rem;
    background: linear-gradient(180deg, rgba(17, 33, 59, 0.98), rgba(7, 14, 24, 0.98));
    border-color: var(--device-accent-strong);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.05),
        0 18px 34px rgba(0, 0, 0, 0.28),
        0 0 0 1px rgba(var(--device-accent-rgb), 0.08);
    animation: deviceCardRise 520ms cubic-bezier(0.22, 1, 0.36, 1) both;
}

.screen-card.is-supporting {
    --device-card-translate: 2px;
    --device-card-scale: 0.988;
    opacity: 0.84;
    width: 100%;
    max-width: 100%;
    padding: 0.64rem 0.7rem;
    overflow: hidden;
    animation: deviceSupportCardFade 260ms cubic-bezier(0.22, 1, 0.36, 1) both;
}

.screen-card__topline,
.screen-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.6rem;
}

.screen-card__eyebrow {
    color: #8adfff;
    font-size: 0.56rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.screen-card__state {
    min-height: 26px;
    padding: 0.18rem 0.42rem;
    border-radius: 999px;
    color: rgba(236, 246, 255, 0.92);
    background: rgba(255, 255, 255, 0.05);
    font-size: 0.54rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    transition: border-color 320ms ease, background-color 320ms ease, color 320ms ease;
}

.screen-card strong {
    color: #f7fbff;
    font-size: 0.84rem;
    line-height: 1.14;
    letter-spacing: -0.03em;
}

.screen-card p {
    color: rgba(190, 208, 232, 0.78);
    font-size: 0.64rem;
    line-height: 1.42;
}

.screen-card.is-supporting strong {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    font-size: 0.74rem;
}

.screen-card.is-supporting p {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
}

.screen-card__metric {
    color: rgba(236, 246, 255, 0.92);
    font-size: 0.56rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.screen-card__signal {
    position: relative;
    display: inline-flex;
    width: 66px;
    height: 6px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.07);
    overflow: hidden;
}

.screen-card__signal i {
    position: relative;
    display: block;
    width: var(--screen-signal);
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #4dc8ff, #8f7dff, #ffc76d);
    transition: width 840ms cubic-bezier(0.22, 1, 0.36, 1);
    overflow: hidden;
}

.screen-card__signal i::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(120deg, transparent 0%, rgba(255, 255, 255, 0.24) 50%, transparent 100%);
    transform: translateX(-140%);
    animation: deviceSignalSweep 3.2s linear infinite;
}

.device-screen.is-transitioning .screen-card {
    opacity: 0.42;
    --device-card-translate: 4px;
}

.device-screen.is-transitioning .device-live-pill {
    transform: translateY(2px);
}

.screen-card--cyan .screen-card__state {
    border: 1px solid rgba(89, 201, 255, 0.14);
    background: rgba(89, 201, 255, 0.1);
}

.screen-card--blue .screen-card__state {
    border: 1px solid rgba(118, 153, 255, 0.14);
    background: rgba(118, 153, 255, 0.1);
}

.screen-card--emerald .screen-card__state {
    border: 1px solid rgba(91, 241, 204, 0.14);
    background: rgba(91, 241, 204, 0.1);
}

.screen-card--gold .screen-card__state {
    border: 1px solid rgba(255, 196, 112, 0.14);
    background: rgba(255, 196, 112, 0.1);
}

.screen-card--violet .screen-card__state {
    border: 1px solid rgba(157, 167, 255, 0.14);
    background: rgba(157, 167, 255, 0.1);
}

.device-screen__footer {
    display: flex;
    flex-wrap: wrap;
    gap: 0.34rem;
    position: relative;
    z-index: 1;
    flex: 0 0 auto;
    margin-top: auto;
    padding-top: 0.22rem;
}

.screen-footer-chip {
    min-height: 26px;
    padding: 0.24rem 0.5rem;
    font-size: 0.6rem;
}

.device-screen--pocket .device-screen__header {
    gap: 0.46rem;
}

.device-screen--pocket .device-screen__header strong {
    font-size: 0.98rem;
    line-height: 1.04;
}

.device-screen--pocket .device-screen__header p {
    max-width: 92%;
    color: rgba(214, 228, 244, 0.84);
    font-size: 0.71rem;
    line-height: 1.56;
}

.device-screen--pocket .device-motion-layer {
    padding: 0.72rem 0.82rem;
    border-radius: 20px;
    background: linear-gradient(180deg, rgba(12, 24, 45, 0.9), rgba(7, 14, 28, 0.9));
    border: 1px solid rgba(118, 153, 255, 0.14);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.04),
        0 16px 32px rgba(0, 0, 0, 0.2);
}

.device-screen--pocket .device-screen__primary {
    margin-top: 0.06rem;
}

.device-screen--pocket .device-screen__metrics {
    gap: 0.42rem;
}

.device-screen--pocket .screen-metric {
    padding: 0.72rem 0.74rem;
}

.device-screen--pocket .device-screen__cards {
    gap: 0.4rem;
    padding-bottom: 0.26rem;
}

.device-screen--pocket .screen-card.is-supporting {
    padding: 0.72rem 0.78rem;
    border-radius: 18px;
    background: linear-gradient(180deg, rgba(15, 28, 48, 0.98), rgba(7, 14, 25, 1));
}

.device-screen--pocket .screen-card.is-supporting strong {
    font-size: 0.76rem;
}

.device-screen--pocket .screen-card.is-supporting p {
    font-size: 0.62rem;
}

.device-screen--pocket .screen-card__signal {
    width: 76px;
}

.device-pocket {
    position: relative;
    display: grid;
    gap: 0.74rem;
    padding: 0.98rem;
    border-radius: 26px;
    border: 1px solid rgba(118, 153, 255, 0.16);
    background:
        radial-gradient(circle at top left, rgba(89, 201, 255, 0.12), transparent 28%),
        linear-gradient(180deg, rgba(10, 20, 38, 0.94), rgba(5, 10, 18, 0.98));
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.05),
        0 20px 36px rgba(0, 0, 0, 0.24);
    overflow: hidden;
}

.device-pocket::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.06), transparent 28%, transparent 72%, rgba(89, 201, 255, 0.06));
    opacity: 0.82;
    pointer-events: none;
}

.device-pocket__camera {
    position: relative;
    display: grid;
    gap: 0.7rem;
    min-height: 228px;
    padding: 0.76rem;
    border-radius: 22px;
    background:
        radial-gradient(circle at 18% 12%, rgba(89, 201, 255, 0.08), transparent 20%),
        linear-gradient(180deg, rgba(7, 16, 31, 0.98), rgba(4, 9, 17, 1));
    border: 1px solid rgba(255, 255, 255, 0.06);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.04),
        0 16px 28px rgba(0, 0, 0, 0.22);
}

.device-pocket__camera-top,
.device-pocket__context-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.6rem;
}

.device-pocket__mode,
.device-pocket__meta-pill,
.device-pocket__tag {
    display: inline-flex;
    align-items: center;
    min-height: 26px;
    padding: 0.22rem 0.52rem;
    border-radius: 999px;
    font-size: 0.54rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.device-pocket__mode {
    color: #eaf5ff;
    background: rgba(89, 201, 255, 0.12);
    border: 1px solid rgba(89, 201, 255, 0.18);
}

.device-pocket__meta-pill {
    color: rgba(224, 236, 248, 0.9);
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.device-pocket__finder {
    position: relative;
    min-height: 152px;
    border-radius: 18px;
    overflow: hidden;
    background:
        radial-gradient(circle at 50% 0%, rgba(89, 201, 255, 0.14), transparent 26%),
        linear-gradient(180deg, rgba(5, 11, 21, 0.98), rgba(3, 7, 14, 1));
    border: 1px solid rgba(255, 255, 255, 0.05);
}

.device-pocket__finder::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(rgba(255, 255, 255, 0.02) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.02) 1px, transparent 1px);
    background-size: 24px 24px;
    opacity: 0.35;
    pointer-events: none;
}

.device-pocket__finder.is-live {
    box-shadow:
        inset 0 0 0 1px rgba(89, 201, 255, 0.06),
        0 0 0 1px rgba(89, 201, 255, 0.05);
}

.device-pocket__sheet {
    position: absolute;
    right: 10%;
    top: 22%;
    width: 42%;
    display: grid;
    gap: 0.34rem;
    padding: 0.9rem 0.8rem;
    border-radius: 22px 22px 18px 18px;
    background: linear-gradient(180deg, rgba(248, 251, 255, 0.98), rgba(223, 234, 247, 0.96));
    box-shadow:
        inset 0 -1px 0 rgba(11, 24, 48, 0.08),
        0 16px 26px rgba(0, 0, 0, 0.18);
    transform: rotate(-10deg);
}

.device-pocket__sheet i {
    display: block;
    height: 3px;
    border-radius: 999px;
    background: rgba(58, 92, 135, 0.22);
}

.device-pocket__sheet i:nth-child(1) {
    width: 72%;
}

.device-pocket__sheet i:nth-child(2) {
    width: 58%;
}

.device-pocket__sheet i:nth-child(3) {
    width: 84%;
}

.device-pocket__scanline {
    position: absolute;
    left: 10%;
    right: 10%;
    top: 24%;
    height: 2px;
    border-radius: 999px;
    background: linear-gradient(90deg, transparent, rgba(122, 222, 255, 0.9), transparent);
    box-shadow: 0 0 18px rgba(89, 201, 255, 0.5);
    animation: devicePocketScan 3.8s cubic-bezier(0.22, 1, 0.36, 1) infinite;
    pointer-events: none;
}

.device-pocket__focus {
    position: absolute;
    inset: 18% 15%;
    border-radius: 20px;
    border: 1px solid rgba(145, 207, 255, 0.3);
    box-shadow:
        inset 0 0 0 1px rgba(255, 255, 255, 0.04),
        0 0 0 1px rgba(89, 201, 255, 0.08);
    pointer-events: none;
}

.device-pocket__banner {
    position: absolute;
    left: 0.72rem;
    right: 0.72rem;
    bottom: 0.72rem;
    display: grid;
    gap: 0.22rem;
    padding: 0.62rem 0.72rem;
    border-radius: 16px;
    border: 1px solid rgba(89, 201, 255, 0.16);
    background: linear-gradient(180deg, rgba(19, 44, 78, 0.92), rgba(9, 21, 40, 0.94));
    backdrop-filter: blur(20px);
    z-index: 1;
}

.device-pocket__banner strong {
    color: #f5faff;
    font-size: 0.74rem;
    line-height: 1.15;
}

.device-pocket__banner span,
.device-pocket__helper,
.device-pocket__queue span {
    color: rgba(213, 226, 243, 0.8);
    font-size: 0.58rem;
    line-height: 1.45;
}

.device-pocket__context {
    display: grid;
    gap: 0.5rem;
    padding: 0.72rem 0.76rem;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.06);
}

.device-pocket__context-head strong {
    color: rgba(246, 250, 255, 0.94);
    font-size: 0.66rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.device-pocket__tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.38rem;
}

.device-pocket__tag {
    color: rgba(232, 240, 248, 0.84);
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.07);
}

.device-pocket__tag.is-primary {
    color: #0a1830;
    background: linear-gradient(135deg, rgba(201, 240, 255, 0.96), rgba(255, 227, 176, 0.96));
    border-color: rgba(255, 255, 255, 0.18);
}

.device-pocket__queue {
    display: grid;
    gap: 0.28rem;
}

.device-pocket__queue i {
    position: relative;
    display: block;
    height: 6px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    overflow: hidden;
}

.device-pocket__queue b {
    position: relative;
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #53d0ff, #6ff0d0, #ffc76d);
    transition: width 840ms cubic-bezier(0.22, 1, 0.36, 1);
    overflow: hidden;
}

.device-pocket__queue b::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(120deg, transparent 0%, rgba(255, 255, 255, 0.26) 50%, transparent 100%);
    transform: translateX(-140%);
    animation: deviceSignalSweep 3.2s linear infinite;
}

.device-pocket[data-pocket-mode="offline"] .device-pocket__mode,
.device-pocket[data-pocket-mode="offline"] .device-pocket__meta-pill {
    color: #ffe1b5;
    background: rgba(255, 196, 112, 0.12);
    border-color: rgba(255, 196, 112, 0.2);
}

.device-pocket[data-pocket-mode="offline"] .device-pocket__finder {
    background:
        radial-gradient(circle at 50% 0%, rgba(255, 196, 112, 0.12), transparent 22%),
        linear-gradient(180deg, rgba(9, 17, 30, 0.98), rgba(4, 8, 14, 1));
}

.device-pocket[data-pocket-mode="offline"] .device-pocket__queue b {
    background: linear-gradient(90deg, #ffbf6a, #ffd68f, #ffe7b1);
}

.device-pocket[data-pocket-mode="sync"] .device-pocket__meta-pill,
.device-pocket[data-pocket-mode="handoff"] .device-pocket__meta-pill {
    color: #cbffef;
    background: rgba(91, 241, 204, 0.12);
    border-color: rgba(91, 241, 204, 0.2);
}

.device-pocket[data-pocket-mode="handoff"] .device-pocket__banner {
    border-color: rgba(91, 241, 204, 0.2);
    background: linear-gradient(180deg, rgba(15, 49, 70, 0.92), rgba(7, 22, 33, 0.96));
}

@keyframes devicePocketScan {
    0% {
        top: 24%;
        opacity: 0;
    }
    12% {
        opacity: 0.88;
    }
    56% {
        opacity: 0.56;
    }
    100% {
        top: 78%;
        opacity: 0;
    }
}

@media (hover: hover) and (pointer: fine) {
    .screen-card:hover {
        transform: translateY(calc(var(--device-card-translate) - 3px)) scale(var(--device-card-scale));
        border-color: rgba(255, 255, 255, 0.11);
    }
}

@media (max-width: 1100px) {
    .phone-showcase-board {
        width: min(100%, 392px) !important;
    }

    .device-frame {
        width: min(100%, 362px);
    }

    .device-screen,
    .device-screen__content {
        min-height: 636px;
    }

    .device-frame--pocket {
        width: min(100%, 378px);
    }

    .device-frame--pocketDetail {
        width: min(100%, 344px);
    }

    .device-frame--pocket .device-screen,
    .device-frame--pocket .device-screen__content {
        min-height: 572px;
    }

    .device-frame--pocketDetail .device-screen,
    .device-frame--pocketDetail .device-screen__content {
        min-height: 534px;
    }
}

@media (max-width: 768px) {
    .phone-showcase-board {
        width: min(100%, 356px) !important;
    }

    .device-frame {
        width: min(100%, 340px);
        padding-bottom: 18px;
    }

    .device-frame__shell {
        padding: 9px;
        border-radius: 42px;
    }

    .device-frame__glass {
        border-radius: 33px;
    }

    .device-frame__speaker {
        top: 11px;
        width: 33%;
        height: 27px;
    }

    .device-frame__buttons {
        bottom: 22px;
    }

    .device-frame__button {
        width: 4px;
    }

    .device-screen,
    .device-screen__content {
        min-height: 604px;
    }

    .device-frame--pocket {
        width: min(100%, 350px);
    }

    .device-frame--pocketDetail {
        width: min(100%, 326px);
    }

    .device-frame--pocket .device-screen,
    .device-frame--pocket .device-screen__content {
        min-height: 548px;
    }

    .device-frame--pocketDetail .device-screen,
    .device-frame--pocketDetail .device-screen__content {
        min-height: 512px;
    }

    .device-screen {
        border-radius: 28px;
    }

    .device-screen__content {
        padding: 2.48rem 0.82rem 0.78rem;
        gap: 0.62rem;
    }

    .device-motion-layer {
        padding: 0.66rem 0.72rem;
    }

    .device-pocket {
        gap: 0.62rem;
        padding: 0.86rem;
        border-radius: 22px;
    }

    .device-pocket__camera {
        min-height: 204px;
        padding: 0.66rem;
        border-radius: 20px;
    }

    .device-pocket__banner {
        left: 0.62rem;
        right: 0.62rem;
        bottom: 0.62rem;
    }

    .device-pocket__context {
        padding: 0.64rem 0.68rem;
    }
}

@media (max-width: 480px) {
    .phone-showcase-board {
        width: min(100%, 334px) !important;
    }

    .device-frame {
        width: min(100%, 314px);
        padding-bottom: 14px;
    }

    .device-frame__shell {
        padding: 8px;
        border-radius: 38px;
    }

    .device-frame__glass {
        border-radius: 30px;
    }

    .device-screen,
    .device-screen__content {
        min-height: 568px;
    }

    .device-frame--pocket {
        width: min(100%, 320px);
    }

    .device-frame--pocketDetail {
        width: min(100%, 300px);
    }

    .device-frame--pocket .device-screen,
    .device-frame--pocket .device-screen__content {
        min-height: 506px;
    }

    .device-frame--pocketDetail .device-screen,
    .device-frame--pocketDetail .device-screen__content {
        min-height: 478px;
    }

    .device-screen {
        border-radius: 26px;
    }

    .device-screen__content {
        padding: 2.3rem 0.78rem 0.74rem;
        gap: 0.56rem;
    }

    .device-motion-layer {
        gap: 0.48rem;
        padding: 0.66rem 0.7rem;
        border-radius: 18px;
    }

    .device-motion-layer__status {
        justify-items: start;
        gap: 0.44rem;
    }

    .device-live-cluster {
        gap: 0.44rem;
    }

    .device-decision-pill {
        font-size: 0.53rem;
    }

    .device-live-copy {
        font-size: 0.63rem;
    }

    .device-progress__value {
        font-size: 0.6rem;
    }

    .device-screen__header strong {
        font-size: 0.95rem;
    }

    .device-frame__speaker {
        width: 37%;
        height: 25px;
    }

    .device-frame__speaker-slot {
        height: 5px;
    }

    .device-frame__speaker-lens {
        width: 8px;
        height: 8px;
    }

    .device-frame__buttons {
        display: none;
    }

    .device-screen__header p,
    .screen-card p {
        font-size: 0.66rem;
    }

    .screen-card {
        padding: 0.72rem;
        border-radius: 17px;
    }

    .screen-card strong {
        font-size: 0.8rem;
    }

    .screen-chip,
    .screen-footer-chip {
        font-size: 0.58rem;
    }

    .device-pocket {
        gap: 0.56rem;
        padding: 0.78rem;
        border-radius: 20px;
    }

    .device-pocket__camera {
        min-height: 186px;
        padding: 0.58rem;
        border-radius: 18px;
    }

    .device-pocket__finder {
        min-height: 132px;
    }

    .device-pocket__banner strong {
        font-size: 0.7rem;
    }

    .device-pocket__banner span,
    .device-pocket__helper,
    .device-pocket__queue span {
        font-size: 0.56rem;
    }
}

@media (prefers-reduced-motion: reduce) {
    .device-screen__ticker--a,
    .device-screen__ticker--b,
    .screen-card,
    .device-live-dot,
    .device-decision-pill,
    .device-progress__track i,
    .device-progress__track i::after,
    .screen-card__signal i::after,
    .device-pocket__scanline,
    .device-pocket__queue b::after {
        animation: none !important;
        transition: none !important;
    }

    .device-motion-layer__veil {
        display: none !important;
    }
}

@keyframes deviceTickerForward {
    0% { transform: rotate(-10deg) translateX(0); }
    100% { transform: rotate(-10deg) translateX(-32%); }
}

@keyframes deviceTickerBackward {
    0% { transform: rotate(-6deg) translateX(-22%); }
    100% { transform: rotate(-6deg) translateX(0); }
}

@keyframes deviceCardRise {
    0% {
        opacity: 0;
        transform: translateY(18px) scale(0.972);
    }
    100% {
        opacity: 1;
        transform: translateY(var(--device-card-translate)) scale(var(--device-card-scale));
    }
}

@keyframes deviceSupportCardFade {
    0% {
        opacity: 0;
        transform: translateY(var(--device-card-translate)) scale(var(--device-card-scale));
    }
    100% {
        opacity: 0.84;
        transform: translateY(var(--device-card-translate)) scale(var(--device-card-scale));
    }
}

@keyframes deviceProgressSweep {
    0% { transform: translateX(-130%); }
    100% { transform: translateX(160%); }
}

@keyframes deviceSignalSweep {
    0% { transform: translateX(-140%); }
    100% { transform: translateX(150%); }
}

@keyframes deviceDotPulse {
    0%, 100% {
        transform: scale(1);
        box-shadow: 0 0 0 1px rgba(var(--device-accent-rgb), 0.28), 0 0 10px rgba(var(--device-accent-rgb), 0.16);
    }
    50% {
        transform: scale(1.16);
        box-shadow: 0 0 0 1px rgba(var(--device-accent-rgb), 0.34), 0 0 16px rgba(var(--device-accent-rgb), 0.24);
    }
}

@view-transition {
    navigation: auto;
}

::view-transition-old(root),
::view-transition-new(root) {
    animation-duration: 0.6s;
    animation-timing-function: cubic-bezier(0.22, 1, 0.36, 1);
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html.lenis {
    height: auto;
}

.lenis.lenis-smooth {
    scroll-behavior: auto;
}

.lenis.lenis-stopped {
    overflow: hidden;
}

body {
    min-height: 100vh;
    overflow-x: hidden;
    color: var(--text-main);
    font-family: "Manrope", sans-serif;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    background:
        radial-gradient(circle at 18% 14%, rgba(89, 201, 255, 0.18), transparent 28%),
        radial-gradient(circle at 82% 18%, rgba(255, 189, 107, 0.14), transparent 30%),
        radial-gradient(circle at 50% 100%, rgba(84, 240, 213, 0.1), transparent 24%),
        linear-gradient(180deg, #050915 0%, #071121 32%, #09142b 70%, #060d1a 100%);
}

p {
    text-wrap: pretty;
}

body::before,
body::after {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: -4;
}

body::before {
    background:
        radial-gradient(circle at calc(50% + (var(--pointer-x) * 16%)) calc(10% + (var(--pointer-y) * 8%)), rgba(47, 124, 255, 0.18), transparent 32%),
        radial-gradient(circle at calc(75% - (var(--pointer-x) * 12%)) calc(78% - (var(--pointer-y) * 10%)), rgba(255, 189, 107, 0.14), transparent 28%);
    opacity: 0.92;
}

body::after {
    background: linear-gradient(180deg, rgba(4, 9, 22, 0.08), rgba(4, 9, 22, 0.74));
}

body.loading {
    overflow: hidden;
}

a {
    color: inherit;
    text-decoration: none;
}

button,
input,
textarea,
select {
    font: inherit;
    color: inherit;
}

button {
    background: none;
    border: none;
    cursor: pointer;
}

img {
    display: block;
    max-width: 100%;
}

main,
section,
footer {
    position: relative;
    z-index: 2;
}

h1,
h2,
h3,
h4,
.brand-copy strong,
.btn-solid,
.btn-outline,
.eyebrow,
.metric-value,
.proof-value {
    font-family: "Sora", sans-serif;
    text-wrap: balance;
}

.scene-shell {
    position: fixed;
    inset: 0;
    overflow: hidden;
    pointer-events: none;
    z-index: -3;
}

.scene-grid,
.noise-layer,
.webgl-bg,
.scene-orb {
    position: absolute;
    inset: 0;
}

.webgl-bg {
    width: 100%;
    height: 100%;
    opacity: 0.96;
}

.scene-grid {
    background-image:
        linear-gradient(rgba(255, 255, 255, 0.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.04) 1px, transparent 1px);
    background-size: 88px 88px;
    mask-image: radial-gradient(circle at center, rgba(0, 0, 0, 0.95) 35%, transparent 92%);
    opacity: 0.28;
}

.noise-layer {
    opacity: 0.08;
    mix-blend-mode: screen;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240' viewBox='0 0 240 240'%3E%3Cg fill='white' fill-opacity='.25'%3E%3Ccircle cx='28' cy='24' r='1'/%3E%3Ccircle cx='86' cy='54' r='1'/%3E%3Ccircle cx='168' cy='70' r='1'/%3E%3Ccircle cx='214' cy='34' r='1'/%3E%3Ccircle cx='52' cy='142' r='1'/%3E%3Ccircle cx='132' cy='124' r='1'/%3E%3Ccircle cx='192' cy='166' r='1'/%3E%3Ccircle cx='24' cy='198' r='1'/%3E%3Ccircle cx='102' cy='206' r='1'/%3E%3Ccircle cx='226' cy='216' r='1'/%3E%3C/g%3E%3C/svg%3E");
}

.scene-orb {
    inset: auto;
    border-radius: 50%;
    filter: blur(110px);
    opacity: 0.34;
    mix-blend-mode: screen;
    transform:
        translate3d(
            calc(var(--base-x, 0px) + (var(--pointer-x) * var(--depth-x, 18px))),
            calc(var(--base-y, 0px) + (var(--pointer-y) * var(--depth-y, 18px))),
            0
        );
    transition: transform 0.28s ease;
}

.orb-a {
    top: -10%;
    left: -8%;
    width: 42vw;
    height: 42vw;
    background: radial-gradient(circle, rgba(89, 201, 255, 0.5), transparent 70%);
    --depth-x: 38px;
    --depth-y: 26px;
}

.orb-b {
    top: 12%;
    right: -12%;
    width: 40vw;
    height: 40vw;
    background: radial-gradient(circle, rgba(47, 124, 255, 0.38), transparent 72%);
    --depth-x: -32px;
    --depth-y: 22px;
}

.orb-c {
    bottom: -16%;
    left: 24%;
    width: 34vw;
    height: 34vw;
    background: radial-gradient(circle, rgba(255, 189, 107, 0.3), transparent 72%);
    --depth-x: 18px;
    --depth-y: -24px;
}

.preloader {
    position: fixed;
    inset: 0;
    z-index: 1400;
    display: grid;
    place-items: center;
    background:
        radial-gradient(circle at top, rgba(89, 201, 255, 0.16), transparent 34%),
        radial-gradient(circle at bottom, rgba(255, 189, 107, 0.12), transparent 30%),
        #040815;
}

.preloader-content {
    width: min(400px, calc(100% - 48px));
    padding: 2rem;
    border-radius: 28px;
    background: rgba(9, 18, 37, 0.72);
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: var(--shadow-deep);
    backdrop-filter: blur(24px);
}

.preloader-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 1rem;
    padding: 0.45rem 0.8rem;
    border-radius: 999px;
    color: var(--accent-blue);
    background: rgba(89, 201, 255, 0.08);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.preloader-label {
    margin-bottom: 1rem;
    color: var(--text-main);
    font-size: 1.2rem;
    font-weight: 700;
}

.preloader-copy {
    margin-bottom: 1.3rem;
    color: var(--text-muted);
    line-height: 1.65;
}

.preloader-bar {
    width: 100%;
    height: 10px;
    border-radius: 999px;
    overflow: hidden;
    background: rgba(255, 255, 255, 0.08);
}

.preloader-progress {
    display: block;
    width: 0;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--accent-blue), var(--accent-cobalt), var(--accent-amber));
}

.site-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1200;
    padding: 1.25rem 0;
    transition: padding 0.25s ease, background 0.25s ease;
}

.site-header.scrolled {
    padding: 0.85rem 0;
    background: rgba(4, 10, 22, 0.72);
    backdrop-filter: blur(24px);
    border-bottom: 1px solid rgba(255, 255, 255, 0.07);
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.22);
}

.nav-container,
.shell,
.hero-grid,
.footer-shell,
.cta-shell,
.contact-shell {
    width: min(1280px, calc(100% - 40px));
    margin: 0 auto;
}

.nav-container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
}

.brand-mark {
    display: inline-flex;
    align-items: center;
    gap: 0.95rem;
    min-width: 0;
}

.brand-symbol {
    flex: none;
    width: 50px;
    height: 50px;
    border-radius: 18px;
    overflow: hidden;
    background: linear-gradient(180deg, rgba(8, 17, 33, 0.9), rgba(17, 34, 64, 0.9));
    border: 1px solid rgba(89, 201, 255, 0.16);
    box-shadow: 0 18px 36px rgba(0, 0, 0, 0.24);
}

.brand-symbol img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.brand-copy {
    display: grid;
    gap: 0.1rem;
}

.brand-copy strong {
    font-size: 1.05rem;
    font-weight: 700;
    letter-spacing: -0.04em;
}

.brand-copy em {
    font-style: normal;
    color: var(--text-muted);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.nav-links {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0.4rem;
    border-radius: 999px;
    background: rgba(7, 14, 28, 0.58);
    border: 1px solid rgba(255, 255, 255, 0.08);
    backdrop-filter: blur(18px);
}

.nav-links a {
    padding: 0.74rem 1rem;
    border-radius: 999px;
    color: var(--text-muted);
    font-size: 0.92rem;
    font-weight: 700;
    transition: color 0.2s ease, background 0.2s ease, transform 0.2s ease;
}

.nav-links a:hover,
.nav-links a.active {
    color: var(--text-main);
    background: rgba(255, 255, 255, 0.08);
    transform: translateY(-1px);
}

.header-actions {
    display: flex;
    align-items: center;
    gap: 0.8rem;
}

.lang-switch {
    display: inline-flex;
    align-items: center;
    gap: 0.2rem;
    padding: 0.32rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.08);
    backdrop-filter: blur(18px);
}

.lang-switch a {
    min-width: 46px;
    padding: 0.56rem 0.85rem;
    border-radius: 999px;
    color: var(--text-muted);
    font-size: 0.8rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-align: center;
    text-transform: uppercase;
    transition: background 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.lang-switch a.active,
.lang-switch a:hover {
    color: var(--text-main);
    background: rgba(255, 255, 255, 0.08);
    transform: translateY(-1px);
}

.btn-solid,
.btn-outline,
.btn-ghost {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.55rem;
    padding: 0.9rem 1.45rem;
    border-radius: 999px;
    font-weight: 700;
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}

.btn-solid {
    color: #071222;
    background: linear-gradient(135deg, #f4fbff 0%, #bdeeff 32%, #ffdcab 100%);
    box-shadow: 0 18px 40px rgba(89, 201, 255, 0.2);
}

.btn-outline {
    color: var(--text-main);
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.12);
    box-shadow: 0 16px 30px rgba(0, 0, 0, 0.12);
}

.btn-ghost {
    color: var(--text-soft);
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.06);
}

.btn-ghost.active {
    color: var(--text-main);
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.14);
    box-shadow: 0 16px 30px rgba(0, 0, 0, 0.12);
}

.btn-solid:hover,
.btn-outline:hover,
.btn-ghost:hover {
    transform: translateY(-2px);
}

.btn-large {
    padding: 1.02rem 1.8rem;
    font-size: 1rem;
}

.eyebrow,
.pill,
.metric-kicker,
.card-kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    width: fit-content;
    padding: 0.45rem 0.85rem;
    border-radius: 999px;
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.eyebrow {
    color: var(--accent-blue);
    background: rgba(89, 201, 255, 0.08);
    border: 1px solid rgba(89, 201, 255, 0.1);
}

.pill {
    color: var(--text-main);
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.page-hero {
    padding: 152px 0 84px;
}

.hero-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(360px, 0.82fr);
    gap: clamp(1.4rem, 2.8vw, 2.4rem);
    align-items: start;
}

.hero-grid.hero-grid-showcase {
    width: min(1400px, calc(100% - 28px));
    grid-template-columns: minmax(0, 0.86fr) minmax(560px, 1.04fr);
    gap: clamp(1.2rem, 2.2vw, 2rem);
}

.hero-grid.hero-grid-showcase .hero-visual {
    min-height: 700px;
    padding-left: 0;
}

.hero-grid.hero-grid-home {
    width: min(1420px, calc(100% - 26px));
    grid-template-columns: minmax(0, 0.84fr) minmax(580px, 1.02fr);
    gap: clamp(1.25rem, 2.3vw, 2.1rem);
}

.hero-grid.hero-grid-home .hero-visual {
    min-height: 740px;
    padding-left: 0;
}

.hero-copy {
    display: grid;
    gap: 1.25rem;
}

.hero-title {
    font-size: clamp(3.5rem, 8vw, 7rem);
    line-height: 0.93;
    letter-spacing: -0.07em;
}

body[data-page="platform"] .hero-grid.hero-grid-showcase {
    gap: clamp(2rem, 3vw, 2.8rem);
}

body[data-page="platform"] .hero-copy {
    max-width: min(100%, 34rem);
}

body[data-page="platform"] .hero-title {
    line-height: 1.1;
    padding-top: 0.05em;
}

.hero-lead,
.section-lead,
.card-copy,
.detail-copy p,
.contact-copy p,
.footer-note,
.comparison-row p,
.step-card p,
.fit-card p {
    color: var(--text-soft);
    line-height: 1.8;
    font-size: 1.04rem;
}

.hero-actions,
.cta-actions {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
}

.metric-row,
.card-grid,
.step-grid,
.proof-grid,
.fit-grid,
.footer-grid,
.comparison-table,
.detail-grid,
.contact-grid {
    display: grid;
    gap: 1rem;
}

.metric-row {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.metric-card,
.feature-card,
.step-card,
.proof-card,
.fit-card,
.quote-card,
.comparison-row,
.contact-card,
.glass-stage {
    position: relative;
    overflow: hidden;
    border-radius: var(--radius-md);
    background: linear-gradient(180deg, rgba(12, 23, 48, 0.88), rgba(9, 18, 37, 0.86));
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: var(--shadow-soft);
    backdrop-filter: blur(18px);
}

.metric-card::before,
.feature-card::before,
.glass-stage::before,
.contact-card::before,
.proof-card::before,
.fit-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.06), transparent 42%);
    opacity: 0.8;
    pointer-events: none;
}

.metric-card,
.feature-card,
.proof-card,
.fit-card,
.step-card,
.comparison-row,
.contact-card {
    padding: 1.3rem;
    transition: transform 0.24s ease, border-color 0.24s ease, box-shadow 0.24s ease, background 0.24s ease;
}

.metric-value,
.proof-value {
    font-size: 2.15rem;
    letter-spacing: -0.06em;
}

.metric-label,
.proof-label,
.muted {
    color: var(--text-muted);
    line-height: 1.6;
}

.feature-card h3,
.proof-card h3,
.fit-card h3,
.step-card h3,
.comparison-row h3,
.contact-card h3 {
    margin-bottom: 0.5rem;
    font-size: 1.16rem;
    letter-spacing: -0.03em;
}

.feature-card:hover,
.proof-card:hover,
.fit-card:hover,
.step-card:hover,
.comparison-row:hover,
.metric-card:hover,
.outcome-card:hover,
.section-visual-card:hover {
    transform: translateY(-5px);
    border-color: rgba(128, 189, 255, 0.24);
    box-shadow: 0 34px 70px rgba(0, 0, 0, 0.18);
}

.hero-visual,
.detail-stage {
    position: relative;
    perspective: 1600px;
}

.hero-visual {
    min-height: 600px;
    isolation: isolate;
    padding-left: clamp(0rem, 1vw, 0.6rem);
}

.glass-stage {
    min-height: 100%;
    padding: 1.35rem;
}

.tilt-card {
    transform-style: preserve-3d;
    transform: perspective(1600px) rotateX(var(--card-rx, 0deg)) rotateY(var(--card-ry, 0deg)) translate3d(var(--card-tx, 0px), var(--card-ty, 0px), 0);
    transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.tilt-card:hover {
    border-color: var(--border-strong);
    box-shadow: 0 36px 90px rgba(0, 0, 0, 0.32);
}

[data-depth] {
    transform:
        translate3d(
            calc(var(--base-x, 0px) + (var(--pointer-x) * var(--depth-x, 18px))),
            calc(var(--base-y, 0px) + (var(--pointer-y) * var(--depth-y, 18px))),
            0
        )
        rotateX(calc(var(--pointer-y) * var(--tilt-x, -5deg)))
        rotateY(calc(var(--pointer-x) * var(--tilt-y, 6deg)));
    transition: transform 0.24s cubic-bezier(0.22, 1, 0.36, 1);
    will-change: transform;
}

.window-bar,
.panel-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding-bottom: 1rem;
    margin-bottom: 1rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.window-title,
.panel-bar strong {
    font-size: 0.9rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-muted);
}

.window-dots {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
}

.window-dots span {
    width: 10px;
    height: 10px;
    border-radius: 50%;
}

.window-dots span:nth-child(1) { background: #ff6f61; }
.window-dots span:nth-child(2) { background: #ffcc66; }
.window-dots span:nth-child(3) { background: #59d390; }

.mission-grid,
.stage-main,
.mini-metrics,
.data-table,
.policy-grid,
.proof-stage {
    display: grid;
    gap: 1rem;
}

.mission-grid {
    grid-template-columns: 220px minmax(0, 1fr);
    min-height: 520px;
}

.stage-sidebar {
    padding: 1rem;
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.stage-sidebar h3 {
    margin-bottom: 1rem;
    font-size: 1rem;
}

.stage-sidebar ul,
.feature-list,
.comparison-points,
.footer-column,
.worker-list,
.routing-column ul,
.contact-card ul {
    display: grid;
    gap: 0.75rem;
    list-style: none;
}

.stage-sidebar li,
.feature-list li,
.comparison-points li,
.contact-card li {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    color: var(--text-soft);
    line-height: 1.65;
}

.stage-sidebar li i,
.feature-list li i,
.comparison-points li i {
    width: 18px;
    height: 18px;
    margin-top: 0.15rem;
    color: var(--accent-blue);
}

.mini-metrics {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.mini-metric {
    padding: 1rem;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.mini-metric strong {
    display: block;
    margin-bottom: 0.3rem;
    font-size: 1.35rem;
}

.mini-metric span {
    color: var(--text-muted);
    font-size: 0.88rem;
}

.data-row {
    display: grid;
    grid-template-columns: 1.7fr 1fr 0.9fr 0.9fr;
    gap: 0.8rem;
    align-items: center;
    padding: 0.95rem 1rem;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.07);
}

.data-row.header {
    color: var(--text-muted);
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    background: transparent;
    border: none;
    padding: 0 0.5rem;
}

.data-row strong {
    display: block;
    margin-bottom: 0.2rem;
    font-size: 0.95rem;
}

.badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    padding: 0.42rem 0.7rem;
    border-radius: 999px;
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.badge.blue { background: rgba(89, 201, 255, 0.12); color: var(--accent-blue); }
.badge.amber { background: rgba(255, 189, 107, 0.14); color: var(--accent-amber); }
.badge.mint { background: rgba(84, 240, 213, 0.14); color: var(--accent-mint); }
.badge.violet { background: rgba(142, 160, 255, 0.14); color: var(--accent-violet); }

.floating-chip {
    position: absolute;
    max-width: 220px;
    padding: 0.9rem 1rem;
    border-radius: 20px;
    background: rgba(9, 18, 37, 0.92);
    border: 1px solid rgba(128, 189, 255, 0.18);
    box-shadow: 0 18px 36px rgba(0, 0, 0, 0.24);
}

.floating-chip strong {
    display: block;
    margin-bottom: 0.2rem;
    font-size: 0.92rem;
}

.floating-chip span {
    color: var(--text-muted);
    font-size: 0.82rem;
    line-height: 1.45;
}

.chip-pocket { top: 48px; right: -12px; --depth-x: 30px; --depth-y: 24px; }
.chip-ai { top: 220px; left: -28px; --depth-x: -24px; --depth-y: 16px; }
.chip-router { bottom: 138px; right: -24px; --depth-x: 22px; --depth-y: -26px; }
.chip-worker { bottom: 18px; left: 22px; --depth-x: -18px; --depth-y: -20px; }

.brand-token {
    display: inline-flex;
    align-items: center;
    gap: 0.9rem;
    padding: 0.9rem 1rem;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.brand-token img {
    width: 56px;
    height: 56px;
    border-radius: 16px;
}

.brand-token strong {
    display: block;
    font-size: 1rem;
}

.brand-token span {
    color: var(--text-muted);
    font-size: 0.88rem;
}

.hero-kicker-line {
    color: var(--accent-mint);
    font-size: 0.96rem;
    font-weight: 700;
    letter-spacing: 0.01em;
}

.hero-title {
    text-shadow: 0 12px 60px rgba(7, 18, 34, 0.28);
}

.text-gradient {
    background: linear-gradient(135deg, #ffffff 0%, #d7f4ff 32%, #7ed4ff 68%, #ffcf8f 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.hero-chip-rail {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    flex-wrap: wrap;
}

.hero-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.72rem 0.95rem;
    border-radius: 999px;
    color: var(--text-soft);
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 16px 30px rgba(3, 11, 24, 0.16);
}

.hero-chip::before {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--accent-blue), var(--accent-mint));
    box-shadow: 0 0 18px rgba(89, 201, 255, 0.52);
}

.metric-card .metric-kicker {
    margin-bottom: 0.45rem;
}

.metric-card {
    background: linear-gradient(180deg, rgba(12, 23, 48, 0.92), rgba(8, 16, 31, 0.9));
}

.hero-premium-stage {
    min-height: 720px;
    padding: 1.2rem;
    overflow: visible;
    background:
        radial-gradient(circle at 14% 14%, rgba(89, 201, 255, 0.12), transparent 22%),
        radial-gradient(circle at 84% 12%, rgba(255, 189, 107, 0.1), transparent 20%),
        linear-gradient(180deg, rgba(11, 21, 42, 0.98), rgba(7, 15, 29, 0.94));
}

.hero-premium-stage:not(.home-flagship) {
    display: grid;
    gap: 1rem;
    min-height: auto;
    overflow: hidden;
}

.hero-premium-stage.home-flagship {
    display: grid;
    gap: 1rem;
    min-height: auto;
    overflow: hidden;
}

.hero-grid.hero-grid-showcase .hero-premium-stage,
.hero-grid.hero-grid-home .hero-premium-stage {
    min-height: 700px;
    overflow: visible;
}

.hero-premium-stage::after {
    content: "";
    position: absolute;
    inset: 18px;
    border-radius: 28px;
    border: 1px solid rgba(255, 255, 255, 0.06);
    pointer-events: none;
}

.hero-dashboard-art {
    width: 100%;
    min-height: 610px;
    object-fit: cover;
    border-radius: 28px;
    border: 1px solid rgba(255, 255, 255, 0.06);
    box-shadow: 0 32px 80px rgba(2, 9, 22, 0.28);
}

.hero-premium-stage.home-flagship .hero-dashboard-art {
    min-height: 520px;
}

.art-asset {
    background:
        radial-gradient(circle at 18% 18%, rgba(89, 201, 255, 0.16), transparent 26%),
        radial-gradient(circle at 82% 18%, rgba(255, 189, 107, 0.14), transparent 22%),
        linear-gradient(180deg, rgba(9, 18, 37, 0.98), rgba(6, 14, 29, 0.94));
}

.hero-dashboard-art.art-asset,
.hero-stage-thumb.art-asset,
.hero-phone-image.art-asset,
.section-visual-card img.art-asset {
    object-fit: cover;
    object-position: center center;
}

.hero-dashboard-art.art-asset {
    padding: 0;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.06),
        0 40px 90px rgba(2, 9, 22, 0.42);
}

.section-visual-card img.art-asset {
    aspect-ratio: 16 / 10;
    padding: 0;
}

.hero-stage-thumb.art-asset,
.hero-phone-image.art-asset {
    padding: 0;
}

.hero-live-card,
.hero-story-card,
.hero-quote-card,
.hero-email-card {
    position: absolute;
    display: grid;
    gap: 0.55rem;
    padding: 1rem 1.05rem;
    border-radius: 24px;
    background: rgba(9, 18, 37, 0.92);
    border: 1px solid rgba(128, 189, 255, 0.14);
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.24);
    backdrop-filter: blur(20px);
}

.hero-premium-stage:not(.home-flagship) .hero-live-card,
.hero-premium-stage:not(.home-flagship) .hero-story-card,
.hero-premium-stage:not(.home-flagship) .hero-quote-card,
.hero-premium-stage:not(.home-flagship) .hero-email-card,
.hero-premium-stage:not(.home-flagship) .hero-phone-shell {
    position: relative;
    inset: auto;
    width: 100%;
    max-width: none;
    margin-top: 0;
}

.hero-premium-stage:not(.home-flagship) .hero-phone-shell {
    right: auto;
    bottom: auto;
    justify-self: stretch;
}

.hero-live-card {
    top: -12px;
    right: 22px;
    width: min(240px, 38vw);
    --depth-x: 18px;
    --depth-y: 16px;
}

.hero-story-card {
    left: -26px;
    bottom: 26px;
    width: min(260px, 42vw);
    --depth-x: -22px;
    --depth-y: -18px;
}

.hero-quote-card {
    right: -20px;
    bottom: 98px;
    width: min(240px, 38vw);
    --depth-x: 16px;
    --depth-y: -20px;
}

.hero-email-card {
    left: 44px;
    top: 18px;
    width: min(230px, 36vw);
    --depth-x: -14px;
    --depth-y: 18px;
}

.hero-card-kicker {
    color: var(--accent-blue);
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.hero-live-card strong,
.hero-story-card strong,
.hero-quote-card strong,
.hero-email-card strong {
    font-size: 1.02rem;
    letter-spacing: -0.03em;
}

.hero-live-card p,
.hero-story-card p,
.hero-quote-card p,
.hero-email-card p,
.hero-email-card span {
    color: var(--text-soft);
    line-height: 1.6;
    font-size: 0.92rem;
}

.hero-live-card ul {
    display: grid;
    gap: 0.55rem;
    list-style: none;
}

.hero-live-card li {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.65rem 0.7rem;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.05);
}

.hero-live-card li span {
    color: var(--text-muted);
    font-size: 0.8rem;
}

.hero-live-card li strong {
    font-size: 0.9rem;
}

.hero-phone-shell {
    position: absolute;
    right: 58px;
    bottom: -54px;
    width: min(320px, 46vw);
    padding: 0.95rem;
    border-radius: 42px;
    background: linear-gradient(180deg, #0b162c, #152644);
    box-shadow: 0 42px 90px rgba(0, 0, 0, 0.34);
    z-index: 3;
    --depth-x: 24px;
    --depth-y: -26px;
}

.hero-phone-frame {
    padding: 1.1rem;
    border-radius: 32px;
    background: linear-gradient(180deg, #eef6ff 0%, #dfeeff 100%);
    color: var(--text-dark);
}

.hero-phone-topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.9rem;
}

.hero-phone-topbar strong {
    font-size: 1rem;
}

.hero-phone-topbar span {
    color: var(--text-dark-soft);
    font-size: 0.82rem;
}

.hero-phone-image {
    width: 100%;
    border-radius: 24px;
    box-shadow: 0 20px 40px rgba(15, 32, 58, 0.12);
}

.hero-phone-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    margin-top: 0.9rem;
    padding: 0.68rem 0.85rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.88);
    box-shadow: 0 14px 26px rgba(15, 32, 58, 0.08);
}

.hero-phone-pill::before {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--accent-blue), var(--accent-mint));
}

.hero-phone-caption {
    margin-top: 0.85rem;
    color: var(--text-dark-soft);
    line-height: 1.55;
    font-size: 0.9rem;
}

.hero-proof-strip {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.9rem;
}

.hero-proof-item {
    position: relative;
    overflow: hidden;
    padding: 1rem 1.05rem;
    border-radius: 22px;
    background: linear-gradient(180deg, rgba(10, 20, 41, 0.92), rgba(7, 15, 30, 0.9));
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.2);
}

.hero-proof-item::before,
.hero-stage-card::before,
.section-visual-card::before,
.feature-card::after,
.proof-card::after,
.fit-card::after,
.step-card::after,
.comparison-row::after,
.metric-card::after,
.outcome-card::after {
    content: "";
    position: absolute;
    inset: 0 auto auto 0;
    width: 100%;
    height: 1px;
    background: linear-gradient(90deg, rgba(89, 201, 255, 0), rgba(89, 201, 255, 0.76), rgba(255, 189, 107, 0.2), rgba(255, 255, 255, 0));
    opacity: 0.65;
}

.hero-proof-item strong {
    display: block;
    margin-bottom: 0.35rem;
    font-size: 1rem;
    letter-spacing: -0.03em;
}

.hero-proof-item span,
.hero-proof-item p {
    color: var(--text-soft);
    font-size: 0.92rem;
    line-height: 1.6;
}

.hero-stage-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: stretch;
}

.hero-stage-grid-home {
    margin-top: 0.1rem;
}

.hero-stage-card {
    position: relative;
    overflow: hidden;
    display: grid;
    gap: 0.65rem;
    min-height: 220px;
    padding: 1.1rem;
    border-radius: 26px;
    background: linear-gradient(180deg, rgba(9, 18, 37, 0.92), rgba(6, 14, 29, 0.9));
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 24px 52px rgba(0, 0, 0, 0.18);
    height: 100%;
}

.hero-stage-card.primary {
    background:
        radial-gradient(circle at top left, rgba(89, 201, 255, 0.18), transparent 54%),
        linear-gradient(180deg, rgba(13, 31, 61, 0.96), rgba(7, 15, 30, 0.92));
}

.hero-stage-card.warm {
    background:
        radial-gradient(circle at top right, rgba(255, 189, 107, 0.2), transparent 52%),
        linear-gradient(180deg, rgba(24, 28, 42, 0.96), rgba(8, 16, 31, 0.92));
}

.hero-stage-card.light {
    color: var(--text-dark);
    background: linear-gradient(180deg, rgba(250, 253, 255, 0.98), rgba(232, 242, 255, 0.96));
    border-color: rgba(11, 24, 48, 0.08);
    box-shadow: 0 22px 48px rgba(14, 35, 58, 0.12);
}

.hero-stage-card.light p,
.hero-stage-card.light li,
.hero-stage-card.light span {
    color: var(--text-dark-soft);
}

.hero-stage-card h3 {
    font-size: 1.2rem;
    letter-spacing: -0.04em;
}

.hero-stage-thumb {
    width: 100%;
    margin-top: auto;
    border-radius: 22px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 22px 44px rgba(0, 0, 0, 0.22);
}

.hero-stage-card p,
.hero-stage-card li {
    color: var(--text-soft);
    line-height: 1.6;
}

.hero-stage-card ul {
    display: grid;
    gap: 0.7rem;
    list-style: none;
}

.hero-stage-card li {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.9rem;
    padding: 0.8rem 0.9rem;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.06);
}

.hero-stage-card.light li {
    background: rgba(255, 255, 255, 0.84);
    border-color: rgba(11, 24, 48, 0.08);
}

.hero-stage-card li strong {
    font-size: 0.92rem;
}

.hero-stage-card li span {
    font-size: 0.84rem;
    color: var(--text-muted);
}

.hero-premium-stage:not(.home-flagship) .hero-stage-grid {
    margin-top: 0.15rem;
}

.hero-premium-stage:not(.home-flagship) .hero-stage-card {
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.05),
        0 24px 54px rgba(0, 0, 0, 0.22);
}

.hero-stage-kicker {
    color: var(--accent-blue);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.hero-stage-metric {
    margin-top: auto;
    font-family: "Sora", sans-serif;
    font-size: clamp(2rem, 4vw, 3.4rem);
    line-height: 0.9;
    letter-spacing: -0.08em;
}

.hero-stage-note {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    width: fit-content;
    padding: 0.7rem 0.9rem;
    border-radius: 999px;
    color: inherit;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.hero-stage-card.light .hero-stage-note {
    background: rgba(255, 255, 255, 0.88);
    border-color: rgba(11, 24, 48, 0.08);
}

.hero-stage-note::before {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--accent-blue), var(--accent-mint));
    box-shadow: 0 0 18px rgba(89, 201, 255, 0.5);
}

.command-surface,
.platform-surface,
.routing-surface {
    padding: clamp(1rem, 2vw, 1.35rem);
}

.command-surface-grid,
.platform-visual-grid,
.routing-surface-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: minmax(0, 1.4fr) minmax(300px, 0.92fr);
}

.command-board,
.flow-stage,
.routing-stage,
.flow-sidebar-card {
    position: relative;
    overflow: hidden;
    border-radius: 30px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background:
        radial-gradient(circle at top left, rgba(89, 201, 255, 0.12), transparent 38%),
        linear-gradient(180deg, rgba(10, 20, 41, 0.96), rgba(6, 14, 29, 0.93));
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.04),
        0 32px 70px rgba(0, 0, 0, 0.24);
}

.command-board,
.flow-stage,
.routing-stage {
    padding: 1.2rem;
}

.command-side-stack,
.flow-sidebar {
    display: grid;
    gap: 1rem;
}

.command-stat-row {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.85rem;
    margin-bottom: 0.95rem;
}

.command-stat {
    padding: 0.95rem 1rem;
    border-radius: 22px;
    border: 1px solid rgba(255, 255, 255, 0.07);
    background: rgba(255, 255, 255, 0.03);
}

.command-stat-kicker {
    display: block;
    margin-bottom: 0.24rem;
    color: var(--text-muted);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.command-stat strong {
    display: block;
    font-size: 1.18rem;
    letter-spacing: -0.04em;
}

.command-stat span {
    display: block;
    margin-top: 0.24rem;
    color: var(--text-soft);
    line-height: 1.5;
    font-size: 0.88rem;
}

.command-chart-card {
    padding: 1rem;
    border-radius: 26px;
    border: 1px solid rgba(255, 255, 255, 0.07);
    background: rgba(255, 255, 255, 0.03);
}

.command-card-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.command-card-head strong,
.flow-stage-head strong,
.flow-sidebar-card strong {
    font-size: 1.05rem;
    letter-spacing: -0.03em;
}

.command-live-pill,
.flow-status-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.55rem 0.8rem;
    border-radius: 999px;
    color: var(--text-white);
    font-size: 0.78rem;
    font-weight: 700;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.command-live-pill::before,
.flow-status-pill::before {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--accent-blue), var(--accent-mint));
    box-shadow: 0 0 18px rgba(89, 201, 255, 0.46);
}

.command-bars {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    align-items: end;
    gap: 0.8rem;
    min-height: 170px;
}

.command-bar {
    position: relative;
    min-height: 72px;
    border-radius: 20px 20px 12px 12px;
    background: linear-gradient(180deg, rgba(89, 201, 255, 0.95), rgba(47, 124, 255, 0.78));
    box-shadow: 0 24px 40px rgba(29, 88, 196, 0.22);
}

.command-bar::after {
    content: "";
    position: absolute;
    inset: auto 0 -10px;
    height: 10px;
    border-radius: 999px;
    background: rgba(3, 9, 18, 0.48);
    filter: blur(8px);
}

.command-table {
    display: grid;
    gap: 0.7rem;
    margin-top: 0.95rem;
}

.command-row {
    display: grid;
    grid-template-columns: 1.15fr 1.15fr 0.8fr;
    gap: 0.8rem;
    align-items: center;
    padding: 0.8rem 0.92rem;
    border-radius: 20px;
    border: 1px solid rgba(255, 255, 255, 0.07);
    background: rgba(255, 255, 255, 0.03);
    color: var(--text-soft);
    font-size: 0.9rem;
}

.command-row.head {
    color: #bfe7ff;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    background: rgba(89, 201, 255, 0.08);
}

.command-status {
    justify-self: start;
    display: inline-flex;
    align-items: center;
    padding: 0.48rem 0.7rem;
    border-radius: 999px;
    color: #bcefff;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    background: rgba(89, 201, 255, 0.1);
}

.command-status.warm {
    color: #ffe5be;
    background: rgba(255, 189, 107, 0.12);
}

.command-status.mint {
    color: #c2fff6;
    background: rgba(83, 239, 213, 0.12);
}

.command-device-shell {
    width: 100%;
}

.command-device-screen {
    min-height: auto;
}

.command-device-image {
    width: 100%;
    border-radius: 24px;
    border: 1px solid rgba(11, 24, 48, 0.08);
    box-shadow: 0 18px 34px rgba(18, 35, 58, 0.14);
}

.flow-stage-head,
.flow-sidebar-card {
    display: grid;
    gap: 0.55rem;
}

.flow-stage-head {
    margin-bottom: 1rem;
}

.flow-stage-head p,
.flow-sidebar-card p {
    color: var(--text-soft);
    line-height: 1.6;
}

.flow-map {
    position: relative;
    min-height: 380px;
    border-radius: 28px;
    border: 1px solid rgba(255, 255, 255, 0.07);
    background:
        radial-gradient(circle at center, rgba(89, 201, 255, 0.06), transparent 54%),
        rgba(255, 255, 255, 0.02);
    overflow: hidden;
}

.flow-map::before {
    content: "";
    position: absolute;
    inset: 10% 16%;
    border-radius: 999px;
    border: 1px solid rgba(89, 201, 255, 0.12);
}

.flow-node {
    position: absolute;
    min-width: 140px;
    padding: 0.9rem 1rem;
    border-radius: 24px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: linear-gradient(180deg, rgba(12, 27, 53, 0.96), rgba(8, 19, 39, 0.94));
    box-shadow: 0 22px 48px rgba(0, 0, 0, 0.18);
}

.flow-node strong {
    display: block;
    font-size: 0.98rem;
    letter-spacing: -0.03em;
}

.flow-node span {
    display: block;
    margin-top: 0.2rem;
    color: var(--text-muted);
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.flow-node.primary {
    background:
        radial-gradient(circle at top left, rgba(89, 201, 255, 0.16), transparent 50%),
        linear-gradient(180deg, rgba(11, 28, 54, 0.98), rgba(8, 18, 37, 0.94));
}

.flow-node.warm {
    background:
        radial-gradient(circle at top right, rgba(255, 189, 107, 0.16), transparent 48%),
        linear-gradient(180deg, rgba(18, 24, 42, 0.96), rgba(8, 16, 31, 0.94));
}

.flow-node.mint {
    background:
        radial-gradient(circle at top left, rgba(83, 239, 213, 0.14), transparent 52%),
        linear-gradient(180deg, rgba(9, 24, 36, 0.96), rgba(7, 16, 28, 0.94));
}

.flow-connector {
    position: absolute;
    border-radius: 999px;
    background: linear-gradient(90deg, rgba(78, 200, 255, 0.08), rgba(83, 239, 213, 0.4), rgba(47, 124, 255, 0.14));
    box-shadow: 0 0 24px rgba(89, 201, 255, 0.16);
}

.flow-connector.vertical {
    width: 8px;
    background: linear-gradient(180deg, rgba(78, 200, 255, 0.08), rgba(83, 239, 213, 0.4), rgba(47, 124, 255, 0.14));
}

.flow-anchor-pill {
    position: absolute;
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.7rem 0.95rem;
    border-radius: 999px;
    background: rgba(9, 21, 41, 0.9);
    border: 1px solid rgba(255, 255, 255, 0.08);
    color: var(--text-white);
    font-size: 0.78rem;
    font-weight: 700;
}

.flow-anchor-pill::before {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--accent-blue), var(--accent-mint));
}

.flow-sidebar-card {
    padding: 1rem 1.05rem;
}

.flow-mini-list {
    display: grid;
    gap: 0.8rem;
    margin-top: 0.25rem;
}

.flow-mini-list li {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.9rem;
    padding: 0.8rem 0.9rem;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.07);
}

.flow-mini-list strong {
    font-size: 0.92rem;
}

.flow-mini-list span {
    color: var(--text-muted);
    font-size: 0.82rem;
}

.surface-stack {
    display: grid;
    gap: 1rem;
}

.cinematic-stage {
    position: relative;
    min-height: 620px;
    padding: clamp(1.1rem, 2vw, 1.5rem);
    overflow: hidden;
}

.cinematic-stage::before {
    content: "";
    position: absolute;
    inset: 6% 8% auto auto;
    width: 42%;
    height: 42%;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(255, 194, 107, 0.14), transparent 68%);
    filter: blur(26px);
    pointer-events: none;
}

.cinematic-stage::after {
    content: "";
    position: absolute;
    inset: auto auto 4% 6%;
    width: 48%;
    height: 42%;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(83, 239, 213, 0.14), transparent 70%);
    filter: blur(32px);
    pointer-events: none;
}

.cinematic-board {
    position: relative;
    width: min(82%, 760px);
    margin: 1.2rem 0 0 auto;
    padding: 1rem;
    border-radius: 34px;
    background: linear-gradient(180deg, rgba(9, 18, 37, 0.92), rgba(6, 13, 26, 0.96));
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.05),
        0 40px 90px rgba(0, 0, 0, 0.34);
    transform: perspective(1800px) rotateY(-16deg) rotateX(6deg);
    transform-style: preserve-3d;
}

.cinematic-board::before {
    content: "";
    position: absolute;
    inset: 14px;
    border-radius: 26px;
    border: 1px solid rgba(255, 255, 255, 0.06);
    pointer-events: none;
}

.cinematic-board img {
    display: block;
    width: 100%;
    border-radius: 24px;
    box-shadow: 0 30px 60px rgba(0, 0, 0, 0.28);
}

.cinematic-device {
    position: absolute;
    left: 3%;
    bottom: 4%;
    z-index: 4;
    width: min(260px, 38%);
    padding: 0.9rem;
    border-radius: 36px;
    background: linear-gradient(180deg, #0b162d, #13223d);
    border: 1px solid rgba(255, 255, 255, 0.1);
    box-shadow: 0 34px 80px rgba(0, 0, 0, 0.38);
    transform: rotate(-11deg);
}

.cinematic-device img {
    display: block;
    width: 100%;
    border-radius: 28px;
    background: linear-gradient(180deg, #f4f9ff, #deecff);
    box-shadow: 0 18px 34px rgba(0, 0, 0, 0.18);
}

.cinematic-device-copy {
    display: grid;
    gap: 0.25rem;
    margin-top: 0.9rem;
}

.cinematic-device-copy strong {
    font-size: 1rem;
    letter-spacing: -0.03em;
}

.cinematic-device-copy span {
    color: var(--text-soft);
    line-height: 1.5;
    font-size: 0.88rem;
}

.cinematic-float {
    position: absolute;
    z-index: 5;
    display: grid;
    gap: 0.4rem;
    padding: 1rem 1.05rem;
    border-radius: 24px;
    background: rgba(8, 18, 37, 0.88);
    border: 1px solid rgba(143, 210, 255, 0.16);
    box-shadow: 0 24px 50px rgba(0, 0, 0, 0.24);
    backdrop-filter: blur(18px);
    max-width: min(270px, 44%);
}

.cinematic-float strong {
    font-size: 1rem;
    letter-spacing: -0.03em;
}

.cinematic-float p,
.cinematic-float span {
    color: var(--text-soft);
    line-height: 1.55;
    font-size: 0.88rem;
}

.cinematic-float .eyebrow-mini {
    color: #bfe7ff;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.cinematic-float.top-left {
    top: 4%;
    left: 4%;
}

.cinematic-float.top-right {
    top: 10%;
    right: 4%;
}

.cinematic-float.bottom-right {
    right: 5%;
    bottom: 7%;
}

.cinematic-float.mid-right {
    right: 2%;
    top: 42%;
}

.cinematic-pill-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.cinematic-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.55rem 0.78rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.08);
    color: var(--text-white);
    font-size: 0.78rem;
    font-weight: 700;
}

.cinematic-pill::before {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--accent-blue), var(--accent-mint));
    box-shadow: 0 0 16px rgba(89, 201, 255, 0.46);
}

.cinematic-orbit {
    position: absolute;
    inset: 14% 10% 10% 18%;
    border-radius: 999px;
    border: 1px solid rgba(89, 201, 255, 0.12);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.02);
    pointer-events: none;
}

.cinematic-orbit::before,
.cinematic-orbit::after {
    content: "";
    position: absolute;
    border-radius: 50%;
}

.showcase-stage {
    position: relative;
    min-height: 560px;
    height: auto;
    padding: clamp(0.9rem, 1.8vw, 1.25rem);
    overflow: visible;
    background:
        radial-gradient(circle at 14% 18%, rgba(89, 201, 255, 0.14), transparent 24%),
        radial-gradient(circle at 86% 16%, rgba(255, 190, 103, 0.08), transparent 22%),
        radial-gradient(circle at 50% 110%, rgba(83, 239, 213, 0.1), transparent 30%),
        linear-gradient(180deg, rgba(8, 17, 33, 0.98), rgba(6, 13, 24, 0.96));
}

.hero-grid.hero-grid-showcase .showcase-stage,
.hero-grid.hero-grid-home .showcase-stage {
    min-height: 760px;
    height: auto;
    padding: clamp(0.95rem, 1.7vw, 1.2rem) clamp(0.95rem, 1.8vw, 1.2rem) clamp(1.65rem, 2.8vw, 2.2rem);
    overflow: visible;
}

.showcase-stage::before {
    content: "";
    position: absolute;
    inset: 18px;
    border-radius: 34px;
    border: 1px solid rgba(255, 255, 255, 0.05);
    background:
        linear-gradient(rgba(255, 255, 255, 0.02) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.02) 1px, transparent 1px);
    background-size: 52px 52px;
    mask-image: radial-gradient(circle at center, rgba(0, 0, 0, 0.92), transparent 100%);
    pointer-events: none;
    opacity: 0.7;
}

.showcase-glow {
    position: absolute;
    border-radius: 999px;
    filter: blur(46px);
    opacity: 0.6;
    pointer-events: none;
}

.showcase-glow.glow-a {
    top: -4%;
    left: -6%;
    width: 220px;
    height: 220px;
    background: rgba(89, 201, 255, 0.28);
}

.showcase-glow.glow-b {
    right: -4%;
    bottom: -8%;
    width: 240px;
    height: 240px;
    background: rgba(83, 239, 213, 0.22);
}

.showcase-orbit {
    position: absolute;
    inset: 12% 10%;
    border-radius: 999px;
    border: 1px solid rgba(89, 201, 255, 0.14);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.02);
    opacity: 0.32;
}

.showcase-orbit::before,
.showcase-orbit::after {
    content: "";
    position: absolute;
    border-radius: 999px;
}

.showcase-orbit::before {
    inset: 12% 14%;
    border: 1px dashed rgba(89, 201, 255, 0.12);
}

.showcase-orbit::after {
    width: 14px;
    height: 14px;
    top: 16%;
    right: 12%;
    background: #53d0ff;
    box-shadow: 0 0 0 10px rgba(83, 208, 255, 0.12), 0 0 22px rgba(83, 208, 255, 0.8);
}

.showcase-board {
    position: relative;
    z-index: 2;
    width: min(100%, 720px);
    margin: clamp(0.6rem, 2.4vw, 1.6rem) auto 0;
    padding: 0.65rem;
    border-radius: 30px;
    background: linear-gradient(180deg, rgba(10, 21, 40, 0.94), rgba(7, 15, 28, 0.98));
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.05),
        0 36px 80px rgba(0, 0, 0, 0.34);
    transform: perspective(1800px) rotateY(-2deg) rotateX(1deg) translateZ(0);
    transform-style: preserve-3d;
}

.showcase-board.showcase-board-expansive,
.hero-grid.hero-grid-showcase .showcase-board {
    width: min(100%, 820px);
    margin: clamp(0.35rem, 1.2vw, 0.85rem) auto 0 0;
}

.showcase-board.showcase-board-home,
.hero-grid.hero-grid-home .showcase-board {
    width: min(100%, 900px);
    margin: clamp(0.25rem, 1vw, 0.75rem) auto 0 0;
}

.showcase-board::before {
    content: "";
    position: absolute;
    inset: 14px;
    border-radius: 26px;
    border: 1px solid rgba(255, 255, 255, 0.05);
    pointer-events: none;
}

.showcase-board::after {
    content: "";
    position: absolute;
    left: 8%;
    right: 8%;
    bottom: -34px;
    height: 62px;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(16, 35, 67, 0.78), transparent 72%);
    filter: blur(18px);
    opacity: 0.86;
    pointer-events: none;
}

.showcase-board img {
    display: block;
    width: 100%;
    aspect-ratio: 20 / 13;
    object-fit: cover;
    object-position: center center;
    border-radius: 24px;
    background: linear-gradient(180deg, rgba(7, 14, 26, 0.96), rgba(6, 12, 23, 0.98));
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.26);
}

.process-visual {
    position: relative;
    aspect-ratio: auto;
    min-height: 420px;
    height: auto;
    padding: clamp(1rem, 2vw, 1.4rem);
    overflow: visible;
    border-radius: 24px;
    background:
        radial-gradient(circle at 18% 18%, rgba(89, 201, 255, 0.18), transparent 24%),
        radial-gradient(circle at 82% 18%, rgba(255, 189, 107, 0.12), transparent 22%),
        linear-gradient(180deg, rgba(7, 15, 28, 0.98), rgba(5, 11, 21, 0.98));
}

.process-platform {
    min-height: 860px;
    height: auto;
    overflow: visible;
    padding-bottom: 1.35rem;
}

.process-ecosystem {
    min-height: 860px;
    height: auto;
    padding-left: clamp(1rem, 2vw, 1.5rem);
    padding-right: clamp(0.95rem, 1.6vw, 1.25rem);
    padding-bottom: 2rem;
}

.process-solutions {
    min-height: 700px;
    height: auto;
    padding-bottom: 1.4rem;
}

.process-visual::before,
.process-visual::after {
    content: "";
    position: absolute;
    pointer-events: none;
}

.process-visual::before {
    inset: 12px;
    border-radius: 20px;
    border: 1px solid rgba(255, 255, 255, 0.06);
    background:
        linear-gradient(rgba(255, 255, 255, 0.02) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.02) 1px, transparent 1px);
    background-size: 28px 28px;
    opacity: 0.65;
}

.process-visual::after {
    inset: auto 14% 4% 14%;
    height: 52px;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(20, 39, 72, 0.72), transparent 72%);
    filter: blur(18px);
}

.process-topline {
    position: relative;
    z-index: 3;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.process-story {
    position: relative;
    z-index: 3;
    max-width: min(560px, 100%);
    margin-bottom: 1rem;
}

.process-story-title {
    display: block;
    font-family: "Sora", sans-serif;
    font-size: clamp(1.15rem, 1.2vw + 0.85rem, 1.6rem);
    line-height: 1.15;
    color: rgba(248, 251, 255, 0.96);
}

.process-story-copy {
    margin-top: 0.55rem;
    max-width: 52ch;
    color: var(--text-muted);
    font-size: 0.92rem;
    line-height: 1.6;
}

.process-kicker,
.process-status {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 0.45rem 0.8rem;
    border-radius: 999px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    font-size: 0.72rem;
    font-weight: 800;
}

.process-kicker {
    color: var(--accent-blue);
    background: rgba(89, 201, 255, 0.08);
    border: 1px solid rgba(89, 201, 255, 0.18);
}

.process-status {
    color: rgba(244, 248, 255, 0.94);
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.process-stage {
    position: relative;
    z-index: 2;
    overflow: hidden;
    border-radius: 20px;
    background: linear-gradient(180deg, rgba(14, 27, 50, 0.92), rgba(7, 15, 29, 0.96));
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.05),
        0 18px 40px rgba(0, 0, 0, 0.2);
    transition: transform 0.4s ease, border-color 0.4s ease, box-shadow 0.4s ease, background 0.4s ease;
}

.process-stage::before {
    content: "";
    position: absolute;
    inset: -30% auto -30% -30%;
    width: 48%;
    background: linear-gradient(180deg, rgba(89, 201, 255, 0), rgba(89, 201, 255, 0.16), rgba(89, 201, 255, 0));
    transform: rotate(18deg) translateX(-180%);
    opacity: 0;
}

.process-stage-index {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    margin-bottom: 0.85rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.05);
    color: var(--accent-blue);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.1em;
}

.process-stage strong,
.process-stage-label {
    display: block;
    font-family: "Sora", sans-serif;
    font-size: 1rem;
    line-height: 1.2;
}

.process-stage p {
    margin-top: 0.45rem;
    color: var(--text-muted);
    font-size: 0.82rem;
    line-height: 1.45;
}

.process-stage-meta {
    display: inline-flex;
    align-items: center;
    margin-top: 0.9rem;
    padding: 0.42rem 0.66rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.06);
    color: rgba(244, 248, 255, 0.74);
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.process-stage:hover {
    transform: translateY(-6px);
    border-color: rgba(84, 240, 213, 0.32);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.08),
        0 22px 54px rgba(0, 0, 0, 0.28),
        0 0 0 1px rgba(84, 240, 213, 0.12);
}

.process-stage.is-active,
.process-visual[data-active-step="1"] .process-stage[data-step="1"],
.process-visual[data-active-step="2"] .process-stage[data-step="2"],
.process-visual[data-active-step="3"] .process-stage[data-step="3"],
.process-visual[data-active-step="4"] .process-stage[data-step="4"] {
    transform: translateY(-6px) scale(1.01);
    border-color: rgba(89, 201, 255, 0.34);
    background: linear-gradient(180deg, rgba(18, 38, 70, 0.96), rgba(8, 18, 34, 0.98));
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.08),
        0 24px 54px rgba(8, 21, 41, 0.36),
        0 0 0 1px rgba(89, 201, 255, 0.14);
}

.process-stage.is-active::before,
.process-visual[data-active-step="1"] .process-stage[data-step="1"]::before,
.process-visual[data-active-step="2"] .process-stage[data-step="2"]::before,
.process-visual[data-active-step="3"] .process-stage[data-step="3"]::before,
.process-visual[data-active-step="4"] .process-stage[data-step="4"]::before {
    opacity: 1;
    animation: processSweep 1.2s ease;
}

.process-platform-rail {
    position: relative;
    z-index: 1;
    height: 96px;
    margin: 0 0 1rem;
}

.process-rail-line,
.process-rail-glow {
    position: absolute;
    left: 10%;
    right: 10%;
    top: 48px;
    height: 2px;
    border-radius: 999px;
}

.process-rail-line {
    background: linear-gradient(90deg, rgba(89, 201, 255, 0.2), rgba(84, 240, 213, 0.2), rgba(255, 189, 107, 0.2));
}

.process-rail-glow {
    background: linear-gradient(90deg, rgba(89, 201, 255, 0), rgba(89, 201, 255, 0.7), rgba(84, 240, 213, 0));
    filter: blur(9px);
    animation: railGlow 3.8s ease-in-out infinite;
}

.process-packet {
    position: absolute;
    top: 36px;
    left: 10%;
    width: 22px;
    height: 22px;
    border-radius: 8px;
    background: linear-gradient(135deg, var(--accent-blue), var(--accent-mint));
    box-shadow:
        0 0 0 8px rgba(89, 201, 255, 0.08),
        0 0 24px rgba(89, 201, 255, 0.6);
}

.packet-primary {
    animation: platformPacket 6.2s cubic-bezier(0.4, 0, 0.2, 1) infinite;
}

.packet-secondary {
    top: 50px;
    width: 14px;
    height: 14px;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--accent-amber), #ffe3bc);
    box-shadow:
        0 0 0 7px rgba(255, 189, 107, 0.08),
        0 0 18px rgba(255, 189, 107, 0.55);
    animation: platformPacketSecondary 6.2s cubic-bezier(0.4, 0, 0.2, 1) infinite;
}

.process-platform-grid {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.9rem;
}

.process-platform-grid .process-stage {
    min-height: 186px;
    padding: 1rem;
}

.process-chip-ledger {
    position: relative;
    z-index: 2;
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    margin-top: 1rem;
}

.ledger-chip {
    padding: 0.5rem 0.75rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.06);
    color: rgba(244, 248, 255, 0.84);
    font-size: 0.72rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.ledger-chip {
    opacity: 0.42;
    transform: translateY(0);
    transition: opacity 0.35s ease, transform 0.35s ease, border-color 0.35s ease, background 0.35s ease, color 0.35s ease;
}

.process-visual[data-active-step="1"] .ledger-chip[data-step-group="1"],
.process-visual[data-active-step="2"] .ledger-chip[data-step-group="2"],
.process-visual[data-active-step="3"] .ledger-chip[data-step-group="3"],
.process-visual[data-active-step="4"] .ledger-chip[data-step-group="4"] {
    opacity: 1;
    transform: translateY(-2px);
    border-color: rgba(89, 201, 255, 0.22);
    background: rgba(89, 201, 255, 0.08);
    color: rgba(248, 251, 255, 0.94);
}

.process-rail-stop {
    position: absolute;
    top: 39px;
    width: 18px;
    height: 18px;
    border-radius: 999px;
    border: 2px solid rgba(89, 201, 255, 0.18);
    background: rgba(8, 18, 34, 0.92);
    box-shadow: 0 0 0 8px rgba(89, 201, 255, 0.04);
    transition: transform 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease, background 0.35s ease;
}

.stop-one { left: 10%; }
.stop-two { left: 35.8%; }
.stop-three { left: 61.6%; }
.stop-four { left: 87.4%; }

.process-visual[data-active-step="1"] .stop-one,
.process-visual[data-active-step="2"] .stop-two,
.process-visual[data-active-step="3"] .stop-three,
.process-visual[data-active-step="4"] .stop-four {
    transform: scale(1.12);
    border-color: rgba(84, 240, 213, 0.54);
    background: rgba(84, 240, 213, 0.2);
    box-shadow:
        0 0 0 8px rgba(84, 240, 213, 0.08),
        0 0 24px rgba(84, 240, 213, 0.24);
}

.process-document-card {
    position: absolute;
    top: 0;
    right: 0;
    z-index: 2;
    width: min(238px, 34%);
    padding: 0.95rem 1rem;
    border-radius: 18px;
    background: linear-gradient(180deg, rgba(14, 29, 54, 0.96), rgba(7, 16, 30, 0.98));
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.05),
        0 18px 42px rgba(0, 0, 0, 0.26);
}

.process-document-card::before {
    content: "";
    position: absolute;
    inset: auto auto 12px 12px;
    width: 34px;
    height: 4px;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--accent-blue), var(--accent-mint));
    opacity: 0.74;
}

.process-document-kicker {
    display: inline-flex;
    margin-bottom: 0.45rem;
    color: var(--accent-blue);
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.process-document-card strong {
    display: block;
    font-family: "Sora", sans-serif;
    font-size: 0.98rem;
    line-height: 1.28;
}

.process-document-card p {
    margin-top: 0.4rem;
    color: var(--text-muted);
    font-size: 0.8rem;
    line-height: 1.55;
}

.process-home {
    min-height: 760px;
    height: auto;
    padding-bottom: 1.45rem;
}

.process-home .home-field {
    position: relative;
    min-height: 560px;
    margin-top: 0.4rem;
}

.process-home .home-orbit,
.process-home .home-link {
    position: absolute;
    pointer-events: none;
}

.process-home .home-orbit {
    border-radius: 50%;
    border: 1px solid rgba(89, 201, 255, 0.16);
}

.process-home .home-orbit.orbit-one {
    inset: 10% 18% 18%;
    animation: slowSpinReverse 22s linear infinite;
}

.process-home .home-orbit.orbit-two {
    inset: 3% 9% 10%;
    border-style: dashed;
    opacity: 0.72;
    animation: slowSpin 20s linear infinite;
}

.process-home .home-core {
    position: absolute;
    top: 37%;
    left: 50%;
    z-index: 3;
    width: min(250px, 39%);
    padding: 0.9rem 1rem;
    border-radius: 30px;
    transform: translate(-50%, -50%);
    text-align: center;
    background:
        radial-gradient(circle at top, rgba(89, 201, 255, 0.18), transparent 52%),
        linear-gradient(180deg, rgba(17, 37, 69, 0.98), rgba(7, 16, 31, 0.98));
    border: 1px solid rgba(89, 201, 255, 0.24);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.08),
        0 28px 64px rgba(0, 0, 0, 0.34);
}

.process-home .home-core-kicker {
    display: inline-flex;
    margin-bottom: 0.45rem;
    color: var(--accent-blue);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.process-home .home-core strong {
    display: block;
    font-family: "Sora", sans-serif;
    font-size: 0.98rem;
    line-height: 1.12;
}

.process-home .home-core p {
    margin-top: 0.45rem;
    color: var(--text-muted);
    font-size: 0.72rem;
    line-height: 1.55;
}

.process-home .home-node {
    position: absolute;
    width: 154px;
    min-height: 132px;
    padding: 0.8rem;
}

.process-home .node-pocket {
    top: 4%;
    left: 5%;
}

.process-home .node-ai {
    top: 4%;
    right: 5%;
}

.process-home .node-routing {
    bottom: 18%;
    left: 10%;
}

.process-home .node-worker {
    bottom: 18%;
    right: 10%;
}

.process-home .home-link {
    height: 2px;
    background: linear-gradient(90deg, rgba(89, 201, 255, 0.08), rgba(89, 201, 255, 0.42), rgba(89, 201, 255, 0.08));
    opacity: 0.46;
    transform-origin: left center;
    transition: opacity 0.35s ease, box-shadow 0.35s ease, background 0.35s ease;
}

.process-home .link-pocket {
    top: 20%;
    left: 25%;
    width: 23%;
    transform: rotate(18deg);
}

.process-home .link-ai {
    top: 20%;
    right: 25%;
    width: 23%;
    transform: rotate(-18deg);
}

.process-home .link-routing {
    bottom: 31%;
    left: 30%;
    width: 18%;
    transform: rotate(-15deg);
}

.process-home .link-worker {
    bottom: 31%;
    right: 30%;
    width: 18%;
    transform: rotate(15deg);
}

.process-home[data-active-step="1"] .link-pocket,
.process-home[data-active-step="2"] .link-ai,
.process-home[data-active-step="3"] .link-routing,
.process-home[data-active-step="4"] .link-worker {
    opacity: 1;
    background: linear-gradient(90deg, rgba(89, 201, 255, 0.14), rgba(84, 240, 213, 0.74), rgba(89, 201, 255, 0.14));
    box-shadow: 0 0 18px rgba(84, 240, 213, 0.22);
}

.process-home .home-outcome {
    position: absolute;
    left: 50%;
    bottom: 3%;
    z-index: 3;
    width: min(320px, 54%);
    padding: 0.82rem 0.92rem;
    border-radius: 24px;
    transform: translateX(-50%);
    background: rgba(8, 18, 34, 0.92);
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.05),
        0 24px 56px rgba(0, 0, 0, 0.28);
    text-align: center;
}

.process-home .home-outcome-kicker {
    display: inline-flex;
    margin-bottom: 0.4rem;
    color: var(--accent-mint);
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.process-home .home-outcome strong {
    display: block;
    font-family: "Sora", sans-serif;
    font-size: 0.88rem;
    line-height: 1.2;
}

.process-home .home-outcome p {
    margin-top: 0.35rem;
    color: var(--text-muted);
    font-size: 0.68rem;
    line-height: 1.5;
}

.home-signal-ledger {
    margin-top: 1.15rem;
}

.process-ecosystem .ecosystem-field {
    position: relative;
    min-height: 760px;
    margin-top: 0.8rem;
    margin-left: 18px;
}

.process-ecosystem .ecosystem-ring,
.process-ecosystem .ecosystem-connector,
.process-ecosystem .ecosystem-pulse {
    position: absolute;
    pointer-events: none;
}

.process-ecosystem .ecosystem-ring {
    inset: 18% 22%;
    border-radius: 50%;
    border: 1px solid rgba(89, 201, 255, 0.16);
}

.process-ecosystem .ecosystem-ring.ring-two {
    inset: 9% 14%;
    border-style: dashed;
    opacity: 0.7;
    animation: slowSpin 16s linear infinite;
}

.process-ecosystem .ecosystem-ring.ring-one {
    animation: slowSpinReverse 18s linear infinite;
}

.process-ecosystem .ecosystem-core {
    position: absolute;
    top: 50%;
    left: 53%;
    z-index: 3;
    width: 220px;
    padding: 1.1rem 1.2rem;
    border-radius: 28px;
    transform: translate(-50%, -50%);
    background:
        radial-gradient(circle at top, rgba(89, 201, 255, 0.16), transparent 48%),
        linear-gradient(180deg, rgba(18, 36, 68, 0.98), rgba(8, 18, 33, 0.98));
    border: 1px solid rgba(89, 201, 255, 0.24);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.08),
        0 26px 60px rgba(0, 0, 0, 0.34);
    text-align: center;
}

.process-ecosystem .ecosystem-core-kicker {
    display: block;
    margin-bottom: 0.35rem;
    color: var(--accent-blue);
    font-size: 0.72rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    font-weight: 800;
}

.process-ecosystem .ecosystem-core strong {
    display: block;
    font-family: "Sora", sans-serif;
    font-size: 1.1rem;
}

.process-ecosystem .ecosystem-core p {
    margin-top: 0.4rem;
    color: var(--text-muted);
    font-size: 0.82rem;
}

.process-ecosystem .ecosystem-core-signals {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.4rem;
    margin-top: 0.85rem;
}

.process-ecosystem .ecosystem-core-signals span {
    padding: 0.32rem 0.56rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.06);
    color: rgba(244, 248, 255, 0.74);
    font-size: 0.64rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.process-ecosystem .ecosystem-node {
    position: absolute;
    width: 146px;
    padding: 0.95rem 1rem;
}

.process-ecosystem .node-pocket {
    top: 2%;
    left: 7%;
}

.process-ecosystem .node-ai {
    top: 2%;
    right: 4%;
}

.process-ecosystem .node-routing {
    bottom: 2%;
    left: 10%;
}

.process-ecosystem .node-worker {
    bottom: 2%;
    right: 7%;
}

.process-ecosystem .ecosystem-connector {
    background: linear-gradient(90deg, rgba(89, 201, 255, 0.08), rgba(89, 201, 255, 0.42), rgba(89, 201, 255, 0.08));
    transform-origin: left center;
    height: 2px;
    filter: blur(0.2px);
    opacity: 0.5;
    transition: opacity 0.35s ease, box-shadow 0.35s ease, background 0.35s ease;
}

.process-ecosystem .connector-pocket {
    top: 22%;
    left: 31%;
    width: 23%;
    transform: rotate(19deg);
}

.process-ecosystem .connector-ai {
    top: 22%;
    right: 24%;
    width: 23%;
    transform: rotate(-19deg);
}

.process-ecosystem .connector-routing {
    bottom: 22%;
    left: 33%;
    width: 20%;
    transform: rotate(-18deg);
}

.process-ecosystem .connector-worker {
    bottom: 22%;
    right: 24%;
    width: 20%;
    transform: rotate(18deg);
}

.process-ecosystem[data-active-step="1"] .connector-pocket,
.process-ecosystem[data-active-step="2"] .connector-ai,
.process-ecosystem[data-active-step="3"] .connector-routing,
.process-ecosystem[data-active-step="4"] .connector-worker {
    opacity: 1;
    background: linear-gradient(90deg, rgba(89, 201, 255, 0.12), rgba(84, 240, 213, 0.74), rgba(89, 201, 255, 0.12));
    box-shadow: 0 0 18px rgba(84, 240, 213, 0.22);
}

.process-ecosystem .ecosystem-pulse {
    width: 18px;
    height: 18px;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--accent-blue), var(--accent-mint));
    box-shadow: 0 0 0 10px rgba(89, 201, 255, 0.08), 0 0 18px rgba(89, 201, 255, 0.7);
}

.process-ecosystem .pulse-one {
    top: 30%;
    left: 28%;
    animation: ecosystemPulseOne 5.8s linear infinite;
}

.process-ecosystem .pulse-two {
    bottom: 27%;
    right: 29%;
    width: 14px;
    height: 14px;
    background: linear-gradient(135deg, var(--accent-amber), #ffe0ba);
    box-shadow: 0 0 0 8px rgba(255, 189, 107, 0.08), 0 0 16px rgba(255, 189, 107, 0.6);
    animation: ecosystemPulseTwo 5.8s linear infinite;
}

.process-ecosystem .ecosystem-satellite {
    position: absolute;
    z-index: 1;
    padding: 0.35rem 0.65rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.06);
    color: rgba(244, 248, 255, 0.7);
    font-size: 0.68rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.process-ecosystem .sat-field { top: 4%; left: 36%; }
.process-ecosystem .sat-cfo { top: 44%; right: 1%; }
.process-ecosystem .sat-backoffice { bottom: 3%; left: 38%; }
.process-ecosystem .sat-pohoda { top: 44%; left: 7%; }

.process-solutions .solutions-field {
    position: relative;
    z-index: 2;
    min-height: 500px;
    margin: 0.8rem 0 1.5rem;
}

.process-solutions .solutions-lane {
    position: absolute;
    left: 0;
    right: 0;
    display: grid;
    grid-template-columns: 1fr 1.2fr 1fr;
    align-items: center;
    gap: 1.15rem;
}

.process-solutions .lane-office { top: 6%; }
.process-solutions .lane-company { bottom: 6%; }

.process-solutions .lane-node {
    display: inline-flex;
    flex-direction: column;
    justify-content: center;
    min-height: 76px;
    padding: 0.95rem 1.05rem;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.06);
    color: rgba(244, 248, 255, 0.88);
    font-size: 0.82rem;
    text-align: center;
    transition: transform 0.35s ease, border-color 0.35s ease, background 0.35s ease, box-shadow 0.35s ease, opacity 0.35s ease;
}

.process-solutions .lane-node strong {
    display: block;
    font-family: "Sora", sans-serif;
    font-size: 0.88rem;
    line-height: 1.2;
    letter-spacing: 0.02em;
}

.process-solutions .lane-node span {
    display: block;
    margin-top: 0.28rem;
    color: rgba(244, 248, 255, 0.68);
    font-size: 0.67rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.process-solutions .lane-track {
    position: relative;
    height: 4px;
    border-radius: 999px;
    background: linear-gradient(90deg, rgba(89, 201, 255, 0.14), rgba(84, 240, 213, 0.28), rgba(255, 189, 107, 0.14));
}

.process-solutions .lane-track::before {
    content: "";
    position: absolute;
    inset: -7px 0;
    border-radius: 999px;
    background: inherit;
    filter: blur(10px);
    opacity: 0.45;
}

.process-solutions .lane-packet {
    position: absolute;
    left: 26%;
    width: 16px;
    height: 16px;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--accent-blue), var(--accent-mint));
    box-shadow: 0 0 0 8px rgba(89, 201, 255, 0.07), 0 0 20px rgba(89, 201, 255, 0.65);
}

.process-solutions .lane-office .lane-packet {
    top: 50%;
    animation: laneFlow 5.8s ease-in-out infinite;
}

.process-solutions .lane-company .lane-packet {
    top: 50%;
    background: linear-gradient(135deg, var(--accent-amber), #ffe3bc);
    box-shadow: 0 0 0 8px rgba(255, 189, 107, 0.08), 0 0 20px rgba(255, 189, 107, 0.5);
    animation: laneFlow 5.8s ease-in-out infinite 1.4s;
}

.process-solutions[data-active-step="1"] .lane-office .lane-node,
.process-solutions[data-active-step="2"] .lane-company .lane-node,
.process-solutions[data-active-step="4"] .lane-target {
    transform: translateY(-4px);
    border-color: rgba(89, 201, 255, 0.24);
    background: rgba(89, 201, 255, 0.08);
    box-shadow: 0 18px 36px rgba(8, 21, 41, 0.2);
}

.process-solutions .solutions-core {
    display: none;
}

.process-solutions .solutions-stage-row {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.9rem;
}

.process-solutions .solutions-stage-row .process-stage {
    min-height: 176px;
    padding: 1rem;
}

.process-solutions .solutions-stage-row .process-stage[data-step="1"] { order: 1; }
.process-solutions .solutions-stage-row .process-stage[data-step="2"] { order: 2; }
.process-solutions .solutions-stage-row .process-stage[data-step="3"] { order: 3; }
.process-solutions .solutions-stage-row .process-stage[data-step="4"] { order: 4; }

.process-solutions .solutions-stage-row .process-stage[data-step="3"] {
    transition: border-color 0.35s ease, background 0.35s ease, box-shadow 0.35s ease, opacity 0.35s ease;
}

.process-solutions .solutions-stage-row .process-stage[data-step="3"]:hover,
.process-solutions .solutions-stage-row .process-stage[data-step="3"].is-active,
.process-solutions[data-active-step="3"] .solutions-stage-row .process-stage[data-step="3"] {
    transform: none;
}

.solutions-fit-ledger {
    margin-top: 1.1rem;
}

@keyframes processSweep {
    0% {
        transform: rotate(18deg) translateX(-180%);
    }
    100% {
        transform: rotate(18deg) translateX(320%);
    }
}

@keyframes railGlow {
    0%, 100% {
        transform: translateX(-18%);
        opacity: 0.24;
    }
    50% {
        transform: translateX(18%);
        opacity: 0.84;
    }
}

@keyframes platformPacket {
    0% {
        transform: translateX(0) scale(0.88);
        opacity: 0;
    }
    8% {
        opacity: 1;
    }
    22% {
        transform: translateX(120px) scale(1);
    }
    48% {
        transform: translateX(280px) scale(1);
    }
    72% {
        transform: translateX(430px) scale(1);
    }
    92% {
        transform: translateX(560px) scale(0.94);
        opacity: 1;
    }
    100% {
        transform: translateX(610px) scale(0.82);
        opacity: 0;
    }
}

@keyframes platformPacketSecondary {
    0%, 12% {
        transform: translateX(0) scale(0.8);
        opacity: 0;
    }
    18% {
        opacity: 1;
    }
    44% {
        transform: translateX(230px) scale(1);
    }
    74% {
        transform: translateX(440px) scale(1);
    }
    94% {
        transform: translateX(580px) scale(0.86);
        opacity: 1;
    }
    100% {
        transform: translateX(610px) scale(0.8);
        opacity: 0;
    }
}

@keyframes slowSpin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

@keyframes slowSpinReverse {
    from { transform: rotate(360deg); }
    to { transform: rotate(0deg); }
}

@keyframes ecosystemPulseOne {
    0% {
        transform: translate(0, 0) scale(0.8);
        opacity: 0;
    }
    10% {
        opacity: 1;
    }
    28% {
        transform: translate(120px, -62px) scale(1);
    }
    48% {
        transform: translate(242px, 18px) scale(1);
    }
    70% {
        transform: translate(110px, 102px) scale(0.94);
    }
    100% {
        transform: translate(0, 0) scale(0.8);
        opacity: 0;
    }
}

@keyframes ecosystemPulseTwo {
    0%, 18% {
        transform: translate(0, 0) scale(0.82);
        opacity: 0;
    }
    26% {
        opacity: 1;
    }
    52% {
        transform: translate(-122px, 58px) scale(1);
    }
    76% {
        transform: translate(-242px, -12px) scale(0.96);
    }
    100% {
        transform: translate(0, 0) scale(0.82);
        opacity: 0;
    }
}

@keyframes laneFlow {
    0% {
        transform: translate(-140px, -50%) scale(0.82);
        opacity: 0;
    }
    12% {
        opacity: 1;
    }
    34% {
        transform: translate(80px, -50%) scale(1);
    }
    56% {
        transform: translate(270px, -50%) scale(1.02);
    }
    82% {
        transform: translate(500px, -50%) scale(0.95);
        opacity: 1;
    }
    100% {
        transform: translate(620px, -50%) scale(0.82);
        opacity: 0;
    }
}

.showcase-dock {
    display: none;
}

.showcase-dot {
    width: 12px;
    height: 12px;
    border-radius: 999px;
    background: var(--accent-blue);
    box-shadow: 0 0 18px rgba(83, 208, 255, 0.8);
}

.showcase-dot.mint {
    background: #59ffd7;
    box-shadow: 0 0 18px rgba(89, 255, 215, 0.8);
}

.showcase-dot.warm {
    background: #f5b872;
    box-shadow: 0 0 18px rgba(245, 184, 114, 0.7);
}

.cinematic-orbit::before {
    top: 12%;
    left: 18%;
    width: 12px;
    height: 12px;
    background: linear-gradient(135deg, var(--accent-blue), var(--accent-mint));
    box-shadow: 0 0 18px rgba(89, 201, 255, 0.5);
}

.cinematic-orbit::after {
    right: 12%;
    bottom: 18%;
    width: 18px;
    height: 18px;
    background: radial-gradient(circle, rgba(255, 189, 107, 0.78), rgba(255, 189, 107, 0.12));
    box-shadow: 0 0 26px rgba(255, 189, 107, 0.24);
}

.signal-grid,
.persona-grid {
    display: grid;
    gap: 0.85rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.signal-card,
.persona-card {
    position: relative;
    overflow: hidden;
    display: grid;
    gap: 0.45rem;
    padding: 0.95rem 1rem;
    border-radius: 22px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background:
        radial-gradient(circle at top left, rgba(89, 201, 255, 0.09), transparent 42%),
        rgba(255, 255, 255, 0.04);
}

.signal-card.warm,
.persona-card.warm {
    background:
        radial-gradient(circle at top right, rgba(255, 189, 107, 0.11), transparent 44%),
        rgba(255, 255, 255, 0.04);
}

.signal-card.mint,
.persona-card.mint {
    background:
        radial-gradient(circle at top left, rgba(83, 239, 213, 0.12), transparent 46%),
        rgba(255, 255, 255, 0.04);
}

.signal-card::before,
.persona-card::before {
    content: "";
    width: 36px;
    height: 36px;
    border-radius: 14px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.04);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.signal-card strong,
.persona-card strong {
    font-size: 1rem;
    letter-spacing: -0.03em;
}

.signal-card p,
.persona-card p {
    color: var(--text-soft);
    line-height: 1.6;
    font-size: 0.9rem;
}

.signal-card span,
.persona-card span {
    color: var(--text-muted);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.timeline-list {
    display: grid;
    gap: 0.8rem;
}

.timeline-item {
    position: relative;
    display: grid;
    gap: 0.25rem;
    padding: 0.9rem 1rem 0.9rem 1.35rem;
    border-radius: 20px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.04);
}

.timeline-item::before {
    content: "";
    position: absolute;
    left: 0.75rem;
    top: 1.05rem;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--accent-blue), var(--accent-mint));
    box-shadow: 0 0 18px rgba(89, 201, 255, 0.38);
}

.timeline-item strong {
    font-size: 0.96rem;
    letter-spacing: -0.02em;
}

.timeline-item p {
    color: var(--text-soft);
    line-height: 1.55;
    font-size: 0.88rem;
}

.timeline-item span {
    color: var(--text-muted);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.story-band {
    display: grid;
    gap: 0.55rem;
    padding: 1rem 1.05rem;
    border-radius: 24px;
    color: var(--text-dark);
    background: linear-gradient(180deg, rgba(247, 251, 255, 0.98), rgba(234, 243, 255, 0.96));
    border: 1px solid rgba(11, 24, 48, 0.08);
    box-shadow: 0 18px 40px rgba(20, 37, 59, 0.08);
}

.story-band strong {
    font-size: 1.04rem;
    letter-spacing: -0.03em;
}

.story-band p {
    color: var(--text-dark-soft);
    line-height: 1.65;
}

.visual-cluster {
    display: grid;
    gap: 1rem;
}

.visual-cluster.two {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.floating-badge {
    position: absolute;
    right: 26px;
    bottom: 26px;
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.82rem 0.95rem;
    border-radius: 999px;
    background: rgba(9, 18, 37, 0.92);
    border: 1px solid rgba(128, 189, 255, 0.18);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.24);
    backdrop-filter: blur(18px);
}

.floating-badge::before {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--accent-blue), var(--accent-mint));
}

.floating-badge span {
    color: var(--text-soft);
    font-size: 0.84rem;
}

.story-proof-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
}

.section-visual-card {
    position: relative;
    overflow: hidden;
    padding: 1rem;
    border-radius: var(--radius-lg);
    background: linear-gradient(180deg, rgba(12, 23, 48, 0.92), rgba(8, 16, 31, 0.9));
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: var(--shadow-soft);
}

.section-visual-card img {
    width: 100%;
    border-radius: 24px;
    border: 1px solid rgba(255, 255, 255, 0.06);
    box-shadow: 0 28px 58px rgba(3, 10, 23, 0.24);
}

.visual-caption {
    display: grid;
    gap: 0.4rem;
    margin-top: 1rem;
}

.visual-caption strong {
    font-size: 1.02rem;
    letter-spacing: -0.03em;
}

.visual-caption p {
    color: var(--text-soft);
    line-height: 1.65;
}

.outcome-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.outcome-card {
    position: relative;
    overflow: hidden;
    padding: 1.3rem;
    border-radius: var(--radius-md);
    background: rgba(255, 255, 255, 0.76);
    border: 1px solid rgba(11, 24, 48, 0.08);
    box-shadow: 0 18px 40px rgba(20, 37, 59, 0.08);
}

.outcome-card strong {
    display: block;
    margin-bottom: 0.4rem;
    color: var(--text-dark);
    font-size: 1rem;
}

.outcome-card p {
    color: var(--text-dark-soft);
    line-height: 1.65;
}

.scan-panel {
    position: relative;
}

.scan-panel::after {
    content: "";
    position: absolute;
    left: 18px;
    right: 18px;
    top: 88px;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(89, 201, 255, 0.94), transparent);
    opacity: 0.5;
    animation: scan-line 4.2s linear infinite;
    pointer-events: none;
}

@keyframes scan-line {
    0% { transform: translateY(0); opacity: 0; }
    12% { opacity: 0.7; }
    50% { opacity: 0.4; }
    100% { transform: translateY(460px); opacity: 0; }
}

.data-row {
    transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}

.data-row:not(.header):hover {
    transform: translateY(-2px);
    border-color: rgba(89, 201, 255, 0.24);
    background: rgba(255, 255, 255, 0.06);
}

.contact-stage-stack {
    display: grid;
    gap: 1rem;
}

.contact-email-card {
    padding: 1.3rem;
    border-radius: var(--radius-md);
    background: linear-gradient(180deg, rgba(10, 20, 41, 0.94), rgba(7, 15, 30, 0.9));
    border: 1px solid rgba(128, 189, 255, 0.18);
    box-shadow: var(--shadow-soft);
    color: var(--text-main);
}

.contact-email-card strong {
    display: block;
    margin-bottom: 0.4rem;
    font-size: 1.12rem;
    letter-spacing: -0.03em;
}

.contact-email-card p {
    color: var(--text-soft);
    line-height: 1.65;
}

.contact-email-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    margin-top: 0.95rem;
    padding: 0.7rem 0.9rem;
    border-radius: 999px;
    color: var(--text-main);
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.contact-email-pill::before {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--accent-blue), var(--accent-mint));
}

.section {
    padding: 0 0 88px;
}

.section-shell,
.cta-shell,
.footer-shell,
.contact-shell {
    padding: clamp(1.45rem, 2vw + 1rem, 2.6rem);
    border-radius: var(--radius-xl);
}

.section-shell {
    position: relative;
    overflow: hidden;
    background: linear-gradient(180deg, rgba(9, 18, 37, 0.78), rgba(7, 15, 30, 0.74));
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: var(--shadow-soft);
    backdrop-filter: blur(20px);
}

.section-shell::before,
.cta-shell::before,
.contact-shell::before {
    content: "";
    position: absolute;
    top: 0;
    left: 10%;
    right: 10%;
    height: 1px;
    background: linear-gradient(90deg, rgba(255, 255, 255, 0), rgba(89, 201, 255, 0.58), rgba(255, 189, 107, 0.22), rgba(255, 255, 255, 0));
    pointer-events: none;
}

.section-shell.light {
    color: var(--text-dark);
    background: linear-gradient(180deg, rgba(249, 252, 255, 0.96), rgba(236, 244, 255, 0.92));
    border: 1px solid rgba(11, 24, 48, 0.08);
}

.section-shell.light .eyebrow,
.contact-shell .eyebrow {
    color: #0d5fd2;
    background: rgba(47, 124, 255, 0.08);
    border-color: rgba(47, 124, 255, 0.14);
}

.section-shell.light .section-title,
.section-shell.light h3,
.section-shell.light h4,
.section-shell.light strong,
.section-shell.light .proof-value {
    color: var(--text-dark);
}

.section-shell.light .section-lead,
.section-shell.light .detail-copy p,
.section-shell.light .feature-card p,
.section-shell.light .step-card p,
.section-shell.light .proof-card p,
.section-shell.light .fit-card p,
.section-shell.light .card-copy,
.section-shell.light .feature-list li,
.section-shell.light .comparison-row p,
.section-shell.light .comparison-points li {
    color: #48607f;
}

.section-shell.light .flow-stage strong,
.section-shell.light .flow-sidebar-card strong,
.section-shell.light .flow-mini-list strong {
    color: #f5f9ff;
}

.section-shell.light .flow-stage-head p,
.section-shell.light .flow-sidebar-card p,
.section-shell.light .flow-mini-list span {
    color: rgba(224, 234, 246, 0.86);
}

.section-shell.light .comparison-row,
.section-shell.light .feature-card,
.section-shell.light .proof-card,
.section-shell.light .fit-card,
.section-shell.light .step-card {
    background: rgba(255, 255, 255, 0.78);
    border-color: rgba(11, 24, 48, 0.08);
    box-shadow: 0 18px 40px rgba(20, 37, 59, 0.08);
}

.section-shell.light .comparison-row.highlight {
    color: var(--text-main);
    background: linear-gradient(180deg, rgba(13, 31, 61, 0.97), rgba(8, 16, 31, 0.94));
    border-color: rgba(128, 189, 255, 0.28);
}

.section-shell.light .comparison-row.highlight h3,
.section-shell.light .comparison-row.highlight .eyebrow,
.section-shell.light .comparison-row.highlight strong {
    color: var(--text-main);
}

.section-shell.light .comparison-row.highlight p,
.section-shell.light .comparison-row.highlight li,
.section-shell.light .comparison-row.highlight span {
    color: var(--text-soft);
}

.section-head {
    display: grid;
    gap: 0.8rem;
    margin-bottom: 1.6rem;
    max-width: 820px;
}

.section-title {
    font-size: clamp(2.3rem, 4vw, 4.3rem);
    line-height: 1.02;
    letter-spacing: -0.06em;
}

.card-grid.two,
.detail-grid,
.contact-grid,
.footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.card-grid.three,
.comparison-table {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.card-grid.four,
.proof-grid,
.fit-grid,
.step-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.detail-grid {
    align-items: center;
}

.detail-copy {
    display: grid;
    gap: 1rem;
}

.detail-copy h2 {
    font-size: clamp(2.1rem, 4vw, 3.7rem);
    line-height: 1.04;
    letter-spacing: -0.05em;
}

.detail-stage {
    min-height: 520px;
}

.device-shell {
    width: min(340px, 100%);
    margin: 0 auto;
    padding: 0.9rem;
    border-radius: 40px;
    background: linear-gradient(180deg, #0b162c, #152644);
    box-shadow: 0 38px 90px rgba(0, 0, 0, 0.38);
}

.device-screen {
    min-height: 620px;
    padding: 1.2rem;
    border-radius: 30px;
    background: linear-gradient(180deg, #eef6ff 0%, #dfeeff 100%);
    color: var(--text-dark);
}

.device-topbar,
.policy-topbar,
.router-topbar,
.worker-topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.device-camera {
    position: relative;
    height: 230px;
    margin-bottom: 1rem;
    border-radius: 28px;
    overflow: hidden;
    background: linear-gradient(135deg, rgba(89, 201, 255, 0.28), rgba(47, 124, 255, 0.22), rgba(255, 189, 107, 0.24));
}

.device-camera::before {
    content: "";
    position: absolute;
    inset: 18px;
    border-radius: 18px;
    border: 2px dashed rgba(11, 24, 48, 0.16);
}

.capture-banner {
    position: absolute;
    left: 18px;
    right: 18px;
    bottom: 18px;
    padding: 0.8rem 0.9rem;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.9);
    box-shadow: 0 18px 30px rgba(18, 35, 58, 0.08);
}

.capture-stack {
    display: grid;
    gap: 0.75rem;
}

.capture-card {
    padding: 0.9rem 1rem;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid rgba(11, 24, 48, 0.08);
    box-shadow: 0 12px 26px rgba(18, 35, 58, 0.06);
}

.capture-card strong {
    display: block;
    margin-bottom: 0.18rem;
}

.capture-card span {
    color: var(--text-dark-soft);
    font-size: 0.88rem;
    line-height: 1.55;
}

.policy-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.policy-card,
.router-card,
.worker-list li,
.ecosystem-node,
.proof-slab {
    padding: 1rem;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.policy-card strong,
.router-card strong,
.ecosystem-node strong,
.proof-slab strong,
.worker-list strong {
    display: block;
    margin-bottom: 0.35rem;
    font-size: 0.98rem;
}

.policy-card p,
.router-card p,
.ecosystem-node p,
.proof-slab p {
    color: var(--text-soft);
    line-height: 1.6;
}

.policy-bar {
    width: 100%;
    height: 8px;
    margin-top: 0.8rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    overflow: hidden;
}

.policy-bar span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--accent-blue), var(--accent-cobalt));
}

.routing-columns {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.8rem;
}

.routing-column h4 {
    margin-bottom: 0.7rem;
    color: var(--text-muted);
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.worker-terminal {
    padding: 1rem;
    border-radius: 22px;
    background: rgba(0, 0, 0, 0.24);
    border: 1px solid rgba(255, 255, 255, 0.06);
    color: #cde2ff;
    font-family: "JetBrains Mono", monospace;
    font-size: 0.84rem;
    line-height: 1.75;
}

.ecosystem-stage {
    display: grid;
    place-items: center;
}

.ecosystem-core {
    position: relative;
    width: min(440px, 100%);
    aspect-ratio: 1 / 1;
}

.ecosystem-ring {
    position: absolute;
    inset: 8%;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.ecosystem-ring.ring-2 { inset: 18%; }
.ecosystem-ring.ring-3 { inset: 32%; }

.ecosystem-hub {
    position: absolute;
    top: 50%;
    left: 50%;
    display: grid;
    place-items: center;
    width: 160px;
    height: 160px;
    border-radius: 36px;
    transform: translate(-50%, -50%);
    background: linear-gradient(180deg, rgba(16, 36, 71, 0.98), rgba(10, 20, 41, 0.98));
    border: 1px solid var(--border-strong);
    box-shadow: 0 26px 60px rgba(0, 0, 0, 0.3);
}

.ecosystem-hub img {
    width: 92px;
    height: 92px;
    border-radius: 24px;
}

.ecosystem-node {
    position: absolute;
    width: 170px;
    backdrop-filter: blur(18px);
}

.node-top { top: 4%; left: 50%; transform: translateX(-50%); }
.node-right { top: 50%; right: 0; transform: translateY(-50%); }
.node-bottom { bottom: 3%; left: 50%; transform: translateX(-50%); }
.node-left { top: 50%; left: 0; transform: translateY(-50%); }

.comparison-row.highlight {
    border-color: var(--border-strong);
    background: linear-gradient(180deg, rgba(14, 32, 63, 0.96), rgba(9, 19, 38, 0.94));
}

.step-card span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    margin-bottom: 1rem;
    border-radius: 50%;
    color: var(--text-dark);
    background: linear-gradient(135deg, #dff7ff, #ffdcab);
    font-weight: 800;
}

.cta-section {
    padding-bottom: 48px;
}

.cta-shell {
    background:
        linear-gradient(135deg, rgba(8, 20, 39, 0.96), rgba(13, 28, 56, 0.96)),
        linear-gradient(135deg, rgba(89, 201, 255, 0.14), transparent 42%);
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: var(--shadow-deep);
}

.cta-shell h2 {
    max-width: 920px;
    margin-bottom: 0.9rem;
    font-size: clamp(2.4rem, 4vw, 4.4rem);
    line-height: 1.02;
    letter-spacing: -0.06em;
}

.cta-shell p {
    max-width: 720px;
    margin-bottom: 1.5rem;
    color: var(--text-soft);
    line-height: 1.75;
}

.contact-shell {
    background: linear-gradient(180deg, rgba(247, 251, 255, 0.98), rgba(233, 243, 255, 0.96));
    border: 1px solid rgba(11, 24, 48, 0.08);
    box-shadow: var(--shadow-soft);
    color: var(--text-dark);
}

.contact-copy h1 {
    margin-top: 0.8rem;
    margin-bottom: 0.9rem;
    font-size: clamp(2.8rem, 5vw, 5.2rem);
    line-height: 0.95;
    letter-spacing: -0.06em;
}

.contact-copy p,
.contact-shell .hero-lead {
    color: #35506f;
}

.contact-card {
    color: var(--text-dark);
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(11, 24, 48, 0.08);
}

.contact-card p,
.contact-card li {
    color: var(--text-dark-soft);
}

.site-footer {
    padding: 0 0 40px;
}

.footer-shell {
    background: linear-gradient(180deg, rgba(7, 15, 30, 0.94), rgba(5, 10, 20, 0.96));
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: var(--shadow-deep);
}

.footer-grid {
    grid-template-columns: 1.2fr repeat(3, minmax(0, 1fr));
    margin-bottom: 1.7rem;
}

.footer-brand {
    display: grid;
    gap: 1rem;
}

.footer-note {
    max-width: 340px;
}

.footer-column strong {
    color: var(--text-main);
    font-size: 0.84rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.footer-column a {
    color: var(--text-soft);
    font-size: 0.95rem;
    transition: color 0.2s ease, transform 0.2s ease;
}

.footer-column a:hover {
    color: #ffffff;
    transform: translateX(2px);
}

.footer-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding-top: 1.3rem;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    color: var(--text-muted);
    font-size: 0.9rem;
}

.footer-meta {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
}

.contact-modal-overlay {
    position: fixed;
    inset: 0;
    z-index: 1500;
    display: grid;
    place-items: center;
    padding: 20px;
    background: rgba(4, 9, 22, 0.58);
    backdrop-filter: blur(22px);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.22s ease;
}

.contact-modal-overlay.active {
    opacity: 1;
    pointer-events: auto;
}

.contact-modal-box {
    width: min(720px, 100%);
    padding: 2rem;
    border-radius: 32px;
    color: var(--text-dark);
    background: linear-gradient(180deg, rgba(252, 254, 255, 0.98), rgba(236, 244, 255, 0.96));
    border: 1px solid rgba(11, 24, 48, 0.08);
    box-shadow: 0 48px 120px rgba(0, 0, 0, 0.34);
    transform: translateY(18px);
    transition: transform 0.22s ease;
    position: relative;
}

.contact-modal-overlay.active .contact-modal-box {
    transform: translateY(0);
}

.modal-close {
    position: absolute;
    top: 18px;
    right: 18px;
    width: 42px;
    height: 42px;
    display: grid;
    place-items: center;
    border-radius: 50%;
    color: var(--text-dark);
    background: rgba(255, 255, 255, 0.84);
    border: 1px solid rgba(11, 24, 48, 0.08);
}

.modal-copy h3 {
    margin-top: 0.4rem;
    margin-bottom: 0.6rem;
    font-size: 2rem;
    letter-spacing: -0.04em;
}

.modal-copy p {
    color: var(--text-dark-soft);
    line-height: 1.7;
}

.modal-options {
    display: grid;
    gap: 1rem;
    margin-top: 1.5rem;
}

.modal-opt {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    padding: 1rem 1.1rem;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.84);
    border: 1px solid rgba(11, 24, 48, 0.08);
    box-shadow: 0 18px 40px rgba(20, 37, 59, 0.08);
}

.modal-opt i {
    width: 22px;
    height: 22px;
    margin-top: 0.2rem;
    color: var(--accent-cobalt);
}

.modal-opt strong {
    display: block;
    margin-bottom: 0.2rem;
    color: var(--text-dark);
}

.modal-opt span {
    color: var(--text-dark-soft);
    line-height: 1.55;
    font-size: 0.92rem;
}

[data-scroll] {
    opacity: 0;
}

@media (max-width: 1180px) {
    .hero-grid,
    .detail-grid,
    .contact-grid,
    .footer-grid,
    .mission-grid,
    .story-proof-grid,
    .card-grid.four,
    .proof-grid,
    .fit-grid,
    .step-grid {
        grid-template-columns: 1fr 1fr;
    }

    .mission-grid {
        grid-template-columns: 1fr;
    }

    .routing-columns,
    .card-grid.three,
    .comparison-table,
    .outcome-grid {
        grid-template-columns: 1fr;
    }

    .nav-links {
        display: none;
    }
}

@media (max-width: 860px) {
    .nav-container,
    .shell,
    .hero-grid,
    .footer-shell,
    .cta-shell,
    .contact-shell {
        width: min(100%, calc(100% - 24px));
    }

    .page-hero {
        padding-top: 132px;
    }

    .hero-grid,
    .detail-grid,
    .contact-grid,
    .story-proof-grid,
    .card-grid.two,
    .card-grid.four,
    .proof-grid,
    .fit-grid,
    .step-grid,
    .metric-row,
    .mini-metrics,
    .data-row,
    .footer-grid {
        grid-template-columns: 1fr;
    }

    .hero-premium-stage {
        min-height: auto;
        padding-bottom: 1rem;
    }

    .hero-grid.hero-grid-showcase,
    .hero-grid.hero-grid-home {
        width: min(100%, calc(100% - 24px));
        grid-template-columns: 1fr;
    }

    .hero-grid.hero-grid-showcase .hero-visual,
    .hero-grid.hero-grid-home .hero-visual,
    .hero-grid.hero-grid-showcase .hero-premium-stage,
    .hero-grid.hero-grid-home .hero-premium-stage,
    .hero-grid.hero-grid-showcase .showcase-stage,
    .hero-grid.hero-grid-home .showcase-stage {
        min-height: auto;
        padding-left: 0;
    }

    .hero-visual,
    .glass-stage {
        min-height: auto;
    }

    .hero-dashboard-art {
        min-height: auto;
    }

    .cinematic-stage {
        min-height: auto;
        padding-bottom: 1rem;
    }

    .cinematic-board {
        width: 100%;
        margin: 0;
        transform: none;
    }

    .cinematic-device,
    .cinematic-float {
        position: relative;
        inset: auto;
        width: 100%;
        max-width: none;
        transform: none;
        margin-top: 1rem;
    }

    .cinematic-orbit {
        inset: 18% 10% 18% 10%;
    }

    .showcase-stage {
        min-height: auto;
    }

    .showcase-board {
        width: 100%;
        transform: none;
    }

    body[data-page="pocket"] .showcase-stage {
        background: linear-gradient(180deg, rgba(7, 15, 29, 0.98), rgba(5, 12, 23, 0.98));
    }

    body[data-page="pocket"] .showcase-stage::before {
        opacity: 0.34;
    }

    body[data-page="pocket"] .showcase-glow,
    body[data-page="pocket"] .showcase-orbit {
        opacity: 0.16;
    }

    body[data-page="pocket"] .showcase-board img {
        object-position: 56% 38%;
        filter: saturate(0.88) brightness(0.76) contrast(1.08);
    }

    .hero-grid.hero-grid-showcase .showcase-board,
    .hero-grid.hero-grid-home .showcase-board {
        width: 100%;
    }

    .process-visual {
        min-height: 0;
        aspect-ratio: auto;
    }

    .process-topline {
        flex-direction: column;
        align-items: flex-start;
    }

    .process-story {
        max-width: 100%;
    }

    .process-platform-grid,
    .solutions-stage-row {
        grid-template-columns: 1fr 1fr;
    }

    .process-document-card {
        width: min(220px, 38%);
    }

    .process-home .home-field {
        min-height: 680px;
    }

    .process-home .home-core {
        width: min(236px, 58%);
    }

    .process-home .home-node {
        width: 138px;
    }

    .process-home .node-pocket {
        top: 4%;
        left: 4%;
    }

    .process-home .node-ai {
        top: 4%;
        right: 4%;
    }

    .process-home .node-routing {
        bottom: 19%;
        left: 8%;
    }

    .process-home .node-worker {
        bottom: 19%;
        right: 8%;
    }

    .process-home .link-pocket {
        top: 23%;
        left: 23%;
        width: 28%;
    }

    .process-home .link-ai {
        top: 23%;
        right: 23%;
        width: 28%;
    }

    .process-home .link-routing {
        bottom: 35%;
        left: 25%;
        width: 23%;
    }

    .process-home .link-worker {
        bottom: 35%;
        right: 25%;
        width: 23%;
    }

    .process-home .home-outcome {
        width: min(300px, 64%);
    }

    .process-platform-grid .process-stage:last-child {
        grid-column: span 2;
    }

    .solutions-stage-row .process-stage:last-child {
        grid-column: auto;
    }

    .process-ecosystem .ecosystem-field {
        min-height: 780px;
        margin-left: 0;
    }

    .process-ecosystem .ecosystem-core {
        width: min(220px, 64%);
    }

    .process-ecosystem .ecosystem-node {
        width: 132px;
    }

    .process-ecosystem .node-pocket {
        top: 3%;
        left: 5%;
    }

    .process-ecosystem .node-ai {
        top: 3%;
        right: 4%;
    }

    .process-ecosystem .node-routing {
        bottom: 3%;
        left: 8%;
    }

    .process-ecosystem .node-worker {
        bottom: 3%;
        right: 6%;
    }

    .process-ecosystem .connector-pocket {
        top: 22%;
        left: 29%;
        width: 24%;
    }

    .process-ecosystem .connector-ai {
        top: 22%;
        right: 24%;
        width: 23%;
    }

    .process-ecosystem .connector-routing {
        bottom: 23%;
        left: 30%;
        width: 19%;
    }

    .process-ecosystem .connector-worker {
        bottom: 23%;
        right: 25%;
        width: 19%;
    }

    .process-ecosystem .pulse-one {
        top: 27%;
        left: 22%;
    }

    .process-ecosystem .pulse-two {
        bottom: 24%;
        right: 23%;
    }

    .process-solutions .solutions-field {
        min-height: 430px;
    }

    .process-solutions .solutions-core {
        width: min(300px, 33%);
    }

    .showcase-orbit {
        inset: 16% 8%;
    }

    .showcase-dock {
        width: auto;
        max-width: 100%;
        gap: 0.7rem;
        padding: 0.65rem 0.9rem;
    }

    .hero-phone-shell,
    .hero-live-card,
    .hero-story-card,
    .hero-quote-card,
    .hero-email-card {
        position: relative;
        inset: auto;
        width: 100%;
        max-width: none;
        margin-top: 1rem;
    }

    .hero-phone-shell {
        right: auto;
        bottom: auto;
    }

    .hero-title,
    .contact-copy h1 {
        font-size: clamp(2.9rem, 15vw, 4.8rem);
    }

    .hero-proof-strip,
    .hero-stage-grid,
    .visual-cluster.two,
    .command-surface-grid,
    .platform-visual-grid,
    .routing-surface-grid,
    .signal-grid,
    .persona-grid,
    .command-stat-row {
        grid-template-columns: 1fr;
    }

    .flow-map {
        min-height: 320px;
    }

    .command-row {
        grid-template-columns: 1fr;
    }

    .section-title,
    .detail-copy h2,
    .cta-shell h2 {
        font-size: clamp(2rem, 10vw, 3.1rem);
    }

    .header-actions .btn-ghost {
        display: none;
    }

    .lang-switch {
        order: 2;
    }

    .footer-bottom {
        flex-direction: column;
        align-items: flex-start;
    }
}

@media (max-width: 620px) {
    .brand-copy em {
        display: none;
    }

    .brand-symbol {
        width: 44px;
        height: 44px;
    }

    .header-actions {
        width: 100%;
        flex-wrap: wrap;
        justify-content: flex-end;
    }

    .lang-switch {
        width: 100%;
        justify-content: center;
    }

    .btn-solid,
    .btn-outline,
    .btn-ghost {
        width: 100%;
    }

    .hero-actions,
    .cta-actions {
        width: 100%;
    }

    .floating-chip {
        max-width: 180px;
        padding: 0.8rem;
    }

    .device-shell {
        width: 100%;
    }

    .flow-node {
        position: relative;
        inset: auto !important;
        min-width: 0;
    }

    .flow-map {
        display: grid;
        gap: 0.9rem;
        align-content: start;
        padding: 1rem;
    }

    .flow-map::before,
    .flow-connector {
        display: none;
    }

    .flow-anchor-pill {
        position: relative;
        left: auto !important;
        top: auto !important;
        bottom: auto !important;
        margin-top: 0.4rem;
        width: fit-content;
    }

    .process-visual {
        padding: 0.9rem;
    }

    .process-platform-grid,
    .solutions-stage-row {
        grid-template-columns: 1fr;
    }

    .process-platform-grid .process-stage:last-child,
    .solutions-stage-row .process-stage:last-child {
        grid-column: auto;
    }

    .process-home .home-field {
        display: grid;
        gap: 0.8rem;
        min-height: 0;
    }

    .process-home .home-core,
    .process-home .home-node,
    .process-home .home-outcome {
        position: relative;
        inset: auto;
        left: auto;
        right: auto;
        top: auto;
        bottom: auto;
        width: 100%;
        transform: none;
        margin: 0;
    }

    .process-home .home-node {
        min-height: 0;
    }

    .process-home .home-core {
        width: 100%;
    }

    .process-home .home-outcome {
        width: 100%;
    }

    .process-home .home-orbit,
    .process-home .home-link {
        display: none;
    }

    .process-story-copy {
        max-width: none;
    }

    .process-platform-rail {
        height: 82px;
    }

    .process-rail-line,
    .process-rail-glow {
        left: 8%;
        right: 8%;
    }

    .process-packet {
        top: 34px;
    }

    .process-platform-rail,
    .process-packet,
    .process-rail-glow,
    .process-rail-stop,
    .process-document-card {
        display: none;
    }

    .process-ecosystem .ecosystem-field {
        min-height: 0;
        margin-left: 0;
    }

    .process-ecosystem .ecosystem-core {
        top: 50%;
        width: min(210px, 78%);
    }

    .process-ecosystem .ecosystem-node {
        position: relative;
        inset: auto;
        width: 100%;
        margin-top: 0.8rem;
    }

    .process-ecosystem .node-pocket,
    .process-ecosystem .node-ai,
    .process-ecosystem .node-routing,
    .process-ecosystem .node-worker {
        left: auto;
        right: auto;
        top: auto;
        bottom: auto;
    }

    .process-ecosystem .ecosystem-field {
        display: grid;
        align-content: start;
        gap: 0.8rem;
    }

    .process-ecosystem .ecosystem-core {
        position: relative;
        left: auto;
        transform: none;
        margin: 0 auto 0.5rem;
    }

    .process-ecosystem .ecosystem-ring,
    .process-ecosystem .ecosystem-connector,
    .process-ecosystem .ecosystem-pulse,
    .process-ecosystem .ecosystem-satellite {
        display: none;
    }

    .process-solutions .solutions-field {
        display: grid;
        gap: 1rem;
        min-height: 0;
    }

    .process-solutions .solutions-lane,
    .process-solutions .solutions-core {
        position: relative;
        inset: auto;
        width: 100%;
        transform: none;
    }

    .process-solutions .solutions-lane {
        grid-template-columns: 1fr;
        gap: 0.8rem;
    }

    .process-solutions .lane-packet {
        display: none;
    }

    .home-signal-ledger {
        margin-top: 0.9rem;
    }
}

@media (prefers-reduced-motion: reduce) {
    * {
        scroll-behavior: auto !important;
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }

    [data-scroll] {
        opacity: 1;
    }

    .process-stage::before,
    .process-rail-glow,
    .process-packet,
    .process-home .home-orbit,
    .process-ecosystem .ecosystem-ring,
    .process-ecosystem .ecosystem-pulse,
    .process-solutions .lane-packet {
        animation: none !important;
    }
}

/* Phone-first showcase shell for hero visuals */
.phone-stage-shell {
    align-items: center;
    justify-items: center;
    overflow: visible;
}

.phone-stage-shell .showcase-glow {
    opacity: 0.42;
    filter: blur(52px);
}

.phone-stage-shell .showcase-orbit {
    inset: 10% 18%;
    opacity: 0.18;
}

.phone-stage-shell .showcase-dock {
    display: none;
}

.phone-showcase-board {
    width: min(100%, 408px) !important;
    margin: clamp(0.3rem, 1vw, 0.9rem) auto 0 !important;
    padding: 12px;
    border-radius: 44px;
    background:
        linear-gradient(180deg, rgba(245, 248, 255, 0.06), rgba(255, 255, 255, 0.01)),
        linear-gradient(180deg, rgba(10, 17, 31, 0.98), rgba(4, 9, 18, 1));
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow:
        0 34px 90px rgba(0, 0, 0, 0.36),
        0 0 0 1px rgba(255, 255, 255, 0.03),
        inset 0 1px 0 rgba(255, 255, 255, 0.08);
    transform: none !important;
}

.phone-showcase-board::before {
    content: "";
    position: absolute;
    top: 11px;
    left: 50%;
    transform: translateX(-50%);
    width: 38%;
    height: 28px;
    border-radius: 0 0 18px 18px;
    background: rgba(3, 7, 16, 0.98);
    box-shadow: inset 0 -1px 0 rgba(255, 255, 255, 0.04);
    z-index: 5;
}

.phone-showcase-board::after {
    content: "";
    position: absolute;
    inset: 12px;
    border-radius: 34px;
    border: 1px solid rgba(255, 255, 255, 0.06);
    pointer-events: none;
    z-index: 4;
}

.phone-stage-shell .showcase-board img,
.phone-stage-shell .process-visual {
    display: block;
    width: 100%;
    aspect-ratio: 9 / 19.5;
    min-height: 690px;
    border-radius: 32px;
    background:
        radial-gradient(circle at 18% 14%, rgba(89, 201, 255, 0.14), transparent 28%),
        linear-gradient(180deg, rgba(8, 16, 30, 0.98), rgba(5, 12, 24, 1));
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.05),
        0 24px 44px rgba(0, 0, 0, 0.28);
}

.phone-stage-shell .showcase-board img {
    object-fit: cover;
    object-position: center top;
}

body[data-page="pocket"] .showcase-stage {
    background:
        radial-gradient(circle at 18% 16%, rgba(89, 201, 255, 0.12), transparent 22%),
        radial-gradient(circle at 82% 78%, rgba(83, 239, 213, 0.08), transparent 24%),
        linear-gradient(180deg, rgba(7, 15, 30, 0.98), rgba(5, 12, 24, 0.98));
}

body[data-page="pocket"] .showcase-stage::before {
    opacity: 0.5;
}

body[data-page="pocket"] .showcase-glow.glow-a {
    opacity: 0.42;
}

body[data-page="pocket"] .showcase-glow.glow-b {
    opacity: 0.28;
}

body[data-page="pocket"] .showcase-orbit {
    opacity: 0.22;
}

body[data-page="pocket"] .showcase-board {
    background: linear-gradient(180deg, rgba(9, 19, 37, 0.96), rgba(6, 13, 25, 1));
}

body[data-page="pocket"] .showcase-board img {
    object-position: 52% 28%;
    filter: saturate(0.94) brightness(0.88) contrast(1.04);
}

.process-pocket-fallback {
    position: relative;
    display: grid;
    align-content: start;
    gap: 0.74rem;
    min-height: 690px;
    padding: 3.2rem 1rem 1rem;
    background:
        radial-gradient(circle at 18% 11%, rgba(89, 201, 255, 0.14), transparent 22%),
        linear-gradient(180deg, rgba(6, 13, 26, 1) 0%, rgba(4, 8, 16, 1) 100%);
}

.process-pocket-fallback--detail {
    min-height: 620px;
    aspect-ratio: 9 / 18.8;
    padding-top: 2.9rem;
}

.process-pocket-fallback__top {
    display: grid;
    gap: 0.32rem;
}

.process-pocket-fallback__kicker {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    min-height: 30px;
    padding: 0.38rem 0.7rem;
    border-radius: 999px;
    color: #8adfff;
    background: rgba(89, 201, 255, 0.08);
    border: 1px solid rgba(89, 201, 255, 0.12);
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.process-pocket-fallback__title {
    color: #f6fbff;
    font-size: 1.08rem;
    line-height: 1.14;
    letter-spacing: -0.03em;
}

.process-pocket-fallback__camera {
    position: relative;
    min-height: 376px;
    padding: 0.84rem;
    border-radius: 28px;
    background:
        radial-gradient(circle at 50% 0%, rgba(89, 201, 255, 0.12), transparent 24%),
        linear-gradient(180deg, rgba(7, 16, 31, 0.98), rgba(4, 9, 17, 1));
    border: 1px solid rgba(255, 255, 255, 0.06);
    overflow: hidden;
}

.process-pocket-fallback__finder,
.process-pocket-fallback__finder::after {
    position: absolute;
    border-radius: 24px;
    pointer-events: none;
}

.process-pocket-fallback__finder {
    inset: 0.9rem;
    border: 1px solid rgba(145, 207, 255, 0.16);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.03);
}

.process-pocket-fallback__finder::after {
    content: "";
    inset: 18% 15%;
    border: 1px solid rgba(145, 207, 255, 0.28);
}

.process-pocket-fallback__sheet {
    position: absolute;
    right: 11%;
    top: 24%;
    width: 41%;
    height: 29%;
    border-radius: 22px;
    background: linear-gradient(180deg, rgba(248, 251, 255, 0.98), rgba(223, 234, 247, 0.96));
    box-shadow: 0 18px 28px rgba(0, 0, 0, 0.2);
    transform: rotate(-11deg);
}

.process-pocket-fallback__banner {
    position: absolute;
    left: 0.84rem;
    right: 0.84rem;
    bottom: 0.84rem;
    display: grid;
    gap: 0.22rem;
    padding: 0.68rem 0.74rem;
    border-radius: 18px;
    color: #f5fbff;
    background: linear-gradient(180deg, rgba(19, 44, 78, 0.92), rgba(9, 21, 40, 0.94));
    border: 1px solid rgba(89, 201, 255, 0.14);
}

.process-pocket-fallback__banner strong {
    font-size: 0.76rem;
}

.process-pocket-fallback__banner span {
    color: rgba(214, 226, 244, 0.8);
    font-size: 0.6rem;
    line-height: 1.45;
}

.process-pocket-fallback__tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.38rem;
}

.process-pocket-fallback__tags span,
.process-pocket-fallback__queue span {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0.24rem 0.56rem;
    border-radius: 999px;
    color: rgba(232, 240, 248, 0.88);
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.07);
    font-size: 0.56rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.process-pocket-fallback__tags span:first-child {
    color: #0a1830;
    background: linear-gradient(135deg, rgba(201, 240, 255, 0.96), rgba(255, 227, 176, 0.96));
}

.process-pocket-fallback__queue {
    display: grid;
    gap: 0.32rem;
    padding: 0.76rem 0.8rem;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.06);
}

.process-pocket-fallback__queue i {
    display: block;
    height: 6px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    overflow: hidden;
}

.process-pocket-fallback__queue i::before {
    content: "";
    display: block;
    width: 72%;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #53d0ff, #6ff0d0, #ffc76d);
}

.pocket-detail-stage {
    min-height: 100%;
}

.pocket-detail-surface {
    position: relative;
    display: grid;
    place-items: center;
    min-height: 100%;
    padding: clamp(1rem, 2vw, 1.35rem);
    border-radius: 34px;
    background: linear-gradient(180deg, rgba(16, 28, 53, 0.94), rgba(8, 15, 30, 0.96));
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.04),
        0 24px 52px rgba(12, 24, 44, 0.18);
}

.pocket-detail-surface::before {
    content: "";
    position: absolute;
    inset: 18px;
    border-radius: 28px;
    border: 1px solid rgba(255, 255, 255, 0.05);
    pointer-events: none;
}

.pocket-detail-board {
    width: min(100%, 420px) !important;
    margin: 0 auto !important;
    background: linear-gradient(180deg, rgba(10, 20, 38, 0.96), rgba(7, 14, 27, 0.98));
    border-color: rgba(255, 255, 255, 0.07);
}

.pocket-detail-board .device-frame {
    width: min(100%, 374px);
}

.phone-stage-shell .process-visual {
    min-height: 690px;
    padding: 3.2rem 1rem 1rem;
    gap: 0.8rem;
}

.phone-stage-shell .process-topline {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.45rem;
    margin-bottom: 0.25rem;
}

.phone-stage-shell .process-kicker,
.phone-stage-shell .process-status {
    min-height: 30px;
    padding: 0.38rem 0.68rem;
    font-size: 0.67rem;
}

.phone-stage-shell .process-story {
    display: grid;
    gap: 0.45rem;
    margin-bottom: 0.25rem;
}

.phone-stage-shell .process-story-title {
    font-size: 1.08rem;
    line-height: 1.15;
}

.phone-stage-shell .process-story-copy {
    font-size: 0.82rem;
    line-height: 1.58;
}

.phone-stage-shell .process-stage {
    min-height: 0;
    padding: 0.8rem;
    border-radius: 18px;
}

.phone-stage-shell .process-stage-label {
    font-size: 0.92rem;
}

.phone-stage-shell .process-stage p,
.phone-stage-shell .process-stage-meta {
    font-size: 0.72rem;
}

.phone-stage-shell .process-chip-ledger {
    gap: 0.35rem;
}

.phone-stage-shell .ledger-chip {
    padding: 0.32rem 0.52rem;
    font-size: 0.6rem;
}

.phone-stage-shell .process-home .home-field {
    min-height: 0;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.6rem;
    padding: 0.1rem 0;
}

.phone-stage-shell .process-home .home-orbit,
.phone-stage-shell .process-home .home-link {
    display: none;
}

.phone-stage-shell .process-home .home-core,
.phone-stage-shell .process-home .home-outcome {
    position: relative;
    inset: auto;
    left: auto;
    top: auto;
    bottom: auto;
    transform: none;
    width: 100%;
    grid-column: 1 / -1;
    padding: 0.85rem;
    border-radius: 18px;
}

.phone-stage-shell .process-home .home-node {
    position: relative;
    inset: auto;
    width: 100%;
    min-height: 0;
    padding: 0.72rem;
}

.phone-stage-shell .process-home .home-core strong,
.phone-stage-shell .process-home .home-outcome strong {
    font-size: 0.92rem;
}

.phone-stage-shell .process-home .home-core p,
.phone-stage-shell .process-home .home-outcome p {
    font-size: 0.72rem;
}

.phone-stage-shell .process-platform-rail,
.phone-stage-shell .process-packet,
.phone-stage-shell .process-rail-glow,
.phone-stage-shell .process-rail-stop,
.phone-stage-shell .process-document-card {
    display: none;
}

.phone-stage-shell .process-platform-grid {
    grid-template-columns: 1fr;
    gap: 0.58rem;
}

.phone-stage-shell .process-ecosystem .ecosystem-field {
    min-height: 0;
    margin-left: 0;
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.58rem;
}

.phone-stage-shell .process-ecosystem .ecosystem-ring,
.phone-stage-shell .process-ecosystem .ecosystem-connector,
.phone-stage-shell .process-ecosystem .ecosystem-pulse,
.phone-stage-shell .process-ecosystem .ecosystem-satellite {
    display: none;
}

.phone-stage-shell .process-ecosystem .ecosystem-core,
.phone-stage-shell .process-ecosystem .ecosystem-node {
    position: relative;
    inset: auto;
    left: auto;
    top: auto;
    right: auto;
    bottom: auto;
    transform: none;
    width: 100%;
}

.phone-stage-shell .process-ecosystem .ecosystem-core {
    padding: 0.86rem;
    border-radius: 18px;
    text-align: center;
}

.phone-stage-shell .process-ecosystem .ecosystem-node {
    padding: 0.74rem;
}

.phone-stage-shell .process-solutions .solutions-field {
    display: grid;
    gap: 0.72rem;
    min-height: 0;
}

.phone-stage-shell .process-solutions .solutions-lane,
.phone-stage-shell .process-solutions .solutions-core {
    position: relative;
    inset: auto;
    width: 100%;
    transform: none;
}

.phone-stage-shell .process-solutions .solutions-lane {
    grid-template-columns: 1fr;
    gap: 0.6rem;
}

.phone-stage-shell .process-solutions .lane-packet,
.phone-stage-shell .process-solutions .solutions-grid-line,
.phone-stage-shell .process-solutions .solutions-orbit {
    display: none;
}

@media (max-width: 900px) {
    .phone-showcase-board {
        width: min(100%, 356px) !important;
    }

    .phone-stage-shell .showcase-board img,
    .phone-stage-shell .process-visual {
        min-height: 630px;
    }
}

@media (max-width: 640px) {
    .phone-showcase-board {
        width: min(100%, 334px) !important;
        padding: 10px;
        border-radius: 36px;
    }

    .phone-showcase-board::before {
        height: 24px;
        border-radius: 0 0 15px 15px;
    }

    .phone-stage-shell .showcase-board img,
    .phone-stage-shell .process-visual {
        min-height: 560px;
        border-radius: 28px;
    }

    .phone-stage-shell .process-visual {
        padding: 2.9rem 0.82rem 0.82rem;
    }

    .phone-stage-shell .process-home .home-field {
        grid-template-columns: 1fr;
    }
}

.native-phone-demo {
    position: relative;
    display: grid;
    grid-template-rows: auto auto auto 1fr auto;
    min-height: 690px;
    padding: 3rem 0.95rem 0.95rem;
    border-radius: 32px;
    overflow: hidden;
    background:
        radial-gradient(circle at 16% 10%, rgba(89, 201, 255, 0.16), transparent 24%),
        radial-gradient(circle at 84% 18%, rgba(255, 185, 107, 0.12), transparent 22%),
        linear-gradient(180deg, rgba(7, 15, 29, 0.98), rgba(4, 9, 18, 1));
}

.native-phone-demo::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(transparent 97%, rgba(255, 255, 255, 0.035) 100%),
        linear-gradient(90deg, transparent 97%, rgba(255, 255, 255, 0.03) 100%);
    background-size: 100% 32px, 32px 100%;
    opacity: 0.22;
    pointer-events: none;
}

.native-phone-demo::after {
    content: "";
    position: absolute;
    inset: auto -15% -12% -15%;
    height: 190px;
    background: radial-gradient(circle, rgba(89, 201, 255, 0.22), transparent 64%);
    filter: blur(26px);
    pointer-events: none;
}

.native-phone-statusbar,
.native-phone-appbar,
.native-phone-scene-window,
.native-phone-footer {
    position: relative;
    z-index: 2;
}

.native-phone-statusbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 0.55rem;
    color: rgba(235, 245, 255, 0.9);
    font-size: 0.72rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.native-phone-status-icons {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
}

.native-phone-status-icons i {
    display: block;
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.44);
}

.native-phone-status-icons .battery {
    width: 16px;
    border-radius: 999px;
    background: linear-gradient(90deg, #61d5ff, #ffc76b);
}

.native-phone-ribbon {
    position: absolute;
    left: -18%;
    right: -18%;
    display: flex;
    gap: 1.8rem;
    width: 136%;
    white-space: nowrap;
    color: rgba(117, 149, 191, 0.2);
    font-size: 0.68rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    pointer-events: none;
    z-index: 1;
}

.native-phone-ribbon span {
    display: inline-flex;
    gap: 1.8rem;
    padding-right: 1.8rem;
}

.native-phone-ribbon.ribbon-a {
    top: 26%;
    animation: nativePhoneRibbon 16s linear infinite;
}

.native-phone-ribbon.ribbon-b {
    top: 55%;
    animation: nativePhoneRibbonReverse 18s linear infinite;
}

.native-phone-appbar {
    display: grid;
    gap: 0.4rem;
    margin-bottom: 0.85rem;
}

.native-phone-badge {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    min-height: 28px;
    padding: 0.32rem 0.62rem;
    border-radius: 999px;
    background: rgba(89, 201, 255, 0.1);
    border: 1px solid rgba(89, 201, 255, 0.18);
    color: #89deff;
    font-size: 0.66rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.native-phone-appbar strong {
    font-size: 1.08rem;
    line-height: 1.15;
    letter-spacing: -0.04em;
    color: var(--text-white);
}

.native-phone-appbar p {
    color: rgba(192, 210, 233, 0.82);
    font-size: 0.79rem;
    line-height: 1.58;
}

.native-phone-scene-window {
    position: relative;
    overflow: hidden;
    border-radius: 24px;
    background: rgba(6, 13, 24, 0.5);
    border: 1px solid rgba(255, 255, 255, 0.06);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.native-phone-scene-track {
    display: grid;
    grid-auto-rows: 1fr;
    animation: nativePhoneSceneFlow 13.5s cubic-bezier(0.76, 0, 0.24, 1) infinite;
}

.native-phone-scene {
    min-height: 328px;
    display: grid;
    align-content: space-between;
    gap: 0.8rem;
    padding: 0.9rem;
}

.native-phone-card {
    display: grid;
    gap: 0.45rem;
    padding: 0.95rem;
    border-radius: 20px;
    background:
        linear-gradient(180deg, rgba(15, 29, 53, 0.94), rgba(7, 14, 26, 0.96));
    border: 1px solid rgba(255, 255, 255, 0.06);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.04),
        0 16px 34px rgba(0, 0, 0, 0.24);
}

.native-phone-kicker {
    font-size: 0.64rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #7edcff;
}

.native-phone-card strong {
    font-size: 0.96rem;
    line-height: 1.2;
    letter-spacing: -0.03em;
}

.native-phone-card p {
    color: rgba(190, 208, 232, 0.78);
    font-size: 0.76rem;
    line-height: 1.58;
}

.native-phone-meta {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 0.65rem;
    padding: 0.8rem 0.9rem;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.05);
}

.native-phone-metric {
    font-size: 1.26rem;
    font-weight: 800;
    letter-spacing: -0.04em;
    color: #f7fbff;
}

.native-phone-tag {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0.28rem 0.58rem;
    border-radius: 999px;
    font-size: 0.64rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    background: rgba(89, 201, 255, 0.12);
    border: 1px solid rgba(89, 201, 255, 0.16);
    color: #9be6ff;
}

.native-phone-footer {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    margin-top: 0.8rem;
}

.native-phone-footer span {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0.28rem 0.56rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.06);
    color: rgba(212, 225, 243, 0.8);
    font-size: 0.64rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.native-phone-home .native-phone-badge,
.native-phone-pocket .native-phone-badge {
    border-color: rgba(89, 201, 255, 0.24);
}

.native-phone-platform .native-phone-badge,
.native-phone-routing .native-phone-badge {
    border-color: rgba(118, 214, 255, 0.22);
}

.native-phone-ecosystem .native-phone-badge,
.native-phone-fit .native-phone-badge {
    border-color: rgba(118, 255, 211, 0.18);
}

.native-phone-intelligence .native-phone-badge,
.native-phone-proof .native-phone-badge,
.native-phone-value .native-phone-badge {
    border-color: rgba(255, 199, 107, 0.18);
}

.native-phone-execution .native-phone-badge,
.native-phone-solutions .native-phone-badge {
    border-color: rgba(138, 171, 255, 0.18);
}

@keyframes nativePhoneSceneFlow {
    0%, 24% { transform: translateY(0%); }
    33%, 57% { transform: translateY(-33.3333%); }
    66%, 90% { transform: translateY(-66.6666%); }
    100% { transform: translateY(0%); }
}

@keyframes nativePhoneRibbon {
    0% { transform: translateX(0); }
    100% { transform: translateX(-34%); }
}

@keyframes nativePhoneRibbonReverse {
    0% { transform: translateX(-24%); }
    100% { transform: translateX(0); }
}

@media (max-width: 900px) {
    .native-phone-demo {
        min-height: 620px;
    }

    .native-phone-scene {
        min-height: 294px;
    }
}

@media (max-width: 640px) {
    .native-phone-demo {
        min-height: 560px;
        padding: 2.65rem 0.78rem 0.78rem;
        border-radius: 28px;
    }

    .native-phone-appbar strong {
        font-size: 0.96rem;
    }

    .native-phone-appbar p,
    .native-phone-card p {
        font-size: 0.72rem;
    }

    .native-phone-scene {
        min-height: 264px;
        padding: 0.72rem;
    }

    .native-phone-card {
        padding: 0.8rem;
        border-radius: 18px;
    }
}

/* FineCon targeted contrast and hero-device focus fixes */
body[data-page="home"] .page-hero .hero-visual .showcase-stage.phone-stage-shell,
body[data-page="platform"] .page-hero .hero-visual .showcase-stage.phone-stage-shell,
body[data-page="ecosystem"] .page-hero .hero-visual .showcase-stage.phone-stage-shell,
body[data-page="solutions"] .page-hero .hero-visual .showcase-stage.phone-stage-shell,
body[data-page="pocket"] .page-hero .hero-visual .showcase-stage.phone-stage-shell,
body[data-page="why"] .page-hero .hero-visual .showcase-stage.phone-stage-shell,
body[data-page="why-wins"] .page-hero .hero-visual .showcase-stage.phone-stage-shell,
body[data-page="fit"] .page-hero .hero-visual .showcase-stage.phone-stage-shell,
body[data-page="intelligence"] .page-hero .hero-visual .showcase-stage.phone-stage-shell,
body[data-page="routing"] .page-hero .hero-visual .showcase-stage.phone-stage-shell,
body[data-page="einvoice"] .page-hero .hero-visual .showcase-stage.phone-stage-shell,
body[data-page="execution"] .page-hero .hero-visual .showcase-stage.phone-stage-shell {
    background: transparent;
    border-color: transparent;
    box-shadow: none;
    backdrop-filter: none;
}

body[data-page="home"] .page-hero .hero-visual .showcase-stage.phone-stage-shell::before,
body[data-page="platform"] .page-hero .hero-visual .showcase-stage.phone-stage-shell::before,
body[data-page="ecosystem"] .page-hero .hero-visual .showcase-stage.phone-stage-shell::before,
body[data-page="solutions"] .page-hero .hero-visual .showcase-stage.phone-stage-shell::before,
body[data-page="pocket"] .page-hero .hero-visual .showcase-stage.phone-stage-shell::before,
body[data-page="why"] .page-hero .hero-visual .showcase-stage.phone-stage-shell::before,
body[data-page="why-wins"] .page-hero .hero-visual .showcase-stage.phone-stage-shell::before,
body[data-page="fit"] .page-hero .hero-visual .showcase-stage.phone-stage-shell::before,
body[data-page="intelligence"] .page-hero .hero-visual .showcase-stage.phone-stage-shell::before,
body[data-page="routing"] .page-hero .hero-visual .showcase-stage.phone-stage-shell::before,
body[data-page="einvoice"] .page-hero .hero-visual .showcase-stage.phone-stage-shell::before,
body[data-page="execution"] .page-hero .hero-visual .showcase-stage.phone-stage-shell::before,
body[data-page="home"] .page-hero .hero-visual .showcase-stage.phone-stage-shell .showcase-glow,
body[data-page="platform"] .page-hero .hero-visual .showcase-stage.phone-stage-shell .showcase-glow,
body[data-page="ecosystem"] .page-hero .hero-visual .showcase-stage.phone-stage-shell .showcase-glow,
body[data-page="solutions"] .page-hero .hero-visual .showcase-stage.phone-stage-shell .showcase-glow,
body[data-page="pocket"] .page-hero .hero-visual .showcase-stage.phone-stage-shell .showcase-glow,
body[data-page="why"] .page-hero .hero-visual .showcase-stage.phone-stage-shell .showcase-glow,
body[data-page="why-wins"] .page-hero .hero-visual .showcase-stage.phone-stage-shell .showcase-glow,
body[data-page="fit"] .page-hero .hero-visual .showcase-stage.phone-stage-shell .showcase-glow,
body[data-page="intelligence"] .page-hero .hero-visual .showcase-stage.phone-stage-shell .showcase-glow,
body[data-page="routing"] .page-hero .hero-visual .showcase-stage.phone-stage-shell .showcase-glow,
body[data-page="einvoice"] .page-hero .hero-visual .showcase-stage.phone-stage-shell .showcase-glow,
body[data-page="execution"] .page-hero .hero-visual .showcase-stage.phone-stage-shell .showcase-glow,
body[data-page="home"] .page-hero .hero-visual .showcase-stage.phone-stage-shell .showcase-orbit,
body[data-page="platform"] .page-hero .hero-visual .showcase-stage.phone-stage-shell .showcase-orbit,
body[data-page="ecosystem"] .page-hero .hero-visual .showcase-stage.phone-stage-shell .showcase-orbit,
body[data-page="solutions"] .page-hero .hero-visual .showcase-stage.phone-stage-shell .showcase-orbit,
body[data-page="pocket"] .page-hero .hero-visual .showcase-stage.phone-stage-shell .showcase-orbit,
body[data-page="why"] .page-hero .hero-visual .showcase-stage.phone-stage-shell .showcase-orbit,
body[data-page="why-wins"] .page-hero .hero-visual .showcase-stage.phone-stage-shell .showcase-orbit,
body[data-page="fit"] .page-hero .hero-visual .showcase-stage.phone-stage-shell .showcase-orbit,
body[data-page="intelligence"] .page-hero .hero-visual .showcase-stage.phone-stage-shell .showcase-orbit,
body[data-page="routing"] .page-hero .hero-visual .showcase-stage.phone-stage-shell .showcase-orbit,
body[data-page="einvoice"] .page-hero .hero-visual .showcase-stage.phone-stage-shell .showcase-orbit,
body[data-page="execution"] .page-hero .hero-visual .showcase-stage.phone-stage-shell .showcase-orbit {
    display: none;
}

body[data-page="home"] .page-hero .phone-showcase-board,
body[data-page="platform"] .page-hero .phone-showcase-board,
body[data-page="ecosystem"] .page-hero .phone-showcase-board,
body[data-page="solutions"] .page-hero .phone-showcase-board,
body[data-page="pocket"] .page-hero .phone-showcase-board,
body[data-page="why"] .page-hero .phone-showcase-board,
body[data-page="why-wins"] .page-hero .phone-showcase-board,
body[data-page="fit"] .page-hero .phone-showcase-board,
body[data-page="intelligence"] .page-hero .phone-showcase-board,
body[data-page="routing"] .page-hero .phone-showcase-board,
body[data-page="einvoice"] .page-hero .phone-showcase-board,
body[data-page="execution"] .page-hero .phone-showcase-board {
    margin-top: 0;
}

.device-screen {
    background:
        radial-gradient(circle at 18% 11%, rgba(77, 186, 255, 0.12), transparent 22%),
        linear-gradient(180deg, rgba(6, 12, 23, 1) 0%, rgba(4, 8, 16, 1) 100%);
    color: #f6faff;
}

.device-screen::before {
    opacity: 0.11;
}

.device-screen::after {
    opacity: 0.2;
    filter: blur(16px);
}

.device-screen__ticker {
    color: rgba(146, 171, 205, 0.12);
}

.device-screen__eyebrow {
    color: rgba(196, 214, 236, 0.82);
}

.device-screen__header p {
    color: rgba(219, 230, 245, 0.86);
}

.screen-chip,
.screen-footer-chip {
    border-color: rgba(255, 255, 255, 0.09);
    background: rgba(255, 255, 255, 0.06);
    color: rgba(232, 240, 250, 0.88);
}

.screen-metric {
    border-color: rgba(255, 255, 255, 0.08);
    background: linear-gradient(180deg, rgba(14, 26, 46, 0.92), rgba(8, 14, 26, 0.98));
}

.screen-metric span {
    color: rgba(212, 225, 242, 0.84);
}

.screen-card,
.screen-card.is-primary {
    border-color: rgba(255, 255, 255, 0.08);
    background: linear-gradient(180deg, rgba(12, 22, 40, 0.98), rgba(6, 12, 23, 1));
}

.screen-card p {
    color: rgba(222, 232, 245, 0.84);
}

.screen-card__state {
    color: rgba(246, 250, 255, 0.96);
}

body[data-page="contact"] .contact-shell {
    background: linear-gradient(180deg, rgba(252, 254, 255, 0.99), rgba(240, 246, 255, 0.98));
    border-color: rgba(11, 24, 48, 0.1);
    box-shadow: 0 26px 60px rgba(16, 35, 58, 0.12);
}

body[data-page="contact"] .contact-copy h1 {
    color: #09172b;
}

body[data-page="contact"] .contact-shell .text-gradient {
    color: #0d5fd2;
    background: none;
    -webkit-background-clip: border-box;
    background-clip: border-box;
    -webkit-text-fill-color: currentColor;
    text-shadow: 0 10px 24px rgba(27, 136, 255, 0.12);
}

body[data-page="contact"] .contact-copy p,
body[data-page="contact"] .contact-shell .hero-lead,
body[data-page="contact"] .contact-card p,
body[data-page="contact"] .contact-card li {
    color: #304a67;
}

body[data-page="contact"] .contact-card {
    background: rgba(255, 255, 255, 0.82);
    border-color: rgba(11, 24, 48, 0.1);
    box-shadow: 0 18px 42px rgba(17, 36, 58, 0.08);
}

body[data-page="contact"] .contact-card h3,
body[data-page="contact"] .contact-card strong {
    color: #0b1c33;
}

body[data-page="contact"] .contact-email-card {
    background: linear-gradient(180deg, rgba(8, 16, 30, 0.98), rgba(5, 11, 21, 0.98));
    border-color: rgba(128, 189, 255, 0.22);
}

body[data-page="contact"] .contact-email-card p {
    color: rgba(224, 234, 246, 0.84);
}

body[data-page="contact"] .contact-email-pill {
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.1);
    color: #f5f9ff;
}

body[data-page="contact"] .contact-grid {
    gap: clamp(1.15rem, 2vw, 1.55rem);
    align-items: stretch;
}

body[data-page="contact"] .contact-copy {
    display: grid;
    align-content: start;
    gap: 0.95rem;
    max-width: 35rem;
}

body[data-page="contact"] .contact-utility-lead {
    max-width: 34rem;
    color: #173659;
    font-size: 1.16rem;
    font-weight: 700;
    line-height: 1.64;
}

body[data-page="contact"] .contact-utility-support {
    max-width: 35rem;
    color: #41607f;
}

body[data-page="contact"] .contact-response-note {
    display: grid;
    gap: 0.6rem;
    padding: 1rem 1.05rem;
    border-radius: 24px;
    background: linear-gradient(180deg, rgba(242, 247, 255, 0.95), rgba(233, 242, 255, 0.92));
    border: 1px solid rgba(47, 124, 255, 0.1);
    box-shadow: 0 16px 34px rgba(17, 36, 58, 0.06);
}

body[data-page="contact"] .contact-response-note p {
    margin: 0;
    color: #244566;
    font-size: 0.96rem;
    line-height: 1.68;
}

body[data-page="contact"] .contact-response-pill,
body[data-page="contact"] .contact-owner-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    min-height: 30px;
    padding: 0.4rem 0.72rem;
    border-radius: 999px;
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

body[data-page="contact"] .contact-response-pill {
    color: #0d5fd2;
    background: rgba(47, 124, 255, 0.08);
    border: 1px solid rgba(47, 124, 255, 0.12);
}

body[data-page="contact"] .contact-stage-stack {
    align-content: start;
    gap: 0.95rem;
}

body[data-page="contact"] .contact-owner-card {
    padding: 1.38rem;
    border-radius: 28px;
    box-shadow: 0 26px 60px rgba(0, 0, 0, 0.22);
}

body[data-page="contact"] .contact-owner-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.6rem;
}

body[data-page="contact"] .contact-owner-chip {
    color: #d7f5ff;
    background: rgba(89, 201, 255, 0.1);
    border: 1px solid rgba(89, 201, 255, 0.16);
}

body[data-page="contact"] .contact-owner-card strong {
    font-size: 1.22rem;
    letter-spacing: -0.04em;
}

body[data-page="contact"] .contact-process-card {
    background: linear-gradient(180deg, rgba(13, 27, 50, 0.96), rgba(8, 17, 33, 0.96));
    border-color: rgba(128, 189, 255, 0.16);
    box-shadow: 0 22px 52px rgba(8, 17, 33, 0.16);
}

body[data-page="contact"] .contact-process-card h3,
body[data-page="contact"] .contact-process-card strong {
    color: #f5f9ff;
}

body[data-page="contact"] .contact-process-rail {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.72rem;
}

body[data-page="contact"] .contact-process-step {
    display: grid;
    gap: 0.48rem;
    padding: 0.95rem;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

body[data-page="contact"] .contact-process-index {
    color: #8adfff;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

body[data-page="contact"] .contact-process-step p {
    margin: 0;
    color: rgba(223, 233, 245, 0.82);
    font-size: 0.92rem;
    line-height: 1.58;
}

body[data-page="contact"] .contact-proof-card {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.9), rgba(247, 250, 255, 0.88));
}

body[data-page="contact"] .contact-proof-list {
    display: grid;
    gap: 0.72rem;
}

body[data-page="contact"] .contact-proof-row {
    display: grid;
    gap: 0.28rem;
    padding-top: 0.82rem;
    border-top: 1px solid rgba(11, 24, 48, 0.08);
}

body[data-page="contact"] .contact-proof-row:first-child {
    padding-top: 0;
    border-top: 0;
}

body[data-page="contact"] .contact-proof-row span {
    color: #0d5fd2;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

body[data-page="contact"] .contact-proof-row strong {
    color: #0b1c33;
    font-size: 0.98rem;
    line-height: 1.5;
}

body[data-page="contact"] .contact-shell .btn-outline {
    color: #0b1c33;
    background: linear-gradient(180deg, rgba(230, 239, 251, 0.54), rgba(255, 255, 255, 0.96));
    border-color: rgba(47, 124, 255, 0.14);
    box-shadow: 0 14px 30px rgba(16, 35, 58, 0.08);
}

body[data-page="contact"] .contact-shell .btn-outline:hover {
    color: #081a32;
    background: linear-gradient(180deg, rgba(214, 231, 250, 0.72), rgba(255, 255, 255, 0.98));
    border-color: rgba(47, 124, 255, 0.24);
}

body[data-page="pocket"] .page-hero .device-frame--pocket {
    width: min(100%, 398px);
}

body[data-page="pocket"] .page-hero .device-frame--pocket .device-screen,
body[data-page="pocket"] .page-hero .device-frame--pocket .device-screen__content {
    min-height: 434px;
}

body[data-page="pocket"] .page-hero .device-frame--pocket .device-screen__content {
    gap: 0.34rem;
    padding: 2.18rem 0.8rem 0.68rem;
}

body[data-page="pocket"] .page-hero .device-frame--pocket .device-screen__header {
    gap: 0.34rem;
}

body[data-page="pocket"] .page-hero .device-frame--pocket .device-screen__header strong {
    font-size: 0.94rem;
    line-height: 1.02;
}

body[data-page="pocket"] .page-hero .device-frame--pocket .device-screen__header p {
    max-width: 100%;
    font-size: 0.66rem;
    line-height: 1.4;
}

body[data-page="pocket"] .page-hero .device-frame--pocket .device-screen__metrics,
body[data-page="pocket"] .page-hero .device-frame--pocket .device-screen__cards,
body[data-page="pocket"] .page-hero .device-frame--pocket .device-screen__footer {
    display: none !important;
}

body[data-page="pocket"] .page-hero .device-frame--pocket .device-pocket__camera {
    min-height: 148px;
    padding: 0.52rem;
    border-radius: 17px;
}

body[data-page="pocket"] .page-hero .device-frame--pocket .device-pocket__finder {
    min-height: 106px;
}

body[data-page="pocket"] .page-hero .device-frame--pocket .device-pocket__banner {
    left: 0.52rem;
    right: 0.52rem;
    bottom: 0.52rem;
}

body[data-page="pocket"] .page-hero .device-frame--pocket .device-pocket__banner strong {
    font-size: 0.78rem;
}

body[data-page="pocket"] .page-hero .device-frame--pocket .device-pocket__banner span,
body[data-page="pocket"] .page-hero .device-frame--pocket .device-pocket__helper,
body[data-page="pocket"] .page-hero .device-frame--pocket .device-pocket__queue span {
    font-size: 0.58rem;
    line-height: 1.35;
}

body[data-page="pocket"] .page-hero .device-frame--pocket .device-motion-layer {
    padding: 0.54rem 0.64rem;
    border-radius: 17px;
}

body[data-page="pocket"] .page-hero .device-frame--pocket .device-pocket {
    gap: 0.42rem;
    padding: 0.64rem;
    border-radius: 20px;
}

body[data-page="pocket"] .pocket-detail-board {
    width: min(100%, 376px) !important;
}

body[data-page="pocket"] .pocket-detail-board .device-frame--pocketDetail {
    width: min(100%, 332px);
}

body[data-page="pocket"] .pocket-detail-board .device-frame--pocketDetail .device-screen,
body[data-page="pocket"] .pocket-detail-board .device-frame--pocketDetail .device-screen__content {
    min-height: 452px;
}

body[data-page="pocket"] .pocket-detail-board .device-frame--pocketDetail .device-screen__content {
    gap: 0.48rem;
    padding: 2.42rem 0.8rem 0.72rem;
}

body[data-page="pocket"] .pocket-detail-board .device-frame--pocketDetail .device-motion-layer {
    padding: 0.62rem 0.7rem;
    border-radius: 18px;
}

body[data-page="pocket"] .pocket-detail-board .device-frame--pocketDetail .device-pocket {
    gap: 0.52rem;
    padding: 0.76rem;
    border-radius: 22px;
}

body[data-page="pocket"] .pocket-detail-board .device-frame--pocketDetail .device-pocket__camera {
    min-height: 184px;
    padding: 0.58rem;
    border-radius: 18px;
}

body[data-page="pocket"] .pocket-detail-board .device-frame--pocketDetail .device-pocket__finder {
    min-height: 126px;
}

body[data-page="pocket"] .pocket-detail-board .device-frame--pocketDetail .device-pocket__banner {
    left: 0.58rem;
    right: 0.58rem;
    bottom: 0.58rem;
}

@media (max-width: 980px) {
    body[data-page="contact"] .contact-process-rail {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 680px) {
    body[data-page="contact"] .contact-shell .hero-actions {
        flex-direction: column;
        align-items: stretch;
    }

    body[data-page="contact"] .contact-shell .hero-actions > * {
        width: 100%;
        justify-content: center;
    }

    body[data-page="contact"] .contact-owner-head {
        flex-direction: column;
        align-items: flex-start;
    }
}

body.nav-open {
    overflow: hidden;
}

.nav-container {
    position: relative;
}

.nav-toggle {
    display: none;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 0.26rem;
    width: 46px;
    height: 46px;
    padding: 0;
    border-radius: 16px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.04);
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.16);
    transition: background 0.22s ease, border-color 0.22s ease, transform 0.22s ease;
}

.nav-toggle:hover {
    transform: translateY(-1px);
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.14);
}

.nav-toggle span {
    display: block;
    width: 18px;
    height: 2px;
    border-radius: 999px;
    background: rgba(244, 248, 255, 0.92);
    transition: transform 0.22s ease, opacity 0.22s ease;
}

.site-header.is-menu-open .nav-toggle span:nth-child(1) {
    transform: translateY(6px) rotate(45deg);
}

.site-header.is-menu-open .nav-toggle span:nth-child(2) {
    opacity: 0;
}

.site-header.is-menu-open .nav-toggle span:nth-child(3) {
    transform: translateY(-6px) rotate(-45deg);
}

.mobile-nav-panel[hidden] {
    display: none !important;
}

.mobile-nav-panel {
    display: none;
}

.mobile-nav-links,
.mobile-nav-actions {
    display: grid;
    gap: 0.7rem;
}

@media (max-width: 1180px) {
    .nav-toggle {
        display: inline-flex;
    }

    .header-actions > .btn-ghost,
    .header-actions > .btn-solid {
        display: none;
    }

    .mobile-nav-panel {
        position: absolute;
        top: calc(100% + 12px);
        left: 0;
        right: 0;
        display: grid;
        gap: 1rem;
        padding: 1rem;
        border-radius: 28px;
        background: linear-gradient(180deg, rgba(7, 14, 28, 0.98), rgba(4, 10, 20, 0.98));
        border: 1px solid rgba(255, 255, 255, 0.08);
        box-shadow: 0 26px 60px rgba(0, 0, 0, 0.28);
        backdrop-filter: blur(24px);
        opacity: 0;
        pointer-events: none;
        transform: translateY(-10px) scale(0.985);
        transition: opacity 0.22s ease, transform 0.22s ease;
        z-index: 1250;
    }

    .site-header.is-menu-open .mobile-nav-panel {
        opacity: 1;
        pointer-events: auto;
        transform: translateY(0) scale(1);
    }

    .mobile-nav-links {
        grid-template-columns: 1fr;
        gap: 0.45rem;
    }

    .mobile-nav-links a {
        display: flex;
        align-items: center;
        justify-content: space-between;
        min-height: 52px;
        padding: 0.9rem 1rem;
        border-radius: 18px;
        color: var(--text-muted);
        font-size: 0.98rem;
        font-weight: 700;
        background: rgba(255, 255, 255, 0.03);
        border: 1px solid rgba(255, 255, 255, 0.05);
        transition: color 0.2s ease, background 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
    }

    .mobile-nav-links a:hover,
    .mobile-nav-links a.active {
        color: var(--text-main);
        background: rgba(255, 255, 255, 0.08);
        border-color: rgba(255, 255, 255, 0.1);
        transform: translateY(-1px);
    }

    .mobile-nav-actions {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.75rem;
    }

    .mobile-nav-actions .btn-ghost,
    .mobile-nav-actions .btn-solid {
        width: 100%;
        justify-content: center;
    }
}

@media (max-width: 860px) {
    .site-header {
        padding: 0.9rem 0;
    }

    .page-hero {
        padding-top: 118px;
        padding-bottom: 58px;
    }

    .hero-copy {
        gap: 0.95rem;
    }

    .hero-kicker-line {
        font-size: 1rem;
        line-height: 1.45;
    }

    .hero-title,
    .contact-copy h1 {
        font-size: clamp(2.8rem, 15vw, 4.6rem);
    }

    .hero-lead,
    .section-lead,
    .detail-copy p,
    .contact-copy p,
    .cta-shell p {
        font-size: 0.98rem;
        line-height: 1.72;
    }

    .section,
    .cta-section {
        padding-bottom: 40px;
    }

    .section-shell,
    .cta-shell,
    .contact-shell,
    .footer-shell {
        padding: 1.15rem;
        border-radius: 28px;
    }

    .hero-actions,
    .cta-actions {
        gap: 0.75rem;
    }

    .hero-grid.hero-grid-showcase .hero-visual,
    .hero-grid.hero-grid-home .hero-visual {
        margin-top: 0.4rem;
    }

    .header-actions {
        width: auto;
        flex-wrap: nowrap;
        justify-content: flex-end;
        gap: 0.55rem;
    }

    .header-actions > .btn-ghost,
    .header-actions > .btn-solid {
        display: none;
    }

    .lang-switch {
        width: auto;
    }

    body[data-page="contact"] .contact-copy,
    body[data-page="contact"] .contact-stage-stack {
        gap: 0.85rem;
    }

    body[data-page="contact"] .contact-owner-card,
    body[data-page="contact"] .contact-process-card,
    body[data-page="contact"] .contact-proof-card,
    body[data-page="contact"] .contact-response-note {
        border-radius: 24px;
    }
}

@media (max-width: 620px) {
    .nav-container,
    .shell,
    .hero-grid,
    .footer-shell,
    .cta-shell,
    .contact-shell {
        width: min(100%, calc(100% - 16px));
    }

    .site-header {
        padding: 0.75rem 0;
    }

    .page-hero {
        padding-top: 104px;
        padding-bottom: 44px;
    }

    .brand-copy strong {
        font-size: 0.98rem;
    }

    .header-actions {
        gap: 0.45rem;
    }

    .lang-switch {
        width: auto;
        justify-content: flex-start;
    }

    .lang-switch a {
        min-width: 40px;
        padding: 0.5rem 0.7rem;
    }

    .nav-toggle {
        width: 44px;
        height: 44px;
        border-radius: 14px;
    }

    .mobile-nav-panel {
        padding: 0.85rem;
        border-radius: 24px;
        gap: 0.85rem;
    }

    .mobile-nav-actions {
        grid-template-columns: 1fr;
    }

    .hero-copy {
        gap: 0.82rem;
    }

    .hero-title,
    .contact-copy h1 {
        font-size: clamp(2.55rem, 16vw, 4rem);
        line-height: 0.92;
    }

    .hero-kicker-line {
        font-size: 0.96rem;
        line-height: 1.42;
    }

    .hero-lead,
    .section-lead,
    .detail-copy p,
    .contact-copy p,
    .cta-shell p {
        font-size: 0.95rem;
        line-height: 1.68;
    }

    .hero-actions,
    .cta-actions {
        display: grid;
        grid-template-columns: 1fr;
    }

    .hero-actions > *,
    .cta-actions > * {
        width: 100%;
        justify-content: center;
    }

    .hero-proof-item,
    .metric-card,
    .feature-card,
    .proof-card,
    .fit-card,
    .step-card,
    .comparison-row,
    .contact-card {
        padding: 1rem;
        border-radius: 20px;
    }

    .section-shell,
    .cta-shell,
    .contact-shell,
    .footer-shell {
        padding: 1rem;
        border-radius: 24px;
    }

    .feature-list li {
        align-items: flex-start;
        gap: 0.72rem;
    }

    body[data-page="contact"] .contact-owner-card,
    body[data-page="contact"] .contact-process-card,
    body[data-page="contact"] .contact-proof-card,
    body[data-page="contact"] .contact-response-note {
        padding: 1rem;
        border-radius: 20px;
    }
}

a:focus-visible,
button:focus-visible,
[role="button"]:focus-visible,
[tabindex]:focus-visible {
    outline: 2px solid rgba(89, 201, 255, 0.96);
    outline-offset: 3px;
    box-shadow: 0 0 0 5px rgba(47, 124, 255, 0.18);
}

.modal-opt:focus-visible,
.lang-chip:focus-visible,
.mobile-menu-toggle:focus-visible,
.btn-solid:focus-visible,
.btn-outline:focus-visible,
.btn-ghost:focus-visible {
    border-color: rgba(89, 201, 255, 0.42);
}
