/* ============================================================
   Onboarding Flow  (.nib-ob)
   ============================================================ */

:root {
    --nib-ob-accent: #1a6b3c;
    --nib-ob-accent-light: color-mix(in oklab, #1a6b3c 14%, transparent);
    --nib-ob-accent-text: #1a6b3c;
    --nib-ob-radius: 12px;
    --nib-ob-badge-size: 32px;
}

/* Container */
.nib-ob {
    background: var(--rz-base-background-color);
    border: 1px solid var(--rz-border-disabled-color);
    border-radius: var(--nib-ob-radius);
    overflow: hidden;
    container-type: inline-size;
}

/* Header */
.nib-ob-head {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 1.1rem 1.25rem 1rem;
    border-bottom: 1px solid var(--rz-border-disabled-color);
    background: color-mix(in oklab, var(--nib-ob-accent) 5%, var(--rz-base-background-color));
}

.nib-ob-head-icon {
    width: 40px;
    height: 40px;
    flex-shrink: 0;
    background: var(--nib-ob-accent-light);
    color: var(--nib-ob-accent-text);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
}

.nib-ob-title {
    font-size: 0.9rem;
    font-weight: 700;
    margin: 0;
    color: var(--rz-text-color);
    line-height: 1.3;
}

.nib-ob-subtitle {
    font-size: 0.75rem;
    color: var(--rz-text-secondary-color);
    margin: 0.1rem 0 0;
    line-height: 1.3;
}

/* Steps wrapper */
.nib-ob-steps {
    padding: 1rem 1.25rem 0.5rem 1.25rem;
    display: flex;
    flex-direction: column;
}

/* Single step row */
.nib-ob-step {
    display: flex;
    gap: 0.875rem;
    align-items: flex-start;
}

/* Left column: badge + connector */
.nib-ob-step-left {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex-shrink: 0;
    width: var(--nib-ob-badge-size);
}

/* Badge circle */
.nib-ob-badge {
    width: var(--nib-ob-badge-size);
    height: var(--nib-ob-badge-size);
    border-radius: 50%;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.78rem;
    font-weight: 700;
    border: 2px solid var(--rz-border-disabled-color);
    color: var(--rz-text-disabled-color);
    background: transparent;
    transition: background 0.2s, border-color 0.2s, color 0.2s;
    line-height: 1;
}

/* Vertical connector between steps */
.nib-ob-connector {
    width: 2px;
    flex: 1;
    min-height: 16px;
    background: var(--rz-border-disabled-color);
    margin: 3px 0;
    border-radius: 1px;
    transition: background 0.2s;
}

/* Right column: content */
.nib-ob-step-body {
    flex: 1;
    padding-bottom: 1.1rem;
    min-width: 0;
}

.nib-ob-step-body--sk {
    padding-top: 0.45rem;
}

.nib-ob-step-top {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
    min-width: 0;
}

.nib-ob-step-title {
    font-size: 0.845rem;
    font-weight: 600;
    margin: 0.2rem 0 0;
    color: var(--rz-text-color);
    line-height: 1.3;
    flex: 1;
    min-width: 0;
}

.nib-ob-step-desc {
    font-size: 0.78rem;
    color: var(--rz-text-secondary-color);
    margin: 0.25rem 0 0.55rem;
    line-height: 1.45;
}

/* Action button */
.nib-ob-action {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.3rem 0.8rem;
    border-radius: 6px;
    font-size: 0.75rem;
    font-weight: 600;
    text-decoration: none;
    transition: opacity 0.15s;
    cursor: pointer;
    background: var(--nib-ob-accent);
    color: #fff;
    line-height: 1.5;
}

.nib-ob-action:hover {
    opacity: 0.85;
    color: #fff;
    text-decoration: none;
}

/* Action disabled (locked) */
.nib-ob-action--locked {
    background: var(--rz-base-300, rgba(0,0,0,0.06));
    color: var(--rz-text-disabled-color);
    pointer-events: none;
    cursor: not-allowed;
    opacity: 0.7;
}

/* "Klaar" pill */
.nib-ob-done-tag {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    font-size: 0.68rem;
    font-weight: 700;
    color: var(--nib-ob-accent-text);
    background: var(--nib-ob-accent-light);
    border-radius: 20px;
    padding: 0.1rem 0.5rem;
    white-space: nowrap;
    flex-shrink: 0;
}

/* ─── States ──────────────────────────────────────────────── */

/* Done */
.nib-ob-step--done .nib-ob-badge {
    background: var(--nib-ob-accent-light);
    border-color: var(--nib-ob-accent);
    color: var(--nib-ob-accent-text);
}

.nib-ob-step--done .nib-ob-connector {
    background: color-mix(in oklab, var(--nib-ob-accent) 35%, var(--rz-border-disabled-color));
}

.nib-ob-step--done .nib-ob-step-title {
    color: var(--rz-text-secondary-color);
    font-weight: 500;
}

.nib-ob-step--done .nib-ob-step-desc {
    font-size: 0.75rem;
    opacity: 0.8;
}

/* Active */
.nib-ob-step--active .nib-ob-badge {
    background: var(--nib-ob-accent);
    border-color: var(--nib-ob-accent);
    color: #fff;
    box-shadow: 0 0 0 3px color-mix(in oklab, var(--nib-ob-accent) 22%, transparent);
}

.nib-ob-step--active .nib-ob-step-title {
    color: var(--rz-text-color);
    font-weight: 700;
}

/* Locked */
.nib-ob-step--locked .nib-ob-step-title {
    color: var(--rz-text-disabled-color);
    font-weight: 500;
}

.nib-ob-step--locked .nib-ob-step-desc {
    opacity: 0.5;
}

/* ─── All done banner ─────────────────────────────────────── */

.nib-ob-complete {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    margin: 0 1.25rem 1rem;
    padding: 0.6rem 0.9rem;
    border-radius: 8px;
    background: var(--nib-ob-accent-light);
    color: var(--nib-ob-accent-text);
    font-size: 0.8rem;
    font-weight: 600;
}

.nib-ob-complete i {
    font-size: 0.9rem;
}

/* ─── Skeleton ────────────────────────────────────────────── */

.nib-ob-sk-title {
    height: 13px;
    width: 62%;
    border-radius: 4px;
    margin-bottom: 7px;
}

.nib-ob-sk-desc {
    height: 10px;
    width: 82%;
    border-radius: 4px;
}

/* ─── Dark mode ───────────────────────────────────────────── */

[data-theme="dark"] {
    --nib-ob-accent-light: color-mix(in oklab, #1a6b3c 22%, transparent);
    --nib-ob-accent-text: color-mix(in oklab, #1a6b3c 80%, #a8ffcb);
}

[data-theme="dark"] .nib-ob-head {
    background: color-mix(in oklab, var(--nib-ob-accent) 9%, var(--rz-base-background-color));
}

[data-theme="dark"] .nib-ob-action--locked {
    background: rgba(255,255,255,0.06);
}
