/**
 * SubNav Component Styles
 *
 * Vertical side navigation with content panel layout.
 * Uses the centralized color system for consistency.
 *
 * Features:
 * - Smooth transitions and animations
 * - Full light/dark mode support
 * - Accessible focus states
 * - Polished modern design
 *
 * @author Austin Steil
 * @version 1.0.0
 * @license MIT <https://raw.githubusercontent.com/AustinSteil/generate-files-model/refs/heads/main/LICENSE>
 * @copyright 2025 Austin Steil
 * @created October 18, 2025
 * @updated October 18, 2025
 */

/* ============================================
   WRAPPER & LAYOUT
   ============================================ */
.subnav-wrapper {
    width: 100%;
    display: grid;
    grid-template-columns: 220px 1fr;
    grid-template-areas: "sidebar content";
    gap: var(--spacing-2xl);
    min-height: 400px;
    align-items: start;
}

/* Larger desktop: Wider sidebar */
@media (min-width: 1200px) {
    .subnav-wrapper {
        grid-template-columns: 250px 1fr;
        gap: var(--spacing-3xl);
    }
}

/* ============================================
   SIDE NAVIGATION
   ============================================ */
.subnav-sidebar {
    grid-area: sidebar;
    background: linear-gradient(to bottom,
        var(--color-bg-primary) 0%,
        var(--color-gray-50) 100%);
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border-light);
    box-shadow: var(--shadow-sm);
    padding: var(--spacing-md);
    position: sticky;
    top: var(--spacing-xl);
    align-self: flex-start;
    max-height: calc(100vh - 120px);
    overflow-y: auto;
    overflow-x: hidden;
}

/* Custom scrollbar for sidebar */
.subnav-sidebar::-webkit-scrollbar {
    width: 6px;
}

.subnav-sidebar::-webkit-scrollbar-track {
    background: transparent;
}

.subnav-sidebar::-webkit-scrollbar-thumb {
    background: var(--color-border-medium);
    border-radius: var(--radius-full);
}

.subnav-sidebar::-webkit-scrollbar-thumb:hover {
    background: var(--color-border-dark);
}

.subnav-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
}

.subnav-item {
    margin: 0;
}

.subnav-link {
    width: 100%;
    padding: var(--spacing-md) var(--spacing-lg);
    background: transparent;
    border: none;
    border-left: 3px solid transparent;
    border-radius: var(--radius-md);
    color: var(--color-text-secondary);
    font-size: 15px;
    font-weight: 500;
    text-align: left;
    cursor: pointer;
    transition: all var(--transition-cubic);
    position: relative;
    font-family: inherit;
}

.subnav-link:hover {
    background: linear-gradient(to right,
        rgba(var(--color-primary-rgb), 0.08) 0%,
        transparent 100%);
    color: var(--color-primary);
    border-left-color: var(--color-primary);
    transform: translateX(2px);
}

.subnav-link.active {
    background: linear-gradient(to right,
        rgba(var(--color-primary-rgb), 0.12) 0%,
        rgba(var(--color-primary-rgb), 0.04) 100%);
    color: var(--color-primary);
    border-left-color: var(--color-primary);
    font-weight: 600;
    box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.08);
}

.subnav-link.active::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 3px;
    background: linear-gradient(to bottom,
        transparent 0%,
        var(--color-primary) 20%,
        var(--color-primary) 80%,
        transparent 100%);
    border-radius: var(--radius-sm);
}

.subnav-link:focus {
    outline: none;
}

.subnav-link:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

/* ============================================
   CONTENT PANEL
   ============================================ */
.subnav-content-panel {
    grid-area: content;
    background: linear-gradient(to bottom,
        var(--color-bg-primary) 0%,
        var(--color-gray-50) 100%);
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border-light);
    box-shadow: var(--shadow-md);
    padding: var(--spacing-3xl);
    min-height: 400px;
    position: relative;
}

/* When content panel contains only no-padding sections, don't enforce min-height */
.subnav-content-panel:has(> .subnav-content.no-padding.active) {
    min-height: auto;
}

.subnav-content {
    display: none;
    animation: contentFadeIn var(--transition-cubic) forwards;
}

.subnav-content.active {
    display: block;
}

@keyframes contentFadeIn {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.subnav-content-title {
    color: var(--color-text-primary);
    font-size: 24px;
    font-weight: 600;
    margin: 0 0 var(--spacing-xl) 0;
    padding-bottom: var(--spacing-md);
    border-bottom: 2px solid var(--color-border-light);
}

.subnav-content-body {
    color: var(--color-text-secondary);
    line-height: 1.6;
}

/* Ensure content body has proper spacing for form elements */
.subnav-content-body > *:first-child {
    margin-top: 0;
}

.subnav-content-body > *:last-child {
    margin-bottom: 0;
}

/* No padding option for sections that need flush content (e.g., tables) */
.subnav-content.no-padding {
    margin-top: calc(var(--spacing-3xl) * -1);
    margin-bottom: calc(var(--spacing-3xl) * -1);
    margin-left: calc(var(--spacing-3xl) * -1);
    margin-right: calc(var(--spacing-3xl) * -1);
}

.subnav-content-body.no-padding {
    padding: 0;
    margin: 0;
}

.subnav-content-body.no-padding > *:first-child {
    margin-top: 0;
}

.subnav-content-body.no-padding > *:last-child {
    margin-bottom: 0;
}

/* Remove margin from table component when inside no-padding content */
.subnav-content-body.no-padding .table-component {
    margin: 0;
}

/* ============================================
   DARK MODE ADJUSTMENTS
   ============================================ */
.dark-mode .subnav-sidebar {
    background: linear-gradient(to bottom,
        var(--color-bg-primary) 0%,
        var(--color-bg-tertiary) 100%);
    border-color: var(--color-border-light);
    box-shadow: var(--shadow-md);
}

.dark-mode .subnav-sidebar::-webkit-scrollbar-thumb {
    background: var(--color-border-medium);
}

.dark-mode .subnav-sidebar::-webkit-scrollbar-thumb:hover {
    background: var(--color-border-dark);
}

.dark-mode .subnav-link:hover {
    background: linear-gradient(to right,
        rgba(var(--color-primary-rgb), 0.15) 0%,
        transparent 100%);
}

.dark-mode .subnav-link.active {
    background: linear-gradient(to right,
        rgba(var(--color-primary-rgb), 0.2) 0%,
        rgba(var(--color-primary-rgb), 0.08) 100%);
    box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.3);
}

.dark-mode .subnav-content-panel {
    background: linear-gradient(to bottom,
        var(--color-bg-primary) 0%,
        var(--color-bg-tertiary) 100%);
    border-color: var(--color-border-light);
    box-shadow: var(--shadow-md);
}



