:root, [data-theme='light'] { --color-bg: #faf9f5; --color-surface: #ffffff; --color-surface-2: #f4f2ea; --color-surface-3: #ece9de; --color-border: #ebe7da; --color-border-strong: #d8d2c0; --color-border-focus: #c2541f; --color-text: #2a2622; --color-text-secondary: #6b6660; --color-text-tertiary: #a09a8e; --color-brand: #c2541f; --color-brand-hover: #a64419; --color-brand-soft: #fdf2ea; --color-brand-soft-2: #fae3d2; --color-success: #4f8a4d; --color-success-soft: #ecf3ec; --color-warning: #b8782a; --color-warning-soft: #fdf3e3; --color-danger: #c0392b; --color-danger-soft: #fbeae8; --color-info: #4a6fa5; --color-info-soft: #ecf1f8; --shadow-xs: 0 1px 2px rgba(40, 30, 20, 0.04); --shadow-sm: 0 1px 2px rgba(40, 30, 20, 0.04), 0 1px 3px rgba(40, 30, 20, 0.05); --shadow-md: 0 2px 4px rgba(40, 30, 20, 0.04), 0 6px 16px rgba(40, 30, 20, 0.06); --shadow-lg: 0 4px 12px rgba(40, 30, 20, 0.06), 0 16px 40px rgba(40, 30, 20, 0.08); --shadow-xl: 0 8px 24px rgba(40, 30, 20, 0.08), 0 24px 60px rgba(40, 30, 20, 0.12); --shadow-focus: 0 0 0 3px rgba(194, 84, 31, 0.18); --gradient-brand: linear-gradient(135deg, #c2541f, #e07b3e); --gradient-hero: radial-gradient(1200px 600px at 0% 0%, #fae3d2 0%, transparent 60%), radial-gradient(900px 500px at 100% 0%, #f0e8d6 0%, transparent 55%), linear-gradient(180deg, #faf9f5 0%, #f4f2ea 100%); } [data-theme='dark'] { --color-bg: #1a1816; --color-surface: #221f1c; --color-surface-2: #2b2824; --color-surface-3: #36322c; --color-border: #36322c; --color-border-strong: #4a443c; --color-border-focus: #e07b3e; --color-text: #f3efe6; --color-text-secondary: #b6afa3; --color-text-tertiary: #7e7869; --color-brand: #e07b3e; --color-brand-hover: #f0935a; --color-brand-soft: #2d2017; --color-brand-soft-2: #3a2a1c; --color-success: #7fb87d; --color-success-soft: #1e2a1d; --color-warning: #d49a4a; --color-warning-soft: #2c2316; --color-danger: #e07060; --color-danger-soft: #2a1a17; --color-info: #8aa9d6; --color-info-soft: #1a2230; --shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.2); --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.25), 0 1px 3px rgba(0, 0, 0, 0.3); --shadow-md: 0 2px 4px rgba(0, 0, 0, 0.25), 0 6px 16px rgba(0, 0, 0, 0.35); --shadow-lg: 0 4px 12px rgba(0, 0, 0, 0.3), 0 16px 40px rgba(0, 0, 0, 0.45); --shadow-xl: 0 8px 24px rgba(0, 0, 0, 0.4), 0 24px 60px rgba(0, 0, 0, 0.55); --shadow-focus: 0 0 0 3px rgba(224, 123, 62, 0.25); --gradient-brand: linear-gradient(135deg, #c2541f, #e07b3e); --gradient-hero: radial-gradient(1200px 600px at 0% 0%, #3a2a1c 0%, transparent 60%), radial-gradient(900px 500px at 100% 0%, #2a2620 0%, transparent 55%), linear-gradient(180deg, #1a1816 0%, #221f1c 100%); } * { box-sizing: border-box; } html, body, #root { height: 100%; margin: 0; padding: 0; font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'PingFang SC', 'Microsoft YaHei', sans-serif; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; background: var(--color-bg); color: var(--color-text); } body { transition: background-color 0.2s ease, color 0.2s ease; } .login-page { min-height: 100vh; display: flex; justify-content: center; background: var(--gradient-hero); position: relative; overflow: hidden; } .login-deco { position: absolute; border-radius: 50%; filter: blur(40px); } .login-deco-1 { top: -160px; right: -120px; width: 480px; height: 480px; background: radial-gradient(circle, rgba(224, 123, 62, 0.18), transparent 60%); } .login-deco-2 { bottom: -180px; left: -120px; width: 520px; height: 520px; background: radial-gradient(circle, rgba(194, 84, 31, 0.16), transparent 60%); } .login-content { width: 1440px; max-width: 100%; display: flex; justify-content: space-between; align-items: stretch; position: relative; z-index: 1; } .login-brand-panel { flex: 1; display: flex; flex-direction: column; justify-content: center; padding: 60px 80px; } .login-brand-header { display: flex; align-items: center; gap: 12px; margin-bottom: 40px; } .login-brand-logo { width: 40px; height: 40px; flex: 0 0 auto; object-fit: contain; filter: drop-shadow(0 12px 22px rgba(17, 103, 255, 0.16)); } .login-brand-name { font-size: 18px; font-weight: 700; color: var(--color-text); } .login-title { font-size: 48px; line-height: 1.15; font-weight: 700; letter-spacing: -0.03em; color: var(--color-text); margin: 0; max-width: 520px; } .login-title-highlight { background: var(--gradient-brand); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; } .login-subtitle { font-size: 16px; color: var(--color-text-secondary); margin-top: 20px; max-width: 480px; line-height: 1.7; } .login-features { display: flex; gap: 24px; margin-top: 40px; flex-wrap: wrap; } .login-feature-item { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--color-text-secondary); } .login-feature-icon { color: var(--color-brand); } .login-form-panel { width: 480px; display: flex; align-items: center; justify-content: center; padding: 40px; } .login-card { width: 100%; max-width: 380px; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: 20px; padding: 36px 32px; box-shadow: var(--shadow-xl); } .login-card-header { margin-bottom: 24px; } .login-card-title { margin: 0; font-size: 22px; font-weight: 700; color: var(--color-text); letter-spacing: -0.01em; } .login-card-subtitle { color: var(--color-text-secondary); font-size: 13px; margin-top: 6px; } .login-form { margin-top: 8px; } .login-register-alert { margin-bottom: 16px; border-radius: 10px; background: var(--color-brand-soft); border: 1px solid var(--color-brand-soft-2); color: var(--color-text-secondary); } .login-submit-btn { margin-top: 4px; height: 44px; font-weight: 600; } .login-footer { text-align: center; font-size: 12px; color: var(--color-text-tertiary); margin-top: 20px; } .layout-shell { display: flex; height: 100vh; background: var(--color-bg); } .main { flex: 1; overflow: auto; background: var(--color-bg); } .main-chat { overflow: hidden; } .sidebar { width: 248px; background: var(--color-surface); border-right: 1px solid var(--color-border); color: var(--color-text); display: flex; flex-direction: column; padding: 14px 12px; } .sidebar .brand { font-size: 15px; font-weight: 700; color: var(--color-text); padding: 6px 10px 18px; display: flex; align-items: center; gap: 10px; } .sidebar .brand .brand-logo { width: 28px; height: 28px; flex: 0 0 auto; object-fit: contain; filter: drop-shadow(0 8px 16px rgba(17, 103, 255, 0.16)); } .sidebar .nav-section-label { font-size: 11px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; color: var(--color-text-tertiary); padding: 14px 12px 6px; } .sidebar .nav-item { padding: 7px 12px; border-radius: 8px; cursor: pointer; display: flex; align-items: center; gap: 10px; margin-bottom: 1px; color: var(--color-text-secondary); text-decoration: none; font-size: 13.5px; font-weight: 500; transition: background 0.15s ease, color 0.15s ease; } .sidebar .nav-item:hover { background: var(--color-surface-2); color: var(--color-text); } .sidebar .nav-item.active { background: var(--color-brand-soft); color: var(--color-brand); font-weight: 600; } .sidebar .nav-item .nav-icon { width: 18px; height: 18px; display: inline-flex; align-items: center; justify-content: center; font-size: 16px; } .sidebar .kbd { font-size: 10.5px; color: var(--color-text-tertiary); background: var(--color-surface-2); border: 1px solid var(--color-border); padding: 1px 5px; border-radius: 4px; font-family: ui-monospace, SFMono-Regular, Menlo, monospace; } .sidebar-user { display: flex; align-items: center; gap: 10px; padding: 8px 10px; cursor: pointer; border-radius: 10px; background: var(--color-surface-2); border: 1px solid var(--color-border); } .agent-card { background: var(--color-surface); border-radius: 14px; padding: 20px; border: 1px solid var(--color-border); height: 100%; display: flex; flex-direction: column; gap: 12px; transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease; box-shadow: var(--shadow-xs); } .agent-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); border-color: var(--color-border-strong); } .agent-card .avatar { width: 48px; height: 48px; border-radius: 50%; background: var(--gradient-brand); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 19px; font-weight: 700; overflow: hidden; box-shadow: var(--shadow-sm); } .agent-card .desc { color: var(--color-text-secondary); font-size: 13px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; min-height: 40px; line-height: 1.55; } .empty-state { text-align: center; padding: 60px 0; color: var(--color-text-tertiary); } .page-hero { background: var(--gradient-hero); border-bottom: 1px solid var(--color-border); padding: 56px 32px 40px; } .page-hero .hero-title { font-size: 32px; font-weight: 700; color: var(--color-text); margin: 0 0 8px; } .page-hero .hero-subtitle { font-size: 15px; color: var(--color-text-secondary); margin: 0; max-width: 640px; } .chat-shell { display: flex; height: 100vh; background: var(--color-bg); } .chat-side { width: 260px; border-right: 1px solid var(--color-border); overflow: hidden; display: flex; flex-direction: column; gap: 0; height: 100%; background: var(--color-surface); } .chat-main { flex: 1; display: flex; flex-direction: column; background: var(--color-bg); min-width: 0; position: relative; } .chat-content-row { flex: 1; min-height: 0; display: flex; } .chat-header { height: 60px; padding: 0 24px; border-bottom: 1px solid var(--color-border); display: flex; align-items: center; justify-content: space-between; background: var(--color-surface); } .chat-header-agent { display: flex; flex-direction: column; gap: 2px; min-width: 0; } .chat-header-agent-title { display: flex; align-items: baseline; gap: 10px; min-width: 0; } .chat-header-agent-name { font-weight: 600; font-size: 16px; color: var(--color-text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 320px; } .chat-header-agent-desc { font-size: 12px; color: var(--color-text-tertiary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 380px; } .chat-header-agent-meta { font-size: 12px; color: var(--color-text-tertiary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 720px; } .chat-header-stream-toggle { display: flex; align-items: center; gap: 6px; margin-right: 12px; } .chat-header-stream-label { font-size: 12px; color: var(--color-text-secondary); } .chat-body { flex: 1; overflow-y: auto; background: var(--color-bg); } .chat-outline { width: 260px; border-left: 1px solid var(--color-border); background: var(--color-surface); padding: 14px 12px; overflow: auto; } .chat-outline-title { font-size: 12px; font-weight: 600; color: var(--color-text-secondary); margin-bottom: 10px; } .chat-outline-list { display: flex; flex-direction: column; gap: 6px; } .chat-outline-item { border: 0; background: var(--color-surface); border-radius: 10px; padding: 4px 10px; text-align: left; cursor: pointer; display: flex; gap: 8px; align-items: flex-start; color: var(--color-text); } .chat-outline-item.active { background-color: #eee; } .chat-outline-index { font-size: 12px; color: var(--color-text-tertiary); line-height: 1.4; flex: 0 0 auto; } .chat-outline-text { font-size: 12.5px; line-height: 1.4; color: var(--color-text); overflow: hidden; display: -webkit-box; -webkit-line-clamp: 1; -webkit-box-orient: vertical; } @media (max-width: 1100px) { .chat-content-row > .chat-outline { display: none; } } @media (max-width: 768px) { html { font-size: clamp(14px, 4.2667vw, 16px); } .layout-shell > .sidebar { display: none; } .main { width: 100vw; display: flex; flex-direction: column; overflow: hidden; } .mobile-topbar { height: 3rem; flex: 0 0 auto; display: flex; align-items: center; gap: 0.5rem; padding: 0 0.5rem; border-bottom: 1px solid var(--color-border); background: var(--color-surface); } .mobile-topbar-title { flex: 1; min-width: 0; font-weight: 700; color: var(--color-text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } .main-content { flex: 1; min-height: 0; overflow: auto; } .chat-shell { height: 100%; } .chat-header { height: auto; min-height: 3.5rem; padding: 0.625rem 0.75rem; gap: 0.625rem; flex-wrap: wrap; align-items: center; background-color: transparent; border:0; } .chat-header-agent-name { max-width: 220px; } .chat-header-agent-desc, .chat-header-agent-meta { display: none; } .chat-body .messages-container { max-width: 100%; padding: 1.125rem 0.75rem 6rem; } .bubble { max-width: 92%; padding: 0.75rem 0.875rem; font-size: 0.875rem; } .chat-input-wrapper { max-width: 100%; padding: 0 0.75rem 1rem; } .chat-input-actions { top: -22px; right: 0; } .chat-model-select { min-width: 0; max-width: 100%; flex: 1 1 auto; } .chat-input-toolbar { flex-wrap: wrap; gap: 0.5rem; } .chat-input-toolbar-left { gap: 0.5rem; flex: 1 1 auto; min-width: 0; } .chat-input-toolbar .chat-send-button { margin-left: auto; } .chat-model-select .ant-select-selector { padding: 0 1.25rem 0 0 !important; } .chat-model-select .ant-select-selection-item { max-width: 10rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } } .main-content { min-height: 0; } .chat-body .messages-container { max-width: 780px; width: 100%; margin: 0 auto; padding: 16px 12px 80px; } .bubble { max-width: 78%; display: inline-block; padding: 14px 18px; border-radius: 14px; margin-bottom: 14px; white-space: pre-wrap; word-wrap: break-word; line-height: 1.65; font-size: 14.5px; } .bubble.user { background: #0a84ff; color: #ffffff; margin-left: auto; border-bottom-right-radius: 5px; } .bubble.assistant { background: #e9e9eb; color: #111827; border: 0; border-bottom-left-radius: 5px; box-shadow: none; } .bubble.assistant p { margin: 0 0 5px; } .bubble.assistant p:last-child { margin-bottom: 0; } .bubble.assistant h1, .bubble.assistant h2, .bubble.assistant h3, .bubble.assistant h4, .bubble.assistant h5, .bubble.assistant h6 { margin: 0.2em 0 0.1em; line-height: 1.3; } .bubble.assistant ol, .bubble.assistant ul { margin: 0.15em 0; padding-left: 1.25em; } .bubble.assistant li { margin: 0.05em 0; } .bubble.assistant hr { margin: 0.4em 0; } .bubble.assistant li > p { margin: 0.15em 0; } .bubble.assistant blockquote { margin: 0.2em 0; padding: 0.2em 0.6em; border-left: 3px solid var(--color-border); background: rgba(15, 23, 42, 0.03); border-radius: 8px; } .bubble.assistant blockquote p { margin: 0.2em 0; } .chat-copy-icon { display: inline-flex; align-items: center; justify-content: center; width: 20px; height: 20px; cursor: pointer; color: var(--color-text-secondary); } .chat-copy-icon:hover { color: var(--color-text); } .bubble.assistant table { border-collapse: collapse; width: 100%; margin: 0.35em 0; font-size: 13.5px; } .bubble.assistant th, .bubble.assistant td { border: 1px solid var(--color-border); padding: 6px 8px; text-align: left; vertical-align: top; } .bubble.assistant thead th { background: var(--color-surface-2); font-weight: 600; } .chat-input-wrapper { width: 100%; max-width: 820px; margin: 0 auto; padding: 0 24px 24px; } .chat-input-card { width: 100%; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: 20px; padding: 14px 16px 12px; min-height: 110px; box-shadow: var(--shadow-sm); } .chat-input-card-wrap { position: relative; } .chat-input-actions { position: absolute; top: -24px; right: 8px; display: flex; gap: 4px; z-index: 2; } .chat-input-action-btn { display: inline-flex; align-items: center; gap: 6px; color: var(--color-text-secondary); } .chat-input-action-btn:hover { color: var(--color-text); } .chat-input-action-btn-primary { color: var(--color-brand); } .chat-input-action-btn-primary:hover { color: var(--color-brand); opacity: 0.9; } .chat-input-stack { display: flex; flex-direction: column; gap: 10px; width: 100%; } .chat-input-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding-top: 8px; border-top: 1px solid var(--color-border); } .chat-input-toolbar-left { display: flex; align-items: center; gap: 12px; flex: 1; min-width: 0; } .chat-model-select { min-width: 240px; max-width: 320px; } .chat-model-select .ant-select-selector { border: none !important; box-shadow: none !important; background: transparent !important; padding: 0 24px 0 0 !important; } .chat-model-select .ant-select-selection-item { color: var(--color-text); font-weight: 500; font-size: 13px; padding: 0 8px; } .chat-model-select .ant-select-selection-placeholder { color: var(--color-text-secondary); font-size: 13px; } .chat-model-select-arrow { font-size: 10px; color: var(--color-text-tertiary); } .chat-tool-button { position: relative; z-index: 1; } .chat-upload { flex: 0 0 auto; display: inline-flex; } .chat-upload .ant-upload { display: inline-flex; } .ant-btn.chat-send-button, .chat-send-button.ant-btn { width: 40px !important; min-width: 40px !important; max-width: 40px !important; height: 40px !important; min-height: 40px !important; max-height: 40px !important; flex: 0 0 40px; padding: 0 !important; border-radius: 9999px !important; display: inline-flex !important; align-items: center; justify-content: center; box-sizing: border-box; aspect-ratio: 1 / 1; } .ant-btn.chat-send-button .ant-btn-icon, .chat-send-button.ant-btn .ant-btn-icon { margin-inline-start: 0; } .chat-send-button-primary { background: var(--color-brand); border: none; } .chat-stop-icon { display: block; width: 10px; height: 10px; background: currentColor; border-radius: 2px; } .session-sidebar { height: 100%; display: flex; flex-direction: column; box-sizing: border-box; } .session-sidebar-new { margin-bottom: 8px; background: var(--ss-primary); border: none; } .session-sidebar-search { margin-top: 4px; margin-bottom: 8px; } .session-sidebar .ant-input-affix-wrapper, .session-sidebar .ant-input-affix-wrapper:hover, .session-sidebar .ant-input-affix-wrapper-focused { background: var(--ss-input-bg); border-color: var(--ss-border); } .session-sidebar .ant-input { color: var(--ss-text); } .session-sidebar-scroll { flex: 1; overflow: auto; } .session-sidebar-loading { padding: 16px; text-align: center; } .session-sidebar-search-section { margin-bottom: 8px; } .session-sidebar-search-section-title { font-size: 11px; color: var(--ss-text-dim); padding: 4px 8px; } .session-sidebar-search-hit { cursor: pointer; padding: 6px 10px; border-radius: 6px; margin-bottom: 2px; background: var(--ss-bg-search); font-size: 12px; color: var(--ss-text); } .session-sidebar-search-hit.active { background: var(--ss-bg-active); } .session-sidebar-search-msg-hit { cursor: pointer; padding: 8px; border-radius: 6px; margin-bottom: 4px; background: var(--ss-bg-search); border-left: 3px solid transparent; } .session-sidebar-search-msg-hit.role-user { border-left-color: #6366f1; } .session-sidebar-search-msg-hit.role-assistant { border-left-color: #10b981; } .session-sidebar-search-msg-meta { font-size: 11px; color: var(--ss-text-dim); margin-bottom: 2px; } .session-sidebar-search-msg-snippet { font-size: 12px; color: var(--ss-text); line-height: 1.4; } .session-sidebar-seg { margin-bottom: 8px; } .session-sidebar-seg-label { display: inline-flex; align-items: center; gap: 6px; } .session-sidebar-list { flex: 1; overflow: auto; } .session-sidebar-item { cursor: pointer; padding: 8px 10px; background: transparent; border-radius: 6px; border: 1px solid transparent; margin-bottom: 4px; } .session-sidebar-item:hover { background: var(--ss-bg-hover); } .session-sidebar-item.active { background: var(--ss-bg-active); border-color: var(--ss-border-active); } .session-sidebar-item-main { flex: 1; min-width: 0; } .session-sidebar-item-title { font-size: 13px; font-weight: 500; color: var(--ss-text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; display: inline-flex; align-items: center; gap: 6px; } .session-sidebar-item-title.active { font-weight: 600; color: var(--ss-text-active); } .session-sidebar-item-subtitle { font-size: 11px; color: var(--ss-text-dim); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; margin-top: 2px; } .session-sidebar-item-actions { display: flex; gap: 2px; margin-left: 6px; } .session-sidebar mark { background: #fef3c7; color: #b45309; padding: 0 2px; border-radius: 2px; } .chat-disclaimer { text-align: center; font-size: 11px; color: var(--color-text-tertiary); margin-top: 8px; } .agent-model-dropdown-trigger { width: 100%; min-height: 42px; display: flex; align-items: center; gap: 10px; padding: 10px 12px; border: 1px solid var(--color-border); border-radius: 12px; background: var(--color-surface); color: var(--color-text); cursor: pointer; text-align: left; } .agent-model-dropdown-summary { flex-shrink: 0; font-weight: 500; } .agent-model-dropdown-values { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--color-text-secondary); font-size: 13px; } .agent-model-dropdown-arrow { flex-shrink: 0; font-size: 12px; color: var(--color-text-tertiary); } .agent-model-dropdown-panel { width: min(720px, calc(100vw - 64px)); max-height: 360px; overflow-y: auto; padding: 12px; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: 12px; box-shadow: var(--shadow-lg); } .agent-model-checkbox-group { display: flex; flex-direction: column; gap: 10px; width: 100%; } .agent-model-checkbox-item { display: flex; align-items: flex-start; margin-inline-start: 0; padding: 12px 14px; border: 1px solid var(--color-border); border-radius: 12px; background: var(--color-surface); } .agent-model-checkbox-item .ant-checkbox { margin-top: 3px; } .agent-model-checkbox-item .ant-checkbox + span { width: 100%; padding-inline-start: 10px; } .agent-model-checkbox-content { display: flex; align-items: center; justify-content: space-between; gap: 12px; width: 100%; } .agent-model-checkbox-meta { display: flex; align-items: center; gap: 8px; min-width: 0; flex: 1; } .agent-model-checkbox-icon { width: 20px; height: 20px; object-fit: contain; border-radius: 4px; flex-shrink: 0; } .agent-model-checkbox-name { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-weight: 500; color: var(--color-text); } .agent-model-checkbox-price { display: flex; flex-direction: column; align-items: flex-end; justify-content: center; flex-shrink: 0; margin-left: 8px; font-size: 10px; color: var(--color-text-tertiary); } .chat-input-textarea { border: none !important; box-shadow: none !important; padding: 10px 4px !important; font-size: 16px; line-height: 1.7; resize: none; background: transparent !important; color: var(--color-text) !important; } .chat-input-textarea:hover, .chat-input-textarea:focus, .chat-input-textarea:focus-visible, .chat-input-textarea:active { border: none !important; box-shadow: none !important; outline: none !important; } .monica-editor-column { height: 100%; overflow-y: auto; padding: 24px; } .monica-section-title { font-size: 15px; font-weight: 600; color: var(--color-text); margin-bottom: 14px; } .monica-card { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: 12px; padding: 16px; margin-bottom: 16px; } .monica-header { height: 56px; border-bottom: 1px solid var(--color-border); display: flex; align-items: center; justify-content: space-between; padding: 0 24px; background: var(--color-surface); } .agent-editor-shell { background: radial-gradient(circle at top left, rgba(8, 145, 178, 0.08), transparent 24%), radial-gradient(circle at top right, rgba(59, 130, 246, 0.07), transparent 22%), var(--color-bg); } .agent-editor-header { height: 72px; padding: 0 28px; border-bottom: 1px solid var(--color-border); background: rgba(255, 255, 255, 0.84); backdrop-filter: blur(14px); } .agent-editor-workbench { display: flex; gap: 14px; padding: 14px; min-height: 0; } .agent-editor-pane { min-width: 0; border: 1px solid rgba(148, 163, 184, 0.14); border-radius: 24px; background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(252,252,253,1) 100%); box-shadow: 0 14px 34px rgba(15, 23, 42, 0.045); overflow: hidden; } .agent-editor-pane-body { height: 100%; overflow-y: auto; padding: 22px; } .agent-editor-pane-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; margin-bottom: 18px; } .agent-editor-pane-title { font-size: 18px; font-weight: 700; color: var(--color-text); margin: 0 0 6px; letter-spacing: -0.02em; } .agent-editor-pane-subtitle { font-size: 13px; line-height: 1.7; color: var(--color-text-secondary); margin: 0; } .agent-editor-badge { display: inline-flex; align-items: center; gap: 8px; padding: 6px 12px; border-radius: 999px; background: rgba(8, 145, 178, 0.08); color: var(--color-brand); font-size: 12px; font-weight: 600; white-space: nowrap; } .agent-editor-intro { border-radius: 18px; padding: 16px 18px; background: linear-gradient(135deg, rgba(236,253,245,0.92) 0%, rgba(240,249,255,0.92) 100%); border: 1px solid rgba(8, 145, 178, 0.12); margin-bottom: 16px; } .agent-editor-intro-title { font-size: 14px; font-weight: 700; color: var(--color-text); margin-bottom: 6px; } .agent-editor-intro-text { font-size: 12.5px; line-height: 1.7; color: var(--color-text-secondary); } .agent-editor-surface { border-radius: 18px; border: 1px solid rgba(148, 163, 184, 0.14); background: linear-gradient(180deg, rgba(255,255,255,0.96) 0%, rgba(248,250,252,0.88) 100%); box-shadow: inset 0 1px 0 rgba(255,255,255,0.65); } .agent-editor-prompt-wrap { padding: 12px; } .agent-editor-prompt { border-radius: 16px; border: 1px solid rgba(148, 163, 184, 0.12); background: rgba(255,255,255,0.72); } .agent-editor-preview-shell { height: 100%; display: flex; flex-direction: column; } .agent-editor-modal-hero { display: grid; grid-template-columns: 220px minmax(0, 1fr); gap: 18px; margin-bottom: 20px; } .agent-editor-modal-card { border-radius: 20px; border: 1px solid rgba(148, 163, 184, 0.14); background: linear-gradient(180deg, rgba(255,255,255,0.96) 0%, rgba(248,250,252,0.88) 100%); } .agent-editor-avatar-grid { display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); gap: 12px; padding: 16px; border-radius: 20px; background: linear-gradient(180deg, rgba(248,250,252,0.9) 0%, rgba(255,255,255,0.92) 100%); border: 1px solid rgba(148, 163, 184, 0.12); max-height: 280px; overflow-y: auto; } .page-container { max-width: 1240px; margin: 0 auto; padding: 40px 32px 60px; } .feature-cover-container { position: relative; } .feature-cover { position: absolute; inset: 0; z-index: 20; display: flex; align-items: center; justify-content: center; background: rgba(255, 255, 255, 0.74); backdrop-filter: blur(2px); } .feature-cover .ant-empty { padding: 26px 30px; border-radius: 16px; background: rgba(255, 255, 255, 0.92); border: 1px solid var(--color-border); box-shadow: var(--shadow-md); } .page-header { margin-bottom: 32px; } .page-title { font-size: 28px; font-weight: 700; color: var(--color-text); margin: 0 0 6px; } .page-subtitle { font-size: 14px; color: var(--color-text-secondary); margin: 0; } .create-card { min-height: 240px; height: 100%; border: 1.5px dashed var(--color-border-strong); border-radius: 14px; display: flex; flex-direction: column; align-items: stretch; justify-content: flex-start; padding: 20px; gap: 12px; cursor: pointer; transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease, background 0.25s ease; background: var(--color-surface); box-shadow: var(--shadow-xs); } .create-card:hover { transform: translateY(-2px); border-color: var(--color-brand); background: var(--color-brand-soft); box-shadow: var(--shadow-md); } .create-card .create-icon { width: 52px; height: 52px; border-radius: 50%; background: var(--color-surface); display: flex; align-items: center; justify-content: center; box-shadow: var(--shadow-sm); color: var(--color-brand); font-size: 22px; border: 1px solid var(--color-border); } .theme-toggle { width: 32px; height: 32px; border-radius: 8px; border: 1px solid var(--color-border); background: var(--color-surface); color: var(--color-text-secondary); cursor: pointer; display: inline-flex; align-items: center; justify-content: center; } .theme-toggle:hover { border-color: var(--color-border-strong); color: var(--color-text); background: var(--color-surface-2); } .flex { display: flex; } .flex-col { flex-direction: column; } .flex-row { flex-direction: row; } .flex-1 { flex: 1; } .items-center { align-items: center; } .justify-between { justify-content: space-between; } .justify-center { justify-content: center; } .justify-start { justify-content: flex-start; } .justify-end { justify-content: flex-end; } .h-full { height: 100%; } .w-full { width: 100%; } .overflow-hidden { overflow: hidden; } .overflow-auto { overflow: auto; } .object-cover { object-fit: cover; } .fixed { position: fixed; } .absolute { position: absolute; } .relative { position: relative; } .inset-0 { top: 0; right: 0; bottom: 0; left: 0; } .z-100 { z-index: 100; } .p-4 { padding: 1rem; } .p-2 { padding: 0.5rem; } .px-1 { padding-left: 0.25rem; padding-right: 0.25rem; } .mb-0 { margin-bottom: 0; } .mb-2 { margin-bottom: 0.5rem; } .mb-3 { margin-bottom: 0.75rem; } .mb-4 { margin-bottom: 1rem; } .mt-2 { margin-top: 0.5rem; } .mt-6 { margin-top: 1.5rem; } .gap-1 { gap: 0.25rem; } .gap-2 { gap: 0.5rem; } .gap-4 { gap: 1rem; } .rounded-full { border-radius: 9999px; } .rounded-lg { border-radius: 0.5rem; } .text-xs { font-size: 0.75rem; } .text-sm { font-size: 0.875rem; } .text-lg { font-size: 1.125rem; } .font-bold { font-weight: 700; } .font-medium { font-weight: 500; } .bg-white { background: var(--color-surface); } .bg-gray-50 { background: var(--color-surface-2); } .text-gray-400 { color: var(--color-text-tertiary); } .text-gray-500 { color: var(--color-text-secondary); } .text-gray-700 { color: var(--color-text); } .text-gray-800 { color: var(--color-text); } .border-none { border: none; } .border-t { border-top: 1px solid var(--color-border); } .border-l { border-left: 1px solid var(--color-border); } .shadow-lg { box-shadow: var(--shadow-lg); } .ant-btn-primary { box-shadow: 0 1px 2px rgba(194, 84, 31, 0.18) !important; } .ant-input, .ant-input-affix-wrapper, .ant-input-number, .ant-select-selector, .ant-picker { background: var(--color-surface) !important; border-color: var(--color-border) !important; color: var(--color-text) !important; } .ant-input::placeholder { color: var(--color-text-tertiary) !important; } .ant-input-affix-wrapper:hover, .ant-input:hover, .ant-select:hover .ant-select-selector, .ant-picker:hover { border-color: var(--color-border-strong) !important; } .ant-input-affix-wrapper-focused, .ant-input:focus, .ant-select-focused .ant-select-selector, .ant-picker-focused { border-color: var(--color-brand) !important; box-shadow: var(--shadow-focus) !important; } .ant-card { background: var(--color-surface) !important; border-color: var(--color-border) !important; } .ant-modal-content, .ant-modal-header, .ant-drawer-content { background: var(--color-surface) !important; } .ant-modal-title, .ant-collapse-header { color: var(--color-text) !important; } .ant-divider, .ant-drawer-header, .ant-collapse, .ant-collapse-item, .ant-collapse-content { border-color: var(--color-border) !important; } .ant-drawer-header { padding: 8px 8px !important; } /* @ Mention highlighting */ span.mention { background: rgba(59, 130, 246, 0.1); border: 1px solid rgba(59, 130, 246, 0.25); color: #3b82f6; padding: 1px 4px; border-radius: 4px; font-weight: 500; display: inline-block; line-height: 1.3; } .bubble.user span.mention { background: rgba(255, 159, 10, 0.22); border: 1px solid rgba(255, 159, 10, 0.38); color: #ff9f0a; } .ant-collapse-content { background: var(--color-surface) !important; color: var(--color-text) !important; } .ant-tabs-tab.ant-tabs-tab-active .ant-tabs-tab-btn { color: var(--color-brand) !important; } .ant-tabs-ink-bar { background: var(--color-brand) !important; } [data-theme='dark'] .ant-btn-default { background: var(--color-surface-2) !important; border-color: var(--color-border) !important; color: var(--color-text) !important; } [data-theme='dark'] .ant-btn-default:hover { background: var(--color-surface-3) !important; border-color: var(--color-border-strong) !important; } [data-theme='dark'] .ant-tag { background: var(--color-surface-2); border-color: var(--color-border); color: var(--color-text-secondary); } /* Avatar Hover Overlay */ .avatar-overlay { position: absolute; inset: 0; background-color: rgba(0, 0, 0, 0.5); opacity: 0; display: flex; align-items: center; justify-content: center; transition: opacity 0.2s ease-in-out; } .avatar-container:hover .avatar-overlay { opacity: 1; } .avatar-overlay-text { font-size: 10px; color: white; font-weight: 500; text-shadow: 0 1px 2px rgba(0,0,0,0.8); } /* Pulse Animation for Indexing Status */ @keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.5; } } /* Points Mall Styles */ .points-mall-hero { border-radius: 24px; padding: 30px 30px 22px; background: linear-gradient(135deg, rgba(255,255,255,0.98) 0%, rgba(236,253,245,0.92) 44%, rgba(239,246,255,0.96) 100%); border: 1px solid rgba(8, 145, 178, 0.12); box-shadow: 0 20px 48px rgba(15, 23, 42, 0.06); margin-bottom: 18px; } .points-mall-header { display: flex; justify-content: space-between; gap: 20px; flex-wrap: wrap; } .points-mall-title-section { max-width: 720px; } .points-mall-balance-card { min-width: 280px; border-radius: 18px; padding: 14px 16px; background: rgba(255,255,255,0.72); border: 1px solid rgba(255,255,255,0.7); } .points-balance-label { font-size: 12.5px; color: var(--color-text-secondary); margin-bottom: 6px; } .points-balance-value { font-size: 28px; font-weight: 800; color: var(--color-text); } .points-balance-subtext { font-size: 12px; color: var(--color-text-tertiary); margin-top: 4px; } .points-balance-row { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; } .points-mall-category-card { border-radius: 18px; box-shadow: 0 12px 28px rgba(15, 23, 42, 0.045); margin-bottom: 14px; } .points-mall-category-body { padding: 16px; } .points-mall-category-row { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; } .points-mall-category-label { font-size: 13px; color: var(--color-text-secondary); font-weight: 600; } .points-mall-banner-section { display: grid; grid-template-columns: minmax(0, 1.55fr) minmax(0, 1fr); gap: 14px; margin-bottom: 16px; } .points-mall-banner-card { border-radius: 22px; padding: 22px; border: 1px solid rgba(236, 72, 153, 0.22); background: linear-gradient(135deg, rgba(236, 72, 153, 0.16) 0%, rgba(59, 130, 246, 0.16) 60%, rgba(34, 197, 94, 0.12) 100%); box-shadow: 0 12px 30px rgba(15, 23, 42, 0.05); min-height: 176px; display: flex; flex-direction: column; justify-content: space-between; } .points-mall-banner-header { display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; } .points-mall-banner-title { font-size: 22px; font-weight: 800; color: var(--color-text); margin-bottom: 4px; } .points-mall-banner-subtitle { font-size: 14px; color: var(--color-text-secondary); } .points-mall-banner-footer { font-size: 12.5px; color: var(--color-text-tertiary); } .points-mall-promo-grid { display: grid; grid-template-rows: repeat(2, minmax(0, 1fr)); gap: 14px; } .points-mall-promo-card { border-radius: 22px; padding: 18px; border: 1px solid var(--color-border); background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(252,252,253,1) 100%); box-shadow: 0 10px 28px rgba(15, 23, 42, 0.04); display: flex; justify-content: space-between; gap: 12px; align-items: center; } .points-mall-promo-title { font-size: 16px; font-weight: 800; color: var(--color-text); margin-bottom: 4px; } .points-mall-promo-subtitle { font-size: 12.5px; color: var(--color-text-secondary); } .points-mall-promo-empty { border-radius: 22px; padding: 18px; border: 1px dashed var(--color-border); background: var(--color-surface); display: flex; align-items: center; justify-content: center; color: var(--color-text-tertiary); } .points-mall-products-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 14px; } .points-mall-product-card { border-radius: 20px; border: 1px solid rgba(148, 163, 184, 0.14); background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(252,252,253,1) 100%); box-shadow: 0 10px 28px rgba(15, 23, 42, 0.045); overflow: hidden; display: flex; flex-direction: column; } .points-mall-product-cover { height: 156px; background: linear-gradient(135deg, rgba(8,145,178,0.12) 0%, rgba(59,130,246,0.10) 55%, rgba(34,197,94,0.10) 100%); } .points-mall-product-body { padding: 14px; display: flex; flex-direction: column; gap: 10px; } .points-mall-product-header { display: flex; justify-content: space-between; gap: 10px; align-items: flex-start; } .points-mall-product-info { min-width: 0; flex: 1; } .points-mall-product-name { font-size: 15px; font-weight: 800; color: var(--color-text); margin-bottom: 4px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } .points-mall-product-desc { font-size: 12.5px; color: var(--color-text-secondary); line-height: 1.5; min-height: 36px; } .points-mall-product-price-row { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; } .points-mall-product-price { font-size: 18px; font-weight: 900; color: var(--color-text); } .points-mall-product-price-label { margin-left: 6px; font-size: 12.5px; color: var(--color-text-secondary); } .points-mall-product-exchange-btn { border-radius: 12px; height: 34px; font-weight: 700; } .points-mall-product-footer { display: flex; justify-content: space-between; gap: 10px; font-size: 12px; color: var(--color-text-tertiary); } .points-mall-pagination { display: flex; justify-content: center; margin-top: 18px; gap: 10px; } /* Exchange Modal Styles */ .points-exchange-modal .ant-modal-content { border-radius: 20px; } .points-exchange-modal-header { text-align: center; padding: 24px 24px 16px; } .points-exchange-product-name { font-size: 20px; font-weight: 700; color: var(--color-text); margin-bottom: 8px; } .points-exchange-points { font-size: 24px; font-weight: 800; color: var(--color-brand); } .points-exchange-form { padding: 0 24px 24px; } .points-exchange-form-item { margin-bottom: 16px; } .points-exchange-form-label { font-size: 13px; font-weight: 600; color: var(--color-text); margin-bottom: 8px; display: block; } .points-exchange-form-input { border-radius: 12px; } .points-exchange-form-input .ant-input, .points-exchange-form-input .ant-select-selector { border-radius: 12px !important; } .points-exchange-submit-btn { width: 100%; height: 44px; border-radius: 12px; font-weight: 600; font-size: 15px; margin-top: 8px; } .points-exchange-balance-warning { text-align: center; padding: 12px; background: var(--color-danger-soft); border-radius: 12px; color: var(--color-danger); font-size: 13px; margin-bottom: 16px; } .points-exchange-expire-tip { text-align: center; padding: 10px 12px; background: var(--color-warning-soft); border-radius: 12px; color: var(--color-warning); font-size: 13px; margin-bottom: 16px; } /* Points History in Stats */ .points-stats-card { border-radius: 18px; padding: 16px 18px; background: rgba(255,255,255,0.72); border: 1px solid rgba(255,255,255,0.7); } .points-stats-label { font-size: 12.5px; color: var(--color-text-secondary); margin-bottom: 10px; display: flex; align-items: center; gap: 8px; } .points-stats-value { font-size: 26px; font-weight: 700; color: var(--color-text); } .points-stats-icon { width: 10px; height: 10px; border-radius: 999px; background: var(--color-brand); } /* Stats Page Styles */ .stats-page-hero { border-radius: 24px; padding: 30px 30px 26px; background: linear-gradient(135deg, rgba(255,255,255,0.98) 0%, rgba(236,253,245,0.92) 44%, rgba(239,246,255,0.96) 100%); border: 1px solid rgba(8, 145, 178, 0.12); box-shadow: 0 20px 48px rgba(15, 23, 42, 0.06); margin-bottom: 24px; } .stats-page-header { display: flex; justify-content: space-between; gap: 20px; flex-wrap: wrap; margin-bottom: 20px; } .stats-page-title-section { max-width: 640px; } .stats-page-badge { display: inline-flex; align-items: center; gap: 8px; padding: 6px 12px; border-radius: 999px; background: rgba(255,255,255,0.78); border: 1px solid rgba(8, 145, 178, 0.10); color: var(--color-text-secondary); font-size: 12px; font-weight: 600; margin-bottom: 16px; } .stats-page-badge-icon { color: var(--color-brand); } .stats-page-summary-card { min-width: 240px; border-radius: 20px; padding: 18px 18px 16px; background: rgba(255,255,255,0.72); border: 1px solid rgba(255,255,255,0.7); } .stats-page-summary-label { font-size: 12.5px; color: var(--color-text-secondary); margin-bottom: 8px; } .stats-page-summary-value { font-size: 30px; font-weight: 700; color: var(--color-text); margin-bottom: 6px; } .stats-page-summary-desc { font-size: 12.5px; color: var(--color-text-tertiary); } .stats-page-cards-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; } .stats-page-card { border-radius: 18px; padding: 16px 18px; background: rgba(255,255,255,0.72); border: 1px solid rgba(255,255,255,0.7); } .stats-page-card-label { display: flex; align-items: center; gap: 8px; color: var(--color-text-secondary); font-size: 12.5px; margin-bottom: 10px; } .stats-page-card-icon { width: 28px; height: 28px; border-radius: 999px; display: inline-flex; align-items: center; justify-content: center; } .stats-page-card-value { font-size: 30px; font-weight: 700; color: var(--color-text); } .stats-page-main-grid { display: grid; grid-template-columns: minmax(0, 1.35fr) minmax(320px, 0.9fr); gap: 18px; } .stats-page-chart-card { border-radius: 22px; box-shadow: 0 12px 28px rgba(15, 23, 42, 0.045); } .stats-page-chart-desc { font-size: 13px; color: var(--color-text-secondary); margin-bottom: 10px; } .stats-page-chart-container { display: flex; align-items: flex-end; gap: 6px; height: 236px; padding: 18px 12px 10px; } .stats-page-chart-bar-group { flex: 1; display: flex; flex-direction: column; align-items: center; position: relative; min-width: 0; } .stats-page-chart-bars { display: flex; align-items: flex-end; gap: 1px; } .stats-page-chart-bar-user { width: 9px; background: var(--color-brand); border-radius: 6px 6px 0 0; } .stats-page-chart-bar-assistant { width: 9px; background: var(--color-success); border-radius: 6px 6px 0 0; } .stats-page-chart-label { font-size: 10px; color: var(--color-text-tertiary); margin-top: 6px; transform: rotate(-45deg); } .stats-page-chart-legend { margin-top: 8px; font-size: 12px; color: var(--color-text-secondary); display: flex; gap: 12px; } .stats-page-chart-legend-item { display: flex; align-items: center; gap: 4px; } .stats-page-chart-legend-dot { display: inline-block; width: 10px; height: 10px; border-radius: 999px; } .stats-page-agent-item { margin-bottom: 12px; padding: 12px 14px; border-radius: 16px; background: linear-gradient(180deg, rgba(255,255,255,0.96) 0%, rgba(248,250,252,0.9) 100%); border: 1px solid rgba(148, 163, 184, 0.12); } .stats-page-agent-header { display: flex; align-items: center; margin-bottom: 8px; gap: 10px; } .stats-page-agent-rank { width: 28px; height: 28px; border-radius: 999px; background: rgba(8, 145, 178, 0.10); color: var(--color-brand); display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; flex-shrink: 0; } .stats-page-agent-name { flex: 1; font-weight: 600; color: var(--color-text); min-width: 0; overflow: hidden; text-overflow: ellipsis; } .stats-page-agent-progress { height: 6px; background: var(--color-surface-2); border-radius: 3px; overflow: hidden; } .stats-page-agent-progress-bar { height: 100%; background: var(--gradient-brand); transition: width 0.4s; } .stats-page-token-section { margin-top: 18px; } .stats-page-token-cards-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 14px; margin-bottom: 16px; } .stats-page-token-card { border-radius: 18px; padding: 16px 18px; background: rgba(255,255,255,0.72); border: 1px solid rgba(255,255,255,0.7); } .stats-page-token-label { font-size: 12.5px; color: var(--color-text-secondary); margin-bottom: 10px; display: flex; align-items: center; gap: 6px; } .stats-page-token-dot { display: inline-block; width: 10px; height: 10px; border-radius: 999px; } .stats-page-token-value { font-size: 26px; font-weight: 700; color: var(--color-text); } .stats-page-token-charts-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 18px; } .stats-page-token-chart-card { border-radius: 18px; box-shadow: none; } .stats-page-token-chart-container { display: flex; align-items: flex-end; gap: 6px; height: 220px; padding: 18px 12px 10px; } .stats-page-token-chart-bar { width: 12px; background: var(--gradient-brand); border-radius: 6px 6px 0 0; } /* Points and USD integration */ .points-integration-section { margin-top: 18px; } .points-integration-card { border-radius: 22px; box-shadow: 0 12px 28px rgba(15, 23, 42, 0.045); } .points-integration-row { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; } .points-integration-item { border-radius: 18px; padding: 16px 18px; background: rgba(255,255,255,0.72); border: 1px solid rgba(255,255,255,0.7); } .points-integration-label { font-size: 12.5px; color: var(--color-text-secondary); margin-bottom: 8px; display: flex; align-items: center; gap: 6px; } .points-integration-value { font-size: 26px; font-weight: 700; color: var(--color-text); } .points-integration-desc { font-size: 11px; color: var(--color-text-tertiary); margin-top: 4px; } .points-conversion-rate { background: var(--color-brand-soft); color: var(--color-brand); padding: 2px 8px; border-radius: 999px; font-size: 11px; font-weight: 600; display: inline-block; margin-left: auto; } /* Additional Points Mall Styles */ .points-mall-filter-select { width: 160px; } .points-mall-filter-select-small { width: 140px; } .points-mall-search-input { width: 260px; } .points-mall-product-tag { margin: 0; border-radius: 999px; background: var(--color-warning-soft); color: var(--color-warning); } .points-mall-pagination-tag { margin: 0; border-radius: 999px; background: var(--color-surface-2); color: var(--color-text-secondary); } .points-mall-exchange-btn { border-radius: 12px; height: 34px; font-weight: 700; } .points-mall-filters-row { display: flex; justify-content: space-between; gap: 10px; flex-wrap: wrap; margin-bottom: 14px; } .points-mall-filters-left { display: flex; gap: 10px; flex-wrap: wrap; } .points-mall-total-text { font-size: 12.5px; color: var(--color-text-secondary); } .points-mall-exchange-modal-title { font-size: 20px; font-weight: 700; color: var(--color-text); margin-bottom: 8px; } .points-mall-exchange-modal-points { font-size: 24px; font-weight: 800; color: var(--color-brand); } .points-mall-address-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; } .points-exchange-form-item-small { margin-bottom: 16px; } /* Stats page inline styles fallback */ .stats-page-title { margin-bottom: 10px; } .stats-page-subtitle { margin-top: 0; font-size: 15px; line-height: 1.75; } .stats-page-mt-18 { margin-top: 18px; }