
/* Simplified Tooltip Component */
.tooltip {
    position: relative;
    display: inline-flex;
    align-items: center;
}

.tooltip .tooltip-content {
    visibility: hidden;
    opacity: 0;
    position: absolute;
    z-index: 1000;
    width: max-content;
    max-width: 250px;
    padding: var(--spacing-xs) var(--spacing-sm);
    background: var(--color-neutral-900);
    color: var(--color-text-inverse);
    text-align: center;
    border-radius: var(--border-radius-sm);
    font-size: var(--font-size-sm);
    line-height: 1.4;
    transition: var(--transition-base);
    box-shadow: var(--shadow-md);
    pointer-events: none;
    text-transform: none;
    
    /* Default position - will be overridden if needed */
    bottom: 115%;
    left: 50%;
    transform: translateX(-50%) translateY(-8px);
}

/* Tooltip arrow */
.tooltip .tooltip-content::after {
    content: "";
    position: absolute;
    left: 50%;
    margin-left: -5px;
    border: 5px solid transparent;
    border-top-color: var(--color-neutral-900);
    bottom: -10px;
}

/* Show tooltip on hover */
.tooltip:hover .tooltip-content {
    visibility: visible;
    opacity: 1;
    transform: translateX(-50%) translateY(0);
}


/* Edge detection - if tooltip would go off-screen */
@media (max-width: 768px) {
    .tooltip .tooltip-content {
        left: auto;
        right: 0;
        transform: translateY(-8px);
    }
    
    .tooltip:hover .tooltip-content {
        transform: translateY(0);
    }
    
    .tooltip .tooltip-content::after {
        left: auto;
        right: 10px;
    }
}


/* Floating tooltip container */
.step-tooltip-container {
    position: absolute;
    left: -280px;
    top: 0;
    width: 260px;
    background: var(--color-background);
    border: 2px solid var(--color-border);
    border-radius: var(--border-radius-lg);
    padding: var(--spacing-md);
    box-shadow: var(--shadow-lg);
    opacity: 0;
    visibility: hidden;
    transition: all var(--transition-base);
    z-index: 1000;
}

.step-tooltip-container.show {
    opacity: 1;
    visibility: visible;
}

.tooltip-content {
    text-align: left;
}

.tooltip-title {
    font-weight: var(--font-weight-bold);
    color: var(--color-primary);
    margin-bottom: var(--spacing-xs);
    font-size: var(--font-size-sm);
}

.tooltip-description {
    color: var(--color-text);
    font-size: var(--font-size-sm);
    line-height: 1.4;
}

/* Workshop progress panel positioning for tooltip */
.workshop-progress-panel {
    position: relative;
}

/* Step header hover cursor */
.step-header {
    cursor: help;
}
