/* 中华养生主题 - 前端样式 - 版本 2.5.0 - 修复Astra主题冲突 */

/* 强制重置Astra主题样式 */
body.chinese-wellness-theme {
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
    overflow-x: hidden !important;
    background: white !important;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif !important;
    line-height: 1.6 !important;
    color: #1a202c !important;
}

/* 重置Astra主题的容器样式 */
body.chinese-wellness-theme #page,
body.chinese-wellness-theme #content,
body.chinese-wellness-theme .site,
body.chinese-wellness-theme .site-content,
body.chinese-wellness-theme .ast-container,
body.chinese-wellness-theme .ast-plain-container,
body.chinese-wellness-theme .entry-content {
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
    max-width: none !important;
    background: transparent !important;
    box-shadow: none !important;
    border: none !important;
}

/* 隐藏Astra主题的默认头部和导航 */
body.chinese-wellness-theme #masthead,
body.chinese-wellness-theme .main-header-bar,
body.chinese-wellness-theme .ast-main-header-wrap,
body.chinese-wellness-theme .site-header {
    display: none !important;
}

/* 确保我们的容器样式优先 */
.container, .hero-container, .nav-container {
    margin: 0 auto !important;
    padding-left: 20px !important;
    padding-right: 20px !important;
    width: 100% !important;
    max-width: 1200px !important;
}

/* 确保hero section占满宽度 */
.hero {
    margin: 0 !important;
    padding: 4rem 0 !important;
    width: 100% !important;
    max-width: none !important;
}

/* 确保section占满宽度 */
section {
    margin: 0 !important;
    width: 100% !important;
    max-width: none !important;
}

/* 最高优先级：确保选中菜单项始终保持橙色 - 覆盖所有可能的样式冲突 */
html body .main-header-menu .menu-item.current-menu-item > a,
html body .main-header-menu .menu-item.current_page_item > a,
html body .main-header-menu .menu-item.current-menu-ancestor > a,
html body .main-header-menu .menu-item.current_page_ancestor > a,
html body .main-header-menu .menu-item.current-menu-parent > a,
html body .main-header-menu .menu-item.current_page_parent > a,
html body .ast-header-menu .menu-item.current-menu-item > a,
html body .ast-header-menu .menu-item.current_page_item > a,
html body .ast-header-menu .menu-item.current-menu-ancestor > a,
html body .ast-header-menu .menu-item.current_page_ancestor > a,
html body .ast-header-menu .menu-item.current-menu-parent > a,
html body .ast-header-menu .menu-item.current_page_parent > a,
html body .nav-link.active,
html body a.nav-link.active,
html body .navbar .nav-menu li a.active,
html body .nav-menu li a.active {
    color: #E76F51 !important;
    font-weight: 700 !important;
    background: rgba(231, 111, 81, 0.15) !important;
    border-radius: 8px !important;
    box-shadow: 0 2px 8px rgba(231, 111, 81, 0.2) !important;
    padding: 0.5rem 1rem !important;
    transform: translateY(-1px) !important;
    text-decoration: none !important;
}

/* 确保悬停时选中状态不被覆盖 */
html body .main-header-menu .menu-item.current-menu-item > a:hover,
html body .main-header-menu .menu-item.current_page_item > a:hover,
html body .main-header-menu .menu-item.current-menu-ancestor > a:hover,
html body .main-header-menu .menu-item.current_page_ancestor > a:hover,
html body .main-header-menu .menu-item.current-menu-parent > a:hover,
html body .main-header-menu .menu-item.current_page_parent > a:hover,
html body .ast-header-menu .menu-item.current-menu-item > a:hover,
html body .ast-header-menu .menu-item.current_page_item > a:hover,
html body .ast-header-menu .menu-item.current-menu-ancestor > a:hover,
html body .ast-header-menu .menu-item.current_page_ancestor > a:hover,
html body .ast-header-menu .menu-item.current-menu-parent > a:hover,
html body .ast-header-menu .menu-item.current_page_parent > a:hover,
html body .nav-link.active:hover,
html body a.nav-link.active:hover,
html body .navbar .nav-menu li a.active:hover,
html body .nav-menu li a.active:hover {
    color: #E76F51 !important;
    font-weight: 700 !important;
    background: rgba(231, 111, 81, 0.25) !important;
    border-radius: 8px !important;
    box-shadow: 0 4px 12px rgba(231, 111, 81, 0.3) !important;
    padding: 0.5rem 1rem !important;
    transform: translateY(-1px) !important;
    text-decoration: none !important;
}

/* 确保导航栏在所有页面都显示为白色背景 */
.header {
    background: rgba(255, 255, 255, 0.95) !important;
    backdrop-filter: blur(10px) !important;
    position: sticky !important;
    top: 0 !important;
    z-index: 1000 !important;
    border-bottom: 1px solid rgba(231, 111, 81, 0.1) !important;
    box-shadow: 0 2px 20px rgba(231, 111, 81, 0.1) !important;
}

.navbar {
    padding: 1rem 0 !important;
}

.navbar .container {
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 0 20px !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
}

.navbar .logo {
    font-size: 1.5rem !important;
    font-weight: 700 !important;
    color: #E76F51 !important;
    text-decoration: none !important;
    transition: all 0.3s !important;
}

.navbar .logo:hover {
    color: #D65A3C !important;
}

/* 确保logo不受active样式影响 */
.navbar .logo,
.navbar a.logo,
a.logo {
    background: none !important;
    border-radius: 0 !important;
    padding: 0 !important;
    box-shadow: none !important;
    transform: none !important;
}

.nav-menu {
    display: flex !important;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    gap: 2rem !important;
}

.nav-menu li a {
    color: #2C3E50 !important;
    text-decoration: none !important;
    font-weight: 500 !important;
    transition: all 0.3s !important;
    padding: 0.5rem 1rem !important;
    position: relative !important;
    border-radius: 6px !important;
}

.nav-menu li a:hover {
    color: #E76F51 !important;
}

/* 确保选中状态的菜单项持续保持橙色 - 最高优先级 */
.nav-menu li a.active,
.nav-menu li a.active:hover,
.nav-menu li a.active:focus,
.nav-menu li a.active:visited {
    color: #E76F51 !important;
    font-weight: 700 !important;
    background: rgba(231, 111, 81, 0.15) !important;
    border-radius: 8px !important;
    box-shadow: 0 2px 8px rgba(231, 111, 81, 0.2) !important;
}

/* 悬停状态的下划线 */
.nav-menu li a:hover::after {
    content: '' !important;
    position: absolute !important;
    bottom: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 2px !important;
    background: #E76F51 !important;
    transition: all 0.3s ease !important;
}

/* 选中状态的下划线 - 更明显 */
.nav-menu li a.active::after {
    content: '' !important;
    position: absolute !important;
    bottom: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 3px !important;
    background: linear-gradient(90deg, #E76F51, #F4A261) !important;
    border-radius: 2px !important;
}

/* 强制确保active状态的最高优先级 - 覆盖所有可能的样式 */
.navbar .nav-menu li a.active,
.nav-menu li a.active,
a.nav-link.active,
.nav-link.active,
.main-header-menu .menu-item.current-menu-item > a,
.main-header-menu .menu-item.current_page_item > a,
.main-header-menu .menu-item.current-menu-ancestor > a,
.main-header-menu .menu-item.current_page_ancestor > a,
.main-header-menu .menu-item.current-menu-parent > a,
.main-header-menu .menu-item.current_page_parent > a,
.ast-header-menu .menu-item.current-menu-item > a,
.ast-header-menu .menu-item.current_page_item > a,
.ast-header-menu .menu-item.current-menu-ancestor > a,
.ast-header-menu .menu-item.current_page_ancestor > a,
.ast-header-menu .menu-item.current-menu-parent > a,
.ast-header-menu .menu-item.current_page_parent > a,
ul.main-header-menu .menu-item.current-menu-item > a,
ul.main-header-menu .menu-item.current_page_item > a,
ul.main-header-menu .menu-item.current-menu-ancestor > a,
ul.main-header-menu .menu-item.current_page_ancestor > a,
ul.main-header-menu .menu-item.current-menu-parent > a,
ul.main-header-menu .menu-item.current_page_parent > a {
    color: #E76F51 !important;
    font-weight: 700 !important;
    background: rgba(231, 111, 81, 0.15) !important;
    border-radius: 8px !important;
    box-shadow: 0 2px 8px rgba(231, 111, 81, 0.2) !important;
    padding: 0.5rem 1rem !important;
    transform: translateY(-1px) !important;
}

/* 确保悬停时active状态不被覆盖 */
.navbar .nav-menu li a.active:hover,
.nav-menu li a.active:hover,
a.nav-link.active:hover,
.nav-link.active:hover,
.main-header-menu .menu-item.current-menu-item > a:hover,
.main-header-menu .menu-item.current_page_item > a:hover,
.main-header-menu .menu-item.current-menu-ancestor > a:hover,
.main-header-menu .menu-item.current_page_ancestor > a:hover,
.main-header-menu .menu-item.current-menu-parent > a:hover,
.main-header-menu .menu-item.current_page_parent > a:hover,
.ast-header-menu .menu-item.current-menu-item > a:hover,
.ast-header-menu .menu-item.current_page_item > a:hover,
.ast-header-menu .menu-item.current-menu-ancestor > a:hover,
.ast-header-menu .menu-item.current_page_ancestor > a:hover,
.ast-header-menu .menu-item.current-menu-parent > a:hover,
.ast-header-menu .menu-item.current_page_parent > a:hover,
ul.main-header-menu .menu-item.current-menu-item > a:hover,
ul.main-header-menu .menu-item.current_page_item > a:hover,
ul.main-header-menu .menu-item.current-menu-ancestor > a:hover,
ul.main-header-menu .menu-item.current_page_ancestor > a:hover,
ul.main-header-menu .menu-item.current-menu-parent > a:hover,
ul.main-header-menu .menu-item.current_page_parent > a:hover {
    color: #E76F51 !important;
    font-weight: 700 !important;
    background: rgba(231, 111, 81, 0.25) !important;
    border-radius: 8px !important;
    box-shadow: 0 4px 12px rgba(231, 111, 81, 0.3) !important;
    padding: 0.5rem 1rem !important;
    transform: translateY(-1px) !important;
}

/* 确保active状态在所有伪类下都保持 */
.navbar .nav-menu li a.active:link,
.navbar .nav-menu li a.active:visited,
.navbar .nav-menu li a.active:hover,
.navbar .nav-menu li a.active:active,
.navbar .nav-menu li a.active:focus {
    color: #E76F51 !important;
    font-weight: 700 !important;
    background: rgba(231, 111, 81, 0.15) !important;
}

/* 覆盖Astra主题的默认样式 - 确保当前页面菜单项保持橙色 */
body .main-header-menu .menu-item.current-menu-item > a,
body .main-header-menu .menu-item.current_page_item > a,
body .main-header-menu .menu-item.current-menu-ancestor > a,
body .main-header-menu .menu-item.current_page_ancestor > a,
body .main-header-menu .menu-item.current-menu-parent > a,
body .main-header-menu .menu-item.current_page_parent > a,
body .ast-header-menu .menu-item.current-menu-item > a,
body .ast-header-menu .menu-item.current_page_item > a,
body .ast-header-menu .menu-item.current-menu-ancestor > a,
body .ast-header-menu .menu-item.current_page_ancestor > a,
body .ast-header-menu .menu-item.current-menu-parent > a,
body .ast-header-menu .menu-item.current_page_parent > a,
body .nav-link.active,
body a.nav-link.active {
    color: #E76F51 !important;
    font-weight: 700 !important;
    background: rgba(231, 111, 81, 0.15) !important;
    border-radius: 8px !important;
    box-shadow: 0 2px 8px rgba(231, 111, 81, 0.2) !important;
    padding: 0.5rem 1rem !important;
    transform: translateY(-1px) !important;
}

/* 确保悬停时当前页面菜单项仍保持橙色 */
body .main-header-menu .menu-item.current-menu-item > a:hover,
body .main-header-menu .menu-item.current_page_item > a:hover,
body .main-header-menu .menu-item.current-menu-ancestor > a:hover,
body .main-header-menu .menu-item.current_page_ancestor > a:hover,
body .main-header-menu .menu-item.current-menu-parent > a:hover,
body .main-header-menu .menu-item.current_page_parent > a:hover,
body .ast-header-menu .menu-item.current-menu-item > a:hover,
body .ast-header-menu .menu-item.current_page_item > a:hover,
body .ast-header-menu .menu-item.current-menu-ancestor > a:hover,
body .ast-header-menu .menu-item.current_page_ancestor > a:hover,
body .ast-header-menu .menu-item.current-menu-parent > a:hover,
body .ast-header-menu .menu-item.current_page_parent > a:hover,
body .nav-link.active:hover,
body a.nav-link.active:hover {
    color: #E76F51 !important;
    font-weight: 700 !important;
    background: rgba(231, 111, 81, 0.25) !important;
    border-radius: 8px !important;
    box-shadow: 0 4px 12px rgba(231, 111, 81, 0.3) !important;
    padding: 0.5rem 1rem !important;
    transform: translateY(-1px) !important;
}

/* 确保桌面端导航操作区域始终显示 */
.nav-actions {
    display: flex !important;
    align-items: center !important;
    gap: 1rem !important;
}

/* 桌面端强制显示用户菜单 */
@media (min-width: 769px) {
    .nav-actions {
        display: flex !important;
        align-items: center !important;
        gap: 1rem !important;
    }
}

.language-switcher {
    background: transparent !important;
    border: 1px solid #E76F51 !important;
    color: #E76F51 !important;
    padding: 0.5rem 1rem !important;
    border-radius: 20px !important;
    font-size: 0.9rem !important;
    cursor: pointer !important;
    transition: all 0.3s !important;
    text-decoration: none !important;
}

.language-switcher:hover {
    background: #E76F51 !important;
    color: white !important;
}

.login-btn {
    background: #E76F51 !important;
    color: white !important;
    padding: 0.5rem 1.5rem !important;
    border: none !important;
    border-radius: 20px !important;
    font-weight: 500 !important;
    cursor: pointer !important;
    transition: all 0.3s !important;
    text-decoration: none !important;
}

.login-btn:hover {
    background: #D65A3C !important;
    color: white !important;
}

/* 移动端菜单按钮 */
.mobile-menu-toggle {
    display: none;
    background: none !important;
    border: none !important;
    font-size: 1.5rem !important;
    cursor: pointer !important;
    color: #E76F51 !important;
    padding: 0.5rem !important;
    border-radius: 4px !important;
    transition: all 0.3s ease !important;
}

.mobile-menu-toggle:hover {
    background: rgba(231, 111, 81, 0.1) !important;
}

/* 桌面端隐藏移动端用户菜单 */
.mobile-user-menu {
    display: none !important;
}

/* 移动端响应式 - 增强优先级 */
@media (max-width: 768px) {
    .navbar .container {
        padding: 0 15px !important;
    }

    /* 强制覆盖所有可能的菜单样式 */
    .navbar .nav-menu,
    .main-header-bar .nav-menu,
    .site-header .nav-menu,
    .nav-menu {
        position: fixed !important;
        top: 0 !important;
        left: -100% !important;
        width: 100vw !important;
        height: 100vh !important;
        background: white !important;
        flex-direction: column !important;
        padding: 80px 2rem 2rem 2rem !important;
        transition: left 0.3s ease !important;
        z-index: 99999 !important;
        box-shadow: 0 0 50px rgba(0, 0, 0, 0.3) !important;
        overflow-y: auto !important;
        margin: 0 !important;
        list-style: none !important;
        display: flex !important; /* 始终为flex，通过left位置控制显示 */
        transform: none !important; /* 防止其他变换影响 */
        right: auto !important; /* 确保不被right属性影响 */
    }

    .navbar .nav-menu.active,
    .main-header-bar .nav-menu.active,
    .site-header .nav-menu.active,
    .nav-menu.active {
        left: 0 !important;
        transform: none !important;
    }

    .nav-menu li {
        width: 100% !important;
        margin: 0 0 0.5rem 0 !important;
    }

    .nav-menu li a {
        padding: 1rem !important;
        border-bottom: 1px solid rgba(231, 111, 81, 0.1) !important;
        width: 100% !important;
        display: block !important;
        text-align: left !important;
        color: #666 !important;
        font-weight: 500 !important;
        border-radius: 8px !important;
        margin-bottom: 0.5rem !important;
    }

    .nav-menu li:last-child a {
        border-bottom: none !important;
    }

    /* 移动端用户菜单显示 */
    .nav-menu .mobile-user-menu {
        display: block !important;
        margin-top: 1rem !important;
        padding-top: 1rem !important;
        border-top: 2px solid #f0f0f0 !important;
        width: 100% !important;
    }

    .nav-menu .mobile-user-menu li {
        width: 100% !important;
        margin: 0 0 0.5rem 0 !important;
    }

    .nav-menu .mobile-user-menu a {
        color: #666 !important;
        font-weight: 500 !important;
        padding: 0.8rem 1rem !important;
    }

    .nav-menu .mobile-user-menu .mobile-logout {
        color: #E74C3C !important;
    }

    .mobile-menu-toggle {
        display: block !important;
    }

    /* 移动端菜单重置 - 确保不受其他样式影响 */
    .navbar .nav-menu *,
    .main-header-bar .nav-menu *,
    .site-header .nav-menu *,
    .nav-menu * {
        box-sizing: border-box !important;
    }

    /* 移动端关闭按钮 */
    .mobile-menu-close {
        display: block !important;
        position: absolute !important;
        top: 20px !important;
        right: 20px !important;
        font-size: 1.5rem !important;
        color: #E76F51 !important;
        cursor: pointer !important;
        z-index: 100000 !important;
        padding: 0.5rem !important;
        border-radius: 50% !important;
        background: rgba(231, 111, 81, 0.1) !important;
        width: 40px !important;
        height: 40px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        transition: all 0.3s ease !important;
        border: none !important;
        outline: none !important;
    }

    .mobile-menu-close:hover {
        background: rgba(231, 111, 81, 0.2) !important;
        transform: scale(1.1) !important;
    }

    .nav-actions {
        display: none !important;
    }

    .nav-actions.mobile-visible {
        display: flex !important;
        gap: 0.5rem !important;
    }

    .nav-actions .btn {
        font-size: 0.9rem !important;
        padding: 0.5rem 1rem !important;
    }
}

/* 平板横屏适配 */
@media (max-width: 1024px) and (min-width: 769px) {
    .navbar .container {
        padding: 0 20px !important;
    }

    .nav-menu {
        gap: 1.5rem !important;
    }

    .nav-menu li a {
        padding: 0.4rem 0.8rem !important;
        font-size: 0.95rem !important;
    }
}

/* 大屏手机适配 */
@media (max-width: 480px) {
    .navbar .container {
        padding: 0 10px !important;
    }

    .mobile-menu-toggle {
        font-size: 1.3rem !important;
        padding: 0.4rem !important;
    }

    .nav-menu {
        top: 60px !important;
        height: calc(100vh - 60px) !important;
        padding: 1.5rem 1rem !important;
    }

    .nav-menu li a {
        padding: 0.8rem !important;
        font-size: 1rem !important;
    }

    .nav-actions {
        margin-top: 1.5rem !important;
    }

    .language-switcher,
    .login-btn {
        padding: 0.7rem 1.2rem !important;
        font-size: 0.9rem !important;
    }
}

/* 小屏手机适配 */
@media (max-width: 360px) {
    .navbar .container {
        padding: 0 8px !important;
    }

    .nav-menu {
        padding: 1rem 0.8rem !important;
    }

    .nav-menu li a {
        padding: 0.7rem !important;
        font-size: 0.95rem !important;
    }
}

/* 课程页面响应式样式 */
.courses-grid {
    display: grid !important;
    gap: 2rem !important;
}

/* 桌面端 - 3列布局 */
@media (min-width: 1200px) {
    .courses-grid {
        grid-template-columns: repeat(3, 1fr) !important;
    }
}

/* 平板端 - 2列布局 */
@media (min-width: 768px) and (max-width: 1199px) {
    .courses-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }

    .courses-hero-title {
        font-size: 2.8rem !important;
    }

    .courses-hero-subtitle {
        font-size: 1.2rem !important;
    }
}

/* 移动端 - 1列布局 */
@media (max-width: 767px) {
    .courses-grid {
        grid-template-columns: 1fr !important;
        gap: 1.5rem !important;
    }

    .courses-hero {
        padding: 2.5rem 0 !important;
    }

    .courses-hero-title {
        font-size: 2.2rem !important;
        margin-bottom: 1rem !important;
    }

    .courses-hero-subtitle {
        font-size: 1.1rem !important;
        padding: 0 1rem !important;
    }

    .courses-filter {
        padding: 2rem 0 !important;
    }

    .filter-buttons {
        gap: 0.8rem !important;
    }

    .filter-btn {
        padding: 0.7rem 1.2rem !important;
        font-size: 0.85rem !important;
        min-width: 120px !important;
    }

    .courses-grid-section {
        padding: 3rem 0 !important;
    }

    .course-card {
        margin-bottom: 1rem !important;
    }

    .course-image {
        height: 180px !important;
        font-size: 2.5rem !important;
    }

    .course-content {
        padding: 1.2rem !important;
    }

    .course-meta {
        flex-direction: column !important;
        gap: 0.5rem !important;
        align-items: flex-start !important;
    }

    .course-stats {
        gap: 0.8rem !important;
        flex-wrap: wrap !important;
    }
}

/* 大屏手机适配 */
@media (max-width: 480px) {
    .courses-hero {
        padding: 2rem 0 !important;
    }

    .courses-hero-title {
        font-size: 1.8rem !important;
    }

    .courses-hero-subtitle {
        font-size: 1rem !important;
    }

    .filter-buttons {
        gap: 0.5rem !important;
    }

    .filter-btn {
        padding: 0.6rem 1rem !important;
        font-size: 0.8rem !important;
        min-width: 100px !important;
    }

    .course-image {
        height: 160px !important;
        font-size: 2rem !important;
    }

    .course-content {
        padding: 1rem !important;
    }

    .course-stats {
        font-size: 0.75rem !important;
    }

    .course-btn {
        padding: 0.7rem 1.5rem !important;
        font-size: 0.85rem !important;
    }
}

/* 小屏手机适配 */
@media (max-width: 360px) {
    .courses-hero-title {
        font-size: 1.5rem !important;
    }

    .courses-hero-subtitle {
        font-size: 0.9rem !important;
    }

    .filter-btn {
        padding: 0.5rem 0.8rem !important;
        font-size: 0.75rem !important;
        min-width: 90px !important;
    }

    .course-image {
        height: 140px !important;
    }

    .course-content {
        padding: 0.8rem !important;
    }
}

/* 确保在首页Hero section上方的导航栏也是白色 */
body.home .header,
body.page-template-home .header {
    background: rgba(255, 255, 255, 0.95) !important;
}

/* 超级强制的active状态 - 覆盖所有可能的样式，包括内联样式 */
.nav-link.active,
a.nav-link.active,
.nav-menu .nav-link.active,
.nav-menu a.nav-link.active,
.navbar .nav-menu .nav-link.active,
.navbar .nav-menu a.nav-link.active,
.navbar .nav-menu li a.nav-link.active {
    color: #E76F51 !important;
    font-weight: 700 !important;
    background: rgba(231, 111, 81, 0.15) !important;
    border-radius: 8px !important;
    box-shadow: 0 2px 8px rgba(231, 111, 81, 0.2) !important;
    padding: 0.5rem 1rem !important;
    transform: translateY(-1px) !important;
    text-decoration: none !important;
}

/* 特别针对首页菜单的强制样式 */
a[href*="/home/"].nav-link.active,
a[href*="/home"].nav-link.active {
    color: #E76F51 !important;
    font-weight: 700 !important;
    background: rgba(231, 111, 81, 0.15) !important;
    border-radius: 8px !important;
    box-shadow: 0 2px 8px rgba(231, 111, 81, 0.2) !important;
    padding: 0.5rem 1rem !important;
    transform: translateY(-1px) !important;
    text-decoration: none !important;
}
