@import"https://fonts.googleapis.com/css2?family=DM+Sans:opsz,wght@9..40,400;9..40,500;9..40,600;9..40,700&family=DM+Mono:wght@400;500&family=Lora:wght@500;600;700&family=Heebo:wght@400;500;600;700;800&display=swap";:root{--bg: #f5f2ec;--bg-2: #efebe3;--surface: #ffffff;--surface2: #f4f0e9;--surface3: #e8e3da;--border: #e2dcd0;--border-soft: #ede8de;--hairline: rgba(28, 25, 23, .06);--text: #1c1917;--text2: #57534e;--text3: #a29c92;--text-on-dark: #f5f2ec;--text-on-dark-mute: rgba(245, 242, 236, .72);--text-on-dark-dim: rgba(245, 242, 236, .5);--accent: #1f5f40;--accent-600: #2d6a4f;--accent-700: #18482f;--accent-800: #0f3220;--accent-dim: rgba(31, 95, 64, .1);--accent-soft: #e6efe9;--expense: #b23a2e;--expense-dim: rgba(178, 58, 46, .1);--expense-soft: #f8e8e5;--warning: #92400e;--warning-dim: rgba(146, 64, 14, .1);--warning-soft: #faf1dc;--info: #1e5a7a;--info-soft: #e4edf3;--tag-bg: #f4ebd0;--tag-text: #92400e;--radius-xs: 6px;--radius-sm: 10px;--radius: 14px;--radius-lg: 20px;--radius-xl: 28px;--radius-pill: 999px;--shadow-xs: 0 1px 2px rgba(28, 25, 23, .04);--shadow-sm: 0 2px 6px rgba(28, 25, 23, .05), 0 1px 2px rgba(28, 25, 23, .04);--shadow-md: 0 8px 24px rgba(28, 25, 23, .08), 0 2px 6px rgba(28, 25, 23, .04);--shadow-lg: 0 20px 48px rgba(28, 25, 23, .12), 0 6px 16px rgba(28, 25, 23, .06);--shadow-hero: 0 24px 60px rgba(15, 50, 32, .32), 0 8px 22px rgba(15, 50, 32, .2);--ring: 0 0 0 4px rgba(31, 95, 64, .2);--ease: cubic-bezier(.2, .7, .2, 1);--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--d-fast: .12s;--d: .22s;--d-slow: .38s}*{box-sizing:border-box;margin:0;padding:0}html,body{height:auto}html{-webkit-text-size-adjust:100%}body{font-family:DM Sans,Heebo,sans-serif;font-size:15px;line-height:1.5;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;font-feature-settings:"kern","liga";background-image:radial-gradient(1200px 600px at 100% -10%,rgba(31,95,64,.03),transparent 60%),radial-gradient(800px 500px at 0% 110%,rgba(178,58,46,.025),transparent 60%)}button,input,select,textarea{font-family:inherit;color:inherit}button{cursor:pointer}img,svg{display:block;max-width:100%}.mono{font-family:DM Mono,monospace;font-variant-numeric:tabular-nums;font-feature-settings:"tnum";letter-spacing:-.01em}::selection{background:var(--accent);color:var(--text-on-dark)}:focus-visible{outline:none;box-shadow:var(--ring);border-radius:var(--radius-xs);transition:box-shadow var(--d-fast) var(--ease)}#root{display:flex;min-height:100vh}.desktop-sidebar{display:none}.app-shell{flex:1;display:flex;flex-direction:column;max-width:480px;margin:0 auto;width:100%;padding-bottom:calc(96px + env(safe-area-inset-bottom,0px));position:relative;animation:app-fade-in var(--d-slow) var(--ease-out) both}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}@keyframes app-fade-in{0%{opacity:0}to{opacity:1;transform:none}}@media (min-width: 900px){body{background:radial-gradient(1200px 700px at 110% -10%,rgba(31,95,64,.05),transparent 60%),radial-gradient(900px 600px at -10% 110%,rgba(178,58,46,.03),transparent 60%),#ece7dd}#root{flex-direction:row;align-items:stretch}.app-shell{max-width:480px;border-inline:1px solid var(--border);background:var(--bg);min-height:100vh;box-shadow:var(--shadow-md)}.desktop-sidebar{display:flex;flex-direction:column;gap:4px;padding:32px 24px;width:280px;flex-shrink:0;border-inline-start:1px solid var(--border);position:sticky;top:0;height:100vh;overflow-y:auto;background:transparent}.desktop-sidebar-title{font-family:Lora,serif;font-size:22px;font-weight:600;color:var(--text);margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--border);letter-spacing:-.01em}.desktop-sidebar-item{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:var(--radius);cursor:pointer;font-size:14px;font-weight:500;color:var(--text2);transition:background var(--d) var(--ease),color var(--d) var(--ease),transform var(--d-fast) var(--ease);position:relative}.desktop-sidebar-item:hover{background:var(--surface2);color:var(--text)}.desktop-sidebar-item.active{background:var(--accent-soft);color:var(--accent);font-weight:600}.desktop-sidebar-item.active:before{content:"";position:absolute;inset-inline-end:0;top:8px;bottom:8px;width:3px;background:var(--accent);border-radius:var(--radius-pill);animation:indicator-in var(--d) var(--ease-spring) both}@keyframes indicator-in{0%{transform:scaleY(0);opacity:0}to{transform:scaleY(1);opacity:1}}.bottom-nav{display:none}.fab{left:calc((100vw - 760px)/2 + 240px);right:auto;margin-inline:0;transform:translate(-50%);bottom:32px}.fab:hover{transform:translate(-50%) translateY(-2px)}.fab:active{transform:translate(-50%) scale(.97)}}.login-screen{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;min-height:100vh;width:100%;max-width:480px;margin:0 auto;padding:52px 28px 36px;text-align:center;box-sizing:border-box;overflow-y:auto;animation:app-fade-in var(--d-slow) var(--ease-out) both;background:radial-gradient(ellipse at 60% 0%,#ede9e0,#f7f5f0 65%)}.login-lang-btn{position:absolute;top:20px;inset-inline-end:20px;background:var(--surface);border:1.5px solid var(--accent);color:var(--accent);border-radius:20px;padding:6px 16px;font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;letter-spacing:.04em;transition:background var(--d) var(--ease),color var(--d) var(--ease)}.login-lang-btn:hover{background:var(--accent);color:#fff}.login-hero{display:flex;flex-direction:column;align-items:center;gap:10px;padding-bottom:20px;padding-top:8px}.login-wordmark{display:inline-flex;align-items:baseline;gap:0;font-family:Lora,Georgia,serif;font-size:52px;font-weight:600;letter-spacing:-2px;line-height:1;filter:drop-shadow(0 2px 0 rgba(45,106,79,.1))}.login-wordmark-b{color:var(--accent)}.login-wordmark-rest{color:var(--text)}.login-tagline{font-family:Lora,Georgia,serif;font-size:17px;font-weight:600;color:var(--text);line-height:1.4;max-width:300px}.login-tagline-sub{display:none}.login-divider{width:40px;height:2px;background:var(--accent);border-radius:2px;margin:0 auto -8px;opacity:.4}.login-card{display:flex;flex-direction:column;align-items:stretch;gap:10px;width:100%;background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:24px 20px;box-sizing:border-box;box-shadow:0 2px 20px #0000000e}.login-provider-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;background:#fff;color:var(--text);border:1.5px solid var(--border);border-radius:10px;padding:14px 16px;min-height:50px;font-family:inherit;font-size:14px;font-weight:600;cursor:pointer;transition:border-color var(--d) var(--ease),transform var(--d) var(--ease-spring),box-shadow var(--d) var(--ease)}.login-provider-btn:hover:not(:disabled){border-color:var(--accent);transform:translateY(-1px);box-shadow:0 4px 14px #2d6a4f1f}.login-provider-btn:active:not(:disabled){transform:translateY(0)}.login-provider-btn:disabled{opacity:.5;cursor:default}.login-provider-manual{background:var(--accent);color:#fff;border-color:var(--accent)}.login-provider-manual:hover:not(:disabled){border-color:var(--accent);box-shadow:0 4px 14px #2d6a4f40}.login-provider-create{background:var(--surface);color:var(--accent);border-color:var(--accent)}.login-provider-create:hover:not(:disabled){background:#2d6a4f0f;box-shadow:0 4px 14px #2d6a4f1a}.login-form-title{font-family:Lora,Georgia,serif;font-size:17px;font-weight:600;color:var(--text);text-align:center;margin-bottom:4px}.login-email-note{font-size:11px;color:var(--text3);text-align:center;line-height:1.5}.login-or{display:flex;align-items:center;gap:10px;color:var(--text3);font-size:12px;margin:2px 0}.login-or:before,.login-or:after{content:"";flex:1;height:1px;background:var(--border)}.login-switch-link{background:none;border:none;color:var(--accent);font-family:inherit;font-size:12px;cursor:pointer;padding:2px 0;text-align:center}.login-switch-link:hover{text-decoration:underline}.login-hint{font-size:12px;color:var(--text3);line-height:1.55;text-align:center}.login-error{color:var(--expense);font-size:13px;background:var(--expense-soft);border:1px solid rgba(178,58,46,.18);border-radius:var(--radius);padding:12px 16px;text-align:center;animation:shake .4s var(--ease) both}.login-features{display:flex;flex-direction:column;align-items:flex-start;gap:10px;width:100%;padding:16px 8px 0}.login-feature-row{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--text2);line-height:1.45;text-align:start}.login-feature-check{font-size:13px;font-weight:700;color:var(--accent);flex-shrink:0;margin-top:1px}.login-footer{font-size:11px;color:var(--text3);letter-spacing:.03em;padding-top:24px}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-4px)}40%,80%{transform:translate(4px)}}.household-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;width:100%;max-width:480px;margin:0 auto;padding:40px 24px;gap:18px;box-sizing:border-box;animation:app-fade-in var(--d-slow) var(--ease-out) both}.household-screen h2{font-family:Lora,serif;font-size:26px;font-weight:600;text-align:center;color:var(--text);letter-spacing:-.5px}.household-screen p{font-size:14px;color:var(--text2);text-align:center;max-width:300px;line-height:1.6}.household-actions{display:flex;flex-direction:column;gap:10px;width:100%;max-width:320px}.btn-primary{width:100%;background:var(--accent);border:none;border-radius:var(--radius);padding:14px;color:#fff;font-family:inherit;font-size:15px;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #1f5f4033;transition:background var(--d) var(--ease),transform var(--d-fast) var(--ease),box-shadow var(--d) var(--ease);position:relative;overflow:hidden}.btn-primary:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(255,255,255,.12),transparent 50%);pointer-events:none}.btn-primary:hover{background:var(--accent-600);transform:translateY(-1px);box-shadow:0 8px 20px #1f5f4040}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}.btn-secondary{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px;color:var(--text);font-family:inherit;font-size:15px;font-weight:500;cursor:pointer;transition:background var(--d) var(--ease),border-color var(--d) var(--ease),transform var(--d-fast) var(--ease)}.btn-secondary:hover{background:var(--surface2);border-color:var(--accent)}.btn-secondary:active{transform:translateY(1px)}.divider{font-size:12px;color:var(--text3);text-align:center;position:relative;width:100%;max-width:320px}.divider:before,.divider:after{content:"";position:absolute;top:50%;width:38%;height:1px;background:var(--border)}.divider:before{right:0}.divider:after{left:0}.invite-code-display{background:linear-gradient(180deg,var(--surface) 0%,var(--surface2) 100%);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;text-align:center;width:100%;max-width:320px;box-shadow:var(--shadow-sm);animation:pop-in var(--d-slow) var(--ease-spring) both}.invite-code-display .code{font-family:DM Mono,monospace;font-size:32px;font-weight:500;letter-spacing:8px;color:var(--accent);margin:12px 0}.invite-code-display p{font-size:12px;color:var(--text2)}.join-form{display:flex;flex-direction:column;gap:10px;width:100%;max-width:320px}@keyframes pop-in{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.app-header{position:sticky;top:0;z-index:100;background:#f5f2ecd9;-webkit-backdrop-filter:saturate(180%) blur(12px);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--hairline);padding:14px 16px;display:flex;align-items:center;justify-content:space-between;transition:box-shadow var(--d) var(--ease)}.app-logo{font-family:Lora,Georgia,serif;font-size:22px;font-weight:600;letter-spacing:-.5px;color:var(--text);display:inline-flex;align-items:center;gap:8px}.header-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.header-lang-btn,.header-sub-badge{display:inline-flex;flex-shrink:0}.header-avatar-pro{display:none}@media (max-width: 480px){.header-sub-badge{display:none!important}.header-avatar-pro{display:flex!important}}.month-selector{display:inline-flex;align-items:center;gap:6px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-pill);padding:7px 14px;font-size:13px;font-weight:500;color:var(--text);cursor:pointer;font-family:inherit;transition:background var(--d) var(--ease),border-color var(--d) var(--ease),transform var(--d-fast) var(--ease);box-shadow:var(--shadow-xs)}.month-selector:hover{border-color:var(--accent);background:var(--surface)}.month-selector:active{transform:scale(.97)}.avatar{width:34px;height:34px;border-radius:50%;background:radial-gradient(circle at 30% 30%,var(--accent-600),var(--accent) 70%);border:1px solid rgba(15,50,32,.2);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;cursor:pointer;color:#fff;font-family:inherit;flex-shrink:0;box-shadow:0 2px 8px #0f322040;transition:transform var(--d) var(--ease-spring)}.avatar:hover{transform:scale(1.05)}.avatar:active{transform:scale(.95)}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;background:#fffffff5;-webkit-backdrop-filter:saturate(180%) blur(16px);backdrop-filter:saturate(180%) blur(16px);border-top:1px solid var(--hairline);display:flex;align-items:flex-end;z-index:200;padding:0 0 calc(10px + env(safe-area-inset-bottom,0px))}.nav-add-wrap{flex:1;display:flex;justify-content:center;align-items:flex-end;padding-bottom:6px}.nav-add-btn{width:54px;height:54px;border-radius:50%;background:var(--accent);color:#fff;border:3px solid #fff;box-shadow:0 4px 18px #2d6a4f61,0 1px 4px #0000001f;font-size:28px;font-weight:300;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;margin-bottom:10px;transition:transform .15s var(--ease-spring),box-shadow .15s var(--ease);position:relative;z-index:201}.nav-add-btn:hover{transform:scale(1.08);box-shadow:0 6px 24px #2d6a4f73,0 2px 6px #00000024}.nav-add-btn:active{transform:scale(.95)}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;padding:6px 4px;background:none;border:none;font-family:inherit;color:var(--text3);position:relative;transition:color var(--d) var(--ease),transform var(--d-fast) var(--ease)}.nav-item:active{transform:scale(.92)}.nav-item.active{color:var(--accent)}.nav-item.active:before{content:"";position:absolute;top:-2px;inset-inline:35%;height:3px;border-radius:var(--radius-pill);background:var(--accent);animation:indicator-in var(--d) var(--ease-spring) both}.nav-item svg{transition:transform var(--d) var(--ease-spring)}.nav-item.active svg{transform:translateY(-1px) scale(1.08)}.nav-label{font-size:10px;font-weight:600;letter-spacing:.3px}.fab{position:fixed;bottom:calc(80px + env(safe-area-inset-bottom,0px));left:0;right:0;margin-inline:auto;width:fit-content;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-pill);padding:14px 26px;font-family:inherit;font-size:14px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:8px;z-index:300;box-shadow:0 10px 30px #0f322052,0 4px 10px #0f32202e;transition:transform var(--d) var(--ease-spring),box-shadow var(--d) var(--ease),background var(--d) var(--ease);animation:fab-in var(--d-slow) var(--ease-spring) both}.fab:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(180deg,rgba(255,255,255,.14),transparent 60%);pointer-events:none}.fab:hover{transform:translateY(-2px);box-shadow:0 16px 36px #0f32205c,0 6px 14px #0f322038;background:var(--accent-600)}.fab:active{transform:scale(.97)}.scroll-top-btn{position:fixed;bottom:calc(80px + env(safe-area-inset-bottom,0px));inset-inline-end:16px;width:40px;height:40px;border-radius:50%;background:var(--surface);border:1px solid var(--border);color:var(--text2);cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:300;box-shadow:0 2px 10px #0000001a;animation:scroll-top-in .2s var(--ease-spring) both;transition:background var(--d) var(--ease),color var(--d) var(--ease),transform .15s var(--ease-spring)}.scroll-top-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent);transform:translateY(-2px)}.scroll-top-btn:active{transform:scale(.92)}@keyframes scroll-top-in{0%{opacity:0;transform:translateY(8px) scale(.8)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes fab-in{0%{opacity:0;transform:translateY(16px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.page{padding:0 16px;animation:page-in var(--d-slow) var(--ease-out) both}@keyframes page-in{0%{opacity:0}to{opacity:1}}.section-title{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:1.2px;margin:24px 0 12px;display:flex;align-items:center;gap:8px}.summary-card{position:relative;isolation:isolate;background:radial-gradient(120% 140% at 100% 0%,var(--accent-600) 0%,var(--accent) 40%,var(--accent-800) 100%);color:var(--text-on-dark);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-lg);padding:26px 22px 24px;margin-top:14px;margin-bottom:14px;box-shadow:var(--shadow-hero);overflow:hidden;animation:hero-in var(--d-slow) var(--ease-out) both}@keyframes hero-in{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.summary-card:before{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;background:radial-gradient(40% 60% at 0% 100%,rgba(255,255,255,.08),transparent 70%),radial-gradient(50% 60% at 100% 0%,rgba(255,255,255,.12),transparent 60%);pointer-events:none;z-index:-1}.summary-card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(rgba(255,255,255,.04) 1px,transparent 1px);background-size:3px 3px;pointer-events:none;opacity:.5;z-index:-1}.summary-card .label{font-size:11px;font-weight:600;color:var(--text-on-dark-mute);margin-bottom:8px;text-transform:uppercase;letter-spacing:1.4px;display:inline-flex;align-items:center;gap:6px}.summary-card .amount{font-family:Lora,serif;font-size:44px;font-weight:600;letter-spacing:-1px;direction:ltr;display:inline-block;color:var(--text-on-dark);line-height:1.05;font-variant-numeric:tabular-nums;animation:amount-in var(--d-slow) var(--ease-spring) .1s both}@keyframes amount-in{0%{opacity:0;transform:translateY(6px);letter-spacing:0}to{opacity:1;transform:translateY(0);letter-spacing:-1px}}.summary-card .amount.green{color:var(--text-on-dark)}.summary-card .amount.red{color:#ffb4ac}.summary-card .sub{font-size:13px;color:var(--text-on-dark-mute);margin-top:8px;display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:#ffffff1a;border-radius:var(--radius-pill);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.cards-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}.mini-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 14px;position:relative;overflow:hidden;transition:transform var(--d) var(--ease),border-color var(--d) var(--ease),box-shadow var(--d) var(--ease);cursor:pointer;box-shadow:var(--shadow-xs)}.mini-card:before{content:"";position:absolute;inset-inline-end:0;top:0;bottom:0;width:3px;background:var(--accent);border-radius:0 var(--radius-pill) var(--radius-pill) 0;opacity:0;transform:scaleY(.5);transition:opacity var(--d) var(--ease),transform var(--d) var(--ease-spring)}.mini-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--accent)}.mini-card:hover:before{opacity:1;transform:scaleY(1)}.mini-card .label{font-size:10px;color:var(--text3);margin-bottom:6px;text-transform:uppercase;letter-spacing:.8px;font-weight:600}.mini-card .val{font-family:DM Mono,monospace;font-size:20px;font-weight:500;direction:ltr;display:inline-block;font-variant-numeric:tabular-nums;letter-spacing:-.02em}.mini-card .val.green{color:var(--accent)}.mini-card .val.red{color:var(--expense)}.mini-card .val.orange{color:var(--warning)}.mini-card.active{border-color:var(--accent);background:linear-gradient(180deg,var(--accent-soft) 0%,var(--surface) 100%)}.mini-card.active:before{opacity:1;transform:scaleY(1)}.progress-section{margin-bottom:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow-xs)}.progress-label{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--text2);margin-bottom:10px;font-weight:500}.progress-bar{background:var(--surface3);border-radius:var(--radius-pill);height:8px;overflow:hidden;position:relative}.progress-bar:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.4) 50%,transparent 100%);background-size:200% 100%;animation:progress-shimmer 2.4s linear infinite;pointer-events:none;opacity:.5}@keyframes progress-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.progress-fill{height:100%;border-radius:var(--radius-pill);transition:width .8s var(--ease-out);position:relative;margin-inline-start:auto}.progress-fill.safe{background:linear-gradient(90deg,var(--accent-600),var(--accent));box-shadow:0 0 12px #1f5f404d}.progress-fill.warn{background:linear-gradient(90deg,#b5841f,var(--warning));box-shadow:0 0 12px #92400e4d}.progress-fill.danger{background:linear-gradient(90deg,#d04a3d,var(--expense));box-shadow:0 0 12px #b23a2e4d}.expense-list{display:flex;flex-direction:column;gap:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-xs)}.expense-item{background:var(--surface);border:none!important;border-bottom:1px solid var(--border-soft)!important;border-radius:0!important;padding:14px 16px;display:flex;align-items:center;gap:13px;cursor:pointer;transition:background var(--d-fast) var(--ease);position:relative;animation:list-item-in var(--d) var(--ease-out) both}.expense-item:nth-child(1){animation-delay:0ms}.expense-item:nth-child(2){animation-delay:40ms}.expense-item:nth-child(3){animation-delay:80ms}.expense-item:nth-child(4){animation-delay:.12s}.expense-item:nth-child(5){animation-delay:.16s}.expense-item:nth-child(6){animation-delay:.2s}.expense-item:nth-child(7){animation-delay:.24s}.expense-item:nth-child(8){animation-delay:.28s}@keyframes list-item-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.expense-item:last-child{border-bottom:none!important}.expense-item:hover{background:var(--surface2)}.expense-item:active{background:var(--surface3)}.expense-icon{width:40px;height:40px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text2);background:var(--surface2);font-size:16px;transition:transform var(--d) var(--ease-spring);box-shadow:inset 0 0 0 1px #00000005}.expense-item:hover .expense-icon{transform:scale(1.06) rotate(-2deg)}.expense-info{flex:1;min-width:0}.expense-name{font-size:14.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text);letter-spacing:-.005em}.expense-meta{font-size:12px;color:var(--text3);margin-top:3px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.expense-amount{font-family:DM Mono,monospace;font-size:15px;font-weight:600;flex-shrink:0;direction:ltr;font-variant-numeric:tabular-nums;letter-spacing:-.02em}.expense-amount.out{color:var(--expense)}.expense-amount.in{color:var(--accent)}.tag{display:inline-flex;align-items:center;font-size:10px;font-weight:600;padding:3px 8px;border-radius:var(--radius-pill);margin-inline-start:4px;background:var(--tag-bg);color:var(--tag-text);letter-spacing:.2px;text-transform:uppercase}.tag.fixed{background:var(--accent-soft);color:var(--accent)}.tag.bimonthly{background:var(--warning-soft);color:var(--warning)}.tag.var{background:var(--surface3);color:var(--text2)}.sep-badge{font-size:10px;font-weight:600;padding:3px 8px;border-radius:var(--radius-pill);background:var(--expense-soft);color:var(--expense);border:1px solid rgba(178,58,46,.18);margin-inline-start:6px;text-transform:uppercase;letter-spacing:.2px}.chip{display:inline-flex;align-items:center;font-size:11px;font-weight:500;padding:3px 10px;border-radius:var(--radius-pill);background:var(--surface2);color:var(--text2);margin-inline-end:4px;border:1px solid var(--border)}.delete-btn{background:none;border:none;color:var(--text3);cursor:pointer;padding:6px;display:inline-flex;align-items:center;border-radius:var(--radius-sm);transition:color var(--d) var(--ease),background var(--d) var(--ease),transform var(--d-fast) var(--ease)}.delete-btn:hover{color:var(--expense);background:var(--expense-soft)}.delete-btn:active{transform:scale(.9)}.cat-housing,.cat-rent{background:linear-gradient(180deg,#efeae0,#e2dcd0);color:#57534e}.cat-food,.cat-groceries{background:linear-gradient(180deg,#fef6e0,#fcefc4);color:#92400e}.cat-transport{background:linear-gradient(180deg,#e2edfc,#c9dcfa);color:#1e40af}.cat-kids{background:linear-gradient(180deg,#fce7f3,#f8d0e5);color:#9d174d}.cat-savings,.cat-income{background:linear-gradient(180deg,#e6efe9,#cfe0d5);color:var(--accent)}.cat-health,.cat-pharma{background:linear-gradient(180deg,#fee7e5,#fbd2cd);color:#991b1b}.cat-other{background:linear-gradient(180deg,var(--surface2),var(--surface3));color:var(--text2)}.cat-restaurants,.cat-dining{background:linear-gradient(180deg,#fef6e0,#fcefc4);color:#92400e}.cat-fuel{background:linear-gradient(180deg,#f3e8ff,#e5d2fa);color:#6b21a8}.cat-entertainment,.cat-leisure{background:linear-gradient(180deg,#ede9fe,#dcd3fb);color:#5b21b6}.cat-subscriptions,.cat-telecom{background:linear-gradient(180deg,#e2edfc,#c9dcfa);color:#1e40af}.cat-insurance{background:linear-gradient(180deg,var(--surface2),var(--surface3));color:var(--text2)}.cat-electricity{background:linear-gradient(180deg,#fef6e0,#fcefc4);color:#92400e}.cat-fashion,.cat-clothing{background:linear-gradient(180deg,#fce7f3,#f8d0e5);color:#9d174d}.cat-home{background:linear-gradient(180deg,var(--surface2),var(--surface3));color:var(--text2)}.cat-education{background:linear-gradient(180deg,#e2edfc,#c9dcfa);color:#1e40af}.cat-gifts{background:linear-gradient(180deg,#fce7f3,#f8d0e5);color:#9d174d}.cat-travel{background:linear-gradient(180deg,#dcfce7,#bcf1ce);color:#166534}.cat-shopping{background:linear-gradient(180deg,#fef6e0,#fcefc4);color:#92400e}.cat-sport{background:linear-gradient(180deg,#dcfce7,#bcf1ce);color:#166534}.cat-pets{background:linear-gradient(180deg,#fef6e0,#fcefc4);color:#92400e}.cat-cosmetics{background:linear-gradient(180deg,#fdf2f8,#fce7f3);color:#be185d}.cat-home_maintenance{background:linear-gradient(180deg,#f0f4ff,#dde6fb);color:#3730a3}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1c19178c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:200;opacity:0;pointer-events:none;transition:opacity var(--d) var(--ease)}.modal-overlay.open{opacity:1;pointer-events:all}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:0;position:fixed;bottom:0;left:0;right:0;width:100vw;min-height:75vh;min-height:75dvh;max-height:92vh;max-height:92dvh;animation:slide-up var(--d-slow) var(--ease-spring);overflow:hidden;box-shadow:0 -20px 50px #0000002e;display:flex;flex-direction:column;z-index:201}.modal-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding:0 16px}.modal-footer{padding:10px 16px calc(env(safe-area-inset-bottom,0px) + 12px);border-top:.5px solid var(--border);display:flex;gap:10px}.modal:before{content:"";position:absolute;top:8px;left:50%;transform:translate(-50%);width:38px;height:4px;border-radius:var(--radius-pill);background:var(--surface3)}@keyframes slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-title{font-size:17px;font-weight:700;margin:0;padding:18px 16px 12px;display:flex;justify-content:space-between;align-items:center;color:var(--text);flex-shrink:0;letter-spacing:-.01em}.modal-close{background:var(--surface2);border:1px solid var(--border);color:var(--text2);width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:14px;display:inline-flex;align-items:center;justify-content:center;transition:background var(--d) var(--ease),color var(--d) var(--ease),transform var(--d-fast) var(--ease)}.modal-close:hover{background:var(--expense-soft);color:var(--expense);border-color:#b23a2e33}.modal-close:active{transform:scale(.92) rotate(90deg)}@media (min-width: 900px){.modal{border-radius:var(--radius-lg);width:90vw;max-width:520px;min-height:0;max-height:85vh;max-height:85dvh;bottom:auto;top:50%;left:50%;right:auto;transform:translate(-50%,-50%);animation:none}}.form-group{margin-bottom:10px}.form-label{font-size:10px;font-weight:700;color:var(--text3);margin-bottom:5px;display:block;text-transform:uppercase;letter-spacing:1px}.form-input{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;font-family:inherit;font-size:15px;color:var(--text);outline:none;transition:background var(--d) var(--ease),border-color var(--d) var(--ease),box-shadow var(--d) var(--ease)}.form-input::placeholder{color:var(--text3)}.form-input:hover{border-color:#c9c2b5}.form-input:focus{border-color:var(--accent);background:var(--surface);box-shadow:var(--ring)}.form-input option{background:var(--surface)}.form-input.input-error{border-color:#c0392b;background:#c0392b0a}.type-toggle{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;background:var(--surface2);padding:4px;border-radius:var(--radius);border:1px solid var(--border)}.type-btn{background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);padding:11px 8px;font-family:inherit;font-size:13px;font-weight:600;color:var(--text2);cursor:pointer;text-align:center;transition:all var(--d) var(--ease);position:relative}.type-btn:hover{color:var(--text)}.type-btn.active.expense{background:var(--surface);border-color:var(--expense);color:var(--expense);box-shadow:var(--shadow-xs)}.type-btn.active.income,.type-btn.active.saving{background:var(--surface);border-color:var(--accent);color:var(--accent);box-shadow:var(--shadow-xs)}.submit-btn{width:100%;background:var(--accent);border:none;border-radius:var(--radius);padding:14px;color:#fff;font-family:inherit;font-size:15px;font-weight:600;cursor:pointer;margin-top:8px;box-shadow:0 6px 16px #1f5f4038;transition:background var(--d) var(--ease),transform var(--d-fast) var(--ease),box-shadow var(--d) var(--ease);position:relative;overflow:hidden}.submit-btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(255,255,255,.14),transparent 60%);pointer-events:none}.submit-btn:hover{background:var(--accent-600);transform:translateY(-1px);box-shadow:0 10px 22px #1f5f4047}.submit-btn:active{transform:translateY(0) scale(.99)}.submit-btn:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}.be-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;margin-bottom:12px;box-shadow:var(--shadow-xs)}.be-card .be-title{font-size:11px;color:var(--text3);margin-bottom:14px;font-weight:700;text-transform:uppercase;letter-spacing:1px}.be-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border-soft)}.be-row:last-child{border-bottom:none}.be-row .name{font-size:14px;color:var(--text);font-weight:500}.be-row .val{font-family:DM Mono,monospace;font-size:14px;font-weight:600;direction:ltr;font-variant-numeric:tabular-nums}.be-total{display:flex;justify-content:space-between;align-items:center;padding:14px 0 0;margin-top:6px;border-top:2px solid var(--text)}.be-total .name{font-size:15px;font-weight:700;letter-spacing:-.01em}.be-total .val{font-family:DM Mono,monospace;font-size:20px;font-weight:600;color:var(--expense);direction:ltr;font-variant-numeric:tabular-nums;letter-spacing:-.02em}.target-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:10px;display:flex;justify-content:space-between;align-items:center;transition:transform var(--d) var(--ease),box-shadow var(--d) var(--ease);cursor:pointer;box-shadow:var(--shadow-xs)}.target-row:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.target-row .tname{font-size:14px;font-weight:600}.target-row .tval{font-family:DM Mono,monospace;font-size:18px;font-weight:600;direction:ltr;font-variant-numeric:tabular-nums;letter-spacing:-.02em}.target-row.breakeven{border-color:#92400e40;background:var(--warning-soft)}.target-row.breakeven .tval{color:var(--warning)}.target-row.surplus{border-color:#1f5f4040;background:var(--accent-soft)}.target-row.surplus .tval{color:var(--accent)}.target-row.sep-mode{border-color:#b23a2e40;background:var(--expense-soft)}.target-row.sep-mode .tval{color:var(--expense)}.toggle-row{display:flex;align-items:center;justify-content:space-between;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;margin-bottom:10px;transition:border-color var(--d) var(--ease)}.toggle-row:hover{border-color:#c9c2b5}.toggle-label{font-size:14px;font-weight:600;color:var(--text)}.toggle-sub{font-size:12px;color:var(--text3);margin-top:3px}.toggle{position:relative;width:46px;height:26px;flex-shrink:0}.toggle input{display:none}.toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--surface3);border-radius:var(--radius-pill);cursor:pointer;transition:background var(--d) var(--ease);box-shadow:inset 0 1px 2px #0000000f}.toggle-slider:after{content:"";position:absolute;width:20px;height:20px;border-radius:50%;background:#fff;top:3px;right:3px;transition:transform var(--d) var(--ease-spring),box-shadow var(--d) var(--ease);box-shadow:0 2px 6px #0000002e,0 0 0 .5px #0000000a}.toggle input:checked+.toggle-slider{background:var(--accent)}.toggle input:checked+.toggle-slider:after{transform:translate(-20px);box-shadow:0 2px 8px #0f322040}.settings-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;width:100%;font-family:inherit;transition:background var(--d) var(--ease),border-color var(--d) var(--ease),transform var(--d-fast) var(--ease);text-align:inherit}.settings-item:hover{background:var(--surface2);border-color:#c9c2b5}.settings-item:active{transform:scale(.99)}.settings-item .si-left{display:flex;align-items:center;gap:14px;flex:1;min-width:0}.settings-item .si-icon{width:38px;height:38px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;background:var(--surface2);color:var(--text2);flex-shrink:0;transition:background var(--d) var(--ease),color var(--d) var(--ease)}.settings-item:hover .si-icon{background:var(--accent-soft);color:var(--accent)}.si-title{font-size:14px;font-weight:600;color:var(--text);text-align:right}.si-sub{font-size:12px;color:var(--text3);margin-top:2px;text-align:right}.si-arrow{color:var(--text3);transition:transform var(--d) var(--ease),color var(--d) var(--ease)}.settings-item:hover .si-arrow{transform:translate(-3px);color:var(--accent)}.alert{background:var(--expense-soft);border:1px solid rgba(178,58,46,.2);border-radius:var(--radius);padding:14px 16px;font-size:13.5px;color:var(--expense);margin-bottom:12px;display:flex;gap:10px;align-items:flex-start;font-weight:500;animation:alert-in var(--d) var(--ease-spring) both}@keyframes alert-in{0%{opacity:0;transform:translateY(-4px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.alert.info{background:var(--accent-soft);border-color:#1f5f4033;color:var(--accent)}.alert.budget{background:var(--expense-soft);border-color:#b23a2e33;color:var(--expense)}.empty-state{text-align:center;padding:48px 24px;color:var(--text3);background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius);animation:page-in var(--d-slow) var(--ease-out) both}.empty-state .es-icon{margin-bottom:14px;opacity:.5;display:inline-block;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.empty-state .es-text{font-size:14px;line-height:1.6;color:var(--text2)}.loader-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:var(--bg);display:flex;align-items:center;justify-content:center}.loader-inline{display:flex;align-items:center;justify-content:center;width:100%;padding:24px 0}.loader-mark{position:relative;display:flex;align-items:center;justify-content:center;animation:loader-breathe 1.6s var(--ease) infinite}.loader-ring{animation:loader-spin 1s linear infinite}.loader-arc{transform-origin:center;transform-box:fill-box}.loader-letter{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-family:Lora,Georgia,serif;font-weight:600;color:var(--accent);letter-spacing:-.5px;-webkit-user-select:none;user-select:none;line-height:1}@keyframes loader-spin{to{transform:rotate(360deg)}}@keyframes loader-breathe{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(.96)}}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh}.loading-spinner{width:32px;height:32px;border:2.5px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:loader-spin .7s linear infinite}.expense-amount,.summary-card .amount,.mini-card .val{direction:ltr}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}}.welcome-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;width:100%;background:radial-gradient(ellipse at 60% 0%,#ede9e0,#f7f5f0 70%);cursor:pointer;animation:app-fade-in .4s ease-out both}.welcome-content{display:flex;flex-direction:column;align-items:center;gap:16px;max-width:360px;padding:40px 28px;text-align:center}.welcome-check{animation:pop-in .5s cubic-bezier(.22,1,.36,1) both}.welcome-wordmark{font-family:Georgia,serif;font-size:36px;letter-spacing:-1px}.welcome-headline{font-family:Lora,Georgia,serif;font-size:26px;font-weight:600;color:var(--text1, #1C1917);margin:0}.welcome-sub{font-family:DM Sans,Heebo,sans-serif;font-size:15px;color:var(--text2, #78716C);margin:0}.welcome-btn{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:13px 28px;font-family:DM Sans,Heebo,sans-serif;font-size:15px;font-weight:600;cursor:pointer;margin-top:8px}.welcome-hint{font-size:12px;color:var(--text3, #a8a29e);margin:0}.currency-picker-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;width:100%;background:var(--bg, #F7F5F0);padding:24px 16px;box-sizing:border-box;animation:app-fade-in .3s ease-out both}.currency-picker-card{width:100%;max-width:480px;display:flex;flex-direction:column;gap:14px}.currency-picker-header h2{font-family:Lora,Georgia,serif;font-size:22px;font-weight:600;color:var(--text1, #1C1917);margin:0 0 4px;text-align:center}.currency-picker-header p{font-size:13px;color:var(--text2, #78716C);margin:0;text-align:center}.currency-search{margin-top:4px}.currency-list{display:flex;flex-direction:column;gap:4px;max-height:52vh;overflow-y:auto;border:1px solid var(--border);border-radius:10px;padding:4px;background:var(--surface)}.currency-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1.5px solid transparent;border-radius:8px;background:none;cursor:pointer;font-family:DM Sans,Heebo,sans-serif;font-size:14px;color:var(--text1, #1C1917);text-align:start;transition:background .15s,border-color .15s}.currency-item:hover{background:var(--bg, #F7F5F0)}.currency-item.selected{border-color:var(--accent);background:#2d6a4f0d}.currency-flag{font-size:20px;flex-shrink:0;line-height:1}.currency-name{flex:1}.currency-code{font-family:DM Mono,monospace;font-size:12px;color:var(--text3, #a8a29e)}.currency-actions{display:flex;flex-direction:column;gap:8px}.tour-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;pointer-events:auto}.tour-spotlight{position:fixed;border-radius:10px;box-shadow:0 0 0 9999px #00000085;pointer-events:none;z-index:10000;transition:all .25s ease}.tour-tooltip{position:fixed;z-index:10002;background:var(--surface, #fff);border:1px solid var(--border);border-radius:12px;padding:14px 16px;width:240px;box-shadow:0 8px 32px #00000029;font-family:DM Sans,Heebo,sans-serif;animation:pop-in .2s ease-out both}.tour-tooltip-title{font-size:14px;font-weight:700;color:var(--text1, #1C1917);margin-bottom:5px}.tour-tooltip-msg{font-size:13px;color:var(--text2, #78716C);line-height:1.5;margin-bottom:12px}.tour-tooltip-footer{display:flex;align-items:center;justify-content:space-between;gap:8px}.tour-skip{background:none;border:none;color:var(--text3, #a8a29e);font-size:12px;cursor:pointer;padding:0;font-family:inherit}.tour-counter{font-size:11px;color:var(--text3, #a8a29e);font-family:DM Mono,monospace}.tour-next{background:var(--accent);color:#fff;border:none;border-radius:6px;padding:6px 14px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit}
