/* ====== Look & feel (dark glass like your screenshot) ====== */
:root {
    --accent: #424DFE;
    --panel-bg: rgba(255, 255, 255, .04);
    --panel-border: rgba(255, 255, 255, .08);
    --text-strong: #424DFE;
    --text-muted: rgba(233, 237, 247, .72);
}

.flow {
    padding: 48px 0
}

.flow__wrap {
    display: grid;
    place-items: center
}

.flow__panel {
    width: min(560px, 100%);
    background: var(--panel-bg);
    border: 1px solid var(--panel-border);
    border-radius: 18px;
    padding: 20px 18px 22px;
    backdrop-filter: blur(10px) saturate(140%);
    -webkit-backdrop-filter: blur(10px) saturate(140%);
    box-shadow: 0 16px 40px rgba(0, 0, 0, .35), inset 0 1px 0 rgba(255, 255, 255, .06);
    color: var(--text-strong);
}

/* ====== List ====== */
.flow__list {
    list-style: none;
    margin: 0 0 14px;
    padding: 0;
    display: grid;
    gap: 10px
}

.flow__item {
    position: relative;
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
    border: 1px solid rgba(255, 255, 255, .08);
    border-radius: 12px;
    background: rgba(255, 255, 255, .02);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .04);
    transition: filter .25s ease, opacity .25s ease, transform .25s ease, border-color .25s ease, background .25s ease;
    overflow: hidden;
}

.flow__icon {
    display: grid;
    place-items: center;
    width: 34px;
    height: 34px;
    border-radius: 8px;
    background: radial-gradient(80% 80% at 50% 20%, rgba(255, 255, 255, .08), rgba(255, 255, 255, .02));
    border: 1px solid rgba(255, 255, 255, .08);
}

.flow__icon svg {
    width: 18px;
    height: 18px;
    fill: #cbd3ff
}

.flow__label {
    font-weight: 600;
    letter-spacing: .2px
}

.flow__status {
    opacity: .9;
    font-weight: 700;
    color: #aab3ff
}

/* Inactive (blurred) */
.flow__item {
    opacity: .35;
    filter: blur(1.2px)
}

/* Active focus */
.flow__item.is-active {
    opacity: 1;
    filter: none;
    transform: translateY(-1px);
    border-color: color-mix(in srgb, var(--accent), transparent 70%);
    background: linear-gradient(180deg, rgba(66, 77, 254, .12), rgba(66, 77, 254, .05));
    box-shadow: 0 10px 28px rgba(66, 77, 254, .18), inset 0 1px 0 rgba(255, 255, 255, .08);
}

.flow__item.is-active .flow__icon {
    border-color: rgba(66, 77, 254, .45)
}

.flow__item.is-active .flow__icon svg {
    fill: #e7e9ff
}

.flow__item.is-active .flow__status {
    color: #dfe2ff
}

/* Caption */
.flow__caption h3 {
    margin: 8px 0 6px;
    font-size: 20px
}

.flow__caption p {
    margin: 0;
    color: var(--text-muted);
    font-size: 15px;
    line-height: 1.45
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
    .flow__item {
        transition: none
    }
}