:root{--bg: #FBF8F3;--surface: #FFFFFF;--surface-2: #F4ECDF;--ink: #1F1A14;--ink-muted: #7A7268;--ink-soft: #A39B91;--border: #ECE2D0;--border-strong: #D8CCB6;--accent: #D04A1C;--accent-hover: #B23E16;--accent-soft: #FCE5D3;--accent-ink: #FFFFFF;--success: #0F7A3F;--success-soft: #E1F4E8;--warn: #B45309;--warn-soft: #FEF3C7;--danger: #B91C1C;--danger-soft: #FEE2E2;--r-sm: 8px;--r-md: 12px;--r-lg: 16px;--r-xl: 24px;--r-full: 999px;--s-1: 4px;--s-2: 8px;--s-3: 12px;--s-4: 16px;--s-5: 20px;--s-6: 24px;--s-8: 32px;--s-10: 40px;--s-12: 48px;--shadow-sm: 0 1px 2px rgba(31, 26, 20, .04);--shadow-md: 0 4px 12px rgba(31, 26, 20, .06), 0 1px 2px rgba(31, 26, 20, .04);--shadow-lg: 0 12px 32px rgba(31, 26, 20, .1), 0 2px 4px rgba(31, 26, 20, .04);--ease: cubic-bezier(.2, .8, .2, 1);--t-fast: .12s var(--ease);--t-base: .2s var(--ease);--t-slow: .32s var(--ease)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;text-rendering:optimizeLegibility}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit;color:inherit}img{display:block;max-width:100%}.app-shell{display:flex;flex-direction:column;min-height:100%;padding-bottom:calc(72px + env(safe-area-inset-bottom,0))}.brand{font-size:1rem;font-weight:700;letter-spacing:-.01em;padding:var(--s-4) var(--s-4) var(--s-2);color:var(--ink)}.container{max-width:520px;margin:0 auto;padding:var(--s-4);width:100%}.stack>*+*{margin-top:var(--s-3)}.stack-lg>*+*{margin-top:var(--s-5)}.row{display:flex;gap:var(--s-3);align-items:center}.row.wrap{flex-wrap:wrap}.between{display:flex;justify-content:space-between;align-items:center;gap:var(--s-3)}.center{display:flex;align-items:center;justify-content:center}.text-center{text-align:center}.muted{color:var(--ink-muted)}.soft{color:var(--ink-soft)}.full{width:100%}.h1{font-size:1.625rem;font-weight:700;letter-spacing:-.02em;line-height:1.2;margin:0}.h2{font-size:1.25rem;font-weight:700;letter-spacing:-.015em;line-height:1.25;margin:0}.h3{font-size:1rem;font-weight:600;letter-spacing:-.01em;line-height:1.3;margin:0}.eyebrow{font-size:.7rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-muted)}.body{font-size:.95rem;line-height:1.5}.body-sm{font-size:.85rem;line-height:1.5}.mono{font-family:ui-monospace,SF Mono,Menlo,monospace}.num{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);display:flex;justify-content:space-around;padding:6px 0 calc(6px + env(safe-area-inset-bottom,0));-webkit-backdrop-filter:saturate(180%) blur(20px);backdrop-filter:saturate(180%) blur(20px);z-index:20}.bottom-nav a{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 4px;color:var(--ink-soft);font-size:.72rem;font-weight:500;transition:color var(--t-fast)}.bottom-nav a.active{color:var(--accent)}.bottom-nav a .nav-ico{width:24px;height:24px;display:flex;align-items:center;justify-content:center}.bottom-nav a svg{width:22px;height:22px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--s-4)}.card-tight{padding:var(--s-3)}.card-loose{padding:var(--s-6)}.card-elev{box-shadow:var(--shadow-md);border-color:transparent}.card-accent{background:var(--accent-soft);border-color:transparent}label.label{display:block;font-size:.78rem;font-weight:600;color:var(--ink-muted);margin-bottom:var(--s-1);letter-spacing:.01em}.field{margin-bottom:var(--s-3)}input,textarea,select{width:100%;padding:12px 14px;border:1px solid var(--border-strong);border-radius:var(--r-md);background:var(--surface);color:var(--ink);font-size:16px;transition:border-color var(--t-fast),box-shadow var(--t-fast)}input::placeholder,textarea::placeholder{color:var(--ink-soft)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.input-lg{font-size:1rem;padding:14px 16px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 18px;border:1px solid transparent;border-radius:var(--r-md);background:var(--surface);color:var(--ink);font-weight:600;font-size:.95rem;cursor:pointer;transition:background var(--t-fast),border-color var(--t-fast),transform var(--t-fast);min-height:44px;text-decoration:none;-webkit-user-select:none;user-select:none}.btn:hover{background:var(--surface-2)}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.primary{background:var(--accent);color:var(--accent-ink)}.btn.primary:hover{background:var(--accent-hover)}.btn.subtle{background:var(--surface-2);color:var(--ink)}.btn.outline{background:transparent;border-color:var(--border-strong)}.btn.ghost{background:transparent}.btn.danger{color:var(--danger);border-color:var(--danger-soft);background:transparent}.btn.block{width:100%}.btn.lg{padding:14px 20px;min-height:52px;font-size:1rem}.btn.sm{padding:8px 12px;min-height:36px;font-size:.85rem}.action-bar{position:sticky;bottom:0;margin:var(--s-4) calc(-1 * var(--s-4)) calc(-1 * var(--s-4));padding:var(--s-3) var(--s-4) calc(var(--s-3) + env(safe-area-inset-bottom,0));background:linear-gradient(to top,var(--bg) 70%,transparent)}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:var(--r-full);background:var(--surface-2);color:var(--ink-muted);font-size:.75rem;font-weight:600;letter-spacing:.01em}.badge.success{background:var(--success-soft);color:var(--success)}.badge.warn{background:var(--warn-soft);color:var(--warn)}.badge.accent{background:var(--accent-soft);color:var(--accent)}.badge.solid{background:var(--ink);color:var(--bg)}.list-row{display:flex;align-items:center;gap:var(--s-3);padding:14px 0;border-bottom:1px solid var(--border);color:inherit;text-decoration:none;transition:background var(--t-fast)}.list-row:last-child{border-bottom:none}.list-row:hover{background:var(--surface-2)}.list-row .meta{flex:1;min-width:0}.list-row .meta .title{font-weight:600;color:var(--ink)}.list-row .meta .sub{color:var(--ink-muted);font-size:.8rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logo{width:44px;height:44px;flex-shrink:0;border-radius:var(--r-md);background:var(--surface-2);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--ink-muted);overflow:hidden;font-size:1.05rem}.logo img{width:100%;height:100%;object-fit:cover}.logo.lg{width:72px;height:72px;border-radius:var(--r-lg);font-size:1.6rem}.progress{height:6px;background:var(--surface-2);border-radius:var(--r-full);overflow:hidden}.progress>div{height:100%;background:var(--accent);transition:width var(--t-slow)}.qr-card{background:var(--surface);border-radius:var(--r-xl);padding:var(--s-6);display:flex;flex-direction:column;align-items:center;box-shadow:var(--shadow-md)}.qr-card svg{display:block}.otp-card{background:var(--ink);color:var(--bg);border-radius:var(--r-lg);padding:var(--s-4) var(--s-5);text-align:center}.otp-card .otp-label{color:var(--ink-soft);font-size:.7rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase}.otp-card .otp-code{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:2.1rem;font-weight:700;letter-spacing:.18em;margin:6px 0 2px}.otp-card .otp-meta{color:var(--ink-soft);font-size:.8rem}.scope-toggle{display:flex;background:var(--surface-2);border-radius:var(--r-full);padding:3px}.scope-pill{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;cursor:pointer;padding:8px 14px;border-radius:var(--r-full);background:transparent;font-weight:600;font-size:.85rem;color:var(--ink-muted);transition:all var(--t-fast)}.scope-pill.active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}.chip-row{display:flex;gap:6px;overflow-x:auto;margin:var(--s-2) calc(-1 * var(--s-4)) 0;padding:0 var(--s-4) 4px;scrollbar-width:none}.chip-row::-webkit-scrollbar{display:none}.chip{flex-shrink:0;padding:7px 14px;border:1px solid var(--border-strong);border-radius:var(--r-full);background:var(--surface);font-size:.83rem;font-weight:500;cursor:pointer;white-space:nowrap;color:var(--ink-muted);transition:all var(--t-fast)}.chip.active{background:var(--ink);color:var(--bg);border-color:var(--ink)}.alert{padding:12px 14px;border-radius:var(--r-md);font-size:.9rem;display:flex;align-items:flex-start;gap:10px}.alert.error{background:var(--danger-soft);color:var(--danger)}.alert.success{background:var(--success-soft);color:var(--success)}.alert.info{background:var(--accent-soft);color:var(--accent-hover)}.spinner{display:inline-block;width:18px;height:18px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:spin .7s linear infinite;opacity:.6}@keyframes spin{to{transform:rotate(360deg)}}.empty{text-align:center;padding:var(--s-8) var(--s-4)}.empty .empty-ico{width:56px;height:56px;margin:0 auto var(--s-3);background:var(--surface-2);border-radius:var(--r-full);display:flex;align-items:center;justify-content:center;color:var(--ink-soft);font-size:1.6rem}.empty h3{margin-bottom:6px}.empty p{color:var(--ink-muted);margin:0 0 var(--s-4)}.stepper{display:flex;gap:4px;padding:0 var(--s-4);margin-bottom:var(--s-5)}.stepper .step{flex:1;height:3px;border-radius:var(--r-full);background:var(--border);transition:background var(--t-base)}.stepper .step.done,.stepper .step.current{background:var(--accent)}.toast-host{position:fixed;left:0;right:0;bottom:calc(88px + env(safe-area-inset-bottom,0));display:flex;justify-content:center;pointer-events:none;z-index:30}.toast{pointer-events:auto;background:var(--ink);color:var(--bg);padding:12px 16px;border-radius:var(--r-md);box-shadow:var(--shadow-lg);font-size:.9rem;font-weight:500;animation:toastIn var(--t-slow);max-width:calc(100vw - 32px)}@keyframes toastIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.avatar{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:50%;overflow:hidden;background:var(--surface-2);color:var(--ink-muted);font-weight:700}.avatar img{width:100%;height:100%;display:block;object-fit:cover}.avatar-initial{background:var(--surface-2);color:var(--ink-muted)}.avatar-tabs{display:inline-flex;background:var(--surface-2);border-radius:var(--r-full);padding:3px;margin-bottom:var(--s-3)}.avatar-tab{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:transparent;cursor:pointer;padding:7px 18px;border-radius:var(--r-full);font-weight:600;font-size:.88rem;color:var(--ink-muted);transition:all var(--t-fast)}.avatar-tab.active{background:var(--ink);color:var(--bg);box-shadow:var(--shadow-sm)}.avatar-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--s-2)}.avatar-choice{border:2px solid transparent;background:transparent;border-radius:var(--r-lg);padding:6px;cursor:pointer;transition:background var(--t-fast),border-color var(--t-fast);display:flex;align-items:center;justify-content:center;aspect-ratio:1 / 1}.avatar-choice .avatar{width:100%!important;height:100%!important}.avatar-choice:hover{background:var(--surface-2)}.avatar-choice.selected{border-color:var(--accent);background:var(--accent-soft)}.myqr-identity{display:flex;align-items:center;gap:var(--s-3);padding:var(--s-3) var(--s-4);border-radius:var(--r-lg);background:var(--surface);border:1px solid var(--border);color:inherit;text-decoration:none;transition:transform var(--t-fast),box-shadow var(--t-fast)}.myqr-identity:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.bottom-nav a .nav-ico.nav-avatar{width:22px;height:22px;padding:0}.bottom-nav a .nav-ico.nav-avatar .avatar{width:22px!important;height:22px!important;border-radius:50%!important}.profile-hero{display:flex;flex-direction:column;align-items:center;gap:var(--s-2);padding:var(--s-6) var(--s-4);text-align:center}.profile-avatar-button{position:relative;background:transparent;border:none;padding:0;cursor:pointer;margin-bottom:var(--s-2);border-radius:50%}.profile-avatar-button:hover .profile-avatar-edit{opacity:1}.profile-avatar-edit{position:absolute;bottom:-4px;left:50%;transform:translate(-50%);background:var(--ink);color:var(--bg);font-size:.7rem;font-weight:700;padding:4px 10px;border-radius:var(--r-full);opacity:0;transition:opacity var(--t-fast);letter-spacing:.04em;text-transform:uppercase}.stat-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(72px,1fr));gap:4px;padding:var(--s-3);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);color:inherit;text-decoration:none;transition:transform var(--t-fast),box-shadow var(--t-fast)}.stat-strip:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.stat-strip-item{text-align:center;padding:6px 4px;border-radius:var(--r-sm)}.stat-strip-item.streak{background:linear-gradient(135deg,#fce5d3,#ffd7b5)}.stat-strip-num{font-size:1.05rem;font-weight:700;letter-spacing:-.01em;color:var(--ink)}.stat-strip-label{font-size:.68rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-soft);margin-top:2px}.balance-card{position:relative;transition:transform var(--t-fast)}.balance-card.has-value{border-color:var(--accent-soft)}.balance-card.ready{background:linear-gradient(135deg,#fff7ee,#fce5d3);border-color:transparent;box-shadow:0 0 0 1px var(--accent-soft),var(--shadow-md);animation:readyGlow 2.4s ease-in-out infinite}@keyframes readyGlow{0%,to{box-shadow:0 0 0 1px var(--accent-soft),var(--shadow-md)}50%{box-shadow:0 0 0 3px var(--accent-soft),0 8px 24px #d04a1c2e}}.balance-card.almost{animation:almostPulse 2s ease-in-out infinite}@keyframes almostPulse{0%,to{transform:scale(1)}50%{transform:scale(1.012)}}.progress.ready>div{background:linear-gradient(90deg,var(--accent),#F0A867,var(--accent));background-size:200% 100%;animation:shimmerBar 2.4s linear infinite}@keyframes shimmerBar{0%{background-position:0% 0}to{background-position:-200% 0}}.badge.celebration{background:linear-gradient(135deg,var(--accent),#E26A38);color:var(--accent-ink);font-weight:700;box-shadow:0 2px 8px #d04a1c4d;animation:trophyBob 2s ease-in-out infinite}@keyframes trophyBob{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}.trophy-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-3)}.trophy-stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--s-4) var(--s-3);text-align:center}.trophy-stat-num{font-size:1.5rem;font-weight:800;letter-spacing:-.02em;color:var(--accent);font-variant-numeric:tabular-nums}.trophy-stat-label{font-size:.72rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-muted);margin-top:4px}.ach-card{display:flex;gap:var(--s-3);align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--s-3) var(--s-4);opacity:.72;transition:opacity var(--t-base),border-color var(--t-base)}.ach-card.unlocked{opacity:1;border-color:var(--accent-soft);background:linear-gradient(135deg,var(--surface),#FFF7EE)}.ach-ico{width:44px;height:44px;flex-shrink:0;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;background:var(--surface-2);color:var(--ink-soft);font-size:1.4rem;font-weight:700}.ach-card.unlocked .ach-ico{background:linear-gradient(135deg,var(--accent),#E26A38);color:var(--accent-ink);box-shadow:0 4px 12px #d04a1c40}.ach-meta{flex:1;min-width:0}.ach-title{font-weight:700}.ach-desc{color:var(--ink-muted);font-size:.85rem;margin-top:2px}.ach-status{font-size:.78rem;font-weight:600;margin-top:6px;color:var(--accent)}.ach-card:not(.unlocked) .ach-status{color:var(--ink-muted)}.ach-progress{height:4px;background:var(--surface-2);border-radius:var(--r-full);overflow:hidden;margin-top:6px}.ach-progress>div{height:100%;background:var(--accent);transition:width var(--t-slow)}.skeleton{background:linear-gradient(90deg,var(--surface-2) 25%,var(--border) 50%,var(--surface-2) 75%);background-size:200% 100%;animation:shimmer 1.5s linear infinite;border-radius:var(--r-md)}@keyframes shimmer{to{background-position:-200% 0}}.locale-switcher{display:inline-flex;gap:4px;padding:3px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-full)}.locale-btn{display:inline-flex;align-items:center;justify-content:center;padding:4px 8px;background:transparent;border:1px solid transparent;border-radius:var(--r-full);cursor:pointer;opacity:.55;transition:opacity var(--t-fast),background var(--t-fast),border-color var(--t-fast)}.locale-btn:hover{opacity:.85}.locale-btn.active{opacity:1;background:var(--surface);border-color:var(--border-strong)}.brand-bar{display:flex;align-items:center;justify-content:space-between;padding:var(--s-3) var(--s-4) var(--s-2)}.brand-bar .brand{padding:0}.intro-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1f1a1473;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--s-4);animation:introFade var(--t-base)}@keyframes introFade{0%{opacity:0}to{opacity:1}}.intro-card{width:100%;max-width:440px;background:var(--surface);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden;animation:introSlide var(--t-slow)}@keyframes introSlide{0%{transform:translateY(12px);opacity:0}to{transform:none;opacity:1}}.intro-header{display:flex;align-items:center;justify-content:space-between;padding:var(--s-4) var(--s-5)}.intro-dots{display:inline-flex;gap:6px}.intro-dot{width:24px;height:4px;background:var(--border);border-radius:var(--r-full);transition:background var(--t-base),width var(--t-base)}.intro-dot.current{background:var(--accent);width:32px}.intro-dot.done{background:var(--border-strong)}.intro-skip{background:transparent;border:none;color:var(--ink-muted);font-size:.85rem;font-weight:500;padding:6px 10px;border-radius:var(--r-md);cursor:pointer;transition:color var(--t-fast)}.intro-skip:hover{color:var(--ink)}.intro-body{padding:var(--s-3) var(--s-6) var(--s-6);text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--s-4)}.intro-icon{width:88px;height:88px;border-radius:var(--r-xl);background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;margin-top:var(--s-2)}.intro-icon svg{width:48px;height:48px}.intro-title{font-size:1.5rem;font-weight:700;letter-spacing:-.015em;margin:0;color:var(--ink)}.intro-text{margin:0;color:var(--ink-muted);font-size:1rem;line-height:1.55;max-width:32ch}.intro-footer{padding:0 var(--s-5) var(--s-5)}
