/* Layout Components - Main Structure */

.main-wrapper {
    display: flex;
    align-items: stretch;
    gap: var(--gap-lg);
    width: 100%;
    max-width: 100%;
    height: calc(100vh - var(--height-wrapper-offset));
    position: relative;
    z-index: 1;
    margin-bottom: var(--margin-wrapper-v);
    margin-top: var(--margin-wrapper-v);
}

.container {
    flex: 1;
    background: var(--color-bg-container);
    background-image: 
        repeating-linear-gradient(0deg, transparent, transparent var(--spacing-xs), rgba(var(--color-primary-rgb), 0.03) var(--spacing-xs), rgba(var(--color-primary-rgb), 0.03) var(--spacing-sm)),
        linear-gradient(to bottom, var(--color-bg-container) 0%, var(--color-bg-container-light) 100%);
    border: var(--border-width-thick) solid var(--color-primary);
    border-radius: var(--border-radius-lg);
    box-shadow: 
        var(--shadow-inset-md),
        var(--shadow-outset-xl),
        0 0 0 var(--border-width-thin) rgba(var(--color-primary-rgb), 0.2);
    padding: var(--spacing-xl);
    display: flex;
    flex-direction: column;
    min-width: 0;
    min-height: 0;
    overflow: hidden;
    position: relative;
    align-self: stretch;
}

.container::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: var(--height-panel-header);
    background: linear-gradient(to bottom, rgba(var(--color-primary-rgb), var(--opacity-overlay-light)), transparent);
    pointer-events: none;
}

.educational-panel {
    width: var(--width-educational-panel);
    min-width: var(--width-educational-panel-min);
    background: var(--color-bg-container);
    background-image: 
        repeating-linear-gradient(0deg, transparent, transparent var(--spacing-xs), rgba(var(--color-primary-rgb), 0.03) var(--spacing-xs), rgba(var(--color-primary-rgb), 0.03) var(--spacing-sm)),
        linear-gradient(to bottom, var(--color-bg-container) 0%, var(--color-bg-container-light) 100%);
    border: var(--border-width-thick) solid var(--color-primary);
    border-radius: var(--border-radius-lg);
    box-shadow: 
        var(--shadow-inset-md),
        var(--shadow-outset-xl),
        0 0 0 var(--border-width-thin) rgba(var(--color-primary-rgb), 0.2);
    padding: var(--spacing-xl);
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    overflow-x: hidden;
    position: relative;
}

.educational-panel::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: var(--height-panel-header);
    background: linear-gradient(to bottom, rgba(var(--color-primary-rgb), var(--opacity-overlay-light)), transparent);
    pointer-events: none;
}

.educational-panel h2 {
    font-family: var(--font-family-heading);
    font-size: var(--font-size-2xl);
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-2xl);
    border-bottom: var(--border-width-base) solid var(--color-primary);
    padding-bottom: var(--spacing-base);
    text-shadow: var(--shadow-text-sm);
    letter-spacing: var(--letter-spacing-md);
}

.formula-content {
    flex: 1;
    font-size: var(--font-size-base);
    line-height: var(--line-height-base);
    color: var(--color-text-secondary);
}

.formula-section {
    margin-bottom: var(--spacing-4xl);
}

.formula-section h3 {
    font-family: var(--font-family-heading);
    font-size: var(--font-size-lg);
    color: var(--color-text-heading);
    margin-bottom: var(--spacing-lg);
    font-weight: var(--font-weight-semibold);
    text-shadow: var(--shadow-text-sm);
    letter-spacing: var(--letter-spacing-sm);
}

.formula-section p {
    margin-bottom: var(--spacing-md);
}

.formula {
    background: rgba(var(--color-primary-rgb), var(--opacity-overlay-formula));
    border-left: var(--spacing-sm) solid var(--color-primary);
    border-right: var(--border-width-thin) solid rgba(var(--color-primary-rgb), var(--opacity-overlay-dark));
    padding: var(--spacing-xl);
    margin: var(--spacing-xl) 0;
    border-radius: var(--border-radius-sm);
    overflow-x: auto;
    text-align: center;
    box-shadow: var(--shadow-inset-sm);
}

.formula code {
    background: transparent;
    padding: 0;
    font-size: var(--font-size-xs);
}

/* KaTeX styling adjustments */
.formula .katex {
    font-size: 1.1em;
}

.formula .katex-display {
    margin: 0.5em 0;
}

.formula-section p .katex {
    font-size: 1em;
}

.visualization-container {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-height: 0;
}

.results-wrapper {
    display: flex;
    gap: var(--gap-lg);
    flex: 1;
    min-height: 0;
}

