*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%}body{font-family:-apple-system,BlinkMacSystemFont,Hiragino Sans,Hiragino Kaku Gothic ProN,Noto Sans JP,Yu Gothic,system-ui,sans-serif;background:#f1f5f9;color:#1e293b;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}input,button,textarea,select{font-family:inherit}button{cursor:pointer;border:none;background:none;padding:0}:root{--green: #16a34a;--green-light: #dcfce7;--green-dark: #15803d;--green-container: #bbf7d0;--teal: #0d9488;--amber: #d97706;--surface: #ffffff;--bg: #f1f5f9;--border: #e2e8f0;--text: #1e293b;--text-muted: #64748b;--text-faint: #94a3b8;--danger: #ef4444;--header-h: 52px;--nav-h: 60px;--radius: 12px;--radius-lg: 20px;--shadow: 0 1px 4px rgba(0,0,0,.08), 0 0 0 1px rgba(0,0,0,.04)}.app{display:flex;flex-direction:column;height:100%;max-width:480px;margin:0 auto;background:var(--bg);position:relative}.app-header{height:var(--header-h);background:var(--green);display:flex;align-items:center;justify-content:space-between;padding:0 16px;flex-shrink:0;position:sticky;top:0;z-index:100}.app-title{color:#fff;font-size:20px;font-weight:700;letter-spacing:.5px}.header-settings-btn{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;background:#ffffff26;transition:background .15s;border:none;cursor:pointer}.header-settings-btn:hover{background:#ffffff40}.app-body{flex:1;overflow:hidden;display:flex;flex-direction:column;min-height:0}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;height:var(--nav-h);background:var(--surface);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:2px;color:var(--text-faint);transition:color .15s;border:none;background:none;cursor:pointer}.nav-item-active{color:var(--green)}.nav-icon{font-size:22px;line-height:1}.nav-label{font-size:11px;font-weight:500}.screen{display:flex;flex-direction:column;flex:1;overflow-y:auto;overflow-x:hidden;min-height:0;padding-bottom:var(--nav-h)}.summary-bar{background:var(--green-container);display:flex;align-items:stretch;padding:14px 16px;flex-shrink:0}.summary-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}.summary-label{font-size:12px;color:#166534;font-weight:500}.summary-value{font-size:18px;font-weight:700;color:#14532d}.summary-divider{width:1px;background:#15803d40;margin:4px 8px}.input-area{background:var(--surface);padding:14px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.chip-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}.chip{padding:6px 12px;border-radius:20px;font-size:13px;border:1.5px solid var(--border);background:var(--bg);color:var(--text);transition:all .15s;cursor:pointer}.chip:hover{border-color:var(--green);color:var(--green)}.chip-selected{background:var(--green-light);border-color:var(--green);color:var(--green-dark);font-weight:600}.chip-edit{background:var(--surface)}.quick-btns{display:flex;gap:8px;margin-bottom:10px}.quick-btn{flex:1;padding:8px 4px;border-radius:8px;border:1.5px solid var(--border);background:var(--surface);font-size:14px;font-weight:600;color:var(--text);transition:all .15s;cursor:pointer}.quick-btn:hover{border-color:var(--green);color:var(--green);background:var(--green-light)}.quick-btn:active{transform:scale(.96)}.input-row{display:flex;gap:8px;align-items:center}.input{width:100%;padding:10px 12px;border:1.5px solid var(--border);border-radius:8px;font-size:15px;color:var(--text);background:var(--surface);outline:none;transition:border-color .15s}.input:focus{border-color:var(--green)}.input[type=number]{-moz-appearance:textfield}.input[type=number]::-webkit-outer-spin-button,.input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none}.input-prefix-wrap{position:relative;display:flex;align-items:center;flex:1}.input-prefix-wrap .input{padding-left:28px}.input-prefix{position:absolute;left:10px;color:var(--text-muted);font-size:15px;pointer-events:none;z-index:1}.date-input{min-width:120px;flex-shrink:0;cursor:pointer;font-size:13px;padding:10px 8px;flex:0 0 auto;width:auto}.btn-primary{padding:10px 18px;border-radius:8px;background:var(--green);color:#fff;font-size:14px;font-weight:600;white-space:nowrap;transition:background .15s,transform .1s;flex-shrink:0;border:none;cursor:pointer}.btn-primary:hover{background:var(--green-dark)}.btn-primary:active{transform:scale(.97)}.btn-text{padding:10px 16px;border-radius:8px;color:var(--text-muted);font-size:14px;font-weight:500;transition:color .15s;border:none;cursor:pointer;background:none}.btn-text:hover{color:var(--text)}.btn-outline{padding:12px 16px;border-radius:8px;border:1.5px solid var(--green);color:var(--green);font-size:15px;font-weight:600;transition:all .15s;background:var(--surface);cursor:pointer}.btn-outline:hover{background:var(--green-light)}.full-width{width:100%}.btn-danger{padding:10px 16px;border-radius:8px;background:var(--danger);color:#fff;font-size:14px;font-weight:600;transition:opacity .15s;border:none;cursor:pointer}.btn-danger:hover{opacity:.85}.icon-btn-sm{background:none;border:none;font-size:16px;padding:4px 6px;border-radius:6px;cursor:pointer;transition:background .15s}.icon-btn-sm:hover{background:var(--bg)}.list{padding:8px 12px 16px}.saving-card{display:flex;align-items:center;gap:14px;background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:14px;margin-bottom:8px;cursor:pointer;transition:box-shadow .15s,transform .1s}.saving-card:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.saving-card:active{transform:scale(.99)}.saving-emoji-box{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.saving-emoji{font-size:26px}.saving-info{flex:1;display:flex;flex-direction:column;gap:3px;min-width:0}.saving-cat{font-size:13px;font-weight:600;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.saving-date{font-size:12px;color:var(--text-faint)}.saving-amount{font-size:22px;font-weight:700;white-space:nowrap;flex-shrink:0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:8px}.empty-icon{font-size:56px;opacity:.4}.empty-text{font-size:16px;color:var(--text-muted)}.empty-sub{font-size:13px;color:var(--text-faint)}.modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:flex-end;justify-content:center;z-index:1000;padding:0}.modal{background:var(--surface);border-radius:var(--radius-lg) var(--radius-lg) 0 0;width:100%;max-width:480px;padding:20px 20px 40px;max-height:90vh;overflow-y:auto}.modal-title{font-size:18px;font-weight:700;margin-bottom:16px;color:var(--text)}.modal-body{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.modal-actions{display:flex;justify-content:flex-end;gap:8px;align-items:center}.field-label{font-size:13px;font-weight:600;color:var(--text-muted);display:block;margin-bottom:-4px}.menu-item{display:flex;align-items:center;gap:12px;width:100%;padding:14px 16px;font-size:16px;border-radius:8px;color:var(--text);margin-bottom:4px;transition:background .12s;background:none;border:none;cursor:pointer;text-align:left}.menu-item:hover{background:var(--bg)}.menu-item-danger{color:var(--danger)}.cal-header{background:var(--green-container);padding:16px;text-align:center;flex-shrink:0}.cal-month-label{display:block;font-size:14px;color:#166534}.cal-month-total{display:block;font-size:32px;font-weight:700;color:#14532d}.cal-nav{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.cal-nav-btn{font-size:24px;color:var(--green);width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .12s;border:none;background:none;cursor:pointer}.cal-nav-btn:hover:not(:disabled){background:var(--green-light)}.cal-nav-btn:disabled{color:var(--border);cursor:default}.cal-nav-label{font-size:15px;font-weight:600;color:var(--text)}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;padding:6px 8px;background:var(--surface);flex-shrink:0}.cal-dow{text-align:center;font-size:12px;font-weight:600;color:var(--text-muted);padding:4px 0}.cal-dow.cal-sat{color:#2563eb}.cal-dow.cal-sun{color:var(--danger)}.cal-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4px 2px;border-radius:8px;min-height:44px;background:none;border:none;transition:background .12s;cursor:pointer}.cal-cell:hover:not(.cal-future):not(:disabled){background:var(--green-light)}.cal-cell.cal-sat .cal-day-num{color:#2563eb}.cal-cell.cal-sun .cal-day-num{color:var(--danger)}.cal-cell.cal-future{opacity:.35;cursor:default}.cal-cell.cal-today{background:#dbeafe}.cal-cell.cal-today .cal-day-num{font-weight:700}.cal-cell.cal-selected{background:var(--green)}.cal-cell.cal-selected .cal-day-num{color:#fff;font-weight:700}.cal-cell.cal-selected .cal-day-amount{color:#ffffffd9}.cal-day-num{font-size:13px;color:var(--text)}.cal-day-amount{font-size:9px;color:var(--green);font-weight:700;white-space:nowrap}.cal-divider{height:1px;background:var(--border);flex-shrink:0}.goal-screen{padding:16px 16px calc(var(--nav-h) + 16px);gap:14px;display:flex;flex-direction:column;overflow-y:auto;min-height:0}.card{background:var(--surface);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow);flex-shrink:0}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.card-title{font-size:16px;font-weight:700}.card-sub{font-size:12px;color:var(--text-faint)}.card-divider{height:1px;background:var(--border);margin:0 -4px}.goal-card-large{display:flex;flex-direction:column;align-items:center;padding:24px 28px;gap:12px}.goal-card-top{width:100%;display:flex;align-items:center;justify-content:space-between}.goal-label-text{font-size:14px;color:var(--text-muted)}.circular-progress-wrap{position:relative;display:flex;align-items:center;justify-content:center}.circular-progress-center{position:absolute;display:flex;flex-direction:column;align-items:center;pointer-events:none}.pct-text{font-size:42px;font-weight:700;line-height:1}.pct-sub{font-size:13px;color:var(--text-faint)}.goal-amounts{text-align:center}.goal-remaining{font-size:14px;color:var(--text-muted)}.motivation-msg{font-size:15px;text-align:center;color:var(--text)}.goal-card-compact{display:flex;align-items:center;gap:14px;padding:14px}.compact-pct{position:absolute;font-size:9px;font-weight:700;top:50%;left:50%;transform:translate(-50%,-50%)}.compact-goal-top{display:flex;align-items:center;justify-content:space-between;gap:6px;margin-bottom:6px}.compact-goal-label{font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.compact-goal-bottom{display:flex;justify-content:space-between;margin-top:4px}.period-badge{font-size:12px;font-weight:600;color:var(--green-dark);background:var(--green-light);padding:3px 10px;border-radius:12px;white-space:nowrap;flex-shrink:0}.progress-bar-track{height:6px;background:var(--border);border-radius:3px;overflow:hidden}.progress-bar-fill{height:100%;border-radius:3px;transition:width .4s ease;min-width:0}.pace-badge{width:100%;padding:6px 12px;border-radius:8px;font-size:12px;text-align:center}.pace-ok{background:#f0fdf4;color:#15803d}.pace-warn{background:#fff7ed;color:#c2410c}.goal-empty{display:flex;flex-direction:column;align-items:center;padding:36px 28px;gap:8px}.cat-bar-item{margin-bottom:12px}.cat-bar-top{display:flex;justify-content:space-between;margin-bottom:4px}.cat-bar-name{font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.cat-bar-amount{font-size:12px;color:var(--text-muted);font-weight:600;flex-shrink:0;margin-left:8px}.stat-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0}.stat-label{font-size:14px;color:var(--text-muted)}.stat-value{font-size:16px;font-weight:700}.achievement-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}.achievement-item:last-child{border-bottom:none}.achievement-icon{width:40px;height:40px;background:#fefce8;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.achievement-label{font-size:14px;font-weight:600}.achievement-sub{font-size:12px;color:var(--text-muted)}.achievement-date{font-size:12px;color:var(--text-faint);flex-shrink:0}.achievement-more{font-size:12px;color:var(--text-faint);margin-top:4px}.segment-buttons{display:flex;border:1.5px solid var(--border);border-radius:8px;overflow:hidden}.segment-btn{flex:1;padding:8px 4px;font-size:13px;color:var(--text-muted);border-right:1px solid var(--border);transition:all .12s;background:var(--surface);border-top:none;border-bottom:none;border-left:none;cursor:pointer}.segment-btn:last-child{border-right:none}.segment-btn-active{background:var(--green);color:#fff;font-weight:600}.settings-screen{padding:0 0 calc(var(--nav-h) + 16px)}.settings-section{padding:16px 16px 8px}.settings-heading{font-size:18px;font-weight:700;margin-bottom:12px;color:var(--text)}.settings-divider{height:8px;background:var(--bg);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.settings-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border);font-size:15px}.settings-row:last-child{border-bottom:none}.cat-list-item{display:flex;align-items:center;gap:14px;padding:10px 0;border-bottom:1px solid var(--border)}.cat-list-item:last-child{border-bottom:none}.cat-emoji-box{width:40px;height:40px;background:var(--bg);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cat-list-name{flex:1;font-size:15px}.cat-list-actions{display:flex;gap:4px}.cat-add-btn{display:flex;align-items:center;gap:8px;padding:12px 0;font-size:15px;color:var(--green);font-weight:600;width:100%;transition:color .12s;background:none;border:none;cursor:pointer;text-align:left}.cat-add-btn:hover{color:var(--green-dark)}.danger-list-item{display:flex;align-items:flex-start;gap:14px;padding:14px 0;width:100%;font-size:15px;text-align:left;transition:background .12s;border-radius:8px;background:none;border:none;cursor:pointer}.danger-list-item>span{font-size:20px;padding-top:2px}.danger-list-item:hover{background:#fef2f2}.toast{position:fixed;bottom:calc(var(--nav-h) + 16px);left:50%;transform:translate(-50%);background:#1e293b;color:#fff;padding:10px 20px;border-radius:24px;font-size:14px;font-weight:500;white-space:nowrap;z-index:2000;box-shadow:0 4px 12px #0003;animation:slideUp .2s ease}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.screen::-webkit-scrollbar,.goal-screen::-webkit-scrollbar,.settings-screen::-webkit-scrollbar,.modal::-webkit-scrollbar{width:4px}.screen::-webkit-scrollbar-thumb,.goal-screen::-webkit-scrollbar-thumb,.settings-screen::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.login-screen{display:flex;align-items:center;justify-content:center;height:100%;background:linear-gradient(160deg,#f0fdf4,#dcfce7);padding:24px}.login-card{background:#fff;border-radius:28px;padding:40px 28px;width:100%;max-width:360px;display:flex;flex-direction:column;align-items:center;gap:12px;box-shadow:0 8px 32px #0000001a}.login-icon{width:96px;height:96px;border-radius:24px}.login-title{font-size:28px;font-weight:700;color:var(--text);margin:0}.login-desc{font-size:15px;color:var(--text-muted);text-align:center;line-height:1.6;margin:0}.login-google-btn{display:flex;align-items:center;gap:12px;padding:14px 24px;border-radius:12px;border:1.5px solid var(--border);background:#fff;font-size:15px;font-weight:600;color:var(--text);width:100%;justify-content:center;margin-top:8px;transition:background .15s,box-shadow .15s;cursor:pointer}.login-google-btn:hover{background:var(--bg);box-shadow:var(--shadow)}.login-note{font-size:12px;color:var(--text-faint);text-align:center;line-height:1.6;margin:0}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:16px;background:var(--bg)}.loading-icon{width:80px;height:80px;border-radius:20px;animation:pulse 1.5s ease-in-out infinite}.loading-text{font-size:14px;color:var(--text-faint)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@media(min-width:480px){body{background:#cbd5e1}.app{box-shadow:0 0 40px #00000026}.modal-overlay{align-items:center}.modal{border-radius:var(--radius-lg);padding-bottom:24px}}
