:root{--green-dark: #2d6a4f;--green-mid: #52b788;--green-light: #d8f3dc;--green-bg: #b7e4c7;--bg: #f5f5f0;--card: #ffffff;--border: #e5e7eb;--text: #111827;--text-2: #6b7280;--text-3: #9ca3af;--danger: #ef4444;--danger-light: #fee2e2;--r: 16px;--r-s: 8px;--r-xs: 6px;--shadow: 0 1px 3px rgba(0,0,0,.08);--shadow-md: 0 4px 12px rgba(0,0,0,.1);--nav-h: 68px;--safe-bottom: env(safe-area-inset-bottom, 0px)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}button{cursor:pointer;border:none;background:none;font:inherit}input,select{font:inherit}a{color:inherit;text-decoration:none}.page{min-height:100%;padding-bottom:calc(var(--nav-h) + var(--safe-bottom) + 16px)}.page--center{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 24px 40px}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:calc(var(--nav-h) + var(--safe-bottom));padding-bottom:var(--safe-bottom);background:var(--card);border-top:1px solid var(--border);display:flex;z-index:100}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:var(--text-3);font-size:11px;font-weight:500;letter-spacing:.02em;transition:color .15s}.nav-item.active{color:var(--green-dark)}.nav-item svg{width:22px;height:22px}.card{background:var(--card);border-radius:var(--r);box-shadow:var(--shadow)}.btn{display:block;width:100%;padding:14px;border-radius:var(--r-s);font-size:16px;font-weight:600;text-align:center;transition:opacity .15s,transform .1s}.btn:active{transform:scale(.98);opacity:.88}.btn--primary{background:var(--green-dark);color:#fff}.btn--outline{border:1.5px solid var(--border);color:var(--text)}.btn--danger{background:var(--danger-light);color:var(--danger)}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:13px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.04em}.input{width:100%;padding:13px 14px;border:1.5px solid var(--border);border-radius:var(--r-s);font-size:16px;background:var(--card);outline:none;transition:border-color .15s}.input:focus{border-color:var(--green-mid)}.error-msg{color:var(--danger);font-size:14px;text-align:center;padding:8px 12px;background:var(--danger-light);border-radius:var(--r-xs)}.page-header{display:flex;align-items:center;gap:12px;padding:16px 20px}.page-header h1{font-size:20px;font-weight:700}.icon-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;color:var(--text)}.icon-btn:active{background:var(--border)}.icon-btn svg{width:22px;height:22px}.progress-track{height:8px;background:var(--border);border-radius:99px;overflow:hidden}.progress-fill{height:100%;border-radius:99px;background:var(--green-dark);transition:width .4s ease}.progress-fill.over{background:var(--danger)}.budget-card{margin:0 16px;padding:20px}.budget-label{font-size:14px;color:var(--text-2);margin-bottom:4px}.budget-amount{font-size:40px;font-weight:800;letter-spacing:-1px;line-height:1.1;margin-bottom:14px}.budget-amount sup{font-size:22px;font-weight:700;vertical-align:super;margin-right:2px}.budget-meta{display:flex;justify-content:space-between;font-size:13px;color:var(--text-2);margin-top:8px}.expense-list{display:flex;flex-direction:column;gap:2px;padding:0 16px}.expense-item{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--card);border-radius:var(--r-s);box-shadow:var(--shadow)}.expense-icon{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.expense-info{flex:1;min-width:0}.expense-name{font-weight:600;font-size:15px}.expense-sub{font-size:12px;color:var(--text-2);margin-top:1px}.expense-amount{font-weight:700;font-size:15px;white-space:nowrap}.section-title{font-size:13px;font-weight:700;color:var(--text-2);text-transform:uppercase;letter-spacing:.06em;padding:0 16px;margin:20px 0 10px}.auth-logo{width:72px;height:72px;background:var(--green-light);border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:36px;margin-bottom:20px}.auth-title{font-size:26px;font-weight:800;margin-bottom:4px}.auth-sub{font-size:14px;color:var(--text-2);margin-bottom:32px}.auth-form{width:100%;max-width:360px;display:flex;flex-direction:column;gap:16px}.auth-link{text-align:center;font-size:14px;color:var(--text-2);margin-top:8px}.auth-link a{color:var(--green-dark);font-weight:600}.pin-dots{display:flex;gap:16px;justify-content:center;margin:24px 0}.pin-dot{width:14px;height:14px;border-radius:50%;border:2px solid var(--text-3);transition:background .1s,border-color .1s}.pin-dot.filled{background:var(--text);border-color:var(--text)}.pin-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;width:100%;max-width:300px;margin:0 auto}.pin-key{aspect-ratio:1;border-radius:var(--r-s);border:1.5px solid var(--border);font-size:22px;font-weight:500;display:flex;align-items:center;justify-content:center;background:var(--card);transition:background .1s;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.pin-key:active{background:var(--green-light)}.pin-key--empty{border-color:transparent;background:transparent;pointer-events:none}.amount-display{background:var(--bg);border-radius:var(--r);padding:24px 20px;text-align:center;margin:0 16px}.amount-label{font-size:13px;color:var(--text-2);margin-bottom:8px}.amount-value{font-size:48px;font-weight:800;letter-spacing:-2px}.amount-value .sym{font-size:28px;margin-right:4px}.category-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 16px}.cat-chip{display:flex;align-items:center;gap:8px;padding:12px 14px;border-radius:var(--r-s);border:1.5px solid var(--border);font-size:14px;font-weight:600;background:var(--card);transition:border-color .15s,background .15s}.cat-chip.selected{border-color:var(--green-dark);background:var(--green-light)}.stats-hero{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:0 16px;margin-bottom:4px}.stat-box{padding:16px;border-radius:var(--r);background:var(--card);box-shadow:var(--shadow)}.stat-box-label{font-size:12px;color:var(--text-2);margin-bottom:4px}.stat-box-value{font-size:22px;font-weight:800}.bar-chart{display:flex;align-items:flex-end;gap:6px;height:120px;padding:0 16px}.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;height:100%;justify-content:flex-end}.bar-track{flex:1;width:100%;background:var(--border);border-radius:6px 6px 0 0;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden}.bar-fill{background:var(--green-dark);border-radius:6px 6px 0 0;min-height:4px;transition:height .4s ease}.bar-day{font-size:11px;color:var(--text-2);font-weight:500}.cat-row{padding:14px 0;border-bottom:1px solid var(--border)}.cat-row:last-child{border-bottom:none}.cat-row-header{display:flex;justify-content:space-between;margin-bottom:8px;font-size:14px}.cat-row-name{font-weight:600}.cat-row-total{font-weight:700}.cat-bar-track{height:6px;background:var(--border);border-radius:99px;overflow:hidden}.cat-bar-fill{height:100%;border-radius:99px}.settings-list{display:flex;flex-direction:column;gap:2px;padding:0 16px}.settings-row{display:flex;align-items:center;gap:14px;padding:16px;background:var(--card);border-radius:var(--r-s);box-shadow:var(--shadow)}.settings-icon{width:36px;height:36px;border-radius:10px;background:var(--green-light);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.settings-label{flex:1;font-weight:600;font-size:15px}.settings-value{color:var(--text-2);font-size:14px}.settings-row svg{width:18px;height:18px;color:var(--text-3)}.settings-row--danger{color:var(--danger)}.settings-row--danger .settings-icon{background:var(--danger-light)}.install-banner{position:fixed;left:12px;right:12px;bottom:calc(var(--nav-h) + var(--safe-bottom) + 10px);z-index:150;display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--green-dark);color:#fff;border-radius:var(--r);box-shadow:0 8px 24px #00000040;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.install-banner__icon{font-size:28px;flex-shrink:0;width:40px;height:40px;background:#ffffff26;border-radius:10px;display:flex;align-items:center;justify-content:center}.install-banner__body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.install-banner__title{font-size:14px;font-weight:700;letter-spacing:.01em}.install-banner__sub{font-size:12px;opacity:.85;line-height:1.3}.install-banner__sub em{font-style:normal;font-weight:700;text-decoration:underline}.install-banner__btn{flex-shrink:0;padding:8px 16px;background:#fff;color:var(--green-dark);font-size:13px;font-weight:800;border-radius:var(--r-xs);letter-spacing:.02em;transition:opacity .15s}.install-banner__btn:active{opacity:.8}.install-banner__close{flex-shrink:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;opacity:.7;color:#fff;transition:opacity .15s,background .15s}.install-banner__close:active{opacity:1;background:#fff3}.page--center~.install-banner,body:not(:has(.bottom-nav)) .install-banner{bottom:calc(var(--safe-bottom) + 16px)}.nav-item--admin{color:var(--text-3)}.nav-item--admin.active{color:#7c3aed}.admin-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:0 16px 4px}.admin-stat-card{background:var(--card);border-radius:var(--r);box-shadow:var(--shadow);padding:16px;display:flex;flex-direction:column;gap:4px}.admin-stat-icon{font-size:22px;margin-bottom:4px}.admin-stat-value{font-size:26px;font-weight:800}.admin-stat-label{font-size:12px;color:var(--text-2)}.status-pill{display:inline-block;padding:2px 10px;border-radius:99px;font-size:12px;font-weight:700;letter-spacing:.02em}.status-pill--active{background:#d1fae5;color:#065f46}.status-pill--admin{background:#ede9fe;color:#5b21b6}.status-pill--disabled{background:#fee2e2;color:#991b1b}.activity-row{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;background:var(--card);border-radius:var(--r-s);box-shadow:var(--shadow)}.user-list-row{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--card);border-radius:var(--r-s);box-shadow:var(--shadow);width:100%;text-align:left;transition:background .1s}.user-list-row:active{background:var(--bg)}.user-avatar{width:40px;height:40px;border-radius:50%;background:var(--green-light);color:var(--green-dark);font-size:18px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.info-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border);font-size:14px}.info-row:last-child{border-bottom:none}.info-row span:first-child{color:var(--text-2)}.info-row span:last-child{font-weight:600}.temp-pw-box{font-family:Courier New,monospace;font-size:22px;font-weight:700;letter-spacing:4px;text-align:center;padding:16px;background:var(--bg);border-radius:var(--r-s);border:2px dashed var(--green-mid);word-break:break-all}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:flex-end;justify-content:center;z-index:200;padding:16px}.modal-box{background:var(--card);border-radius:var(--r) var(--r) 0 0;padding:24px 20px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto}.spinner{width:32px;height:32px;border:3px solid var(--green-light);border-top-color:var(--green-dark);border-radius:50%;animation:spin .7s linear infinite;margin:40px auto}@keyframes spin{to{transform:rotate(360deg)}}.empty{text-align:center;padding:40px 24px;color:var(--text-2)}.empty-icon{font-size:40px;margin-bottom:12px}.empty p{font-size:15px}.add-btn{display:flex;align-items:center;justify-content:center;gap:8px;margin:20px 16px 0;padding:16px;border-radius:var(--r-s);border:1.5px dashed var(--green-mid);color:var(--green-dark);font-weight:600;font-size:15px;background:transparent;width:calc(100% - 32px);transition:background .15s}.add-btn:active{background:var(--green-light)}
