:root,[data-theme=midnight]{--bg: #0F1424;--bg-deep: #0A0F1C;--bg-soft: #1A2138;--bg-card: #161C2F;--bg-card-hover: #1E2640;--bg-elev: #232B47;--ink: #F2EEE3;--ink-mid: #B4B7C9;--ink-soft: #7A809A;--ink-faint: #4D5474;--accent: #FF8C42;--accent-deep: #FF6B1A;--accent-soft: #FFB380;--accent-glow: rgba(255, 140, 66, .25);--silver: #C9D4F0;--silver-soft: #8B96B8;--silver-bg: rgba(201, 212, 240, .08);--gold: #E8C170;--gold-bg: rgba(232, 193, 112, .12);--rose: #D7798F;--rose-bg: rgba(215, 121, 143, .12);--line: rgba(201, 212, 240, .08);--line-strong: rgba(201, 212, 240, .15);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow: 0 8px 24px rgba(0, 0, 0, .35);--shadow-lg: 0 20px 50px rgba(0, 0, 0, .45);--shadow-glow: 0 8px 30px var(--accent-glow);--grad-hero: radial-gradient(at 20% 10%, rgba(255, 140, 66, .18) 0, transparent 50%), radial-gradient(at 85% 90%, rgba(201, 212, 240, .1) 0, transparent 50%), linear-gradient(180deg, #131830 0%, #0F1424 100%);--grad-accent: linear-gradient(135deg, #FF8C42 0%, #FF6B1A 100%);--grad-soul: linear-gradient(135deg, #2A2D5A 0%, #1A2138 100%);--grad-ambient: radial-gradient(900px 620px at 10% -6%, rgba(255,140,66,.12), transparent 58%), radial-gradient(820px 700px at 112% 6%, rgba(120,150,255,.1), transparent 58%), radial-gradient(700px 800px at 50% 122%, rgba(255,140,66,.06), transparent 60%)}[data-theme=warm]{--bg: #FCF2E2;--bg-deep: #F4E4C9;--bg-soft: #FFF9EF;--bg-card: #FFFDFA;--bg-card-hover: #FFF6E9;--bg-elev: #FFFFFF;--ink: #3A2916;--ink-mid: #785F44;--ink-soft: #A78F6C;--ink-faint: #CDB896;--accent: #E5752B;--accent-deep: #C5541A;--accent-soft: #F6AB66;--accent-glow: rgba(229, 117, 43, .24);--silver: #8C7A5C;--silver-soft: #B6A483;--silver-bg: rgba(140, 122, 92, .08);--gold: #D29A30;--gold-bg: rgba(210, 154, 48, .16);--rose: #DC6F5C;--rose-bg: rgba(220, 111, 92, .12);--line: rgba(92, 64, 34, .1);--line-strong: rgba(92, 64, 34, .18);--shadow-sm: 0 1px 3px rgba(150, 96, 40, .1);--shadow: 0 10px 30px rgba(180, 110, 45, .16);--shadow-lg: 0 24px 56px rgba(180, 110, 45, .22);--shadow-glow: 0 10px 36px var(--accent-glow);--grad-hero: radial-gradient(at 8% -4%, rgba(255, 176, 102, .62) 0, transparent 46%), radial-gradient(at 96% 6%, rgba(255, 150, 120, .46) 0, transparent 44%), radial-gradient(at 50% 116%, rgba(255, 206, 130, .5) 0, transparent 56%), linear-gradient(165deg, #FFF7EB 0%, #FCEDD7 48%, #F6DEBE 100%);--grad-accent: linear-gradient(135deg, #F89A3E 0%, #E5752B 52%, #D2541C 100%);--grad-soul: linear-gradient(135deg, #FDEFD6 0%, #F6DCB6 100%);--grad-ambient: radial-gradient(940px 640px at 8% -8%, rgba(255, 178, 108, .55), transparent 56%), radial-gradient(780px 620px at 110% 4%, rgba(255, 146, 116, .42), transparent 54%), radial-gradient(960px 820px at 50% 122%, rgba(255, 208, 138, .46), transparent 60%)}:root{--font-display: "Fraunces", "Noto Serif SC", Georgia, serif;--font-body: "Plus Jakarta Sans", "Noto Serif SC", -apple-system, BlinkMacSystemFont, sans-serif;--font-serif-zh: "Noto Serif SC", "Songti SC", "宋体", serif;--radius-xs: 6px;--radius-sm: 10px;--radius: 16px;--radius-lg: 24px;--radius-xl: 32px;--radius-pill: 999px;--ease-out: cubic-bezier(.22, 1, .36, 1);--ease-spring: cubic-bezier(.34, 1.45, .4, 1);--ease-smooth: cubic-bezier(.4, 0, .2, 1);--dur-fast: .18s;--dur: .3s;--dur-slow: .55s}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{height:100%;background:var(--bg);color:var(--ink);font-family:var(--font-body);font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior-y:none;transition:background-color .5s ease,color .5s ease}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;background:var(--grad-ambient);opacity:1;transition:background .6s ease}#root{min-height:100vh;display:flex;flex-direction:column;overflow-x:hidden}button{font:inherit;color:inherit;background:none;border:none;cursor:pointer;touch-action:manipulation}a{touch-action:manipulation}html{scroll-behavior:smooth}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}::selection{background:var(--accent);color:#fff}input,textarea,select{font:inherit;color:inherit;outline:none}a{color:inherit;text-decoration:none}.container{width:100%;max-width:560px;margin:0 auto;padding:0 22px}@media (min-width: 480px){.container{padding:0 28px}}.page{padding:8px 0 100px;min-height:100dvh;position:relative}.display{font-family:var(--font-display);font-weight:400;letter-spacing:-.02em;line-height:1.1}.display-xxl{font-size:clamp(40px,11vw,56px);font-weight:300}.display-xl{font-size:clamp(32px,8vw,42px)}.display-lg{font-size:clamp(26px,6.5vw,32px)}.display-md{font-size:clamp(20px,5vw,24px)}.display-sm{font-size:18px}.serif-zh{font-family:var(--font-serif-zh)}.label-mini{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-soft);font-weight:500}.label-tiny{font-size:11px;letter-spacing:.15em;color:var(--ink-soft)}.text-mid{color:var(--ink-mid)}.text-soft{color:var(--ink-soft)}.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 22px;border-radius:var(--radius);font-size:15px;font-weight:500;transition:transform var(--dur) var(--ease-spring),background .2s,box-shadow .25s,opacity .2s,filter .2s;white-space:nowrap;-webkit-user-select:none;user-select:none;overflow:hidden}.btn:active:not(:disabled){transform:scale(.96);transition-duration:var(--dur-fast)}.btn-primary{background:var(--grad-accent);color:#fff;box-shadow:var(--shadow-glow)}.btn-primary:after{content:"";position:absolute;top:0;bottom:0;width:46%;left:-60%;background:linear-gradient(105deg,transparent,rgba(255,255,255,.35),transparent);transform:skew(-18deg);animation:btnSheen 4.2s var(--ease-smooth) infinite;pointer-events:none}@keyframes btnSheen{0%,64%{left:-60%}to{left:130%}}.btn-primary:hover:not(:disabled){filter:brightness(1.08);box-shadow:var(--shadow-glow),0 6px 20px var(--accent-glow);transform:translateY(-1px)}.btn-primary:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.btn-ghost{background:var(--bg-soft);color:var(--ink)}.btn-ghost:hover:not(:disabled){background:var(--bg-elev)}.btn-outline{border:1px solid var(--line-strong);color:var(--ink);background:transparent}.btn-outline:hover:not(:disabled){background:var(--bg-soft);border-color:var(--ink-soft)}.btn-block{width:100%}.btn-lg{padding:17px 28px;font-size:16px}.btn-sm{padding:10px 16px;font-size:13px;border-radius:var(--radius-sm)}.card{background:var(--bg-card);border-radius:var(--radius-lg);padding:22px;border:1px solid var(--line)}.card-elev{background:var(--bg-elev);border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow)}.input{width:100%;padding:16px 18px;background:var(--bg-soft);border:1.5px solid transparent;border-radius:var(--radius);font-size:16px;color:var(--ink);transition:all .2s}.input:focus{border-color:var(--accent);background:var(--bg-elev);box-shadow:0 0 0 4px var(--accent-glow)}.input::placeholder{color:var(--ink-faint)}.textarea{width:100%;padding:18px;background:var(--bg-soft);border:1.5px solid transparent;border-radius:var(--radius);font-size:15px;line-height:1.75;color:var(--ink);resize:vertical;min-height:140px;font-family:var(--font-serif-zh);transition:all .2s}.textarea:focus{border-color:var(--accent);background:var(--bg-elev);box-shadow:0 0 0 4px var(--accent-glow)}.textarea::placeholder{color:var(--ink-faint)}.tag{display:inline-flex;align-items:center;gap:5px;padding:5px 11px;border-radius:var(--radius-pill);font-size:11px;font-weight:500;background:var(--bg-soft);color:var(--ink-mid);letter-spacing:.02em}.tag-accent{background:var(--accent-glow);color:var(--accent)}.tag-gold{background:var(--gold-bg);color:var(--gold)}.tag-silver{background:var(--silver-bg);color:var(--silver)}.divider{height:1px;background:var(--line);margin:24px 0}.divider-ornament{display:flex;align-items:center;gap:14px;margin:28px 0 22px;color:var(--ink-soft);font-size:10px;letter-spacing:.4em;text-transform:uppercase}.divider-ornament:before,.divider-ornament:after{content:"";flex:1;height:1px;background:var(--line)}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes pulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.4)}}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.fade-up{animation:fadeUp .6s var(--ease-out) both}.fade-in{animation:fadeIn .5s both}.scale-in{animation:scaleIn .4s var(--ease-out) both}.stagger>*{animation:fadeUp .55s var(--ease-out) both}.stagger>*:nth-child(1){animation-delay:.04s}.stagger>*:nth-child(2){animation-delay:.1s}.stagger>*:nth-child(3){animation-delay:.16s}.stagger>*:nth-child(4){animation-delay:.22s}.stagger>*:nth-child(5){animation-delay:.28s}.stagger>*:nth-child(6){animation-delay:.34s}.stagger>*:nth-child(7){animation-delay:.4s}.stagger>*:nth-child(8){animation-delay:.46s}.stagger>*:nth-child(9){animation-delay:.52s}.stagger>*:nth-child(10){animation-delay:.58s}.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out);will-change:opacity,transform}.reveal.in{opacity:1;transform:none}.reveal-stagger>*{opacity:0;transform:translateY(18px);transition:opacity .55s var(--ease-out),transform .55s var(--ease-out)}.reveal-stagger.in>*{opacity:1;transform:none}.reveal-stagger.in>*:nth-child(1){transition-delay:.03s}.reveal-stagger.in>*:nth-child(2){transition-delay:.09s}.reveal-stagger.in>*:nth-child(3){transition-delay:.15s}.reveal-stagger.in>*:nth-child(4){transition-delay:.21s}.reveal-stagger.in>*:nth-child(5){transition-delay:.27s}.reveal-stagger.in>*:nth-child(6){transition-delay:.33s}.reveal-stagger.in>*:nth-child(7){transition-delay:.39s}.reveal-stagger.in>*:nth-child(8){transition-delay:.45s}.reveal-stagger.in>*:nth-child(9){transition-delay:.51s}.reveal-stagger.in>*:nth-child(10){transition-delay:.57s}.route-view{animation:routeIn .35s var(--ease-out) both}@keyframes routeIn{0%{opacity:0}to{opacity:1}}.has-tabbar{padding-bottom:calc(64px + env(safe-area-inset-bottom,0px))}.skeleton{position:relative;overflow:hidden;background:var(--bg-soft);border-radius:var(--radius-sm)}.skeleton:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,var(--bg-elev),transparent);background-size:200% 100%;animation:shimmer 1.4s linear infinite}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.reveal,.reveal-stagger>*{opacity:1;transform:none}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:200;animation:fadeIn .25s;display:flex;align-items:flex-end;justify-content:center}.modal{width:100%;max-width:480px;background:var(--bg-card);border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:24px 22px calc(32px + env(safe-area-inset-bottom,0px));border-top:1px solid var(--line);animation:sheetUp .45s var(--ease-spring);max-height:90dvh;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}@keyframes sheetUp{0%{opacity:.4;transform:translateY(60%)}to{opacity:1;transform:translateY(0)}}.modal-handle{width:40px;height:4px;background:var(--line-strong);border-radius:999px;margin:0 auto 18px}.modal-title{font-family:var(--font-display);font-size:22px;margin-bottom:8px;color:var(--ink)}.modal-desc{font-size:13px;color:var(--ink-soft);line-height:1.7;margin-bottom:20px}@media (min-width: 600px){.modal-backdrop{align-items:center}.modal{border-radius:var(--radius-xl);border-top:none;border:1px solid var(--line)}}.error-msg{background:var(--accent-glow);color:var(--accent);padding:11px 14px;border-radius:var(--radius);font-size:13px;margin-bottom:14px;border:1px solid var(--accent-glow)}.spin{display:inline-block;width:16px;height:16px;border:2px solid var(--ink-faint);border-top-color:var(--accent);border-radius:50%;animation:rotate .7s linear infinite}.scroll-x{display:flex;gap:12px;overflow-x:auto;scroll-snap-type:x mandatory;-ms-overflow-style:none;scrollbar-width:none;padding:4px 22px;margin:0 -22px}.scroll-x::-webkit-scrollbar{display:none}@supports (padding: max(0px)){.page{padding-bottom:max(100px,env(safe-area-inset-bottom))}}
