:root {
    --mx-sidebar-width: 88px;
    --mx-violet: #713dea;
    --mx-violet-soft: #ab7aff;
    --mx-ink: #1f2937;
    --mx-ink-soft: #4b5563;
    --mx-surface-soft: #f8f7fb;
    --mx-surface-strong: #ffffff;
    --mx-button-primary-bg: linear-gradient(135deg, #202631 0%, #3c4657 100%);
    --mx-button-primary-hover: linear-gradient(135deg, #252d39 0%, #475365 100%);
    --mx-button-secondary-bg: rgba(255, 255, 255, 0.94);
    --mx-button-secondary-border: rgba(148, 163, 184, 0.22);
    --mx-page-bg: linear-gradient(180deg, #fdf9fe 0%, #f6f5f9 37%, #fdf9fe 100%);
    --mx-panel-bg: #ffffff;
    --mx-border: #ece8f6;
    --mx-shadow: 0 18px 40px rgba(31, 23, 60, 0.1);
    --mx-shadow-strong: 0 18px 52px rgba(31, 23, 60, 0.2);
}

html {
    scroll-behavior: smooth;
}

body.page-home,
body.page-normal {
    background: var(--mx-page-bg);
    color: #191919;
}

body.page-home .global-announcement-bar,
body.page-normal .global-announcement-bar {
    display: none !important;
}

body.page-home .navbar,
body.page-normal .navbar {
    position: fixed;
    left: 0;
    top: 36px;
    width: var(--mx-sidebar-width);
    height: calc(100vh - 36px);
    border: none;
    box-shadow: none;
    background: transparent;
    z-index: 120;
}

body.page-home .nav-container,
body.page-normal .nav-container {
    position: relative;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    padding: 4px 4px 12px;
}

body.page-home .nav-container::before,
body.page-normal .nav-container::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 0;
    background: rgba(246, 245, 250, 0.82);
    border: 1px solid rgba(221, 217, 232, 0.9);
    box-shadow: 0 8px 22px rgba(36, 28, 70, 0.08);
    backdrop-filter: blur(8px);
    z-index: -1;
}

body.page-home .nav-brand,
body.page-normal .nav-brand {
    width: 80px;
    height: 84px;
    padding-top: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
}

body.page-home .nav-brand .mx-brand-logo,
body.page-normal .nav-brand .mx-brand-logo {
    width: 56px;
    height: 56px;
    object-fit: contain;
    filter: drop-shadow(0 4px 8px rgba(37, 30, 72, 0.12));
}

body.page-home .nav-brand .logo,
body.page-normal .nav-brand .logo {
    display: none;
}

body.page-home .nav-brand h1,
body.page-home .nav-brand .version,
body.page-normal .nav-brand h1,
body.page-normal .nav-brand .version {
    display: none;
}

body.page-home .nav-links,
body.page-normal .nav-links {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    margin: 0;
    width: 40px;
    overflow: visible;
}

body.page-home .nav-link,
body.page-normal .nav-link {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    gap: 0;
    width: 40px;
    min-height: 60px;
    padding: 0;
    border-radius: 8px;
    text-decoration: none;
    color: rgba(0, 0, 0, 0.65);
    background: transparent;
    transition: all 0.2s ease;
}

body.page-home .nav-link::after,
body.page-normal .nav-link::after {
    display: none;
}

body.page-home .nav-link .mx-nav-icon,
body.page-normal .nav-link .mx-nav-icon {
    width: 40px;
    height: 40px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    line-height: 1;
    transition: all 0.2s ease;
}

body.page-home .nav-link .mx-nav-icon img,
body.page-normal .nav-link .mx-nav-icon img {
    width: 20px;
    height: 20px;
    object-fit: contain;
}

body.page-home .nav-link .mx-nav-label,
body.page-normal .nav-link .mx-nav-label {
    margin-top: 0;
    font-size: 11px;
    line-height: 20px;
    font-weight: 400;
    color: rgba(16, 12, 31, 0.56);
    letter-spacing: 0.2px;
    white-space: nowrap;
}

body.page-home .nav-link .mx-nav-legacy,
body.page-normal .nav-link .mx-nav-legacy {
    display: none;
}

body.page-home .nav-link:hover .mx-nav-icon,
body.page-normal .nav-link:hover .mx-nav-icon {
    background: rgba(113, 61, 234, 0.07);
}

body.page-home .nav-link.active .mx-nav-icon,
body.page-home .nav-link.hot .mx-nav-icon,
body.page-normal .nav-link.active .mx-nav-icon,
body.page-normal .nav-link.hot .mx-nav-icon {
    background: #ffffff;
    color: var(--mx-violet);
}

body.page-home .nav-link.active .mx-nav-label,
body.page-home .nav-link.hot .mx-nav-label,
body.page-normal .nav-link.active .mx-nav-label,
body.page-normal .nav-link.hot .mx-nav-label {
    color: var(--mx-violet);
    font-weight: 500;
}

body.page-home .nav-auth,
body.page-normal .nav-auth {
    width: 100%;
    margin: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
}

body.page-home .nav-notification,
body.page-normal .nav-notification,
body.page-history .nav-notification,
body.page-community .nav-notification {
    margin: 0;
}

body.page-home .notification-bell,
body.page-normal .notification-bell,
body.page-history .notification-bell,
body.page-community .notification-bell {
    width: 32px;
    height: 32px;
    border-radius: 8px;
    border: 1px solid rgba(0, 0, 0, 0.08);
    background: rgba(255, 255, 255, 0.9);
    color: rgba(0, 0, 0, 0.65);
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

body.page-home .notification-dropdown,
body.page-normal .notification-dropdown {
    left: var(--mx-sidebar-width);
    right: auto;
    top: 0;
    bottom: 0;
    width: clamp(460px, 33vw, 720px);
    max-width: calc(100vw - var(--mx-sidebar-width));
}

body.page-home #normalThemeToggle,
body.page-normal #normalThemeToggle {
    display: inline-flex !important;
    width: 60px;
    height: 30px;
    border-radius: 999px;
    border: 1px solid rgba(113, 61, 234, 0.22);
    background: linear-gradient(180deg, #f8f7fc 0%, #f1eff9 100%);
    box-shadow: 0 6px 16px rgba(39, 28, 77, 0.12);
    padding: 0 8px;
    align-items: center;
    justify-content: space-between;
}

body.page-home #normalThemeToggle .theme-toggle-thumb,
body.page-normal #normalThemeToggle .theme-toggle-thumb {
    width: 20px;
    height: 20px;
    top: 4px;
    left: 4px;
    box-shadow: 0 4px 12px rgba(29, 20, 60, 0.2);
}

body.page-home #normalThemeToggle[data-mode="night"] .theme-toggle-thumb,
body.page-normal #normalThemeToggle[data-mode="night"] .theme-toggle-thumb {
    transform: translateX(30px);
}

body.page-home #normalThemeToggle .theme-toggle-icon,
body.page-normal #normalThemeToggle .theme-toggle-icon {
    width: 14px;
    height: 14px;
}

body.page-home .nav-user,
body.page-normal .nav-user {
    display: none;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    width: 60px;
    padding: 4px 2px;
    border: none;
    background: transparent;
}

body.page-home .nav-user::before,
body.page-home .nav-user::after,
body.page-normal .nav-user::before,
body.page-normal .nav-user::after {
    display: none;
}

body.page-home .nav-username,
body.page-normal .nav-username {
    max-width: 60px;
    font-size: 10px;
    line-height: 1.2;
    text-align: center;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

body.page-home .nav-auth .btn,
body.page-normal .nav-auth .btn {
    width: 60px;
    min-height: 28px;
    padding: 0 4px;
    border-radius: 8px;
    font-size: 12px;
    line-height: 1;
    justify-content: center;
}

body.page-home .contact-support,
body.page-normal .contact-support {
    right: 18px;
    bottom: 18px;
}

/* Home page */
body.page-home .mx-home-main {
    margin-left: var(--mx-sidebar-width);
    min-height: 100vh;
    border-radius: 24px 0 0 24px;
    background: var(--mx-panel-bg);
    overflow: hidden;
}

body.page-home .mx-home-wrap {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 20px;
    padding: 64px 24px 24px;
}

body.page-home .mx-home-hero {
    text-align: center;
}

body.page-home .mx-home-title {
    margin: 0;
    font-size: 36px;
    line-height: 1.3;
    font-weight: 500;
    color: #191919;
}

body.page-home .mx-home-model-icons {
    margin: 10px auto 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

body.page-home .mx-home-model-icons img {
    width: 24px;
    height: 24px;
    border-radius: 999px;
    object-fit: cover;
    border: 1px solid rgba(113, 61, 234, 0.16);
    background: #f5f4fa;
    box-shadow: 0 2px 10px rgba(43, 29, 86, 0.08);
}

body.page-home .mx-home-model-line {
    margin-top: 8px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 5px 14px;
    border-radius: 999px;
    background: linear-gradient(120deg, rgba(113, 61, 234, 0.1), rgba(33, 126, 253, 0.08));
    border: 1px solid rgba(113, 61, 234, 0.24);
    font-size: 12px;
    color: #5e5098;
}

body.page-home .mx-home-subtitle {
    margin: 12px 0 0;
    min-height: 31px;
    font-size: 20px;
    line-height: 31px;
    background: linear-gradient(90deg, #1e1e20 50%, #217efd 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

body.page-home #heroTypewriter {
    display: block;
    min-height: 31px;
}

body.page-home .mx-home-composer {
    width: min(792px, calc(100vw - 180px));
    margin: 0 auto;
    position: relative;
}

body.page-home .mx-home-tabs {
    position: absolute;
    top: -50px;
    left: 10px;
    display: inline-flex;
    align-items: center;
    gap: 2px;
    padding: 4px;
    border-radius: 12px;
    border: 1px solid #ebe7f5;
    background: linear-gradient(180deg, #f6f5f9 0%, #f1eff7 100%);
    box-shadow: 0 8px 18px rgba(39, 29, 78, 0.08);
    z-index: 4;
}

body.page-home .mx-home-tab {
    width: 150px;
    height: 44px;
    margin-right: 0;
    border-radius: 10px;
    border: 1px solid transparent;
    background: transparent;
    color: rgba(0, 0, 0, 0.65);
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 0 12px;
    transition: all 0.2s ease;
}

body.page-home .mx-home-tab.active {
    background: #ffffff;
    color: var(--mx-violet);
    border-color: rgba(113, 61, 234, 0.24);
    box-shadow: 0 4px 12px rgba(113, 61, 234, 0.12);
    z-index: 2;
}

body.page-home .mx-home-tab .mx-tab-icon {
    width: 20px;
    height: 20px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

body.page-home .mx-home-tab .mx-tab-icon svg {
    width: 20px;
    height: 20px;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.6;
    stroke-linecap: round;
    stroke-linejoin: round;
}

body.page-home .mx-home-composer-panel {
    border-radius: 24px;
    border: 1px solid rgba(113, 61, 234, 0.68);
    background: #ffffff;
    box-shadow: 0 10px 24px rgba(80, 49, 174, 0.08);
    padding: 13px;
    min-height: 214px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

body.page-home .mx-home-input-row {
    display: flex;
    gap: 12px;
    align-items: flex-start;
    flex: 1;
}

body.page-home .mx-home-upload {
    width: 60px;
    height: 72px;
    border: 1px dashed #cfcfd8;
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #fafafa;
    cursor: pointer;
    color: rgba(0, 0, 0, 0.58);
    font-size: 30px;
    flex-shrink: 0;
    margin-bottom: 12px;
}

body.page-home .mx-home-upload:hover {
    border-color: rgba(113, 61, 234, 0.35);
    background: #f7f3ff;
}

body.page-home .mx-home-upload > span.mx-home-upload-empty:not(.mx-home-upload-card):not(.mx-home-upload-count) {
    transform: translateY(-2px);
}

body.page-home .mx-home-upload input {
    display: none;
}

body.page-home #mxHomePrompt {
    flex: 1;
    min-height: 84px;
    max-height: 124px;
    border: none;
    outline: none;
    resize: vertical;
    padding: 5px 0 10px;
    font-size: 14px;
    line-height: 22px;
    color: rgba(0, 0, 0, 0.82);
    font-family: "SF Pro Text", "PingFang SC", "Helvetica Neue", Arial, sans-serif;
}

body.page-home #mxHomePrompt::placeholder {
    color: #bfbfbf;
}

body.page-home #mxHomePrompt:focus-visible {
    outline: none;
}

body.page-home .mx-home-toolbar {
    margin-top: 2px;
    display: flex;
    align-items: center;
    gap: 8px;
}

body.page-home .mx-home-model {
    position: relative;
}

body.page-home #mxHomeModelTrigger {
    height: 36px;
    border-radius: 24px;
    border: 1px solid #f3f3f5;
    background: #ffffff;
    padding: 0 9px 0 12px;
    font-size: 12px;
    color: rgba(0, 0, 0, 0.88);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

body.page-home #mxHomeModelTrigger img {
    width: 16px;
    height: 16px;
    object-fit: cover;
    border-radius: 999px;
}

body.page-home #mxHomeModelTriggerText {
    line-height: 20px;
    font-weight: 500;
}

body.page-home .mx-trigger-arrow {
    opacity: 0.65;
    font-size: 12px;
}

body.page-home #mxHomeModelMenu {
    display: none;
    position: absolute;
    left: 0;
    top: calc(100% + 10px);
    width: min(590px, calc(100vw - 220px));
    max-height: min(64vh, 480px);
    overflow-y: auto;
    background: #ffffff;
    border: 1px solid #e8e7ea;
    border-radius: 8px;
    box-shadow:
        0 6px 16px rgba(0, 0, 0, 0.08),
        0 3px 6px -4px rgba(0, 0, 0, 0.12),
        0 9px 28px 8px rgba(0, 0, 0, 0.05);
    padding: 16px 16px 16px 176px;
    z-index: 2400;
}

body.page-home #mxHomeModelMenu.show {
    display: block;
}

body.page-home .mx-home-model-option {
    width: 100%;
    border: none;
    background: transparent;
    text-align: left;
    font-size: 12px;
    color: rgba(0, 0, 0, 0.72);
    border-radius: 12px;
    padding: 13px;
    cursor: pointer;
    display: block;
    border: 1px solid #f3f3f5;
}

body.page-home .mx-home-model-option:last-child {
    border-bottom: 1px solid #f3f3f5;
}

body.page-home .mx-home-model-group {
    display: block;
    position: static;
}

body.page-home .mx-home-model-group + .mx-home-model-group {
    margin-top: 0;
}

body.page-home .mx-home-model-group-head {
    position: absolute;
    left: 16px;
    width: 148px;
    min-height: 96px;
    padding: 16px 10px;
    border: 1px solid rgba(228, 224, 241, 0.95);
    border-radius: 12px;
    background: #f8f8f9;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    cursor: pointer;
    transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

body.page-home .mx-home-model-group[data-group="reference"] .mx-home-model-group-head {
    top: 16px;
}

body.page-home .mx-home-model-group[data-group="text"] .mx-home-model-group-head {
    top: 118px;
}

body.page-home .mx-home-model-group[data-group="video"] .mx-home-model-group-head {
    top: 16px;
    min-height: 96px;
}

body.page-home .mx-home-model-group-title {
    font-size: 14px;
    font-weight: 700;
    line-height: 1.35;
    color: rgba(0, 0, 0, 0.65);
}

body.page-home .mx-home-model-group[data-group="reference"] .mx-home-model-group-title {
    color: rgba(0, 0, 0, 0.65);
}

body.page-home .mx-home-model-group[data-group="text"] .mx-home-model-group-title {
    color: rgba(0, 0, 0, 0.65);
}

body.page-home .mx-home-model-group-sub {
    margin-top: 3px;
    font-size: 11px;
    line-height: 20px;
    color: rgba(26, 15, 52, 0.5);
}

body.page-home .mx-home-model-group-head.is-active {
    border-color: #c9b3fe;
    background: linear-gradient(180deg, #ccf4ff 0%, #efebf9 100%);
}

body.page-home .mx-home-model-group-head.is-active .mx-home-model-group-title {
    color: #1a93b3;
}

body.page-home .mx-home-model-group-head.is-inactive {
    background: #f8f8f9;
}

body.page-home .mx-home-model-group-head:focus-visible {
    outline: 2px solid rgba(137, 82, 232, 0.42);
    outline-offset: 1px;
}

body.page-home .mx-home-model-group-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

body.page-home .mx-home-model-option-main {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 6px;
}

body.page-home .mx-home-model-left {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    min-width: 0;
    flex: 1 1 auto;
}

body.page-home .mx-home-model-title-wrap {
    min-width: 0;
}

body.page-home .mx-home-model-title {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    line-height: 22px;
    font-weight: 700;
    color: #1f2436;
}

body.page-home .mx-home-model-badge {
    height: 18px;
    padding: 0 6px;
    border-radius: 999px;
    font-size: 11px;
    line-height: 18px;
    font-weight: 700;
    color: #ffffff;
    background: linear-gradient(135deg, #2fcd7c 0%, #17a85f 100%);
}

body.page-home .mx-home-model-badge.mx-home-model-badge-hot {
    background: linear-gradient(135deg, #f59e0b 0%, #ef4444 100%);
}

body.page-home .mx-home-model-desc {
    margin-top: 2px;
    font-size: 12px;
    line-height: 20px;
    color: #687389;
}

body.page-home .mx-home-model-cost {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    font-size: 13px;
    font-weight: 700;
    color: #6e778f;
    line-height: 1;
    white-space: nowrap;
}

body.page-home .mx-home-model-cost-icon {
    color: #f4b401;
    font-size: 12px;
}

body.page-home .mx-home-model-cap-row {
    margin-top: 4px;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 4px;
}

body.page-home .mx-home-model-cap-chip {
    height: 24px;
    padding: 0 6px;
    border-radius: 4px;
    border: 1px solid transparent;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    line-height: 1;
    font-weight: 600;
}

body.page-home .mx-home-model-cap-chip.is-supported {
    color: #1a93b3;
    background: #efebf9;
    border-color: #bee9f4;
}

body.page-home .mx-home-model-cap-chip.is-unsupported {
    color: rgba(26, 15, 52, 0.5);
    background: #ffffff;
    border-color: #e8e7eb;
}

body.page-home .mx-home-model-option img {
    width: 28px;
    height: 28px;
    border-radius: 999px;
    object-fit: cover;
    flex-shrink: 0;
}

/* ========== Entry Banana Pro 合并卡片 - 胶囊切换器 ========== */
/* ========== Entry Banana Pro 合并卡片 ========== */
body.page-home .entry-banana-merged {
    display: block;
    cursor: default;
}

body.page-home .entry-banana-merged .mx-home-model-option-main {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 6px;
}

body.page-home .entry-banana-merged .mx-home-model-left {
    flex: 1 1 auto;
    min-width: 0;
}

body.page-home .entry-banana-merged .entry-banana-mode-desc {
    color: #888;
}

/* 胶囊独占一行左对齐 */
body.page-home .entry-banana-speed-switch {
    display: inline-flex;
    position: relative;
    padding: 3px;
    border-radius: 999px;
    background: transparent;
    border: none;
    flex-shrink: 0;
    margin-top: 4px;
    gap: 2px;
}

body.page-home .entry-banana-speed-slider {
    position: absolute;
    top: 3px;
    bottom: 3px;
    left: 3px;
    width: 76px;
    border-radius: 999px;
    background: #fff;
    box-shadow: 0 1px 6px rgba(0, 0, 0, 0.10), 0 0 0 0.5px rgba(0, 0, 0, 0.04);
    transition: left 0.24s cubic-bezier(0.4, 0, 0.2, 1), width 0.24s cubic-bezier(0.4, 0, 0.2, 1);
    pointer-events: none;
    z-index: 0;
}

body.page-home .entry-banana-speed-item {
    flex: 0 0 auto;
    position: relative;
    z-index: 1;
}

body.page-home .entry-banana-speed-option {
    display: flex;
    align-items: center;
    gap: 3px;
    padding: 5px 10px;
    border-radius: 999px;
    border: 0;
    background: transparent;
    color: rgba(0, 0, 0, 0.32);
    cursor: pointer;
    transition: color 0.18s ease;
    white-space: nowrap;
    line-height: 1;
}

body.page-home .entry-banana-speed-option:hover {
    color: rgba(0, 0, 0, 0.56);
}

body.page-home .entry-banana-speed-item.is-active .entry-banana-speed-option {
    color: #111;
    font-weight: 700;
}

body.page-home .entry-banana-speed-label {
    font-size: 12px;
    font-weight: 600;
    line-height: 1.2;
}

body.page-home .entry-banana-speed-item.is-active .entry-banana-speed-label {
    font-weight: 800;
}

body.page-home .entry-banana-speed-cost {
    font-size: 10px;
    font-weight: 600;
    color: rgba(0, 0, 0, 0.18);
    line-height: 1;
}

body.page-home .entry-banana-speed-item.is-active .entry-banana-speed-cost {
    color: #e5a400;
}

body.page-home .entry-banana-speed-tooltip {
    position: absolute;
    z-index: 1000;
    bottom: calc(100% + 10px);
    left: 50%;
    transform: translateX(-50%);
    width: max-content;
    max-width: 220px;
    padding: 10px 12px;
    border-radius: 12px;
    background: #1a1a1a;
    color: rgba(255, 255, 255, 0.92);
    font-size: 11px;
    line-height: 1.6;
    box-shadow: 0 14px 36px rgba(0, 0, 0, 0.28);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.16s ease;
    text-align: left;
}

body.page-home .entry-banana-speed-tooltip::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: -5px;
    transform: translateX(-50%) rotate(45deg);
    width: 10px;
    height: 10px;
    background: #1a1a1a;
}

body.page-home .entry-banana-speed-item:hover .entry-banana-speed-tooltip {
    opacity: 1;
    pointer-events: auto;
}

body.page-home .mx-home-model-option:hover,
body.page-home .mx-home-model-option.active {
    background: #ffffff;
}

body.page-home .mx-home-model-option.active {
    border-color: #c9b3fe;
    background-image: linear-gradient(-60deg, #ffffff 0%, #ffffff 40%, #f3f3f5 100%);
}

body.page-home .mx-home-chip {
    height: 36px;
    border-radius: 24px;
    border: 1px solid #f3f3f5;
    background: #ffffff;
    padding: 0 12px;
    font-size: 12px;
    color: rgba(0, 0, 0, 0.8);
    display: inline-flex;
    align-items: center;
    white-space: nowrap;
    gap: 6px;
}

body.page-home .mx-home-setting-chip {
    padding-right: 9px;
}

body.page-home .mx-home-chip-divider {
    width: 1px;
    height: 12px;
    background: #e0e0e0;
}

body.page-home .mx-home-chip.accent {
    background: #ffffff;
    border-color: #f3f3f5;
    color: #8657cf;
    gap: 4px;
    cursor: pointer;
    transition: all 0.15s ease;
}

body.page-home .mx-home-chip.accent:hover {
    border-color: #e3d5ff;
    background: #fcf9ff;
}

body.page-home .mx-home-chip.accent:disabled {
    opacity: 0.72;
    cursor: not-allowed;
}

body.page-home .mx-home-chip.accent.is-loading .mx-home-chip-text {
    opacity: 0.85;
}

body.page-home .mx-home-chip.accent .mx-chip-icon {
    background: linear-gradient(90deg, #a971ff 0%, #e87fc2 97%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

body.page-home #mxHomeGenerateBtn {
    margin-left: auto;
    width: 60px;
    height: 36px;
    border: 1px solid rgba(15, 23, 42, 0.18);
    border-radius: 20px;
    background: #9ca3af;
    color: #111827;
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    box-shadow: 0 2px 8px rgba(15, 23, 42, 0.12), inset 0 1px 0 rgba(255, 255, 255, 0.3);
    transition: all 0.15s ease;
}

body.page-home #mxHomeGenerateBtn.is-ready {
    background: #6b7280;
    color: #111827;
    border-color: rgba(15, 23, 42, 0.2);
}

body.page-home #mxHomeGenerateBtn.is-ready:hover {
    background: #4b5563;
    color: #111827;
    box-shadow: 0 4px 12px rgba(15, 23, 42, 0.18), inset 0 1px 0 rgba(255, 255, 255, 0.22);
    transform: translateY(-1px);
}

body.page-home #mxHomeGenerateBtn:not(.is-ready):hover {
    background: #9ca3af;
    color: #111827;
}

body.page-home .mx-home-templates-wrapper {
    position: relative;
    margin-top: 8px;
}

body.page-home .mx-home-templates-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 24px 12px;
}

body.page-home .mx-home-templates-title {
    font-size: 16px;
    font-weight: 600;
    color: #191919;
}

body.page-home .mx-home-templates-more {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 6px 12px;
    border-radius: 999px;
    border: 1px solid rgba(113, 61, 234, 0.24);
    background: rgba(113, 61, 234, 0.06);
    color: var(--mx-violet);
    font-size: 13px;
    font-weight: 500;
    text-decoration: none;
    transition: all 0.2s ease;
}

body.page-home .mx-home-templates-more:hover {
    background: rgba(113, 61, 234, 0.12);
    border-color: rgba(113, 61, 234, 0.35);
}

body.page-home .mx-home-templates {
    display: flex;
    gap: 16px;
    overflow-x: auto;
    overflow-y: hidden;
    overscroll-behavior-x: contain;
    -webkit-overflow-scrolling: touch;
    padding: 0 24px 6px;
    scrollbar-width: none;
    -ms-overflow-style: none;
    cursor: grab;
}

body.page-home .mx-home-templates::-webkit-scrollbar {
    display: none;
}

body.page-home .mx-home-templates.is-dragging {
    cursor: grabbing;
}

body.page-home .mx-template-card {
    width: 180px;
    min-width: 180px;
    height: 240px;
    border-radius: 20px;
    overflow: hidden;
    border: none;
    padding: 0;
    position: relative;
    cursor: pointer;
    background: #b0b3b6;
}

body.page-home .mx-template-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

body.page-home .mx-template-title {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 40px;
    display: flex;
    align-items: center;
    padding: 0 12px;
    color: #ffffff;
    font-size: 14px;
    font-weight: 500;
    background: rgba(207, 207, 207, 0.5);
    backdrop-filter: blur(5px);
    border-radius: 0 0 20px 20px;
}

body.page-home .mx-home-footer {
    text-align: center;
    font-size: 10px;
    color: #8382a4;
    line-height: 20px;
    margin-top: auto;
}

/* Generate page */
body.page-normal .page-header {
    display: none !important;
}

body.page-normal .main-content {
    margin-left: var(--mx-sidebar-width);
    width: calc(100% - var(--mx-sidebar-width));
    min-height: 100vh;
    padding: 16px 0 260px;
    border-radius: 24px 0 0 24px;
    background: #ffffff;
    transform: none !important;
    zoom: 1 !important;
}

@supports not (zoom: 1) {
    body.page-normal .main-content {
        width: calc(100% - var(--mx-sidebar-width));
        transform: none !important;
    }
}

body.page-normal .main-content > .container {
    width: 100%;
    max-width: 1640px;
    padding: 0 clamp(20px, 2.8vw, 44px);
}

body.page-normal .studio-layout {
    max-width: 1460px;
    margin: 0 auto;
    gap: 0;
}

body.page-normal .studio-stream {
    background: transparent;
    border: none;
    box-shadow: none;
    padding: 0;
}

body.page-normal .stream-header {
    top: 16px;
    border-radius: 999px;
    border: 1px solid rgba(228, 224, 241, 0.9);
    background: rgba(255, 255, 255, 0.88);
    backdrop-filter: blur(8px);
    padding: 6px 8px 6px 10px;
    box-shadow: 0 6px 18px rgba(37, 29, 68, 0.08);
    margin-bottom: 12px;
}

body.page-normal .stream-header {
    justify-content: flex-end;
    gap: 8px;
    width: max-content;
    max-width: calc(100% - 8px);
    margin-left: auto;
}

body.page-normal .stream-meta {
    margin-left: auto;
    gap: 6px;
}

body.page-normal .history-filter-select {
    min-width: 92px;
    height: 32px;
    padding: 0 10px;
    border-radius: 999px;
    font-size: 12px;
    color: rgba(38, 40, 54, 0.72);
    background: rgba(255, 255, 255, 0.92);
}

body.page-normal .task-count-badge {
    min-width: 22px;
    height: 22px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 600;
}

body.theme-night.page-normal .stream-header {
    background: rgba(18, 24, 38, 0.72);
    border-color: rgba(117, 133, 168, 0.44);
    box-shadow: 0 8px 22px rgba(0, 0, 0, 0.34);
}

body.theme-night.page-normal .history-filter-select {
    background: rgba(20, 28, 44, 0.92);
    border-color: rgba(117, 133, 168, 0.38);
    color: rgba(223, 232, 250, 0.9);
}

body.page-normal .history-filter-select {
    border-color: #ece8f6;
    box-shadow: none;
}

body.page-normal .task-count-badge {
    background: rgba(113, 61, 234, 0.12);
    color: var(--mx-violet);
}

body.page-normal .timeline-list {
    gap: 18px;
    padding-right: 0;
    padding-bottom: 320px;
    overflow: visible;
    max-width: 1320px;
    width: 100%;
    margin: 0 auto;
    padding-left: 20px;
    padding-right: 20px;
    box-sizing: border-box;
}

body.page-normal .timeline-item {
    border: 1px solid #f0ecfa;
    border-radius: 12px;
    box-shadow: none;
    padding: 12px;
    width: 100%;
    max-width: 100%;
    margin: 0 auto;
    box-sizing: border-box;
}

body.page-normal .timeline-images-row {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
    align-items: start;
    max-width: min(1120px, 100%);
    overflow: visible;
    min-height: auto;
}

body.page-normal .timeline-thumb {
    width: 100%;
    max-width: 100%;
    height: auto;
    aspect-ratio: 3 / 4;
    border-radius: 8px;
    box-shadow: none;
}

body.page-normal .timeline-thumb img,
body.page-normal .timeline-thumb video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

body.page-normal .timeline-placeholder {
    width: 100%;
    max-width: 100%;
}

body.page-normal .timeline-item[data-result-count="1"] .timeline-images-row,
body.page-normal .timeline-item[data-result-count="2"] .timeline-images-row,
body.page-normal .timeline-item[data-result-count="3"] .timeline-images-row {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

body.page-normal .timeline-image-actions {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 10px;
    flex-wrap: wrap;
}

body.page-normal .timeline-image-action-btn {
    height: 34px;
    padding: 0 14px;
    border-radius: 12px;
    border: 1px solid #e8e3f7;
    background: #ffffff;
    color: #423b5e;
    font-size: 13px;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    cursor: pointer;
    transition: all 0.18s ease;
}

body.page-normal .timeline-image-action-btn i {
    font-size: 12px;
}

body.page-normal .timeline-image-action-btn:hover {
    border-color: rgba(113, 61, 234, 0.42);
    color: var(--mx-violet);
    background: rgba(245, 240, 255, 0.9);
}

body.page-normal .timeline-image-action-btn.is-danger {
    color: #d14a52;
    border-color: rgba(239, 68, 68, 0.26);
    background: rgba(255, 241, 242, 0.82);
}

body.page-normal .timeline-image-action-btn.is-danger:hover {
    border-color: rgba(239, 68, 68, 0.42);
    background: rgba(255, 228, 230, 0.9);
}

body.theme-night.page-normal .timeline-image-action-btn {
    background: rgba(20, 28, 44, 0.9);
    border-color: rgba(95, 112, 146, 0.42);
    color: rgba(221, 231, 249, 0.9);
}

body.theme-night.page-normal .timeline-image-action-btn:hover {
    border-color: rgba(154, 123, 255, 0.58);
    color: #d6c8ff;
    background: rgba(56, 43, 96, 0.4);
}

body.theme-night.page-normal .timeline-image-action-btn.is-danger {
    border-color: rgba(239, 68, 68, 0.38);
    color: #ff9aa0;
    background: rgba(116, 34, 44, 0.28);
}

body.theme-night.page-normal .timeline-image-action-btn.is-danger:hover {
    border-color: rgba(239, 68, 68, 0.54);
    background: rgba(148, 40, 54, 0.34);
}

body.page-generate-workspace #resultPreviewModal {
    padding-left: 0;
    padding-right: 0;
    align-items: stretch;
    justify-content: stretch;
    background: rgba(248, 249, 252, 0.94);
    backdrop-filter: blur(10px);
}

body.page-generate-workspace #resultPreviewModal .image-preview-modal {
    width: 100vw;
    max-width: 100vw;
    height: 100vh;
    max-height: 100vh;
    margin: 0;
    padding: 0;
    border-radius: 0;
    background: #ffffff;
    box-shadow: 0 28px 70px rgba(15, 23, 42, 0.22);
    overflow: hidden;
}

body.page-generate-workspace #resultPreviewModal .image-preview-layout {
    flex: 1;
    height: 100%;
    max-height: none;
    overflow: hidden;
}

body.page-generate-workspace #resultPreviewModal .image-preview-layout.two-column-preview {
    height: 100%;
    gap: 0;
}

body.page-generate-workspace #resultPreviewModal .image-preview-main {
    position: relative;
    flex: 1;
    max-height: none;
    justify-content: flex-start;
    gap: 18px;
    padding: 36px 28px 20px;
    background: linear-gradient(135deg, #f5f7fa 0%, #e8ecf1 100%);
    min-width: 0;
    overflow: hidden;
}

body.page-generate-workspace #resultPreviewModal .image-preview-canvas-wrapper {
    flex: 1;
    height: auto;
    min-height: 0;
    max-height: none;
    border-radius: 16px;
    background: transparent;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}

body.page-generate-workspace #resultPreviewModal .image-preview-canvas-wrapper img,
body.page-generate-workspace #resultPreviewModal .image-preview-canvas-wrapper video {
    height: auto;
    max-height: 100%;
    width: auto;
    max-width: 100%;
    border-radius: 16px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.16), 0 0 1px rgba(0, 0, 0, 0.08);
    object-fit: contain;
}

body.page-generate-workspace #resultPreviewModal .modal-close-ghost {
    top: 20px;
    right: 20px;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    border: none;
    background: rgba(255, 255, 255, 0.9);
    color: #666666;
    font-size: 28px;
    line-height: 1;
    box-shadow: 0 10px 26px rgba(0, 0, 0, 0.12);
    transform: none;
}

body.page-generate-workspace #resultPreviewModal .modal-close-ghost:hover {
    background: #ffffff;
    color: #333333;
    transform: rotate(90deg);
}

body.page-generate-workspace .preview-counter {
    position: absolute;
    top: 20px;
    left: 20px;
    z-index: 5;
    display: inline-flex;
    align-items: center;
    padding: 8px 16px;
    border-radius: 20px;
    background: rgba(0, 0, 0, 0.6);
    color: #ffffff;
    font-size: 0.875rem;
    font-weight: 600;
}

body.page-generate-workspace .preview-main-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 52px;
    height: 52px;
    border-radius: 999px;
    border: none;
    background: rgba(255, 255, 255, 0.9);
    color: #334155;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 7;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
}

body.page-generate-workspace .preview-main-nav:hover {
    background: #ffffff;
}

body.page-generate-workspace .preview-main-nav:disabled {
    opacity: 0.32;
    cursor: not-allowed;
}

body.page-generate-workspace .preview-main-nav-prev {
    left: 18px;
}

body.page-generate-workspace .preview-main-nav-next {
    right: 18px;
}

body.page-generate-workspace .preview-batch-nav {
    margin-top: auto;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    padding: 8px 2px 2px;
}

body.page-generate-workspace .preview-batch-btn {
    display: none !important;
}

body.page-generate-workspace .preview-batch-btn:disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

body.page-generate-workspace .preview-batch-thumbs {
    flex: 0 1 auto;
    display: flex;
    justify-content: center;
    gap: 12px;
    overflow-x: auto;
    max-width: min(100%, 620px);
    margin: 0 auto;
    padding: 2px 0 6px;
    scrollbar-width: thin;
    scrollbar-color: rgba(0, 0, 0, 0.2) transparent;
}

body.page-generate-workspace .preview-batch-thumbs::-webkit-scrollbar {
    height: 6px;
}

body.page-generate-workspace .preview-batch-thumbs::-webkit-scrollbar-track {
    background: transparent;
}

body.page-generate-workspace .preview-batch-thumbs::-webkit-scrollbar-thumb {
    background: rgba(0, 0, 0, 0.2);
    border-radius: 3px;
}

body.page-generate-workspace .preview-batch-thumb {
    width: 80px;
    height: 80px;
    border-radius: 8px;
    border: 2px solid rgba(0, 0, 0, 0.1);
    overflow: hidden;
    background: #ffffff;
    flex: 0 0 auto;
    cursor: pointer;
    padding: 0;
    opacity: 0.65;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    transition: all 0.2s ease;
}

body.page-generate-workspace .preview-batch-thumb:hover {
    opacity: 1;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

body.page-generate-workspace .preview-batch-thumb.active {
    border-color: #667eea;
    opacity: 1;
    box-shadow: 0 4px 16px rgba(102, 126, 234, 0.3);
}

body.page-generate-workspace .preview-batch-thumb img,
body.page-generate-workspace .preview-batch-thumb video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

body.page-generate-workspace #resultPreviewModal .image-preview-side {
    flex: 0 0 420px;
    max-width: 420px;
    border-left: 1px solid #e0e0e0;
    border-radius: 0;
    background: #ffffff;
    padding: 0;
    gap: 0;
    height: 100%;
    max-height: none;
    overflow-y: auto;
}

body.page-generate-workspace #resultPreviewModal .preview-meta-header {
    padding: 24px 28px 18px;
    border-bottom: 1px solid #e0e0e0;
}

body.page-generate-workspace #resultPreviewModal .preview-meta-chips .meta-pill {
    background: rgba(59, 130, 246, 0.08);
    border: 1px solid rgba(59, 130, 246, 0.12);
    color: #3550a8;
    padding: 6px 12px;
    font-size: 13px;
    font-weight: 700;
}

body.page-generate-workspace #resultPreviewModal .preview-meta-time {
    flex: 1 1 100%;
    padding: 0;
    background: transparent;
    color: #7c8799;
    border-radius: 0;
    font-size: 13px;
    font-weight: 500;
    line-height: 1.5;
}

body.page-generate-workspace #resultPreviewModal .preview-section {
    margin: 20px 30px 0;
    border: none;
    border-radius: 0;
    background: transparent;
    padding: 0;
}

body.page-generate-workspace #resultPreviewModal .preview-section-title {
    color: #1a1a1a;
    font-size: 1.1rem;
    font-weight: 600;
    margin-bottom: 10px;
}

body.page-generate-workspace #resultPreviewModal .preview-prompt {
    background: #f3f7ff;
    padding: 16px 18px;
    border-radius: 18px;
    color: #333333;
    font-size: 14px;
    line-height: 1.72;
    max-height: 260px;
}

body.page-generate-workspace #resultPreviewModal .preview-upload-list {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

body.page-generate-workspace #resultPreviewModal .preview-upload-list .upload-thumb {
    height: 108px;
    border-radius: 16px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    background: #f4f7fb;
}

body.page-generate-workspace #resultPreviewModal .layered-action-section {
    margin-top: 22px;
}

body.page-generate-workspace #resultPreviewModal .preview-actions-stack {
    margin-top: auto;
    padding: 18px 28px 28px;
    border-top: 1px solid #e0e0e0;
    display: flex;
    flex-direction: column;
    gap: 10px;
    position: sticky;
    bottom: 0;
    background: #ffffff;
    z-index: 2;
}

body.page-generate-workspace #resultPreviewModal .preview-actions-stack .btn,
body.page-generate-workspace #resultPreviewModal .download-dropdown-btn {
    width: 100%;
    min-height: 48px;
    padding: 0 18px;
    border-radius: 999px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    background: #ffffff;
    color: #333333;
    justify-content: center;
    font-size: 14px;
    font-weight: 700;
    line-height: 1;
    white-space: nowrap;
}

body.page-generate-workspace #resultPreviewModal .preview-actions-stack .btn:hover,
body.page-generate-workspace #resultPreviewModal .download-dropdown-btn:hover {
    background: #f8f9fa;
    border-color: #667eea;
    color: #667eea;
}

body.page-generate-workspace #resultPreviewModal .download-menu-wrapper {
    width: 100%;
}

body.page-generate-workspace #resultPreviewModal #previewSendToComposerBtn {
    background: #ffffff;
    border-color: rgba(15, 23, 42, 0.08);
    color: #333333;
}

body.page-generate-workspace #resultPreviewModal #downloadDropdownBtn {
    background: linear-gradient(180deg, #1f2937 0%, #111827 100%);
    color: #f8fafc;
    border-color: rgba(15, 23, 42, 0.08);
}

body.page-generate-workspace #resultPreviewModal #downloadDropdownBtn:hover {
    background: linear-gradient(180deg, #111827 0%, #0f172a 100%);
    color: #f8fafc;
    border-color: rgba(15, 23, 42, 0.08);
}

body.page-generate-workspace #resultPreviewModal .download-dropdown-menu {
    left: 0;
    right: auto;
    transform: none;
    min-width: 260px;
}

body.theme-night.page-generate-workspace #resultPreviewModal {
    background-color: rgba(0, 0, 0, 0.95);
}

body.theme-night.page-generate-workspace #resultPreviewModal .image-preview-modal {
    background: rgba(20, 20, 20, 0.96);
    box-shadow: 0 28px 70px rgba(0, 0, 0, 0.72);
}

body.theme-night.page-generate-workspace #resultPreviewModal .image-preview-main {
    background: linear-gradient(135deg, #1a1a1a 0%, #2d2d2d 100%);
}

body.theme-night.page-generate-workspace #resultPreviewModal .image-preview-canvas-wrapper img,
body.theme-night.page-generate-workspace #resultPreviewModal .image-preview-canvas-wrapper video {
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.8), 0 0 1px rgba(255, 255, 255, 0.1);
}

body.theme-night.page-generate-workspace #resultPreviewModal .modal-close-ghost,
body.theme-night.page-generate-workspace .preview-batch-btn,
body.theme-night.page-generate-workspace .preview-main-nav {
    background: rgba(255, 255, 255, 0.1);
    color: #ffffff;
    border: 1px solid rgba(255, 255, 255, 0.2);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

body.theme-night.page-generate-workspace #resultPreviewModal .modal-close-ghost:hover,
body.theme-night.page-generate-workspace .preview-batch-btn:hover,
body.theme-night.page-generate-workspace .preview-main-nav:hover {
    background: rgba(255, 255, 255, 0.2);
    color: #ffffff;
}

body.theme-night.page-generate-workspace .preview-counter {
    background: rgba(0, 0, 0, 0.7);
    color: #ffffff;
}

body.theme-night.page-generate-workspace #resultPreviewModal .preview-batch-thumbs {
    scrollbar-color: rgba(255, 255, 255, 0.3) transparent;
}

body.theme-night.page-generate-workspace #resultPreviewModal .preview-batch-thumb {
    border-color: rgba(255, 255, 255, 0.2);
    background: rgba(255, 255, 255, 0.05);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

body.theme-night.page-generate-workspace #resultPreviewModal .preview-batch-thumb:hover {
    border-color: rgba(255, 255, 255, 0.3);
}

body.theme-night.page-generate-workspace #resultPreviewModal .preview-batch-thumb.active {
    border-color: #667eea;
    box-shadow: 0 4px 16px rgba(102, 126, 234, 0.5);
}

body.theme-night.page-generate-workspace #resultPreviewModal .image-preview-side {
    background: rgba(20, 20, 20, 0.95);
    border-left-color: rgba(255, 255, 255, 0.1);
}

body.theme-night.page-generate-workspace #resultPreviewModal .preview-meta-header {
    border-bottom-color: rgba(255, 255, 255, 0.1);
}

body.theme-night.page-generate-workspace #resultPreviewModal .preview-meta-chips .meta-pill {
    background: rgba(96, 165, 250, 0.14);
    border-color: rgba(147, 197, 253, 0.2);
    color: rgba(191, 219, 254, 0.98);
}

body.theme-night.page-generate-workspace #resultPreviewModal .preview-meta-time {
    color: rgba(220, 228, 244, 0.85);
}

body.theme-night.page-generate-workspace #resultPreviewModal .preview-section-title {
    color: #ffffff;
}

body.theme-night.page-generate-workspace #resultPreviewModal .preview-prompt {
    background: rgba(255, 255, 255, 0.06);
    color: rgba(255, 255, 255, 0.9);
}

body.theme-night.page-generate-workspace #resultPreviewModal .preview-upload-list .upload-thumb {
    border-color: rgba(255, 255, 255, 0.18);
    background: rgba(255, 255, 255, 0.06);
}

body.theme-night.page-generate-workspace #resultPreviewModal .preview-actions-stack {
    border-top-color: rgba(255, 255, 255, 0.1);
    background: rgba(20, 20, 20, 0.95);
}

body.theme-night.page-generate-workspace #resultPreviewModal .preview-actions-stack .btn,
body.theme-night.page-generate-workspace #resultPreviewModal .download-dropdown-btn,
body.theme-night.page-generate-workspace #resultPreviewModal #previewSendToComposerBtn {
    background: rgba(32, 42, 64, 0.8);
    border-color: rgba(103, 118, 149, 0.4);
    color: rgba(220, 228, 244, 0.9);
}

body.theme-night.page-generate-workspace #resultPreviewModal #downloadDropdownBtn {
    background: linear-gradient(180deg, #334155 0%, #1f2937 100%);
    color: rgba(255, 255, 255, 0.96);
    border-color: rgba(148, 163, 184, 0.18);
}

body.theme-night.page-generate-workspace #resultPreviewModal #downloadDropdownBtn:hover {
    background: linear-gradient(180deg, #1f2937 0%, #111827 100%);
    color: rgba(255, 255, 255, 0.98);
    border-color: rgba(148, 163, 184, 0.2);
}

body.theme-night.page-generate-workspace #resultPreviewModal .preview-actions-stack .btn:hover,
body.theme-night.page-generate-workspace #resultPreviewModal .download-dropdown-btn:hover {
    background: rgba(42, 52, 74, 0.9);
    border-color: rgba(154, 123, 255, 0.5);
    color: #e6dcff;
}

body.page-normal .studio-composer {
    position: fixed;
    left: 50%;
    transform: translateX(calc(-50% + 44px));
    bottom: 16px;
    width: min(980px, calc(100vw - 180px));
    z-index: 40;
    border-radius: 24px;
    border: 1px solid rgba(113, 61, 234, 0.35);
    background: #ffffff;
    box-shadow: var(--mx-shadow-strong);
    padding: 10px;
}

body.page-normal .composer-form,
body.page-normal .composer-shell {
    gap: 0;
}

body.page-normal .composer-input-shell {
    border: none;
    box-shadow: none;
    background: transparent;
}

body.page-normal .composer-preview-row {
    min-height: 44px;
    border-bottom: none;
    padding: 0 0 8px;
}

body.page-normal .composer-upload-inline {
    width: 44px;
    min-height: 44px;
    border-radius: 12px;
}

body.page-normal .composer-input textarea {
    min-height: 98px;
    max-height: 170px;
    padding: 6px 8px 10px;
    font-size: 14px;
    line-height: 22px;
}

body.page-normal .compact-controls {
    margin-top: 6px;
    border-radius: 24px;
    border: 1px solid #f3f3f5;
    background: #ffffff;
    box-shadow: none;
}

body.page-normal .normal-media-mode-switch {
    background: #f6f5f9;
    border: 1px solid #ece8f6;
}

body.page-normal .normal-media-mode-switch .media-mode-option {
    border-radius: 999px;
}

body.page-normal .normal-media-mode-switch .media-mode-option.active {
    background: #ffffff;
    color: var(--mx-violet);
    box-shadow: 0 2px 8px rgba(113, 61, 234, 0.16);
}

body.page-normal .engine-current-display {
    border-color: #f3f3f5;
    box-shadow: none;
}

body.page-normal .engine-current-display::before {
    width: 16px;
    height: 16px;
}

body.page-normal #normalSubmitBtn {
    width: 60px;
    height: 36px;
    border-radius: 20px;
    padding: 0;
    min-height: 36px;
    border: none;
    background: #e2e1e4;
    box-shadow: none;
}

body.page-normal #normalSubmitBtn .btn-icon {
    display: none;
}

body.page-normal #normalSubmitText {
    font-size: 12px;
    font-weight: 500;
    line-height: 1;
}

body.page-normal.mx-composer-collapsed .studio-composer {
    width: min(860px, calc(100vw - 220px));
    border-radius: 20px;
    padding: 6px 8px;
}

body.page-normal.mx-composer-collapsed .composer-preview-row {
    display: none;
}

body.page-normal.mx-composer-collapsed .composer-input textarea {
    min-height: 42px;
    max-height: 56px;
    padding: 10px 4px;
}

body.page-normal.mx-composer-collapsed .prompt-enhance-wrap {
    display: none;
}

body.page-normal.mx-composer-collapsed .compact-controls {
    margin-top: 2px;
    padding: 4px 6px;
}

body.page-normal.mx-composer-collapsed .normal-media-mode-switch .media-mode-label {
    display: none;
}

body.page-normal.mx-composer-collapsed .normal-media-mode-switch .media-mode-option {
    min-width: 30px;
    padding: 4px 8px;
}

body.page-normal.mx-composer-collapsed .normal-media-mode-switch {
    padding: 2px;
}

body.page-normal .loading-overlay {
    z-index: 300;
}

@media (max-width: 1024px) {
    body.page-home .mx-home-main,
    body.page-normal .main-content {
        margin-left: 0;
        width: 100%;
        border-radius: 0;
    }

    body.page-home .navbar,
    body.page-normal .navbar {
        width: 100%;
        height: 72px;
        top: 34px;
        left: 0;
        right: 0;
    }

    body.page-normal .timeline-list,
    body.page-normal .timeline-item,
    body.page-normal .timeline-images-row {
        max-width: 100%;
    }

    body.page-home .nav-container,
    body.page-normal .nav-container {
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
        padding: 0 12px;
    }

    body.page-home .nav-container::before,
    body.page-normal .nav-container::before {
        inset: 0;
        border-radius: 0;
    }

    body.page-home .nav-brand,
    body.page-normal .nav-brand {
        width: 64px;
        height: 64px;
        padding: 0;
    }

    body.page-home .nav-brand .mx-brand-logo,
    body.page-normal .nav-brand .mx-brand-logo {
        width: 46px;
        height: 46px;
    }

    body.page-home .nav-links,
    body.page-normal .nav-links {
        flex-direction: row;
        gap: 8px;
        width: auto;
    }

    body.page-home .nav-link,
    body.page-normal .nav-link {
        width: auto;
        min-height: auto;
        padding: 4px 8px;
    }

    body.page-home .nav-link .mx-nav-icon,
    body.page-normal .nav-link .mx-nav-icon {
        width: 30px;
        height: 30px;
        font-size: 14px;
    }

    body.page-home .nav-link .mx-nav-icon img,
    body.page-normal .nav-link .mx-nav-icon img {
        width: 16px;
        height: 16px;
    }

    body.page-home .nav-link .mx-nav-label,
    body.page-normal .nav-link .mx-nav-label {
        font-size: 11px;
        line-height: 16px;
    }

    body.page-home .nav-auth,
    body.page-normal .nav-auth {
        flex-direction: row;
        width: auto;
    }

    body.page-home #normalThemeToggle,
    body.page-normal #normalThemeToggle {
        width: 52px;
        height: 28px;
        padding: 0 7px;
    }

    body.page-home #normalThemeToggle .theme-toggle-thumb,
    body.page-normal #normalThemeToggle .theme-toggle-thumb {
        width: 18px;
        height: 18px;
    }

    body.page-home #normalThemeToggle[data-mode="night"] .theme-toggle-thumb,
    body.page-normal #normalThemeToggle[data-mode="night"] .theme-toggle-thumb {
        transform: translateX(24px);
    }

    body.page-home .mx-home-wrap {
        padding: 110px 14px 18px;
    }

    body.page-home .mx-home-composer {
        width: 100%;
    }

    body.page-home .mx-home-tabs {
        display: none;
    }

    body.page-home .mx-home-toolbar {
        flex-wrap: wrap;
    }

    body.page-home #mxHomeGenerateBtn {
        margin-left: 0;
    }

    body.page-normal .main-content {
        padding: 92px 0 200px;
    }

    body.page-normal .main-content > .container {
        padding: 0 12px;
    }

    body.page-normal .studio-composer,
    body.page-normal.mx-composer-collapsed .studio-composer {
        left: 50%;
        transform: translateX(-50%);
        width: calc(100vw - 20px);
        bottom: 10px;
    }

    body.page-normal .stream-header {
        top: 84px;
    }

    body.page-normal .timeline-list {
        padding-bottom: 260px;
    }

    body.page-generate-workspace #resultPreviewModal {
        padding-left: 0;
    }

    body.page-generate-workspace #resultPreviewModal .image-preview-modal {
        width: calc(100vw - 12px);
        max-width: calc(100vw - 12px);
        height: calc(100vh - 12px);
        max-height: calc(100vh - 12px);
        margin: 6px auto;
        border-radius: 14px;
        overflow-y: auto;
        overflow-x: hidden;
        -webkit-overflow-scrolling: touch;
    }

    body.page-generate-workspace #resultPreviewModal .image-preview-layout {
        height: auto;
        min-height: 100%;
        max-height: none;
        overflow: visible;
    }

    body.page-generate-workspace #resultPreviewModal .image-preview-layout.two-column-preview {
        flex-direction: column;
        height: auto;
        min-height: 100%;
    }

    body.page-generate-workspace #resultPreviewModal .image-preview-main {
        padding: 18px 12px 10px;
        min-height: 0;
        flex: 0 0 auto;
        overflow: visible;
        gap: 10px;
    }

    body.page-generate-workspace #resultPreviewModal .image-preview-canvas-wrapper {
        height: min(56dvh, calc(100dvh - 330px));
        min-height: 260px;
        max-height: none;
        overflow: hidden;
    }

    body.page-generate-workspace #resultPreviewModal .image-preview-canvas-wrapper img,
    body.page-generate-workspace #resultPreviewModal .image-preview-canvas-wrapper video {
        height: 100%;
        width: auto;
        max-width: 100%;
        max-height: 100%;
    }

    body.page-generate-workspace #resultPreviewModal .image-preview-side {
        max-width: 100%;
        width: 100%;
        border-left: none;
        border-top: 1px solid rgba(148, 163, 184, 0.25);
        height: auto;
        max-height: none;
        overflow: visible;
    }

    body.page-generate-workspace #resultPreviewModal .preview-meta-header {
        padding: 16px 14px 12px;
    }

    body.page-generate-workspace #resultPreviewModal .preview-meta-chips {
        flex-wrap: wrap;
        white-space: normal;
        overflow: visible;
    }

    body.page-generate-workspace #resultPreviewModal .preview-section {
        margin: 14px 14px 0;
    }

    body.page-generate-workspace #resultPreviewModal .preview-prompt {
        max-height: none;
        overflow: visible;
    }

    body.page-generate-workspace #resultPreviewModal .preview-actions-stack {
        padding: 14px;
        position: static;
        margin-top: 14px;
        border-top: none;
        z-index: auto;
    }

    body.page-generate-workspace #resultPreviewModal .preview-counter {
        top: 14px;
        left: 14px;
        font-size: 0.8rem;
        padding: 6px 12px;
    }

    body.page-generate-workspace #resultPreviewModal .modal-close-ghost {
        top: 14px;
        right: 14px;
        width: 36px;
        height: 36px;
        font-size: 24px;
    }

    body.page-normal .timeline-images-row {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 860px) {
    body.page-normal .timeline-images-row {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* Landing page shell: keep original home content, only move canvas right to clear sidebar */
body.page-home-landing > section,
body.page-home-landing > footer {
    margin-left: var(--mx-sidebar-width);
    width: calc(100% - var(--mx-sidebar-width));
}

/* Keep recharge content centered within the landing canvas area */
body.page-home-landing > section.recharge-section {
    max-width: none;
    margin-top: var(--spacing-10);
    margin-right: 0;
    margin-bottom: 0;
    padding-left: 0;
    padding-right: 0;
}

body.page-home-landing > section.recharge-section > .recharge-header,
body.page-home-landing > section.recharge-section > .recharge-grid {
    max-width: 1400px;
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--spacing-4);
    padding-right: var(--spacing-4);
    box-sizing: border-box;
}

/* History / Community pages use the same sidebar shell */
body.page-history,
body.page-community {
    background: var(--mx-page-bg);
}

body.page-history .global-announcement-bar,
body.page-community .global-announcement-bar {
    display: none !important;
}

body.page-history .navbar,
body.page-community .navbar {
    position: fixed;
    left: 0;
    top: 36px;
    width: var(--mx-sidebar-width);
    height: calc(100vh - 36px);
    border: none;
    box-shadow: none;
    background: transparent;
    z-index: 120;
}

body.page-history .nav-container,
body.page-community .nav-container {
    position: relative;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    padding: 4px 4px 12px;
}

body.page-history .nav-container::before,
body.page-community .nav-container::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 0;
    background: rgba(246, 245, 250, 0.82);
    border: 1px solid rgba(221, 217, 232, 0.9);
    box-shadow: 0 8px 22px rgba(36, 28, 70, 0.08);
    backdrop-filter: blur(8px);
    z-index: -1;
}

body.page-history .nav-brand,
body.page-community .nav-brand {
    width: 80px;
    height: 84px;
    padding-top: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
}

body.page-history .nav-brand .mx-brand-logo,
body.page-community .nav-brand .mx-brand-logo {
    width: 56px;
    height: 56px;
    object-fit: contain;
    filter: drop-shadow(0 4px 8px rgba(37, 30, 72, 0.12));
}

body.page-history .nav-brand .logo,
body.page-community .nav-brand .logo {
    display: none;
}

body.page-history .nav-brand h1,
body.page-history .nav-brand .version,
body.page-community .nav-brand h1,
body.page-community .nav-brand .version {
    display: none;
}

body.page-history .nav-links,
body.page-community .nav-links {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    margin: 0;
    width: 40px;
    overflow: visible;
}

body.page-history .nav-link,
body.page-community .nav-link {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    width: 40px;
    min-height: 60px;
    padding: 0;
    border-radius: 8px;
    text-decoration: none;
    color: rgba(0, 0, 0, 0.65);
    background: transparent;
}

body.page-history .nav-link::after,
body.page-community .nav-link::after {
    display: none;
}

body.page-history .nav-link .mx-nav-icon,
body.page-community .nav-link .mx-nav-icon {
    width: 40px;
    height: 40px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
}

body.page-history .nav-link .mx-nav-icon img,
body.page-community .nav-link .mx-nav-icon img {
    width: 20px;
    height: 20px;
    object-fit: contain;
}

body.page-history .nav-link .mx-nav-label,
body.page-community .nav-link .mx-nav-label {
    margin-top: 0;
    font-size: 11px;
    line-height: 20px;
    color: rgba(16, 12, 31, 0.56);
    letter-spacing: 0.2px;
    white-space: nowrap;
}

body.page-history .nav-link .mx-nav-legacy,
body.page-community .nav-link .mx-nav-legacy {
    display: none;
}

body.page-history .nav-link.active .mx-nav-icon,
body.page-history .nav-link.hot .mx-nav-icon,
body.page-community .nav-link.active .mx-nav-icon,
body.page-community .nav-link.hot .mx-nav-icon {
    background: #ffffff;
    color: var(--mx-violet);
}

body.page-history .nav-link.active .mx-nav-label,
body.page-history .nav-link.hot .mx-nav-label,
body.page-community .nav-link.active .mx-nav-label,
body.page-community .nav-link.hot .mx-nav-label {
    color: var(--mx-violet);
    font-weight: 500;
}

body.page-history .nav-auth,
body.page-community .nav-auth {
    width: 100%;
    margin: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
}

/* AI工具图标独立放大，保持和其他菜单视觉一致 */
body.page-home .nav-link .mx-nav-icon img.mx-tools-icon,
body.page-normal .nav-link .mx-nav-icon img.mx-tools-icon,
body.page-history .nav-link .mx-nav-icon img.mx-tools-icon,
body.page-community .nav-link .mx-nav-icon img.mx-tools-icon {
    width: 24px !important;
    height: 24px !important;
}

@media (max-width: 1200px) {
    body.page-home .nav-link .mx-nav-icon img.mx-tools-icon,
    body.page-normal .nav-link .mx-nav-icon img.mx-tools-icon,
    body.page-history .nav-link .mx-nav-icon img.mx-tools-icon,
    body.page-community .nav-link .mx-nav-icon img.mx-tools-icon {
        width: 18px !important;
        height: 18px !important;
    }
}

body.page-history .notification-dropdown,
body.page-community .notification-dropdown {
    left: var(--mx-sidebar-width);
    right: auto;
    top: 0;
    bottom: 0;
    width: clamp(460px, 33vw, 720px);
    max-width: calc(100vw - var(--mx-sidebar-width));
}

body.page-home .notification-dropdown,
body.page-normal .notification-dropdown,
body.page-history .notification-dropdown,
body.page-community .notification-dropdown {
    pointer-events: none;
}

body.page-home .notification-dropdown.show,
body.page-normal .notification-dropdown.show,
body.page-history .notification-dropdown.show,
body.page-community .notification-dropdown.show {
    pointer-events: auto;
}

@media (max-width: 768px) {
    body.page-home .notification-dropdown,
    body.page-normal .notification-dropdown,
    body.page-history .notification-dropdown,
    body.page-community .notification-dropdown {
        position: fixed;
        left: 0;
        right: 0;
        top: max(0px, env(safe-area-inset-top, 0px));
        bottom: 0;
        width: 100vw;
        max-width: 100vw;
        height: 100dvh;
        max-height: 100dvh;
        border-radius: 0 0 18px 18px;
        z-index: 1400;
        transform: none;
    }

    body.page-home .notification-dropdown.show,
    body.page-normal .notification-dropdown.show,
    body.page-history .notification-dropdown.show,
    body.page-community .notification-dropdown.show {
        transform: none;
    }

    body.page-home .notification-list,
    body.page-normal .notification-list,
    body.page-history .notification-list,
    body.page-community .notification-list {
        flex: 1 1 auto;
        max-height: none;
        min-height: 0;
    }
}

/* 白天模式通知中心 */
body.theme-day.page-home .notification-bell,
body.theme-day.page-normal .notification-bell,
body.theme-day.page-history .notification-bell,
body.theme-day.page-community .notification-bell {
    background: rgba(255, 255, 255, 0.95);
    border-color: rgba(226, 232, 240, 0.9);
    color: #4a5568;
}

body.theme-day.page-home .notification-dropdown,
body.theme-day.page-normal .notification-dropdown,
body.theme-day.page-history .notification-dropdown,
body.theme-day.page-community .notification-dropdown {
    background: rgba(255, 255, 255, 0.98);
    border-color: rgba(226, 232, 240, 0.9);
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.12);
}

body.theme-day.page-home .notification-header,
body.theme-day.page-normal .notification-header,
body.theme-day.page-history .notification-header,
body.theme-day.page-community .notification-header {
    border-bottom-color: rgba(226, 232, 240, 0.8);
}

body.theme-day.page-home .notification-header h3,
body.theme-day.page-normal .notification-header h3,
body.theme-day.page-history .notification-header h3,
body.theme-day.page-community .notification-header h3 {
    color: #1a202c;
}

body.theme-day.page-home .notification-item,
body.theme-day.page-normal .notification-item,
body.theme-day.page-history .notification-item,
body.theme-day.page-community .notification-item {
    border-bottom-color: rgba(226, 232, 240, 0.6);
}

body.theme-day.page-home .notification-item:hover,
body.theme-day.page-normal .notification-item:hover,
body.theme-day.page-history .notification-item:hover,
body.theme-day.page-community .notification-item:hover {
    background: rgba(247, 250, 252, 0.8);
}

body.theme-day.page-home .notification-item-title,
body.theme-day.page-normal .notification-item-title,
body.theme-day.page-history .notification-item-title,
body.theme-day.page-community .notification-item-title {
    color: #1a202c;
}

body.theme-day.page-home .notification-item-content,
body.theme-day.page-normal .notification-item-content,
body.theme-day.page-history .notification-item-content,
body.theme-day.page-community .notification-item-content {
    color: #4a5568;
}

body.theme-day.page-home .notification-item-date,
body.theme-day.page-normal .notification-item-date,
body.theme-day.page-history .notification-item-date,
body.theme-day.page-community .notification-item-date {
    color: #718096;
}

body.theme-day.page-home .mark-all-read,
body.theme-day.page-normal .mark-all-read,
body.theme-day.page-history .mark-all-read,
body.theme-day.page-community .mark-all-read {
    color: var(--mx-violet);
}

body.theme-day.page-home .notification-close-btn,
body.theme-day.page-normal .notification-close-btn,
body.theme-day.page-history .notification-close-btn,
body.theme-day.page-community .notification-close-btn {
    color: #64748b;
}

body.theme-day.page-home .notification-close-btn:hover,
body.theme-day.page-normal .notification-close-btn:hover,
body.theme-day.page-history .notification-close-btn:hover,
body.theme-day.page-community .notification-close-btn:hover {
    color: #0f172a;
    background: rgba(15, 23, 42, 0.08);
}

body.page-history #normalThemeToggle,
body.page-community #normalThemeToggle {
    display: inline-flex !important;
    width: 60px;
    height: 30px;
    border-radius: 999px;
    border: 1px solid rgba(113, 61, 234, 0.22);
    background: linear-gradient(180deg, #f8f7fc 0%, #f1eff9 100%);
    box-shadow: 0 6px 16px rgba(39, 28, 77, 0.12);
    padding: 0 8px;
    align-items: center;
    justify-content: space-between;
}

body.page-history #normalThemeToggle .theme-toggle-thumb,
body.page-community #normalThemeToggle .theme-toggle-thumb {
    width: 20px;
    height: 20px;
    top: 4px;
    left: 4px;
    box-shadow: 0 4px 12px rgba(29, 20, 60, 0.2);
}

body.page-history #normalThemeToggle[data-mode="night"] .theme-toggle-thumb,
body.page-community #normalThemeToggle[data-mode="night"] .theme-toggle-thumb {
    transform: translateX(30px);
}

body.page-history #normalThemeToggle .theme-toggle-icon,
body.page-community #normalThemeToggle .theme-toggle-icon {
    width: 14px;
    height: 14px;
}

body.page-history .nav-auth .btn,
body.page-community .nav-auth .btn {
    width: 60px;
    min-height: 28px;
    padding: 0 4px;
    border-radius: 8px;
    font-size: 12px;
    line-height: 1;
    justify-content: center;
}

body.page-history .history-scale {
    margin-left: var(--mx-sidebar-width);
    width: calc(100% - var(--mx-sidebar-width));
    min-height: 100vh;
    background: #ffffff;
    border-radius: 24px 0 0 24px;
    zoom: 1;
}

@supports not (zoom: 1) {
    body.page-history .history-scale {
        transform: none;
        width: calc(100% - var(--mx-sidebar-width));
        margin-left: var(--mx-sidebar-width);
    }
}

body.page-history .main-content {
    padding-bottom: 48px;
}

body.page-community .main-content,
body.page-community .footer {
    margin-left: var(--mx-sidebar-width);
    width: calc(100% - var(--mx-sidebar-width));
}

body.page-community .main-content {
    min-height: 100vh;
    padding-top: 0;
}

/* Landing polish */
body.page-home-landing .hero,
body.page-home-landing .testimonials-section,
body.page-home-landing .pricing-section,
body.page-home-landing .faq-section,
body.page-home-landing .contact-section,
body.page-home-landing footer {
    transition: background-color 0.25s ease, color 0.25s ease, border-color 0.25s ease;
}

body.page-home-landing .hero-compare {
    border: 1px solid rgba(113, 61, 234, 0.14);
    box-shadow: 0 20px 44px rgba(29, 22, 53, 0.12);
}

/* Global day/night theme */
body.theme-day.page-home {
    --home-bg: #f5f7fc;
    --home-surface: rgba(255, 255, 255, 0.95);
    --home-border: rgba(121, 136, 171, 0.22);
    --home-text: #151b2c;
    --home-text-body: #3c4762;
    --home-text-muted: #6f7b98;
    --home-gold: #7d4bff;
    --home-gold-deep: #217efd;
    --gradient-primary: linear-gradient(135deg, #7d4bff 0%, #4f8dff 100%);
}

body.theme-day.page-home-landing .hero,
body.theme-day.page-home-landing .testimonials-section,
body.theme-day.page-home-landing .recharge-section,
body.theme-day.page-home-landing .features-section,
body.theme-day.page-home-landing footer {
    background: #f5f7fc;
    color: var(--home-text-body);
}

body.theme-day.page-home .hero::before {
    background:
        radial-gradient(circle at 18% 24%, rgba(113, 61, 234, 0.12), transparent 46%),
        radial-gradient(circle at 86% 20%, rgba(33, 126, 253, 0.11), transparent 44%),
        radial-gradient(circle at 52% 84%, rgba(143, 105, 238, 0.08), transparent 52%);
}

body.theme-day.page-home .hero::after {
    opacity: 0.06;
}

body.theme-day.page-home .kicker-pill {
    background: rgba(255, 255, 255, 0.82);
    border-color: rgba(124, 140, 180, 0.26);
    color: #3a2c80;
}

body.theme-day.page-home .kicker-note,
body.theme-day.page-home .hero-typing {
    color: #4a5568;
}

body.theme-day.page-home .hero-title,
body.theme-day.page-home .section-header h2,
body.theme-day.page-home .testimonials-header h2,
body.theme-day.page-home .recharge-header h2,
body.theme-day.page-home .recharge-name,
body.theme-day.page-home .feature-card h3,
body.theme-day.page-home .feature-showcase-title,
body.theme-day.page-home .showcase-main h3,
body.theme-day.page-home .review-card-name {
    color: #1a202c;
}

body.theme-day.page-home .hero-subtitle,
body.theme-day.page-home .section-subtitle,
body.theme-day.page-home .recharge-subtitle,
body.theme-day.page-home .review-card-sub,
body.theme-day.page-home .review-card-text,
body.theme-day.page-home .feature-showcase-desc,
body.theme-day.page-home .showcase-main p,
body.theme-day.page-home .module-desc,
body.theme-day.page-home .wechat-id,
body.theme-day.page-home .feature-item {
    color: #2d3748;
}

body.theme-day.page-home .hero-compare,
body.theme-day.page-home .review-card,
body.theme-day.page-home .recharge-card,
body.theme-day.page-home .feature-card,
body.theme-day.page-home .feature-showcase-card,
body.theme-day.page-home .showcase-item,
body.theme-day.page-home .proof-marquee,
body.theme-day.page-home .review-pill {
    background: var(--home-surface);
    border: 1px solid var(--home-border);
    box-shadow: 0 18px 46px rgba(27, 32, 56, 0.08);
}

body.page-home .testimonials-header {
    text-align: left;
    margin-bottom: clamp(18px, 2.2vw, 30px);
}

body.page-home .notion-rating-card {
    position: relative;
    overflow: hidden;
    display: grid;
    grid-template-columns: minmax(0, 460px) minmax(0, 1fr);
    align-items: center;
    gap: clamp(12px, 1.4vw, 18px);
    padding: clamp(14px, 1.6vw, 20px);
    border-radius: 24px;
    border: 1px solid var(--home-border);
    background:
        linear-gradient(120deg, rgba(125, 75, 255, 0.08), rgba(33, 126, 253, 0.03) 52%, rgba(16, 185, 129, 0.05) 100%),
        var(--home-surface);
    box-shadow: 0 10px 24px rgba(18, 26, 44, 0.08);
}

body.page-home .notion-rating-card::before {
    content: "";
    position: absolute;
    width: 300px;
    height: 300px;
    right: -110px;
    top: -170px;
    background: radial-gradient(circle, rgba(37, 99, 235, 0.16), transparent 72%);
    pointer-events: none;
}

body.page-home .notion-rating-left {
    position: relative;
    min-height: 72px;
    display: flex;
    align-items: center;
}

body.page-home .notion-avatar-stack {
    display: flex;
    align-items: center;
    padding-right: 8px;
}

body.page-home .notion-avatar {
    width: clamp(58px, 5.2vw, 72px);
    height: clamp(58px, 5.2vw, 72px);
    margin-left: -14px;
    padding: 0;
    border-radius: 50%;
    border: 3px solid #d3d9e8;
    background: #f8fafc;
    overflow: hidden;
    flex: 0 0 auto;
    position: relative;
    box-shadow: 0 10px 26px rgba(21, 29, 44, 0.12);
    transition: transform 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease;
    cursor: default;
    -webkit-appearance: none;
    appearance: none;
}

body.page-home .notion-avatar:first-child {
    margin-left: 0;
}

body.page-home .notion-avatar:nth-child(1) { z-index: 1; }
body.page-home .notion-avatar:nth-child(2) { z-index: 2; }
body.page-home .notion-avatar:nth-child(3) { z-index: 3; }
body.page-home .notion-avatar:nth-child(4) { z-index: 4; }
body.page-home .notion-avatar:nth-child(5) { z-index: 5; }

body.page-home .notion-avatar-fallback {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    font-weight: 800;
    color: #1e293b;
    background: linear-gradient(135deg, hsl(var(--h, 210) 70% 82%), hsl(calc(var(--h, 210) + 24) 68% 74%));
}

body.page-home .notion-avatar img {
    position: relative;
    z-index: 1;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

body.page-home .notion-avatar.img-failed img {
    display: none;
}

body.page-home .notion-avatar.is-active {
    z-index: 11;
    border-color: #22c55e;
    transform: translateY(-4px) scale(1.05);
    box-shadow: 0 14px 34px rgba(34, 197, 94, 0.3);
    animation: notion-avatar-bob 2.6s ease-in-out infinite;
}

body.page-home .notion-avatar:focus-visible {
    outline: 2px solid rgba(34, 197, 94, 0.55);
    outline-offset: 2px;
}

body.page-home .notion-live-pill {
    position: absolute;
    top: -2px;
    right: 2px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    height: 40px;
    border-radius: 999px;
    padding: 0 16px;
    font-size: 1rem;
    font-weight: 800;
    letter-spacing: 0.5px;
    color: #f0fdf4;
    background: linear-gradient(135deg, #22c55e, #10b981);
    box-shadow: 0 12px 24px rgba(16, 185, 129, 0.34);
}

body.page-home .notion-live-pill span {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.85);
    box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.45);
    animation: notion-live-pulse 1.6s ease-out infinite;
}

body.page-home .notion-rating-right {
    display: flex;
    flex-direction: column;
    gap: 6px;
    position: relative;
    padding-right: 232px;
}

body.page-home .notion-rating-topline {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 10px;
    min-height: 38px;
}

body.page-home .notion-stars {
    position: relative;
    display: inline-flex;
    font-size: clamp(1.7rem, 3.4vw, 2.3rem);
    letter-spacing: 5px;
    line-height: 1;
    margin: 0;
    text-shadow: none;
}

body.page-home .notion-stars .notion-stars-base,
body.page-home .notion-stars .notion-stars-fill {
    display: block;
    font-family: ui-sans-serif, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    white-space: nowrap;
}

body.page-home .notion-stars .notion-stars-base {
    color: rgba(148, 163, 184, 0.42);
}

body.page-home .notion-stars .notion-stars-fill {
    position: absolute;
    left: 0;
    top: 0;
    width: var(--rating-fill, 98%);
    overflow: hidden;
    color: #f59e0b;
    filter: drop-shadow(0 6px 12px rgba(245, 158, 11, 0.3));
    animation: notion-stars-sheen 2.8s ease-in-out infinite;
}

body.page-home .notion-score-chip {
    position: absolute;
    top: 0;
    right: 0;
    display: inline-flex;
    align-items: center;
    gap: 0;
    padding: 8px 16px;
    border-radius: 999px;
    border: 1px solid rgba(16, 185, 129, 0.25);
    background: rgba(16, 185, 129, 0.12);
    color: #047857;
    font-weight: 700;
    min-width: 220px;
    max-width: 240px;
    justify-content: center;
    white-space: nowrap;
}

body.page-home .notion-score-chip .chip-icon {
    font-size: 0.95rem;
}

body.page-home .notion-score-chip .chip-value {
    font-size: 1rem;
    line-height: 1;
}

body.page-home .notion-rating-right h2 {
    font-size: clamp(2.4rem, 5.4vw, 3.5rem);
    line-height: 1;
    letter-spacing: -1px;
    margin: 0;
}

body.page-home .notion-rating-right .section-subtitle {
    font-size: 1.02rem;
    margin-top: 0;
}

body.page-home .notion-status-row {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px 12px;
    font-size: 0.98rem;
    font-weight: 600;
    color: #334155;
    margin-top: 2px;
}

body.page-home .notion-status-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    display: inline-block;
    margin-right: 2px;
}

body.page-home .notion-status-dot.online {
    background: #22c55e;
    box-shadow: 0 0 0 5px rgba(34, 197, 94, 0.14);
}

@keyframes notion-avatar-bob {
    0%, 100% {
        transform: translateY(-4px) scale(1.05);
    }
    50% {
        transform: translateY(-8px) scale(1.07);
    }
}

@keyframes notion-live-pulse {
    0% {
        box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.44);
    }
    100% {
        box-shadow: 0 0 0 12px rgba(255, 255, 255, 0);
    }
}

@keyframes notion-stars-sheen {
    0%, 100% {
        filter: drop-shadow(0 6px 12px rgba(245, 158, 11, 0.2));
    }
    50% {
        filter: drop-shadow(0 10px 18px rgba(245, 158, 11, 0.38));
    }
}

body.theme-night.page-home .notion-rating-card {
    background:
        linear-gradient(120deg, rgba(67, 56, 202, 0.18), rgba(14, 116, 144, 0.08) 55%, rgba(16, 185, 129, 0.08) 100%),
        rgba(17, 24, 39, 0.9);
    border-color: rgba(82, 101, 136, 0.52);
    box-shadow: 0 12px 28px rgba(2, 6, 23, 0.35);
}

body.theme-night.page-home .notion-rating-card::before {
    background: radial-gradient(circle, rgba(59, 130, 246, 0.22), transparent 72%);
}

body.theme-night.page-home .notion-avatar {
    border-color: rgba(94, 112, 145, 0.85);
    background: #162133;
}

body.theme-night.page-home .notion-avatar-fallback {
    color: #dbeafe;
}

body.theme-night.page-home .notion-live-pill {
    background: linear-gradient(135deg, #16a34a, #0f766e);
    color: #dcfce7;
}

body.theme-night.page-home .notion-stars .notion-stars-base {
    color: rgba(148, 163, 184, 0.34);
}

body.theme-night.page-home .notion-score-chip {
    background: rgba(16, 185, 129, 0.12);
    border-color: rgba(52, 211, 153, 0.32);
    color: #34d399;
}

body.theme-night.page-home .notion-status-row {
    color: rgba(203, 213, 225, 0.88);
}

@media (max-width: 980px) {
    body.page-home .notion-rating-card {
        grid-template-columns: 1fr;
        gap: 10px;
    }

    body.page-home .notion-rating-left {
        justify-content: space-between;
    }

    body.page-home .notion-live-pill {
        position: static;
        margin-left: 12px;
        font-size: 0.95rem;
        height: 36px;
        padding: 0 14px;
    }

    body.page-home .notion-rating-topline {
        flex-wrap: wrap;
        gap: 8px;
        min-height: auto;
    }

    body.page-home .notion-rating-right {
        padding-right: 0;
    }

    body.page-home .notion-score-chip {
        position: static;
        min-width: 0;
        max-width: none;
        width: fit-content;
        padding: 7px 12px;
    }

    body.page-home .notion-status-row {
        font-size: 0.92rem;
        gap: 8px 14px;
    }
}

@media (max-width: 640px) {
    body.page-home .notion-avatar {
        width: 56px;
        height: 56px;
        margin-left: -10px;
        border-width: 2px;
    }

    body.page-home .notion-live-pill {
        margin-left: 8px;
        font-size: 0.88rem;
    }

    body.page-home .notion-rating-right h2 {
        font-size: 2.2rem;
    }

    body.page-home .notion-stars {
        letter-spacing: 3px;
    }
}

@media (prefers-reduced-motion: reduce) {
    body.page-home .notion-avatar,
    body.page-home .notion-stars .notion-stars-fill,
    body.page-home .notion-live-pill span {
        animation: none !important;
        transition: none !important;
    }
}

body.theme-day.page-home .btn-secondary {
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid var(--home-border);
    color: #374056;
}

body.theme-day.page-home .btn-secondary:hover {
    border-color: rgba(113, 61, 234, 0.32);
    color: #312871;
    background: #ffffff;
}

body.theme-day.page-home .recharge-badge,
body.theme-day.page-home .proof-tag,
body.theme-day.page-home .showcase-index,
body.theme-day.page-home .feature-showcase-badge,
body.theme-day.page-home .showcase-tag,
body.theme-day.page-home .section-kicker {
    background: rgba(113, 61, 234, 0.08);
    border-color: rgba(113, 61, 234, 0.2);
    color: #5e45c4;
}

body.theme-day.page-home .compare-images {
    background: linear-gradient(135deg, rgba(246, 248, 255, 0.95) 0%, rgba(240, 243, 252, 0.96) 100%);
    border: 1px solid rgba(118, 133, 166, 0.2);
}

body.theme-day.page-home .compare-canvas {
    border-color: rgba(121, 136, 171, 0.24);
    background: rgba(255, 255, 255, 0.85);
}

body.theme-day.page-home .footer-bottom {
    border-top-color: rgba(121, 136, 171, 0.24);
}

body.theme-day.page-home .footer,
body.theme-day.page-home .footer p,
body.theme-day.page-home .footer a {
    color: #4c556f;
}

body.theme-day.page-home .recharge-credits {
    color: #1a1a1a;
}

body.theme-day.page-home .recharge-unitprice {
    color: #4a5568;
}

body.theme-night.page-home,
body.theme-night.page-history,
body.theme-night.page-community,
body.theme-night.page-normal {
    --mx-page-bg: linear-gradient(180deg, #0d1118 0%, #121826 42%, #0d1118 100%);
    --mx-panel-bg: #111722;
    --mx-border: #2c3649;
    --mx-violet: #9a7bff;
    color: #dde4f2;
}

body.theme-night.page-home .nav-container::before,
body.theme-night.page-normal .nav-container::before,
body.theme-night.page-history .nav-container::before,
body.theme-night.page-community .nav-container::before {
    background: rgba(18, 24, 38, 0.86);
    border: 1px solid rgba(84, 99, 130, 0.45);
    box-shadow: 0 10px 28px rgba(0, 0, 0, 0.4);
}

body.theme-night.page-home .notification-bell,
body.theme-night.page-normal .notification-bell,
body.theme-night.page-history .notification-bell,
body.theme-night.page-community .notification-bell {
    background: rgba(19, 25, 40, 0.96);
    border-color: rgba(103, 121, 154, 0.5);
    color: rgba(224, 231, 246, 0.9);
}

body.theme-night.page-home .notification-close-btn,
body.theme-night.page-normal .notification-close-btn,
body.theme-night.page-history .notification-close-btn,
body.theme-night.page-community .notification-close-btn {
    color: rgba(207, 221, 246, 0.75);
}

body.theme-night.page-home .notification-close-btn:hover,
body.theme-night.page-normal .notification-close-btn:hover,
body.theme-night.page-history .notification-close-btn:hover,
body.theme-night.page-community .notification-close-btn:hover {
    color: rgba(237, 245, 255, 0.95);
    background: rgba(150, 170, 210, 0.16);
}

body.theme-night.page-home .nav-link,
body.theme-night.page-normal .nav-link,
body.theme-night.page-history .nav-link,
body.theme-night.page-community .nav-link {
    color: rgba(214, 223, 244, 0.78);
}

body.theme-night.page-home .nav-link .mx-nav-label,
body.theme-night.page-normal .nav-link .mx-nav-label,
body.theme-night.page-history .nav-link .mx-nav-label,
body.theme-night.page-community .nav-link .mx-nav-label {
    color: rgba(201, 212, 236, 0.72);
}

body.theme-night.page-home .nav-link.active .mx-nav-icon,
body.theme-night.page-home .nav-link.hot .mx-nav-icon,
body.theme-night.page-normal .nav-link.active .mx-nav-icon,
body.theme-night.page-normal .nav-link.hot .mx-nav-icon,
body.theme-night.page-history .nav-link.active .mx-nav-icon,
body.theme-night.page-history .nav-link.hot .mx-nav-icon,
body.theme-night.page-community .nav-link.active .mx-nav-icon,
body.theme-night.page-community .nav-link.hot .mx-nav-icon {
    background: rgba(154, 123, 255, 0.18);
    color: #c9b3ff;
}

body.theme-night.page-home #normalThemeToggle,
body.theme-night.page-normal #normalThemeToggle,
body.theme-night.page-history #normalThemeToggle,
body.theme-night.page-community #normalThemeToggle {
    border-color: rgba(143, 163, 202, 0.45);
    background: linear-gradient(180deg, #1a2236 0%, #151c2d 100%);
}

body.theme-night.page-home .mx-home-main,
body.theme-night.page-history .history-scale,
body.theme-night.page-community .main-content {
    background: #111722;
}

/* 历史页面黑夜模式 - 主内容区域 */
body.theme-night.page-history .main-content {
    background: #111722;
}

body.theme-night.page-history .container {
    background: transparent;
}

/* 历史页面黑夜模式 - 统计和筛选区域 */
body.theme-night.page-history .history-filters {
    background: rgba(29, 37, 56, 0.6);
    border-color: rgba(103, 118, 149, 0.3);
}

body.theme-night.page-history .history-stats {
    color: rgba(220, 228, 244, 0.9);
}

body.theme-night.page-history .stat-item {
    background: rgba(32, 42, 64, 0.5);
    border-color: rgba(103, 118, 149, 0.3);
}

body.theme-night.page-history .stat-value {
    color: #c8b3ff;
}

body.theme-night.page-history .stat-label {
    color: rgba(201, 212, 236, 0.7);
}

/* 历史页面黑夜模式 - 历史记录列表 */
body.theme-night.page-history .history-content {
    background: transparent;
}

body.theme-night.page-history .history-list {
    background: transparent;
}

body.theme-night.page-history .history-item {
    background: rgba(29, 37, 56, 0.6);
    border-color: rgba(103, 118, 149, 0.3);
}

body.theme-night.page-history .history-item:hover {
    background: rgba(32, 42, 64, 0.8);
    border-color: rgba(154, 123, 255, 0.4);
}

body.theme-night.page-history .history-empty {
    color: rgba(201, 212, 236, 0.6);
    background: rgba(29, 37, 56, 0.4);
}

/* 历史页面黑夜模式 - 分页 */
body.theme-night.page-history .pagination-section {
    background: transparent;
}

body.theme-night.page-history .pagination-info {
    color: rgba(220, 228, 244, 0.8);
}

/* 历史页面黑夜模式 - 按钮 */
body.theme-night.page-history .btn-secondary {
    background: rgba(32, 42, 64, 0.8);
    border-color: rgba(103, 118, 149, 0.4);
    color: rgba(220, 228, 244, 0.9);
}

body.theme-night.page-history .btn-secondary:hover {
    background: rgba(42, 52, 74, 0.9);
    border-color: rgba(154, 123, 255, 0.5);
}

/* 历史页面黑夜模式 - 全屏查看器 */
body.theme-night.page-history #fullscreenModal {
    background-color: rgba(0, 0, 0, 0.95);
}

body.theme-night.page-history #fullscreenModal .fullscreen-image-section {
    background: linear-gradient(135deg, #1a1a1a 0%, #2d2d2d 100%);
}

body.theme-night.page-history #fullscreenModal .fullscreen-main-image {
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.8), 0 0 1px rgba(255, 255, 255, 0.1);
}

body.theme-night.page-history #fullscreenModal .fullscreen-close,
body.theme-night.page-history #fullscreenModal .fullscreen-nav {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.2);
    color: #ffffff;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

body.theme-night.page-history #fullscreenModal .fullscreen-close:hover,
body.theme-night.page-history #fullscreenModal .fullscreen-nav:hover {
    background: rgba(255, 255, 255, 0.2);
}

body.theme-night.page-history #fullscreenModal .fullscreen-counter {
    background: rgba(0, 0, 0, 0.7);
    color: #ffffff;
    border-color: rgba(255, 255, 255, 0.1);
}

body.theme-night.page-history #fullscreenModal .fullscreen-info-section {
    background: rgba(20, 20, 20, 0.95);
    border-left-color: rgba(255, 255, 255, 0.1);
}

body.theme-night.page-history #fullscreenModal .fullscreen-info-header {
    border-bottom-color: rgba(255, 255, 255, 0.1);
}

body.theme-night.page-history #fullscreenModal .fullscreen-title {
    color: #ffffff;
}

body.theme-night.page-history #fullscreenModal .fullscreen-meta {
    color: rgba(255, 255, 255, 0.7);
}

body.theme-night.page-history #fullscreenModal .fullscreen-prompt-section h3 {
    color: #ffffff;
}

body.theme-night.page-history #fullscreenModal .fullscreen-prompt-text {
    background: rgba(255, 255, 255, 0.05);
    color: rgba(255, 255, 255, 0.9);
}

body.theme-night.page-history #fullscreenModal .fullscreen-copy-btn {
    background: rgba(255, 255, 255, 0.1);
    color: #ffffff;
    border-color: rgba(255, 255, 255, 0.2);
}

body.theme-night.page-history #fullscreenModal .fullscreen-copy-btn:hover {
    background: rgba(255, 255, 255, 0.2);
}

body.theme-night.page-history #fullscreenModal .fullscreen-actions {
    border-top-color: rgba(255, 255, 255, 0.1);
}

body.theme-night.page-history #fullscreenModal .fullscreen-action-btn {
    background: rgba(32, 42, 64, 0.8);
    border-color: rgba(103, 118, 149, 0.4);
    color: rgba(220, 228, 244, 0.9);
}

body.theme-night.page-history #fullscreenModal .fullscreen-action-btn:hover {
    background: rgba(42, 52, 74, 0.9);
    border-color: rgba(154, 123, 255, 0.5);
}

body.theme-night.page-history #fullscreenModal .fullscreen-thumbnails {
    scrollbar-color: rgba(255, 255, 255, 0.3) transparent;
}

body.theme-night.page-history #fullscreenModal .fullscreen-thumbnail {
    border-color: rgba(255, 255, 255, 0.2);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
    background: rgba(255, 255, 255, 0.05);
}

body.theme-night.page-history #fullscreenModal .fullscreen-thumbnail:hover {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.5);
    border-color: rgba(255, 255, 255, 0.3);
}

body.theme-night.page-history #fullscreenModal .fullscreen-thumbnail.active {
    border-color: #667eea;
    box-shadow: 0 4px 16px rgba(102, 126, 234, 0.5);
}

body.theme-night.page-home .mx-home-title {
    color: #f0f4ff;
}

body.theme-night.page-home .mx-home-model-line {
    background: rgba(154, 123, 255, 0.14);
    border-color: rgba(154, 123, 255, 0.28);
    color: #c8bcf9;
}

body.theme-night.page-home .mx-home-subtitle {
    background: linear-gradient(90deg, #f2f6ff 38%, #72a2ff 100%);
    -webkit-background-clip: text;
    background-clip: text;
}

body.theme-night.page-home .mx-home-tabs {
    background: linear-gradient(180deg, #1d2538 0%, #161d2e 100%);
    border-color: rgba(103, 118, 149, 0.48);
}

body.theme-night.page-home .mx-home-tab {
    color: rgba(220, 228, 244, 0.76);
}

body.theme-night.page-home .mx-home-tab.active {
    background: #202a40;
    color: #c8b3ff;
    border-color: rgba(154, 123, 255, 0.4);
}

body.theme-night.page-home .mx-home-composer-panel {
    background: #141c2b;
    border-color: rgba(154, 123, 255, 0.5);
    box-shadow: 0 14px 28px rgba(0, 0, 0, 0.35);
}

body.theme-night.page-home .mx-home-upload {
    background: #171f2f;
    border-color: rgba(108, 128, 163, 0.5);
    color: rgba(227, 234, 247, 0.85);
}

body.theme-night.page-home #mxHomePrompt {
    color: rgba(233, 240, 254, 0.95);
    background: transparent;
}

body.theme-night.page-home #mxHomePrompt::placeholder {
    color: rgba(177, 192, 220, 0.72);
}

body.theme-night.page-home #mxHomeModelTrigger,
body.theme-night.page-home .mx-home-chip {
    background: #171f2f;
    border-color: rgba(106, 124, 156, 0.45);
    color: rgba(229, 236, 251, 0.92);
}

body.theme-night.page-home .mx-home-chip.accent:hover {
    border-color: rgba(154, 123, 255, 0.52);
    background: #1f2a40;
}

body.theme-night.page-home #mxHomeGenerateBtn {
    border: 1px solid rgba(255, 255, 255, 0.16);
    background: #27272a;
    color: #f4f4f5;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.45), inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

body.theme-night.page-home #mxHomeGenerateBtn.is-ready {
    background: #3f3f46;
    color: #fafafa;
    border-color: rgba(255, 255, 255, 0.22);
}

body.theme-night.page-home #mxHomeGenerateBtn.is-ready:hover {
    background: #52525b;
    color: #fafafa;
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.52), inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

body.theme-night.page-home #mxHomeGenerateBtn:not(.is-ready):hover {
    background: #32323a;
    color: #f4f4f5;
}

body.theme-night.page-home #mxHomeModelMenu {
    background: #1a2336;
    border-color: rgba(104, 124, 161, 0.52);
}

body.theme-night.page-home .mx-home-model-group {
    background: transparent;
    border-color: transparent;
}

body.theme-night.page-home .mx-home-model-group-head {
    border-color: rgba(92, 111, 146, 0.44);
    background: rgba(29, 38, 58, 0.9);
}

body.theme-night.page-home .mx-home-model-group-list {
    border-color: rgba(92, 111, 146, 0.44);
    background: rgba(20, 28, 44, 0.9);
}

body.theme-night.page-home .mx-home-model-group-title {
    color: rgba(195, 206, 230, 0.9);
}

body.theme-night.page-home .mx-home-model-group[data-group="reference"] .mx-home-model-group-title {
    color: rgba(195, 206, 230, 0.9);
}

body.theme-night.page-home .mx-home-model-group[data-group="text"] .mx-home-model-group-title {
    color: rgba(195, 206, 230, 0.9);
}

body.theme-night.page-home .mx-home-model-group-sub {
    color: rgba(174, 189, 219, 0.74);
}

body.theme-night.page-home .mx-home-model-group-head.is-active {
    border-color: rgba(154, 123, 255, 0.56);
    background: linear-gradient(180deg, rgba(68, 93, 116, 0.9) 0%, rgba(55, 69, 103, 0.9) 100%);
}

body.theme-night.page-home .mx-home-model-group-head.is-active .mx-home-model-group-title {
    color: #8dd7ff;
}

body.theme-night.page-home .mx-home-model-option {
    color: rgba(223, 233, 250, 0.88);
    border-bottom-color: rgba(91, 110, 145, 0.24);
}

body.theme-night.page-home .mx-home-model-option:hover,
body.theme-night.page-home .mx-home-model-option.active {
    background: rgba(66, 81, 117, 0.4);
    color: inherit;
}

body.theme-night.page-home .mx-home-model-option.active {
    box-shadow: inset 0 0 0 1px rgba(154, 123, 255, 0.48);
}

body.theme-night.page-home .mx-home-model-title {
    color: rgba(235, 242, 255, 0.95);
}

body.theme-night.page-home .mx-home-model-desc {
    color: rgba(169, 185, 214, 0.84);
}

body.theme-night.page-home .mx-home-model-cost {
    color: rgba(188, 199, 223, 0.9);
}

body.theme-night.page-home .mx-home-model-cap-chip.is-supported {
    color: #8dd7ff;
    background: rgba(44, 76, 103, 0.58);
    border-color: rgba(85, 153, 193, 0.65);
}

body.theme-night.page-home .mx-home-model-cap-chip.is-unsupported {
    color: rgba(180, 190, 212, 0.88);
    background: rgba(44, 53, 73, 0.76);
    border-color: rgba(96, 113, 147, 0.52);
}

/* 夜间 Banana 胶囊 */
body.theme-night.page-home .entry-banana-speed-slider {
    background: rgba(255, 255, 255, 0.12);
    box-shadow: 0 1px 6px rgba(0, 0, 0, 0.3);
}

body.theme-night.page-home .entry-banana-speed-option {
    color: rgba(255, 255, 255, 0.3);
}

body.theme-night.page-home .entry-banana-speed-option:hover {
    color: rgba(255, 255, 255, 0.6);
}

body.theme-night.page-home .entry-banana-speed-item.is-active .entry-banana-speed-option {
    color: #fff;
}

body.theme-night.page-home .entry-banana-speed-cost {
    color: rgba(255, 255, 255, 0.2);
}

body.theme-night.page-home .entry-banana-speed-item.is-active .entry-banana-speed-cost {
    color: #f4b401;
}

body.theme-night.page-home .entry-banana-speed-tooltip {
    background: #252525;
    box-shadow: 0 14px 36px rgba(0, 0, 0, 0.5);
}

body.theme-night.page-home .entry-banana-speed-tooltip::after {
    background: #252525;
}

@media (max-width: 980px) {
    body.page-home #mxHomeModelMenu {
        width: min(640px, calc(100vw - 20px));
        padding: 10px;
    }

    body.page-home #mxHomeModelMenu.show {
        display: block;
    }

    body.page-home .mx-home-model-group {
        position: static;
        border: none;
        border-radius: 0;
        overflow: visible;
        background: transparent;
    }

    body.page-home .mx-home-model-group + .mx-home-model-group {
        margin-top: 10px;
    }

    body.page-home .mx-home-model-group-head {
        position: static;
        left: auto;
        width: auto;
        min-height: auto;
        border: 1px solid rgba(228, 224, 241, 0.95);
        border-radius: 12px;
        align-items: center;
        text-align: center;
        padding: 10px 12px 8px;
    }

    body.page-home .mx-home-model-group-list {
        margin-top: 8px;
    }

    body.theme-night.page-home .mx-home-model-group {
        background: transparent;
        border-color: transparent;
    }

    body.theme-night.page-home .mx-home-model-group-head {
        border-bottom-color: rgba(93, 111, 146, 0.3);
    }
}

body.theme-night.page-home .mx-template-title {
    background: rgba(20, 28, 44, 0.54);
}

body.theme-night.page-home .mx-home-templates-title {
    color: #f0f4ff;
}

body.theme-night.page-home .mx-home-templates-more {
    border-color: rgba(154, 123, 255, 0.35);
    background: rgba(154, 123, 255, 0.12);
    color: #c8b3ff;
}

body.theme-night.page-home .mx-home-templates-more:hover {
    background: rgba(154, 123, 255, 0.2);
    border-color: rgba(154, 123, 255, 0.5);
}

body.theme-night.page-home-landing .hero,
body.theme-night.page-home-landing .testimonials-section,
body.theme-night.page-home-landing .pricing-section,
body.theme-night.page-home-landing .faq-section,
body.theme-night.page-home-landing .contact-section,
body.theme-night.page-home-landing footer {
    background: #101521;
    color: #dce5f8;
}

@media (max-width: 1024px) {
    body.page-home-landing > section,
    body.page-home-landing > footer,
    body.page-history .history-scale,
    body.page-community .main-content,
    body.page-community .footer {
        margin-left: 0;
        width: 100%;
        border-radius: 0;
    }

    body.page-history .navbar,
    body.page-community .navbar {
        width: 100%;
        height: 72px;
        top: 34px;
        left: 0;
        right: 0;
    }

    body.page-history .nav-container,
    body.page-community .nav-container {
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
        padding: 0 12px;
    }

    body.page-history .nav-container::before,
    body.page-community .nav-container::before {
        inset: 0;
        border-radius: 0;
    }

    body.page-history .nav-brand,
    body.page-community .nav-brand {
        width: 64px;
        height: 64px;
        padding: 0;
    }

    body.page-history .nav-brand .mx-brand-logo,
    body.page-community .nav-brand .mx-brand-logo {
        width: 46px;
        height: 46px;
    }

    body.page-history .nav-links,
    body.page-community .nav-links {
        flex-direction: row;
        gap: 8px;
        width: auto;
    }

    body.page-history .nav-link,
    body.page-community .nav-link {
        width: auto;
        min-height: auto;
        padding: 4px 8px;
    }

    body.page-history .nav-link .mx-nav-icon,
    body.page-community .nav-link .mx-nav-icon {
        width: 30px;
        height: 30px;
        font-size: 14px;
    }

    body.page-history .nav-link .mx-nav-icon img,
    body.page-community .nav-link .mx-nav-icon img {
        width: 16px;
        height: 16px;
    }

    body.page-history .nav-auth,
    body.page-community .nav-auth {
        flex-direction: row;
        width: auto;
    }

    body.page-history #normalThemeToggle,
    body.page-community #normalThemeToggle {
        width: 52px;
        height: 28px;
        padding: 0 7px;
    }

    body.page-history #normalThemeToggle .theme-toggle-thumb,
    body.page-community #normalThemeToggle .theme-toggle-thumb {
        width: 18px;
        height: 18px;
    }

    body.page-history #normalThemeToggle[data-mode="night"] .theme-toggle-thumb,
    body.page-community #normalThemeToggle[data-mode="night"] .theme-toggle-thumb {
        transform: translateX(24px);
    }

    body.page-history .history-scale {
        padding-top: 78px;
    }

    body.page-community .main-content {
        padding-top: 72px;
    }
}

/* ===== Final polish overrides: generate flow ===== */

/* Hide VIP tip bubble globally to reduce distraction */
body.page-home #contactSupport .contact-tip,
body.page-normal #contactSupport .contact-tip,
body.page-history #contactSupport .contact-tip,
body.page-community #contactSupport .contact-tip {
    display: none !important;
}

/* Stream header: keep only lightweight controls on the right */
body.page-normal .stream-header {
    position: sticky;
    top: 14px;
    z-index: 6;
    width: fit-content;
    max-width: calc(100% - 8px);
    margin: 0 0 10px auto;
    padding: 0;
    border: none;
    background: transparent;
    box-shadow: none;
}

body.page-normal .stream-meta {
    margin-left: 0;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 5px 6px 5px 8px;
    border-radius: 999px;
    border: 1px solid rgba(228, 224, 241, 0.88);
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(8px);
    box-shadow: 0 8px 20px rgba(33, 27, 62, 0.08);
}

body.page-normal .history-filter-select {
    min-width: 90px;
    height: 30px;
    padding: 0 9px;
    border-radius: 999px;
    border: 1px solid rgba(227, 222, 241, 0.9);
    background: rgba(250, 248, 255, 0.92);
    font-size: 12px;
    color: rgba(45, 40, 67, 0.72);
    box-shadow: none;
}

body.page-normal .task-count-badge {
    min-width: 20px;
    height: 20px;
    font-size: 11px;
    font-weight: 600;
    background: rgba(113, 61, 234, 0.12);
    color: var(--mx-violet);
}

/* Model list in composer: grouped as 参考生图 / 文生图 */
body.page-normal .engine-cards-dropdown {
    width: min(760px, calc(100vw - 220px));
    max-height: min(62vh, 620px);
    left: 0;
    right: auto;
    padding: 10px;
    border-radius: 16px;
    border: 1px solid rgba(228, 224, 241, 0.96);
    background: rgba(255, 255, 255, 0.98);
    box-shadow: 0 24px 56px rgba(29, 23, 53, 0.16);
}

body.page-normal .engine-mode-group {
    border: 1px solid #ece8f6;
    border-radius: 14px;
    background: #ffffff;
    overflow: hidden;
}

body.page-normal .engine-mode-group + .engine-mode-group {
    margin-top: 10px;
}

body.page-normal .engine-mode-group-head {
    padding: 10px 12px 8px;
    border-bottom: 1px solid #f2eefb;
    background: linear-gradient(180deg, #fbfaff 0%, #f6f4fd 100%);
}

body.page-normal .engine-mode-group-title {
    font-size: 13px;
    font-weight: 700;
    line-height: 1.35;
    color: #34295f;
}

body.page-normal .engine-mode-group-sub {
    margin-top: 2px;
    font-size: 11px;
    line-height: 1.35;
    color: rgba(57, 48, 88, 0.58);
}

body.page-normal .engine-mode-group-list {
    display: flex;
    flex-direction: column;
}

body.page-normal .engine-mode-group .engine-option-card {
    min-height: 96px;
    padding: 12px 12px 12px 56px;
    border-bottom: 1px solid #f2eefb;
    background: transparent;
}

body.page-normal .engine-mode-group .engine-option-card:last-child {
    border-bottom: none;
}

body.page-normal .engine-mode-group .engine-option-card:hover {
    background: rgba(245, 241, 255, 0.52);
}

body.page-normal .engine-mode-group .engine-option-card.active {
    border-left: none;
    background: rgba(240, 234, 255, 0.75);
    box-shadow: inset 0 0 0 1px rgba(151, 123, 235, 0.44);
}

body.page-normal .engine-mode-group .engine-option-card .channel-status-indicator {
    display: none;
}

body.page-normal .engine-mode-group .engine-option-card::before {
    left: 12px;
    top: 14px;
    width: 34px;
    height: 34px;
}

body.page-normal .engine-mode-group .engine-option-card .card-left {
    max-width: calc(100% - 76px);
    padding-left: 0 !important;
}

body.page-normal .engine-mode-group .card-title {
    font-size: 16px;
    font-weight: 700;
    line-height: 1.35;
    color: #20263a;
}

body.page-normal .engine-mode-group .card-meta {
    margin-top: 4px;
    font-size: 12px;
    line-height: 1.4;
    color: #657089;
}

body.page-normal .engine-mode-group .card-right {
    width: 66px;
    padding-left: 8px;
}

body.page-normal .engine-capability-row {
    margin-top: 8px;
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

body.page-normal .engine-capability-chip {
    height: 24px;
    padding: 0 9px;
    border-radius: 8px;
    border: 1px solid transparent;
    font-size: 12px;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}

body.page-normal .engine-capability-chip.is-supported {
    color: #1b88c7;
    background: rgba(222, 243, 255, 0.82);
    border-color: rgba(136, 203, 237, 0.9);
}

body.page-normal .engine-capability-chip.is-unsupported {
    color: #8e8ea3;
    background: rgba(247, 247, 251, 0.96);
    border-color: rgba(216, 216, 229, 0.96);
}

body.page-normal .engine-mode-group[data-group="reference"] .engine-mode-group-title {
    color: #2e8fb6;
}

body.page-normal .engine-mode-group[data-group="text"] .engine-mode-group-title {
    color: #555a6f;
}

body.theme-night.page-normal .stream-meta {
    background: rgba(17, 24, 38, 0.86);
    border-color: rgba(95, 112, 146, 0.48);
    box-shadow: 0 10px 22px rgba(0, 0, 0, 0.35);
}

body.theme-night.page-normal .engine-cards-dropdown {
    border-color: rgba(95, 112, 146, 0.5);
    background: rgba(17, 24, 38, 0.95);
    box-shadow: 0 26px 58px rgba(0, 0, 0, 0.48);
}

body.theme-night.page-normal .engine-mode-group {
    border-color: rgba(92, 110, 145, 0.44);
    background: rgba(20, 28, 44, 0.88);
}

body.theme-night.page-normal .engine-mode-group-head {
    border-bottom-color: rgba(92, 110, 145, 0.32);
    background: linear-gradient(180deg, rgba(41, 52, 75, 0.88) 0%, rgba(28, 38, 60, 0.88) 100%);
}

body.theme-night.page-normal .engine-mode-group-title {
    color: rgba(222, 232, 250, 0.92);
}

body.theme-night.page-normal .engine-mode-group-sub {
    color: rgba(174, 190, 220, 0.72);
}

body.theme-night.page-normal .engine-mode-group .engine-option-card {
    border-bottom-color: rgba(92, 110, 145, 0.24);
}

body.theme-night.page-normal .engine-mode-group .engine-option-card:hover {
    background: rgba(58, 73, 108, 0.4);
}

body.theme-night.page-normal .engine-mode-group .engine-option-card.active {
    background: rgba(70, 57, 120, 0.4);
    box-shadow: inset 0 0 0 1px rgba(154, 123, 255, 0.46);
}

body.theme-night.page-normal .engine-mode-group .card-title {
    color: rgba(236, 242, 255, 0.95);
}

body.theme-night.page-normal .engine-mode-group .card-meta {
    color: rgba(170, 185, 213, 0.82);
}

body.theme-night.page-normal .engine-capability-chip.is-supported {
    color: #8cd5ff;
    background: rgba(42, 73, 99, 0.56);
    border-color: rgba(79, 150, 190, 0.62);
}

body.theme-night.page-normal .engine-capability-chip.is-unsupported {
    color: rgba(181, 190, 212, 0.86);
    background: rgba(43, 52, 72, 0.74);
    border-color: rgba(96, 112, 146, 0.52);
}

body.theme-night.page-normal .history-filter-select {
    background: rgba(18, 27, 43, 0.9);
    border-color: rgba(95, 112, 146, 0.4);
    color: rgba(220, 230, 246, 0.9);
}

/* Sidebar login area: keep compact, avoid big username block */
body.page-home .nav-username,
body.page-normal .nav-username,
body.page-history .nav-username,
body.page-community .nav-username {
    display: none !important;
}

body.page-home #navRedeemBtn,
body.page-normal #navRedeemBtn,
body.page-history #navRedeemBtn,
body.page-community #navRedeemBtn {
    margin: 2px 0 0;
    min-width: 58px;
    height: 22px;
    padding: 0 8px;
    border-radius: 999px;
    border: 1px solid rgba(113, 61, 234, 0.32);
    background: rgba(113, 61, 234, 0.08);
    color: #713dea;
    font-size: 11px;
    line-height: 1.1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    white-space: nowrap;
}

body.page-home .nav-user,
body.page-normal .nav-user,
body.page-history .nav-user,
body.page-community .nav-user {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    width: auto !important;
    min-height: auto;
    padding: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    border: none !important;
}

body.page-home .nav-user::before,
body.page-home .nav-user::after,
body.page-normal .nav-user::before,
body.page-normal .nav-user::after,
body.page-history .nav-user::before,
body.page-history .nav-user::after,
body.page-community .nav-user::before,
body.page-community .nav-user::after {
    display: none !important;
}

body.theme-night.page-home .nav-user,
body.theme-night.page-normal .nav-user,
body.theme-night.page-history .nav-user,
body.theme-night.page-community .nav-user {
    background: transparent !important;
    border: none !important;
}

body.theme-night.page-home #navRedeemBtn,
body.theme-night.page-normal #navRedeemBtn,
body.theme-night.page-history #navRedeemBtn,
body.theme-night.page-community #navRedeemBtn {
    border-color: rgba(154, 123, 255, 0.48);
    background: rgba(154, 123, 255, 0.16);
    color: #c7b5ff;
}

/* Generate entry hero: split support models and copy line */
body.page-home .mx-home-composer {
    width: min(704px, calc(100vw - 256px));
}

body.page-home .mx-home-model-icons {
    display: inline-flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 8px;
    max-width: min(420px, calc(100vw - 240px));
}

body.page-home .mx-home-support {
    margin-top: 0;
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
}

body.page-home .mx-home-support .mx-home-model-icons {
    margin: 0;
}

body.page-home .mx-home-support-kicker {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 22px;
    padding: 0 10px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.2px;
    color: #66529d;
    background: rgba(113, 61, 234, 0.1);
    border: 1px solid rgba(113, 61, 234, 0.2);
}

body.page-home .mx-home-model-line {
    display: block;
    max-width: min(540px, calc(100vw - 240px));
    white-space: normal;
    text-align: center;
    line-height: 20px;
    letter-spacing: 0.2px;
    padding: 6px 14px;
}

body.page-home .mx-home-copy {
    margin: 8px auto 0;
    font-size: 15px;
    line-height: 23px;
    color: #2b3f69;
    max-width: min(520px, calc(100vw - 260px));
}

body.theme-night.page-home .mx-home-support-kicker {
    color: #cfbefd;
    background: rgba(154, 123, 255, 0.14);
    border-color: rgba(154, 123, 255, 0.34);
}

body.theme-night.page-home .mx-home-copy {
    color: #9bb6e7;
}

body.theme-night.page-home .mx-home-upload.has-files {
    border-color: rgba(154, 123, 255, 0.5);
    background: linear-gradient(180deg, rgba(32, 42, 66, 0.94) 0%, rgba(24, 33, 52, 0.96) 100%);
}

body.theme-night.page-home .mx-home-upload-card,
body.theme-night.page-home .mx-home-upload-more {
    border-color: rgba(104, 122, 158, 0.58);
    box-shadow: none;
}

body.theme-night.page-home .mx-home-upload .mx-home-upload-empty {
    background: transparent;
    border: none;
    color: rgba(229, 238, 252, 0.6);
}

body.theme-night.page-home .mx-home-upload.has-files .mx-home-upload-empty {
    background: rgba(25, 35, 55, 0.85);
    border-color: rgba(99, 119, 156, 0.6);
    box-shadow: none;
    cursor: pointer;
    z-index: 20;
}

body.theme-night.page-home .mx-home-upload .mx-home-upload-count {
    color: #d5c7ff;
    border-color: rgba(154, 123, 255, 0.5);
    background: rgba(56, 43, 96, 0.9);
}

/* Entry composer tabs: elegant segmented control, detached from box edge */
body.page-home .mx-home-tabs {
    position: static;
    margin: 0 0 10px 10px;
    display: inline-flex;
    align-items: center;
    gap: 2px;
    padding: 4px;
    border-radius: 12px;
    border: 1px solid rgba(228, 224, 241, 0.88);
    background: linear-gradient(180deg, #faf9ff 0%, #f3f2f9 100%);
    box-shadow: 0 6px 16px rgba(36, 26, 70, 0.08);
}

body.page-home .mx-home-composer-panel {
    margin-top: 0;
    min-height: 214px;
    border-radius: 24px;
}

body.page-home .mx-home-tab {
    width: 130px;
    height: 40px;
    border-radius: 9px;
    font-size: 14px;
}

/* Entry upload: horizontal card layout with drag-and-drop */
body.page-home .mx-home-upload {
    position: relative;
    width: auto;
    min-width: 86px;
    height: 110px;
    border-radius: 22px;
    overflow: visible;
    border: 1px dashed transparent;
    background: transparent;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
    display: flex;
    align-items: center;
    padding: 0 12px;
    gap: 8px;
}

body.page-home .mx-home-upload:hover {
    border-color: transparent;
    background: transparent;
}

body.page-home .mx-home-upload.has-files {
    border-color: rgba(113, 61, 234, 0.35);
    background: #ffffff;
    min-width: auto;
    width: auto;
    max-width: 600px;
}

body.page-home .mx-home-upload.has-files:hover {
    border-color: rgba(113, 61, 234, 0.45);
    background: #ffffff;
}

body.page-home .mx-home-upload.drag-over {
    border-color: rgba(113, 61, 234, 0.6);
    background: rgba(113, 61, 234, 0.08);
    box-shadow: 0 0 0 3px rgba(113, 61, 234, 0.15);
}

body.page-home .mx-home-upload.drag-over .mx-home-upload-empty {
    transform: scale(1.1);
    color: #713dea;
}

body.page-home .mx-home-upload-stack {
    position: relative;
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 1;
    min-height: 88px;
}

body.page-home .mx-home-upload-card {
    position: relative;
    width: 64px;
    height: 88px;
    border-radius: 12px;
    border: 1px solid rgba(219, 214, 236, 0.94);
    background-size: cover;
    background-position: center;
    box-shadow: 0 2px 8px rgba(37, 26, 76, 0.08);
    cursor: grab;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    flex-shrink: 0;
}

body.page-home .mx-home-upload-card:hover {
    box-shadow: 0 4px 12px rgba(37, 26, 76, 0.15);
    transform: translateY(-2px);
}

body.page-home .mx-home-upload-card.dragging {
    opacity: 0.5;
    cursor: grabbing;
    transform: scale(1.05) rotate(3deg);
    z-index: 100;
}

body.page-home .mx-home-upload-card.drag-over-left {
    transform: translateX(-4px);
}

body.page-home .mx-home-upload-card.drag-over-right {
    transform: translateX(4px);
}

body.page-home .mx-home-upload-badge {
    position: absolute;
    top: 4px;
    left: 4px;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: rgba(113, 61, 234, 0.95);
    color: white;
    font-size: 11px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
    pointer-events: none;
    z-index: 1;
}

body.page-home .mx-home-upload-card-remove {
    position: absolute;
    top: -6px;
    right: -6px;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: rgba(147, 197, 253, 0.75);
    color: white;
    font-size: 14px;
    line-height: 1;
    display: none;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    border: none;
    padding: 0;
    z-index: 2;
    transition: background 0.2s ease;
}

body.page-home .mx-home-upload-card-remove:hover {
    background: rgba(147, 197, 253, 0.95);
}

body.page-home .mx-home-upload-card:hover .mx-home-upload-card-remove {
    display: flex;
}

body.page-home .mx-home-upload .mx-home-upload-empty {
    width: 64px;
    height: 88px;
    border-radius: 12px;
    background: rgba(245, 241, 255, 0.6);
    border: 1px dashed rgba(113, 61, 234, 0.3);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 28px;
    color: rgba(113, 61, 234, 0.6);
    cursor: pointer;
    transition: all 0.2s ease;
    flex-shrink: 0;
}

body.page-home .mx-home-upload .mx-home-upload-empty:hover {
    background: rgba(245, 241, 255, 0.9);
    border-color: rgba(113, 61, 234, 0.5);
    color: rgba(113, 61, 234, 0.9);
}

body.page-home .mx-home-upload .mx-home-upload-count {
    position: absolute;
    left: 8px;
    top: -10px;
    height: 20px;
    padding: 0 8px;
    border-radius: 999px;
    font-size: 11px;
    line-height: 20px;
    font-weight: 600;
    color: #5b3dbb;
    background: rgba(225, 214, 253, 0.95);
    border: 1px solid rgba(197, 175, 255, 0.95);
    z-index: 10;
    display: none;
}

body.page-home .mx-home-upload.has-files .mx-home-upload-count {
    display: block;
}

body.page-home .mx-home-upload .mx-home-upload-clear {
    position: absolute;
    right: 8px;
    top: -10px;
    width: 24px;
    height: 24px;
    border: none;
    border-radius: 999px;
    background: rgba(147, 197, 253, 0.75);
    color: #fff;
    font-size: 16px;
    line-height: 1;
    display: none;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 10;
    transition: background 0.2s ease;
}

body.page-home .mx-home-upload .mx-home-upload-clear:hover {
    background: rgba(147, 197, 253, 0.95);
}

body.page-home .mx-home-upload.has-files .mx-home-upload-clear {
    display: flex;
}

body.page-home .mx-home-upload-more {
    display: none;
}

body.theme-night.page-home .mx-home-upload {
    border-color: transparent;
    background: transparent;
}

body.theme-night.page-home .mx-home-upload:hover {
    border-color: transparent;
    background: transparent;
}

body.theme-night.page-home .mx-home-upload.has-files {
    border-color: rgba(154, 123, 255, 0.5);
    background: rgba(20, 28, 44, 0.9);
}

body.theme-night.page-home .mx-home-upload.has-files:hover {
    border-color: rgba(154, 123, 255, 0.6);
    background: rgba(20, 28, 44, 0.9);
}

body.theme-night.page-home .mx-home-upload.drag-over {
    border-color: rgba(154, 123, 255, 0.7);
    background: rgba(56, 43, 96, 0.5);
    box-shadow: 0 0 0 3px rgba(154, 123, 255, 0.2);
}

body.theme-night.page-home .mx-home-upload.drag-over .mx-home-upload-empty {
    background: rgba(56, 43, 96, 0.7);
    border-color: rgba(154, 123, 255, 0.7);
    color: rgba(154, 123, 255, 1);
    transform: scale(1.1);
}

body.theme-night.page-home .mx-home-upload-card {
    border-color: rgba(104, 122, 158, 0.58);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

body.theme-night.page-home .mx-home-upload .mx-home-upload-empty {
    background: rgba(56, 43, 96, 0.4);
    border-color: rgba(154, 123, 255, 0.4);
    color: rgba(154, 123, 255, 0.7);
}

body.theme-night.page-home .mx-home-upload .mx-home-upload-empty:hover {
    background: rgba(56, 43, 96, 0.6);
    border-color: rgba(154, 123, 255, 0.6);
    color: rgba(154, 123, 255, 0.95);
}

body.theme-night.page-home .mx-home-upload .mx-home-upload-count {
    color: #d5c7ff;
    border-color: rgba(154, 123, 255, 0.5);
    background: rgba(56, 43, 96, 0.9);
}

body.theme-night.page-home .mx-home-upload .mx-home-upload-clear {
    background: rgba(147, 197, 253, 0.65);
}

body.theme-night.page-home .mx-home-upload .mx-home-upload-clear:hover {
    background: rgba(147, 197, 253, 0.85);
}

body.theme-night.page-home .mx-home-upload-card-remove {
    background: rgba(147, 197, 253, 0.65);
}

body.theme-night.page-home .mx-home-upload-card-remove:hover {
    background: rgba(147, 197, 253, 0.85);
}

@keyframes slideDown {
    from {
        opacity: 0;
        transform: translate(-50%, -20px);
    }
    to {
        opacity: 1;
        transform: translate(-50%, 0);
    }
}

@keyframes slideUp {
    from {
        opacity: 1;
        transform: translate(-50%, 0);
    }
    to {
        opacity: 0;
        transform: translate(-50%, -20px);
    }
}

/* Entry dropdown menus and settings panel */
body.page-home #mxHomeModelMenu,
body.page-home #mxHomeSettingsMenu {
    border: 1px solid rgba(224, 219, 240, 0.95);
    box-shadow: 0 16px 28px rgba(28, 22, 56, 0.14);
    backdrop-filter: blur(10px);
}

body.page-home .mx-home-settings {
    position: relative;
}

body.page-home .mx-home-setting-chip {
    cursor: pointer;
}

body.page-home #mxHomeSettingsMenu {
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    width: min(460px, calc(100vw - 220px));
    max-height: 320px;
    overflow-y: auto;
    border-radius: 14px;
    padding: 10px;
    background: rgba(255, 255, 255, 0.98);
    display: none;
    z-index: 12;
}

body.page-home #mxHomeSettingsMenu.show {
    display: block;
}

body.page-home .mx-home-settings-group {
    padding: 8px 4px;
    border-bottom: 1px solid rgba(236, 232, 246, 0.7);
}

body.page-home .mx-home-settings-group:last-child {
    border-bottom: none;
}

body.page-home .mx-home-settings-label {
    font-size: 12px;
    color: rgba(70, 64, 96, 0.72);
    margin-bottom: 7px;
}

body.page-home .mx-home-settings-row {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

body.page-home .mx-setting-chip {
    border: 1px solid rgba(229, 224, 243, 0.95);
    border-radius: 999px;
    height: 30px;
    padding: 0 10px;
    font-size: 12px;
    color: rgba(45, 40, 67, 0.8);
    background: #fff;
    cursor: pointer;
    transition: all 0.2s ease;
    position: relative;
}

body.page-home .quality-rec-tag {
    position: absolute;
    top: -8px;
    right: -4px;
    font-size: 9px;
    font-weight: 700;
    color: #fff;
    background: linear-gradient(135deg, #f59e0b, #f97316);
    padding: 1px 4px;
    border-radius: 4px;
    line-height: 1.3;
    pointer-events: none;
}

body.page-home .count-lv-tag {
    position: absolute;
    top: -8px;
    right: -4px;
    font-size: 9px;
    font-weight: 700;
    color: #fff;
    padding: 1px 4px;
    border-radius: 4px;
    line-height: 1.3;
    pointer-events: none;
}

body.page-home .count-lv-tag.lv2 {
    background: linear-gradient(135deg, #818cf8, #6366f1);
}

body.page-home .count-lv-tag.lv3 {
    background: linear-gradient(135deg, #f59e0b, #f97316);
}

body.page-home .mx-setting-chip.lv-locked {
    opacity: 0.45;
    cursor: not-allowed;
}

body.theme-night.page-home .mx-setting-chip.lv-locked {
    opacity: 0.35;
}

body.page-home .mx-setting-chip:hover {
    border-color: rgba(113, 61, 234, 0.35);
}

body.page-home .mx-setting-chip.active {
    background: rgba(113, 61, 234, 0.12);
    border-color: rgba(113, 61, 234, 0.42);
    color: #5c3dbe;
}

body.page-home .mx-setting-chip.disabled {
    opacity: 0.45;
    cursor: not-allowed;
    pointer-events: none;
}

body.theme-night.page-home #mxHomeSettingsMenu {
    background: rgba(21, 31, 49, 0.98);
    border-color: rgba(95, 112, 146, 0.5);
}

body.theme-night.page-home .mx-home-settings-group {
    border-bottom-color: rgba(87, 102, 133, 0.36);
}

body.theme-night.page-home .mx-home-settings-label {
    color: rgba(186, 199, 226, 0.76);
}

body.theme-night.page-home .mx-setting-chip {
    border-color: rgba(90, 108, 143, 0.46);
    background: rgba(22, 31, 47, 0.92);
    color: rgba(223, 233, 250, 0.86);
}

body.theme-night.page-home .mx-setting-chip.active {
    background: rgba(154, 123, 255, 0.2);
    border-color: rgba(154, 123, 255, 0.45);
    color: #ddccff;
}

body.theme-night.page-home .mx-setting-chip.disabled {
    opacity: 0.4;
}

/* Night landing sections should switch as a complete page */
body.theme-night.page-home-landing .hero,
body.theme-night.page-home-landing .testimonials-section,
body.theme-night.page-home-landing .recharge-section,
body.theme-night.page-home-landing .features-section,
body.theme-night.page-home-landing footer {
    background: #101521;
    color: #dce5f8;
}

/* ===== Mobile centering fixes (restored) ===== */
@media (max-width: 768px) {
    html {
        overflow-x: hidden;
    }

    body.page-home .navbar,
    body.page-normal .navbar,
    body.page-history .navbar,
    body.page-community .navbar {
        width: 100vw;
        max-width: 100vw;
        left: 0;
        right: auto;
        height: auto;
        min-height: 106px;
    }

    body.page-home .nav-container,
    body.page-normal .nav-container,
    body.page-history .nav-container,
    body.page-community .nav-container {
        display: grid;
        grid-template-columns: minmax(0, 1fr) auto;
        grid-template-areas:
            "brand auth"
            "links links";
        align-items: center;
        row-gap: 6px;
        column-gap: 10px;
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
        height: auto;
        flex-wrap: nowrap;
        justify-content: normal;
        padding: 6px 10px 8px;
    }

    body.page-home .nav-brand,
    body.page-normal .nav-brand,
    body.page-history .nav-brand,
    body.page-community .nav-brand {
        grid-area: brand;
        width: auto;
        height: 40px;
        padding: 0;
        justify-content: flex-start;
    }

    body.page-home .nav-brand .mx-brand-logo,
    body.page-normal .nav-brand .mx-brand-logo,
    body.page-history .nav-brand .mx-brand-logo,
    body.page-community .nav-brand .mx-brand-logo {
        width: 36px;
        height: 36px;
    }

    body.page-home .nav-links,
    body.page-normal .nav-links,
    body.page-history .nav-links,
    body.page-community .nav-links {
        grid-area: links;
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
        margin: 0;
        padding-bottom: 0;
        display: grid;
        grid-template-columns: repeat(5, minmax(0, 1fr));
        gap: 4px;
        justify-items: center;
        overflow: visible;
    }

    body.page-home .nav-link,
    body.page-normal .nav-link,
    body.page-history .nav-link,
    body.page-community .nav-link {
        width: 100%;
        min-height: 44px;
        padding: 2px 0;
        border-radius: 8px;
        justify-content: center;
    }

    body.page-home .nav-link .mx-nav-icon,
    body.page-normal .nav-link .mx-nav-icon,
    body.page-history .nav-link .mx-nav-icon,
    body.page-community .nav-link .mx-nav-icon {
        width: 28px;
        height: 28px;
        border-radius: 8px;
    }

    body.page-home .nav-link .mx-nav-label,
    body.page-normal .nav-link .mx-nav-label,
    body.page-history .nav-link .mx-nav-label,
    body.page-community .nav-link .mx-nav-label {
        margin-top: 2px;
        font-size: 11px;
        line-height: 1.2;
    }

    body.page-home .nav-auth,
    body.page-normal .nav-auth,
    body.page-history .nav-auth,
    body.page-community .nav-auth {
        grid-area: auth;
        width: auto;
        min-width: 0;
        margin-left: auto;
        display: inline-flex;
        flex-direction: row;
        flex-wrap: nowrap;
        justify-content: flex-end;
        align-items: center;
        gap: 4px;
    }

    body.page-home .nav-auth .btn,
    body.page-normal .nav-auth .btn,
    body.page-history .nav-auth .btn,
    body.page-community .nav-auth .btn {
        width: auto;
        min-width: 58px;
        height: 30px;
        padding: 0 8px;
        font-size: 12px;
    }

    body.page-home #normalThemeToggle,
    body.page-normal #normalThemeToggle,
    body.page-history #normalThemeToggle,
    body.page-community #normalThemeToggle {
        width: 46px;
        height: 26px;
        padding: 0 7px;
    }

    body.page-home #normalThemeToggle .theme-toggle-thumb,
    body.page-normal #normalThemeToggle .theme-toggle-thumb,
    body.page-history #normalThemeToggle .theme-toggle-thumb,
    body.page-community #normalThemeToggle .theme-toggle-thumb {
        width: 16px;
        height: 16px;
    }

    body.page-home #normalThemeToggle[data-mode="night"] .theme-toggle-thumb,
    body.page-normal #normalThemeToggle[data-mode="night"] .theme-toggle-thumb,
    body.page-history #normalThemeToggle[data-mode="night"] .theme-toggle-thumb,
    body.page-community #normalThemeToggle[data-mode="night"] .theme-toggle-thumb {
        transform: translateX(22px);
    }

    body.page-home .nav-user,
    body.page-normal .nav-user,
    body.page-history .nav-user,
    body.page-community .nav-user {
        display: inline-flex;
        flex-direction: row;
        align-items: center;
        gap: 6px;
        min-width: 36px;
        position: relative;
    }

    body.page-home .nav-avatar-wrapper,
    body.page-normal .nav-avatar-wrapper,
    body.page-history .nav-avatar-wrapper,
    body.page-community .nav-avatar-wrapper {
        display: inline-flex;
        flex-direction: row;
        align-items: center;
        gap: 4px;
    }

    body.page-home .nav-credits-display,
    body.page-normal .nav-credits-display,
    body.page-history .nav-credits-display,
    body.page-community .nav-credits-display {
        position: static;
        font-size: 12px;
        line-height: 1;
        margin: 0;
    }

    body.page-home #navRedeemBtn,
    body.page-normal #navRedeemBtn,
    body.page-history #navRedeemBtn,
    body.page-community #navRedeemBtn {
        margin: 0 0 0 4px;
        min-width: 56px;
        height: 28px;
        padding: 0 10px;
        font-size: 11px;
        line-height: 1.1;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        text-align: center;
    }

    /* 移动端导航改为单行：品牌 + 菜单 + 账号区同一行 */
    body.page-home .navbar,
    body.page-normal .navbar,
    body.page-history .navbar,
    body.page-community .navbar {
        min-height: 72px;
    }

    body.page-home .nav-container,
    body.page-normal .nav-container,
    body.page-history .nav-container,
    body.page-community .nav-container {
        display: flex;
        flex-direction: row;
        flex-wrap: nowrap;
        align-items: center;
        justify-content: flex-start;
        gap: 4px;
        padding: 6px 8px;
    }

    body.page-home .nav-brand,
    body.page-normal .nav-brand,
    body.page-history .nav-brand,
    body.page-community .nav-brand {
        flex: 0 0 auto;
        width: 38px;
        height: 34px;
        padding: 0;
    }

    body.page-home .nav-brand .mx-brand-logo,
    body.page-normal .nav-brand .mx-brand-logo,
    body.page-history .nav-brand .mx-brand-logo,
    body.page-community .nav-brand .mx-brand-logo {
        width: 30px;
        height: 30px;
    }

    body.page-home .nav-links,
    body.page-normal .nav-links,
    body.page-history .nav-links,
    body.page-community .nav-links {
        flex: 1 1 auto;
        width: auto;
        max-width: none;
        min-width: 0;
        margin: 0;
        padding: 0;
        display: grid;
        grid-template-columns: repeat(5, minmax(0, 1fr));
        gap: 2px;
        align-items: start;
        justify-items: center;
        overflow: visible;
    }

    body.page-home .nav-link,
    body.page-normal .nav-link,
    body.page-history .nav-link,
    body.page-community .nav-link {
        width: 100%;
        min-height: 34px;
        padding: 0;
        border-radius: 6px;
    }

    body.page-home .nav-link .mx-nav-icon,
    body.page-normal .nav-link .mx-nav-icon,
    body.page-history .nav-link .mx-nav-icon,
    body.page-community .nav-link .mx-nav-icon {
        width: 22px;
        height: 22px;
        border-radius: 6px;
    }

    body.page-home .nav-link .mx-nav-icon img,
    body.page-normal .nav-link .mx-nav-icon img,
    body.page-history .nav-link .mx-nav-icon img,
    body.page-community .nav-link .mx-nav-icon img {
        width: 14px;
        height: 14px;
    }

    body.page-home .nav-link .mx-nav-label,
    body.page-normal .nav-link .mx-nav-label,
    body.page-history .nav-link .mx-nav-label,
    body.page-community .nav-link .mx-nav-label {
        margin-top: 1px;
        font-size: 10px;
        line-height: 1.1;
    }

    body.page-home .nav-auth,
    body.page-normal .nav-auth,
    body.page-history .nav-auth,
    body.page-community .nav-auth {
        flex: 0 0 auto;
        width: auto;
        min-width: 0;
        margin-left: 0;
        gap: 3px;
    }

    body.page-home .nav-user,
    body.page-normal .nav-user,
    body.page-history .nav-user,
    body.page-community .nav-user {
        gap: 4px;
        min-width: 0;
    }

    body.page-home .nav-avatar,
    body.page-normal .nav-avatar,
    body.page-history .nav-avatar,
    body.page-community .nav-avatar {
        width: 34px;
        height: 34px;
        font-size: 15px;
    }

    body.page-home .nav-credits-display,
    body.page-normal .nav-credits-display,
    body.page-history .nav-credits-display,
    body.page-community .nav-credits-display {
        font-size: 11px;
    }

    body.page-home.page-home-entry .mx-home-wrap {
        padding: 92px 12px 18px;
        gap: 16px;
        align-items: center;
    }

    body.page-home.page-home-entry .mx-home-hero,
    body.page-home.page-home-entry .mx-home-support,
    body.page-home.page-home-entry .mx-home-composer {
        width: 100%;
    }

    body.page-home.page-home-entry .mx-home-model-line,
    body.page-home.page-home-entry .mx-home-copy {
        max-width: 100%;
    }

    body.page-home.page-home-entry .mx-home-composer-panel {
        border-radius: 20px;
        padding: 12px;
        min-height: 0;
    }

    body.page-home.page-home-entry .mx-home-input-row {
        flex-direction: column;
        align-items: stretch;
        gap: 8px;
    }

    body.page-home.page-home-entry .mx-home-upload {
        width: 100%;
        min-width: 0;
        min-height: 0;
        height: auto;
        padding: 30px 8px 8px;
        border-radius: 14px;
        flex-direction: row;
        align-items: center;
        justify-content: flex-start;
        gap: 6px;
    }

    body.page-home.page-home-entry .mx-home-upload.has-files {
        width: 100%;
        max-width: 100%;
    }

    body.page-home.page-home-entry .mx-home-upload-stack {
        min-height: 0;
        width: 100%;
        max-width: 100%;
        flex: 1 1 auto;
        justify-content: flex-start;
        overflow-x: auto;
        overflow-y: hidden;
        padding: 2px 2px 2px 0;
        gap: 6px;
        scrollbar-width: thin;
    }

    body.page-home.page-home-entry .mx-home-upload-stack::-webkit-scrollbar {
        height: 4px;
    }

    body.page-home.page-home-entry .mx-home-upload-stack::-webkit-scrollbar-thumb {
        background: rgba(148, 163, 184, 0.42);
        border-radius: 999px;
    }

    body.page-home.page-home-entry .mx-home-upload-card,
    body.page-home.page-home-entry .mx-home-upload .mx-home-upload-empty {
        width: 54px;
        height: 72px;
        border-radius: 10px;
    }

    body.page-home.page-home-entry .mx-home-upload .mx-home-upload-empty {
        font-size: 24px;
    }

    body.page-home.page-home-entry .mx-home-upload .mx-home-upload-count {
        top: 6px;
        left: 8px;
        height: 18px;
        line-height: 18px;
        padding: 0 7px;
        font-size: 10px;
    }

    body.page-home.page-home-entry .mx-home-upload .mx-home-upload-clear {
        top: 5px;
        right: 8px;
        width: 20px;
        height: 20px;
        font-size: 13px;
    }

    body.page-home.page-home-entry #mxHomePrompt {
        width: 100%;
        flex: 0 1 auto;
        min-height: 108px;
        max-height: 280px;
        padding: 4px 2px 10px;
    }

    body.page-home.page-home-entry .mx-home-toolbar {
        flex-wrap: wrap;
        justify-content: center;
        gap: 8px;
    }

    body.page-home.page-home-entry .mx-home-model,
    body.page-home.page-home-entry .mx-home-settings,
    body.page-home.page-home-entry #mxHomePromptEnhanceBtn {
        flex: 1 1 100%;
        min-width: 0;
    }

    body.page-home.page-home-entry #mxHomeModelTrigger,
    body.page-home.page-home-entry .mx-home-setting-chip,
    body.page-home.page-home-entry #mxHomePromptEnhanceBtn {
        width: 100%;
        justify-content: center;
    }

    body.page-home.page-home-entry #mxHomeGenerateBtn {
        flex: 1 1 100%;
        width: 100%;
        max-width: none;
        height: 42px;
        margin-left: 0;
    }

    body.page-home.page-home-entry #mxHomeModelMenu,
    body.page-home.page-home-entry #mxHomeSettingsMenu {
        left: 50%;
        right: auto;
        transform: translateX(-50%);
        width: min(560px, calc(100vw - 24px));
        max-width: min(560px, calc(100vw - 24px));
    }

    body.page-home.page-home-entry #mxHomeModelMenu {
        padding: 10px;
        max-height: min(70vh, 520px);
        z-index: 2600;
    }

    body.page-home.page-home-entry #mxHomeSettingsMenu {
        max-height: min(62vh, 420px);
    }

    body.page-home.page-home-entry .mx-home-templates-wrapper {
        width: 100%;
    }

    body.page-home.page-home-entry .mx-home-templates-header {
        padding: 0 4px 10px;
    }

    body.page-home.page-home-entry .mx-home-templates {
        padding: 0 4px 6px;
    }

    body.page-home.page-home-landing .hero {
        padding-top: 146px;
    }

    body.page-home.page-home-landing > section,
    body.page-home.page-home-landing > footer {
        width: 100vw;
        max-width: 100vw;
        margin-left: 0;
    }

    body.page-home.page-home-landing .hero-content {
        gap: 24px;
        width: 100%;
        max-width: 100%;
        padding: 0 12px;
        box-sizing: border-box;
    }

    body.page-home.page-home-landing .hero-left {
        width: min(420px, calc(100vw - 24px));
        max-width: 100%;
        align-items: center;
        text-align: center;
        gap: 18px;
        padding-inline: 8px;
        margin-inline: auto;
        box-sizing: border-box;
    }

    body.page-home.page-home-landing .hero-subtitle {
        width: 100%;
        max-width: calc(100vw - 40px);
        margin-inline: auto;
        padding-inline: 6px;
    }

    body.page-home.page-home-landing .hero-kicker {
        width: 100%;
        justify-content: center;
    }

    body.page-home.page-home-landing .kicker-note {
        display: block;
        width: 100%;
        margin-top: 2px;
        white-space: normal;
        text-align: center;
    }

    body.page-home.page-home-landing .hero-title-art {
        width: min(310px, calc(100vw - 40px));
        margin-inline: auto;
    }

    body.page-home.page-home-landing .hero-compare,
    body.page-home.page-home-landing .compare-header,
    body.page-home.page-home-landing .compare-view,
    body.page-home.page-home-landing .compare-images {
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
    }

    body.page-home.page-home-landing .hero-compare {
        width: min(420px, calc(100vw - 24px));
        margin-inline: auto;
    }

    body.page-home.page-home-landing .compare-controls {
        gap: 6px;
    }

    body.page-home.page-home-landing .compare-counter {
        font-size: 12px;
    }

    body.page-normal .main-content {
        padding: 122px 0 188px;
    }

    body.page-normal .main-content > .container,
    body.page-history .main-content > .container {
        padding: 0 10px;
    }

    /* Generate workspace: fix mobile composer controls alignment */
    body.page-normal .studio-composer,
    body.page-normal.mx-composer-collapsed .studio-composer {
        width: calc(100vw - 16px);
        left: 50%;
        transform: translateX(-50%);
        bottom: 8px;
        padding: 8px;
        border-radius: 18px;
    }

    body.page-normal .timeline-list {
        padding-bottom: 320px;
    }

    body.page-normal .composer-input textarea,
    body.page-normal.mx-composer-collapsed .composer-input textarea {
        min-height: 96px;
        max-height: 30vh;
        padding: 8px 10px;
        font-size: 14px;
        line-height: 1.45;
    }

    body.page-normal .compact-controls,
    body.page-normal.mx-composer-collapsed .compact-controls {
        margin-top: 8px;
        padding: 8px;
        border-radius: 14px;
        display: flex;
        flex-wrap: wrap;
        align-items: stretch;
        gap: 8px;
    }

    body.page-normal .compact-controls .composer-left,
    body.page-normal.mx-composer-collapsed .compact-controls .composer-left {
        flex: 1 1 100%;
        display: grid;
        grid-template-columns: auto minmax(0, 1fr) auto auto;
        flex-wrap: nowrap;
        align-items: center;
        gap: 6px;
        min-width: 0;
    }

    body.page-normal .normal-media-mode-switch {
        flex: 0 0 auto;
        min-width: 104px;
    }

    body.page-normal .engine-selector-inline {
        flex: 0 1 clamp(132px, 40vw, 190px);
        min-width: 0;
        max-width: clamp(132px, 40vw, 190px);
    }

    body.page-normal .engine-current-display {
        padding-left: 28px;
        padding-right: 8px;
        min-width: 0;
        max-width: 100%;
        width: 100%;
        overflow: hidden;
        gap: 4px;
    }

    body.page-normal .engine-current-display::before {
        left: 8px;
        width: 16px;
        height: 16px;
        border-radius: 6px;
    }

    body.page-normal .engine-current-display .engine-mode-info {
        min-width: 0;
        flex: 1 1 auto;
    }

    body.page-normal .engine-current-display .engine-mode-name {
        display: block;
        min-width: 0;
        max-width: 100%;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        font-size: 12px;
    }

    body.page-normal .engine-current-display .engine-arrow {
        flex: 0 0 auto;
        margin-left: 2px;
        font-size: 11px;
    }

    body.page-normal .engine-cards-dropdown {
        width: min(318px, calc(100vw - 24px));
        max-height: min(56vh, 420px);
    }

    body.page-normal .engine-option-card {
        min-height: 62px;
        padding: 10px 10px 10px 44px;
    }

    body.page-normal .engine-option-card::before {
        left: 10px;
        width: 28px;
        height: 28px;
        border-radius: 9px;
    }

    body.page-normal .engine-option-card .card-left {
        max-width: calc(100% - 66px);
        padding-right: 6px;
    }

    body.page-normal .engine-option-card .card-title {
        font-size: 12px;
        line-height: 1.3;
        gap: 4px;
    }

    body.page-normal .engine-option-card .card-meta {
        font-size: 10px;
        margin-top: 2px;
        line-height: 1.3;
    }

    body.page-normal .engine-option-card .card-right {
        width: 58px;
        gap: 4px;
        padding-left: 6px;
    }

    body.page-normal .engine-option-card .credits-tag {
        font-size: 12px;
        padding: 0;
    }

    body.page-normal .engine-option-card .channel-status-indicator {
        transform: scale(0.92);
        transform-origin: right top;
    }

    body.page-normal .settings-chip-wrap {
        flex: 0 0 auto;
        min-width: 98px;
    }

    body.page-normal #normalSettingsBtn {
        width: auto;
        min-width: 98px;
        height: 34px;
        padding: 0 10px;
        justify-content: center;
    }

    body.page-normal .prompt-enhance-wrap {
        margin-left: 0;
        flex: 0 0 auto;
    }

    body.page-normal .compact-controls .composer-right,
    body.page-normal.mx-composer-collapsed .compact-controls .composer-right {
        flex: 1 1 100%;
        margin-left: 0;
        justify-content: stretch;
    }

    body.page-normal #normalSubmitBtn {
        min-width: 108px;
        height: 34px;
        border-radius: 12px;
        width: 100%;
    }

    body.page-history .history-scale {
        padding-top: 122px;
    }

    body.page-history .history-filters {
        padding: 12px;
        gap: 10px;
    }

    body.page-history .history-stats-left,
    body.page-history .history-actions-right {
        width: 100%;
        justify-content: center;
        flex-wrap: wrap;
    }

    body.page-history .history-action-btn {
        flex: 1 1 120px;
        min-width: 0;
    }

    body.page-history .history-content {
        padding: 14px;
        border-radius: 14px;
    }

    /* History fullscreen modal: keep media area clear on mobile */
    body.page-history #fullscreenModal .fullscreen-container {
        height: 100dvh;
        display: flex;
        flex-direction: column;
        overflow-y: auto;
        overflow-x: hidden;
        -webkit-overflow-scrolling: touch;
    }

    body.page-history #fullscreenModal .fullscreen-image-section {
        flex: 0 0 auto;
        height: min(56dvh, calc(100dvh - 330px));
        min-height: 260px;
        padding: 8px 8px 0;
        justify-content: flex-start;
        overflow: hidden;
    }

    body.page-history #fullscreenModal .fullscreen-main-image-container {
        flex: 1 1 auto;
        min-height: 0;
        padding: 54px 8px 10px;
    }

    body.page-history #fullscreenModal .fullscreen-main-image,
    body.page-history #fullscreenModal .fullscreen-main-video {
        max-height: 100%;
        max-width: calc(100% - 96px);
    }

    body.page-history #fullscreenModal .fullscreen-thumbnails {
        width: 100%;
        box-sizing: border-box;
        margin-top: auto;
        padding: 8px 12px 10px;
        gap: 8px;
        min-height: 70px;
        align-items: center;
    }

    body.page-history #fullscreenModal .fullscreen-thumbnail {
        flex: 0 0 56px;
        width: 56px;
        height: 56px;
    }

    body.page-history #fullscreenModal .fullscreen-close,
    body.page-history #fullscreenModal .fullscreen-counter {
        top: 10px;
    }

    body.page-history #fullscreenModal .fullscreen-close {
        right: 10px;
    }

    body.page-history #fullscreenModal .fullscreen-counter {
        left: 10px;
        padding: 6px 10px;
        font-size: 12px;
    }

    body.page-history #fullscreenModal .fullscreen-nav {
        width: 42px;
        height: 42px;
        z-index: 6;
    }

    body.page-history #fullscreenModal .fullscreen-nav-prev {
        left: 8px;
    }

    body.page-history #fullscreenModal .fullscreen-nav-next {
        right: 8px;
    }

    body.page-history #fullscreenModal .fullscreen-info-section {
        width: 100%;
        max-height: none;
        min-height: 0;
        overflow: visible;
        border-left: none;
        border-top: 1px solid rgba(212, 219, 232, 0.7);
    }

    body.page-history #fullscreenModal .fullscreen-info-header {
        padding: 10px 14px 8px;
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        column-gap: 8px;
        row-gap: 6px;
    }

    body.page-history #fullscreenModal .fullscreen-meta-chips {
        flex: 1 1 100%;
        display: flex;
        flex-wrap: nowrap;
        gap: 8px;
        white-space: nowrap;
        overflow-x: auto;
        padding-bottom: 4px;
    }

    body.page-history #fullscreenModal .fullscreen-meta-pill {
        padding: 3px 8px;
        font-size: 12px;
    }

    body.page-history #fullscreenModal .fullscreen-info-body {
        flex: 0 0 auto;
        overflow: visible;
        padding: 14px 16px;
    }

    body.page-history #fullscreenModal .fullscreen-sub-meta {
        margin-top: 0;
        font-size: 12px;
        line-height: 1.35;
    }

    body.page-history #fullscreenModal .fullscreen-prompt-text {
        max-height: none;
        overflow: visible;
        min-height: 120px;
    }

    body.page-history #fullscreenModal .fullscreen-actions {
        padding: 12px 16px 20px;
    }

    body.page-history .pagination-section {
        flex-wrap: wrap;
        gap: 8px;
    }

    body.page-community .main-content {
        padding-top: 122px;
    }
}

@media (max-width: 480px) {
    body.page-home .nav-container,
    body.page-normal .nav-container,
    body.page-history .nav-container,
    body.page-community .nav-container {
        padding: 5px 6px;
        row-gap: 0;
    }

    body.page-home .nav-link,
    body.page-normal .nav-link,
    body.page-history .nav-link,
    body.page-community .nav-link {
        min-height: 34px;
    }

    body.page-home .nav-link .mx-nav-label,
    body.page-normal .nav-link .mx-nav-label,
    body.page-history .nav-link .mx-nav-label,
    body.page-community .nav-link .mx-nav-label {
        font-size: 10px;
    }

    body.page-home .nav-auth .btn,
    body.page-normal .nav-auth .btn,
    body.page-history .nav-auth .btn,
    body.page-community .nav-auth .btn {
        min-width: 46px;
        padding: 0 6px;
        font-size: 9px;
        height: 26px;
    }

    body.page-home.page-home-entry .mx-home-wrap {
        padding-top: 90px;
    }

    body.page-home.page-home-entry .mx-home-upload-card,
    body.page-home.page-home-entry .mx-home-upload .mx-home-upload-empty {
        width: 50px;
        height: 66px;
        border-radius: 9px;
    }

    body.page-home.page-home-entry .mx-home-upload {
        padding: 28px 6px 6px;
    }

    body.page-home.page-home-entry .mx-home-upload .mx-home-upload-count {
        top: 5px;
        left: 6px;
    }

    body.page-home.page-home-entry .mx-home-upload .mx-home-upload-clear {
        top: 4px;
        right: 6px;
    }

    body.page-home.page-home-entry .mx-home-support {
        gap: 6px;
    }

    body.page-home.page-home-entry .mx-home-model-line {
        padding: 6px 10px;
        font-size: 13px;
    }

    body.page-normal .main-content,
    body.page-history .history-scale,
    body.page-community .main-content {
        padding-top: 116px;
    }

    body.page-normal .timeline-list {
        padding-bottom: 350px;
    }

    body.page-normal .compact-controls .composer-left {
        grid-template-columns: auto minmax(0, 1fr) auto auto;
        gap: 5px;
    }

    body.page-normal .normal-media-mode-switch {
        width: auto;
        min-width: 98px;
        justify-content: flex-start;
    }

    body.page-normal .engine-selector-inline {
        flex: 0 1 clamp(108px, 38vw, 160px);
        max-width: clamp(108px, 38vw, 160px);
    }

    body.page-normal .engine-current-display {
        padding-left: 24px;
        padding-right: 6px;
        gap: 3px;
    }

    body.page-normal .engine-current-display::before {
        left: 6px;
        width: 14px;
        height: 14px;
        border-radius: 5px;
    }

    body.page-normal .engine-current-display .engine-mode-name {
        font-size: 11px;
    }

    body.page-normal .settings-chip-wrap {
        flex: 0 0 auto;
        min-width: 90px;
    }

    body.page-normal #normalSettingsBtn {
        width: auto;
        min-width: 90px;
        height: 32px;
        padding: 0 8px;
    }

    body.page-normal #normalSettingsBtn .chip-text {
        font-size: 11px;
        max-width: 82px;
    }

    body.page-normal .composer-input textarea,
    body.page-normal.mx-composer-collapsed .composer-input textarea {
        min-height: 82px;
        max-height: 24vh;
        font-size: 13px;
    }

    body.page-normal .engine-cards-dropdown {
        width: min(300px, calc(100vw - 14px));
        max-height: min(52vh, 380px);
    }

    body.page-normal .engine-option-card {
        min-height: 58px;
        padding: 9px 9px 9px 40px;
    }

    body.page-normal .engine-option-card::before {
        left: 8px;
        width: 26px;
        height: 26px;
    }

    body.page-normal .engine-option-card .card-title {
        font-size: 11px;
    }

    body.page-normal .engine-option-card .card-meta {
        font-size: 9px;
    }

    body.page-normal .compact-controls .composer-right {
        justify-content: stretch;
    }

    body.page-normal #normalSubmitBtn {
        width: 100%;
    }

    body.page-history .history-actions-right .history-action-btn {
        flex: 1 1 100%;
    }

    body.page-history #fullscreenModal .fullscreen-image-section {
        height: min(54dvh, calc(100dvh - 320px));
        min-height: 230px;
    }

    body.page-history #fullscreenModal .fullscreen-main-image,
    body.page-history #fullscreenModal .fullscreen-main-video {
        max-width: calc(100% - 86px);
    }

    body.page-history #fullscreenModal .fullscreen-info-section {
        max-height: none;
    }

    body.page-history #fullscreenModal .fullscreen-info-header {
        padding: 8px 12px 6px;
        row-gap: 4px;
    }

    body.page-history #fullscreenModal .fullscreen-meta-pill {
        padding: 2px 7px;
        font-size: 11px;
    }

    body.page-history #fullscreenModal .fullscreen-info-body {
        padding: 12px;
    }
}

/* Image preview modal */
.mx-image-preview-modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.9);
    z-index: 10000;
    display: none;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    animation: fadeIn 0.2s ease;
}

.mx-image-preview-modal.show {
    display: flex;
}

.mx-image-preview-modal img {
    max-width: 90%;
    max-height: 90%;
    object-fit: contain;
    border-radius: 8px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5);
    cursor: default;
}

@keyframes fadeIn {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

body.page-home .recharge-proof {
    position: absolute;
    top: 14px;
    right: 14px;
    z-index: 3;
    padding: 5px 12px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.02em;
    backdrop-filter: blur(6px);
}

@media (max-width: 768px) {
    body.page-home .recharge-proof {
        top: 10px;
        right: 10px;
        font-size: 11px;
        padding: 4px 10px;
    }
}

/* Landing hero: model matrix stage */
body.page-home.page-home-landing {
    --mx-stage-bg: linear-gradient(145deg, rgba(13, 21, 38, 0.97) 0%, rgba(18, 31, 54, 0.95) 48%, rgba(22, 40, 68, 0.93) 100%);
    --mx-stage-border: rgba(145, 166, 212, 0.35);
    --mx-stage-shadow: 0 30px 90px rgba(0, 0, 0, 0.36);
    --mx-stage-card-bg: rgba(19, 34, 60, 0.74);
    --mx-stage-card-border: rgba(157, 180, 230, 0.26);
    --mx-stage-text: rgba(236, 244, 255, 0.95);
    --mx-stage-muted: rgba(199, 214, 241, 0.82);
    --mx-stage-link-bg: rgba(82, 177, 255, 0.2);
    --mx-stage-link-border: rgba(108, 194, 255, 0.48);
    --mx-stage-review-bg: rgba(17, 31, 56, 0.62);
    --mx-stage-review-border: rgba(156, 182, 236, 0.22);
}

body.theme-day.page-home.page-home-landing {
    --mx-stage-bg: linear-gradient(145deg, rgba(240, 246, 255, 0.98) 0%, rgba(231, 242, 255, 0.95) 52%, rgba(239, 248, 255, 0.95) 100%);
    --mx-stage-border: rgba(125, 153, 205, 0.34);
    --mx-stage-shadow: 0 24px 80px rgba(39, 57, 102, 0.18);
    --mx-stage-card-bg: rgba(255, 255, 255, 0.76);
    --mx-stage-card-border: rgba(132, 162, 216, 0.34);
    --mx-stage-text: #1a2d56;
    --mx-stage-muted: #4a6291;
    --mx-stage-link-bg: rgba(65, 138, 255, 0.12);
    --mx-stage-link-border: rgba(72, 140, 252, 0.42);
    --mx-stage-review-bg: rgba(255, 255, 255, 0.72);
    --mx-stage-review-border: rgba(132, 162, 216, 0.3);
}

body.theme-night.page-home.page-home-landing {
    --mx-stage-bg: linear-gradient(145deg, rgba(12, 20, 35, 0.98) 0%, rgba(16, 26, 45, 0.95) 52%, rgba(18, 34, 58, 0.97) 100%);
    --mx-stage-border: rgba(134, 157, 209, 0.35);
    --mx-stage-shadow: 0 30px 92px rgba(0, 0, 0, 0.44);
    --mx-stage-card-bg: rgba(18, 31, 54, 0.72);
    --mx-stage-card-border: rgba(159, 184, 233, 0.22);
    --mx-stage-text: rgba(234, 243, 255, 0.95);
    --mx-stage-muted: rgba(199, 214, 241, 0.84);
    --mx-stage-link-bg: rgba(82, 177, 255, 0.18);
    --mx-stage-link-border: rgba(108, 194, 255, 0.44);
    --mx-stage-review-bg: rgba(17, 31, 56, 0.64);
    --mx-stage-review-border: rgba(156, 182, 236, 0.24);
}

body.page-home.page-home-landing .hero-content {
    grid-template-columns: minmax(320px, 540px) minmax(0, 1fr);
    gap: clamp(22px, 2.8vw, 52px);
    align-items: stretch;
}

body.page-home.page-home-landing .hero-left {
    max-width: 560px;
}

body.page-home.page-home-landing #heroTypewriter {
    display: inline;
    min-height: 0;
}

body.page-home.page-home-landing .hero-trust-chips {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
}

body.page-home.page-home-landing .hero-trust-chip {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 12px;
    border-radius: 999px;
    font-size: 0.77rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    color: var(--mx-stage-text);
    border: 1px solid rgba(137, 170, 227, 0.32);
    background: rgba(28, 48, 82, 0.35);
}

body.theme-day.page-home.page-home-landing .hero-trust-chip {
    color: #24457f;
    border-color: rgba(110, 145, 208, 0.3);
    background: rgba(255, 255, 255, 0.78);
}

body.page-home.page-home-landing .hero-confidence {
    margin-top: 4px;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

body.page-home.page-home-landing .hero-confidence-item {
    border-radius: 14px;
    border: 1px solid rgba(135, 167, 223, 0.24);
    background: rgba(22, 40, 70, 0.32);
    padding: 10px 12px;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

body.theme-day.page-home.page-home-landing .hero-confidence-item {
    border-color: rgba(115, 145, 206, 0.24);
    background: rgba(255, 255, 255, 0.66);
}

body.page-home.page-home-landing .hero-confidence-item strong {
    font-size: 0.86rem;
    color: var(--mx-stage-text);
    letter-spacing: 0.01em;
}

body.page-home.page-home-landing .hero-confidence-item span {
    font-size: 0.73rem;
    line-height: 1.45;
    color: var(--mx-stage-muted);
}

body.page-home.page-home-landing .hero-model-stage {
    position: relative;
    min-height: 520px;
    border-radius: 30px;
    padding: 24px;
    border: 1px solid var(--mx-stage-border);
    background: var(--mx-stage-bg);
    box-shadow: var(--mx-stage-shadow);
    overflow: hidden;
    isolation: isolate;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

body.page-home.page-home-landing .hero-model-stage::before,
body.page-home.page-home-landing .hero-model-stage::after {
    content: "";
    position: absolute;
    pointer-events: none;
    z-index: 1;
}

body.page-home.page-home-landing .hero-model-stage::before {
    inset: -30%;
    background: conic-gradient(
        from 0deg at 50% 50%,
        rgba(90, 201, 255, 0.24) 0deg,
        rgba(117, 151, 255, 0.14) 95deg,
        rgba(255, 198, 113, 0.16) 180deg,
        rgba(84, 196, 255, 0.2) 270deg,
        rgba(90, 201, 255, 0.24) 360deg
    );
    animation: mxAuraSpin 28s linear infinite;
    opacity: 0.55;
}

body.page-home.page-home-landing .hero-model-stage::after {
    inset: 0;
    background: linear-gradient(
        110deg,
        transparent 0%,
        rgba(120, 191, 255, 0.08) 42%,
        rgba(255, 206, 128, 0.07) 55%,
        transparent 72%
    );
    transform: translateX(-120%);
    animation: mxScanFlow 10s ease-in-out infinite;
    opacity: 0.6;
}

body.page-home.page-home-landing .hero-stage-texture,
body.page-home.page-home-landing .hero-stage-lines {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
}

body.page-home.page-home-landing .hero-stage-texture {
    opacity: 0.66;
    mix-blend-mode: screen;
    animation: mxTextureFloat 14s ease-in-out infinite;
}

body.page-home.page-home-landing .hero-stage-lines {
    opacity: 0.92;
}

body.page-home.page-home-landing .stage-line {
    fill: none;
    stroke-width: 1.4;
    stroke-linecap: round;
    stroke-dasharray: 10 12;
    animation: mxLineDash 10s linear infinite;
}

body.page-home.page-home-landing .stage-line-a {
    stroke: rgba(84, 205, 255, 0.72);
}

body.page-home.page-home-landing .stage-line-b {
    stroke: rgba(131, 162, 255, 0.7);
    animation-duration: 12s;
    animation-direction: reverse;
}

body.page-home.page-home-landing .stage-line-c {
    stroke: rgba(255, 202, 122, 0.62);
    animation-duration: 14s;
}

body.page-home.page-home-landing .hero-stage-orb {
    position: absolute;
    border-radius: 999px;
    filter: blur(3px);
    opacity: 0.72;
    pointer-events: none;
}

body.page-home.page-home-landing .hero-stage-orb.orb-a {
    width: 180px;
    height: 180px;
    left: -46px;
    top: 38px;
    background: radial-gradient(circle at 32% 30%, rgba(68, 211, 250, 0.64) 0%, rgba(43, 115, 235, 0.18) 70%, transparent 100%);
    animation: mxOrbDriftA 8.5s ease-in-out infinite;
}

body.page-home.page-home-landing .hero-stage-orb.orb-b {
    width: 220px;
    height: 220px;
    right: -72px;
    bottom: -40px;
    background: radial-gradient(circle at 40% 34%, rgba(255, 197, 105, 0.58) 0%, rgba(76, 174, 255, 0.14) 74%, transparent 100%);
    animation: mxOrbDriftB 9.5s ease-in-out infinite;
}

body.page-home.page-home-landing .hero-stage-header,
body.page-home.page-home-landing .hero-model-matrix,
body.page-home.page-home-landing .hero-stage-social,
body.page-home.page-home-landing .hero-stage-foot {
    position: relative;
    z-index: 2;
}

body.page-home.page-home-landing .hero-stage-header h3 {
    margin: 8px 0 6px;
    font-size: clamp(1.22rem, 1.6vw, 1.52rem);
    line-height: 1.3;
    color: var(--mx-stage-text);
    letter-spacing: 0.01em;
}

body.page-home.page-home-landing .hero-stage-header p {
    margin: 0;
    font-size: 0.92rem;
    line-height: 1.6;
    color: var(--mx-stage-muted);
}

body.page-home.page-home-landing .hero-stage-assurance {
    margin-top: 8px;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 7px;
}

body.page-home.page-home-landing .hero-stage-assurance-item {
    display: inline-flex;
    align-items: center;
    min-height: 24px;
    padding: 0 9px;
    border-radius: 999px;
    border: 1px solid rgba(141, 173, 229, 0.3);
    background: rgba(24, 46, 80, 0.28);
    color: var(--mx-stage-muted);
    font-size: 0.69rem;
    font-weight: 700;
    letter-spacing: 0.02em;
}

body.theme-day.page-home.page-home-landing .hero-stage-assurance-item {
    border-color: rgba(112, 145, 206, 0.26);
    background: rgba(255, 255, 255, 0.68);
}

body.page-home.page-home-landing .hero-stage-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    min-height: 28px;
    padding: 0 12px;
    border-radius: 999px;
    background: rgba(67, 151, 255, 0.14);
    border: 1px solid rgba(116, 174, 255, 0.34);
    color: #6ecbff;
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.1em;
}

body.theme-day.page-home.page-home-landing .hero-stage-badge {
    color: #1f67d9;
    background: rgba(56, 121, 226, 0.12);
    border-color: rgba(70, 130, 236, 0.26);
}

body.page-home.page-home-landing .hero-model-matrix {
    margin-top: 4px;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

body.page-home.page-home-landing .hero-model-card {
    min-height: 104px;
    border-radius: 18px;
    padding: 13px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 8px;
    background: var(--mx-stage-card-bg);
    border: 1px solid var(--mx-stage-card-border);
    box-shadow: 0 12px 36px rgba(14, 28, 58, 0.24);
    backdrop-filter: blur(6px);
    transition: transform 0.24s ease, box-shadow 0.24s ease, border-color 0.24s ease;
    animation: mxCardFloat 5.6s ease-in-out infinite;
    position: relative;
    overflow: hidden;
}

body.page-home.page-home-landing .hero-model-card::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: -42%;
    width: 42%;
    transform: skewX(-24deg);
    background: linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, 0.26) 50%, transparent 100%);
    opacity: 0.22;
    animation: mxCardSheen 7.8s ease-in-out infinite;
    pointer-events: none;
}

body.page-home.page-home-landing .hero-model-card:nth-child(2) {
    animation-delay: 0.45s;
}

body.page-home.page-home-landing .hero-model-card:nth-child(3) {
    animation-delay: 0.8s;
}

body.page-home.page-home-landing .hero-model-card:nth-child(4) {
    animation-delay: 1.15s;
}

body.page-home.page-home-landing .hero-model-card:nth-child(5) {
    animation-delay: 1.45s;
}

body.page-home.page-home-landing .hero-model-card:nth-child(6) {
    animation-delay: 1.85s;
}

body.page-home.page-home-landing .hero-model-card:nth-child(2)::before {
    animation-delay: 1s;
}

body.page-home.page-home-landing .hero-model-card:nth-child(3)::before {
    animation-delay: 2s;
}

body.page-home.page-home-landing .hero-model-card:nth-child(4)::before {
    animation-delay: 3s;
}

body.page-home.page-home-landing .hero-model-card:nth-child(5)::before {
    animation-delay: 4s;
}

body.page-home.page-home-landing .hero-model-card:nth-child(6)::before {
    animation-delay: 5s;
}

body.page-home.page-home-landing .hero-model-card:hover {
    transform: translateY(-3px);
    border-color: rgba(120, 188, 255, 0.56);
    box-shadow: 0 16px 44px rgba(15, 34, 70, 0.3);
}

body.page-home.page-home-landing .hero-model-brand {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
}

body.page-home.page-home-landing .hero-model-icon {
    width: 34px;
    height: 34px;
    min-width: 34px;
    border-radius: 12px;
    border: 1px solid rgba(157, 184, 233, 0.38);
    background: rgba(255, 255, 255, 0.1);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    color: #b7d7ff;
    font-weight: 800;
    font-size: 11px;
}

body.theme-day.page-home.page-home-landing .hero-model-icon {
    border-color: rgba(86, 127, 206, 0.28);
    background: rgba(255, 255, 255, 0.9);
    color: #335ca8;
}

body.page-home.page-home-landing .hero-model-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

body.page-home.page-home-landing .hero-model-icon-fallback {
    background: linear-gradient(145deg, rgba(78, 174, 255, 0.3), rgba(83, 131, 255, 0.28));
}

body.theme-day.page-home.page-home-landing .hero-model-icon-fallback {
    background: linear-gradient(145deg, rgba(69, 141, 255, 0.16), rgba(76, 116, 247, 0.14));
}

body.page-home.page-home-landing .hero-model-name {
    min-width: 0;
    color: var(--mx-stage-text);
    font-size: 0.95rem;
    font-weight: 800;
    letter-spacing: 0.01em;
    line-height: 1.3;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

body.page-home.page-home-landing .hero-model-note {
    margin: 0;
    font-size: 0.77rem;
    color: var(--mx-stage-muted);
    line-height: 1.45;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

body.page-home.page-home-landing .hero-model-card.tone-banana {
    background: linear-gradient(145deg, rgba(31, 56, 88, 0.8), rgba(24, 44, 80, 0.72));
}

body.page-home.page-home-landing .hero-model-card.tone-qwen {
    background: linear-gradient(145deg, rgba(24, 58, 87, 0.76), rgba(21, 43, 77, 0.7));
}

body.page-home.page-home-landing .hero-model-card.tone-mj {
    background: linear-gradient(145deg, rgba(33, 48, 89, 0.76), rgba(23, 36, 74, 0.7));
}

body.page-home.page-home-landing .hero-model-card.tone-jimeng {
    background: linear-gradient(145deg, rgba(26, 66, 84, 0.76), rgba(19, 42, 73, 0.68));
}

body.page-home.page-home-landing .hero-model-card.tone-sora {
    background: linear-gradient(145deg, rgba(43, 57, 93, 0.74), rgba(26, 36, 74, 0.68));
}

body.page-home.page-home-landing .hero-model-card.tone-edit {
    background: linear-gradient(145deg, rgba(29, 61, 92, 0.74), rgba(22, 44, 79, 0.68));
}

body.theme-day.page-home.page-home-landing .hero-model-card.tone-banana,
body.theme-day.page-home.page-home-landing .hero-model-card.tone-qwen,
body.theme-day.page-home.page-home-landing .hero-model-card.tone-mj,
body.theme-day.page-home.page-home-landing .hero-model-card.tone-jimeng,
body.theme-day.page-home.page-home-landing .hero-model-card.tone-sora,
body.theme-day.page-home.page-home-landing .hero-model-card.tone-edit {
    background: linear-gradient(145deg, rgba(255, 255, 255, 0.86), rgba(246, 250, 255, 0.72));
}

body.page-home.page-home-landing .hero-stage-social {
    margin-top: 4px;
}

body.page-home.page-home-landing .hero-stage-social-title {
    font-size: 0.8rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: rgba(133, 202, 255, 0.92);
    margin-bottom: 8px;
}

body.theme-day.page-home.page-home-landing .hero-stage-social-title {
    color: #2e72da;
}

body.page-home.page-home-landing .hero-stage-reviews {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
}

body.page-home.page-home-landing .hero-stage-review {
    min-height: 66px;
    padding: 10px 11px;
    border-radius: 12px;
    border: 1px solid var(--mx-stage-review-border);
    background: var(--mx-stage-review-bg);
    color: var(--mx-stage-text);
    font-size: 0.74rem;
    line-height: 1.45;
    box-shadow: 0 9px 28px rgba(13, 27, 52, 0.16);
    animation: mxReviewFloat 6.4s ease-in-out infinite;
}

body.page-home.page-home-landing .hero-stage-review:nth-child(2) {
    animation-delay: 0.8s;
}

body.page-home.page-home-landing .hero-stage-review:nth-child(3) {
    animation-delay: 1.6s;
}

body.page-home.page-home-landing .hero-stage-review span {
    display: block;
    margin-top: 6px;
    color: var(--mx-stage-muted);
    font-size: 0.69rem;
}

body.page-home.page-home-landing .hero-stage-foot {
    margin-top: 0;
    display: flex;
    align-items: stretch;
    justify-content: space-between;
    gap: 10px;
    flex-wrap: wrap;
}

body.page-home.page-home-landing .hero-stage-metrics {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    flex: 1 1 360px;
}

body.page-home.page-home-landing .hero-stage-metric {
    min-height: 62px;
    padding: 9px 10px;
    border-radius: 14px;
    border: 1px solid rgba(139, 166, 218, 0.32);
    background: rgba(15, 36, 65, 0.48);
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 2px;
}

body.theme-day.page-home.page-home-landing .hero-stage-metric {
    border-color: rgba(107, 139, 196, 0.28);
    background: rgba(255, 255, 255, 0.74);
}

body.page-home.page-home-landing .hero-stage-metric strong {
    font-size: 1rem;
    line-height: 1.2;
    color: var(--mx-stage-text);
}

body.page-home.page-home-landing .hero-stage-metric span {
    font-size: 0.73rem;
    color: var(--mx-stage-muted);
    letter-spacing: 0.01em;
}

body.page-home.page-home-landing .hero-stage-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 40px;
    min-width: 220px;
    padding: 0 16px;
    border-radius: 999px;
    border: 1px solid var(--mx-stage-link-border);
    background: var(--mx-stage-link-bg);
    color: var(--mx-stage-text);
    text-decoration: none;
    font-weight: 700;
    font-size: 0.86rem;
    transition: transform 0.2s ease, background-color 0.2s ease, border-color 0.2s ease;
}

body.page-home.page-home-landing .hero-stage-link:hover {
    transform: translateY(-2px);
    border-color: rgba(131, 211, 255, 0.7);
    background: rgba(75, 171, 255, 0.22);
}

body.theme-day.page-home.page-home-landing .hero-stage-link:hover {
    background: rgba(68, 148, 255, 0.16);
}

body.page-home.page-home-landing .hero-stage-ticker {
    position: relative;
    margin-top: 4px;
    border-radius: 12px;
    border: 1px solid rgba(142, 173, 229, 0.22);
    background: rgba(13, 28, 52, 0.34);
    overflow: hidden;
    z-index: 2;
}

body.theme-day.page-home.page-home-landing .hero-stage-ticker {
    border-color: rgba(120, 151, 210, 0.24);
    background: rgba(255, 255, 255, 0.62);
}

body.page-home.page-home-landing .hero-stage-ticker::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: linear-gradient(90deg, rgba(10, 18, 32, 0.78) 0%, rgba(10, 18, 32, 0) 8%, rgba(10, 18, 32, 0) 92%, rgba(10, 18, 32, 0.78) 100%);
}

body.theme-day.page-home.page-home-landing .hero-stage-ticker::before {
    background: linear-gradient(90deg, rgba(236, 244, 255, 0.92) 0%, rgba(236, 244, 255, 0) 8%, rgba(236, 244, 255, 0) 92%, rgba(236, 244, 255, 0.92) 100%);
}

body.page-home.page-home-landing .hero-stage-ticker-track {
    display: inline-flex;
    align-items: center;
    gap: 18px;
    min-width: max-content;
    padding: 8px 0;
    white-space: nowrap;
    animation: mxTickerMarquee 26s linear infinite;
}

body.page-home.page-home-landing .hero-stage-ticker-track span {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--mx-stage-muted);
    font-size: 0.72rem;
    font-weight: 700;
}

body.page-home.page-home-landing .hero-stage-ticker-track span::before {
    content: "";
    width: 6px;
    height: 6px;
    border-radius: 999px;
    background: rgba(116, 194, 255, 0.88);
    box-shadow: 0 0 0 4px rgba(116, 194, 255, 0.16);
}

@keyframes mxAuraSpin {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}

@keyframes mxScanFlow {
    0% {
        transform: translateX(-120%);
    }
    45% {
        transform: translateX(10%);
    }
    55% {
        transform: translateX(18%);
    }
    100% {
        transform: translateX(130%);
    }
}

@keyframes mxLineDash {
    from {
        stroke-dashoffset: 0;
    }
    to {
        stroke-dashoffset: -220;
    }
}

@keyframes mxTextureFloat {
    0%,
    100% {
        transform: translate3d(0, 0, 0) scale(1);
    }
    50% {
        transform: translate3d(-8px, 10px, 0) scale(1.02);
    }
}

@keyframes mxOrbDriftA {
    0%,
    100% {
        transform: translate3d(0, 0, 0) scale(1);
    }
    50% {
        transform: translate3d(22px, -14px, 0) scale(1.06);
    }
}

@keyframes mxOrbDriftB {
    0%,
    100% {
        transform: translate3d(0, 0, 0) scale(1);
    }
    50% {
        transform: translate3d(-20px, 16px, 0) scale(1.08);
    }
}

@keyframes mxCardFloat {
    0%,
    100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-3px);
    }
}

@keyframes mxCardSheen {
    0%,
    70%,
    100% {
        left: -42%;
    }
    82% {
        left: 122%;
    }
}

@keyframes mxReviewFloat {
    0%,
    100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-2px);
    }
}

@keyframes mxTickerMarquee {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-50%);
    }
}

@media (max-width: 1240px) {
    body.page-home.page-home-landing .hero-model-stage {
        min-height: 500px;
    }
}

@media (max-width: 1100px) {
    body.page-home.page-home-landing .hero-model-stage {
        width: min(720px, calc(100vw - 24px));
        margin: 0 auto;
        min-height: 0;
    }

    body.page-home.page-home-landing .hero-stage-reviews {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    body.page-home.page-home-landing .hero-stage-metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    body.page-home.page-home-landing .hero-confidence {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    body.page-home.page-home-landing .hero-subtitle {
        width: 100%;
        max-width: calc(100vw - 24px);
        padding-inline: 0;
        white-space: nowrap;
        font-size: clamp(0.88rem, 3.5vw, 1.05rem);
        line-height: 1.35;
    }

    body.page-home.page-home-landing .hero-buttons {
        width: 100%;
        display: flex;
        flex-direction: row;
        flex-wrap: wrap;
        justify-content: center;
        align-items: center;
        gap: 10px;
    }

    body.page-home.page-home-landing .hero-cta,
    body.page-home.page-home-landing .hero-badge-entry {
        display: flex;
        flex: 0 1 auto;
    }

    body.page-home.page-home-landing .hero-buttons .btn {
        min-width: 0;
        white-space: nowrap;
        padding: 12px 20px;
        font-size: 1rem;
    }

    body.page-home.page-home-landing .hero-model-stage {
        width: min(440px, calc(100vw - 24px));
        border-radius: 22px;
        padding: 14px;
        gap: 10px;
    }

    body.page-home.page-home-landing .hero-stage-header h3 {
        font-size: 1.08rem;
    }

    body.page-home.page-home-landing .hero-stage-header p {
        font-size: 0.84rem;
    }

    body.page-home.page-home-landing .hero-trust-chips {
        width: 100%;
        flex-wrap: nowrap;
        justify-content: center;
        gap: 6px;
    }

    body.page-home.page-home-landing .hero-trust-chip {
        flex: 1 1 0;
        min-width: 0;
        justify-content: center;
        white-space: nowrap;
        min-height: 26px;
        font-size: 0.66rem;
        padding: 0 6px;
    }

    body.page-home.page-home-landing .hero-model-matrix {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px;
    }

    body.page-home.page-home-landing .hero-model-card {
        min-height: 90px;
        padding: 10px;
        border-radius: 14px;
    }

    body.page-home.page-home-landing .hero-model-name {
        font-size: 0.82rem;
    }

    body.page-home.page-home-landing .hero-model-note {
        font-size: 0.71rem;
    }

    body.page-home.page-home-landing .hero-stage-reviews {
        grid-template-columns: 1fr;
        gap: 6px;
    }

    body.page-home.page-home-landing .hero-stage-review {
        min-height: auto;
        font-size: 0.72rem;
    }

    body.page-home.page-home-landing .hero-stage-metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 6px;
    }

    body.page-home.page-home-landing .hero-stage-metric {
        min-height: 56px;
        padding: 8px;
    }

    body.page-home.page-home-landing .hero-stage-metric strong {
        font-size: 0.95rem;
    }

    body.page-home.page-home-landing .hero-stage-link {
        width: 100%;
        min-width: 0;
    }

    body.page-home.page-home-landing .hero-stage-ticker-track {
        gap: 14px;
        animation-duration: 21s;
    }

    body.page-home.page-home-landing .hero-stage-ticker-track span {
        font-size: 0.68rem;
    }
}

@media (max-width: 560px) {
    body.page-home.page-home-landing .hero-model-matrix {
        grid-template-columns: 1fr;
    }

    body.page-home.page-home-landing .hero-stage-metrics {
        grid-template-columns: 1fr;
    }

    body.page-home.page-home-landing .hero-trust-chip {
        flex: 1 1 0;
        justify-content: center;
        font-size: 0.62rem;
        padding: 0 4px;
    }

    body.page-home.page-home-landing .hero-buttons .btn {
        padding: 10px 14px;
        font-size: 0.94rem;
    }
}

@media (prefers-reduced-motion: reduce) {
    body.page-home.page-home-landing .hero-model-stage::before,
    body.page-home.page-home-landing .hero-model-stage::after,
    body.page-home.page-home-landing .hero-stage-texture,
    body.page-home.page-home-landing .stage-line,
    body.page-home.page-home-landing .hero-stage-orb,
    body.page-home.page-home-landing .hero-model-card,
    body.page-home.page-home-landing .hero-model-card::before,
    body.page-home.page-home-landing .hero-stage-review,
    body.page-home.page-home-landing .hero-stage-ticker-track {
        animation: none !important;
    }
}

/* Landing mobile/tablet flow fix: force right stage below left intro */
@media (max-width: 1180px) {
    body.page-home.page-home-landing .hero {
        min-height: auto;
        align-items: flex-start;
    }

    body.page-home.page-home-landing .hero-content {
        grid-template-columns: 1fr !important;
        align-items: flex-start;
        gap: 18px;
    }

    body.page-home.page-home-landing .hero-left {
        width: min(760px, calc(100vw - 24px));
        max-width: 100%;
        margin-inline: auto;
    }

    body.page-home.page-home-landing .hero-model-stage {
        width: min(760px, calc(100vw - 24px));
        max-width: 100%;
        margin-inline: auto;
        min-height: 0;
    }
}

@media (max-width: 900px) {
    body.page-home.page-home-landing .hero {
        padding-top: 120px;
    }

    body.page-home.page-home-landing .hero-left {
        width: min(520px, calc(100vw - 24px));
        text-align: center;
        align-items: center;
    }

    body.page-home.page-home-landing .hero-model-stage {
        width: min(520px, calc(100vw - 24px));
    }
}

/* Avatar menu aggregation */
body.page-home .nav-auth,
body.page-normal .nav-auth,
body.page-history .nav-auth,
body.page-community .nav-auth {
    position: relative;
    overflow: visible;
}

body.page-home .nav-user,
body.page-normal .nav-user,
body.page-history .nav-user,
body.page-community .nav-user {
    position: relative;
    overflow: visible;
}

body.page-home .nav-avatar-tooltip,
body.page-normal .nav-avatar-tooltip,
body.page-history .nav-avatar-tooltip,
body.page-community .nav-avatar-tooltip {
    display: none !important;
}

body.mx-user-authenticated.page-home #normalThemeToggle,
body.mx-user-authenticated.page-normal #normalThemeToggle,
body.mx-user-authenticated.page-history #normalThemeToggle,
body.mx-user-authenticated.page-community #normalThemeToggle,
body.mx-user-authenticated.page-home #navLogoutBtn,
body.mx-user-authenticated.page-normal #navLogoutBtn,
body.mx-user-authenticated.page-history #navLogoutBtn,
body.mx-user-authenticated.page-community #navLogoutBtn,
body.mx-user-authenticated.page-home #navRedeemBtn,
body.mx-user-authenticated.page-normal #navRedeemBtn,
body.mx-user-authenticated.page-history #navRedeemBtn,
body.mx-user-authenticated.page-community #navRedeemBtn {
    display: none !important;
}

body.page-home .nav-user.has-avatar-menu::before,
body.page-home .nav-user.has-avatar-menu::after,
body.page-normal .nav-user.has-avatar-menu::before,
body.page-normal .nav-user.has-avatar-menu::after,
body.page-history .nav-user.has-avatar-menu::before,
body.page-history .nav-user.has-avatar-menu::after,
body.page-community .nav-user.has-avatar-menu::before,
body.page-community .nav-user.has-avatar-menu::after {
    display: none !important;
}

body.page-home .nav-avatar-menu,
body.page-normal .nav-avatar-menu,
body.page-history .nav-avatar-menu,
body.page-community .nav-avatar-menu {
    position: absolute;
    top: calc(100% + 10px);
    bottom: auto;
    left: auto;
    right: 0;
    width: 286px;
    max-height: min(78vh, 560px);
    border-radius: 20px;
    border: 1px solid rgba(201, 206, 221, 0.82);
    background: rgba(252, 252, 255, 0.98);
    box-shadow: 0 24px 64px rgba(18, 20, 32, 0.22);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-8px) scale(0.98);
    transform-origin: top right;
    transition: opacity 0.18s ease, transform 0.18s ease, visibility 0.18s ease;
    pointer-events: none;
    z-index: 1600;
}

body.page-home .nav-avatar-menu.show,
body.page-normal .nav-avatar-menu.show,
body.page-history .nav-avatar-menu.show,
body.page-community .nav-avatar-menu.show {
    opacity: 1;
    visibility: visible;
    transform: translateY(0) scale(1);
    pointer-events: auto;
}

body.page-home .nav-avatar-menu-header,
body.page-normal .nav-avatar-menu-header,
body.page-history .nav-avatar-menu-header,
body.page-community .nav-avatar-menu-header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px;
    border-bottom: 1px solid rgba(201, 206, 221, 0.76);
}

body.page-home .nav-avatar-menu-face,
body.page-normal .nav-avatar-menu-face,
body.page-history .nav-avatar-menu-face,
body.page-community .nav-avatar-menu-face {
    width: 48px;
    height: 48px;
    border-radius: 999px;
    color: #fff;
    display: grid;
    place-items: center;
    font-size: 22px;
    font-weight: 700;
}

body.page-home .nav-avatar-menu-meta,
body.page-normal .nav-avatar-menu-meta,
body.page-history .nav-avatar-menu-meta,
body.page-community .nav-avatar-menu-meta {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}

body.page-home .nav-avatar-menu-name,
body.page-normal .nav-avatar-menu-name,
body.page-history .nav-avatar-menu-name,
body.page-community .nav-avatar-menu-name {
    color: #0f172a;
    font-size: 23px;
    line-height: 1.1;
    font-weight: 700;
}

body.page-home .nav-avatar-menu-email,
body.page-normal .nav-avatar-menu-email,
body.page-history .nav-avatar-menu-email,
body.page-community .nav-avatar-menu-email {
    color: #6b7280;
    font-size: 14px;
    line-height: 1.35;
    max-width: 200px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

body.page-home .nav-avatar-menu-body,
body.page-normal .nav-avatar-menu-body,
body.page-history .nav-avatar-menu-body,
body.page-community .nav-avatar-menu-body {
    display: flex;
    flex-direction: column;
    padding: 10px;
    gap: 6px;
    max-height: min(62vh, 420px);
    overflow-y: auto;
}

body.page-home .nav-avatar-menu-row,
body.page-normal .nav-avatar-menu-row,
body.page-history .nav-avatar-menu-row,
body.page-community .nav-avatar-menu-row {
    width: 100%;
    border: none;
    border-radius: 12px;
    background: transparent;
    min-height: 48px;
    padding: 10px 12px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    cursor: pointer;
    transition: background 0.16s ease;
}

body.page-home .nav-avatar-menu-row:hover,
body.page-normal .nav-avatar-menu-row:hover,
body.page-history .nav-avatar-menu-row:hover,
body.page-community .nav-avatar-menu-row:hover {
    background: rgba(113, 61, 234, 0.08);
}

body.page-home .nav-avatar-menu-row-main,
body.page-normal .nav-avatar-menu-row-main,
body.page-history .nav-avatar-menu-row-main,
body.page-community .nav-avatar-menu-row-main {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 2px;
}

body.page-home .nav-avatar-menu-label,
body.page-normal .nav-avatar-menu-label,
body.page-history .nav-avatar-menu-label,
body.page-community .nav-avatar-menu-label {
    font-size: 15px;
    font-weight: 600;
    color: #111827;
    line-height: 1.25;
}

body.page-home .nav-avatar-menu-value,
body.page-normal .nav-avatar-menu-value,
body.page-history .nav-avatar-menu-value,
body.page-community .nav-avatar-menu-value {
    font-size: 13px;
    color: #6b7280;
    font-weight: 600;
}

body.page-home .nav-avatar-menu-action,
body.page-normal .nav-avatar-menu-action,
body.page-history .nav-avatar-menu-action,
body.page-community .nav-avatar-menu-action {
    border: 1px solid rgba(17, 24, 39, 0.2);
    background: rgba(255, 255, 255, 0.92);
    color: #111827;
    border-radius: 10px;
    padding: 6px 14px;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.16s ease;
}

body.page-home .nav-avatar-menu-action:hover,
body.page-normal .nav-avatar-menu-action:hover,
body.page-history .nav-avatar-menu-action:hover,
body.page-community .nav-avatar-menu-action:hover {
    border-color: rgba(113, 61, 234, 0.52);
    color: #713dea;
}

body.page-home .nav-avatar-menu-row-theme,
body.page-normal .nav-avatar-menu-row-theme,
body.page-history .nav-avatar-menu-row-theme,
body.page-community .nav-avatar-menu-row-theme {
    border-top: 1px solid rgba(229, 231, 235, 0.75);
    margin-top: 2px;
    padding-top: 12px;
}

body.page-home .nav-avatar-menu-switch,
body.page-normal .nav-avatar-menu-switch,
body.page-history .nav-avatar-menu-switch,
body.page-community .nav-avatar-menu-switch {
    width: 42px;
    height: 24px;
    border-radius: 999px;
    background: rgba(148, 163, 184, 0.4);
    border: 1px solid rgba(148, 163, 184, 0.62);
    position: relative;
    transition: background 0.18s ease, border-color 0.18s ease;
}

body.page-home .nav-avatar-menu-switch-thumb,
body.page-normal .nav-avatar-menu-switch-thumb,
body.page-history .nav-avatar-menu-switch-thumb,
body.page-community .nav-avatar-menu-switch-thumb {
    position: absolute;
    top: 2px;
    left: 2px;
    width: 18px;
    height: 18px;
    border-radius: 999px;
    background: #fff;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.24);
    transition: transform 0.18s ease;
}

body.page-home .nav-avatar-menu-row-theme.is-night .nav-avatar-menu-switch,
body.page-normal .nav-avatar-menu-row-theme.is-night .nav-avatar-menu-switch,
body.page-history .nav-avatar-menu-row-theme.is-night .nav-avatar-menu-switch,
body.page-community .nav-avatar-menu-row-theme.is-night .nav-avatar-menu-switch {
    background: rgba(113, 61, 234, 0.36);
    border-color: rgba(113, 61, 234, 0.56);
}

body.page-home .nav-avatar-menu-row-theme.is-night .nav-avatar-menu-switch-thumb,
body.page-normal .nav-avatar-menu-row-theme.is-night .nav-avatar-menu-switch-thumb,
body.page-history .nav-avatar-menu-row-theme.is-night .nav-avatar-menu-switch-thumb,
body.page-community .nav-avatar-menu-row-theme.is-night .nav-avatar-menu-switch-thumb {
    transform: translateX(18px);
}

body.page-home .nav-avatar-menu-row-logout,
body.page-normal .nav-avatar-menu-row-logout,
body.page-history .nav-avatar-menu-row-logout,
body.page-community .nav-avatar-menu-row-logout {
    border-top: 1px solid rgba(229, 231, 235, 0.75);
    margin-top: 2px;
    color: #dc2626;
}

body.page-home .nav-avatar-menu-row-logout .nav-avatar-menu-label,
body.page-normal .nav-avatar-menu-row-logout .nav-avatar-menu-label,
body.page-history .nav-avatar-menu-row-logout .nav-avatar-menu-label,
body.page-community .nav-avatar-menu-row-logout .nav-avatar-menu-label {
    color: inherit;
}

body.mx-user-authenticated .nav-avatar-wrapper {
    position: relative;
}

body.mx-user-authenticated .nav-avatar-wrapper.is-menu-open {
    z-index: 1500;
}

body.mx-user-authenticated .nav-notification.nav-notification-avatar {
    position: absolute;
    top: -5px;
    right: -5px;
    margin: 0;
    z-index: 6;
    pointer-events: auto;
}

body.mx-user-authenticated .nav-notification.nav-notification-avatar .notification-bell {
    width: 24px;
    height: 24px;
    border-radius: 999px;
    border: none;
    background: transparent;
    color: transparent;
    padding: 0;
    display: grid;
    place-items: center;
    box-shadow: none;
    overflow: visible;
}

body.mx-user-authenticated .nav-notification.nav-notification-avatar .notification-bell svg {
    display: none;
}

body.mx-user-authenticated .nav-notification.nav-notification-avatar .notification-bell:hover {
    background: transparent;
    transform: none;
}

body.mx-user-authenticated .nav-notification.nav-notification-avatar .notification-badge {
    top: -5px;
    right: -5px;
    min-width: 20px;
    padding: 1px 6px;
    font-size: 11px;
    box-shadow: 0 0 0 2px #ffffff, 0 6px 14px rgba(220, 38, 38, 0.42);
}

body.theme-night.mx-user-authenticated .nav-notification.nav-notification-avatar .notification-bell {
    border-color: transparent;
    background: transparent;
}

body.theme-night.mx-user-authenticated .nav-notification.nav-notification-avatar .notification-badge {
    box-shadow: 0 0 0 2px #151923, 0 6px 14px rgba(220, 38, 38, 0.5);
}

body.theme-night.page-home .nav-avatar-menu,
body.theme-night.page-normal .nav-avatar-menu,
body.theme-night.page-history .nav-avatar-menu,
body.theme-night.page-community .nav-avatar-menu {
    border-color: rgba(91, 103, 133, 0.65);
    background: rgba(19, 24, 37, 0.98);
    box-shadow: 0 28px 70px rgba(0, 0, 0, 0.5);
}

body.theme-night.page-home .nav-avatar-menu-header,
body.theme-night.page-normal .nav-avatar-menu-header,
body.theme-night.page-history .nav-avatar-menu-header,
body.theme-night.page-community .nav-avatar-menu-header {
    border-bottom-color: rgba(95, 112, 146, 0.44);
}

body.theme-night.page-home .nav-avatar-menu-name,
body.theme-night.page-home .nav-avatar-menu-label,
body.theme-night.page-normal .nav-avatar-menu-name,
body.theme-night.page-normal .nav-avatar-menu-label,
body.theme-night.page-history .nav-avatar-menu-name,
body.theme-night.page-history .nav-avatar-menu-label,
body.theme-night.page-community .nav-avatar-menu-name,
body.theme-night.page-community .nav-avatar-menu-label {
    color: rgba(236, 242, 255, 0.95);
}

body.theme-night.page-home .nav-avatar-menu-email,
body.theme-night.page-home .nav-avatar-menu-value,
body.theme-night.page-normal .nav-avatar-menu-email,
body.theme-night.page-normal .nav-avatar-menu-value,
body.theme-night.page-history .nav-avatar-menu-email,
body.theme-night.page-history .nav-avatar-menu-value,
body.theme-night.page-community .nav-avatar-menu-email,
body.theme-night.page-community .nav-avatar-menu-value {
    color: rgba(172, 189, 220, 0.86);
}

body.theme-night.page-home .nav-avatar-menu-row:hover,
body.theme-night.page-normal .nav-avatar-menu-row:hover,
body.theme-night.page-history .nav-avatar-menu-row:hover,
body.theme-night.page-community .nav-avatar-menu-row:hover {
    background: rgba(93, 107, 139, 0.26);
}

body.theme-night.page-home .nav-avatar-menu-action,
body.theme-night.page-normal .nav-avatar-menu-action,
body.theme-night.page-history .nav-avatar-menu-action,
body.theme-night.page-community .nav-avatar-menu-action {
    background: rgba(33, 45, 67, 0.9);
    color: rgba(232, 240, 255, 0.92);
    border-color: rgba(122, 142, 177, 0.46);
}

body.theme-night.page-home .nav-avatar-menu-action:hover,
body.theme-night.page-normal .nav-avatar-menu-action:hover,
body.theme-night.page-history .nav-avatar-menu-action:hover,
body.theme-night.page-community .nav-avatar-menu-action:hover {
    border-color: rgba(167, 137, 255, 0.75);
    color: #d8c8ff;
}

body.theme-night.page-home .nav-avatar-menu-row-theme,
body.theme-night.page-home .nav-avatar-menu-row-logout,
body.theme-night.page-normal .nav-avatar-menu-row-theme,
body.theme-night.page-normal .nav-avatar-menu-row-logout,
body.theme-night.page-history .nav-avatar-menu-row-theme,
body.theme-night.page-history .nav-avatar-menu-row-logout,
body.theme-night.page-community .nav-avatar-menu-row-theme,
body.theme-night.page-community .nav-avatar-menu-row-logout {
    border-top-color: rgba(95, 112, 146, 0.44);
}

@media (max-width: 980px) {
    body.page-home .nav-avatar-menu,
    body.page-normal .nav-avatar-menu,
    body.page-history .nav-avatar-menu,
    body.page-community .nav-avatar-menu {
        top: calc(100% + 10px);
        bottom: auto;
        left: auto;
        right: 0;
        width: min(320px, calc(100vw - 18px));
        max-height: min(72vh, 560px);
        transform-origin: top right;
        transform: translateY(-8px) scale(0.98);
    }

    body.page-home .nav-avatar-menu.show,
    body.page-normal .nav-avatar-menu.show,
    body.page-history .nav-avatar-menu.show,
    body.page-community .nav-avatar-menu.show {
        transform: translateY(0) scale(1);
    }
}

/* ===== Unified 2026-03 refresh ===== */
@media (max-width: 768px) {
    body.page-home .navbar,
    body.page-normal .navbar,
    body.page-history .navbar,
    body.page-community .navbar {
        width: 100%;
        height: auto;
        min-height: 110px;
    }

    body.page-home .nav-container,
    body.page-normal .nav-container,
    body.page-history .nav-container,
    body.page-community .nav-container {
        display: grid;
        grid-template-columns: minmax(0, 1fr) auto;
        grid-template-areas:
            "brand auth"
            "links links";
        align-items: center;
        row-gap: 8px;
        column-gap: 10px;
        width: 100%;
        padding: 8px 12px 10px;
    }

    body.page-home .nav-brand,
    body.page-normal .nav-brand,
    body.page-history .nav-brand,
    body.page-community .nav-brand {
        grid-area: brand;
        width: auto;
        height: 38px;
        justify-content: flex-start;
    }

    body.page-home .nav-brand .mx-brand-logo,
    body.page-normal .nav-brand .mx-brand-logo,
    body.page-history .nav-brand .mx-brand-logo,
    body.page-community .nav-brand .mx-brand-logo {
        width: 34px;
        height: 34px;
    }

    body.page-home .nav-links,
    body.page-normal .nav-links,
    body.page-history .nav-links,
    body.page-community .nav-links {
        grid-area: links;
        width: 100%;
        display: grid;
        grid-template-columns: repeat(5, minmax(0, 1fr));
        gap: 6px;
        justify-items: center;
    }

    body.page-home .nav-link,
    body.page-normal .nav-link,
    body.page-history .nav-link,
    body.page-community .nav-link {
        min-height: 46px;
        width: 100%;
        padding: 2px 0;
        border-radius: 10px;
    }

    body.page-home .nav-link .mx-nav-icon,
    body.page-normal .nav-link .mx-nav-icon,
    body.page-history .nav-link .mx-nav-icon,
    body.page-community .nav-link .mx-nav-icon {
        width: 30px;
        height: 30px;
        border-radius: 9px;
    }

    body.page-home .nav-link .mx-nav-icon img,
    body.page-normal .nav-link .mx-nav-icon img,
    body.page-history .nav-link .mx-nav-icon img,
    body.page-community .nav-link .mx-nav-icon img {
        width: 16px;
        height: 16px;
    }

    body.page-home .nav-link .mx-nav-label,
    body.page-normal .nav-link .mx-nav-label,
    body.page-history .nav-link .mx-nav-label,
    body.page-community .nav-link .mx-nav-label {
        margin-top: 2px;
        font-size: 10px;
        line-height: 1.15;
    }

    body.page-home .nav-auth,
    body.page-normal .nav-auth,
    body.page-history .nav-auth,
    body.page-community .nav-auth {
        grid-area: auth;
        display: inline-flex;
        justify-content: flex-end;
        align-items: center;
        gap: 6px;
        margin-left: auto;
    }

    body.page-home .nav-auth .btn,
    body.page-normal .nav-auth .btn,
    body.page-history .nav-auth .btn,
    body.page-community .nav-auth .btn {
        min-width: 56px;
        height: 30px;
        padding: 0 10px;
        font-size: 11px;
    }

    body.page-home #normalThemeToggle,
    body.page-normal #normalThemeToggle,
    body.page-history #normalThemeToggle,
    body.page-community #normalThemeToggle {
        width: 48px;
        height: 28px;
        padding: 0 7px;
    }

    body.page-home #normalThemeToggle .theme-toggle-thumb,
    body.page-normal #normalThemeToggle .theme-toggle-thumb,
    body.page-history #normalThemeToggle .theme-toggle-thumb,
    body.page-community #normalThemeToggle .theme-toggle-thumb {
        width: 18px;
        height: 18px;
    }

    body.page-home #normalThemeToggle[data-mode="night"] .theme-toggle-thumb,
    body.page-normal #normalThemeToggle[data-mode="night"] .theme-toggle-thumb,
    body.page-history #normalThemeToggle[data-mode="night"] .theme-toggle-thumb,
    body.page-community #normalThemeToggle[data-mode="night"] .theme-toggle-thumb {
        transform: translateX(22px);
    }

    body.page-home.page-home-entry .mx-home-wrap {
        padding: 112px 14px 18px;
        gap: 10px;
    }

    body.page-home.page-home-entry .mx-home-hero {
        gap: 10px;
        margin-bottom: 2px;
    }

    body.page-home.page-home-entry .mx-home-copy {
        gap: 8px;
    }

    body.page-home.page-home-entry .mx-home-model-line {
        padding: 6px 12px;
        font-size: 12px;
    }

    body.page-home.page-home-entry .mx-home-subtitle {
        margin-top: 2px;
        min-height: calc(1.45em);
        font-size: 14px;
        line-height: 1.45;
    }

    body.page-home.page-home-entry .mx-home-tabs {
        margin-bottom: 8px;
    }

    body.page-home.page-home-entry .mx-home-composer-panel {
        padding: 8px;
        border-radius: 18px;
    }

    body.page-home.page-home-entry #mxHomePrompt {
        min-height: 72px;
        max-height: 180px;
        padding: 2px 2px 8px;
    }

    body.page-home.page-home-entry .mx-home-toolbar {
        gap: 6px;
    }

    body.page-home.page-home-entry #mxHomeGenerateBtn {
        height: 38px;
    }

    body.page-history .history-scale {
        padding-top: 126px;
    }

    body.page-history .history-filters {
        display: grid;
        grid-template-columns: 1fr;
        gap: 10px;
        padding: 14px;
    }

    body.page-history .history-stats-left {
        width: 100%;
        text-align: center;
    }

    body.page-history .history-actions-right {
        width: 100%;
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
        justify-content: stretch;
    }

    body.page-history .history-actions-right .history-action-btn,
    body.page-history .batch-select-group .history-action-btn,
    body.page-history .batch-confirm-group .history-action-btn {
        width: 100%;
        min-width: 0;
    }

    body.page-history .batch-controls,
    body.page-history .batch-select-group,
    body.page-history .batch-confirm-group {
        width: 100%;
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
        border-left: none;
        padding-left: 0;
    }

    body.page-history .batch-selected-count {
        grid-column: 1 / -1;
        justify-content: center;
    }
}

@media (max-width: 480px) {
    body.page-home .nav-container,
    body.page-normal .nav-container,
    body.page-history .nav-container,
    body.page-community .nav-container {
        padding: 8px 8px 10px;
        row-gap: 6px;
    }

    body.page-home .nav-link .mx-nav-label,
    body.page-normal .nav-link .mx-nav-label,
    body.page-history .nav-link .mx-nav-label,
    body.page-community .nav-link .mx-nav-label {
        font-size: 9px;
    }

    body.page-history .history-actions-right,
    body.page-history .batch-select-group,
    body.page-history .batch-confirm-group {
        grid-template-columns: 1fr;
    }
}

/* ===== Home Recharge Six-Pack Refresh ===== */
body.theme-day.page-home-landing {
    --mx-recharge-section-bg:
        radial-gradient(circle at 12% 18%, rgba(255, 215, 125, 0.12), transparent 30%),
        radial-gradient(circle at 88% 8%, rgba(99, 102, 241, 0.1), transparent 28%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.2) 0%, rgba(246, 248, 255, 0.28) 100%);
    --mx-recharge-card-base: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(247, 249, 255, 0.96) 100%);
    --mx-recharge-card-border: rgba(147, 160, 197, 0.24);
    --mx-recharge-card-shadow: 0 18px 48px rgba(22, 31, 52, 0.08);
    --mx-recharge-card-shadow-hover: 0 26px 72px rgba(22, 31, 52, 0.14);
    --mx-recharge-title: #121826;
    --mx-recharge-text: #334155;
    --mx-recharge-muted: #5b6780;
    --mx-recharge-button-bg: rgba(255, 255, 255, 0.9);
    --mx-recharge-button-border: rgba(148, 163, 184, 0.36);
    --mx-recharge-button-text: #1f2937;
    --mx-recharge-proof-bg: rgba(255, 255, 255, 0.84);
}

body.theme-night.page-home-landing {
    --mx-recharge-section-bg:
        radial-gradient(circle at 14% 18%, rgba(245, 193, 84, 0.1), transparent 28%),
        radial-gradient(circle at 88% 8%, rgba(94, 129, 255, 0.14), transparent 26%),
        linear-gradient(180deg, rgba(10, 14, 24, 0.2) 0%, rgba(11, 15, 24, 0.26) 100%);
    --mx-recharge-card-base: linear-gradient(180deg, rgba(18, 24, 39, 0.98) 0%, rgba(11, 17, 28, 0.98) 100%);
    --mx-recharge-card-border: rgba(98, 111, 145, 0.42);
    --mx-recharge-card-shadow: 0 22px 58px rgba(0, 0, 0, 0.34);
    --mx-recharge-card-shadow-hover: 0 28px 80px rgba(0, 0, 0, 0.46);
    --mx-recharge-title: #f8fafc;
    --mx-recharge-text: rgba(226, 232, 240, 0.88);
    --mx-recharge-muted: rgba(148, 163, 184, 0.9);
    --mx-recharge-button-bg: rgba(15, 23, 42, 0.78);
    --mx-recharge-button-border: rgba(99, 116, 156, 0.46);
    --mx-recharge-button-text: #f8fafc;
    --mx-recharge-proof-bg: rgba(26, 35, 57, 0.82);
}

body.page-home-landing .recharge-section {
    position: relative;
    padding-inline: 16px;
}

body.page-home-landing .recharge-section::before {
    content: "";
    position: absolute;
    inset: -18px 0 -18px;
    border-radius: 32px;
    background: var(--mx-recharge-section-bg);
    pointer-events: none;
}

body.page-home-landing .recharge-section > * {
    position: relative;
    z-index: 1;
}

body.page-home-landing .recharge-header {
    margin-bottom: 16px;
    gap: 18px;
}

body.page-home-landing .recharge-header h2 {
    letter-spacing: -0.02em;
}

body.page-home-landing .recharge-subtitle {
    max-width: 780px;
    margin: 10px 0 0;
}

body.page-home-landing .wechat-id {
    display: inline-flex;
    align-items: center;
    min-height: 42px;
    padding: 0 14px;
    border-radius: 999px;
    border: 1px solid rgba(148, 163, 184, 0.22);
    background: rgba(255, 255, 255, 0.46);
    backdrop-filter: blur(12px);
}

body.theme-night.page-home-landing .wechat-id {
    background: rgba(15, 23, 42, 0.52);
}

body.page-home-landing .recharge-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
    align-items: stretch;
    max-width: none;
    margin: 0;
}

body.page-home-landing .recharge-card {
    --card-accent-rgb: 99, 102, 241;
    position: relative;
    min-height: 392px;
    height: 100%;
    display: grid;
    grid-template-rows: auto auto auto auto 1fr auto;
    gap: 10px;
    padding: 18px 16px 16px;
    border-radius: 22px;
    border: 1px solid var(--mx-recharge-card-border);
    background:
        radial-gradient(circle at 14% 16%, rgba(var(--card-accent-rgb), 0.14), transparent 34%),
        radial-gradient(circle at 88% 0%, rgba(var(--card-accent-rgb), 0.1), transparent 30%),
        var(--mx-recharge-card-base);
    box-shadow: var(--mx-recharge-card-shadow);
    overflow: hidden;
    isolation: isolate;
    transform: translateY(0);
    transition: transform 0.22s ease, border-color 0.24s ease, box-shadow 0.24s ease;
}

body.page-home-landing .recharge-card::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    border: 1px solid rgba(var(--card-accent-rgb), 0.14);
    pointer-events: none;
}

body.page-home-landing .recharge-card > * {
    position: relative;
    z-index: 1;
}

body.page-home-landing .recharge-card:hover {
    transform: translateY(-6px);
    border-color: rgba(var(--card-accent-rgb), 0.34);
    box-shadow:
        0 28px 72px rgba(var(--card-accent-rgb), 0.14),
        var(--mx-recharge-card-shadow-hover);
}

body.page-home-landing .recharge-card-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 10px;
}

body.page-home-landing .recharge-top-left {
    display: flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
    flex: 1 1 auto;
}

body.page-home-landing .recharge-badge,
body.page-home-landing .recharge-corner,
body.page-home-landing .recharge-proof {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.01em;
    white-space: nowrap;
}

body.page-home-landing .recharge-badge {
    align-self: auto;
    margin-bottom: 0;
    padding: 5px 11px;
    background: rgba(var(--card-accent-rgb), 0.12);
    color: rgb(var(--card-accent-rgb));
    border: 1px solid rgba(var(--card-accent-rgb), 0.16);
    box-shadow: none;
    text-transform: none;
}

body.page-home-landing .recharge-badge.popular {
    background: linear-gradient(135deg, rgba(255, 188, 82, 0.95) 0%, rgba(244, 138, 37, 0.95) 100%);
    color: #1f2937;
    border-color: transparent;
}

body.page-home-landing .recharge-corner {
    position: static;
    top: auto;
    right: auto;
    height: auto;
    padding: 5px 10px;
    background: rgba(var(--card-accent-rgb), 0.1);
    border: 1px solid rgba(var(--card-accent-rgb), 0.16);
    color: var(--mx-recharge-text);
}

body.page-home-landing .recharge-proof {
    position: static;
    z-index: auto;
    margin: 0;
    padding: 5px 10px;
    background: var(--mx-recharge-proof-bg);
    border: 1px solid rgba(var(--card-accent-rgb), 0.22);
    color: var(--mx-recharge-text);
    backdrop-filter: blur(10px);
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
}

body.page-home-landing .recharge-name {
    font-size: 1.16rem;
    font-weight: 800;
    letter-spacing: -0.01em;
    color: var(--mx-recharge-title);
}

body.page-home-landing .recharge-price {
    margin: 0;
    align-items: flex-end;
    gap: 4px;
    color: rgb(var(--card-accent-rgb));
}

body.page-home-landing .price-currency {
    margin-top: 0;
    font-size: 1.38rem;
    line-height: 1.05;
    color: rgb(var(--card-accent-rgb));
}

body.page-home-landing .price-amount {
    font-size: clamp(2.7rem, 3.7vw, 3.7rem);
    line-height: 0.95;
    letter-spacing: -0.06em;
    color: rgb(var(--card-accent-rgb));
}

body.page-home-landing .recharge-desc {
    margin-top: 0;
    gap: 3px;
}

body.page-home-landing .recharge-credits {
    font-size: 1.08rem;
    font-weight: 800;
    color: var(--mx-recharge-title);
}

body.page-home-landing .recharge-note {
    font-size: 0.82rem;
    font-weight: 700;
    line-height: 1.45;
    color: var(--mx-recharge-muted);
}

body.page-home-landing .recharge-unitprice {
    display: none;
}

body.page-home-landing .recharge-features {
    margin: 0;
    padding-top: 12px;
    gap: 8px;
    border-top-color: rgba(148, 163, 184, 0.22);
}

body.page-home-landing .feature-item {
    font-size: 0.9rem;
    line-height: 1.5;
    color: var(--mx-recharge-text);
}

body.page-home-landing .feature-item:before {
    width: 20px;
    height: 20px;
    background: rgba(var(--card-accent-rgb), 0.16);
    color: rgb(var(--card-accent-rgb));
    font-size: 0.76rem;
}

body.page-home-landing .recharge-output-pitch {
    display: grid;
    gap: 6px;
    margin-top: 2px;
    padding: 10px 12px;
    border-radius: 16px;
    background: rgba(var(--card-accent-rgb), 0.08);
    border: 1px solid rgba(var(--card-accent-rgb), 0.14);
}

body.page-home-landing .recharge-output-title {
    font-size: 0.72rem;
    font-weight: 800;
    line-height: 1.3;
    letter-spacing: 0.02em;
    color: var(--mx-recharge-muted);
}

body.page-home-landing .recharge-output-mode {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 12px;
    font-size: 0.82rem;
    line-height: 1.35;
    color: var(--mx-recharge-text);
}

body.page-home-landing .recharge-output-mode strong {
    font-size: 0.88rem;
    font-weight: 800;
    color: rgb(var(--card-accent-rgb));
}

body.page-home-landing .recharge-btn {
    margin-top: auto;
    min-height: 46px;
    border-radius: 14px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    background: linear-gradient(180deg, #1f2937 0%, #111827 100%);
    color: #f8fafc;
    box-shadow: 0 18px 36px rgba(17, 24, 39, 0.16);
    font-weight: 800;
    letter-spacing: 0.02em;
}

body.page-home-landing .recharge-btn:hover {
    transform: translateY(-1px);
    background: linear-gradient(180deg, #111827 0%, #0f172a 100%);
    border-color: rgba(113, 61, 234, 0.18);
    box-shadow: 0 18px 32px rgba(113, 61, 234, 0.12);
}

body.page-home-landing .recharge-card.starter {
    --card-accent-rgb: 124, 92, 255;
}

body.page-home-landing .recharge-card.standard {
    --card-accent-rgb: 59, 130, 246;
}

body.page-home-landing .recharge-card.premium {
    --card-accent-rgb: 245, 158, 11;
}

body.page-home-landing .recharge-card.ultimate {
    --card-accent-rgb: 163, 80, 122;
}

body.page-home-landing .recharge-card.enterprise {
    --card-accent-rgb: 103, 92, 198;
}

body.page-home-landing .recharge-card.max3000 {
    --card-accent-rgb: 223, 188, 118;
}

body.theme-day.page-home-landing .recharge-card.is-spotlight {
    border-color: rgba(163, 80, 122, 0.32);
    background:
        radial-gradient(circle at 14% 16%, rgba(206, 150, 191, 0.22), transparent 34%),
        radial-gradient(circle at 88% 0%, rgba(242, 226, 234, 0.48), transparent 34%),
        linear-gradient(180deg, rgba(255, 252, 254, 0.99) 0%, rgba(252, 244, 249, 0.98) 100%);
    box-shadow: 0 28px 78px rgba(163, 80, 122, 0.14), 0 24px 68px rgba(22, 31, 52, 0.10);
}

body.theme-night.page-home-landing .recharge-card.is-spotlight {
    border-color: rgba(198, 126, 162, 0.36);
    background:
        radial-gradient(circle at 14% 16%, rgba(182, 113, 148, 0.18), transparent 34%),
        radial-gradient(circle at 88% 0%, rgba(222, 193, 208, 0.12), transparent 32%),
        linear-gradient(180deg, rgba(35, 21, 32, 0.98) 0%, rgba(28, 18, 26, 0.98) 100%);
    box-shadow: 0 30px 82px rgba(0, 0, 0, 0.5), 0 20px 56px rgba(182, 113, 148, 0.12);
}

body.page-home-landing .recharge-card.is-spotlight .recharge-proof {
    border-color: rgba(163, 80, 122, 0.18);
}

body.page-home-landing .recharge-card.is-spotlight .recharge-btn {
    border: 1px solid rgba(15, 23, 42, 0.08);
    color: #f8fafc;
    background: linear-gradient(180deg, #1f2937 0%, #111827 100%);
    box-shadow: 0 18px 36px rgba(17, 24, 39, 0.16);
}

body.page-home-landing .recharge-card.is-spotlight .recharge-btn:hover {
    border-color: rgba(113, 61, 234, 0.18);
}

body.theme-day.page-home-landing .recharge-card.is-spotlight .recharge-name,
body.theme-day.page-home-landing .recharge-card.is-spotlight .recharge-credits {
    color: #2e1b26;
}

body.theme-day.page-home-landing .recharge-card.is-spotlight .recharge-note,
body.theme-day.page-home-landing .recharge-card.is-spotlight .feature-item,
body.theme-day.page-home-landing .recharge-card.is-spotlight .recharge-corner,
body.theme-day.page-home-landing .recharge-card.is-spotlight .recharge-proof {
    color: #7a3d5c;
}

body.theme-day.page-home-landing .recharge-card.is-spotlight .price-currency,
body.theme-day.page-home-landing .recharge-card.is-spotlight .price-amount {
    color: #9e3f68;
}

body.theme-night.page-home-landing .recharge-card.is-spotlight .recharge-name,
body.theme-night.page-home-landing .recharge-card.is-spotlight .recharge-credits,
body.theme-night.page-home-landing .recharge-card.is-spotlight .price-currency,
body.theme-night.page-home-landing .recharge-card.is-spotlight .price-amount {
    color: #ffd8e6;
}

body.theme-night.page-home-landing .recharge-card.is-spotlight .recharge-note,
body.theme-night.page-home-landing .recharge-card.is-spotlight .feature-item,
body.theme-night.page-home-landing .recharge-card.is-spotlight .recharge-corner,
body.theme-night.page-home-landing .recharge-card.is-spotlight .recharge-proof {
    color: rgba(249, 212, 229, 0.9);
}

body.theme-day.page-home-landing .recharge-card.enterprise {
    background:
        radial-gradient(circle at 16% 16%, rgba(132, 117, 232, 0.14), transparent 34%),
        radial-gradient(circle at 88% 0%, rgba(231, 227, 255, 0.5), transparent 30%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(247, 246, 255, 0.96) 100%);
    border-color: rgba(103, 92, 198, 0.18);
    box-shadow: 0 24px 60px rgba(94, 79, 177, 0.10), 0 20px 54px rgba(22, 31, 52, 0.08);
}

body.theme-night.page-home-landing .recharge-card.enterprise {
    background:
        radial-gradient(circle at 16% 16%, rgba(132, 117, 232, 0.16), transparent 34%),
        radial-gradient(circle at 88% 0%, rgba(164, 153, 255, 0.08), transparent 28%),
        linear-gradient(180deg, rgba(24, 22, 40, 0.98) 0%, rgba(16, 16, 30, 0.98) 100%);
    border-color: rgba(124, 113, 214, 0.26);
    box-shadow: 0 28px 70px rgba(0, 0, 0, 0.42), 0 18px 48px rgba(132, 117, 232, 0.10);
}

body.theme-day.page-home-landing .recharge-card.max3000,
body.theme-night.page-home-landing .recharge-card.max3000 {
    background:
        radial-gradient(circle at 16% 16%, rgba(223, 188, 118, 0.16), transparent 34%),
        radial-gradient(circle at 88% 0%, rgba(255, 255, 255, 0.07), transparent 28%),
        linear-gradient(160deg, rgba(19, 23, 35, 0.98) 0%, rgba(10, 14, 24, 0.98) 100%);
    border-color: rgba(223, 188, 118, 0.38);
    box-shadow: 0 30px 80px rgba(0, 0, 0, 0.46), 0 20px 56px rgba(223, 188, 118, 0.10);
}

body.page-home-landing .recharge-card.max3000 .recharge-name,
body.page-home-landing .recharge-card.max3000 .recharge-credits {
    color: #f8fafc;
}

body.page-home-landing .recharge-card.max3000 .recharge-note,
body.page-home-landing .recharge-card.max3000 .feature-item,
body.page-home-landing .recharge-card.max3000 .recharge-corner,
body.page-home-landing .recharge-card.max3000 .recharge-proof {
    color: rgba(226, 232, 240, 0.88);
}

body.page-home-landing .recharge-card.max3000 .price-currency,
body.page-home-landing .recharge-card.max3000 .price-amount,
body.page-home-landing .recharge-card.max3000 .recharge-badge {
    color: #f5c454;
}

body.page-home-landing .recharge-card.max3000 .recharge-badge {
    background: rgba(245, 196, 84, 0.14);
    border-color: rgba(245, 196, 84, 0.2);
}

body.page-home-landing .recharge-card.max3000 .recharge-proof {
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(245, 196, 84, 0.22);
}

body.page-home-landing .recharge-card.max3000 .feature-item:before {
    background: rgba(245, 196, 84, 0.16);
    color: #f5c454;
}

body.page-home-landing .recharge-card.max3000 .recharge-output-pitch {
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(245, 196, 84, 0.18);
}

body.page-home-landing .recharge-card.max3000 .recharge-output-title,
body.page-home-landing .recharge-card.max3000 .recharge-output-mode {
    color: rgba(248, 250, 252, 0.9);
}

body.page-home-landing .recharge-card.max3000 .recharge-btn {
    border: 1px solid rgba(15, 23, 42, 0.08);
    background: linear-gradient(180deg, #1f2937 0%, #111827 100%);
    color: #f8fafc;
    box-shadow: 0 18px 36px rgba(17, 24, 39, 0.16);
}

@media (max-width: 1200px) {
    body.page-home-landing .recharge-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        max-width: none;
        margin: 0;
    }

    body.page-home-landing .recharge-card {
        min-height: 376px;
    }
}

@media (max-width: 768px) {
    body.page-home-landing .recharge-section::before {
        inset: -10px 0;
        border-radius: 24px;
    }

    body.page-home-landing .recharge-grid {
        grid-template-columns: 1fr;
        max-width: 680px;
        margin: 0 auto;
    }

    body.page-home-landing .recharge-card {
        min-height: auto;
        padding: 16px 14px 14px;
        gap: 9px;
    }

    body.page-home-landing .recharge-card:hover {
        transform: translateY(-2px);
    }

    body.page-home-landing .recharge-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 14px;
    }

    body.page-home-landing .recharge-contact {
        width: 100%;
    }

    body.page-home-landing .wechat-id {
        width: 100%;
        justify-content: center;
    }

    body.page-home-landing .recharge-card-top {
        align-items: flex-start;
    }

    body.page-home-landing .price-currency {
        font-size: 1.3rem;
    }

    body.page-home-landing .price-amount {
        font-size: clamp(2.55rem, 13vw, 3.45rem);
    }

    body.page-home-landing .recharge-credits {
        font-size: 1rem;
    }
}
