:root{--bg: #0f0f14;--surface: #1a1a24;--surface-2: #22222f;--border: rgba(255,255,255,.07);--border-hover: rgba(255,255,255,.14);--text-primary: #f0ede8;--text-secondary: #9895a0;--text-muted: #5a5770;--gold: #d4a84b;--gold-soft: rgba(212,168,75,.12);--green: #4caf87;--green-soft:rgba(76,175,135,.12);--red: #e05c6a;--red-soft: rgba(224,92,106,.12);--blue: #6b8cff;--blue-soft: rgba(107,140,255,.12);--spending-color: #4caf87;--savings-color: #6b8cff;--giving-color: #e07b5c;--total-color: #d4a84b;--radius: 12px;--radius-lg: 20px;--radius-xl: 28px;--shadow: 0 4px 24px rgba(0,0,0,.4);--shadow-lg: 0 12px 48px rgba(0,0,0,.6);--font-display: "DM Serif Display", Georgia, serif;--font-body: "DM Sans", system-ui, sans-serif;--transition: .2s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;height:100%}body{font-family:var(--font-body);font-size:15px;line-height:1.6;color:var(--text-primary);background:var(--bg);min-height:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3{font-family:var(--font-display);font-weight:400;line-height:1.2}h1{font-size:clamp(1.8rem,5vw,2.8rem)}h2{font-size:clamp(1.4rem,4vw,2rem)}h3{font-size:clamp(1.1rem,3vw,1.4rem)}.app-shell{max-width:680px;margin:0 auto;padding:0 16px 100px;width:100%}.page-header{padding:48px 0 32px;text-align:center}.page-header p{color:var(--text-secondary);margin-top:6px;font-size:.95rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:border-color var(--transition)}.card:hover{border-color:var(--border-hover)}.card-header{padding:20px 24px 0;display:flex;align-items:center;justify-content:space-between}.card-header h3{font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;color:var(--text-secondary);font-family:var(--font-body);font-weight:600}.card-body{padding:20px 24px 24px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-body);font-size:.9rem;font-weight:500;cursor:pointer;transition:all var(--transition);text-decoration:none;white-space:nowrap;background:var(--surface-2);color:var(--text-primary);-webkit-tap-highlight-color:transparent}.btn:active{transform:scale(.97)}.btn:hover{border-color:var(--border-hover);background:var(--surface)}.btn-primary{background:var(--gold);color:#1a1200;border-color:var(--gold);font-weight:600}.btn-primary:hover{background:#e0b85a;border-color:#e0b85a}.btn-danger{background:var(--red-soft);border-color:transparent;color:var(--red)}.btn-danger:hover{background:#e05c6a38}.btn-ghost{background:transparent;border-color:transparent;color:var(--text-secondary)}.btn-ghost:hover{color:var(--text-primary);background:var(--surface-2)}.btn-sm{padding:8px 14px;font-size:.82rem}.btn-full{width:100%}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:.82rem;font-weight:500;color:var(--text-secondary);margin-bottom:8px;text-transform:uppercase;letter-spacing:.08em}.form-group input,.form-group select{width:100%;padding:13px 16px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-family:var(--font-body);font-size:15px!important;transition:border-color var(--transition),box-shadow var(--transition);-webkit-appearance:none}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-soft)}.form-group input::placeholder{color:var(--text-muted)}.form-hint{font-size:.78rem;color:var(--text-muted);margin-top:6px}.account-spending{--acc-color: var(--spending-color);--acc-soft: var(--green-soft)}.account-savings{--acc-color: var(--savings-color);--acc-soft: var(--blue-soft)}.account-giving{--acc-color: var(--giving-color);--acc-soft: rgba(224,123,92,.12)}.account-total{--acc-color: var(--total-color);--acc-soft: var(--gold-soft)}.alert{padding:14px 18px;border-radius:var(--radius);font-size:.9rem;margin-bottom:20px}.alert-success{background:var(--green-soft);color:var(--green);border:1px solid rgba(76,175,135,.2)}.alert-error{background:var(--red-soft);color:var(--red);border:1px solid rgba(224,92,106,.2)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#0f0f14eb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-around;padding:10px 0 max(10px,env(safe-area-inset-bottom));z-index:100}.bottom-nav .nav-item{display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--text-muted);font-size:.7rem;font-weight:500;text-decoration:none;padding:4px 16px;border-radius:8px;transition:color var(--transition);-webkit-tap-highlight-color:transparent}.bottom-nav .nav-item.active{color:var(--gold)}.bottom-nav .nav-icon{font-size:1.4rem}.divider{border:none;border-top:1px solid var(--border);margin:20px 0}.amount-positive{color:var(--green)}.amount-negative{color:var(--red)}.badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.75rem;font-weight:500}.badge-spending{background:var(--green-soft);color:var(--green)}.badge-savings{background:var(--blue-soft);color:var(--blue)}.badge-giving{background:#e07b5c1f;color:var(--giving-color)}.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--gold);border-radius:50%;animation:spin .7s linear infinite;margin:40px auto}@keyframes spin{to{transform:rotate(360deg)}}.loading-center{display:flex;justify-content:center;padding:40px}.fade-enter-active,.fade-leave-active{transition:opacity .18s ease}.fade-enter-from,.fade-leave-to{opacity:0}.slide-up-enter-active{transition:all .22s cubic-bezier(.4,0,.2,1)}.slide-up-enter-from{opacity:0;transform:translateY(12px)}@supports (padding-top: env(safe-area-inset-top)){.app-shell{padding-top:env(safe-area-inset-top)}}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}
