:root{--bg-primary: #f5f5f7;--bg-secondary: #ffffff;--bg-surface: #ffffff;--bg-card: #ffffff;--bg-card-hover: #fafafc;--bg-elevated: #ffffff;--bg-glass: rgba(255, 255, 255, .88);--primary: #0071e3;--primary-glow: rgba(0, 113, 227, .24);--primary-dim: rgba(0, 113, 227, .12);--secondary: #34c759;--secondary-glow: rgba(52, 199, 89, .28);--success: #34c759;--success-glow: rgba(52, 199, 89, .28);--danger: #ff3b30;--danger-glow: rgba(255, 59, 48, .3);--warning: #ff9f0a;--warning-glow: rgba(255, 159, 10, .3);--info: #5e5ce6;--pink: #ff2d55;--text-primary: #1d1d1f;--text-secondary: #3a3a3c;--text-muted: #6e6e73;--text-dim: #8e8e93;--border-color: #e5e5ea;--border-light: #d2d2d7;--radius-xs: 8px;--radius-sm: 12px;--radius-md: 16px;--radius-lg: 20px;--radius-xl: 24px;--radius-2xl: 32px;--transition-fast: .18s cubic-bezier(.4, 0, .2, 1);--transition-smooth: .35s cubic-bezier(.4, 0, .2, 1);--transition-bounce: .5s cubic-bezier(.34, 1.56, .64, 1);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .06);--shadow-md: 0 10px 30px rgba(0, 0, 0, .08);--shadow-lg: 0 18px 46px rgba(0, 0, 0, .12);--shadow-glow: 0 0 35px var(--primary-glow);--safe-bottom: env(safe-area-inset-bottom, 20px);--max-content: 1040px;--nav-width: 260px;--topbar-h: 64px;--text-xs: 12px;--text-sm: 14px;--text-base: 16px;--text-lg: 18px;--text-xl: 22px;--text-2xl: 28px;--text-3xl: 36px;--text-4xl: 48px;--money-xl: 32px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{margin:0;min-height:100vh;background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img,picture,svg,video{display:block;max-width:100%}button{font:inherit;color:inherit;background:none;border:0;padding:0;cursor:pointer}input,textarea,select{font:inherit;color:inherit}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}body{font-family:Space Grotesk,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:var(--text-base);font-weight:400;line-height:1.6}h1,h2,h3,h4,h5,h6{margin:0 0 var(--space-3);font-weight:600;line-height:1.25;color:var(--text-primary);letter-spacing:-.01em}h1{font-size:var(--text-3xl);font-weight:700;letter-spacing:-.02em}h2{font-size:var(--text-2xl);font-weight:700;letter-spacing:-.015em}h3{font-size:var(--text-xl);font-weight:600}h4{font-size:var(--text-lg);font-weight:600}p{margin:0 0 var(--space-4)}.text-mono,.amount{font-family:JetBrains Mono,ui-monospace,SF Mono,Menlo,Consolas,monospace;font-feature-settings:"tnum" 1}.text-muted{color:var(--text-muted)}.text-dim{color:var(--text-dim)}.text-secondary{color:var(--text-secondary)}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.text-3xl{font-size:var(--text-3xl)}.mt-wrap{max-width:var(--max-content);margin:0 auto;padding:0 var(--space-5)}@media(min-width:768px){.mt-wrap{padding:0 var(--space-6)}}.mt-skip{position:absolute;left:-9999px;top:0;padding:var(--space-2) var(--space-4);background:var(--primary);color:#fff;z-index:10000;text-decoration:none;border-radius:var(--radius-sm)}.mt-skip:focus{left:var(--space-4);top:var(--space-4)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.block{display:block}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-5{gap:var(--space-5)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.w-full{width:100%}[x-cloak]{display:none!important}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);height:44px;padding:0 var(--space-5);border-radius:var(--radius-md);font-weight:500;font-size:var(--text-sm);line-height:1;text-decoration:none;transition:background var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast),opacity var(--transition-fast);-webkit-user-select:none;user-select:none;white-space:nowrap}.btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.btn:disabled,.btn[aria-disabled=true]{opacity:.5;pointer-events:none}.btn-primary-glow{background:var(--primary);color:#fff;box-shadow:0 8px 24px var(--primary-glow)}.btn-primary-glow:hover{background:#0064cc;box-shadow:0 12px 32px var(--primary-glow);transform:translateY(-1px);text-decoration:none;color:#fff}.btn-secondary{background:var(--bg-card);color:var(--primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--primary-dim);text-decoration:none}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-card-hover);color:var(--text-primary);text-decoration:none}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#d32f25;text-decoration:none;color:#fff}.btn-google{background:#fff;color:var(--text-primary);border:1px solid var(--border-light);font-weight:500}.btn-google:hover{background:var(--bg-card-hover);text-decoration:none;color:var(--text-primary)}.btn-icon{width:40px;height:40px;padding:0;border-radius:var(--radius-sm);color:var(--text-secondary)}.btn-icon:hover{background:var(--bg-card-hover);color:var(--text-primary)}.btn-fab{position:fixed;right:var(--space-5);bottom:calc(var(--space-5) + var(--safe-bottom));width:56px;height:56px;border-radius:50%;background:var(--primary);color:#fff;box-shadow:var(--shadow-md),0 0 0 0 var(--primary-glow);font-size:var(--text-2xl);z-index:50}.btn-fab:hover{box-shadow:var(--shadow-lg),0 0 0 8px var(--primary-glow);transform:translateY(-2px);text-decoration:none;color:#fff}.btn-block{width:100%}.card{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-fast),transform var(--transition-fast)}.card--padded{padding:var(--space-6)}.card--clickable{cursor:pointer}.card--clickable:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-color)}.card-body{padding:var(--space-6)}.card-footer{padding:var(--space-5) var(--space-6);border-top:1px solid var(--border-color)}.form-group{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-4)}.form-label,.modal-form-label{font-size:var(--text-sm);font-weight:500;color:var(--text-secondary)}.form-input{width:100%;height:48px;padding:0 var(--space-4);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--text-primary);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-input::placeholder{color:var(--text-dim)}.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-dim)}.form-input[aria-invalid=true]{border-color:var(--danger)}.form-input[aria-invalid=true]:focus{box-shadow:0 0 0 3px #ff3b3029}.form-input--textarea{height:auto;min-height:96px;padding:var(--space-3) var(--space-4);resize:vertical}.form-help{font-size:var(--text-xs);color:var(--text-muted)}.form-error,.auth-field-error{font-size:var(--text-xs);color:var(--danger);margin:0;min-height:1em}.amount-input{font-family:JetBrains Mono,ui-monospace,monospace;text-align:right;font-feature-settings:"tnum" 1}.form-alert,.auth-form-alert{padding:var(--space-3) var(--space-4);background:#ff3b3014;color:var(--danger);border-radius:var(--radius-md);font-size:var(--text-sm);margin-bottom:var(--space-4)}.form-alert--success{background:#34c7591a;color:#1f8c3e}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:100;display:flex;align-items:center;justify-content:center;padding:var(--space-5)}.modal-panel{background:var(--bg-elevated);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);max-width:480px;width:100%;max-height:90vh;overflow-y:auto;animation:modal-in .35s cubic-bezier(.34,1.56,.64,1)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-color)}.modal-title{margin:0;font-size:var(--text-xl);font-weight:600}.modal-body{padding:var(--space-6)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-5) var(--space-6);border-top:1px solid var(--border-color)}@keyframes modal-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.toast-stack{position:fixed;top:var(--space-5);right:var(--space-5);z-index:9999;display:flex;flex-direction:column;gap:var(--space-2);pointer-events:none}.toast{display:flex;align-items:center;gap:var(--space-3);min-width:280px;max-width:420px;padding:var(--space-3) var(--space-4);background:var(--bg-elevated);border-radius:var(--radius-md);box-shadow:var(--shadow-md);border-left:3px solid var(--primary);pointer-events:auto;animation:toast-in .35s cubic-bezier(.4,0,.2,1)}.toast--success{border-left-color:var(--success)}.toast--error{border-left-color:var(--danger)}.toast--warning{border-left-color:var(--warning)}.toast--info{border-left-color:var(--info)}.toast-body{flex:1;font-size:var(--text-sm)}.toast-close{color:var(--text-muted);padding:var(--space-1);border-radius:var(--radius-xs)}.toast-close:hover{color:var(--text-primary);background:var(--bg-card-hover)}@keyframes toast-in{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-6);flex-wrap:wrap}.page-header-text{min-width:0}.page-header-title{margin:0;font-size:var(--text-2xl);font-weight:700;letter-spacing:-.02em}.page-header-subtitle{margin:var(--space-1) 0 0;color:var(--text-muted);font-size:var(--text-sm)}.page-header-actions{display:flex;gap:var(--space-2);flex-shrink:0}.empty-state{text-align:center;padding:var(--space-12) var(--space-6);background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.empty-state-icon{width:64px;height:64px;margin:0 auto var(--space-4);background:var(--primary-dim);color:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px}.empty-state-title{margin:0 0 var(--space-2);font-size:var(--text-lg);font-weight:600}.empty-state-text{color:var(--text-muted);font-size:var(--text-sm);margin:0 0 var(--space-5)}.summary-row,.txn-summary-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4);margin-bottom:var(--space-5)}.summary-card,.txn-summary-card{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--space-4) var(--space-5)}.summary-label,.txn-summary-label{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.summary-value,.txn-summary-value{font-family:JetBrains Mono,ui-monospace,monospace;font-size:var(--text-xl);font-weight:700;margin-top:var(--space-1)}.guest-shell{min-height:100vh;background:var(--bg-primary);position:relative}.guest-shell:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:-1;background:radial-gradient(ellipse 100% 80% at 50% -20%,rgba(0,113,227,.06),transparent 50%),radial-gradient(ellipse 70% 50% at 0% 50%,rgba(52,199,89,.04),transparent 45%),radial-gradient(ellipse 60% 40% at 100% 80%,rgba(94,92,230,.05),transparent 40%)}.guest-topbar{position:sticky;top:0;z-index:10;background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-color)}.guest-topbar-inner{display:flex;align-items:center;justify-content:space-between;height:var(--topbar-h)}.guest-brand{display:inline-flex;align-items:center;gap:var(--space-2);font-weight:700;font-size:var(--text-lg);color:var(--text-primary);text-decoration:none}.guest-brand:hover{text-decoration:none}.brand-dot,.logo-dot{width:12px;height:12px;border-radius:50%;background:var(--primary);box-shadow:0 0 0 4px var(--primary-glow)}.guest-brand span:last-child{color:var(--primary)}.guest-nav-actions{display:flex;align-items:center;gap:var(--space-3)}.guest-main{padding:var(--space-12) 0}.guest-footer{border-top:1px solid var(--border-color);padding:var(--space-8) 0;color:var(--text-muted);font-size:var(--text-sm);text-align:center}.auth-root{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-5);background:var(--bg-primary);position:relative}.auth-root:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:-1;background:radial-gradient(ellipse 100% 80% at 50% -20%,rgba(0,113,227,.08),transparent 50%),radial-gradient(ellipse 70% 50% at 0% 50%,rgba(52,199,89,.05),transparent 45%),radial-gradient(ellipse 60% 40% at 100% 80%,rgba(94,92,230,.06),transparent 40%)}.auth-panel{width:100%;max-width:440px}.auth-brand-block{display:flex;align-items:center;justify-content:center;gap:var(--space-2);margin-bottom:var(--space-3)}.auth-brand-text{font-weight:700;font-size:var(--text-xl);letter-spacing:-.01em;color:var(--text-primary)}.auth-brand-text span{color:var(--primary)}.auth-tagline{text-align:center;color:var(--text-muted);margin-bottom:var(--space-8);font-size:var(--text-sm)}.auth-card{background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);padding:var(--space-8)}.auth-title{margin:0 0 var(--space-2);font-size:var(--text-2xl);font-weight:700}.auth-sub{color:var(--text-muted);margin:0 0 var(--space-6);font-size:var(--text-sm)}.auth-form{display:flex;flex-direction:column}.auth-btn-primary{width:100%;margin-top:var(--space-3);height:48px;font-size:var(--text-base)}.auth-divider{display:flex;align-items:center;gap:var(--space-3);margin:var(--space-5) 0;color:var(--text-dim);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.auth-btn-google{width:100%;height:48px}.auth-switch{margin:var(--space-6) 0 0;text-align:center;color:var(--text-muted);font-size:var(--text-sm)}.auth-link-btn{color:var(--primary);font-weight:500;background:none;border:0;cursor:pointer;padding:0;font-size:inherit}.auth-link-btn:hover{text-decoration:underline}.auth-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4);font-size:var(--text-sm)}.app-shell{min-height:100vh;background:var(--bg-primary);display:flex}.app-sidebar{width:var(--nav-width);background:var(--bg-surface);border-right:1px solid var(--border-color);padding:var(--space-6) var(--space-4);position:sticky;top:0;height:100vh;overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-2);flex-shrink:0}.app-sidebar-brand{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2);margin-bottom:var(--space-4);text-decoration:none;color:var(--text-primary)}.app-sidebar-brand:hover{text-decoration:none}.app-sidebar-brand-text{font-weight:700;font-size:var(--text-base);letter-spacing:-.01em}.app-sidebar-brand-text span{color:var(--primary)}.app-sidebar-tagline{font-size:var(--text-xs);color:var(--text-muted);margin:0 0 var(--space-4);padding-left:calc(var(--space-2) * 2 + 12px)}.app-nav-section{display:flex;flex-direction:column;gap:2px}.app-nav-section+.app-nav-section{margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--border-color)}.app-nav-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);color:var(--text-secondary);text-decoration:none;font-size:var(--text-sm);font-weight:500;transition:background var(--transition-fast),color var(--transition-fast)}.app-nav-link:hover{background:var(--bg-card-hover);color:var(--text-primary);text-decoration:none}.app-nav-link.is-active{background:var(--primary-dim);color:var(--primary)}.app-nav-link[aria-disabled=true]{opacity:.4;cursor:not-allowed;pointer-events:none}.app-nav-link i{width:18px;font-size:var(--text-base)}.app-nav-link .nav-soon{margin-left:auto;font-size:10px;font-weight:600;color:var(--text-dim);padding:2px 6px;border-radius:var(--radius-xs);background:var(--bg-card-hover);letter-spacing:.04em}.app-content{flex:1;min-width:0;display:flex;flex-direction:column}.app-topbar{height:var(--topbar-h);background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:10}.app-topbar-inner{display:flex;align-items:center;justify-content:space-between;height:100%;padding:0 var(--space-6)}.app-topbar-title{font-size:var(--text-base);font-weight:500;margin:0}.app-topbar-actions{display:flex;align-items:center;gap:var(--space-3)}.app-user-chip{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2);color:var(--text-secondary);font-size:var(--text-sm)}.app-user-avatar{width:32px;height:32px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:var(--text-sm);flex-shrink:0}.app-main{flex:1;padding:var(--space-6)}.app-main-wrap{max-width:var(--max-content);margin:0 auto}@media(max-width:768px){.app-shell{flex-direction:column}.app-sidebar{display:none}.app-mobile-nav{position:fixed;bottom:0;left:0;right:0;background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border-color);padding:var(--space-2) var(--space-2) calc(var(--space-2) + var(--safe-bottom));display:flex;justify-content:space-around;z-index:20}.app-main{padding-bottom:calc(72px + var(--safe-bottom))}}@media(min-width:769px){.app-mobile-nav{display:none}}.app-mobile-nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--space-2);color:var(--text-muted);text-decoration:none;font-size:11px;font-weight:500}.app-mobile-nav-item.is-active{color:var(--primary)}.app-mobile-nav-item i{font-size:20px}
