*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f4ede2;--surface:#faf7f2;--surface-2:#ede4d6;--primary:#bf5e3a;--primary-h:#a04d30;--primary-dim:rgba(191,94,58,.09);--primary-pale:#edd5c6;--text:#291710;--text-2:#7b5a4c;--muted:#ae9282;--border:#dacfc1;--shadow-sm:0 1px 4px rgba(80,40,20,.07),0 2px 12px rgba(80,40,20,.04);--shadow-md:0 4px 24px rgba(80,40,20,.11),0 1px 4px rgba(80,40,20,.06);--r-sm:8px;--r-md:14px;--r-lg:20px;--ease:cubic-bezier(0.4,0,0.2,1);--t:220ms}body,html{height:100%;background:var(--bg);color:var(--text);font-family:Outfit,system-ui,sans-serif;font-size:15px;line-height:1.65;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.page{min-height:100vh;max-width:1160px;margin:0 auto;padding:28px 32px 48px;display:flex;flex-direction:column}.header{margin-bottom:28px;padding-bottom:20px;border-bottom:1px solid var(--border);justify-content:space-between}.brand,.header{display:flex;align-items:center}.brand{gap:13px}.brand-mark{width:46px;height:46px;background:var(--primary);color:#faf7f2;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;border-radius:13px;box-shadow:0 3px 10px rgba(191,94,58,.35);flex-shrink:0;-webkit-user-select:none;-moz-user-select:none;user-select:none}.brand-mark,.brand-name{font-family:Sora,sans-serif;letter-spacing:-.3px}.brand-name{font-size:19px;font-weight:600;color:var(--text);line-height:1.25}.brand-sub{font-size:11px;color:var(--muted);font-weight:400;letter-spacing:1.1px;text-transform:uppercase;font-family:Outfit,sans-serif;margin-top:1px}.workspace{flex:1 1;display:grid;grid-template-columns:400px 1fr;grid-gap:20px;gap:20px;align-items:stretch}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:28px;box-shadow:var(--shadow-sm)}.control-panel,.panel{display:flex;flex-direction:column}.control-panel{position:relative;overflow:hidden;gap:22px}.loading-mask{position:absolute;inset:0;background:hsla(38,44%,96%,.93);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;z-index:30;border-radius:var(--r-lg);animation:mask-in .18s var(--ease) both}@keyframes mask-in{0%{opacity:0}to{opacity:1}}.mask-spinner{width:52px;height:52px;position:relative;flex-shrink:0}.mask-spinner:after,.mask-spinner:before{content:"";position:absolute;border-radius:50%;inset:0}.mask-spinner:before{border:3.5px solid var(--primary-pale)}.mask-spinner:after{border-left:3.5px solid transparent;border-bottom:3.5px solid transparent;border-top:3.5px solid transparent;border-top-color:var(--primary);border-right:3.5px solid rgba(191,94,58,.4);animation:spin .9s cubic-bezier(.5,.1,.5,.9) infinite}@keyframes spin{to{transform:rotate(1turn)}}.mask-label{font-family:Sora,sans-serif;font-size:14px;font-weight:500;color:var(--text-2);display:flex;align-items:baseline;gap:2px}.mask-dots{display:inline-flex;gap:1px}.mask-dots i{font-style:normal;animation:dot-fade 1.4s ease-in-out infinite both;opacity:0}.mask-dots i:first-child{animation-delay:0s}.mask-dots i:nth-child(2){animation-delay:.22s}.mask-dots i:nth-child(3){animation-delay:.44s}@keyframes dot-fade{0%,70%{opacity:0}35%{opacity:1}}.mask-elapsed{font-size:12px;color:var(--muted);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;letter-spacing:.3px}.field{display:flex;flex-direction:column;gap:9px}.field-label{font-family:Sora,sans-serif;font-size:11px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.9px;-webkit-user-select:none;-moz-user-select:none;user-select:none}.prompt-textarea{width:100%;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r-sm);padding:14px 16px;font-family:Outfit,sans-serif;font-size:14px;line-height:1.75;color:var(--text);resize:vertical;outline:none;min-height:140px;transition:border-color var(--t) var(--ease),box-shadow var(--t) var(--ease)}.prompt-textarea::placeholder{color:var(--muted)}.prompt-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3.5px rgba(191,94,58,.1)}.prompt-textarea:disabled{opacity:.55;cursor:not-allowed}.field-hint{font-size:11.5px;color:var(--muted);text-align:right}.ratio-row{display:flex;flex-wrap:wrap;gap:8px}.ratio-btn{flex:1 1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px 6px 11px;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r-sm);cursor:pointer;font-family:Outfit,sans-serif;font-size:11.5px;color:var(--text-2);transition:border-color var(--t) var(--ease),color var(--t) var(--ease),background var(--t) var(--ease)}.ratio-btn.active,.ratio-btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.ratio-btn.active{background:var(--primary-dim);font-weight:500}.ratio-btn:disabled{opacity:.45;cursor:not-allowed}.ratio-icon{display:block;background:currentColor;border-radius:3px;opacity:.3;flex-shrink:0;transition:opacity var(--t) var(--ease)}.ratio-btn.active .ratio-icon{opacity:.55}.ratio-text{font-feature-settings:"tnum";font-variant-numeric:tabular-nums;letter-spacing:.2px}.gen-btn{width:100%;padding:14.5px;background:var(--primary);color:#faf7f2;border:none;border-radius:var(--r-sm);font-family:Sora,sans-serif;font-size:15px;font-weight:600;letter-spacing:.5px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 2px 8px rgba(191,94,58,.28);transition:background var(--t) var(--ease),box-shadow var(--t) var(--ease),transform var(--t) var(--ease)}.gen-btn:hover:not(:disabled){background:var(--primary-h);box-shadow:0 5px 18px rgba(191,94,58,.4);transform:translateY(-1.5px)}.gen-btn:active:not(:disabled){transform:translateY(0)}.gen-btn:disabled{opacity:.38;cursor:not-allowed;box-shadow:none;transform:none}.gen-spinner{width:16px;height:16px;border:2px solid hsla(38,44%,96%,.3);border-top-color:hsla(38,44%,96%,.9);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}.output-panel{min-height:500px;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:16px}.output-main{flex:1 1;justify-content:center;min-height:280px}.img-container,.output-main{display:flex;align-items:center}.img-container{width:100%;flex-direction:column;gap:16px;animation:fade-up .3s var(--ease) both}@keyframes fade-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.img-refreshing{opacity:.55;pointer-events:none}.result-img{width:100%;height:auto;max-height:72vh;object-fit:contain;border-radius:var(--r-sm);box-shadow:var(--shadow-md);display:block}.output-toolbar{display:flex;justify-content:flex-end;margin-bottom:8px}.sidebar-toggle{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:var(--bg);border:1.5px solid var(--border);border-radius:999px;font-family:Outfit,sans-serif;font-size:12px;color:var(--text-2);cursor:pointer;transition:border-color var(--t) var(--ease),color var(--t) var(--ease),background var(--t) var(--ease)}.sidebar-toggle.active,.sidebar-toggle:hover{border-color:var(--primary);color:var(--primary)}.sidebar-toggle.active{background:var(--primary-dim);font-weight:500}.sidebar-badge{padding:1px 6px;background:var(--primary);color:#faf7f2;font-size:10px;font-weight:600;border-radius:999px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.history-sidebar{position:fixed;top:0;right:0;width:280px;height:100vh;background:var(--surface);border-left:1.5px solid var(--border);box-shadow:-4px 0 24px rgba(41,23,16,.12);z-index:150;display:flex;flex-direction:column;animation:slide-in-right .22s var(--ease) both}@keyframes slide-in-right{0%{opacity:0;transform:translateX(24px)}to{opacity:1;transform:translateX(0)}}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px}.sidebar-header,.sidebar-toolbar{border-bottom:1px solid var(--border);flex-shrink:0}.sidebar-toolbar{padding:10px 18px}.sidebar-select-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.sidebar-tool-btn{padding:4px 10px;background:var(--bg);border:1px solid var(--border);border-radius:var(--r-sm);font-size:12px;color:var(--muted);cursor:pointer;transition:all var(--t) var(--ease)}.sidebar-tool-btn:hover{border-color:var(--primary);color:var(--primary)}.sidebar-select-count{margin-left:auto;font-size:12px;color:var(--muted)}.sidebar-download-row{display:flex;gap:8px}.sidebar-download-btn{flex:1 1;padding:7px 0;background:var(--primary);color:#faf7f2;border:none;border-radius:var(--r-sm);font-family:Sora,sans-serif;font-size:12px;font-weight:600;cursor:pointer;transition:background var(--t) var(--ease)}.sidebar-download-btn:hover{background:var(--primary-h)}.sidebar-download-btn:disabled{background:#b8a99a;cursor:not-allowed}.sidebar-title{font-family:Sora,sans-serif;font-size:14px;font-weight:600;color:var(--text)}.sidebar-close{width:28px;height:28px;background:none;border:none;color:var(--muted);font-size:20px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:color var(--t) var(--ease),background var(--t) var(--ease)}.sidebar-close:hover{color:var(--text);background:var(--bg)}.sidebar-body{flex:1 1;overflow-y:auto;padding:16px 18px}.sidebar-empty{text-align:center;font-size:13px;color:var(--muted);padding:40px 0}.sidebar-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:10px;gap:10px}.sidebar-thumb{position:relative;aspect-ratio:1;border:1.5px solid var(--border);border-radius:var(--r-sm);overflow:hidden;background:var(--bg);transition:border-color var(--t) var(--ease),transform var(--t) var(--ease)}.sidebar-thumb.selected{border-color:var(--primary);box-shadow:0 0 0 3px rgba(191,94,58,.2)}.sidebar-thumb:hover{border-color:var(--primary);transform:translateY(-2px)}.sidebar-thumb img{width:100%;height:100%;object-fit:cover;display:block}.sidebar-thumb-img-btn{width:100%;height:100%;padding:0;border:none;background:none;cursor:pointer}.sidebar-checkbox{position:absolute;top:6px;left:6px;width:18px;height:18px;z-index:2;accent-color:var(--primary);cursor:pointer}.sidebar-thumb-ratio{position:absolute;bottom:4px;right:4px;padding:1px 5px;background:rgba(41,23,16,.55);color:#faf7f2;font-size:9px;font-weight:500;border-radius:3px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;pointer-events:none}.profile-avatar-wrap{position:relative;width:52px;height:52px;flex-shrink:0}.profile-avatar-img{width:52px;height:52px;border-radius:50%;object-fit:cover;display:block}.avatar-upload-btn{position:absolute;bottom:-2px;right:-2px;width:20px;height:20px;background:var(--primary);color:#faf7f2;border:2px solid var(--surface);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--t) var(--ease)}.avatar-upload-btn:hover{background:var(--primary-h)}.empty-state{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;padding:40px 20px}.empty-icon{width:60px;height:60px;color:var(--muted);opacity:.45}.empty-title{font-family:Sora,sans-serif;font-size:15px;font-weight:500;color:var(--text-2)}.empty-sub{font-size:13px;color:var(--muted)}.output-loading{display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;padding:40px 20px}.paint-ring{width:64px;height:64px;border-radius:50%;background:conic-gradient(from 0deg,var(--primary) 0deg 130deg,rgba(191,94,58,.12) 130deg 1turn);animation:spin 1.15s linear infinite;position:relative;flex-shrink:0}.paint-ring:after{content:"";position:absolute;inset:8px;background:var(--surface);border-radius:50%}.ol-title{font-family:Sora,sans-serif;font-size:14px;font-weight:500;color:var(--text-2)}.ol-elapsed{font-size:12px;color:var(--muted);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;margin-top:-6px}.error-state{flex-direction:column;gap:10px;text-align:center;max-width:320px;padding:32px 20px}.error-badge,.error-state{display:flex;align-items:center}.error-badge{width:46px;height:46px;background:#fbf0ec;border:1.5px solid var(--primary-pale);color:var(--primary);border-radius:50%;font-size:20px;font-weight:700;justify-content:center;flex-shrink:0}.error-badge,.error-title{font-family:Sora,sans-serif}.error-title{font-size:15px;font-weight:600;color:var(--text)}.error-msg{font-size:13px;color:var(--text-2);line-height:1.6;word-break:break-word}.retry-btn{margin-top:6px;padding:7px 24px;background:var(--primary);color:#faf7f2;border:none;border-radius:999px;font-family:Outfit,sans-serif;font-size:13px;font-weight:500;cursor:pointer;transition:background var(--t) var(--ease)}.retry-btn:hover{background:var(--primary-h)}.user-bar{gap:10px}.user-bar,.user-info{display:flex;align-items:center}.user-info{gap:8px;padding:5px 12px 5px 5px;background:var(--surface-2);border:1.5px solid var(--border);border-radius:999px;cursor:pointer;transition:border-color var(--t) var(--ease),background var(--t) var(--ease)}.user-info:hover{border-color:var(--primary);background:var(--primary-dim)}.user-avatar{color:#faf7f2;font-family:Sora,sans-serif;font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:center}.user-avatar,.user-avatar-img{width:30px;height:30px;border-radius:50%;flex-shrink:0}.user-avatar-img{object-fit:cover}.user-name{font-size:13px;font-weight:500;color:var(--text);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.balance-badge{padding:4px 10px;background:var(--primary-dim);color:var(--primary);font-size:12px;font-weight:600;border-radius:999px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.recharge-mini{padding:4px 12px;background:var(--primary);color:#faf7f2;border:none;border-radius:999px;font-family:Outfit,sans-serif;font-size:12px;font-weight:500;cursor:pointer;transition:background var(--t) var(--ease)}.recharge-mini:hover{background:var(--primary-h)}.logout-btn{padding:4px 12px;background:transparent;border:1.5px solid var(--border);border-radius:999px;font-family:Outfit,sans-serif;font-size:12px;color:var(--text-2);cursor:pointer;transition:border-color var(--t) var(--ease),color var(--t) var(--ease)}.logout-btn:hover{border-color:var(--primary);color:var(--primary)}.auth-trigger{padding:9px 22px;background:var(--primary);color:#faf7f2;border:none;border-radius:999px;font-family:Sora,sans-serif;font-size:13px;font-weight:600;cursor:pointer;box-shadow:0 2px 8px rgba(191,94,58,.22);transition:background var(--t) var(--ease),box-shadow var(--t) var(--ease)}.auth-trigger:hover{background:var(--primary-h);box-shadow:0 4px 14px rgba(191,94,58,.32)}.price-tag{text-align:center;font-size:12px;color:var(--muted);margin-top:-4px}.price-free{color:var(--primary);font-weight:500}.modal-overlay{position:fixed;inset:0;background:rgba(41,23,16,.45);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:200;padding:20px;animation:fade-in .18s var(--ease) both}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-lg);padding:28px;width:100%;max-width:400px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-md);position:relative;animation:slide-up .22s var(--ease) both}@keyframes slide-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.modal-close{position:absolute;top:14px;right:16px;width:30px;height:30px;background:none;border:none;color:var(--muted);font-size:22px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:color var(--t) var(--ease),background var(--t) var(--ease)}.modal-close:hover{color:var(--text);background:var(--bg)}.modal-tabs{display:flex;gap:0;margin-bottom:20px;border-bottom:1.5px solid var(--border)}.modal-tab{flex:1 1;padding:10px 0 12px;background:none;border:none;font-family:Sora,sans-serif;font-size:14px;font-weight:500;color:var(--muted);cursor:pointer;position:relative;transition:color var(--t) var(--ease)}.modal-tab.active{color:var(--primary);font-weight:600}.modal-tab.active:after{content:"";position:absolute;bottom:-1.5px;left:20%;right:20%;height:2.5px;background:var(--primary);border-radius:2px}.modal-title{font-family:Sora,sans-serif;font-size:17px;font-weight:600;color:var(--text);margin-bottom:18px;text-align:center}.modal-form{gap:14px}.modal-field,.modal-form{display:flex;flex-direction:column}.modal-field{gap:6px}.modal-label{font-size:12px;font-weight:500;color:var(--text-2)}.modal-input{width:100%;padding:11px 14px;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r-sm);font-family:Outfit,sans-serif;font-size:14px;color:var(--text);outline:none;transition:border-color var(--t) var(--ease),box-shadow var(--t) var(--ease)}.modal-input:focus{border-color:var(--primary);box-shadow:0 0 0 3.5px rgba(191,94,58,.1)}.modal-input::placeholder{color:var(--muted)}textarea.modal-input{resize:vertical;min-height:70px}.code-row{display:flex;gap:8px}.code-input{flex:1 1;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;letter-spacing:2px;text-align:center}.code-send-btn{padding:0 16px;background:var(--primary);color:#faf7f2;border:none;border-radius:var(--r-sm);font-family:Outfit,sans-serif;font-size:13px;font-weight:500;cursor:pointer;white-space:nowrap;flex-shrink:0;box-shadow:0 2px 8px rgba(191,94,58,.22);transition:background var(--t) var(--ease),box-shadow var(--t) var(--ease)}.code-send-btn:hover{background:var(--primary-h);box-shadow:0 4px 14px rgba(191,94,58,.32)}.code-send-btn:disabled{background:#b8a99a;color:#faf7f2;cursor:not-allowed;box-shadow:none}.code-send-btn.sending{position:relative;padding-left:30px}.code-send-btn.sending:before{content:"";position:absolute;left:10px;top:50%;transform:translateY(-50%);width:12px;height:12px;border:2px solid hsla(38,44%,96%,.3);border-top-color:#faf7f2;border-radius:50%;animation:spin .7s linear infinite}.modal-submit{width:100%;padding:13px;background:var(--primary);color:#faf7f2;border:none;border-radius:var(--r-sm);font-family:Sora,sans-serif;font-size:14px;font-weight:600;cursor:pointer;margin-top:4px;box-shadow:0 2px 8px rgba(191,94,58,.24);transition:background var(--t) var(--ease),box-shadow var(--t) var(--ease)}.modal-submit:hover{background:var(--primary-h);box-shadow:0 4px 14px rgba(191,94,58,.34)}.qr-panel{display:flex;flex-direction:column;align-items:center;gap:16px;padding:8px 0 4px}.qr-img{width:220px;height:220px;border-radius:var(--r-sm);border:2px solid var(--border);object-fit:contain}.qr-link-box{text-align:center;padding:16px;background:#f4ede2;border-radius:var(--r-sm);width:100%}.qr-link-label{margin:0 0 8px;font-size:13px;color:var(--muted)}.qr-link{font-size:12px;color:var(--primary);word-break:break-all;text-decoration:underline}.qr-order{margin:0;font-size:12px;color:var(--muted);font-family:Sora,monospace}.modal-error{font-size:13px;margin-bottom:10px}.modal-error,.modal-fee-note{color:var(--primary);text-align:center}.modal-fee-note{font-size:11px;margin:-6px 0 2px;opacity:.85}.modal-note{font-size:12px;color:var(--muted);text-align:center;margin-top:-4px}.profile-preview{display:flex;align-items:center;gap:14px;margin-bottom:18px;padding-bottom:18px;border-bottom:1px solid var(--border)}.profile-avatar-lg{width:52px;height:52px;border-radius:50%;color:#faf7f2;font-family:Sora,sans-serif;font-size:20px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.profile-meta{display:flex;flex-direction:column;gap:2px}.profile-username{font-family:Sora,sans-serif;font-size:15px;font-weight:600;color:var(--text)}.profile-email{font-size:12px;color:var(--muted)}.profile-stats{display:flex;gap:12px;margin-bottom:18px}.profile-stat{flex:1 1;text-align:center;padding:10px;background:var(--bg);border-radius:var(--r-sm)}.profile-stat-num{display:block;font-family:Sora,sans-serif;font-size:16px;font-weight:700;color:var(--primary);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.profile-stat-label{font-size:11px;color:var(--muted)}.color-picker{display:flex;gap:8px;flex-wrap:wrap}.color-dot{width:28px;height:28px;border-radius:50%;border:2.5px solid transparent;cursor:pointer;transition:transform var(--t) var(--ease),border-color var(--t) var(--ease)}.color-dot:hover{transform:scale(1.1)}.color-dot.active{border-color:var(--text);transform:scale(1.12)}.alipay-badge{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px;background:var(--bg);border:1.5px dashed var(--border);border-radius:var(--r-sm);font-size:12px;color:var(--text-2)}.amount-presets{display:flex;gap:8px;margin-bottom:8px}.amount-preset{flex:1 1;padding:8px 0;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r-sm);font-family:Outfit,sans-serif;font-size:13px;color:var(--text-2);cursor:pointer;transition:border-color var(--t) var(--ease),color var(--t) var(--ease),background var(--t) var(--ease)}.amount-preset.active,.amount-preset:hover{border-color:var(--primary)}.amount-preset.active{background:var(--primary-dim);color:var(--primary);font-weight:500}.paytype-row{display:flex;gap:8px}.paytype-btn{flex:1 1;padding:9px 0;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r-sm);font-family:Outfit,sans-serif;font-size:12.5px;color:var(--text-2);cursor:pointer;transition:border-color var(--t) var(--ease),color var(--t) var(--ease),background var(--t) var(--ease)}.paytype-btn.active,.paytype-btn:hover{border-color:var(--primary)}.paytype-btn.active{background:var(--primary-dim);color:var(--primary);font-weight:500}.tx-modal{max-width:420px}.tx-balance{display:flex;flex-direction:column;align-items:center;gap:2px;padding:16px;background:var(--primary-dim);border:1.5px solid var(--primary-pale);border-radius:var(--r-sm);margin-bottom:16px}.tx-balance-label{font-size:12px;color:var(--text-2)}.tx-balance-value{font-family:Sora,sans-serif;font-size:24px;font-weight:700;color:var(--primary);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.tx-list{display:flex;flex-direction:column;gap:8px;max-height:340px;overflow-y:auto;padding-right:4px}.tx-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--bg);border-radius:var(--r-sm);border-left:3px solid var(--border)}.tx-recharge{border-left-color:#5ebf8d}.tx-expense{border-left-color:var(--primary)}.tx-left{display:flex;flex-direction:column;gap:2px}.tx-desc{font-size:13px;font-weight:500;color:var(--text)}.tx-time{font-size:11px;color:var(--muted)}.tx-right{display:flex;flex-direction:column;align-items:flex-end;gap:1px}.tx-amount{font-family:Sora,sans-serif;font-size:14px;font-weight:600;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.tx-recharge .tx-amount{color:#5ebf8d}.tx-expense .tx-amount{color:var(--primary)}.tx-balance-after{font-size:11px;color:var(--muted)}.tx-empty{text-align:center;font-size:13px;color:var(--muted);padding:20px}.toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%);padding:11px 28px;border-radius:999px;font-size:13.5px;font-weight:500;z-index:300;box-shadow:var(--shadow-md);animation:toast-in .3s var(--ease) both}@keyframes toast-in{0%{opacity:0;transform:translateX(-50%) translateY(12px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.toast-success{background:#5ebf8d;color:#fff}.toast-error{background:var(--primary);color:#faf7f2}.footer{margin-top:auto;padding-top:32px;padding-bottom:8px;border-top:1px solid var(--border)}.footer-inner{justify-content:center;gap:14px;flex-wrap:wrap}.footer-brand,.footer-inner{display:flex;align-items:center}.footer-brand{gap:7px}.footer-mark{width:20px;height:20px;background:var(--primary);color:#faf7f2;font-size:8px;font-weight:700;display:flex;align-items:center;justify-content:center;border-radius:5px;flex-shrink:0}.footer-mark,.footer-name{font-family:Sora,sans-serif}.footer-name{font-size:13px;font-weight:600;color:var(--text)}.footer-divider{width:3px;height:3px;border-radius:50%;background:var(--muted);opacity:.5;flex-shrink:0}.footer-copy,.footer-url{font-size:12px;color:var(--muted)}.footer-url{font-feature-settings:"tnum";font-variant-numeric:tabular-nums}@media (max-width:840px){.page{padding:16px 16px 32px}.workspace{grid-template-columns:1fr}.output-panel{min-height:320px}.user-bar{gap:6px}.user-name{display:none}.logout-btn{padding:4px 8px;font-size:11px}}@media (max-width:480px){.ratio-btn{padding:10px 4px 9px}.brand-mark{width:40px;height:40px;font-size:11px;border-radius:11px}.brand-name{font-size:17px}.auth-trigger{padding:7px 14px;font-size:12px}.recharge-mini{display:none}.modal-card{padding:22px 18px;border-radius:var(--r-md)}.history-sidebar{width:240px}}