/**
 * Micras Demographics Tool - Wizard Styles
 * 
 * Styles for wizard navigation, progress indicator, and step containers.
 */

/* ===== Wizard Container ===== */
.wizard {
    display: flex;
    flex-direction: column;
    min-height: 600px;
}

/* ===== Progress Indicator ===== */
.wizard-progress {
    background: var(--color-bg-secondary);
    border-bottom: 1px solid var(--color-border);
    padding: var(--space-4);
    overflow-x: auto;
}

.progress-steps {
    display: flex;
    list-style: none;
    justify-content: space-between;
    min-width: max-content;
    gap: var(--space-2);
}

.progress-step {
    flex: 1;
    min-width: 80px;
}

.progress-step-button {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-1);
    width: 100%;
    padding: var(--space-2);
    background: transparent;
    border: none;
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: background-color var(--transition-fast);
    position: relative;
}

.progress-step-button:hover {
    background: var(--color-bg-tertiary);
}

.step-number {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    font-weight: 600;
    font-size: var(--text-sm);
    transition: all var(--transition-fast);
}

.step-name {
    font-size: var(--text-xs);
    color: var(--color-text-secondary);
    text-align: center;
    transition: color var(--transition-fast);
}

.status-icon {
    position: absolute;
    top: 0;
    right: var(--space-2);
    font-size: var(--text-sm);
}

/* Progress Step States */
.progress-step.incomplete .step-number {
    background: var(--color-bg-tertiary);
    color: var(--color-text-muted);
    border: 2px solid var(--color-border);
}

.progress-step.current .step-number {
    background: var(--color-primary);
    color: white;
    border: 2px solid var(--color-primary);
}

.progress-step.current .step-name {
    color: var(--color-primary);
    font-weight: 500;
}

.progress-step.completed .step-number {
    background: var(--color-success-light);
    color: var(--color-success);
    border: 2px solid var(--color-success);
}

.progress-step.completed .status-icon {
    color: var(--color-success);
}

.progress-step.error .step-number {
    background: var(--color-error-light);
    color: var(--color-error);
    border: 2px solid var(--color-error);
}

.progress-step.error .status-icon {
    color: var(--color-error);
}

/* ===== Wizard Content ===== */
.wizard-content {
    flex: 1;
    padding: var(--space-6) var(--space-8);
    overflow-y: auto;
}

.step-container {
    max-width: 800px;
    margin: 0 auto;
}

.step-title {
    margin-bottom: var(--space-6);
    padding-bottom: var(--space-4);
    border-bottom: 1px solid var(--color-border);
}

.step-content {
    /* Container for step-specific content */
}

.step-placeholder {
    text-align: center;
    padding: var(--space-16) var(--space-8);
    color: var(--color-text-secondary);
}

.placeholder-message {
    font-style: italic;
}

/* ===== Wizard Navigation ===== */
.wizard-navigation {
    background: var(--color-bg-secondary);
    border-top: 1px solid var(--color-border);
    padding: var(--space-4) var(--space-8);
}

.nav-buttons {
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 800px;
    margin: 0 auto;
}

.nav-spacer {
    width: 100px;
}

.nav-center {
    display: flex;
    gap: var(--space-4);
}

/* ===== Section Groups ===== */
.section-group {
    margin-bottom: var(--space-8);
}

.section-group:last-child {
    margin-bottom: 0;
}

.section-header {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    margin-bottom: var(--space-4);
}

.section-header h3 {
    margin: 0;
}

.section-description {
    color: var(--color-text-secondary);
    font-size: var(--text-sm);
    margin-bottom: var(--space-4);
}

/* ===== Conditional Sections ===== */
.conditional-section {
    margin-top: var(--space-6);
    padding: var(--space-4);
    background: var(--color-bg-secondary);
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
}

.conditional-section[hidden] {
    display: none;
}

.conditional-section h4 {
    margin-bottom: var(--space-4);
}

/* ===== Info Boxes ===== */
.info-box {
    display: flex;
    gap: var(--space-3);
    padding: var(--space-4);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-4);
}

.info-box-icon {
    flex-shrink: 0;
    font-size: var(--text-lg);
}

.info-box-content {
    flex: 1;
}

.info-box-content p {
    margin-bottom: var(--space-2);
}

.info-box-content p:last-child {
    margin-bottom: 0;
}

.info-box-info {
    background: var(--color-primary-light);
    border: 1px solid var(--color-primary);
}

.info-box-info .info-box-icon {
    color: var(--color-primary);
}

.info-box-warning {
    background: var(--color-warning-light);
    border: 1px solid var(--color-warning);
}

.info-box-warning .info-box-icon {
    color: var(--color-warning);
}

.info-box-success {
    background: var(--color-success-light);
    border: 1px solid var(--color-success);
}

.info-box-success .info-box-icon {
    color: var(--color-success);
}

/* ===== Responsive ===== */
@media (max-width: 768px) {
    .wizard-progress {
        padding: var(--space-2);
    }
    
    .progress-steps {
        gap: var(--space-1);
    }
    
    .progress-step {
        min-width: 60px;
    }
    
    .step-number {
        width: 28px;
        height: 28px;
        font-size: var(--text-xs);
    }
    
    .step-name {
        font-size: var(--text-xs);
    }
    
    .wizard-content {
        padding: var(--space-4);
    }
    
    .wizard-navigation {
        padding: var(--space-4);
    }
    
    .nav-buttons {
        flex-wrap: wrap;
        gap: var(--space-3);
    }
    
    .nav-center {
        order: 3;
        width: 100%;
        justify-content: center;
    }
}

@media (max-width: 480px) {
    .progress-steps {
        justify-content: flex-start;
    }
    
    .progress-step {
        min-width: 50px;
    }
    
    .step-name {
        display: none;
    }
    
    .progress-step.current .step-name {
        display: block;
    }
}
