/* ==========================================================================
   STREAM PAGE - Message listing and chain view styles
   ========================================================================== */

/* ==========================================================================
   Stream Container
   ========================================================================== */

.stream-container {
    max-width: 95vw;
    margin: 0 auto;
    padding: var(--spacing-base);
}

/* ==========================================================================
   Stream Message Card
   ========================================================================== */

.stream-message {
    margin: var(--spacing-lg) 0;
    padding: var(--spacing-base);
    border: 1px solid var(--color-border);
    border-radius: var(--border-radius-base);
    background: var(--color-background);
}

/* ==========================================================================
   Primary Navigation (All Messages / Current Channel / View Index)
   ========================================================================== */

.primary-nav {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 1rem;
    font-size: var(--font-size-sm);
}

.primary-nav .channel-link {
    padding: var(--spacing-xs) var(--spacing-sm);
    color: var(--color-primary);
    text-decoration: none;
    border-radius: var(--border-radius-sm);
    transition: background-color var(--transition-base), color var(--transition-base);
}

.primary-nav .channel-link:hover {
    background-color: var(--color-annotation-bg);
    text-decoration: none;
}

/* Back link styling */
.primary-nav .nav-back {
    color: var(--color-text-secondary);
}

.primary-nav .nav-back:hover {
    color: var(--color-primary);
}

/* Current location indicator */
.primary-nav .nav-current {
    font-weight: 600;
    color: var(--color-text);
}

/* Separator between nav items */
.primary-nav .nav-separator {
    color: var(--color-border);
    user-select: none;
}

/* Action link styling (View Index) */
.primary-nav .nav-action {
    color: var(--color-text-secondary);
}

.primary-nav .nav-action:hover {
    color: var(--color-primary);
}

/* ==========================================================================
   Channel Navigation
   ========================================================================== */

.channel-navigation {
    margin: var(--spacing-lg) 0;
    border-bottom: 1px solid var(--color-border);
}

/* ==========================================================================
   Chain View (Threaded Messages)
   ========================================================================== */

.chain-container {
    max-width: 95vw;
    margin: 0 auto;
    padding: var(--spacing-base);
}

.chain-message {
    margin: var(--spacing-lg) 0;
    padding: var(--spacing-base);
    border: 1px solid var(--color-border);
    border-radius: var(--border-radius-base);
    background: var(--color-background);
    position: relative;
}

.chain-message.target-message {
    border: 2px solid var(--color-primary);
    background: rgba(var(--color-primary-rgb), 0.05);
}

/* Message connector lines */
.message-connector {
    position: absolute;
    left: 50%;
    height: var(--spacing-lg);
    border-left: 2px dashed var(--color-border);
    transform: translateX(-50%);
}

.connector-top {
    top: calc(-1 * var(--spacing-lg));
}

.connector-bottom {
    bottom: calc(-1 * var(--spacing-lg));
}

/* Chain navigation header */
.chain-navigation {
    top: var(--spacing-base);
    z-index: var(--z-sticky);
    background: var(--color-background);
    padding: var(--spacing-base);
    border-radius: var(--border-radius-base);
    margin-bottom: var(--spacing-lg);
}

.chain-overview {
    display: flex;
    gap: var(--spacing-base);
    align-items: center;
    justify-content: space-between;
}

/* ==========================================================================
   Message Channel Badge
   ========================================================================== */

.message-channel {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    padding: 0.2em 0.5em;
    border: 1px solid var(--color-border);
    border-radius: var(--border-radius-base);
}

/* ==========================================================================
   Theme Adjustments
   ========================================================================== */

/* Dark theme */
[data-theme="dark"] .primary-nav .nav-current {
    color: var(--color-text);
}

[data-theme="dark"] .primary-nav .nav-back,
[data-theme="dark"] .primary-nav .nav-action {
    color: var(--color-text-secondary);
}

[data-theme="dark"] .primary-nav .channel-link:hover {
    color: var(--color-primary);
}

/* Grayscale/High-contrast theme */
[data-theme="grayscale"] .stream-container {
    max-width: 95vw;
}

[data-theme="grayscale"] .message-header {
    border-bottom: 1px solid var(--color-text);
    padding-bottom: var(--spacing-base);
}

[data-theme="grayscale"] .message-sidebar {
    position: relative;
    max-height: none;
    border-left: 2px solid var(--color-text);
}

[data-theme="grayscale"] .channel-navigation {
    border-bottom: 2px solid var(--color-text);
}

[data-theme="grayscale"] .message-channel {
    border: 2px solid currentColor;
}

/* ==========================================================================
   Responsive Design
   ========================================================================== */

@media screen and (max-width: 1024px) {
    [data-theme="grayscale"] .stream-message {
        grid-template-columns: 1fr;
        gap: var(--spacing-base);
    }

    [data-theme="grayscale"] .message-sidebar {
        border-left: none;
        border-top: 2px solid var(--color-text);
        padding-top: var(--spacing-base);
    }
}

@media screen and (max-width: 768px) {
    .primary-nav {
        flex-wrap: wrap;
        gap: 0.5rem;
        justify-content: center;
    }

    .message-channel {
        align-self: flex-start;
    }
}
