/* ---------- Mini Swim – simple 3-lane board with one enlarged card ---------- */
.swim-mini {
    --bg: var(--panel-dark, #1f1b3f);
    --glass: rgba(255, 255, 255, .06);
    --glass2: rgba(255, 255, 255, .10);
    --stroke: var(--bd-soft, rgba(255, 255, 255, .14));
    --ink: var(--ink-dark, #eaf1ff);
    --muted: var(--ink-muted, #9fb0cf);
    --c1: var(--ai-c1, #423dfc);
    --c2: var(--ai-c2, #7271fb);

    position: relative;
    padding: 16px;
    border-radius: 16px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, .08), rgba(255, 255, 255, .02)),
        var(--bg);
    border: 1px solid var(--stroke);
    color: var(--ink);
    box-shadow: 0 10px 32px rgba(0, 0, 0, .35), inset 0 1px 0 rgba(255, 255, 255, .06);
    overflow: hidden;
}

/* Lanes grid */
.swim-mini .swim-lanes {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 14px;
}

@media (max-width: 992px) {
    .swim-mini .swim-lanes {
        grid-template-columns: 1fr;
    }
}

/* Lane shell */
.swim-mini .lane {
    display: grid;
    gap: 10px;
    padding: 12px;
    border-radius: 14px;
    background: linear-gradient(180deg, var(--glass2), rgba(255, 255, 255, .04));
    border: 1px solid var(--stroke);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .10);
}

.swim-mini .lane--focus {
    outline: 1px solid color-mix(in oklab, var(--c1), transparent 40%);
    box-shadow: 0 12px 28px rgba(0, 0, 0, .4), inset 0 1px 0 rgba(255, 255, 255, .12);
}

.swim-mini .lane-head {
    width: max-content;
    padding: 6px 10px;
    border-radius: 999px;
    font: 800 12px/1 Inter, system-ui, sans-serif;
    letter-spacing: .02em;
    background: rgba(255, 255, 255, .12);
    border: 1px solid rgba(255, 255, 255, .22);
}

/* Cards */
.swim-mini .card {
    display: grid;
    gap: 8px;
    padding: 12px;
    border-radius: 12px;
    background: rgba(0, 0, 0, .22);
    border: 1px solid rgba(255, 255, 255, .18);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .10);
}

.swim-mini .card--dragged {
    background: linear-gradient(135deg, var(--c1), var(--c2));
    border-color: rgba(255, 255, 255, .28);
    box-shadow: 0 10px 24px rgba(0, 0, 0, .35);
}

.swim-mini .ghost {
    background: rgba(255, 255, 255, .06);
    border-style: dashed;
}

.swim-mini .ghost-line {
    height: 10px;
    border-radius: 999px;
    background: rgba(255, 255, 255, .20);
}

/* Card bits */
.swim-mini .pill {
    width: max-content;
    padding: 4px 8px;
    border-radius: 999px;
    font: 800 10px/1 Inter, system-ui, sans-serif;
    letter-spacing: .02em;
    background: rgba(255, 255, 255, .16);
    border: 1px solid rgba(255, 255, 255, .20);
}

.swim-mini .title {
    margin: 0;
    font: 800 14px/1.2 Inter, system-ui, sans-serif;
    color: var(--ink);
}

.swim-mini .meta {
    color: var(--muted);
    font-size: 12px;
}

.swim-mini .dot {
    display: inline-block;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    margin-right: 6px;
    background: linear-gradient(135deg, var(--c1), var(--c2));
}

/* Progress bar */
.swim-mini .bar {
    height: 8px;
    border-radius: 999px;
    background: rgba(255, 255, 255, .12);
    overflow: hidden;
}

.swim-mini .bar b {
    display: block;
    height: 100%;
    background: linear-gradient(90deg, var(--c1), var(--c2));
}

/* Enlarged floating card */
.swim-mini .swim-highlight {
    position: absolute;
    left: 18px;
    top: -18px;
    width: clamp(240px, 36vw, 320px);
    padding: 14px;
    border-radius: 16px;
    background: linear-gradient(180deg, rgba(255, 255, 255, .12), rgba(255, 255, 255, .04));
    border: 1px solid rgba(255, 255, 255, .18);
    box-shadow: 0 22px 44px rgba(0, 0, 0, .45), inset 0 1px 0 rgba(255, 255, 255, .08);
    backdrop-filter: blur(8px);
    z-index: 3;
}

.swim-mini .hl-pill {
    width: max-content;
    padding: 4px 8px;
    border-radius: 999px;
    font: 800 11px/1 Inter, system-ui, sans-serif;
    letter-spacing: .02em;
    color: #fff;
    background: linear-gradient(135deg, var(--c1), var(--c2));
    border: 1px solid rgba(255, 255, 255, .28);
}

.swim-mini .hl-title {
    margin: 8px 0 6px;
    font: 800 16px/1.2 Inter, system-ui, sans-serif;
}

.swim-mini .hl-bar {
    height: 10px;
    border-radius: 999px;
    background: rgba(255, 255, 255, .12);
    overflow: hidden;
    margin: 6px 0 8px;
}

.swim-mini .hl-bar b {
    display: block;
    height: 100%;
    background: linear-gradient(90deg, var(--c1), var(--c2));
}

.swim-mini .hl-meta {
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--muted);
    font-size: 12px;
}

.swim-mini .hl-meta .dot {
    margin-right: 0;
}

.swim-mini .avatars {
    margin-left: auto;
    display: flex;
}

.swim-mini .avatars i {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: rgba(255, 255, 255, .9);
    box-shadow: 0 0 0 2px rgba(0, 0, 0, .2);
    margin-left: -4px;
}