@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Roboto+Mono:ital,wght@0,100..700;1,100..700&display=swap";.ds-fade-enter-active[data-v-7cf66871],.ds-fade-leave-active[data-v-7cf66871]{transition:opacity .15s ease,transform .15s ease}.ds-fade-enter-from[data-v-7cf66871],.ds-fade-leave-to[data-v-7cf66871]{opacity:0;transform:translateY(-8px)}.ds-fade-enter-to[data-v-7cf66871],.ds-fade-leave-from[data-v-7cf66871]{opacity:1;transform:translateY(0)}.app-layout[data-v-7cf66871]{display:flex;flex-direction:column;width:100%;height:100vh;overflow:hidden;background:var(--color-bg-page)}.app-topbar[data-v-7cf66871]{width:100%;height:var(--topbar-height);background:var(--color-bg-topbar);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-xl);flex-shrink:0;z-index:var(--z-topbar)}.topbar-left[data-v-7cf66871]{display:flex;align-items:center;position:relative}.logo-wrapper[data-v-7cf66871]{display:flex;align-items:center;gap:8px;cursor:pointer;padding:6px 10px;border-radius:var(--radius-md);transition:background .15s ease;-webkit-user-select:none;user-select:none}.logo-wrapper[data-v-7cf66871]:hover{background:var(--color-bg-hover)}.topbar-logo[data-v-7cf66871]{height:28px;width:auto;object-fit:contain}.topbar-brand[data-v-7cf66871]{font-size:15px;font-weight:600;color:var(--color-text-primary);letter-spacing:-.3px}.logo-arrow[data-v-7cf66871]{width:16px;height:16px;color:var(--color-text-secondary);transition:transform .2s ease;flex-shrink:0}.logo-arrow-open[data-v-7cf66871]{transform:rotate(180deg)}.logo-dropdown[data-v-7cf66871]{position:absolute;top:calc(100% + 6px);left:0;z-index:9999;animation:dropdown-in-7cf66871 .15s ease}@keyframes dropdown-in-7cf66871{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.logo-dropdown-arrow[data-v-7cf66871]{position:absolute;top:-5px;left:22px;width:10px;height:10px;background:var(--color-bg-card);border-left:1px solid var(--color-border);border-top:1px solid var(--color-border);transform:rotate(45deg);z-index:1}.logo-dropdown-inner[data-v-7cf66871]{position:relative;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;box-shadow:0 8px 30px #0000001f;padding:6px;min-width:168px}.logo-dropdown-item[data-v-7cf66871]{display:flex;align-items:center;gap:10px;width:100%;padding:9px 12px;border:none;background:transparent;color:var(--color-text-primary);font-size:13px;cursor:pointer;transition:background .12s ease;text-align:left;border-radius:8px}.logo-dropdown-item[data-v-7cf66871]:hover{background:var(--color-bg-hover)}.logo-dropdown-active[data-v-7cf66871]{background:var(--color-bg-hover);font-weight:600}.logo-dropdown-icon[data-v-7cf66871]{width:18px;height:18px;color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.logo-dropdown-active .logo-dropdown-icon[data-v-7cf66871]{color:var(--color-text-primary)}.logo-dropdown-icon[data-v-7cf66871] svg{width:100%;height:100%}.logo-dropdown-label[data-v-7cf66871]{white-space:nowrap}.logo-dropdown-divider[data-v-7cf66871]{height:1px;background:var(--color-border);margin:4px 8px}.logo-dropdown-danger[data-v-7cf66871],.logo-dropdown-danger .logo-dropdown-icon[data-v-7cf66871]{color:var(--color-danger)}.logo-dropdown-danger[data-v-7cf66871]:hover{background:var(--color-danger-light)}.topbar-center[data-v-7cf66871]{flex:1;display:flex;align-items:center;justify-content:center;min-width:0}.topbar-project-name[data-v-7cf66871]{border:none;border-bottom:1.5px solid transparent;background:transparent;text-align:center;font-size:14px;font-weight:500;color:var(--color-text-primary);padding:4px 12px;border-radius:0;outline:none;transition:border-color .15s ease;max-width:300px;width:100%}.topbar-project-name[data-v-7cf66871]:hover{border-bottom-color:var(--color-border)}.topbar-project-name[data-v-7cf66871]:focus{border-bottom-color:var(--color-text-primary)}.topbar-right[data-v-7cf66871]{display:flex;align-items:center;gap:var(--space-sm)}.topbar-icon-btn[data-v-7cf66871]{position:relative;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius-md);background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:all .15s ease}.topbar-icon-btn[data-v-7cf66871]:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.topbar-icon-btn svg[data-v-7cf66871]{width:20px;height:20px}.topbar-icon-badge[data-v-7cf66871]{position:absolute;top:2px;right:2px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:var(--color-text-secondary);color:var(--color-text-inverse);font-size:10px;font-weight:600;line-height:16px;text-align:center}.topbar-badge[data-v-7cf66871]{position:absolute;top:4px;right:4px;min-width:14px;height:14px;padding:0 4px;background:var(--color-danger);color:var(--color-text-inverse);font-size:10px;font-weight:600;line-height:14px;text-align:center;border-radius:7px}.user-wrapper[data-v-7cf66871]{position:relative}.topbar-user-btn[data-v-7cf66871]{width:32px;height:32px;padding:0;border:none;border-radius:50%;background:var(--color-bg-hover);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .15s}.topbar-user-btn[data-v-7cf66871]:hover{opacity:.8}.topbar-user-avatar[data-v-7cf66871]{width:32px;height:32px;border-radius:50%;background:var(--color-accent);color:var(--color-accent-text);font-size:13px;font-weight:600;display:flex;align-items:center;justify-content:center}.user-dropdown[data-v-7cf66871]{position:absolute;top:calc(100% + 8px);right:0;z-index:1000}.user-dropdown-arrow[data-v-7cf66871]{position:absolute;top:-6px;right:10px;width:12px;height:12px;background:var(--color-bg-card);border:1px solid var(--color-border);border-right:none;border-bottom:none;transform:rotate(45deg)}.user-dropdown-inner[data-v-7cf66871]{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg, 12px);box-shadow:0 4px 16px #00000014;padding:8px;min-width:180px}.user-dropdown-info[data-v-7cf66871]{display:flex;align-items:center;gap:10px;padding:8px}.user-dropdown-avatar[data-v-7cf66871]{width:36px;height:36px;border-radius:50%;background:var(--color-accent);color:var(--color-accent-text);font-size:14px;font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0}.user-dropdown-meta[data-v-7cf66871]{flex:1;min-width:0}.user-dropdown-name[data-v-7cf66871]{font-size:14px;font-weight:500;color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-dropdown-divider[data-v-7cf66871]{height:1px;background:var(--color-border);margin:4px 0}.user-dropdown-item[data-v-7cf66871]{width:100%;display:flex;align-items:center;gap:8px;padding:8px;border:none;border-radius:var(--radius-md, 8px);background:transparent;color:var(--color-text-primary);font-size:13px;cursor:pointer;transition:background .15s}.user-dropdown-item[data-v-7cf66871]:hover{background:var(--color-bg-hover)}.user-dropdown-logout[data-v-7cf66871]{color:var(--color-danger)}.user-dropdown-logout[data-v-7cf66871]:hover{background:var(--color-danger-light)}.changelog-wrapper[data-v-7cf66871]{position:relative}.changelog-dropdown[data-v-7cf66871]{position:absolute;top:calc(100% + 8px);right:0;z-index:1000}.changelog-dropdown-arrow[data-v-7cf66871]{position:absolute;top:-6px;right:12px;width:12px;height:12px;background:var(--color-bg-card);border:1px solid var(--color-border);border-right:none;border-bottom:none;transform:rotate(45deg)}.changelog-dropdown-inner[data-v-7cf66871]{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg, 12px);box-shadow:0 8px 32px #0000001f;width:340px;max-height:480px;overflow-y:auto}.changelog-header[data-v-7cf66871]{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid var(--color-border)}.changelog-title[data-v-7cf66871]{font-size:15px;font-weight:700;color:var(--color-text-primary)}.changelog-date[data-v-7cf66871]{font-size:12px;color:var(--color-text-secondary);background:var(--color-bg-hover);padding:2px 8px;border-radius:var(--radius-sm, 4px)}.changelog-body[data-v-7cf66871]{padding:8px 0}.changelog-section[data-v-7cf66871]{padding:8px 20px}.changelog-section+.changelog-section[data-v-7cf66871]{border-top:1px solid var(--color-border-light, rgba(0,0,0,.04))}.changelog-section-title[data-v-7cf66871]{font-size:13px;font-weight:600;color:var(--color-text-primary);margin-bottom:6px;display:flex;align-items:center;gap:6px}.changelog-section-title svg[data-v-7cf66871]{color:var(--color-accent);flex-shrink:0}.changelog-list[data-v-7cf66871]{margin:0;padding:0 0 0 16px;list-style:none}.changelog-list li[data-v-7cf66871]{position:relative;font-size:12px;line-height:1.6;color:var(--color-text-secondary);padding:2px 0}.changelog-list li[data-v-7cf66871]:before{content:"";position:absolute;left:-12px;top:9px;width:4px;height:4px;border-radius:50%;background:var(--color-accent)}.topbar-member-btn[data-v-7cf66871]{padding:7px 16px;font-size:13px;font-weight:500;color:var(--color-text-primary);background:var(--color-bg-hover);border:none;border-radius:20px;cursor:pointer;transition:all .15s ease;white-space:nowrap}.topbar-member-btn[data-v-7cf66871]:hover{background:var(--color-border-dark)}.app-body[data-v-7cf66871]{flex:1;min-height:0;display:flex}.app-sidebar[data-v-7cf66871]{width:var(--sidebar-width);flex-shrink:0;background:var(--color-bg-sidebar);border-right:1px solid var(--color-border);display:flex;flex-direction:column;align-items:center;padding:var(--space-lg) 0;z-index:var(--z-sidebar);overflow:visible}.sidebar-nav-top[data-v-7cf66871]{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1}.sidebar-nav-spacer[data-v-7cf66871]{flex:1}.sidebar-nav-bottom[data-v-7cf66871]{display:flex;flex-direction:column;align-items:center;gap:4px;padding-top:var(--space-md);border-top:1px solid var(--color-border);width:56px}.settings-fab-wrapper[data-v-7cf66871]{position:fixed;bottom:24px;right:24px;z-index:900}.settings-fab[data-v-7cf66871]{width:44px;height:44px;border-radius:50%;border:1px solid var(--color-border);background:var(--color-bg-card);color:var(--color-text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000001a;transition:background .15s,box-shadow .15s}.settings-fab[data-v-7cf66871]:hover{background:var(--color-bg-hover);box-shadow:0 4px 12px #00000026}.settings-fab svg[data-v-7cf66871]{width:22px;height:22px}.settings-fab-dropdown[data-v-7cf66871]{position:absolute;bottom:calc(100% + 8px);right:0;z-index:1000;filter:drop-shadow(0 4px 12px rgba(0,0,0,.12))}.settings-fab-arrow[data-v-7cf66871]{position:absolute;bottom:-6px;right:16px;width:12px;height:12px;background:var(--color-bg-card);border:1px solid var(--color-border);border-top:none;border-left:none;transform:rotate(45deg)}.settings-fab-inner[data-v-7cf66871]{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:8px;padding:4px;min-width:160px}.settings-fab-item[data-v-7cf66871]{display:flex;align-items:center;gap:10px;width:100%;padding:8px 12px;border:none;background:none;border-radius:6px;cursor:pointer;font-size:14px;color:var(--color-text-primary);transition:background .15s}.settings-fab-item[data-v-7cf66871]:hover{background:var(--color-bg-hover)}.settings-fab-icon[data-v-7cf66871]{width:18px;height:18px;flex-shrink:0;color:var(--color-text-secondary)}.settings-fab-icon[data-v-7cf66871] svg{width:100%;height:100%}.settings-fab-label[data-v-7cf66871]{white-space:nowrap}.sidebar-nav-item[data-v-7cf66871]{display:flex;flex-direction:column;align-items:center;justify-content:center;width:56px;height:56px;border:none;border-radius:10px;background:transparent;cursor:pointer;transition:all .15s ease;gap:3px}.sidebar-nav-item[data-v-7cf66871]:hover,.sidebar-nav-active[data-v-7cf66871]{background:var(--color-bg-hover)}.sidebar-nav-active .sidebar-nav-icon[data-v-7cf66871]{color:var(--color-text-primary)}.sidebar-nav-active .sidebar-nav-label[data-v-7cf66871]{color:var(--color-text-primary);font-weight:600}.sidebar-nav-icon[data-v-7cf66871]{width:22px;height:22px;color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center}.sidebar-nav-icon[data-v-7cf66871] svg{width:100%;height:100%}.sidebar-nav-label[data-v-7cf66871]{font-size:10px;color:var(--color-text-secondary);line-height:1;white-space:nowrap}.sidebar-miniapp-wrapper[data-v-7cf66871]{position:relative;display:flex;flex-direction:column;align-items:center}.miniapp-bubble[data-v-7cf66871]{position:absolute;left:calc(100% + 10px);bottom:-8px;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;box-shadow:0 8px 30px #0000001f;padding:var(--space-md);display:flex;flex-direction:column;align-items:center;z-index:9999;width:180px;animation:dropdown-in-7cf66871 .15s ease}.miniapp-bubble-arrow[data-v-7cf66871]{position:absolute;left:-5px;bottom:24px;width:10px;height:10px;background:var(--color-bg-card);border-left:1px solid var(--color-border);border-bottom:1px solid var(--color-border);transform:rotate(45deg)}.miniapp-bubble-img[data-v-7cf66871]{width:140px;height:140px;object-fit:contain;border-radius:8px;border:1px solid var(--color-border)}.miniapp-bubble-tip[data-v-7cf66871]{margin-top:8px;margin-bottom:0;font-size:12px;color:var(--color-text-secondary);text-align:center}.app-content[data-v-7cf66871]{flex:1;min-width:0;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;background:var(--color-bg-page)}.app-content-craft[data-v-7cf66871]{overflow:hidden}.topbar-user-avatar-img[data-v-7cf66871]{width:32px;height:32px;border-radius:50%;object-fit:cover}.user-dropdown-avatar-img[data-v-7cf66871]{width:40px;height:40px;border-radius:50%;object-fit:cover}.help-panel[data-v-7cf66871]{max-width:640px}.help-search[data-v-7cf66871]{position:relative;margin:0 0 20px}.help-search-icon[data-v-7cf66871]{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--color-text-tertiary)}.help-search-input[data-v-7cf66871]{width:100%;padding:10px 12px 10px 38px;border:1px solid var(--color-border);border-radius:8px;font-size:14px;outline:none;background:var(--color-bg-page);color:var(--color-text-primary);transition:border-color .15s}.help-search-input[data-v-7cf66871]:focus{border-color:var(--color-text-primary)}.help-section[data-v-7cf66871]{margin-bottom:24px}.help-section[data-v-7cf66871]:last-child{margin-bottom:0}.help-section-title[data-v-7cf66871]{font-size:14px;font-weight:600;color:var(--color-text-secondary);margin:0 0 12px;text-transform:uppercase;letter-spacing:.5px}.help-cards[data-v-7cf66871]{display:grid;grid-template-columns:1fr 1fr;gap:10px}.help-card[data-v-7cf66871]{padding:14px;border:1px solid var(--color-border);border-radius:8px;cursor:default;transition:border-color .15s,box-shadow .15s}.help-card[data-v-7cf66871]:hover{border-color:var(--color-text-secondary);box-shadow:0 2px 8px #0000000f}.help-card-title[data-v-7cf66871]{font-size:14px;font-weight:600;color:var(--color-text-primary);margin-bottom:6px}.help-card-desc[data-v-7cf66871]{font-size:12px;color:var(--color-text-secondary);line-height:1.5}.help-faq-list[data-v-7cf66871]{display:flex;flex-direction:column;gap:10px}.help-faq-item[data-v-7cf66871]{padding:14px;border:1px solid var(--color-border);border-radius:8px}.help-faq-q[data-v-7cf66871]{font-size:14px;font-weight:600;color:var(--color-text-primary);margin-bottom:6px}.help-faq-a[data-v-7cf66871]{font-size:13px;color:var(--color-text-secondary);line-height:1.6}.help-empty[data-v-7cf66871]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 0;color:var(--color-text-tertiary);gap:12px}.help-empty p[data-v-7cf66871]{margin:0;font-size:14px}.fb-modal[data-v-7cf66871]{max-width:440px}.fb-field[data-v-7cf66871]{margin-bottom:16px}.fb-label[data-v-7cf66871]{display:block;font-size:13px;font-weight:500;color:var(--color-text-primary);margin-bottom:8px}.fb-chips[data-v-7cf66871]{display:flex;gap:8px}.fb-chip[data-v-7cf66871]{padding:6px 14px;border:1px solid var(--color-border);border-radius:16px;background:var(--color-bg-card);font-size:13px;color:var(--color-text-secondary);cursor:pointer}.fb-chip-active[data-v-7cf66871]{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-light)}.fb-textarea[data-v-7cf66871]{width:100%;min-height:96px;resize:vertical;padding:10px 12px;border:1px solid var(--color-border);border-radius:8px;font-size:13px;color:var(--color-text-primary);box-sizing:border-box;font-family:inherit}.fb-input[data-v-7cf66871]{width:100%;padding:10px 12px;border:1px solid var(--color-border);border-radius:8px;font-size:13px;color:var(--color-text-primary);box-sizing:border-box}.fb-textarea[data-v-7cf66871]:focus,.fb-input[data-v-7cf66871]:focus{outline:none;border-color:var(--color-accent)}.fb-counter[data-v-7cf66871]{margin-top:6px;text-align:right;font-size:12px;color:var(--color-text-tertiary)}.login-standalone[data-v-dd948414]{width:100%;height:100vh;display:flex;flex-direction:column}.app-view[data-v-dd948414]{flex:1;min-height:0;display:flex;flex-direction:column}.ds-modal-lg[data-v-dd948414]{max-width:75rem;max-height:90vh}.ds-modal-body[data-v-dd948414]{background:var(--color-bg-page)}:root{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent;--g-brand-50: rgb(255 190 92 / .1);--g-brand-100: rgb(255 190 92 / .15);--g-brand-150: rgb(255 190 92 / .2);--g-brand-200: rgb(255 190 92 / .3);--g-brand-250: rgb(255 190 92 / .4);--g-brand-300: rgb(255 190 92 / .5);--g-brand-350: rgb(255 190 92 / .6);--g-brand-400: rgb(255 190 92 / .7);--g-brand-450: rgb(255 190 92 / .8);--g-brand-500: rgb(255 190 92 / .9);--g-brand-550: rgb(255 190 92);--g-brand-solid-50: rgb(255 249 239);--g-brand-solid-100: rgb(255 245 231);--g-brand-solid-150: rgb(255 242 222);--g-brand-solid-200: rgb(255 236 206);--g-brand-solid-250: rgb(255 229 190);--g-brand-solid-300: rgb(255 223 174);--g-brand-solid-350: rgb(255 216 157);--g-brand-solid-400: rgb(255 210 141);--g-brand-solid-450: rgb(255 203 125);--g-brand-solid-500: rgb(255 197 108);--g-brand-solid-550: rgb(255 190 92);--g-brand-solid-600: rgb(233 174 86);--g-brand-solid-650: rgb(211 158 80);--g-brand-solid-700: rgb(189 142 75);--g-brand-solid-750: rgb(167 126 69);--g-brand-solid-800: rgb(145 110 63);--g-brand-solid-850: rgb(122 93 57);--g-brand-solid-900: rgb(100 77 51);--g-brand-solid-950: rgb(78 61 46);--g-brand-solid-1000: rgb(67 53 43);--color-text-primary: #1A1A1A;--color-text-secondary: #888888;--color-text-placeholder: #BBBBBB;--color-text-inverse: #FFFFFF;--color-text-brand: var(--g-brand-solid-700);--color-text-link: var(--g-brand-solid-600);--color-text-link-hover: var(--g-brand-solid-800);--color-bg-page: #FFFFFF;--color-bg-card: #FFFFFF;--color-bg-sidebar: #FAFAFA;--color-bg-topbar: #FFFFFF;--color-bg-hover: #F5F5F5;--color-bg-active: #EEEEEE;--color-bg-overlay: rgba(0, 0, 0, .45);--color-bg-mask: rgba(0, 0, 0, .3);--color-bg-brand: var(--g-brand-solid-550);--color-bg-brand-hover: var(--g-brand-solid-600);--color-bg-brand-light: var(--g-brand-solid-100);--color-bg-selection: var(--g-brand-200);--color-bg-selection-hover: var(--g-brand-300);--color-border: #EEEEEE;--color-border-light: #F5F5F5;--color-border-dark: #DDDDDD;--color-divider: #EEEEEE;--color-line-brand: var(--g-brand-solid-600);--color-accent: var(--g-brand-solid-550);--color-accent-hover: var(--g-brand-solid-600);--color-accent-active: var(--g-brand-solid-650);--color-accent-light: var(--g-brand-solid-100);--color-accent-text: var(--g-brand-solid-1000);--color-danger: #E53935;--color-danger-hover: #C62828;--color-danger-light: #FFF0F0;--color-danger-border: #FECACA;--color-success: #43A047;--color-success-hover: #2E7D32;--color-success-light: #F0FFF0;--color-success-border: #BBF7D0;--color-warning: #FB8C00;--color-warning-hover: #E65100;--color-warning-light: #FFF8E1;--color-info: #1E88E5;--color-info-light: #E3F2FD;--color-shadow: rgba(0, 0, 0, .15);--color-like: #E53935;--color-favorite: #FB8C00;--color-tag-bg: var(--g-brand-solid-550);--color-tag-text: var(--g-brand-solid-1000);--space-xs: 4px;--space-sm: 8px;--space-md: 12px;--space-lg: 16px;--space-xl: 20px;--space-2xl: 24px;--space-3xl: 32px;--space-4xl: 40px;--space-5xl: 48px;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Microsoft YaHei", "Helvetica Neue", Arial, sans-serif;--font-family-monospace: "Roboto Mono", "Monaco", "Consolas", "Liberation Mono", monospace;--font-size-xs: 12px;--font-size-sm: 13px;--font-size-base: 14px;--font-size-md: 15px;--font-size-lg: 16px;--font-size-xl: 18px;--font-size-2xl: 20px;--font-size-3xl: 24px;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.65;--radius-xs: 4px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 20px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px rgba(0, 0, 0, .05), 0 2px 4px rgba(0, 0, 0, .04);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .06), 0 4px 6px rgba(0, 0, 0, .04);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .08), 0 8px 10px rgba(0, 0, 0, .04);--sidebar-width: 72px;--sidebar-width-collapsed: 72px;--sidebar-width-expanded: 200px;--topbar-height: 56px;--content-max-width: 1440px;--content-padding: 24px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;--transition-spring: .3s cubic-bezier(.4, 0, .2, 1);--z-sidebar: 100;--z-topbar: 110;--z-dropdown: 200;--z-overlay: 300;--z-modal: 400;--z-toast: 500;--z-tooltip: 600}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--color-text-primary);background:var(--color-bg-page)}button,input,textarea,select{font:inherit;color:inherit}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}ul,ol{list-style:none}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-inverse{color:var(--color-text-inverse)}.text-danger{color:var(--color-danger)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-info{color:var(--color-info)}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-base{font-size:var(--font-size-base)}.text-md{font-size:var(--font-size-md)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-2xl{font-size:var(--font-size-2xl)}.text-3xl{font-size:var(--font-size-3xl)}.font-regular{font-weight:var(--font-weight-regular)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.flex{display:flex}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.gap-xs{gap:var(--space-xs)}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.gap-xl{gap:var(--space-xl)}.gap-2xl{gap:var(--space-2xl)}.w-full{width:100%}.h-full{height:100%}.min-h-screen{min-height:100vh}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.overflow-y-auto{overflow-y:auto}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.m-xs{margin:var(--space-xs)}.m-sm{margin:var(--space-sm)}.m-md{margin:var(--space-md)}.m-lg{margin:var(--space-lg)}.m-xl{margin:var(--space-xl)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mt-xl{margin-top:var(--space-xl)}.mt-2xl{margin-top:var(--space-2xl)}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.mb-xl{margin-bottom:var(--space-xl)}.ml-sm{margin-left:var(--space-sm)}.ml-md{margin-left:var(--space-md)}.mr-sm{margin-right:var(--space-sm)}.mr-md{margin-right:var(--space-md)}.p-xs{padding:var(--space-xs)}.p-sm{padding:var(--space-sm)}.p-md{padding:var(--space-md)}.p-lg{padding:var(--space-lg)}.p-xl{padding:var(--space-xl)}.p-2xl{padding:var(--space-2xl)}.px-sm{padding-left:var(--space-sm);padding-right:var(--space-sm)}.px-md{padding-left:var(--space-md);padding-right:var(--space-md)}.px-lg{padding-left:var(--space-lg);padding-right:var(--space-lg)}.px-xl{padding-left:var(--space-xl);padding-right:var(--space-xl)}.py-sm{padding-top:var(--space-sm);padding-bottom:var(--space-sm)}.py-md{padding-top:var(--space-md);padding-bottom:var(--space-md)}.py-lg{padding-top:var(--space-lg);padding-bottom:var(--space-lg)}.ds-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.ds-card-hover{transition:box-shadow var(--transition-normal),transform var(--transition-normal);cursor:pointer}.ds-card-hover:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.ds-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:8px 16px;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);line-height:1;border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;-webkit-user-select:none;user-select:none;outline:none}.ds-btn:active{transform:scale(.97)}.ds-btn-primary{background:var(--color-accent);color:var(--color-accent-text);border-color:var(--color-accent)}.ds-btn-primary:hover{background:var(--color-accent-hover);border-color:var(--color-accent-hover)}.ds-btn-secondary{background:var(--color-bg-card);color:var(--color-text-primary);border-color:var(--color-border)}.ds-btn-secondary:hover{background:var(--color-bg-hover);border-color:var(--color-border-dark)}.ds-btn-ghost{background:transparent;color:var(--color-text-secondary);border-color:transparent}.ds-btn-ghost:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.ds-btn-danger{background:var(--color-danger);color:var(--color-text-inverse);border-color:var(--color-danger)}.ds-btn-danger:hover{background:#c62828}.ds-btn-sm{padding:5px 12px;font-size:var(--font-size-sm);border-radius:var(--radius-sm)}.ds-btn-lg{padding:12px 24px;font-size:var(--font-size-md);border-radius:var(--radius-lg)}.ds-btn-icon{width:36px;height:36px;padding:0;border-radius:var(--radius-md)}.ds-btn-icon.ds-btn-sm{width:28px;height:28px}.ds-btn[disabled],.ds-btn.disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.ds-tag{display:inline-flex;align-items:center;padding:2px 8px;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border-radius:var(--radius-sm);line-height:1.5;white-space:nowrap}.ds-tag-dark{background:var(--color-tag-bg);color:var(--color-tag-text)}.ds-tag-light{background:var(--color-bg-active);color:var(--color-text-primary)}.ds-tag-outline{background:transparent;border:1px solid var(--color-border);color:var(--color-text-secondary)}.ds-input{width:100%;padding:8px 12px;font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--color-text-primary);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.ds-input::placeholder{color:var(--color-text-placeholder)}.ds-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #ffbe5c26}.ds-input-sm{padding:5px 10px;font-size:var(--font-size-sm)}.ds-avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-full);overflow:hidden;background:var(--color-bg-active);color:var(--color-text-secondary);font-weight:var(--font-weight-semibold);flex-shrink:0}.ds-avatar img{width:100%;height:100%;object-fit:cover}.ds-avatar-sm{width:24px;height:24px;font-size:10px}.ds-avatar-md{width:32px;height:32px;font-size:12px}.ds-avatar-lg{width:40px;height:40px;font-size:14px}.ds-avatar-xl{width:48px;height:48px;font-size:16px}.ds-divider{width:100%;height:1px;background:var(--color-divider);border:none}.ds-divider-vertical{width:1px;height:auto;align-self:stretch;background:var(--color-divider)}.ds-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-4xl) var(--space-2xl);text-align:center}.ds-empty-icon{font-size:40px;color:var(--color-text-placeholder);margin-bottom:var(--space-lg)}.ds-empty-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin-bottom:var(--space-sm)}.ds-empty-desc{font-size:var(--font-size-sm);color:var(--color-text-placeholder);max-width:320px}.ds-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#11182773;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--space-2xl);animation:ds-modal-mask-in .2s ease-out}@keyframes ds-modal-mask-in{0%{opacity:0}to{opacity:1}}.ds-modal{width:100%;max-width:720px;max-height:85vh;background:var(--color-bg-card);border-radius:20px;box-shadow:0 24px 64px #1118273d,0 2px 8px #11182714;display:flex;flex-direction:column;overflow:hidden;animation:ds-modal-in .28s cubic-bezier(.16,1,.3,1)}@keyframes ds-modal-in{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.ds-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:12px 24px;background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-accent-hover) 100%)}.ds-modal-header-text{display:flex;flex-direction:column;gap:4px;min-width:0}.ds-modal-title{font-size:19px;font-weight:800;color:var(--color-accent-text);letter-spacing:.01em;margin:0}.ds-modal-subtitle{font-size:12px;font-weight:500;color:var(--color-accent-text);opacity:.72}.ds-modal-close{flex-shrink:0;width:30px;height:30px;border:none;border-radius:50%;background:#ffffff38;color:var(--color-accent-text);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;line-height:1;transition:background .15s}.ds-modal-close:hover{background:#ffffff61;color:var(--color-accent-text)}.ds-modal-body{flex:1;overflow-y:auto;padding:20px 24px;background:var(--color-bg-sidebar)}.ds-modal-footer{display:flex;align-items:center;gap:10px;padding:16px 24px;background:var(--color-bg-card);border-top:1px solid var(--color-border-light)}.ds-modal-btn{flex:1;height:44px;border:none;border-radius:12px;font-size:14px;font-weight:700;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:6px}.ds-modal-btn.cancel{color:var(--color-text-primary);background:var(--color-bg-hover)}.ds-modal-btn.cancel:hover{background:var(--color-border-dark)}.ds-modal-btn.confirm{color:var(--color-accent-text);background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-accent-hover) 100%);box-shadow:0 6px 16px var(--color-accent-light)}.ds-modal-btn.confirm:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 20px var(--color-accent-light)}.ds-modal-btn.danger{color:var(--color-danger);background:var(--color-danger-light)}.ds-modal-btn.danger:hover{color:var(--color-text-inverse);background:var(--color-danger)}.ds-modal-btn:disabled{opacity:.55;cursor:not-allowed}.ds-toast{position:fixed;top:calc(var(--topbar-height) + var(--space-lg));left:50%;transform:translate(-50%);padding:10px 20px;background:var(--color-accent);color:var(--color-accent-text);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);box-shadow:var(--shadow-lg);z-index:var(--z-toast);pointer-events:none;animation:ds-toast-in .3s ease,ds-toast-out .3s ease 1.7s forwards}@keyframes ds-toast-in{0%{opacity:0;transform:translate(-50%) translateY(-8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes ds-toast-out{0%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(-8px)}}.ds-loading-mask{position:fixed;top:0;right:0;bottom:0;left:0;background:#ffffffd9;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);z-index:var(--z-overlay)}.ds-loading-spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-bg-brand);border-radius:var(--radius-full);animation:ds-spin .8s linear infinite}@keyframes ds-spin{to{transform:rotate(360deg)}}.ds-loading-text{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.ds-scrollbar::-webkit-scrollbar{width:6px;height:6px}.ds-scrollbar::-webkit-scrollbar-track{background:transparent}.ds-scrollbar::-webkit-scrollbar-thumb{background:var(--color-border-dark);border-radius:var(--radius-full)}.ds-scrollbar::-webkit-scrollbar-thumb:hover{background:var(--color-text-placeholder)}.ds-tabs{display:flex;align-items:center;gap:var(--space-xl);border-bottom:1px solid var(--color-divider)}.ds-tab{position:relative;padding:var(--space-md) 0;font-size:var(--font-size-base);font-weight:var(--font-weight-regular);color:var(--color-text-secondary);cursor:pointer;background:none;border:none;transition:color var(--transition-fast)}.ds-tab:hover{color:var(--color-text-primary)}.ds-tab-active{color:var(--color-text-primary);font-weight:var(--font-weight-semibold)}.ds-tab-active:after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--color-line-brand);border-radius:1px}.ds-stepper{display:inline-flex;align-items:center;gap:var(--space-sm)}.ds-stepper-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-card);color:var(--color-text-primary);cursor:pointer;font-size:var(--font-size-lg);transition:all var(--transition-fast)}.ds-stepper-btn:hover{background:var(--color-bg-hover);border-color:var(--color-border-dark)}.ds-stepper-value{min-width:40px;text-align:center;font-size:var(--font-size-base);font-weight:var(--font-weight-medium)}.ds-fade-enter-active,.ds-fade-leave-active{transition:opacity var(--transition-normal)}.ds-fade-enter-from,.ds-fade-leave-to{opacity:0}.ds-slide-up-enter-active,.ds-slide-up-leave-active{transition:all var(--transition-spring)}.ds-slide-up-enter-from,.ds-slide-up-leave-to{opacity:0;transform:translateY(12px)}.ds-scale-enter-active,.ds-scale-leave-active{transition:all var(--transition-spring)}.ds-scale-enter-from,.ds-scale-leave-to{opacity:0;transform:scale(.95)}.ds-grid{display:grid;gap:var(--space-lg)}.ds-grid-2{grid-template-columns:repeat(2,1fr)}.ds-grid-3{grid-template-columns:repeat(3,1fr)}.ds-grid-4{grid-template-columns:repeat(4,1fr)}.ds-grid-5{grid-template-columns:repeat(5,1fr)}@media (max-width: 1200px){.ds-grid-4{grid-template-columns:repeat(3,1fr)}.ds-grid-5{grid-template-columns:repeat(4,1fr)}}@media (max-width: 900px){.ds-grid-3,.ds-grid-4{grid-template-columns:repeat(2,1fr)}.ds-grid-5{grid-template-columns:repeat(3,1fr)}}@media (max-width: 600px){.ds-grid-2,.ds-grid-3,.ds-grid-4,.ds-grid-5{grid-template-columns:1fr}}html,body,#app{margin:0;height:100%}body{font-family:var(--font-family);background:var(--color-bg-page);color:var(--color-text-primary)}button,input,textarea{font:inherit}*{box-sizing:border-box}.toast-container{position:fixed;top:20px;left:50%;transform:translate(-50%);z-index:10000;display:flex;flex-direction:column;align-items:center;gap:12px;pointer-events:none}.toast{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;background:var(--color-bg-card, #fff);border:1px solid var(--color-border, #e5e7eb);border-radius:8px;box-shadow:0 4px 12px #00000026;font-size:14px;line-height:1.5;max-width:90vw;word-break:break-word;pointer-events:auto;cursor:pointer;opacity:0;transform:translateY(-20px);transition:all .3s cubic-bezier(.4,0,.2,1)}.toast-show{opacity:1;transform:translateY(0)}.toast-hide{opacity:0;transform:translateY(-20px)}.toast-icon{width:18px;height:18px;flex-shrink:0}.toast-message{color:var(--color-text-primary, #1f2937)}.toast-success{background:var(--color-success-bg, #ecfdf5);border-color:var(--color-success, #10b981)}.toast-success .toast-icon{color:var(--color-success, #10b981)}.toast-error{background:var(--color-danger-bg, #fef2f2);border-color:var(--color-danger, #ef4444)}.toast-error .toast-icon{color:var(--color-danger, #ef4444)}.toast-warning{background:var(--color-warning-bg, #fffbeb);border-color:var(--color-warning, #f59e0b)}.toast-warning .toast-icon{color:var(--color-warning, #f59e0b)}.toast-info{background:var(--color-info-bg, #eff6ff);border-color:var(--color-info, #3b82f6)}.toast-info .toast-icon{color:var(--color-info, #3b82f6)}@media (max-width: 640px){.toast{max-width:calc(100vw - 40px);font-size:13px;padding:10px 16px}}
