.login-overlay[data-v-fa0b717c]{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:#00000073;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.login-card[data-v-fa0b717c]{position:relative;width:380px;max-width:90vw;background:#fffffff2;border-radius:16px;padding:36px 32px 28px;box-shadow:0 20px 60px #00000026,0 0 0 1px #c5a05926}.login-card.shake[data-v-fa0b717c]{animation:shake-fa0b717c .4s ease-in-out}@keyframes shake-fa0b717c{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-5px)}80%{transform:translate(5px)}}.close-btn[data-v-fa0b717c]{position:absolute;top:12px;right:14px;width:28px;height:28px;border:none;background:none;font-size:16px;color:#999;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s}.close-btn[data-v-fa0b717c]:hover{background:#0000000f;color:#333}.login-header[data-v-fa0b717c]{text-align:center;margin-bottom:28px}.login-icon[data-v-fa0b717c]{display:inline-block;font-size:28px;margin-bottom:8px;color:var(--color-gold, #C5A059)}.login-title[data-v-fa0b717c]{font-size:20px;font-weight:700;color:#1a1a1a;margin:0 0 6px;letter-spacing:1px}.login-subtitle[data-v-fa0b717c]{font-size:13px;color:#888;margin:0}.login-form[data-v-fa0b717c]{display:flex;flex-direction:column;gap:18px}.form-group[data-v-fa0b717c]{display:flex;flex-direction:column;gap:6px}.form-group label[data-v-fa0b717c]{font-size:13px;font-weight:600;color:#555}.form-group input[data-v-fa0b717c]{padding:10px 14px;border:1.5px solid #e0dcd4;border-radius:10px;font-size:14px;color:#333;background:#faf9f7;transition:all .2s;outline:none}.form-group input[data-v-fa0b717c]:focus{border-color:var(--color-gold, #C5A059);box-shadow:0 0 0 3px #c5a05926;background:#fff}.form-group input[data-v-fa0b717c]:disabled{opacity:.6}.error-msg[data-v-fa0b717c]{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#fff5f5;border:1px solid #fecaca;border-radius:8px;font-size:13px;color:#dc2626}.error-icon[data-v-fa0b717c]{font-size:14px}.btn-login[data-v-fa0b717c]{padding:11px 0;border:none;border-radius:10px;background:linear-gradient(135deg,var(--color-gold, #C5A059),var(--color-gold-dark, #A8863C));color:#fff;font-size:15px;font-weight:600;letter-spacing:2px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;min-height:42px}.btn-login[data-v-fa0b717c]:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #c5a05966}.btn-login[data-v-fa0b717c]:disabled{opacity:.5;cursor:not-allowed}.spinner[data-v-fa0b717c]{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin-fa0b717c .6s linear infinite}@keyframes spin-fa0b717c{to{transform:rotate(360deg)}}.login-footer[data-v-fa0b717c]{margin-top:20px;text-align:center}.hint-text[data-v-fa0b717c]{font-size:12px;color:#aaa;margin:0}.hint-text code[data-v-fa0b717c]{background:#f0ede6;padding:1px 5px;border-radius:4px;font-size:11px;color:#666}.dialog-fade-enter-active[data-v-fa0b717c]{transition:opacity .25s ease}.dialog-fade-enter-active .login-card[data-v-fa0b717c]{transition:transform .25s ease,opacity .25s ease}.dialog-fade-leave-active[data-v-fa0b717c]{transition:opacity .2s ease}.dialog-fade-leave-active .login-card[data-v-fa0b717c]{transition:transform .2s ease,opacity .2s ease}.dialog-fade-enter-from[data-v-fa0b717c]{opacity:0}.dialog-fade-enter-from .login-card[data-v-fa0b717c]{transform:scale(.92) translateY(10px);opacity:0}.dialog-fade-leave-to[data-v-fa0b717c]{opacity:0}.dialog-fade-leave-to .login-card[data-v-fa0b717c]{transform:scale(.95);opacity:0}.error-fade-enter-active[data-v-fa0b717c],.error-fade-leave-active[data-v-fa0b717c]{transition:all .2s ease}.error-fade-enter-from[data-v-fa0b717c],.error-fade-leave-to[data-v-fa0b717c]{opacity:0;transform:translateY(-4px)}.app[data-v-45a43f53]{min-height:100vh;position:relative}.star-canvas[data-v-45a43f53]{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none;background:var(--gradient-starry);opacity:.06}.nav-bar[data-v-45a43f53]{position:fixed;top:0;left:0;right:0;height:var(--nav-height);z-index:1000;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-bottom:var(--glass-border);box-shadow:var(--shadow-nav)}.nav-inner[data-v-45a43f53]{max-width:var(--container-max);margin:0 auto;height:100%;display:flex;align-items:center;justify-content:space-between;padding:0 var(--container-padding)}.nav-brand[data-v-45a43f53]{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--color-text-primary)}.brand-icon[data-v-45a43f53]{font-size:24px;color:var(--color-gold);filter:drop-shadow(0 0 8px rgba(197,160,89,.4));animation:twinkle-45a43f53 3s ease-in-out infinite}@keyframes twinkle-45a43f53{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.brand-text[data-v-45a43f53]{display:flex;flex-direction:column;line-height:1.2}.brand-cn[data-v-45a43f53]{font-size:16px;font-weight:700;letter-spacing:2px;color:var(--color-text-primary)}.brand-en[data-v-45a43f53]{font-family:var(--font-en);font-size:11px;color:var(--color-gold);letter-spacing:1.5px;font-style:italic}.nav-links[data-v-45a43f53]{display:flex;align-items:center;gap:4px}.nav-link[data-v-45a43f53]{display:flex;align-items:center;gap:6px;padding:8px 18px;border-radius:var(--radius-button);font-size:14px;font-weight:600;color:var(--color-text-primary);text-decoration:none;text-shadow:0 1px 3px rgba(255,255,255,.6),0 0 8px rgba(249,248,246,.4);transition:all var(--transition-normal);position:relative}.nav-link[data-v-45a43f53]:hover{color:var(--color-gold);background:#c5a0591a}.nav-link.router-link-active[data-v-45a43f53]{color:var(--color-gold);background:#c5a05924;font-weight:600}.nav-icon-svg[data-v-45a43f53]{flex-shrink:0;opacity:.7}.nav-link:hover .nav-icon-svg[data-v-45a43f53],.nav-link.router-link-active .nav-icon-svg[data-v-45a43f53]{opacity:1;color:var(--color-gold)}.nav-admin[data-v-45a43f53]{opacity:.7;font-size:13px}.nav-right[data-v-45a43f53]{display:flex;align-items:center;gap:12px}.nav-user[data-v-45a43f53]{display:flex;align-items:center;gap:8px}.user-name[data-v-45a43f53]{font-size:13px;color:var(--color-text-secondary);font-weight:500}.user-avatar[data-v-45a43f53]{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--color-gold),var(--color-gold-dark));color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;box-shadow:0 2px 8px #c5a0594d}.guest-btn[data-v-45a43f53]{cursor:pointer;padding:6px 16px;border:1.5px solid var(--color-gold);border-radius:var(--radius-button);color:var(--color-gold);font-size:13px;font-weight:500;transition:all var(--transition-normal)}.guest-btn[data-v-45a43f53]:hover{background:var(--color-gold);color:#fff}.nav-user-wrap[data-v-45a43f53]{position:relative;display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 8px;border-radius:20px;transition:background .2s}.nav-user-wrap[data-v-45a43f53]:hover{background:#c5a05914}.user-dropdown[data-v-45a43f53]{position:absolute;top:calc(100% + 8px);right:0;width:220px;background:#fffffff7;border-radius:12px;box-shadow:0 8px 32px #0000001f,0 0 0 1px #c5a0591a;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);overflow:hidden;z-index:1001}.dropdown-header[data-v-45a43f53]{display:flex;align-items:center;gap:10px;padding:14px 16px}.dropdown-avatar[data-v-45a43f53]{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--color-gold),var(--color-gold-dark));color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;flex-shrink:0}.dropdown-info[data-v-45a43f53]{display:flex;flex-direction:column;gap:2px}.dropdown-name[data-v-45a43f53]{font-size:14px;font-weight:600;color:#1a1a1a}.dropdown-role[data-v-45a43f53]{font-size:11px;color:#999;padding:1px 6px;background:#f5f3ee;border-radius:4px;width:fit-content}.dropdown-divider[data-v-45a43f53]{height:1px;background:#f0ede6;margin:0 12px}.dropdown-item[data-v-45a43f53]{display:flex;align-items:center;gap:8px;padding:10px 16px;font-size:13px;color:#555;text-decoration:none;transition:all .15s;cursor:pointer;border:none;background:none;width:100%;text-align:left}.dropdown-item[data-v-45a43f53]:hover{background:#c5a05914;color:var(--color-gold-dark)}.logout-item[data-v-45a43f53]{color:#999}.logout-item[data-v-45a43f53]:hover{color:#dc2626;background:#fff5f5}.user-menu-overlay[data-v-45a43f53]{position:fixed;inset:0;z-index:1000}.dropdown-fade-enter-active[data-v-45a43f53]{transition:all .2s ease}.dropdown-fade-leave-active[data-v-45a43f53]{transition:all .15s ease}.dropdown-fade-enter-from[data-v-45a43f53]{opacity:0;transform:translateY(-6px) scale(.96)}.dropdown-fade-leave-to[data-v-45a43f53]{opacity:0;transform:translateY(-4px)}.hamburger[data-v-45a43f53]{display:none;flex-direction:column;gap:5px;padding:4px;cursor:pointer}.hamburger span[data-v-45a43f53]{display:block;width:22px;height:2px;background:var(--color-text-primary);border-radius:2px;transition:all var(--transition-fast)}.main-content[data-v-45a43f53]{padding-top:var(--nav-height);min-height:100vh;position:relative;z-index:1}.mobile-overlay[data-v-45a43f53]{display:none;position:fixed;inset:0;background:#0006;z-index:999}.bottom-tab-bar[data-v-45a43f53]{display:none}@media(max-width:768px){.hamburger[data-v-45a43f53]{display:flex}.nav-links[data-v-45a43f53]{position:fixed;top:var(--nav-height);right:-280px;width:280px;height:calc(100vh - var(--nav-height));background:var(--color-cream);flex-direction:column;align-items:stretch;padding:20px;gap:8px;transition:right var(--transition-normal);box-shadow:-4px 0 20px #0000001a;z-index:1001}.nav-links.mobile-open[data-v-45a43f53]{right:0}.nav-link[data-v-45a43f53]{padding:14px 18px;font-size:15px;border-radius:var(--radius-input)}.mobile-overlay[data-v-45a43f53]{display:block}.user-name[data-v-45a43f53]{display:none}.bottom-tab-bar[data-v-45a43f53]{display:flex;position:fixed;bottom:0;left:0;right:0;height:56px;background:var(--color-white);border-top:1px solid var(--color-border);align-items:center;justify-content:space-around;z-index:100;padding:0 4px;padding-bottom:env(safe-area-inset-bottom,0)}.tab-item[data-v-45a43f53]{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;flex:1;padding:6px 0;text-decoration:none;color:var(--color-text-muted);transition:color var(--transition-fast);-webkit-tap-highlight-color:transparent}.tab-item.active[data-v-45a43f53]{color:var(--color-gold)}.tab-icon[data-v-45a43f53]{width:22px;height:22px;transition:transform var(--transition-fast)}.tab-item.active .tab-icon[data-v-45a43f53]{transform:scale(1.1)}.tab-label[data-v-45a43f53]{font-size:10px;font-weight:500;line-height:1}.tab-item.active .tab-label[data-v-45a43f53]{font-weight:700}.main-content.has-bottom-tab[data-v-45a43f53]{padding-bottom:56px}}@media(max-width:480px){.brand-en[data-v-45a43f53]{display:none}.brand-cn[data-v-45a43f53]{font-size:15px}}:root{--color-cream: #F9F8F6;--color-amber: #F5EBD9;--color-gold: #C5A059;--color-gold-light: #D4B77A;--color-gold-dark: #A88A45;--color-text-primary: #2C2418;--color-text-secondary: #6B5D4F;--color-text-muted: #9B8E7E;--color-border: #E8E0D4;--color-white: #FFFFFF;--color-overlay: rgba(44, 36, 24, .5);--gradient-starry: linear-gradient(135deg, #0D0A1A 0%, #1A0E2E 40%, #12082B 70%, #0A0614 100%);--color-star-gold: #C5A059;--color-star-light: #D4B77A;--color-star-white: #FFFFFF;--color-soul: #FF8C42;--color-wisdom: #5B8DEF;--color-aesthetic: #9B72CF;--color-love: #E8739E;--color-life: #4CAF7A;--color-fate: #8B7355;--font-cn: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "PingFang SC", "Hiragino Sans GB", "Noto Sans SC", "Microsoft YaHei UI", "Microsoft YaHei", Arial, sans-serif;--font-en: "Playfair Display", "Georgia", serif;--font-system: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-serif: "Noto Serif SC", "Songti SC", "STSong", serif;--radius-tag: 4px;--radius-input: 8px;--radius-card: 16px;--radius-button: 9999px;--shadow-card: 0 4px 20px rgba(197, 160, 89, .08);--shadow-card-hover: 0 12px 32px rgba(197, 160, 89, .15);--shadow-nav: 0 2px 20px rgba(0, 0, 0, .08);--shadow-modal: 0 20px 60px rgba(0, 0, 0, .2);--glass-bg: rgba(249, 248, 246, .96);--glass-blur: blur(28px);--glass-border: 1px solid rgba(197, 160, 89, .18);--transition-fast: .2s cubic-bezier(.4, 0, .2, 1);--transition-normal: .3s cubic-bezier(.4, 0, .2, 1);--transition-slow: .5s cubic-bezier(.4, 0, .2, 1);--hover-lift: translateY(-8px);--hover-lift-sm: translateY(-3px);--nav-height: 64px;--sidebar-width: 300px;--container-max: 1200px;--container-padding: 24px}@media(max-width:768px){:root{--nav-height: 56px;--container-padding: 16px;--sidebar-width: 280px}}@media(max-width:480px){:root{--nav-height: 52px;--container-padding: 12px}}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-cn);color:var(--color-text-primary);background-color:var(--color-cream);line-height:1.7;min-height:100vh;overflow-x:hidden}a{color:var(--color-gold);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-gold-dark)}img{max-width:100%;display:block}button{font-family:inherit;cursor:pointer;border:none;outline:none;background:none}input,textarea,select{font-family:inherit;border:none;outline:none;background:none}ul,ol{list-style:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-gold-light);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-gold)}::selection{background:#c5a05940;color:var(--color-text-primary)}.container{max-width:var(--container-max);margin:0 auto;padding:0 var(--container-padding)}.font-en{font-family:var(--font-en)}.text-gold{color:var(--color-gold)}.text-muted{color:var(--color-text-muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 28px;border-radius:var(--radius-button);font-size:14px;font-weight:500;letter-spacing:.5px;transition:all var(--transition-normal);position:relative;overflow:hidden}.btn-primary{background:linear-gradient(135deg,var(--color-gold),var(--color-gold-dark));color:var(--color-white);box-shadow:0 4px 15px #c5a0594d}.btn-primary:hover{transform:var(--hover-lift-sm);box-shadow:0 8px 25px #c5a05966}.btn-outline{border:1.5px solid var(--color-gold);color:var(--color-gold);background:transparent}.btn-outline:hover{background:var(--color-gold);color:var(--color-white);transform:var(--hover-lift-sm)}.btn-ghost{color:var(--color-text-secondary);padding:8px 16px}.btn-ghost:hover{color:var(--color-gold);background:#c5a05914}.ripple{position:absolute;border-radius:50%;background:#c5a0594d;transform:scale(0);animation:ripple-animation .4s ease-out;pointer-events:none}@keyframes ripple-animation{to{transform:scale(4);opacity:0}}.card{background:var(--color-white);border-radius:var(--radius-card);box-shadow:var(--shadow-card);transition:all var(--transition-normal)}.card:hover{box-shadow:var(--shadow-card-hover)}.tag{display:inline-flex;align-items:center;padding:4px 12px;border-radius:var(--radius-tag);font-size:12px;font-weight:500;letter-spacing:.3px}.fade-in{animation:fadeIn .6s ease forwards}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.slide-in-left{animation:slideInLeft .4s ease forwards}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.page-enter-active,.page-leave-active{transition:all .3s ease}.page-enter-from{opacity:0;transform:translateY(10px)}.page-leave-to{opacity:0;transform:translateY(-10px)}@media(max-width:768px){html{font-size:14px}}@media(max-width:480px){.container{padding:0 12px}}
