:root{--color-primary: #4A7DFF;--color-primary-soft: rgba(74, 125, 255, .12);--color-primary-hover: #3A6AE8;--color-primary-active: #2E5AD4;--color-success: #34C759;--color-success-soft: rgba(52, 199, 89, .12);--color-warning: #FF9500;--color-warning-soft: rgba(255, 149, 0, .12);--color-danger: #FF3B30;--color-danger-soft: rgba(255, 59, 48, .12);--color-bg: #F5F5F7;--color-surface: #FFFFFF;--color-surface-elevated: #FFFFFF;--color-border: rgba(0, 0, 0, .06);--color-divider: rgba(0, 0, 0, .04);--color-text-primary: #1D1D1F;--color-text-secondary: #6E6E73;--color-text-tertiary: #AEAEB2;--color-text-inverse: #FFFFFF;--font-family: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", "Helvetica Neue", "PingFang SC", "Microsoft YaHei", sans-serif;--font-mono: "SF Mono", "Menlo", "Monaco", monospace;--text-xs: .6875rem;--text-sm: .8125rem;--text-base: .9375rem;--text-md: 1.0625rem;--text-lg: 1.25rem;--text-xl: 1.5rem;--text-2xl: 1.75rem;--text-3xl: 2.125rem;--text-hero: 3rem;--weight-regular: 400;--weight-medium: 500;--weight-semibold: 600;--weight-bold: 700;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-2xl: 24px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .04), 0 1px 2px rgba(0, 0, 0, .02);--shadow-md: 0 4px 12px rgba(0, 0, 0, .06), 0 1px 4px rgba(0, 0, 0, .03);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .08), 0 2px 8px rgba(0, 0, 0, .04);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .1), 0 4px 16px rgba(0, 0, 0, .05);--glass-bg: rgba(255, 255, 255, .72);--glass-blur: blur(20px) saturate(180%);--glass-border: rgba(255, 255, 255, .5);--ease-out: cubic-bezier(.25, .46, .45, .94);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--ease-smooth: cubic-bezier(.4, 0, .2, 1);--duration-fast: .15s;--duration-base: .25s;--duration-slow: .4s;--duration-page: .5s;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px);--nav-height: 56px;--nav-height-safe: calc(56px + var(--safe-bottom))}[data-theme=dark]{--color-bg: #000000;--color-surface: #1C1C1E;--color-surface-elevated: #2C2C2E;--color-border: rgba(255, 255, 255, .08);--color-divider: rgba(255, 255, 255, .05);--color-text-primary: #F5F5F7;--color-text-secondary: #98989D;--color-text-tertiary: #636366;--color-text-inverse: #1D1D1F;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .2);--shadow-md: 0 4px 12px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .4);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .5);--glass-bg: rgba(28, 28, 30, .72);--glass-border: rgba(255, 255, 255, .08)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;scroll-behavior:smooth;height:100%}body{min-height:100%;font-family:var(--font-family);font-size:var(--text-base);line-height:1.5;color:var(--color-text-primary);background-color:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;overflow-x:hidden;position:relative}@supports (padding: env(safe-area-inset-top)){body{padding-top:env(safe-area-inset-top);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}}a{color:inherit;text-decoration:none}button{border:none;background:none;cursor:pointer;font:inherit;color:inherit}input,textarea,select{font:inherit;color:inherit;border:none;outline:none;background:none;-webkit-appearance:none;appearance:none}ul,ol{list-style:none}img,video,svg{display:block;max-width:100%}h1,h2,h3,h4,h5,h6{font-weight:var(--weight-semibold)}table{border-collapse:collapse;border-spacing:0}*{-webkit-touch-callout:none}input,textarea{-webkit-touch-callout:default}body{-webkit-user-select:none;user-select:none}input,textarea{-webkit-user-select:text;user-select:text}::-webkit-scrollbar{width:0;height:0}body{overscroll-behavior-y:none}@media(display-mode:standalone){body{padding-top:env(safe-area-inset-top)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideInLeft{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOutLeft{0%{transform:translate(0);opacity:1}to{transform:translate(-30%);opacity:0}}@keyframes slideOutRight{0%{transform:translate(0);opacity:1}to{transform:translate(30%);opacity:0}}@keyframes scaleUp{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}@keyframes popIn{0%{opacity:0;transform:scale(.6)}70%{transform:scale(1.05)}to{opacity:1;transform:scale(1)}}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-4px)}20%,40%,60%,80%{transform:translate(4px)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes pulseScale{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}@keyframes checkPop{0%{transform:scale(0);opacity:0}50%{transform:scale(1.3)}to{transform:scale(1);opacity:1}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}@keyframes overlayOut{0%{opacity:1}to{opacity:0}}@keyframes modalIn{0%{opacity:0;transform:translateY(40px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes modalOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(40px) scale(.95)}}@keyframes numberBounce{0%,to{transform:translateY(0)}40%{transform:translateY(-8px)}60%{transform:translateY(-4px)}}.animate-fade-in{animation:fadeIn var(--duration-base) var(--ease-out) both}.animate-fade-in-up{animation:fadeInUp var(--duration-slow) var(--ease-out) both}.animate-scale-up{animation:scaleUp var(--duration-base) var(--ease-spring) both}.animate-pop-in{animation:popIn var(--duration-slow) var(--ease-spring) both}.animate-shake{animation:shake .5s var(--ease-out)}.animate-pulse{animation:pulse 2s var(--ease-smooth) infinite}.animate-float{animation:float 3s var(--ease-smooth) infinite}.animate-spin{animation:spin 1s linear infinite}.stagger-1{animation-delay:50ms}.stagger-2{animation-delay:.1s}.stagger-3{animation-delay:.15s}.stagger-4{animation-delay:.2s}.stagger-5{animation-delay:.25s}.stagger-6{animation-delay:.3s}.stagger-7{animation-delay:.35s}.stagger-8{animation-delay:.4s}#app{min-height:100vh;min-height:100dvh;position:relative;overflow-x:hidden}.page{min-height:100vh;min-height:100dvh;padding:var(--space-4);padding-bottom:calc(var(--nav-height-safe) + var(--space-4))}.page-header{padding:var(--space-6) 0 var(--space-4)}.page-title{font-size:var(--text-2xl);font-weight:var(--weight-bold);letter-spacing:-.02em}.page-subtitle{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:var(--space-1)}.card{background:var(--color-surface);border-radius:var(--radius-xl);padding:var(--space-5);box-shadow:var(--shadow-sm);transition:transform var(--duration-base) var(--ease-out),box-shadow var(--duration-base) var(--ease-out)}.card:active{transform:scale(.98)}.card-elevated{box-shadow:var(--shadow-md)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);border-radius:var(--radius-full);font-size:var(--text-base);font-weight:var(--weight-semibold);transition:all var(--duration-fast) var(--ease-out);position:relative;overflow:hidden;white-space:nowrap}.btn:after{content:"";position:absolute;inset:0;background:#0000;transition:background var(--duration-fast)}.btn:active:after{background:#00000014}.btn-primary{background:var(--color-primary);color:var(--color-text-inverse)}.btn-primary:hover{background:var(--color-primary-hover)}.btn-secondary{background:var(--color-primary-soft);color:var(--color-primary)}.btn-danger{background:var(--color-danger-soft);color:var(--color-danger)}.btn-ghost{color:var(--color-text-secondary)}.btn-ghost:hover{background:var(--color-primary-soft);color:var(--color-primary)}.btn-block{display:flex;width:100%}.btn-lg{padding:var(--space-4) var(--space-6);font-size:var(--text-md)}.btn-sm{padding:var(--space-2) var(--space-3);font-size:var(--text-sm)}.btn-icon{width:40px;height:40px;padding:0;border-radius:var(--radius-full)}.input-group{margin-bottom:var(--space-4)}.input-label{display:block;font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text-secondary);margin-bottom:var(--space-2)}.input{width:100%;padding:var(--space-3) var(--space-4);background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--color-text-primary);transition:border-color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-soft)}.input::placeholder{color:var(--color-text-tertiary)}.input-error{border-color:var(--color-danger)}.input-error:focus{box-shadow:0 0 0 3px var(--color-danger-soft)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--nav-height-safe);background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-top:.5px solid var(--glass-border);display:flex;align-items:flex-start;justify-content:space-around;padding-top:var(--space-2);padding-bottom:var(--safe-bottom);z-index:100}.nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--space-1) var(--space-3);color:var(--color-text-tertiary);font-size:var(--text-xs);font-weight:var(--weight-medium);transition:color var(--duration-fast) var(--ease-out);position:relative}.nav-item.active{color:var(--color-primary)}.nav-item svg{width:24px;height:24px;transition:transform var(--duration-fast) var(--ease-spring)}.nav-item.active svg{transform:scale(1.1)}.nav-badge{position:absolute;top:-2px;right:4px;min-width:16px;height:16px;padding:0 4px;border-radius:var(--radius-full);background:var(--color-danger);color:#fff;font-size:10px;font-weight:var(--weight-bold);display:flex;align-items:center;justify-content:center;animation:popIn var(--duration-slow) var(--ease-spring)}.modal-overlay{position:fixed;inset:0;background:#0006;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:200;display:flex;align-items:flex-end;justify-content:center;animation:overlayIn var(--duration-base) var(--ease-out)}.modal-overlay.closing{animation:overlayOut var(--duration-base) var(--ease-out) forwards}.modal-content{background:var(--color-surface);border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;width:100%;max-width:500px;max-height:85vh;overflow-y:auto;padding:var(--space-6);padding-bottom:calc(var(--space-6) + var(--safe-bottom));animation:modalIn var(--duration-slow) var(--ease-spring)}.modal-overlay.closing .modal-content{animation:modalOut var(--duration-base) var(--ease-out) forwards}.modal-handle{width:36px;height:4px;background:var(--color-text-tertiary);border-radius:var(--radius-full);margin:0 auto var(--space-5);opacity:.4}.modal-title{font-size:var(--text-lg);font-weight:var(--weight-bold);margin-bottom:var(--space-4)}.toast-container{position:fixed;top:calc(var(--safe-top) + var(--space-4));left:var(--space-4);right:var(--space-4);z-index:300;display:flex;flex-direction:column;gap:var(--space-2);pointer-events:none}.toast{background:var(--color-surface-elevated);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:var(--space-3);animation:fadeInDown var(--duration-slow) var(--ease-spring);pointer-events:auto;font-size:var(--text-sm);font-weight:var(--weight-medium)}.toast.leaving{animation:fadeInUp var(--duration-base) var(--ease-out) reverse forwards}.toast-success{border-left:3px solid var(--color-success)}.toast-error{border-left:3px solid var(--color-danger)}.toast-warning{border-left:3px solid var(--color-warning)}.toast-info{border-left:3px solid var(--color-primary)}.tabs{display:flex;gap:var(--space-1);background:var(--color-divider);border-radius:var(--radius-md);padding:3px;margin-bottom:var(--space-4)}.tab{flex:1;padding:var(--space-2) var(--space-3);border-radius:calc(var(--radius-md) - 2px);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text-secondary);text-align:center;transition:all var(--duration-base) var(--ease-out)}.tab.active{background:var(--color-surface);color:var(--color-text-primary);box-shadow:var(--shadow-sm)}.badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--weight-semibold)}.badge-primary{background:var(--color-primary-soft);color:var(--color-primary)}.badge-success{background:var(--color-success-soft);color:var(--color-success)}.badge-warning{background:var(--color-warning-soft);color:var(--color-warning)}.badge-danger{background:var(--color-danger-soft);color:var(--color-danger)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16) var(--space-6);text-align:center}.empty-state svg{width:64px;height:64px;color:var(--color-text-tertiary);margin-bottom:var(--space-4);opacity:.5}.empty-state h3{font-size:var(--text-md);color:var(--color-text-secondary);margin-bottom:var(--space-2)}.empty-state p{font-size:var(--text-sm);color:var(--color-text-tertiary)}.list-group{background:var(--color-surface);border-radius:var(--radius-xl);overflow:hidden}.list-item{display:flex;align-items:center;padding:var(--space-4);gap:var(--space-3);transition:background var(--duration-fast)}.list-item:active{background:var(--color-divider)}.list-item+.list-item{border-top:.5px solid var(--color-border)}.list-item-content{flex:1;min-width:0}.list-item-title{font-size:var(--text-base);font-weight:var(--weight-medium)}.list-item-subtitle{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:2px}.stat-card{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-4);text-align:center}.stat-value{font-size:var(--text-2xl);font-weight:var(--weight-bold);letter-spacing:-.02em}.stat-label{font-size:var(--text-xs);color:var(--color-text-secondary);margin-top:var(--space-1)}.avatar{width:40px;height:40px;border-radius:var(--radius-full);background:var(--color-primary-soft);color:var(--color-primary);display:flex;align-items:center;justify-content:center;font-weight:var(--weight-bold);font-size:var(--text-sm);flex-shrink:0}.avatar-lg{width:56px;height:56px;font-size:var(--text-lg)}.progress-bar{height:6px;background:var(--color-divider);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;background:var(--color-primary);border-radius:var(--radius-full);transition:width var(--duration-slow) var(--ease-out)}.divider{height:.5px;background:var(--color-border);margin:var(--space-4) 0}.photo-preview{width:100%;aspect-ratio:4/3;border-radius:var(--radius-lg);overflow:hidden;background:var(--color-divider)}.photo-preview img{width:100%;height:100%;object-fit:cover}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3)}.points-display{font-family:var(--font-mono);font-weight:var(--weight-bold);color:var(--color-primary)}.gradient-blob{position:absolute;border-radius:50%;filter:blur(60px);opacity:.15;pointer-events:none}
