*,*:before,*:after{box-sizing:border-box}:root{--bg: #fbfaf7;--ink: #1f2420;--muted: #6d746e;--soft: #ece8df;--field: #ffffff;--glass: rgba(255, 255, 255, .58);--glass-strong: rgba(255, 255, 255, .74);--glass-line: rgba(255, 255, 255, .72);--accent: #256c5f;--accent-soft: #dfeee9;--bar-food: #256c5f;--bar-groceries: #8b6f47;--bar-transport: #4f6f8f;--bar-rent: #8a5a72;--bar-misc: #747970;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}body{min-height:100vh;margin:0;background:radial-gradient(circle at 18% 8%,rgba(37,108,95,.1),transparent 28%),radial-gradient(circle at 82% 4%,rgba(138,90,114,.09),transparent 25%),linear-gradient(180deg,#fbfaf7,#f5f1ea);color:var(--ink)}button,input,select{font:inherit}button{cursor:pointer;border:0}h1,h2,h3,p{margin:0}.app{width:min(100%,480px);min-height:100vh;margin:0 auto;padding:20px 18px 92px;position:relative}.screen{display:none}.screen.active{display:block;min-height:100vh}.top{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:44px;margin-bottom:28px}.top-actions{display:flex;align-items:center;gap:16px;flex:0 0 auto}.brand-lockup{display:flex;align-items:center;gap:10px;min-width:0}.pig-mark{display:grid;width:34px;height:34px;place-items:center;border-radius:12px;background:#256c5f1a;color:var(--accent);flex:0 0 auto}.pig-mark svg{width:24px;height:24px;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round;fill:none}.back-button,.text-button{min-height:40px;padding:0;background:transparent;color:var(--accent);font-weight:750}.icon-button{display:grid;width:42px;height:42px;place-items:center;border-radius:8px;background:transparent;color:var(--accent)}.icon-button:hover,.icon-button:focus-visible{background:var(--accent-soft);outline:none}.icon-button svg{width:22px;height:22px;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;fill:none}.title{font-size:1.3rem;line-height:1.15;font-weight:850;letter-spacing:0}.brand-name{color:var(--muted);font-size:.82rem;font-weight:850;letter-spacing:0;margin-bottom:4px}.summary{display:grid;gap:12px}.glass-panel{padding:18px;margin-bottom:16px;border:1px solid var(--glass-line);border-radius:18px;background:linear-gradient(145deg,var(--glass-strong),var(--glass));box-shadow:inset 0 1px #ffffffe0,0 18px 48px #1f242017;backdrop-filter:blur(18px) saturate(1.12);-webkit-backdrop-filter:blur(18px) saturate(1.12)}.summary-label{color:var(--muted);font-size:.92rem}.summary-header{display:flex;flex-direction:column;gap:2px}.summary-title{font-size:1rem;font-weight:850;color:var(--ink)}.summary-meta{display:flex;align-items:center;gap:6px;font-size:.82rem;color:var(--muted)}.summary-dot{opacity:.4}.summary-value{font-size:clamp(1.9rem,10vw,3.05rem);line-height:1;font-weight:850;letter-spacing:0;overflow-wrap:anywhere}.summary-row{display:flex;align-items:baseline;justify-content:space-between;gap:14px}.summary-budget{color:var(--muted);font-size:.98rem;font-weight:780;white-space:nowrap}.summary-foot{display:flex;align-items:center;justify-content:space-between;gap:14px;color:var(--muted);font-size:.9rem}.primary-button{width:100%;min-height:58px;border-radius:16px;background:var(--ink);color:#fff;font-weight:850;font-size:1.04rem}.floating-add{position:fixed;left:50%;bottom:18px;width:min(calc(100% - 36px),444px);transform:translate(-50%);box-shadow:0 14px 34px #1f242038;z-index:5}.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:14px;margin:0 0 16px}.section-head h2{font-size:1rem;font-weight:850}.muted{color:var(--muted);font-size:.9rem}.expense-list{display:grid;gap:16px}.expense{display:grid;grid-template-columns:1fr auto;gap:10px 14px;align-items:start;padding:0 0 16px;border-bottom:1px solid rgba(109,116,110,.12);animation:settle .22s ease both}.expense:last-child{padding-bottom:0;border-bottom:0}.expense-main{display:grid;gap:8px;min-width:0}.expense-title{font-weight:800;overflow-wrap:anywhere}.expense-meta{color:var(--muted);font-size:.92rem;line-height:1.35}.expense-amount{font-weight:850;white-space:nowrap}.expense-side{display:flex;flex-direction:column;align-items:flex-end;gap:4px;justify-self:end}.expense-actions,.expense-confirm-actions{display:flex;gap:8px;align-items:center}.expense-confirm-actions{grid-column:1 / -1;gap:14px;margin-top:0}.expense-actions button,.expense-confirm-actions button{min-height:32px;padding:0;background:transparent;color:var(--accent);font-size:.86rem;font-weight:800}.expense-actions .danger-action,.expense-confirm-actions .danger-action{color:#9f4a3b}.expense-icon-action{display:grid;width:26px;height:26px;min-height:26px;place-items:center;border-radius:8px}.expense-icon-action:hover,.expense-icon-action:focus-visible{background:#256c5f14;outline:none}.expense-icon-action.danger-action:hover,.expense-icon-action.danger-action:focus-visible{background:#9f4a3b17}.expense-icon-action svg{width:15px;height:15px;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;fill:none}.empty{color:var(--muted);line-height:1.45;padding:28px 0}.toast{position:fixed;left:50%;bottom:88px;transform:translate(-50%,14px);min-height:42px;display:grid;place-items:center;padding:0 16px;border-radius:8px;background:var(--accent);color:#fff;font-weight:760;opacity:0;pointer-events:none;transition:opacity .16s ease,transform .16s ease;z-index:6}.toast.show{opacity:1;transform:translate(-50%)}.form{display:grid;gap:18px}.field{display:grid;gap:8px}label{color:var(--muted);font-size:.82rem;font-weight:800}input,select{width:100%;min-height:52px;border:1px solid rgba(255,255,255,.74);border-radius:14px;background:#ffffffb8;color:var(--ink);outline:none;padding:0 14px;box-shadow:inset 0 1px #fffc}input:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}.amount-wrap{position:relative}.amount-prefix{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--muted);font-weight:850;font-size:1rem;pointer-events:none}.amount-wrap input{min-height:72px;padding-left:50px;font-size:2rem;font-weight:850}input[type=date]{-webkit-appearance:none;appearance:none;width:100%;display:block;text-align:left;-webkit-text-fill-color:var(--ink)}.inline-row{display:grid;grid-template-columns:1fr auto;gap:10px}.small-button{min-height:52px;padding:0 14px;border-radius:14px;background:var(--accent-soft);color:var(--accent);font-weight:850;white-space:nowrap}.toggle{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:4px;border-radius:14px;background:#ece8dfb8}.toggle button{min-height:44px;border-radius:11px;background:transparent;color:var(--muted);font-weight:820}.toggle button.active{background:#fff;color:var(--ink);box-shadow:0 2px 10px #1f242014}.custom-split{display:none;grid-template-columns:1fr 1fr;gap:10px}.custom-split.active{display:grid}.save-row{display:grid;gap:10px;margin-top:8px}.progress{height:8px;border-radius:999px;background:#ece8dfc7;overflow:hidden}.progress span{display:block;width:0%;height:100%;border-radius:inherit;background:var(--accent);transition:width .18s ease}.analytics-group{display:grid;gap:16px;margin-top:16px}.panel-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.mini-toggle{display:flex;gap:4px;padding:3px;border-radius:999px;background:#ece8dfb8;flex:0 0 auto}.mini-toggle button{min-height:30px;padding:0 10px;border-radius:999px;background:transparent;color:var(--muted);font-size:.8rem;font-weight:850}.mini-toggle button.active{background:#ffffffdb;color:var(--ink);box-shadow:0 2px 8px #1f242012}.category-chart{display:grid;grid-template-columns:118px 1fr;gap:18px;align-items:center}.pie-chart{width:118px;aspect-ratio:1;border-radius:50%;box-shadow:inset 0 0 0 1px #ffffffb8,0 12px 24px #1f242014;position:relative}.pie-chart:after{content:"";position:absolute;inset:31px;border-radius:50%;background:#ffffffc2;box-shadow:inset 0 1px #ffffffe0}.category-legend{display:grid;gap:10px}.legend-row{display:grid;grid-template-columns:auto 1fr auto;gap:8px;align-items:center;color:var(--muted);font-size:.92rem;font-weight:760}.legend-row strong{color:var(--ink);font-weight:850}.legend-dot{width:10px;height:10px;border-radius:50%}.bar-row{display:grid;gap:7px}.bar-label{display:flex;align-items:center;justify-content:space-between;gap:14px;font-weight:780}.soft-bar{height:9px;border-radius:999px;background:#ece8dfc7;overflow:hidden}.soft-bar span{display:block;height:100%;width:0%;border-radius:inherit;background:var(--accent)}.settings{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}.subtle-button{min-height:46px;border-radius:14px;background:#ffffff57;color:var(--muted);border:1px solid var(--soft);font-weight:760}@keyframes settle{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.field-hint{font-size:.78rem;color:var(--muted);margin-top:4px}.hint-found{color:#256c5f;font-weight:500}.hint-new{color:var(--muted)}.hint-error{color:#b94040}.join-hero{display:flex;flex-direction:column;align-items:center;text-align:center;padding:32px 0 24px;gap:6px}.join-pig-wrap{display:grid;place-items:center;width:72px;height:72px;border-radius:20px;background:#256c5f1a;color:var(--accent);margin-bottom:4px}.join-pig-wrap .pig-mark{width:72px;height:72px;border-radius:20px;background:transparent}.join-pig-wrap .pig-mark svg{width:44px;height:44px}.join-brand{font-size:1.75rem;font-weight:700;letter-spacing:-.02em;color:var(--ink);margin:0}.join-tagline{font-size:.95rem;color:var(--muted);margin:0 0 12px}.join-benefits{display:flex;flex-direction:column;gap:10px;width:100%;background:var(--soft);border-radius:14px;padding:14px 16px;text-align:left}.join-benefit{display:flex;align-items:flex-start;gap:10px;font-size:.875rem;color:var(--ink);line-height:1.4}.join-benefit-icon{font-size:.95rem;flex-shrink:0;margin-top:1px}.join-switch{text-align:center;font-size:.85rem;color:var(--muted);margin-top:4px}.link-button{background:none;border:none;padding:0;font:inherit;font-size:inherit;color:var(--accent);cursor:pointer;text-decoration:underline;text-underline-offset:2px}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;min-height:60vh;color:var(--muted);font-size:.9rem}@media(max-width:360px){.app{padding-inline:14px}.category-chart{grid-template-columns:1fr}.pie-chart{justify-self:center}.custom-split,.settings{grid-template-columns:1fr}}
