/**
 * Demos Navigation - Accessible Expandable Menu
 * Desktop sidebar + Mobile collapsible
 * WCAG 2.1 Level AA Compliant
 */

/* ==========================================================================
   Layout - Desktop Sidebar + Main Content
   ========================================================================== */

.demo-content-wrapper {
    display: flex;
    gap: 2rem;
    margin-top: 0;  /* Align "Featured Demonstrations" with top of navbar */
}

/* Sidebar navigation - Desktop (positioned on right) */
.demo-navigation {
    flex-shrink: 0;
    width: 380px;
    order: 2; /* Place navigation on right side */
}

/* Main content area (positioned on left) */
.demo-main-content {
    flex-grow: 1;
    min-width: 0; /* Prevent flex overflow */
    order: 1; /* Place content on left side */
}

/* ==========================================================================
   Mobile Toggle Button (Hidden on Desktop)
   ========================================================================== */

.demo-nav-mobile-toggle {
    display: none; /* Hidden on desktop */
    width: 100%;
    padding: 1rem;
    background: var(--ucb-dark-gray);
    color: var(--ucb-light-gray);
    border: 2px solid var(--gray-800);
    border-radius: var(--radius-md);
    font-size: 1rem;
    font-weight: 600;
    text-align: left;
    cursor: pointer;
    align-items: center;
    gap: 0.75rem;
    transition: var(--transition-fast);
    /* Fix sub-pixel rendering artifacts at rounded corners */
    transform: translateZ(0);
    backface-visibility: hidden;
}

.demo-nav-mobile-toggle .icon-menu {
    fill: currentColor;
}

.demo-nav-mobile-toggle .icon-chevron {
    fill: currentColor;
    margin-left: auto;
    transition: transform var(--transition-base);
}

.demo-nav-mobile-toggle[aria-expanded="true"] .icon-chevron {
    transform: rotate(180deg);
}

.demo-nav-mobile-toggle:hover,
.demo-nav-mobile-toggle:focus-visible {
    background: var(--gray-900);
    border-color: var(--ucb-gold);
}

.demo-nav-mobile-toggle:focus-visible {
    outline: 3px solid var(--ucb-gold);
    outline-offset: 2px;
}

/* ==========================================================================
   Navigation Menu Container
   ========================================================================== */

.demo-nav-menu {
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    padding: 1rem;
    /* Fix sub-pixel rendering artifacts at rounded corners */
    transform: translateZ(0);
    backface-visibility: hidden;
}

/* ==========================================================================
   Collapse All Button
   ========================================================================== */

.demo-nav-collapse-all {
    width: 100%;
    padding: 0.75rem;
    background: var(--ucb-dark-gray);
    color: var(--ucb-light-gray);
    border: none;
    border-radius: var(--radius-sm);
    font-size: 0.95rem;
    font-weight: 600;
    cursor: pointer;
    margin-bottom: 1rem;
    transition: var(--transition-fast);
    /* Fix sub-pixel rendering artifacts at rounded corners */
    transform: translateZ(0);
    backface-visibility: hidden;
}

.demo-nav-collapse-all:hover {
    background: var(--gray-900);
}

.demo-nav-collapse-all:focus-visible {
    outline: 3px solid var(--ucb-gold);
    outline-offset: 2px;
}

/* ==========================================================================
   Navigation Tree
   ========================================================================== */

.demo-nav-tree {
    max-height: calc(100vh - 300px); /* Limit height, enable scrolling */
    overflow-y: auto;
    overflow-x: hidden;
    padding-right: 0.5rem; /* Space between content and scrollbar */
}

/* Custom scrollbar for webkit browsers */
.demo-nav-tree::-webkit-scrollbar {
    width: 8px;
}

.demo-nav-tree::-webkit-scrollbar-track {
    background: var(--scrollbar-track-bg);
    border-radius: var(--radius-sm);
}

.demo-nav-tree::-webkit-scrollbar-thumb {
    background: var(--scrollbar-thumb-bg);
    border-radius: var(--radius-sm);
}

.demo-nav-tree::-webkit-scrollbar-thumb:hover {
    background: var(--scrollbar-thumb-hover-bg);
}

/* ==========================================================================
   Navigation Items - Hierarchical Structure
   ========================================================================== */

.demo-nav-item {
    margin-bottom: var(--spacing-1);
}

.demo-nav-item-row {
    display: flex;
    align-items: stretch;
    gap: var(--spacing-1);
}

/* Navigation Links */
.demo-nav-link {
    flex-grow: 1;
    display: flex;
    align-items: center;
    padding: 0.75rem;
    text-decoration: none;
    border-radius: var(--radius-sm);
    font-size: 0.95rem;
    font-weight: 500;
    transition: var(--transition-fast);
    min-height: 44px; /* WCAG minimum touch target */
    /* Fix sub-pixel rendering artifacts at rounded corners */
    transform: translateZ(0);
    backface-visibility: hidden;
}

/* Demo count badge */
.demo-count {
    margin-left: auto;
    padding-left: 0.5rem;
    font-size: 0.85rem;
    font-weight: 400;
    opacity: 0.75;
}

/* Level 1 - Areas (Dark gray - matching REFERENCE button-gray-dark) */
.demo-nav-area {
    background: var(--ucb-dark-gray);
    color: var(--ucb-white);
    font-weight: 600;
}

.demo-nav-area:hover,
.demo-nav-area:focus-visible {
    background: var(--gray-900);
    color: var(--ucb-white);
}

.demo-nav-area:visited {
    background-color: var(--ucb-dark-gray) !important;
    color: var(--ucb-white) !important;
}

.demo-nav-area:visited:hover,
.demo-nav-area:visited:focus-visible {
    background-color: var(--gray-900) !important;
    color: var(--ucb-white) !important;
}

/* Level 2 - Topics (UCB Gold - matching REFERENCE button-gold) */
.demo-nav-topic {
    background: var(--ucb-gold);
    color: var(--ucb-black);
    margin-left: 1rem;
    font-weight: 600;
}

.demo-nav-topic:hover,
.demo-nav-topic:focus-visible {
    background: var(--ucb-gold-dark);
    color: var(--ucb-black);
}

.demo-nav-topic:visited {
    background-color: var(--ucb-gold) !important;
    color: var(--ucb-black) !important;
}

.demo-nav-topic:visited:hover,
.demo-nav-topic:visited:focus-visible {
    background-color: var(--ucb-gold-dark) !important;
    color: var(--ucb-black) !important;
}

/* Level 3 - Concepts (Light gray - matching REFERENCE button-gray-light) */
.demo-nav-concept {
    background: var(--ucb-light-gray);
    color: var(--ucb-black);
    margin-left: 2rem;
    font-weight: 600;
}

.demo-nav-concept:hover,
.demo-nav-concept:focus-visible {
    background: var(--gray-300);
    color: var(--ucb-black);
}

.demo-nav-concept:visited {
    background-color: var(--ucb-light-gray) !important;
    color: var(--ucb-black) !important;
}

.demo-nav-concept:visited:hover,
.demo-nav-concept:visited:focus-visible {
    background-color: var(--gray-300) !important;
    color: var(--ucb-black) !important;
}

/* Level 4 - Demos (Blue - matching REFERENCE button-blue) */
.demo-nav-demo {
    background: var(--ucb-link-blue);
    color: var(--ucb-white);
    margin-left: 3rem;
    font-size: 0.9rem;
    font-weight: 600;
}

.demo-nav-demo:hover,
.demo-nav-demo:focus-visible {
    background: var(--ucb-link-blue-hover);
    color: var(--ucb-white);
}

.demo-nav-demo:visited {
    background-color: var(--ucb-link-blue) !important;
    color: var(--ucb-white) !important;
}

.demo-nav-demo:visited:hover,
.demo-nav-demo:visited:focus-visible {
    background-color: var(--ucb-link-blue-hover) !important;
    color: var(--ucb-white) !important;
}

/* Focus states for all links */
.demo-nav-link:focus-visible {
    outline: 3px solid var(--ucb-gold);
    outline-offset: 2px;
}

/* ==========================================================================
   Expand/Collapse Toggle Buttons
   ========================================================================== */

.demo-nav-toggle {
    flex-shrink: 0;
    width: 44px; /* WCAG minimum */
    min-height: 44px; /* WCAG minimum - allows stretching to match link height */
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: var(--transition-fast);
    padding: 0;
    /* Fix sub-pixel rendering artifacts at rounded corners */
    transform: translateZ(0);
    backface-visibility: hidden;
}

/* Match button colors to level */
.demo-nav-level-1 .demo-nav-toggle {
    background: var(--ucb-dark-gray);
    color: var(--ucb-light-gray);
}

.demo-nav-level-2 .demo-nav-toggle {
    background: var(--ucb-gold);
    color: var(--ucb-black);
}

.demo-nav-level-3 .demo-nav-toggle {
    background: var(--ucb-light-gray);
    color: var(--ucb-black);
}

/* Hover states */
.demo-nav-level-1 .demo-nav-toggle:hover {
    background: var(--gray-900);
}

.demo-nav-level-2 .demo-nav-toggle:hover {
    background: var(--ucb-gold-dark);
}

.demo-nav-level-3 .demo-nav-toggle:hover {
    background: var(--gray-300);
}

/* Focus states */
.demo-nav-toggle:focus-visible {
    outline: 3px solid var(--ucb-gold);
    outline-offset: 2px;
}

/* Chevron icons */
.demo-nav-toggle svg {
    fill: currentColor;
    transition: transform var(--transition-base);
}

.demo-nav-toggle[aria-expanded="true"] .icon-chevron-down {
    display: none;
}

.demo-nav-toggle[aria-expanded="true"] .icon-chevron-up {
    display: block !important;
}

.demo-nav-toggle[aria-expanded="false"] .icon-chevron-down {
    display: block;
}

.demo-nav-toggle[aria-expanded="false"] .icon-chevron-up {
    display: none;
}

/* ==========================================================================
   Submenu Containers
   ========================================================================== */

.demo-nav-submenu {
    margin-top: var(--spacing-1);
    margin-bottom: 0;
}

.demo-nav-submenu[hidden] {
    display: none;
}

/* Smooth reveal animation */
@media (prefers-reduced-motion: no-preference) {
    .demo-nav-submenu {
        animation: slideDown 0.3s ease-out;
    }

    @keyframes slideDown {
        from {
            opacity: 0;
            transform: translateY(-10px);
        }
        to {
            opacity: 1;
            transform: translateY(0);
        }
    }
}

/* ==========================================================================
   Mobile Styles (max-width: 991px)
   ========================================================================== */

@media (max-width: 991px) {
    /* Stack layout on mobile */
    .demo-content-wrapper {
        flex-direction: column;
    }

    /* Full width navigation */
    .demo-navigation {
        width: 100%;
    }

    /* Show mobile toggle button */
    .demo-nav-mobile-toggle {
        display: flex;
    }

    /* Hide menu by default on mobile */
    .demo-nav-menu {
        display: none;
        margin-top: 1rem;
    }

    .demo-nav-menu.is-open {
        display: block;
    }

    /* Adjust tree height for mobile */
    .demo-nav-tree {
        max-height: 70vh;
    }

    /* Reduce indentation on mobile */
    .demo-nav-topic {
        margin-left: 0.5rem;
    }

    .demo-nav-concept {
        margin-left: 1rem;
    }

    .demo-nav-demo {
        margin-left: 1.5rem;
    }

    /* Slightly smaller fonts on mobile */
    .demo-nav-link {
        font-size: 0.9rem;
        padding: 0.65rem;
    }

    .demo-nav-demo {
        font-size: 0.85rem;
    }
}

/* ==========================================================================
   Tablet Styles (768px - 991px)
   ========================================================================== */

@media (min-width: 768px) and (max-width: 991px) {
    .demo-navigation {
        width: 100%;
    }

    /* Slightly more generous spacing on tablets */
    .demo-nav-topic {
        margin-left: 0.75rem;
    }

    .demo-nav-concept {
        margin-left: 1.5rem;
    }

    .demo-nav-demo {
        margin-left: 2.25rem;
    }
}

/* ==========================================================================
   Reduced Motion Support
   ========================================================================== */

@media (prefers-reduced-motion: reduce) {
    .demo-nav-submenu,
    .demo-nav-toggle svg,
    .demo-nav-mobile-toggle .icon-chevron {
        animation: none !important;
        transition: none !important;
    }
}

/* ==========================================================================
   Dark Mode Overrides
   ========================================================================== */

[data-theme="dark"] .demo-nav-menu {
    background: var(--bg-elevated);
    border-color: var(--border-color);
}

/* Keep navigation buttons with same colors in dark mode for consistency */
/* Level 1 (Areas) - Already dark gray, keep as is */
/* Level 2 (Topics) - Keep UCB gold with black text */
/* Level 3 (Concepts) - Adjust light gray to medium gray for dark mode */
[data-theme="dark"] .demo-nav-concept {
    background: var(--gray-600);
    color: var(--ucb-white);
}

[data-theme="dark"] .demo-nav-concept:hover,
[data-theme="dark"] .demo-nav-concept:focus-visible {
    background: var(--gray-500);
    color: var(--ucb-white);
}

[data-theme="dark"] .demo-nav-concept:visited {
    background-color: var(--gray-600) !important;
    color: var(--ucb-white) !important;
}

[data-theme="dark"] .demo-nav-concept:visited:hover,
[data-theme="dark"] .demo-nav-concept:visited:focus-visible {
    background-color: var(--gray-500) !important;
    color: var(--ucb-white) !important;
}

/* Level 4 (Demos) - Keep blue, already good contrast */

/* Adjust Level 3 toggle buttons for dark mode */
[data-theme="dark"] .demo-nav-level-3 .demo-nav-toggle {
    background: var(--gray-600);
    color: var(--ucb-white);
}

[data-theme="dark"] .demo-nav-level-3 .demo-nav-toggle:hover {
    background: var(--gray-500);
}

/* ==========================================================================
   Info Box Section (Global Utility)
   ========================================================================== */

.demo-nav-info-box {
    margin-top: 1.25rem;
    padding: 1rem;
    background-color: var(--info-box-bg);
    border: 1px solid var(--info-box-border);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-sm);
    /* Fix sub-pixel rendering artifacts at rounded corners */
    transform: translateZ(0);
    backface-visibility: hidden;
}

.demo-nav-info-box h3 {
    margin: 0 0 0.5rem 0;
    font-weight: 500;
    font-size: var(--font-size-base);
}

.demo-nav-info-box p {
    margin: 0;
    font-size: var(--font-size-sm);
    color: var(--info-box-text);
    line-height: 1.5;
}

.demo-nav-info-box a {
    color: var(--ucb-gold);
    font-weight: 500;
    text-decoration: none;
}

.demo-nav-info-box a:hover,
.demo-nav-info-box a:focus-visible {
    text-decoration: underline;
}

.demo-nav-info-box a:focus-visible {
    outline: 3px solid var(--ucb-gold);
    outline-offset: 2px;
    border-radius: 2px;
}

/* Dark mode support for info box */
[data-theme="dark"] .demo-nav-info-box {
    background-color: var(--bg-elevated);
    border-color: var(--border-color);
}

[data-theme="dark"] .demo-nav-info-box p,
[data-theme="dark"] .demo-nav-info-box h3 {
    color: var(--text-primary);
}

[data-theme="dark"] .demo-nav-info-box a {
    color: var(--ucb-gold);
}

[data-theme="dark"] .demo-nav-info-box a:visited {
    color: var(--ucb-gold-dark);
}

/* ==========================================================================
   Print Styles
   ========================================================================== */

@media print {
    .demo-nav-mobile-toggle,
    .demo-nav-collapse-all {
        display: none;
    }

    .demo-nav-submenu[hidden] {
        display: block !important;
    }

    .demo-nav-toggle {
        display: none;
    }
}
