/* NoovHub Modern Header v2.0 */
:root {
    --noovhub-header-bg: #ffffff;
    --noovhub-header-text: #1a1a2e;
    --noovhub-header-accent: #dd083b;
    --noovhub-header-accent-hover: #b8062f;
    --noovhub-header-border: #e5e7eb;
    --noovhub-header-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px -1px rgba(0, 0, 0, 0.1);
    --noovhub-header-height: 70px;
    --noovhub-transition: 0.2s ease;
}

/* Masquer le header Woffice natif pour éviter le double affichage */
#main-header,
.celst-top-bar,
body #main-header.celst-top-bar {
    display: none !important;
}

/* ==========================================================================
   Sidebar Menu - Système pliable/dépliable
   ========================================================================== */

:root {
    --sidebar-width-expanded: 260px;
    --sidebar-width-collapsed: 72px;
    --sidebar-transition: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Sidebar par défaut (dépliée) */
body.vertical-modern-menu .celst-left-sidebar {
    width: var(--sidebar-width-expanded) !important;
    min-width: var(--sidebar-width-expanded) !important;
    transition: width var(--sidebar-transition), min-width var(--sidebar-transition) !important;
    overflow-x: hidden;
    overflow-y: auto;
    background: #ffffff;
    margin: 15px;
    margin-top: calc(var(--noovhub-header-height) + 15px);
    border-radius: 20px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.08);
    height: calc(100vh - var(--noovhub-header-height) - 30px) !important;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 999;
}

/* Admin bar adjustment pour sidebar */
.admin-bar.vertical-modern-menu .celst-left-sidebar {
    margin-top: calc(var(--noovhub-header-height) + 32px + 15px);
    height: calc(100vh - var(--noovhub-header-height) - 32px - 30px) !important;
}

body.vertical-modern-menu .celst-main-content {
    margin-left: calc(var(--sidebar-width-expanded) + 30px) !important;
    transition: margin-left var(--sidebar-transition) !important;
}

body.vertical-modern-menu .celst-left-sidebar .nav-brand-logo {
    display: none !important;
}

/* Bouton Toggle Sidebar */
.sidebar-toggle-btn {
    position: fixed;
    bottom: 35px;
    left: calc(var(--sidebar-width-expanded) + 15px - 18px);
    width: 32px;
    height: 32px;
    background: linear-gradient(135deg, #dd083b 0%, #b8062f 100%);
    border: 2px solid #fff;
    border-radius: 50%;
    cursor: pointer;
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 15px rgba(221, 8, 59, 0.4);
    transition: all var(--sidebar-transition);
}

.admin-bar .sidebar-toggle-btn {
    bottom: 35px;
}

.sidebar-toggle-btn:hover {
    transform: scale(1.1);
    box-shadow: 0 6px 20px rgba(221, 8, 59, 0.5);
}

.sidebar-toggle-btn svg {
    width: 18px;
    height: 18px;
    fill: #fff;
    transition: transform var(--sidebar-transition);
}

/* Menu items styling */
body.vertical-modern-menu .celst-left-sidebar .celst-nav ul#main-modern-menu {
    padding: 10px 12px;
}

body.vertical-modern-menu .celst-left-sidebar .celst-nav ul#main-modern-menu > li.menu-item {
    margin-bottom: 4px;
}

body.vertical-modern-menu .celst-left-sidebar .celst-nav ul#main-modern-menu > li.menu-item > a {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    border-radius: 12px;
    transition: all 0.2s ease;
    white-space: nowrap;
    overflow: hidden;
}

body.vertical-modern-menu .celst-left-sidebar .celst-nav ul#main-modern-menu > li.menu-item > a i,
body.vertical-modern-menu .celst-left-sidebar .celst-nav ul#main-modern-menu > li.menu-item > a .menu-icon-wrapper {
    flex-shrink: 0;
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
}

body.vertical-modern-menu .celst-left-sidebar .celst-nav ul#main-modern-menu > li.menu-item > a .celst-menu-title {
    flex: 1;
    opacity: 1;
    transition: opacity 0.2s ease, transform 0.2s ease;
    transform: translateX(0);
}

.noovmail-menu-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    margin-right: 6px;
}

/* ==========================================================================
   Sidebar PLIÉE (collapsed)
   ========================================================================== */

body.vertical-modern-menu.sidebar-collapsed .celst-left-sidebar {
    width: var(--sidebar-width-collapsed) !important;
    min-width: var(--sidebar-width-collapsed) !important;
}

body.vertical-modern-menu.sidebar-collapsed .celst-main-content {
    margin-left: calc(var(--sidebar-width-collapsed) + 30px) !important;
}

/* Bouton toggle en mode plié */
body.vertical-modern-menu.sidebar-collapsed .sidebar-toggle-btn {
    left: calc(var(--sidebar-width-collapsed) + 15px - 18px);
}

body.vertical-modern-menu.sidebar-collapsed .sidebar-toggle-btn svg {
    transform: rotate(180deg);
}

/* Menu items en mode plié */
body.vertical-modern-menu.sidebar-collapsed .celst-left-sidebar .celst-nav ul#main-modern-menu {
    padding: 10px 8px;
}

body.vertical-modern-menu.sidebar-collapsed .celst-left-sidebar .celst-nav ul#main-modern-menu > li.menu-item > a {
    justify-content: center;
    padding: 12px;
}

body.vertical-modern-menu.sidebar-collapsed .celst-left-sidebar .celst-nav ul#main-modern-menu > li.menu-item > a .celst-menu-title {
    opacity: 0;
    width: 0;
    overflow: hidden;
    transform: translateX(-10px);
}

/* Masquer les flèches des sous-menus en mode plié */
body.vertical-modern-menu.sidebar-collapsed .celst-left-sidebar .celst-nav ul#main-modern-menu > li.menu-item > a .menu-icon.fa-angle-down {
    display: none;
}

/* Tooltip au survol en mode plié */
body.vertical-modern-menu.sidebar-collapsed .celst-left-sidebar .celst-nav ul#main-modern-menu > li.menu-item {
    position: relative;
}

body.vertical-modern-menu.sidebar-collapsed .celst-left-sidebar .celst-nav ul#main-modern-menu > li.menu-item::after {
    content: attr(data-title);
    position: absolute;
    left: calc(100% + 10px);
    top: 50%;
    transform: translateY(-50%);
    background: #1a1a2e;
    color: #fff;
    padding: 8px 14px;
    border-radius: 8px;
    font-size: 13px;
    font-weight: 500;
    white-space: nowrap;
    opacity: 0;
    visibility: hidden;
    transition: all 0.2s ease;
    z-index: 10002;
    pointer-events: none;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
}

body.vertical-modern-menu.sidebar-collapsed .celst-left-sidebar .celst-nav ul#main-modern-menu > li.menu-item:hover::after {
    opacity: 1;
    visibility: visible;
}

/* Sous-menus en mode plié - affichage en popup */
body.vertical-modern-menu.sidebar-collapsed .celst-left-sidebar .celst-nav ul#main-modern-menu > li.menu-item > .sub-menu {
    position: absolute;
    left: 100%;
    top: 0;
    min-width: 200px;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
    padding: 8px;
    opacity: 0;
    visibility: hidden;
    transform: translateX(10px);
    transition: all 0.2s ease;
    z-index: 10003;
}

body.vertical-modern-menu.sidebar-collapsed .celst-left-sidebar .celst-nav ul#main-modern-menu > li.menu-item:hover > .sub-menu {
    opacity: 1;
    visibility: visible;
    transform: translateX(0);
}

/* ==========================================================================
   Responsive - Tablette et Mobile
   ========================================================================== */

@media (max-width: 1200px) {
    :root {
        --sidebar-width-expanded: 240px;
    }
}

@media (max-width: 1024px) {
    /* Sur tablette/mobile, la sidebar devient un drawer */
    body.vertical-modern-menu .celst-left-sidebar {
        position: fixed !important;
        top: calc(var(--noovhub-header-height) + 10px);
        left: 10px;
        bottom: 10px;
        height: auto !important;
        width: 280px !important;
        min-width: 280px !important;
        z-index: 9999;
        transform: translateX(calc(-100% - 20px));
        transition: transform 0.3s ease;
        background: #ffffff;
        margin: 0;
        border-radius: 20px;
        box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
    }

    body.vertical-modern-menu .celst-main-content {
        margin-left: 0 !important;
    }

    /* Sidebar ouverte sur mobile */
    body.vertical-modern-menu.noovhub-sidebar-open .celst-left-sidebar {
        transform: translateX(0);
    }

    /* Masquer le bouton toggle sur mobile (on utilise le hamburger du header) */
    .sidebar-toggle-btn {
        display: none;
    }

    /* Afficher le texte du menu sur mobile quand ouvert */
    body.vertical-modern-menu .celst-left-sidebar .celst-nav ul#main-modern-menu > li.menu-item > a .celst-menu-title {
        display: inline-flex !important;
        opacity: 1 !important;
        width: auto !important;
        transform: translateX(0) !important;
    }

    /* Admin bar adjustment */
    .admin-bar body.vertical-modern-menu .celst-left-sidebar,
    body.admin-bar.vertical-modern-menu .celst-left-sidebar {
        top: calc(var(--noovhub-header-height) + 32px + 10px);
    }
}

@media (max-width: 782px) {
    .admin-bar body.vertical-modern-menu .celst-left-sidebar,
    body.admin-bar.vertical-modern-menu .celst-left-sidebar {
        top: calc(var(--noovhub-header-height) + 46px + 10px);
    }
}

@media (max-width: 640px) {
    body.vertical-modern-menu .celst-left-sidebar {
        width: calc(100% - 20px) !important;
        min-width: calc(100% - 20px) !important;
        max-width: 300px;
        left: 10px;
        right: 10px;
    }
}

.admin-bar #noovhub-header {
    top: 32px;
}
.admin-bar .noovhub-header__spacer {
    height: calc(var(--noovhub-header-height) + 32px);
}
@media screen and (max-width: 782px) {
    .admin-bar #noovhub-header {
        top: 46px;
    }
    .admin-bar .noovhub-header__spacer {
        height: calc(var(--noovhub-header-height) + 46px);
    }
}

#noovhub-sidebar-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.25);
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.2s ease;
    z-index: 9998;
}

.noovhub-sidebar-open #noovhub-sidebar-backdrop {
    opacity: 1;
    visibility: visible;
}

.noovhub-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 9999;
    background: var(--noovhub-header-bg);
    border-bottom: 1px solid var(--noovhub-header-border);
    box-shadow: var(--noovhub-header-shadow);
    height: var(--noovhub-header-height);
}

.noovhub-header__spacer {
    height: var(--noovhub-header-height);
}

.noovhub-header__container {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 24px;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 32px;
}

/* Logo */
.noovhub-header__logo a {
    display: flex;
    align-items: center;
    text-decoration: none;
}

.noovhub-header__logo img {
    height: 40px;
    width: auto;
    object-fit: contain;
}

.noovhub-header__site-name {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--noovhub-header-text);
    letter-spacing: -0.025em;
}

/* Navigation */
.noovhub-header__nav {
    display: none !important;
}

.noovhub-header__close-menu {
    display: none;
}

.noovhub-header__menu {
    display: flex;
    list-style: none;
    margin: 0;
    padding: 0;
    gap: 8px;
}

.noovhub-header__menu li {
    position: relative;
}

.noovhub-header__menu > li > a {
    display: flex;
    align-items: center;
    padding: 10px 16px;
    color: var(--noovhub-header-text);
    text-decoration: none;
    font-weight: 500;
    font-size: 0.9375rem;
    border-radius: 8px;
    transition: all var(--noovhub-transition);
}

.noovhub-header__menu > li > a:hover,
.noovhub-header__menu > li.current-menu-item > a {
    background: rgba(79, 70, 229, 0.1);
    color: var(--noovhub-header-accent);
}

/* Sous-menus */
.noovhub-header__menu .sub-menu {
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 220px;
    background: var(--noovhub-header-bg);
    border: 1px solid var(--noovhub-header-border);
    border-radius: 12px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.12);
    padding: 8px;
    list-style: none;
    margin: 0;
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px);
    transition: all var(--noovhub-transition);
}

.noovhub-header__menu li:hover > .sub-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.noovhub-header__menu .sub-menu a {
    display: block;
    padding: 10px 14px;
    color: var(--noovhub-header-text);
    text-decoration: none;
    font-size: 0.875rem;
    border-radius: 8px;
    transition: all var(--noovhub-transition);
}

.noovhub-header__menu .sub-menu a:hover {
    background: rgba(79, 70, 229, 0.1);
    color: var(--noovhub-header-accent);
}

/* Actions */
.noovhub-header__actions {
    display: flex;
    align-items: center;
    gap: 8px;
}

/* Centrage du pill actif dans le menu icône-only */
body.vertical-modern-menu.sidebar-collapsed .main-modern-menu > li.menu-item > a.current-menu-highlight,
body.vertical-modern-menu .main-modern-menu.icon-only > li.menu-item > a.current-menu-highlight {
    display: flex !important;
    align-items: center;
    justify-content: center;
    padding: 14px !important;
}

/* Boutons icones */
.noovhub-header__icon-btn,
.noovhub-header__search-toggle,
.noovhub-header__notifications-toggle,
.noovhub-header__cart-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    background: transparent;
    border: none;
    border-radius: 10px;
    color: var(--noovhub-header-text);
    cursor: pointer;
    transition: all var(--noovhub-transition);
    position: relative;
    text-decoration: none;
}

.noovhub-header__icon-btn:hover,
.noovhub-header__search-toggle:hover,
.noovhub-header__notifications-toggle:hover,
.noovhub-header__cart-toggle:hover {
    background: rgba(79, 70, 229, 0.1);
    color: var(--noovhub-header-accent);
}

.noovhub-header__icon-btn:focus-visible,
.noovhub-header__search-toggle:focus-visible,
.noovhub-header__notifications-toggle:focus-visible,
.noovhub-header__cart-toggle:focus-visible,
.noovhub-header__user-toggle:focus-visible,
.noovhub-header__login-btn:focus-visible,
.noovhub-header__mobile-toggle:focus-visible {
    outline: 2px solid var(--noovhub-header-accent);
    outline-offset: 2px;
    box-shadow: 0 0 0 3px rgba(221, 8, 59, 0.2);
}

/* Badge notifications/panier */
.noovhub-header__badge {
    position: absolute;
    top: 4px;
    right: 4px;
    min-width: 18px;
    height: 18px;
    background: #ef4444;
    color: white;
    font-size: 0.6875rem;
    font-weight: 600;
    border-radius: 9px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 5px;
}

/* Recherche */
.noovhub-header__search { display: none !important; }

.noovhub-header__search-form {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    width: 320px;
    background: var(--noovhub-header-bg);
    border: 1px solid var(--noovhub-header-border);
    border-radius: 12px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.12);
    padding: 12px;
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px);
    transition: all var(--noovhub-transition);
}

.noovhub-header__search-form.active {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.noovhub-header__search-form input[type="search"],
.noovhub-header__search-form input[type="text"] {
    width: 100%;
    padding: 12px 16px;
    border: 1px solid var(--noovhub-header-border);
    border-radius: 8px;
    font-size: 0.9375rem;
    outline: none;
    transition: border-color var(--noovhub-transition);
}

.noovhub-header__search-form input:focus {
    border-color: var(--noovhub-header-accent);
}

/* Notifications */
.noovhub-header__notifications {
    position: relative;
}

/* User */
.noovhub-header__user {
    position: relative;
}

.noovhub-header__user-toggle {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 6px 12px 6px 6px;
    background: #f3f4f6;
    border: none;
    border-radius: 50px;
    cursor: pointer;
    transition: all var(--noovhub-transition);
}

.noovhub-header__user-toggle:hover {
    background: #e5e7eb;
}

.noovhub-header__user-toggle img {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    object-fit: cover;
}

.noovhub-header__user-name {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--noovhub-header-text);
    max-width: 120px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.noovhub-header__user-dropdown {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    min-width: 200px;
    background: var(--noovhub-header-bg);
    border: 1px solid var(--noovhub-header-border);
    border-radius: 12px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.12);
    padding: 8px;
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px);
    transition: all var(--noovhub-transition);
}

.noovhub-header__user-dropdown.active {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.noovhub-header__user-dropdown a {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    color: var(--noovhub-header-text);
    text-decoration: none;
    font-size: 0.875rem;
    border-radius: 8px;
    transition: all var(--noovhub-transition);
}

.noovhub-header__user-dropdown a:hover {
    background: rgba(79, 70, 229, 0.1);
    color: var(--noovhub-header-accent);
}

.noovhub-header__divider {
    height: 1px;
    background: var(--noovhub-header-border);
    margin: 8px 0;
}

.noovhub-header__logout {
    color: #ef4444 !important;
}

.noovhub-header__logout:hover {
    background: rgba(239, 68, 68, 0.1) !important;
    color: #dc2626 !important;
}

/* Login button */
.noovhub-header__login-btn {
    display: inline-flex;
    align-items: center;
    padding: 10px 20px;
    background: var(--noovhub-header-accent);
    color: white !important;
    text-decoration: none;
    font-weight: 500;
    font-size: 0.875rem;
    border-radius: 8px;
    transition: all var(--noovhub-transition);
}

.noovhub-header__login-btn:hover {
    background: var(--noovhub-header-accent-hover);
}

/* Mobile toggle */
.noovhub-header__mobile-toggle {
    display: none;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    background: transparent;
    border: none;
    border-radius: 10px;
    color: var(--noovhub-header-text);
    cursor: pointer;
    transition: all var(--noovhub-transition);
}

.noovhub-header__mobile-toggle:hover {
    background: rgba(79, 70, 229, 0.1);
}

/* Responsive */
@media (max-width: 1024px) {
    /* sidebar mobile offcanvas */
    .celst-left-sidebar {
        position: fixed !important;
        top: var(--noovhub-header-height);
        left: 0;
        bottom: 0;
        height: auto;
        width: 220px !important;
        min-width: 220px !important;
        z-index: 9999;
        transform: translateX(-100%);
        transition: transform 0.2s ease;
        visibility: visible !important;
        background: #ffffff;
        display: block !important;
        box-shadow: 0 6px 20px rgba(0, 0, 0, 0.12);
    }
    .admin-bar .celst-left-sidebar {
        top: calc(var(--noovhub-header-height) + 32px);
    }
    @media (max-width: 782px) {
        .admin-bar .celst-left-sidebar {
            top: calc(var(--noovhub-header-height) + 46px);
        }
    }
    .noovhub-sidebar-open .celst-left-sidebar {
        transform: translateX(0);
    }
    body.navigation-hidden .celst-left-sidebar,
    body.navigation-hidden .celst-left-sidebar.celst-collapse-nav {
        left: 0 !important;
        visibility: visible !important;
        transform: translateX(-100%);
    }
    .noovhub-sidebar-open .celst-left-sidebar,
    .noovhub-sidebar-open body.navigation-hidden .celst-left-sidebar,
    .noovhub-sidebar-open body.navigation-hidden .celst-left-sidebar.celst-collapse-nav {
        transform: translateX(0);
    }
    .celst-main-content,
    #main-content,
    .celst-main-content .celst-main-content-container #content-container {
        margin-left: 0 !important;
        padding-left: 0 !important;
        width: 100% !important;
    }
    .noovhub-sidebar-open .celst-main-content,
    .noovhub-sidebar-open #main-content,
    .noovhub-sidebar-open .celst-main-content .celst-main-content-container #content-container {
        margin-left: 0 !important;
        padding-left: 0 !important;
        width: 100% !important;
    }
    .celst-left-sidebar .celst-nav ul#main-modern-menu > li.menu-item > a .celst-menu-title {
        display: inline-flex !important;
    }

    /* bouton mobile pour ouvrir la sidebar */
    .noovhub-header__mobile-toggle {
        display: inline-flex;
    }
    .noovhub-header__user-name {
        display: none;
    }
    /* nav/search du header custom masqués */
    .noovhub-header__nav,
    .noovhub-header__close-menu,
    .noovhub-header__menu,
    .noovhub-header__search,
    .noovhub-header__search-form {
        display: none !important;
    }
}

@media (max-width: 640px) {
    .noovhub-header__container {
        padding: 0 16px;
        flex-wrap: wrap;
        row-gap: 8px;
    }

    .noovhub-header__logo img {
        height: 32px;
    }

    .noovhub-header__site-name {
        font-size: 1.25rem;
    }

    .noovhub-header__actions {
        margin-left: auto;
    }
}

/* Animation du header au scroll */
.noovhub-header.scrolled,
.noovhub-header--scrolled {
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
}

/* Dropdown générique */
.noovhub-header__dropdown {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    min-width: 200px;
    background: var(--noovhub-header-bg);
    border: 1px solid var(--noovhub-header-border);
    border-radius: 12px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.12);
    padding: 8px;
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px);
    transition: all var(--noovhub-transition);
    z-index: 10000;
}

.noovhub-header__dropdown.active {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

/* Dark mode support */
@media (prefers-color-scheme: dark) {
    :root {
        --noovhub-header-bg: #1a1a2e;
        --noovhub-header-text: #f3f4f6;
        --noovhub-header-border: #374151;
    }

    .noovhub-header__user-toggle {
        background: #374151;
    }

    .noovhub-header__user-toggle:hover {
        background: #4b5563;
    }

    .noovhub-header__close-menu {
        background: #374151;
    }

    .noovhub-header__close-menu:hover {
        background: #4b5563;
    }

    .noovhub-header__menu .sub-menu {
        background: #1f2937;
    }

    @media (max-width: 1024px) {
        .noovhub-header__menu .sub-menu {
            background: #111827;
        }
    }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    :root {
        --sidebar-transition: 0s;
        --noovhub-transition: 0s;
    }
    * {
        transition: none !important;
        animation-duration: 0s !important;
    }
}
