/* ── Tour Overlay ─────────────────────────────────────────── */
.tour-overlay {
    position: fixed;
    inset: 0;
    z-index: 9990;
    pointer-events: none;
}

.tour-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.55);
    z-index: 9991;
    pointer-events: all;
}

.tour-spotlight {
    position: fixed;
    z-index: 9992;
    border-radius: 10px;
    box-shadow: 0 0 0 9999px rgba(0,0,0,0.55);
    pointer-events: none;
    transition: all 0.3s ease;
}

/* ── Tooltip ──────────────────────────────────────────────── */
.tour-tooltip {
    position: fixed;
    z-index: 9993;
    background: var(--bg-card, #fff);
    border: 1px solid var(--border-color, #e5e7eb);
    border-radius: 14px;
    padding: 1.25rem 1.4rem;
    width: 300px;
    box-shadow: 0 8px 32px rgba(0,0,0,0.18);
    transition: all 0.3s ease;
    pointer-events: all;
}

.tour-tooltip-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 0.5rem;
}

.tour-tooltip-title {
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--text-primary, #111);
    margin: 0;
}

.tour-tooltip-close {
    background: none;
    border: none;
    font-size: 1.1rem;
    cursor: pointer;
    color: var(--text-secondary, #6b7280);
    padding: 0;
    line-height: 1;
}

.tour-tooltip-text {
    font-size: 0.875rem;
    color: var(--text-secondary, #6b7280);
    line-height: 1.6;
    margin-bottom: 1rem;
}

.tour-tooltip-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
}

.tour-step-count {
    font-size: 0.78rem;
    color: var(--text-secondary, #6b7280);
}

.tour-tooltip-actions {
    display: flex;
    gap: 0.5rem;
}

.tour-btn-skip {
    background: none;
    border: 1.5px solid var(--border-color, #e5e7eb);
    border-radius: 7px;
    padding: 4px 12px;
    font-size: 0.8rem;
    cursor: pointer;
    color: var(--text-secondary, #6b7280);
    transition: border-color 0.15s;
}
.tour-btn-skip:hover { border-color: var(--accent, #7c3aed); color: var(--accent, #7c3aed); }

.tour-btn-next {
    background: var(--accent, #7c3aed);
    border: none;
    border-radius: 7px;
    padding: 4px 16px;
    font-size: 0.8rem;
    font-weight: 600;
    cursor: pointer;
    color: #fff;
    transition: opacity 0.15s;
}
.tour-btn-next:hover { opacity: 0.88; }

/* ── Progress dots ────────────────────────────────────────── */
.tour-dots {
    display: flex;
    gap: 5px;
    align-items: center;
    flex-wrap: wrap;
    max-width: 120px;
}
.tour-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--border-color, #e5e7eb);
    transition: background 0.2s;
    flex-shrink: 0;
}
.tour-dot.active { background: var(--accent, #7c3aed); }

.tour-step-counter {
    font-size: 0.78rem;
    color: var(--text-secondary, #6b7280);
    white-space: nowrap;
}
