/* Zeheng brand unification layer. Layout stays owned by each page design. */
html {
    overflow-y: scroll !important;
    scrollbar-gutter: stable !important;
}

:root {
    --zeheng-red: #8b1416;
    --zeheng-red-deep: #741012;
    --zeheng-gold: #b89f6f;
    --zeheng-paper: #f9f8f6;
    --zeheng-ink: #2c2c2c;
    --zeheng-type-display: 44px;
    --zeheng-type-section-title: 32px;
    --zeheng-type-module-title: 28px;
    --zeheng-type-card-title: 20px;
    --zeheng-type-body: 16px;
    --zeheng-type-body-compact: 15px;
    --zeheng-type-label: 12px;
}

/* Global content typography calibrated to the compact News Insights module. */
main .text-display-lg,
main .font-display-lg {
    font-size: var(--zeheng-type-display) !important;
    line-height: 1.12 !important;
}

main .text-headline-lg,
main .font-headline-lg {
    font-size: var(--zeheng-type-section-title) !important;
    line-height: 1.22 !important;
}

main .text-headline-md,
main .font-headline-md {
    font-size: var(--zeheng-type-module-title) !important;
    line-height: 1.28 !important;
}

main .text-headline-sm,
main .font-headline-sm {
    font-size: var(--zeheng-type-card-title) !important;
    line-height: 1.36 !important;
}

main .text-body-lg,
main .font-body-lg,
main .text-body-md,
main .font-body-md {
    font-size: var(--zeheng-type-body) !important;
    line-height: 1.75 !important;
}

main .text-body-sm,
main .font-body-sm {
    font-size: var(--zeheng-type-body-compact) !important;
    line-height: 1.7 !important;
}

main .text-label-caps,
main .font-label-caps {
    font-size: var(--zeheng-type-label) !important;
    line-height: 1 !important;
}

@media (max-width: 960px) {
    :root {
        --zeheng-type-display: 36px;
        --zeheng-type-section-title: 30px;
        --zeheng-type-module-title: 26px;
        --zeheng-type-card-title: 20px;
        --zeheng-type-body: 15px;
        --zeheng-type-body-compact: 14px;
    }
}

.site-header .brand-mark,
.site-footer .footer-brand::before {
    filter: saturate(1.08) contrast(1.04);
}

.main-nav a[aria-current="page"],
.mobile-menu a[aria-current="page"] {
    color: var(--zeheng-red) !important;
}

.main-nav a[aria-current="page"]::after,
.nav-item > a[aria-current="page"]::after {
    background: var(--zeheng-red) !important;
}

.main-nav a:hover,
.mobile-menu a:hover,
.site-footer a:hover {
    color: var(--zeheng-red) !important;
}

.site-footer h4::before,
.site-footer h5::before,
.footer-brand {
    border-color: var(--zeheng-red) !important;
}

.label,
.section-eyebrow {
    color: var(--zeheng-red) !important;
}

.font-label-caps.text-muted-gold,
.text-muted-gold {
    color: var(--zeheng-gold) !important;
}

.bg-muted-gold,
.editorial-accent::after {
    background-color: var(--zeheng-red) !important;
}

.border-muted-gold {
    border-color: var(--zeheng-red) !important;
}

.hover\:border-muted-gold:hover,
.group:hover .group-hover\:border-muted-gold,
.card-hover-effect:hover,
.value-item:hover,
.stitch-side-news:hover,
.stitch-news-feature:hover,
.practice-minimal-list article:hover,
.group.block:hover {
    border-color: var(--zeheng-red) !important;
}

.hover\:text-muted-gold:hover,
.group:hover .group-hover\:text-muted-gold,
.group:hover .group-hover\:text-cinnabar-red,
.hover\:text-cinnabar-red:hover,
.stitch-read-link:hover,
.stitch-view-all:hover,
.map-link:hover {
    color: var(--zeheng-red) !important;
}

.hover\:bg-muted-gold:hover,
button.hover\:bg-muted-gold:hover,
a.hover\:bg-muted-gold:hover {
    background-color: var(--zeheng-red) !important;
}

.text-cinnabar-red,
.hover\:text-cinnabar-red:hover {
    color: var(--zeheng-red) !important;
}

.bg-cinnabar-red {
    background-color: var(--zeheng-red) !important;
}

.border-cinnabar-red {
    border-color: var(--zeheng-red) !important;
}

.responsibility-carousel {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.responsibility-carousel-slide {
    position: absolute;
    inset: 0;
    opacity: 0;
    transition: opacity 700ms ease;
}

.responsibility-carousel-slide.is-active {
    opacity: 1;
}

.responsibility-carousel-slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: grayscale(0.18);
    opacity: 0.96;
    transition: filter 500ms ease, opacity 500ms ease;
}

.group:hover .responsibility-carousel-slide img {
    filter: grayscale(0);
    opacity: 1;
}

.responsibility-carousel-caption {
    position: absolute;
    left: 26px;
    right: 88px;
    bottom: 22px;
    max-width: none;
    padding: 4px 0;
    color: #fff;
    font-size: clamp(15px, 1.3vw, 21px) !important;
    line-height: 1.42 !important;
    font-weight: 500;
    letter-spacing: normal;
    text-wrap: normal;
    text-shadow: 0 2px 12px rgba(6, 14, 26, 0.72);
    background: linear-gradient(0deg, rgba(12, 22, 40, 0.32) 0%, rgba(12, 22, 40, 0.16) 62%, rgba(12, 22, 40, 0) 100%);
    backdrop-filter: none;
}

.responsibility-carousel-dots {
    position: absolute;
    right: 14px;
    bottom: 14px;
    display: flex;
    gap: 6px;
}

.responsibility-carousel-caption + .responsibility-carousel-dots {
    bottom: 16px;
}

.responsibility-carousel-dot {
    width: 6px;
    height: 6px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.48);
}

.responsibility-carousel-dot.is-active {
    background: var(--zeheng-gold);
}

input:focus,
textarea:focus,
select:focus,
.focus\:border-muted-gold:focus {
    border-color: var(--zeheng-red) !important;
    box-shadow: none !important;
}

.site-footer {
    background: linear-gradient(180deg, rgba(10, 20, 40, 0.96) 0%, rgba(7, 17, 27, 0.98) 100%) !important;
    border-top: 1px solid rgba(184, 159, 111, 0.24) !important;
}

.site-footer::before {
    background: linear-gradient(90deg, rgba(184, 159, 111, 0) 0%, rgba(184, 159, 111, 0.72) 50%, rgba(184, 159, 111, 0) 100%) !important;
}

.footer-brand,
.site-footer a,
.site-footer p,
.site-footer li {
    color: rgba(244, 239, 230, 0.78) !important;
}

.site-footer a:hover {
    color: var(--zeheng-gold) !important;
}

.site-footer h4,
.site-footer h5 {
    color: var(--zeheng-gold) !important;
}

.site-footer h4 span,
.site-footer h5 span {
    color: rgba(244, 239, 230, 0.54) !important;
}

.site-footer ul,
.site-footer .footer-grid > div:not(:first-child):not(.footer-bottom) {
    border-top-color: rgba(184, 159, 111, 0.16) !important;
}

.footer-bottom,
.site-footer > .footer-bottom,
.footer-grid .footer-bottom {
    border-top-color: rgba(184, 159, 111, 0.16) !important;
    color: rgba(244, 239, 230, 0.5) !important;
}

.hero-media img,
.stitch-feature-media img,
.practice-minimal-list img,
.contact-location-media img,
.group img {
    filter: saturate(0.9) contrast(1.03);
}

.hero-media img {
    object-position: 50% 18% !important;
}

.hero-media::after {
    background:
        linear-gradient(90deg, rgba(7, 17, 27, 0.76), rgba(7, 17, 27, 0.34)),
        linear-gradient(180deg, rgba(139, 20, 22, 0.18), transparent 46%) !important;
}

.value-item:hover::after {
    color: rgba(139, 20, 22, 0.07) !important;
}

.stitch-news-meta span,
.stitch-news-meta time,
.practice-minimal-list article span,
.num {
    color: var(--zeheng-red) !important;
}

.back-to-top {
    background: var(--zeheng-red) !important;
    color: #fff !important;
}

/* Global Stitch-style navigation. Keep the existing Zeheng logo/brand area, only restyle the bar and menu. */
.site-header {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 1000 !important;
    box-sizing: border-box !important;
    height: 64px !important;
    min-height: 64px !important;
    max-height: 64px !important;
    padding: 0 !important;
    background: rgba(250, 249, 247, 0.94) !important;
    border-bottom: 1px solid rgba(10, 20, 40, 0.08) !important;
    box-shadow: none !important;
    backdrop-filter: blur(10px) saturate(120%) !important;
    transition: background-color 300ms ease, border-color 300ms ease, backdrop-filter 300ms ease, height 300ms cubic-bezier(0.25, 1, 0.5, 1), min-height 300ms cubic-bezier(0.25, 1, 0.5, 1), max-height 300ms cubic-bezier(0.25, 1, 0.5, 1) !important;
}

.site-header::before {
    display: none !important;
}

.site-header.is-over-hero:not(.is-scrolled) {
    background: transparent !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0) !important; /* 1px边框占位防抖 */
    backdrop-filter: none !important;
}

.site-header.is-over-hero:hover,
.site-header.is-over-hero.is-scrolled,
.site-header.is-scrolled,
body.menu-open .site-header {
    background: rgba(10, 20, 40, 0.9) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0) !important; /* 1px边框占位防抖 */
    backdrop-filter: blur(10px) saturate(120%) !important;
}

.site-nav {
    box-sizing: border-box !important;
    height: 100% !important;
    min-height: 100% !important;
    max-height: 100% !important;
    max-width: none !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 32px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 24px !important;
}

.site-brand {
    box-sizing: border-box !important;
    display: inline-flex !important;
    align-items: center !important;
    height: 100% !important;
    min-width: max-content !important;
    color: #0a1428 !important;
    font-family: "Libre Franklin", var(--sans, "Work Sans", "Noto Sans SC", system-ui, sans-serif) !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    letter-spacing: 0.18em !important;
    text-transform: uppercase !important;
    padding: 0 !important;
    margin: 0 !important;
}

.brand-text {
    display: none !important;
    color: #0a1428 !important;
    line-height: 1 !important;
    text-shadow: none !important;
}

.site-header.is-over-hero:not(.is-scrolled) .site-brand,
.site-header.is-over-hero:not(.is-scrolled) .brand-text,
.site-header.is-scrolled .site-brand,
.site-header.is-scrolled .brand-text,
body.menu-open .site-header .site-brand,
body.menu-open .site-header .brand-text {
    color: #ffffff !important;
}

.site-brand:hover,
.site-brand:hover .brand-text {
    color: var(--zeheng-gold) !important;
}

/* logo图片尺寸锁定 */
.site-header .brand-mark,
.site-header .site-brand img,
.site-header .brand img,
.site-header a img {
    box-sizing: border-box !important;
    width: 22px !important;
    height: 36px !important;
    max-width: 22px !important;
    max-height: 36px !important;
    min-width: 22px !important;
    min-height: 36px !important;
    object-fit: contain !important;
    transition: none !important; /* 取消尺寸过渡以防跳动 */
    filter: brightness(1.08) saturate(0.96) contrast(1.02) !important;
}

.main-nav {
    box-sizing: border-box !important;
    height: 100% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 40px !important;
    margin-left: auto !important;
    margin-right: 74px !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    padding: 0 !important;
}

.nav-item {
    box-sizing: border-box !important;
    display: flex !important;
    align-items: center !important;
    height: 100% !important;
}

.main-nav a,
.nav-item > a,
.main-nav > a {
    box-sizing: border-box !important;
    display: inline-flex !important;
    align-items: center !important;
    height: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
    color: rgba(10, 20, 40, 0.74) !important;
    font-family: var(--sans, "Work Sans", "Noto Sans SC", system-ui, sans-serif) !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    letter-spacing: 0.12em !important;
    text-transform: uppercase !important;
    white-space: nowrap !important;
    transition: color 250ms ease, opacity 250ms ease !important;
    position: relative !important;
}

.site-header.is-over-hero:not(.is-scrolled) .main-nav a,
.site-header.is-over-hero:not(.is-scrolled) .nav-item > a,
.site-header.is-over-hero:not(.is-scrolled) .main-nav > a,
.site-header.is-scrolled .main-nav a,
.site-header.is-scrolled .nav-item > a,
.site-header.is-scrolled .main-nav > a,
body.menu-open .site-header .main-nav a,
body.menu-open .site-header .nav-item > a,
body.menu-open .site-header .main-nav > a {
    color: rgba(255, 255, 255, 0.86) !important;
}

.main-nav a:hover,
.nav-item:hover > a,
.main-nav a[aria-current="page"],
.mobile-menu a[aria-current="page"] {
    color: var(--zeheng-gold) !important;
}

.main-nav a::after,
.nav-item > a::after,
.main-nav > a::after {
    content: "" !important;
    position: absolute !important;
    left: 50% !important;
    bottom: 14px !important; /* 确保悬浮红/金线下移到合适的位置而不会随整体高度抖动 */
    width: 22px !important;
    height: 1px !important;
    background: var(--zeheng-gold) !important;
    transform: translateX(-50%) scaleX(0) !important;
    transform-origin: center !important;
    transition: transform 250ms ease !important;
}

.main-nav a:hover::after,
.nav-item:hover > a::after,
.main-nav a[aria-current="page"]::after,
.nav-item > a[aria-current="page"]::after {
    transform: translateX(-50%) scaleX(1) !important;
}

.nav-actions {
    box-sizing: border-box !important;
    display: flex !important;
    align-items: center !important;
    height: 100% !important;
    gap: 16px !important;
}

.menu-toggle {
    color: rgba(10, 20, 40, 0.78) !important;
    border-color: rgba(10, 20, 40, 0.16) !important;
    background: transparent !important;
}

.site-header.is-over-hero:not(.is-scrolled) .menu-toggle {
    color: rgba(255, 255, 255, 0.86) !important;
    border-color: rgba(255, 255, 255, 0.28) !important;
}

.site-header.is-scrolled .menu-toggle,
body.menu-open .site-header .menu-toggle {
    color: rgba(255, 255, 255, 0.86) !important;
    border-color: rgba(255, 255, 255, 0.28) !important;
}

.menu-toggle:hover {
    color: var(--zeheng-gold) !important;
    border-color: var(--zeheng-gold) !important;
}

.page-main,
main[id="main-content"] {
    scroll-margin-top: 80px;
}

@media (max-width: 960px) {
    .site-header {
        height: 60px !important;
        min-height: 60px !important;
        max-height: 60px !important;
        background: rgba(250, 249, 247, 0.94) !important;
    }

    .site-nav {
        height: 100% !important;
        min-height: 100% !important;
        max-height: 100% !important;
        padding: 0 20px !important;
    }

    /* 强力覆盖 unify 层大屏样式，在 960px 以下彻底隐藏 PC 端常规导航栏，防止顶栏挤爆 */
    .main-nav {
        display: none !important;
    }

    /* 确保移动端汉堡包菜单按钮强制显示 */
    .menu-toggle {
        display: inline-flex !important;
    }

    /* 确保移动端折叠菜单在 960px 断点即刻激活 */
    .mobile-menu {
        display: block !important;
    }

    .main-nav a::after,
    .nav-item > a::after,
    .main-nav > a::after {
        bottom: 16px !important;
    }
}

/* P0 visual unification: keep layouts, remove SaaS-like softness and push brand red into page accents. */
main .rounded,
main .rounded-sm,
main .rounded-lg,
main .rounded-xl,
main .rounded-full,
main [class~="rounded"],
main [class~="rounded-sm"],
main [class~="rounded-lg"],
main [class~="rounded-xl"],
main [class~="rounded-full"] {
    border-radius: 0 !important;
}

main .shadow-sm,
main .shadow,
main .shadow-lg,
main .shadow-xl,
main [class*="shadow-"] {
    box-shadow: none !important;
}

main .bg-paper-white.border,
main .bg-surface-container-low.border,
main .bg-surface-container.border,
main .group.block.border,
main .article-detail-card,
main .case-card,
main .lawyer-mini-card {
    border-color: rgba(139, 20, 22, 0.18) !important;
    box-shadow: none !important;
}

main .bg-paper-white.border:hover,
main .bg-surface-container-low.border:hover,
main .bg-surface-container.border:hover,
main .group.block.border:hover,
main .article-detail-card:hover,
main .case-card:hover,
main .lawyer-mini-card:hover {
    border-color: var(--zeheng-red) !important;
    box-shadow: none !important;
}

main .text-muted-gold,
main .group:hover .group-hover\:text-muted-gold,
main .hover\:text-muted-gold:hover,
main .material-symbols-outlined.text-muted-gold {
    color: var(--zeheng-red) !important;
}

main .border-muted-gold,
main .hover\:border-muted-gold:hover,
main .group:hover .group-hover\:border-muted-gold {
    border-color: var(--zeheng-red) !important;
}

main .bg-muted-gold,
main .bg-muted-gold\/30,
main .bg-muted-gold\/20 {
    background-color: var(--zeheng-red) !important;
}

main .focus\:border-muted-gold:focus {
    border-color: var(--zeheng-red) !important;
}

.consultation-notice {
    margin-top: 24px;
    padding-top: 18px;
    border-top: 1px solid rgba(139, 20, 22, 0.2);
    color: rgba(68, 71, 72, 0.82);
    font-size: 13px;
    line-height: 1.8;
}

/* Team portraits: fill the editorial frame with a calm top-weighted crop. */
.team-directory-page main section.py-20 a.group.block > div:first-child {
    display: flex !important;
    align-items: stretch !important;
    justify-content: stretch !important;
    aspect-ratio: 3 / 4 !important;
    min-height: 320px !important;
    background: #f4f3f1 !important;
}

.team-directory-page main section.py-20 a.group.block > div:first-child img {
    width: 100% !important;
    height: 100% !important;
    padding: 0 !important;
    box-sizing: border-box !important;
    object-fit: cover !important;
    object-position: center 16% !important;
    filter: none !important;
    transform: scale(1.01) !important;
    transform-origin: center top !important;
}

.team-directory-page main section.py-20 a.group.block:hover > div:first-child img {
    filter: none !important;
    transform: scale(1.03) !important;
}

/* Team directory: keep three columns while making portraits calmer and more breathable. */
body.team-directory-page [data-lawyer-directory-grid] {
    gap: clamp(52px, 5vw, 76px) clamp(42px, 4vw, 64px) !important;
}

body.team-directory-page [data-lawyer-card] {
    display: block;
    transition: transform 0.28s ease, color 0.28s ease !important;
}

body.team-directory-page [data-lawyer-photo-frame] {
    width: min(74%, 290px) !important;
    min-height: 0 !important;
    margin: 0 auto 26px !important;
    aspect-ratio: 3 / 4 !important;
    display: flex !important;
    align-items: stretch !important;
    justify-content: stretch !important;
    background: #f4f3f1 !important;
    border: 1px solid rgba(121, 92, 45, 0.18) !important;
    box-shadow: 18px 18px 0 rgba(121, 92, 45, 0.06) !important;
    transition: border-color 0.28s ease, box-shadow 0.28s ease !important;
}

body.team-directory-page [data-lawyer-photo-frame]::after {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    background: rgba(91, 0, 6, 0.08) !important;
    opacity: 0 !important;
    transition: opacity 0.45s ease !important;
    pointer-events: none !important;
}

body.team-directory-page [data-lawyer-photo-frame] img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center 16% !important;
    filter: none !important;
    transform: scale(1.01) !important;
    transform-origin: center top !important;
}

body.team-directory-page [data-lawyer-card]:hover {
    transform: translateY(-8px) !important;
}

body.team-directory-page [data-lawyer-card]:hover [data-lawyer-photo-frame] img {
    filter: none !important;
    transform: scale(1.045) !important;
}

body.team-directory-page [data-lawyer-card]:hover [data-lawyer-photo-frame]::after {
    opacity: 1 !important;
}

body.team-directory-page [data-lawyer-card] > :not([data-lawyer-photo-frame]) {
    width: min(74%, 290px);
    margin-left: auto;
    margin-right: auto;
    text-align: left !important;
}

body.team-directory-page [data-lawyer-card] > .flex.justify-between {
    display: block !important;
    margin-bottom: 14px !important;
    padding-top: 18px !important;
    border-top: 1px solid rgba(140, 113, 111, 0.22) !important;
}

body.team-directory-page [data-lawyer-name] {
    font-size: 23px !important;
    line-height: 1.18 !important;
    margin-bottom: 10px !important;
    text-align: left !important;
    color: #1a1c1b !important;
    letter-spacing: 0 !important;
    transition: color 0.25s ease !important;
}

body.team-directory-page [data-lawyer-card]:hover [data-lawyer-name] {
    color: var(--zeheng-red) !important;
}

body.team-directory-page [data-lawyer-role] {
    display: inline-block !important;
    max-width: none !important;
    text-align: left !important;
    margin-top: 0 !important;
    padding-left: 0 !important;
    border-left: 0 !important;
    line-height: 1.4 !important;
    color: var(--zeheng-red) !important;
    letter-spacing: 0.12em !important;
    font-size: 12px !important;
}

body.team-directory-page [data-lawyer-summary] {
    margin-top: 16px !important;
    margin-bottom: 18px !important;
    font-size: 15px !important;
    line-height: 1.82 !important;
    color: rgba(68, 71, 72, 0.86) !important;
    text-align: left !important;
}

body.team-directory-page [data-lawyer-tags] {
    margin-bottom: 24px !important;
    padding-top: 14px !important;
    border-top: 1px solid rgba(140, 113, 111, 0.14) !important;
    font-size: 12px !important;
    line-height: 1.7 !important;
    color: var(--zeheng-red) !important;
    letter-spacing: 0.1em !important;
    text-align: left !important;
    transition: color 0.25s ease !important;
}

body.team-directory-page [data-lawyer-card]:hover [data-lawyer-tags] {
    color: var(--zeheng-red) !important;
}

body.team-directory-page [data-lawyer-card] .thin-line-hover {
    color: #1a1c1b !important;
    letter-spacing: 0.14em !important;
    transition: color 0.2s ease, transform 0.2s ease !important;
}

body.team-directory-page [data-lawyer-card]:hover .thin-line-hover {
    color: var(--zeheng-red) !important;
}

@media (max-width: 1023px) {
    body.team-directory-page [data-lawyer-photo-frame] {
        width: min(88%, 340px) !important;
    }

    body.team-directory-page [data-lawyer-card] > :not([data-lawyer-photo-frame]) {
        width: min(88%, 340px) !important;
    }
}

.team-pagination button:disabled {
    opacity: 0.34;
    cursor: not-allowed;
    pointer-events: none;
}

/* ==========================================
   品牌主标题视觉统一规范覆盖（统一4个内页主标题，关于泽亨页面保持原状）
   ========================================== */

/* 统一4个内页（业务领域概览、专业团队、新闻洞察、联系我们）大标题样式 */
main#main-content h1.font-display-lg:not(.leading-tight),
body.team-directory-page main#main-content h1.font-display-lg,
main.page-main[data-news-page] .news-page-head h1,
body.min-h-screen main#main-content h1.font-display-lg {
    font-family: "Newsreader", "Noto Serif SC", serif !important;
    font-weight: 600 !important;
    letter-spacing: -0.01em !important;
    border-left: none !important;
    padding-left: 0 !important;
    margin-left: 0 !important;
    background: none !important;
    -webkit-text-fill-color: initial !important;
}

/* 仅在浅色底页面（业务领域概览、专业团队、联系我们）中将标题设为沉稳的墨黑色 */
main#main-content h1.font-display-lg:not(.leading-tight),
body.team-directory-page main#main-content h1.font-display-lg,
body.min-h-screen main#main-content h1.font-display-lg {
    color: #1a1a1a !important;
}

/* 新闻洞察页面大标题颜色自适应：保持在深色大背景下的优雅暖白色 */
main.page-main[data-news-page] .news-page-head h1 {
    color: #f8efe3 !important;
}

/* 纯CSS通过伪元素在标题上方动态渲染朱砂红短横线，专业团队页不再使用该装饰。 */
main.page-main[data-news-page] .news-page-head h1::before,
body.min-h-screen main#main-content h1.font-display-lg::before {
    content: "" !important;
    display: block !important;
    width: 40px !important;
    height: 2px !important;
    background-color: var(--zeheng-red, #8b1416) !important;
    margin-bottom: 24px !important; /* 完美重现 mb-6 的间距效果 */
}

body.team-directory-page main#main-content h1.font-display-lg::before {
    content: none !important;
    display: none !important;
}

/* 新闻洞察页标题区改为与业务领域、专业团队一致的浅底版式 */
main.page-main[data-news-page] > .news-title-aligned {
    position: relative !important;
    overflow: hidden !important;
    isolation: isolate !important;
    background: #0b1524 !important;
    color: #ffffff !important;
    padding: 128px 0 64px !important;
}

main.page-main[data-news-page] > .news-title-aligned::before {
    content: "" !important;
    display: block !important;
    position: absolute !important;
    inset: 0 !important;
    z-index: -2 !important;
    pointer-events: none !important;
    background:
        linear-gradient(90deg, rgba(7, 16, 30, 0.82) 0%, rgba(7, 16, 30, 0.56) 42%, rgba(7, 16, 30, 0.22) 100%),
        url("assets/case-books-table-photo.webp") center 52% / cover no-repeat !important;
    filter: grayscale(10%) saturate(96%) contrast(1.02);
    opacity: 0.96 !important;
}

main.page-main[data-news-page] > .news-title-aligned::after {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    z-index: -1 !important;
    pointer-events: none !important;
    background:
        radial-gradient(circle at 18% 14%, rgba(184, 159, 111, 0.18), transparent 26rem),
        linear-gradient(180deg, rgba(3, 10, 20, 0.08), rgba(3, 10, 20, 0.28));
    background-size: auto, auto;
    opacity: 0.78 !important;
}

main.page-main[data-news-page] > .news-title-aligned h1::before {
    display: none !important;
}

main.page-main[data-news-page] > .news-title-aligned .container {
    position: relative !important;
    z-index: 1 !important;
}

main.page-main[data-news-page] > .news-title-aligned .news-title-grid {
    align-items: end !important;
}

main.page-main[data-news-page] > .news-title-aligned .news-title-copy {
    grid-column: span 7 !important;
}

main.page-main[data-news-page] > .news-title-aligned .news-title-rule {
    width: 40px;
    height: 2px;
    margin-bottom: 24px;
    background: var(--zeheng-red, #8b1416);
}

main.page-main[data-news-page] > .news-title-aligned .label {
    display: block;
    margin-bottom: 20px;
    color: #d8c198 !important;
    font-family: var(--sans);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}

main.page-main[data-news-page] > .news-title-aligned h1 {
    margin: 0 0 32px !important;
    padding: 0 !important;
    border: 0 !important;
    color: #ffffff !important;
    text-shadow: none !important;
}

main.page-main[data-news-page] > .news-title-aligned p {
    color: rgba(255, 255, 255, 0.82) !important;
}

main.page-main[data-news-page] > .news-title-aligned .right-note {
    grid-column: 8 / span 5 !important;
    align-self: end !important;
    color: rgba(255, 255, 255, 0.42) !important;
    font-family: var(--serif);
    font-size: clamp(72px, 9vw, 120px);
    font-style: normal;
    font-weight: 600;
    line-height: 0.8;
    letter-spacing: -0.05em;
    opacity: 0.24;
    text-align: right;
}

main.page-main[data-news-page] > .news-title-aligned .tabs {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 28px;
    width: 100%;
    margin-top: 84px;
    padding: 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.24);
    background: transparent;
}

main.page-main[data-news-page] > .news-title-aligned .tab-btn {
    min-width: max-content;
    border: 0;
    margin-bottom: -1px;
    padding: 0 0 16px;
    background: transparent;
    color: rgba(255, 255, 255, 0.72);
    font-family: var(--sans);
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.05em;
}

main.page-main[data-news-page] > .news-title-aligned .tab-btn.active,
main.page-main[data-news-page] > .news-title-aligned .tab-btn:hover {
    color: #ffffff;
}

main.page-main[data-news-page] > .news-title-aligned .tab-btn.active::after {
    display: block;
    bottom: -1px;
    height: 2px;
    background: var(--zeheng-red, #8b1416);
}

/* 联系我们页顶部：图片背景下使用深色压暗层与白色标题，避免文字压在图上发灰。 */
.contact-spotlight-hero {
    background: #08111f !important;
    padding-top: 132px !important;
    padding-bottom: 92px !important;
}

.contact-spotlight-hero::before {
    content: "" !important;
    display: block !important;
    position: absolute !important;
    inset: 0 !important;
    z-index: -2 !important;
    background:
        linear-gradient(90deg, rgba(5, 12, 24, 0.86) 0%, rgba(5, 12, 24, 0.62) 44%, rgba(5, 12, 24, 0.26) 100%),
        url("assets/contact-office-photo.webp") center 54% / cover no-repeat !important;
    filter: saturate(0.98) contrast(1.04);
    opacity: 1 !important;
}

.contact-spotlight-hero::after {
    content: "" !important;
    display: block !important;
    position: absolute !important;
    inset: 0 !important;
    z-index: -1 !important;
    pointer-events: none !important;
    background:
        radial-gradient(circle at 20% 18%, rgba(184, 159, 111, 0.18), transparent 24rem),
        linear-gradient(180deg, rgba(3, 10, 20, 0.02), rgba(3, 10, 20, 0.34));
}

.contact-spotlight-hero span.font-label-caps {
    color: #d8c198 !important;
}

.contact-spotlight-hero h1.font-display-lg {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    text-shadow: 0 18px 44px rgba(0, 0, 0, 0.42);
}

body.min-h-screen main#main-content .contact-spotlight-hero h1.font-display-lg {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    opacity: 1 !important;
}

.contact-spotlight-hero h1.font-display-lg::before {
    background-color: #8b1416 !important;
}

.contact-spotlight-hero p {
    color: rgba(255, 255, 255, 0.82) !important;
}

/* 专业团队卡片业务标签：默认黑色，悬停整卡时变品牌红。 */
body.team-directory-page .team-card--editorial .team-card-tags,
body.team-directory-page .team-card--editorial .team-card-tags span {
    color: #1a1a1a !important;
    transition: color 0.25s ease !important;
}

body.team-directory-page .team-card--editorial:hover .team-card-tags,
body.team-directory-page .team-card--editorial:hover .team-card-tags span,
body.team-directory-page .team-card--editorial .team-card-tags span:hover {
    color: var(--zeheng-red, #8b1416) !important;
}

@media (max-width: 960px) {
    main.page-main[data-news-page] > .news-title-aligned {
        padding: 104px 0 48px !important;
    }

    main.page-main[data-news-page] > .news-title-aligned .news-title-copy,
    main.page-main[data-news-page] > .news-title-aligned .right-note {
        grid-column: 1 / -1 !important;
    }

    main.page-main[data-news-page] > .news-title-aligned .right-note {
        margin-top: 28px;
        font-size: 64px;
        text-align: left;
    }
}

/* ==========================================
   四、网站全局高级响应式自适应与顶栏防抖重构补丁
   ========================================== */

/* 一、全局防水平溢出（彻底解决移动端拖拽页面时的晃动 Bug） */
html, body {
    max-width: 100% !important;
    overflow-x: hidden !important;
}

/* 二、移动端自适应核心体验微修护（@media 断点覆盖） */
@media (max-width: 960px) {
    /* 1. 取消专业团队页面（lawyers.html）筛选条在移动端的 sticky 状态，防止霸屏并消除 12px 空隙 */
    section.sticky.top-\[84px\],
    main#main-content section.sticky {
        position: static !important;
        border-bottom: 1px solid rgba(139, 20, 22, 0.12) !important;
        background-color: var(--zeheng-paper, #f9f8f6) !important;
    }

    /* 2. 限制新闻洞察页（news.html）分类 Tab 不折行，并开启优雅的横向流式无痕手势滚动 */
    .tabs {
        display: flex !important;
        flex-wrap: nowrap !important;
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch !important;
        gap: 20px !important;
        margin-top: 32px !important;
        scrollbar-width: none !important; /* Firefox */
        padding-bottom: 4px !important;
        border-bottom: 1px solid rgba(139, 20, 22, 0.15) !important;
    }
    
    .tabs::-webkit-scrollbar {
        display: none !important; /* Chrome, Safari, Opera 下无痕隐藏滚动条 */
    }
    
    .tabs button, 
    .tabs a {
        white-space: nowrap !important;
        font-size: 16px !important; /* 移动端字阶优雅微调 */
        padding-bottom: 10px !important;
    }
    
    .tabs button.active::after,
    .tabs .active::after {
        background: var(--zeheng-red, #8b1416) !important; /* 统一下划线为尊贵朱砂红 */
    }

    /* 3. 针对联系我们页面（contact.html）右侧大图在小屏下写死 500px 导致的高度崩塌进行微调 */
    .col-span-1.h-\[500px\],
    main#main-content .h-\[500px\] {
        height: 260px !important;
    }
}

/* ==========================================
   全站内容字号最终统一：以关于页新闻洞察紧凑模块为基准
   ========================================== */
main#main-content :where(h1, .page-title, .hero-title, .contact-spotlight-hero h1, .news-title-copy h1) {
    font-size: var(--zeheng-type-display, 44px) !important;
    line-height: 1.12 !important;
    letter-spacing: -0.02em !important;
}

main#main-content :where(h2, .section-title, .title-block h2, .page-section-title) {
    font-size: var(--zeheng-type-module-title, 28px) !important;
    line-height: 1.28 !important;
    letter-spacing: -0.02em !important;
}

main#main-content :where(h3, h4, .card-title, .team-card-name, .news-card-title, .article-title, .practice-card-title) {
    font-size: var(--zeheng-type-card-title, 20px) !important;
    line-height: 1.36 !important;
    letter-spacing: -0.01em !important;
}

main#main-content :where(p, li, .body-copy, .card-copy, .summary, .description, .team-card-desc, .news-card-summary) {
    font-size: var(--zeheng-type-body-compact, 15px) !important;
    line-height: 1.75 !important;
}

main#main-content :where(.text-label-caps, .font-label-caps, .section-eyebrow, .label, small, time) {
    font-size: var(--zeheng-type-label, 12px) !important;
    line-height: 1.1 !important;
    letter-spacing: 0.16em !important;
}

main#main-content :where(.text-body-lg, .font-body-lg, .text-body-md, .font-body-md, .text-body-sm, .font-body-sm) {
    font-size: var(--zeheng-type-body-compact, 15px) !important;
}

main#main-content :where(.text-headline-lg, .font-headline-lg, .text-headline-md, .font-headline-md) {
    font-size: var(--zeheng-type-module-title, 28px) !important;
}

main#main-content :where(.text-headline-sm, .font-headline-sm) {
    font-size: var(--zeheng-type-card-title, 20px) !important;
}

/* Typography hierarchy guard: element meaning wins over utility classes. */
main#main-content :where(h3, h4, h5, h6) {
    font-size: var(--zeheng-type-card-title, 20px) !important;
    line-height: 1.36 !important;
}

main#main-content :where(p, li, dd, blockquote, figcaption) {
    font-size: var(--zeheng-type-body-compact, 15px) !important;
    line-height: 1.75 !important;
    font-weight: 400 !important;
}

main#main-content :where(p, span, div, a, li):where(.font-headline-lg, .text-headline-lg, .font-headline-md, .text-headline-md, .font-display-lg, .text-display-lg):not(h1):not(h2):not(h3):not(h4):not(h5):not(h6):not(.decorative-type) {
    font-size: var(--zeheng-type-body, 16px) !important;
    line-height: 1.65 !important;
}

main#main-content :where([data-lawyer-role], [data-lawyer-tags], .team-card-tags, .team-card-role, .section-eyebrow, .label, time, small) {
    font-size: var(--zeheng-type-label, 12px) !important;
    line-height: 1.2 !important;
}

main#main-content :where([data-lawyer-name], .team-card-name) {
    font-size: var(--zeheng-type-card-title, 20px) !important;
    line-height: 1.36 !important;
}

main#main-content :where([data-lawyer-summary], .team-card-summary, .news-card-summary, .article-summary) {
    font-size: var(--zeheng-type-body-compact, 15px) !important;
    line-height: 1.72 !important;
}

main#main-content :where(.text-\[120px\], .text-\[104px\], .text-\[80px\]) {
    font-size: clamp(48px, 7vw, 72px) !important;
    line-height: 1 !important;
}

/* 新闻洞察列表：沿用首页新闻洞察紧凑模块的文字层级。 */
main.page-main[data-news-page] .news-list {
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
    row-gap: 0 !important;
}

main.page-main[data-news-page] .news-item {
    grid-template-columns: 76px minmax(0, 1fr) !important;
    gap: 18px !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    align-items: start !important;
}

main.page-main[data-news-page] .news-item h2,
main.page-main[data-news-page] .news-item h2 a {
    font-size: 18px !important;
    line-height: 1.34 !important;
    letter-spacing: -0.01em !important;
    font-weight: 500 !important;
}

main.page-main[data-news-page] .news-item p {
    margin-top: 8px !important;
    font-size: 14px !important;
    line-height: 1.58 !important;
    color: rgba(68, 71, 72, 0.9) !important;
    display: -webkit-box !important;
    -webkit-box-orient: vertical !important;
    -webkit-line-clamp: 2 !important;
    overflow: hidden !important;
}

main.page-main[data-news-page] .news-meta {
    margin-bottom: 8px !important;
}

main.page-main[data-news-page] .news-meta,
main.page-main[data-news-page] .news-date span,
main.page-main[data-news-page] .news-badge {
    font-size: var(--zeheng-type-label, 12px) !important;
    line-height: 1.2 !important;
    letter-spacing: 0.16em !important;
}

main.page-main[data-news-page] .news-date strong {
    font-size: 28px !important;
    line-height: 1 !important;
}

main.page-main[data-news-page] .news-date small {
    display: block !important;
    margin-top: 4px !important;
    font-size: 11px !important;
    line-height: 1.15 !important;
    letter-spacing: 0.08em !important;
    color: #75777c !important;
}

main.page-main[data-news-page] .news-list,
main.page-main[data-news-page] .sidebar,
main.page-main[data-news-page] .page-head {
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
}

main.page-main[data-news-page] .news-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 8px;
    margin: 38px 0 0;
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
}

main.page-main[data-news-page] .news-pagination button,
main.page-main[data-news-page] .news-pagination-total,
main.page-main[data-news-page] .news-pagination-gap {
    min-width: 38px;
    height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(159, 24, 33, 0.22);
    background: rgba(255, 255, 255, 0.54);
    color: var(--ink);
    font: 700 12px/1 var(--sans);
}

main.page-main[data-news-page] .news-pagination button {
    cursor: pointer;
    transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

main.page-main[data-news-page] .news-pagination button:hover,
main.page-main[data-news-page] .news-pagination button.active {
    border-color: var(--red);
    background: var(--red);
    color: #fff;
}

main.page-main[data-news-page] .news-pagination button:disabled {
    cursor: not-allowed;
    opacity: 0.42;
}

main.page-main[data-news-page] .news-pagination-total {
    width: auto;
    padding: 0 14px;
    color: var(--muted);
}

main.page-main[data-news-page] .news-pagination-gap {
    width: 30px;
    min-width: 30px;
    border-color: transparent;
    background: transparent;
    color: var(--muted);
}

main.page-main[data-news-page] .journal-divider {
    margin-top: 10px !important;
    margin-bottom: 18px !important;
}

/* Inner-page spacing compaction: remove oversized blank bands across pages. */
main > section.py-32,
main > section.py-28,
main > section.py-24,
main > section.py-20,
main#main-content > section.py-32,
main#main-content > section.py-28,
main#main-content > section.py-24,
main#main-content > section.py-20 {
    padding-top: 48px !important;
    padding-bottom: 48px !important;
}

main > section.px-8.py-32,
main > section.py-32.px-8,
main#main-content > section.px-8.py-32,
main#main-content > section.py-32.px-8 {
    padding-top: 48px !important;
    padding-bottom: 48px !important;
}

main#main-content :where(.mb-section-gap) {
    margin-bottom: 48px !important;
}

main#main-content :where(.py-section-gap) {
    padding-top: 48px !important;
    padding-bottom: 48px !important;
}

main#main-content :where(.pt-32) {
    padding-top: 96px !important;
}

main#main-content :where(.pb-section-gap) {
    padding-bottom: 64px !important;
}

main :where(.mb-16),
main#main-content :where(.mb-16) {
    margin-bottom: 32px !important;
}

main :where(.mt-16),
main#main-content :where(.mt-16) {
    margin-top: 32px !important;
}

main :where(.mt-24),
main#main-content :where(.mt-24) {
    margin-top: 40px !important;
}

main :where(.gap-16),
main#main-content :where(.gap-16) {
    gap: 32px !important;
}

main :where(.gap-12),
main#main-content :where(.gap-12) {
    gap: 28px !important;
}

main :where(.py-8),
main#main-content :where(.py-8) {
    padding-top: 20px !important;
    padding-bottom: 20px !important;
}

main :where(.space-y-24) > :not([hidden]) ~ :not([hidden]),
main#main-content :where(.space-y-24) > :not([hidden]) ~ :not([hidden]) {
    margin-top: 40px !important;
}

main :where(.space-y-12) > :not([hidden]) ~ :not([hidden]),
main#main-content :where(.space-y-12) > :not([hidden]) ~ :not([hidden]) {
    margin-top: 28px !important;
}

main.page-main[data-news-page] > .section {
    padding-top: 28px !important;
    padding-bottom: 48px !important;
}

main.page-main[data-news-page] .news-layout {
    gap: 42px !important;
}

main.page-main[data-news-page] .news-main-column {
    min-width: 0;
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
}

main#main-content [data-purpose="department-matrix"] article h3 {
    font-size: 17px !important;
    line-height: 1.28 !important;
}

main#main-content [data-purpose="department-matrix"] article span {
    font-size: 11px !important;
    line-height: 1 !important;
}

@media (max-width: 960px) {
    main#main-content :where(h1, .page-title, .hero-title, .contact-spotlight-hero h1, .news-title-copy h1) {
        font-size: var(--zeheng-type-display, 36px) !important;
    }

    main#main-content :where(h2, .section-title, .title-block h2, .page-section-title, .text-headline-lg, .font-headline-lg, .text-headline-md, .font-headline-md) {
        font-size: var(--zeheng-type-module-title, 26px) !important;
    }

    main#main-content :where(h3, h4, .card-title, .team-card-name, .news-card-title, .article-title, .practice-card-title, .text-headline-sm, .font-headline-sm) {
        font-size: var(--zeheng-type-card-title, 20px) !important;
    }

    main#main-content :where(p, li, .body-copy, .card-copy, .summary, .description, .team-card-desc, .news-card-summary, .text-body-lg, .font-body-lg, .text-body-md, .font-body-md, .text-body-sm, .font-body-sm) {
        font-size: var(--zeheng-type-body-compact, 14px) !important;
    }

    main#main-content :where(p, span, div, a, li):where(.font-headline-lg, .text-headline-lg, .font-headline-md, .text-headline-md, .font-display-lg, .text-display-lg):not(h1):not(h2):not(h3):not(h4):not(h5):not(h6):not(.decorative-type) {
        font-size: var(--zeheng-type-body, 15px) !important;
    }
}

/* Page-aware navigation palettes: each page uses a bar tone that matches its hero/background imagery. */
body.nav-theme-night {
    --zeheng-nav-bg: rgba(7, 17, 27, 0.92);
    --zeheng-nav-border: rgba(184, 159, 111, 0.22);
    --zeheng-nav-brand: #f6efe4;
    --zeheng-nav-link: rgba(246, 239, 228, 0.82);
    --zeheng-nav-active: #c9a56f;
    --zeheng-nav-line: #c9a56f;
    --zeheng-nav-toggle: rgba(246, 239, 228, 0.84);
}

body.nav-theme-practice {
    --zeheng-nav-bg: rgba(247, 241, 232, 0.95);
    --zeheng-nav-border: rgba(139, 20, 22, 0.14);
    --zeheng-nav-brand: #231f1a;
    --zeheng-nav-link: rgba(35, 31, 26, 0.76);
    --zeheng-nav-active: #8b1416;
    --zeheng-nav-line: #8b1416;
    --zeheng-nav-toggle: rgba(35, 31, 26, 0.78);
}

body.nav-theme-team {
    --zeheng-nav-bg: rgba(241, 238, 232, 0.95);
    --zeheng-nav-border: rgba(74, 83, 92, 0.14);
    --zeheng-nav-brand: #20262d;
    --zeheng-nav-link: rgba(32, 38, 45, 0.74);
    --zeheng-nav-active: #9b1c1f;
    --zeheng-nav-line: #9b1c1f;
    --zeheng-nav-toggle: rgba(32, 38, 45, 0.78);
}

body.nav-theme-news {
    --zeheng-nav-bg: rgba(250, 246, 239, 0.96);
    --zeheng-nav-border: rgba(121, 92, 45, 0.18);
    --zeheng-nav-brand: #2b251e;
    --zeheng-nav-link: rgba(43, 37, 30, 0.74);
    --zeheng-nav-active: #795c2d;
    --zeheng-nav-line: #795c2d;
    --zeheng-nav-toggle: rgba(43, 37, 30, 0.78);
}

body.nav-theme-office {
    --zeheng-nav-bg: rgba(37, 43, 44, 0.9);
    --zeheng-nav-border: rgba(224, 205, 174, 0.18);
    --zeheng-nav-brand: #f8efe3;
    --zeheng-nav-link: rgba(248, 239, 227, 0.82);
    --zeheng-nav-active: #d0b987;
    --zeheng-nav-line: #d0b987;
    --zeheng-nav-toggle: rgba(248, 239, 227, 0.84);
}

body[class*="nav-theme-"] .site-header {
    background: var(--zeheng-nav-bg) !important;
    border-bottom-color: var(--zeheng-nav-border) !important;
}

body[class*="nav-theme-"] .site-header.is-over-hero:not(.is-scrolled) {
    background: transparent !important;
    border-bottom-color: transparent !important;
}

body[class*="nav-theme-"] .site-header.is-over-hero:hover,
body[class*="nav-theme-"] .site-header.is-over-hero.is-scrolled,
body[class*="nav-theme-"] .site-header.is-scrolled,
body[class*="nav-theme-"].menu-open .site-header {
    background: var(--zeheng-nav-bg) !important;
    border-bottom-color: var(--zeheng-nav-border) !important;
}

body[class*="nav-theme-"] .site-brand,
body[class*="nav-theme-"] .brand-text {
    color: var(--zeheng-nav-brand) !important;
}

body[class*="nav-theme-"] .main-nav a,
body[class*="nav-theme-"] .nav-item > a,
body[class*="nav-theme-"] .main-nav > a {
    color: var(--zeheng-nav-link) !important;
}

body[class*="nav-theme-"] .site-header.is-scrolled .main-nav a,
body[class*="nav-theme-"] .site-header.is-scrolled .nav-item > a,
body[class*="nav-theme-"] .site-header.is-scrolled .main-nav > a,
body[class*="nav-theme-"].menu-open .site-header .main-nav a,
body[class*="nav-theme-"].menu-open .site-header .nav-item > a,
body[class*="nav-theme-"].menu-open .site-header .main-nav > a {
    color: var(--zeheng-nav-link) !important;
}

body[class*="nav-theme-"] .main-nav a:hover,
body[class*="nav-theme-"] .nav-item:hover > a,
body[class*="nav-theme-"] .main-nav a[aria-current="page"],
body[class*="nav-theme-"] .mobile-menu a[aria-current="page"] {
    color: var(--zeheng-nav-active) !important;
}

body[class*="nav-theme-"] .site-header.is-scrolled .main-nav a:hover,
body[class*="nav-theme-"] .site-header.is-scrolled .nav-item:hover > a,
body[class*="nav-theme-"] .site-header.is-scrolled .main-nav a[aria-current="page"] {
    color: var(--zeheng-nav-active) !important;
}

body[class*="nav-theme-"] .main-nav a::after,
body[class*="nav-theme-"] .nav-item > a::after,
body[class*="nav-theme-"] .main-nav > a::after {
    background: var(--zeheng-nav-line) !important;
}

body[class*="nav-theme-"] .menu-toggle {
    color: var(--zeheng-nav-toggle) !important;
    border-color: color-mix(in srgb, var(--zeheng-nav-toggle) 28%, transparent) !important;
}

body[class*="nav-theme-"] .site-header.is-over-hero:not(.is-scrolled) .site-brand,
body[class*="nav-theme-"] .site-header.is-over-hero:not(.is-scrolled) .brand-text,
body[class*="nav-theme-"] .site-header.is-over-hero:not(.is-scrolled) .main-nav a,
body[class*="nav-theme-"] .site-header.is-over-hero:not(.is-scrolled) .nav-item > a,
body[class*="nav-theme-"] .site-header.is-over-hero:not(.is-scrolled) .main-nav > a {
    color: rgba(255, 255, 255, 0.9) !important;
}

body[class*="nav-theme-"] .site-header.is-over-hero:not(.is-scrolled) .menu-toggle {
    color: rgba(255, 255, 255, 0.86) !important;
    border-color: rgba(255, 255, 255, 0.3) !important;
}

body[class*="nav-theme-"] .site-header.is-over-hero:not(.is-scrolled) .main-nav a:hover,
body[class*="nav-theme-"] .site-header.is-over-hero:not(.is-scrolled) .nav-item:hover > a,
body[class*="nav-theme-"] .site-header.is-over-hero:not(.is-scrolled) .main-nav a[aria-current="page"] {
    color: var(--zeheng-nav-active) !important;
}

/* Stitch refinement: final lawyer-card editorial hierarchy. */
body.team-directory-page main#main-content [data-lawyer-card] > .flex.justify-between {
    display: block !important;
    padding-top: 18px !important;
    border-top: 1px solid rgba(140, 113, 111, 0.22) !important;
}

body.team-directory-page main#main-content [data-lawyer-name] {
    color: #1a1c1b !important;
    font-family: "Source Serif 4", "Noto Serif SC", serif !important;
    font-size: 24px !important;
    line-height: 1.18 !important;
    font-weight: 500 !important;
    letter-spacing: 0 !important;
    text-align: left !important;
}

body.team-directory-page main#main-content [data-lawyer-role] {
    display: inline-block !important;
    margin-top: 10px !important;
    padding-left: 0 !important;
    border-left: 0 !important;
    color: var(--zeheng-red) !important;
    font-size: 12px !important;
    line-height: 1.4 !important;
    letter-spacing: 0.12em !important;
    text-align: left !important;
}

body.team-directory-page main#main-content [data-lawyer-summary] {
    margin-top: 16px !important;
    margin-bottom: 18px !important;
    color: rgba(68, 71, 72, 0.86) !important;
    font-size: 15px !important;
    line-height: 1.82 !important;
    text-align: left !important;
}

body.team-directory-page main#main-content [data-lawyer-tags] {
    padding-top: 14px !important;
    border-top: 1px solid rgba(140, 113, 111, 0.14) !important;
    color: var(--zeheng-red) !important;
    font-size: 12px !important;
    line-height: 1.7 !important;
    letter-spacing: 0.1em !important;
    text-align: left !important;
}

/* Site-wide IA polish: keep current layouts, make hierarchy quieter and more consistent. */
main .reveal {
    transform: translateY(24px);
    transition: opacity 0.82s ease, transform 0.82s ease;
}

main .reveal.visible {
    transform: translateY(0);
}

main .sidebar,
main .side-panel,
main aside .bg-ink-charcoal,
main aside .bg-deep-obsidian,
main [class*="bg-deep-obsidian"] {
    border-radius: 0 !important;
    box-shadow: none !important;
}

main aside .bg-ink-charcoal,
main aside .bg-deep-obsidian {
    background: #202020 !important;
}

main .case-card,
main .article-card,
main .insight-card,
main .practice-card,
main .service-card,
main .value-card,
main .content-card,
main .news-item,
main .profile-card,
main .portrait-card,
main .lawyer-mini-card {
    border-radius: 0 !important;
    box-shadow: none !important;
}

main .case-card:hover,
main .article-card:hover,
main .insight-card:hover,
main .practice-card:hover,
main .service-card:hover,
main .value-card:hover,
main .content-card:hover,
main .news-item:hover,
main .profile-card:hover,
main .portrait-card:hover,
main .lawyer-mini-card:hover {
    box-shadow: none !important;
}

main h1,
main h2,
main h3 {
    letter-spacing: 0 !important;
}

/* ==========================================================================
   ZEHENG PREMIUM VISUAL & ANIMATION SYSTEM (SOFT BREATHING EDITION)
   ========================================================================== */

/* === 1. Gentle Viewport Enter cubic-bezier (easeOutCubic) === */
main .reveal,
.reveal {
    opacity: 0;
    transform: translateY(14px) !important; /* Reduced from 32px to 14px for extreme gentleness */
    transition: opacity 1.5s cubic-bezier(0.215, 0.61, 0.355, 1), 
                transform 1.5s cubic-bezier(0.215, 0.61, 0.355, 1) !important;
    will-change: transform, opacity;
}

main .reveal.visible,
.reveal.visible {
    opacity: 1 !important;
    transform: translateY(0) !important;
}

/* === 2. High-end Stagger Delay Utilities === */
.stagger-1 { transition-delay: 50ms !important; }
.stagger-2 { transition-delay: 110ms !important; }
.stagger-3 { transition-delay: 170ms !important; }
.stagger-4 { transition-delay: 230ms !important; }
.stagger-5 { transition-delay: 290ms !important; }

/* === 3. Ultra-Smooth Image Zoom & Hover Transition === */
body.team-directory-page [data-lawyer-photo-frame] img,
.team-card-photo img,
.lawyer-mini-card img,
.aspect-\[16\/9\] img,
.aspect-\[21\/9\] img,
.about-stitch-intro-media img {
    transition: transform 1.8s cubic-bezier(0.215, 0.61, 0.355, 1), 
                filter 0.8s ease !important;
}

/* === 4. Extremely Gentle Floating Transition for Lawyer Cards === */
body.team-directory-page [data-lawyer-card] {
    transition: transform 1.2s cubic-bezier(0.215, 0.61, 0.355, 1), 
                color 0.28s ease !important;
}

body.team-directory-page [data-lawyer-card]:hover {
    transform: translateY(-4px) !important; /* Gentle 4px float instead of the aggressive 8px */
}

/* === 5. Header Scroll Transition Smoothing === */
.site-header {
    transition: background-color 0.8s cubic-bezier(0.215, 0.61, 0.355, 1),
                backdrop-filter 0.8s cubic-bezier(0.215, 0.61, 0.355, 1),
                border-color 0.8s cubic-bezier(0.215, 0.61, 0.355, 1) !important;
}

/* === 6. Interactive Video Modal Overlay System === */
.video-modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(10, 20, 40, 0.82);
    backdrop-filter: blur(12px);
    z-index: 9999;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.6s cubic-bezier(0.215, 0.61, 0.355, 1);
    display: flex;
    align-items: center;
    justify-content: center;
}

.video-modal-overlay.is-active {
    opacity: 1;
    pointer-events: auto;
}

.video-modal-container {
    position: relative;
    width: min(90%, 960px);
    aspect-ratio: 16 / 9;
    background: #000;
    border: 1px solid rgba(184, 159, 111, 0.24);
    transform: scale(0.95);
    transition: transform 0.6s cubic-bezier(0.215, 0.61, 0.355, 1);
    box-shadow: 0 24px 80px rgba(0, 0, 0, 0.8);
}

.video-modal-overlay.is-active .video-modal-container {
    transform: scale(1);
}

.video-modal-container video {
    width: 100%;
    height: 100%;
    display: block;
}

.video-modal-close {
    position: absolute;
    top: -48px;
    right: 0;
    width: 36px;
    height: 36px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.4);
    background: rgba(255, 255, 255, 0.15);
    color: #fff;
    font-size: 20px;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background-color 0.2s, border-color 0.2s, transform 0.2s;
}

.video-modal-close:hover {
    background: rgba(255, 255, 255, 0.25);
    border-color: #fff;
    transform: scale(1.05);
}

@media (max-width: 640px) {
    .video-modal-close {
        top: auto;
        bottom: -56px;
        right: 50%;
        transform: translateX(50%);
    }
    .video-modal-overlay.is-active .video-modal-close {
        transform: translateX(50%) scale(1);
    }
    .video-modal-close:hover {
        transform: translateX(50%) scale(1.05);
    }
}

/* ==========================================================================
   MINIMALIST EDITORIAL & CLEAN AESTHETICS UPGRADE (大气简约干净)
   ========================================================================== */

/* === 1. Warm Editorial Paper Background === */
body,
.bg-surface,
.bg-background,
.bg-paper-white,
.team-directory-page {
    background-color: #faf8f5 !important;
}

/* === 2. Airy Typography: Spacing & Line Height === */
main h1, main h2, main h3,
.font-display-lg, .font-headline-lg, .font-headline-md {
    letter-spacing: 0.04em !important;
}

/* Subsection Eyebrows & Meta Labels */
.section-eyebrow, 
.font-label-caps, 
.text-label-caps,
.about-stitch-intro-kicker,
.about-section-tag {
    letter-spacing: 0.18em !important;
    text-transform: uppercase !important;
}

/* Softer & Wider Body Paragraphs */
main p, 
.font-body-md, 
.font-body-lg,
.team-card-summary,
.about-stitch-intro-copy p {
    line-height: 1.88 !important;
    color: rgba(44, 44, 44, 0.72) !important;
}

/* Restore soft paper-white color for text inside dark backgrounds */
[data-purpose="hero-section"] p,
.about-hero p,
.about-hero .font-body-lg,
.bg-deep-blue p,
.side-panel.dark,
.side-panel.dark p,
.text-paper-white,
.text-white {
    color: rgba(255, 255, 255, 0.86) !important;
}

/* === 3. Architectural Straight Edges (直角美学) === */
main .rounded,
main .rounded-lg,
main .rounded-sm,
main .rounded-xl,
main .rounded-full,
main [class*="rounded-"],
.about-academic-frame,
.team-card,
.team-card-photo,
.lawyer-mini-card,
.about-stitch-intro-media,
[data-lawyer-photo-frame],
.video-modal-container {
    border-radius: 0 !important;
}

/* === 4. Flat Design (去除全站投影与浮空杂影) === */
main .shadow,
main .shadow-sm,
main .shadow-lg,
main .shadow-xl,
main [class*="shadow-"],
.team-card,
.lawyer-mini-card,
[data-lawyer-photo-frame] {
    box-shadow: none !important;
}

/* === 5. Hairline Micro-Borders (极细微光分割线) === */
.border,
.border-t,
.border-b,
.border-l,
.border-r,
.border-surface-dim,
[class*="border-"] {
    border-color: rgba(139, 20, 22, 0.08) !important;
}

/* === 6. High-end Photo Desaturation & Contrast === */
main img,
.team-card-photo img,
.lawyer-mini-card img,
.about-stitch-intro-media img,
[data-lawyer-photo-frame] img {
    filter: saturate(0.88) contrast(1.02) !important;
}

/* === 7. Clean Navigation Highlights === */
.main-nav a::after,
.nav-item > a::after {
    height: 1px !important;
    background: var(--zeheng-red) !important;
}

/* ==========================================================================
   HERO TEXT READABILITY & CONTRAST ENHANCEMENT (首屏文案高对比度易读性防护)
   ========================================================================== */

/* 3. 提升文案颜色为纯白，并融入极细腻的抗锯齿多层阴影保护 */
.about-hero h1,
[data-purpose="hero-section"] h1,
.about-hero p,
[data-purpose="hero-section"] p,
.about-hero .font-body-lg,
[data-purpose="hero-section"] .font-body-lg,
.about-hero .text-on-primary\/90,
[data-purpose="hero-section"] .text-on-primary\/90 {
    color: #ffffff !important;
    text-shadow: 
        0 2px 10px rgba(0, 0, 0, 0.78),
        0 1px 3px rgba(0, 0, 0, 0.6) !important;
}

/* 4. 优化微金分割线亮度，确保视觉呼吸感一致 */
.about-hero .bg-secondary,
[data-purpose="hero-section"] .bg-secondary {
    background-color: #cbb07f !important; /* 提升至明亮高级暖金色 */
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.35) !important;
}

/* ==========================================================================
   SUBPAGE PREMIUM INTERACTIVE & 美学微动效重构系统
   ========================================================================== */

/* === 1. 💼 业务领域页 (practice.html) === */

.practice-panel {
    position: relative;
    padding-left: 24px !important;
    transition: transform 0.6s cubic-bezier(0.215, 0.61, 0.355, 1) !important;
}

.practice-panel::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 2px;
    height: 0%;
    background-color: #cbb07f;
    transition: height 0.6s cubic-bezier(0.215, 0.61, 0.355, 1);
}

.practice-panel:hover {
    transform: translateY(-4px) !important;
}

.practice-panel:hover::before {
    height: 100%;
}

/* Sibling image inner zoom when text panel or section is hovered */
main section:has(.practice-panel:hover) img,
main section#civil:hover img,
main section#criminal-detail:hover img {
    transform: scale(1.04) !important;
    filter: saturate(1) contrast(1.02) grayscale(0) !important;
}

/* List dot shifts */
.practice-list-square {
    transition: transform 0.4s cubic-bezier(0.215, 0.61, 0.355, 1), 
                color 0.4s ease !important;
}

.practice-list-square:hover {
    transform: translateX(4px) !important;
    color: #1a1c1b !important;
}

.practice-list-square::before {
    transition: transform 0.4s cubic-bezier(0.215, 0.61, 0.355, 1), 
                background-color 0.4s ease, 
                box-shadow 0.4s ease !important;
}

.practice-list-square:hover::before {
    background-color: #cbb07f !important;
    box-shadow: 0 0 8px rgba(203, 176, 127, 0.8) !important;
}

/* === 2. 👥 专业团队页 (lawyers.html) === */

[data-lawyer-page-status] {
    transition: opacity 0.4s cubic-bezier(0.215, 0.61, 0.355, 1), 
                transform 0.4s cubic-bezier(0.215, 0.61, 0.355, 1) !important;
}

[data-lawyer-page-status]:not(:empty) {
    opacity: 0.86 !important;
    transform: translateY(0) !important;
}

body.team-directory-page [data-lawyer-card] [data-lawyer-photo-frame] {
    overflow: hidden;
    border-color: rgba(203, 176, 127, 0.15) !important;
    transition: border-color 0.6s ease, box-shadow 0.6s ease !important;
}

body.team-directory-page [data-lawyer-card]:hover [data-lawyer-photo-frame] {
    border-color: rgba(203, 176, 127, 0.5) !important;
    box-shadow: 0 8px 24px -6px rgba(139, 20, 22, 0.15) !important;
}

body.team-directory-page [data-lawyer-card] img {
    filter: saturate(0.8) contrast(1.01) !important;
    transition: transform 1.2s cubic-bezier(0.215, 0.61, 0.355, 1), 
                filter 0.6s ease !important;
}

body.team-directory-page [data-lawyer-card]:hover img {
    transform: scale(1.03) !important;
    filter: saturate(1) contrast(1.02) !important;
}

/* === 3. ⚖️ 律师详情页 (lawyer-detail.html) === */

[data-lawyer-highlight-card] {
    position: relative;
    padding-left: 24px !important;
    background-color: #faf8f5 !important;
    border-color: rgba(139, 20, 22, 0.08) !important;
    transition: background-color 0.5s ease, 
                border-color 0.5s ease, 
                transform 0.5s ease, 
                box-shadow 0.5s ease !important;
}

[data-lawyer-highlight-card]::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 0;
    height: 100%;
    background-image: linear-gradient(to bottom, #8b1b1b, #cbb07f);
    transition: width 0.4s cubic-bezier(0.215, 0.61, 0.355, 1);
}

[data-lawyer-highlight-card]:hover {
    background-color: #1c1d1f !important;
    border-color: transparent !important;
    transform: translateY(-2px);
    box-shadow: 0 12px 32px -8px rgba(0, 0, 0, 0.15) !important;
}

[data-lawyer-highlight-card]:hover::before {
    width: 3px;
}

[data-lawyer-highlight-card] h3,
[data-lawyer-highlight-card] p {
    transition: color 0.4s ease !important;
}

[data-lawyer-highlight-card]:hover h3 {
    color: #ffffff !important;
}

[data-lawyer-highlight-card]:hover p {
    color: rgba(255, 255, 255, 0.72) !important;
}

main section [data-lawyer-photo-frame] {
    position: relative;
    border-color: rgba(203, 176, 127, 0.28) !important;
    box-shadow: 
        0 0 0 1px rgba(203, 176, 127, 0.12),
        0 12px 40px -12px rgba(139, 20, 22, 0.08) !important;
    transition: box-shadow 0.8s cubic-bezier(0.215, 0.61, 0.355, 1), 
                border-color 0.8s cubic-bezier(0.215, 0.61, 0.355, 1) !important;
}

main section [data-lawyer-photo-frame]:hover {
    border-color: rgba(203, 176, 127, 0.6) !important;
    box-shadow: 
        0 0 0 1px rgba(203, 176, 127, 0.28),
        0 20px 48px -10px rgba(139, 20, 22, 0.18) !important;
}

/* === 4. 📞 联系我们页 (contact.html) === */

/* Form input border override */
body.nav-theme-office form[data-contact-form] input:focus,
body.nav-theme-office form[data-contact-form] textarea:focus {
    border-color: rgba(139, 20, 22, 0.08) !important;
    box-shadow: none !important;
    outline: none !important;
}

.input-focus-line {
    position: absolute;
    bottom: 0;
    left: 50%;
    width: 0;
    height: 1.5px;
    background-color: #cbb07f;
    transition: width 0.4s cubic-bezier(0.25, 1, 0.5, 1), 
                left 0.4s cubic-bezier(0.25, 1, 0.5, 1);
    pointer-events: none;
}

form[data-contact-form] input:focus ~ .input-focus-line,
form[data-contact-form] textarea:focus ~ .input-focus-line {
    width: 100%;
    left: 0;
}

[data-hiring-card] {
    transition: transform 0.6s cubic-bezier(0.215, 0.61, 0.355, 1), 
                box-shadow 0.6s cubic-bezier(0.215, 0.61, 0.355, 1), 
                border-color 0.4s ease !important;
}

[data-hiring-card]:hover {
    transform: translateY(-4px) !important;
    border-color: rgba(203, 176, 127, 0.6) !important;
    box-shadow: 0 12px 32px -8px rgba(139, 20, 22, 0.08) !important;
}

[data-hiring-card] a span.material-symbols-outlined {
    transition: transform 0.4s cubic-bezier(0.215, 0.61, 0.355, 1) !important;
}

[data-hiring-card]:hover a span.material-symbols-outlined {
    transform: translate(2px, -2px) !important;
}


