:root{--bg:#f5f6fa;--card-bg:#fff;--text:#2a2118;--text-muted:#7a6b5a;--border:#e6e8ef;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;font:16px/1.5 system-ui,-apple-system,sans-serif}@media (prefers-color-scheme:dark){:root{--bg:#f5f6fa;--card-bg:#fff;--text:#2a2118;--text-muted:#7a6b5a;--border:#e6e8ef}}*{box-sizing:border-box;margin:0;padding:0}html{background:var(--bg)}body{min-width:0;margin:0}#root{max-width:1120px;padding:0 max(16px, env(safe-area-inset-left)) max(80px, env(safe-area-inset-bottom)) max(16px, env(safe-area-inset-right));margin:0 auto}:root{--radius:8px;--radius-card:8px;--shadow-sm:0 1px 2px #141b250d;--shadow:0 1px 2px #141b250a, 0 10px 22px -20px #141b2557;--shadow-lg:0 18px 44px -30px #141b256b;--accent:#0f766e;--accent-strong:#115e59;--success:#047857;--danger:#b91c1c;--font-sans:"Inter", "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif}@media (prefers-color-scheme:dark){:root{--shadow-sm:0 1px 2px #00000047;--shadow:0 12px 28px -24px #000000db;--shadow-lg:0 24px 56px -28px #000000c7}}body{font-family:var(--font-sans);background-color:var(--bg);color:var(--text);margin:0;transition:background-color .3s,color .3s}.app{box-sizing:border-box;font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1;letter-spacing:0;max-width:980px;margin:0 auto;padding:28px 12px 48px}.card-balance,.carry-over-amount,.donut-center-value,.transfer-row .amount,.legend-value{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}.toast{z-index:20;border-radius:var(--radius);background:color-mix(in srgb, var(--card-bg) 92%, var(--success));width:fit-content;max-width:100%;box-shadow:var(--shadow);color:var(--success);border:1px solid #05966938;align-items:center;gap:7px;margin:-8px auto 16px;padding:9px 13px;font-size:13px;font-weight:800;display:flex;position:sticky;top:12px}header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;padding:4px 0 24px;display:flex}.header-logo{align-items:center;gap:8px;display:flex}.logo-icon{color:var(--accent)}header h1{letter-spacing:0;color:var(--text);margin:0;font-size:22px;font-weight:800}.header-info{box-shadow:none;color:var(--text-muted);background:0 0;border:none;flex-wrap:wrap;flex:420px;justify-content:flex-start;gap:6px;min-width:260px;padding:0;font-size:12px;display:flex}.info-item{border:1px solid var(--border);border-radius:var(--radius);background:color-mix(in srgb, var(--card-bg) 92%, var(--bg));min-height:30px;color:var(--text-muted);white-space:nowrap;align-items:center;gap:6px;padding:5px 9px;display:flex}.header-actions{justify-content:flex-end;align-items:center;gap:8px;display:flex}.settings-button{border:1px solid var(--border);border-radius:var(--radius);background:var(--card-bg);color:var(--text-muted);cursor:pointer;justify-content:center;align-items:center;width:34px;height:34px;padding:0;transition:background-color .2s,border-color .2s,color .2s;display:inline-flex}.settings-button:hover{background:var(--bg);border-color:color-mix(in srgb, var(--accent) 42%, var(--border));color:var(--accent)}.sync-button{border:1px solid var(--border);border-radius:var(--radius);background:var(--card-bg);color:var(--text-muted);cursor:pointer;min-height:32px;font:inherit;align-items:center;gap:7px;padding:7px 11px;font-size:12px;font-weight:800;transition:background-color .2s,border-color .2s,color .2s;display:inline-flex}.sync-button.active{border-color:color-mix(in srgb, var(--success) 32%, var(--border));background:color-mix(in srgb, var(--card-bg) 92%, var(--success));color:var(--success)}.sync-button.error{border-color:color-mix(in srgb, var(--danger) 32%, var(--border));background:color-mix(in srgb, var(--card-bg) 92%, var(--danger));color:var(--danger)}.sync-button:hover{background:var(--bg);border-color:color-mix(in srgb, var(--accent) 42%, var(--border));color:var(--accent)}.sync-label-short{display:none}.spin{animation:.9s linear infinite spin}.auth-gate{place-items:center;min-height:calc(100dvh - 80px);padding:32px 0;display:grid}.auth-panel{border:1px solid var(--border);border-radius:var(--radius);background:var(--card-bg);width:min(100%,380px);box-shadow:var(--shadow);flex-direction:column;align-items:stretch;gap:18px;padding:26px;display:flex}.auth-mark{border-radius:var(--radius);background:color-mix(in srgb, var(--card-bg) 88%, var(--accent));width:50px;height:50px;color:var(--accent);place-items:center;display:grid}.auth-title-group{flex-direction:column;gap:4px;display:flex}.auth-title-group p{color:var(--accent);margin:0;font-size:13px;font-weight:800}.auth-title-group h1{color:var(--text);letter-spacing:0;margin:0;font-size:24px;line-height:1.2}.auth-login-btn{border-radius:var(--radius);background:var(--accent);color:#fff;min-height:46px;font:inherit;cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;padding:0 16px;font-size:14px;font-weight:800;transition:opacity .2s,transform .2s;display:inline-flex}.auth-login-btn:hover:not(:disabled){background:var(--accent-strong)}.auth-login-btn:disabled{cursor:not-allowed;opacity:.62}.auth-error{color:var(--danger);margin:0;font-size:12px;font-weight:700}.chart-section{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-card);box-shadow:var(--shadow);margin-bottom:22px;padding:22px;position:relative;overflow:hidden}.chart-section.is-compact{padding:18px}.donut-chart-container{flex-flow:wrap;justify-content:center;align-items:center;gap:32px;display:flex}.donut-chart-container.compact{gap:16px}.donut-chart-container.empty{min-height:160px}.donut-chart-container.empty.compact{min-height:124px}.svg-wrapper{width:160px;height:160px;position:relative}.donut-center{pointer-events:none;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.donut-center-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:0;text-align:center;white-space:nowrap;text-overflow:ellipsis;max-width:100px;font-size:11px;font-weight:600;overflow:hidden}.donut-center-value{letter-spacing:0;margin:2px 0;font-size:20px;font-weight:800;transition:color .3s}.donut-center-sub{color:var(--text-muted);font-size:11px;font-weight:700}.donut-chart-container.compact .donut-center-value{font-size:18px}.chart-legend{flex-direction:column;flex:auto;gap:8px;min-width:180px;max-width:380px;max-height:160px;padding-right:6px;display:flex;overflow-y:auto}.chart-legend::-webkit-scrollbar{width:4px}.chart-legend::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.legend-item{border-radius:var(--radius);cursor:pointer;align-items:center;padding:6px 7px;font-size:12px;transition:background-color .2s,color .2s;display:flex}.legend-item:hover,.legend-item.active{background:color-mix(in srgb, var(--card-bg) 90%, var(--accent))}.legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-right:8px}.legend-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;flex:1;font-weight:500;overflow:hidden}.legend-value{color:var(--text-muted);margin-left:8px;font-weight:700}.top-summary{grid-template-columns:minmax(0,1.15fr) minmax(260px,.85fr);align-items:stretch;gap:10px;margin-bottom:22px;display:grid}.top-summary .free-section,.top-summary .carry-over-card{margin-bottom:0}.top-summary .account-card,.top-summary .carry-over-card{min-height:128px}.carry-over-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-card);text-align:center;cursor:pointer;width:100%;box-shadow:var(--shadow);font:inherit;color:inherit;flex-direction:column;justify-content:center;margin-bottom:20px;padding:18px 20px;transition:border-color .2s,background .2s,box-shadow .2s;display:flex;position:relative;overflow:hidden}.carry-over-card:hover{border-color:color-mix(in srgb, var(--accent) 48%, var(--border));background:color-mix(in srgb, var(--card-bg) 96%, var(--accent));box-shadow:var(--shadow-lg)}.carry-over-label{color:var(--accent);justify-content:center;align-items:center;gap:6px;margin-bottom:6px;font-size:12px;font-weight:700;display:flex}.carry-over-edit{color:var(--text-muted)}.carry-over-amount{color:var(--text);letter-spacing:0;font-size:28px;font-weight:800}.carry-over-meta{color:var(--text-muted);margin-top:4px;font-size:12px;font-weight:700}.free-section{margin-bottom:24px}.free-section .account-card{background:var(--card-bg);border-left-width:4px;border-color:var(--border);border-left-color:var(--success)}.free-section .account-card:hover{background:color-mix(in srgb, var(--card-bg) 96%, var(--success))}.free-section .card-balance{font-size:26px}.section{margin-bottom:26px}.section h2{letter-spacing:0;color:var(--text-muted);align-items:center;gap:6px;margin-bottom:10px;padding-left:0;font-size:13px;font-weight:800;display:flex}.section-hint{color:var(--text-muted);margin:0 0 12px;padding-left:6px;font-size:11px;line-height:1.5}.section-empty{color:var(--text-muted);border:1px dashed var(--border);border-radius:var(--radius);background:var(--card-bg);text-align:center;padding:16px;font-size:12px}.section-count{background:var(--card-bg);border:1px solid var(--border);min-width:20px;height:20px;color:var(--text);border-radius:999px;justify-content:center;align-items:center;padding:0 6px;font-size:12px;line-height:1;display:inline-flex}.section-help{border-radius:var(--radius);width:22px;height:22px;color:var(--text-muted);cursor:help;opacity:.74;justify-content:center;align-items:center;display:inline-flex}.section-help:hover,.section-help:focus-visible{background:color-mix(in srgb, var(--bg) 72%, var(--border));color:var(--text);opacity:1;outline:none}@media (width<=640px){.app{padding:14px 0 36px}header{padding:10px 0 18px}.header-info{width:100%}.sync-button{justify-content:center;width:auto;min-width:112px;min-height:40px}.sync-label-full{display:none}.sync-label-short{display:inline}.header-actions{align-self:flex-start;width:auto}.settings-button{flex:0 0 40px;width:40px;height:40px}.chart-section{margin-bottom:20px;padding:18px 14px}.donut-chart-container{gap:18px}.chart-legend{min-width:100%;max-height:none;padding-right:0}.account-row{padding:16px}.cards-grid{grid-template-columns:1fr}.top-summary{grid-template-columns:1fr;gap:10px;margin-bottom:20px}.top-summary .account-card,.top-summary .carry-over-card{min-height:116px}.account-card{min-height:88px;padding:16px}.card-icon-btn{width:38px;height:38px}.btn-add,.btn-reset{min-height:44px;font-size:12px}.modal{max-width:100%;padding:20px}.sync-code-box{grid-template-columns:1fr}.sync-copy-btn{width:100%}.modal-actions button{min-height:44px}}.account-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-card);box-shadow:var(--shadow);-webkit-user-select:none;user-select:none;border-left:4px solid #ccc;flex-direction:column;gap:10px;min-height:92px;padding:16px;transition:transform .2s,box-shadow .2s,background-color .2s,border-color .2s;display:flex;position:relative;overflow:hidden}.account-card.is-editable{cursor:pointer}.account-card.is-editable:focus-visible{outline-offset:3px;outline:3px solid #0d948847}.account-card.is-draggable{cursor:grab;touch-action:none}@media (hover:hover){.account-card.is-editable:hover,.account-card.is-draggable:not(.is-dragging):hover{box-shadow:var(--shadow-lg);border-color:color-mix(in srgb, var(--accent) 38%, var(--border));background:color-mix(in srgb, var(--card-bg) 97%, var(--accent));transform:translateY(-1px)}}.account-card.is-draggable:active{cursor:grabbing;transform:scale(.97)translateY(0)}.account-card.is-dragging{cursor:grabbing;opacity:.96;z-index:50;will-change:transform;transition:none;box-shadow:0 22px 44px -10px #0f172a80,0 10px 18px -8px #0f172a59}.card-drag-badge{border-radius:var(--radius);color:#fff;white-space:nowrap;pointer-events:none;z-index:60;align-items:center;gap:5px;padding:6px 12px;font-size:13px;font-weight:800;display:inline-flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 4px 12px #0f172a4d}.card-drag-badge.transfer{background:#ec4899}.card-drag-badge.reorder{background:#16a34a}.card-drag-badge.blocked{background:#6b7280}.account-card.drag-over{z-index:20;transition:transform .18s cubic-bezier(.34,1.56,.64,1);animation:.7s ease-in-out infinite dropTargetPulse;transform:scale(1.06);box-shadow:0 0 0 4px #ec4899,0 12px 28px #ec489973}@keyframes dropTargetPulse{0%,to{box-shadow:0 0 0 4px #ec4899,0 12px 28px #ec489973}50%{box-shadow:0 0 0 10px #ec48994d,0 18px 36px #ec48998c}}.account-card.drag-over-before,.account-card.drag-over-after{transition:box-shadow .18s}.account-card.drag-over-before{box-shadow:inset 8px 0 0 0 #16a34a, 0 0 0 3px #16a34a80, var(--shadow);animation:.7s ease-in-out infinite reorderEdgePulseLeft}.account-card.drag-over-after{box-shadow:inset -8px 0 0 0 #16a34a, 0 0 0 3px #16a34a80, var(--shadow);animation:.7s ease-in-out infinite reorderEdgePulseRight}@keyframes reorderEdgePulseLeft{0%,to{box-shadow:inset 6px 0 0 0 #16a34a, 0 0 0 2px #16a34a66, var(--shadow)}50%{box-shadow:inset 10px 0 0 0 #16a34a, 0 0 0 5px #16a34a59, var(--shadow)}}@keyframes reorderEdgePulseRight{0%,to{box-shadow:inset -6px 0 0 0 #16a34a, 0 0 0 2px #16a34a66, var(--shadow)}50%{box-shadow:inset -10px 0 0 0 #16a34a, 0 0 0 5px #16a34a59, var(--shadow)}}@media (prefers-reduced-motion:reduce){.account-card.drag-over,.account-card.drag-over-before,.account-card.drag-over-after{animation:none}}.account-card.negative .card-balance{color:var(--danger)!important}.view-toggle-bar{justify-content:flex-end;margin:-8px 0 16px;display:flex}.view-toggle{background:color-mix(in srgb, var(--border) 72%, var(--bg));border-radius:var(--radius);gap:3px;padding:3px;display:inline-flex}.view-toggle button{color:var(--text-muted);font:inherit;cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:5px;padding:6px 10px;font-size:12px;font-weight:700;transition:background-color .15s,color .15s;display:inline-flex}.view-toggle button.active{background:var(--card-bg);color:var(--text);box-shadow:0 1px 1px #141b250f}.cards-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}@media (width<=900px){.cards-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=640px){.cards-grid{grid-template-columns:1fr}}.account-list{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-card);box-shadow:var(--shadow);overflow:hidden}.account-row{border-bottom:1px solid var(--border);cursor:pointer;-webkit-tap-highlight-color:transparent;align-items:center;gap:12px;padding:13px 15px;transition:background-color .15s;display:flex}.account-row:last-child{border-bottom:none}@media (hover:hover){.account-row:hover{background:color-mix(in srgb, var(--card-bg) 96%, var(--accent))}}.account-row:focus-visible{outline-offset:-2px;outline:2px solid #0d948866}.row-icon{border-radius:var(--radius);flex-shrink:0;place-items:center;width:36px;height:36px;display:grid}.row-main{flex-direction:column;flex:1;gap:6px;min-width:0;display:flex}.row-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:750;overflow:hidden}.row-share-track{background:var(--border);border-radius:999px;max-width:160px;height:3px;overflow:hidden}.row-share-fill{border-radius:999px;height:100%;transition:width .3s}.row-meta{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:2px;display:flex}.row-balance{color:var(--text);font-variant-numeric:tabular-nums;white-space:nowrap;font-size:15px;font-weight:800}.account-row.negative .row-balance{color:var(--danger)}.row-pct{color:var(--text-muted);font-variant-numeric:tabular-nums;font-size:11px;font-weight:700}.row-menu{border-radius:var(--radius);width:34px;height:34px;color:var(--text-muted);cursor:pointer;opacity:.6;background:0 0;border:none;flex-shrink:0;place-items:center;transition:background-color .15s,color .15s,opacity .15s;display:grid}.row-menu:hover{background:color-mix(in srgb, var(--bg) 72%, var(--border));color:var(--text);opacity:1}.card-title-group{align-items:center;gap:8px;min-width:0;display:flex}.account-icon{flex-shrink:0;justify-content:center;align-items:center;display:flex}.card-header{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.card-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:700;overflow:hidden}.card-tools{flex-shrink:0;align-items:center;gap:2px;display:flex}.card-icon-btn{border-radius:var(--radius);width:28px;height:28px;color:var(--text-muted);cursor:pointer;opacity:.55;background:0 0;border:none;justify-content:center;align-items:center;padding:0;transition:background-color .2s,color .2s,opacity .2s;display:flex}.card-icon-btn:hover{background:color-mix(in srgb, var(--bg) 72%, var(--border));color:var(--text);opacity:1}.card-balance{letter-spacing:0;word-break:keep-all;margin:2px 0 0;font-size:20px;font-weight:800}.card-share{align-items:center;gap:8px;margin-top:auto;display:flex}.card-share-track{background:var(--border);border-radius:999px;flex:1;height:4px;overflow:hidden}.card-share-fill{border-radius:999px;height:100%;transition:width .3s}.card-share-pct{color:var(--text-muted);text-align:right;font-variant-numeric:tabular-nums;min-width:30px;font-size:11px;font-weight:700}.btn-add{border:1px dashed var(--border);border-radius:var(--radius);width:100%;color:var(--text-muted);cursor:pointer;background:0 0;justify-content:center;align-items:center;gap:6px;margin-top:14px;padding:12px;font-size:13px;font-weight:700;transition:all .2s;display:flex}.btn-add:hover{border-color:color-mix(in srgb, var(--accent) 48%, var(--border));background:color-mix(in srgb, var(--card-bg) 96%, var(--accent));color:var(--accent)}.transfers{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-card);box-shadow:var(--shadow);flex-direction:column;display:flex;overflow:hidden}.transfer-row{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:12px 15px;font-size:13px;transition:background-color .2s;display:flex}.transfer-row:hover{background:color-mix(in srgb, var(--card-bg) 94%, var(--accent))}.transfer-row:last-child{border-bottom:none}.transfer-info{flex:auto;align-items:center;gap:8px;min-width:0;font-weight:600;display:flex}.transfer-info .from,.transfer-info .to{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.transfer-date{color:var(--text-muted);white-space:nowrap;flex-shrink:0;font-size:11px}.transfer-undo{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;transition:background-color .2s,color .2s;display:inline-flex}.transfer-undo:hover{background:color-mix(in srgb, var(--card-bg) 90%, var(--danger));color:var(--danger)}.transfer-info .from{color:var(--text-muted)}.transfer-info .to{color:var(--text)}.transfer-info .arrow{color:var(--text-muted)}.transfer-row .amount{color:var(--accent);flex-shrink:0;font-weight:700}.btn-clear{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;margin:8px auto 0;padding:6px 12px;font-size:11px;font-weight:600;transition:all .2s;display:block}.btn-clear:hover{background:color-mix(in srgb, var(--card-bg) 92%, var(--danger));color:var(--danger)}footer{text-align:center;z-index:10;margin-top:40px;position:relative}.btn-reset{border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);cursor:pointer;z-index:11;background:0 0;align-items:center;gap:6px;padding:6px 16px;font-size:11px;font-weight:600;transition:all .2s;display:inline-flex;position:relative}.btn-reset:hover{background:color-mix(in srgb, var(--card-bg) 92%, var(--danger));border-color:color-mix(in srgb, var(--danger) 38%, var(--border));color:var(--danger)}.modal-overlay{-webkit-backdrop-filter:blur(8px);z-index:100;background:#0a0c1075;justify-content:center;align-items:flex-start;padding:16px;animation:.18s ease-out fadeIn;display:flex;position:fixed;inset:0;overflow-y:auto}.modal{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:350px;max-height:calc(100dvh - 32px);box-shadow:var(--shadow-lg);box-sizing:border-box;margin:auto;padding:22px;animation:.18s ease-out scaleUp;position:relative;overflow-y:auto}.modal-wide{max-width:440px}.settings-preview{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:16px;display:grid}.settings-preview div{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);justify-content:space-between;align-items:center;gap:10px;min-width:0;padding:10px 12px;display:flex}.settings-preview span{color:var(--text-muted);white-space:nowrap;font-size:11px;font-weight:800}.settings-preview strong{color:var(--text);white-space:nowrap;font-size:13px;font-weight:800}@media (width<=420px){.settings-preview{grid-template-columns:1fr}}.sync-panel{flex-direction:column;gap:14px;display:flex}.google-login-btn{border:1px solid var(--border);border-radius:var(--radius);background:var(--card-bg);width:100%;min-height:44px;color:var(--text);cursor:pointer;font:inherit;justify-content:center;align-items:center;gap:8px;font-size:13px;font-weight:800;display:inline-flex}.google-login-btn:hover{background:var(--bg);border-color:color-mix(in srgb, var(--accent) 48%, var(--border));color:var(--accent)}.google-login-btn:disabled{opacity:.55;cursor:not-allowed}.sync-divider{color:var(--text-muted);align-items:center;gap:10px;font-size:11px;font-weight:800;display:flex}.sync-divider:before,.sync-divider:after{content:"";background:var(--border);flex:1;height:1px}.sync-account{border:1px solid color-mix(in srgb, var(--success) 28%, var(--border));border-radius:var(--radius);background:color-mix(in srgb, var(--card-bg) 92%, var(--success));color:var(--success);align-items:center;gap:10px;padding:12px;display:flex}.sync-account div{flex-direction:column;gap:2px;min-width:0;display:flex}.sync-account strong,.sync-account span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.sync-account strong{color:var(--text);font-size:13px}.sync-account span,.sync-message,.sync-error{font-size:12px;font-weight:700}.sync-code-box{grid-template-columns:1fr auto;align-items:end;gap:8px;display:grid}.sync-code-box label{color:var(--text-muted);grid-column:1/-1;font-size:11px;font-weight:800}.sync-code-box textarea{resize:vertical;word-break:break-all;min-height:78px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12px;line-height:1.45}.sync-copy-btn{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);cursor:pointer;min-height:42px;font:inherit;white-space:nowrap;justify-content:center;align-items:center;gap:6px;padding:0 12px;font-size:12px;font-weight:800;display:inline-flex}.sync-copy-btn:hover{background:var(--card-bg);border-color:color-mix(in srgb, var(--accent) 48%, var(--border));color:var(--accent)}.sync-message{color:var(--success)}.sync-error{color:var(--danger)}.sync-empty{text-align:center;color:var(--text-muted);flex-direction:column;align-items:center;gap:10px;display:flex}.modal-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.modal-header h3{color:var(--text);margin:0;font-size:16px;font-weight:800}.modal-close{border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;width:28px;height:28px;color:var(--text-muted);background:0 0;justify-content:center;align-items:center;transition:all .2s;display:flex}.modal-close:hover{background:var(--bg);color:var(--text)}.modal-desc{color:var(--text-muted);text-align:center;margin:0 0 16px;font-size:13px;line-height:1.5}.modal-route{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);justify-content:center;align-items:center;gap:12px;margin-bottom:20px;padding:12px 16px;font-size:14px;font-weight:700;display:flex}.modal-from,.modal-to{color:var(--text)}.modal-arrow{color:var(--accent);align-items:center;display:flex}.modal-select{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);outline:none;padding:6px 12px;font-size:13px;font-weight:700}.modal-form-group{text-align:left;flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.modal-form-group label{color:var(--text-muted);text-transform:uppercase;letter-spacing:0;font-size:11px;font-weight:700}.modal-text-input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);box-sizing:border-box;outline:none;width:100%;padding:10px 14px;font-size:14px;font-weight:600;transition:border-color .2s}.modal-text-input:focus{border-color:color-mix(in srgb, var(--accent) 58%, var(--border))}textarea.modal-text-input{resize:vertical;min-height:88px;line-height:1.45}.type-toggle{background:color-mix(in srgb, var(--border) 72%, var(--bg));border-radius:var(--radius);gap:4px;padding:4px;display:flex}.type-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;flex:1;padding:8px;font-size:12px;font-weight:700;transition:all .2s}.type-btn.active{background:var(--card-bg);color:var(--text);box-shadow:0 1px 1px #141b250f}.icon-selector-grid{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);grid-template-columns:repeat(5,1fr);gap:8px;max-height:150px;padding:4px;display:grid;overflow-y:auto}.icon-select-btn{border-radius:var(--radius);cursor:pointer;color:var(--text-muted);background:0 0;border:1px solid #0000;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;transition:all .2s;display:flex}.icon-select-btn span{white-space:nowrap;text-overflow:ellipsis;width:100%;font-size:9px;font-weight:600;overflow:hidden}.icon-select-btn:hover{background:color-mix(in srgb, var(--bg) 72%, var(--border));color:var(--text)}.icon-select-btn.active{border-color:color-mix(in srgb, var(--accent) 58%, var(--border));background:color-mix(in srgb, var(--card-bg) 92%, var(--accent));color:var(--accent)}.bank-badge{border-radius:var(--radius);background:var(--bg);border:1px solid var(--border);max-width:100%;color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;align-self:flex-start;align-items:center;gap:5px;margin:4px 0 0;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex;overflow:hidden}.bank-dot{border-radius:999px;flex-shrink:0;width:8px;height:8px}.bank-dot.none{background:var(--border)}.row-name-line{align-items:center;gap:8px;min-width:0;display:flex}.row-name-line .bank-badge{margin:0}.bank-selector-grid{flex-wrap:wrap;gap:8px;display:flex}.bank-select-btn{border-radius:var(--radius);border:1px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;align-items:center;gap:6px;padding:7px 12px;font-size:13px;font-weight:600;transition:all .2s;display:inline-flex}.bank-select-btn:hover{color:var(--text)}.bank-select-btn.active{border-color:color-mix(in srgb, var(--accent) 58%, var(--border));background:color-mix(in srgb, var(--card-bg) 92%, var(--accent));color:var(--accent)}.color-selector-grid{flex-wrap:wrap;gap:8px;display:flex}.color-select-btn{cursor:pointer;border:1px solid #0000;border-radius:999px;width:28px;height:28px;padding:0;transition:transform .15s,border-color .15s}.color-select-btn:hover{transform:scale(1.04)}.color-select-btn.active{border-color:var(--text);box-shadow:0 0 0 2px var(--card-bg) inset}.modal-hint{color:var(--text-muted);text-align:center;margin:-10px 0 16px;font-size:12px}.modal-hint.warn{color:var(--danger);font-weight:700}.modal-input-row{justify-content:center;align-items:center;gap:8px;margin-bottom:20px;display:flex}.modal-input-row span{color:var(--text);font-size:26px;font-weight:800}.modal-input-row input{text-align:center;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);min-width:0;max-width:280px;color:var(--text);outline:none;flex:1;padding:10px 12px;font-size:22px;font-weight:800;transition:border-color .2s}.modal-input-row.compact input{width:100%;padding:8px;font-size:20px}.modal-input-row input:focus{border-color:color-mix(in srgb, var(--accent) 58%, var(--border))}.modal-actions{gap:10px;margin-top:8px;display:flex}.modal-actions button{border-radius:var(--radius);cursor:pointer;border:none;flex:1;padding:12px;font-size:14px;font-weight:700;transition:all .2s}.btn-cancel{background:color-mix(in srgb, var(--border) 70%, var(--bg));color:var(--text-muted)}.btn-cancel:hover{background:var(--bg);color:var(--text)}.btn-confirm{background:var(--accent);color:#fff;box-shadow:none}.btn-confirm:hover{background:var(--accent-strong)}.btn-confirm:disabled{background:var(--border);color:var(--text-muted);cursor:not-allowed;box-shadow:none;transform:none}.btn-confirm.btn-danger{background:var(--danger);box-shadow:none}.btn-confirm.btn-danger:hover{background:#b91c1c}.btn-confirm.btn-danger:disabled{background:var(--border);color:var(--text-muted);box-shadow:none;transform:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleUp{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}.build-tag{color:var(--text-muted);opacity:.35;letter-spacing:0;margin-left:8px;font-size:10px;font-weight:500;transition:opacity .2s}.header-logo:hover .build-tag{opacity:.7}.sheet-overlay{-webkit-backdrop-filter:blur(6px);z-index:110;background:#0a0c1075;justify-content:center;align-items:flex-end;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.action-sheet{width:100%;max-width:440px;margin:0 12px max(12px, env(safe-area-inset-bottom));background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-card);box-shadow:var(--shadow-lg);flex-direction:column;gap:2px;padding:10px;animation:.18s ease-out sheetUp;display:flex}@keyframes sheetUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.sheet-title{color:var(--text-muted);text-align:center;padding:8px 12px 6px;font-size:12px;font-weight:700}.sheet-item{width:100%;color:var(--text);border-radius:var(--radius);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:12px;padding:14px;font-family:inherit;font-size:15px;font-weight:600;transition:background-color .15s;display:flex}.sheet-item:hover{background:color-mix(in srgb, var(--bg) 72%, var(--border))}.sheet-item.danger{color:var(--danger)}.sheet-item.danger:hover{background:color-mix(in srgb, var(--card-bg) 92%, var(--danger))}.sheet-item.cancel{color:var(--text-muted);background:var(--bg);justify-content:center;margin-top:4px;font-weight:700}:root{--radius:8px;--radius-card:8px;--radius-pill:9999px;--bg:#fff7e8;--card-bg:#fff;--text:#2a2118;--text-muted:#7a6b5a;--border:#f0dec4;--accent:#ffa30d;--accent-strong:#ff6538;--accent-soft:#fff0cf;--success:#ffa30d;--danger:#d93b30;--shadow-sm:0 1px 4px #784d120f;--shadow:0 1px 4px #784d120f, 0 14px 36px -28px #ff84209e;--shadow-lg:0 16px 44px -26px #ff8420b8;--font-sans:"Noto Sans JP", Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}@media (prefers-color-scheme:dark){:root{--bg:#fff7e8;--card-bg:#fff;--text:#2a2118;--text-muted:#7a6b5a;--border:#f0dec4;--shadow-sm:0 1px 4px #784d120f;--shadow:0 1px 4px #784d120f, 0 14px 36px -28px #ff84209e;--shadow-lg:0 16px 44px -26px #ff8420b8}}#root{max-width:760px}.app{max-width:720px;padding-top:30px}header{align-items:flex-start;padding:2px 0 22px}.header-logo{gap:11px}.logo-icon{border-radius:var(--radius);background:linear-gradient(135deg, var(--accent), var(--accent-strong));color:#fff;width:38px;height:38px;padding:9px;box-shadow:0 10px 24px -16px #ff6538e6}header h1,.auth-title-group h1{color:var(--accent);font-weight:800}header h1{padding-top:5px;font-size:24px;line-height:1.1}.build-tag{color:#b79b73}.header-info{gap:8px}.info-item{border-radius:var(--radius-pill);min-height:32px;box-shadow:var(--shadow-sm);color:#6d6256;background:#ffffffdb;border:1px solid #f0dec4d9;padding:6px 11px;font-weight:600}.info-item svg{color:var(--accent)}.settings-button,.sync-button,.view-toggle,.view-toggle button,.btn-add,.btn-reset,.google-login-btn,.sync-copy-btn,.bank-badge,.bank-select-btn,.btn-clear,.sheet-item,.sheet-item.cancel{border-radius:var(--radius-pill)}.settings-button,.sync-button{min-height:38px;box-shadow:var(--shadow-sm);background:#ffffffe6;border-color:#f0dec4e6}.settings-button{width:38px;height:38px}.settings-button:hover,.sync-button:hover,.google-login-btn:hover,.sync-copy-btn:hover{color:var(--accent);background:#fffaf1;border-color:#ffa30d73}.sync-button.active{background:var(--accent-soft);color:#b86500;border-color:#ffa30d5c}.toast{border-radius:var(--radius-pill);color:#b86500;background:#fff;border-color:#ffa30d52}.auth-gate{min-height:calc(100dvh - 40px)}.auth-panel{max-width:520px;box-shadow:none;text-align:center;background:0 0;border:none;align-items:center;padding:34px 18px}.auth-mark{border-radius:var(--radius);background:linear-gradient(135deg, var(--accent), var(--accent-strong));color:#fff;width:76px;height:76px;box-shadow:0 18px 36px -22px #ff6538f2}.auth-title-group{align-items:center;gap:8px}.auth-title-group p{color:#9a8c78}.auth-title-group h1{font-size:clamp(30px,8vw,42px)}.auth-login-btn,.btn-confirm{border-radius:var(--radius-pill);background:linear-gradient(135deg, var(--accent), var(--accent-strong));color:#fff;box-shadow:0 10px 24px -16px #ff6538f2}.auth-login-btn:hover:not(:disabled),.btn-confirm:hover{background:linear-gradient(135deg,#ffb331,#ff7047)}.auth-error{color:var(--danger)}.top-summary{grid-template-columns:1fr;gap:12px;margin-bottom:18px}.chart-section,.account-card,.carry-over-card,.account-list,.transfers,.modal,.action-sheet,.section-empty,.settings-preview div{box-shadow:var(--shadow);background:#ffffffeb;border-color:#f0dec4eb}.chart-section,.carry-over-card{padding:20px}.account-card{border-left-width:5px}.free-section .account-card{border-color:#f0dec4eb;border-left-color:var(--accent);background:#fff}.free-section .account-card:hover,.carry-over-card:hover,.account-card.is-editable:hover,.account-card.is-draggable:not(.is-dragging):hover,.account-row:hover,.transfer-row:hover,.btn-add:hover{background:#fffaf1}.carry-over-label,.transfer-row .amount,.modal-arrow{color:#d47a00}.carry-over-amount,.card-balance,.row-balance{color:var(--text)}.donut-center-value{color:var(--accent)}.svg-wrapper circle:first-child{stroke:#eadfce}.section h2{color:#7c6141;font-size:13px}.section-count{color:#7c6141;background:#fff;border-color:#f0dec4e6}.section-help:hover,.section-help:focus-visible,.row-menu:hover,.card-icon-btn:hover,.sheet-item:hover{color:#9b5a00;background:#fff0cf}.view-toggle{box-shadow:var(--shadow-sm);background:#ffffffc7;border:1px solid #f0dec4f2;padding:4px}.view-toggle button.active,.type-btn.active{background:var(--accent-soft);color:#9b5a00;box-shadow:none}.account-list,.transfers{overflow:hidden}.account-row{border-bottom-color:#f0dec4bf}.row-icon{border-radius:var(--radius-pill);background-color:#fff2d5}.row-share-track,.card-share-track{background:#eadfce}.btn-add{color:#9b5a00;background:#ffffffd1;border-color:#ffa30d73}.modal-overlay,.sheet-overlay{background:#492e0942}.modal-route,.modal-text-input,.modal-input-row input,.modal-select,.type-toggle,.icon-selector-grid,.bank-select-btn,.settings-preview div,.sheet-item.cancel{background:#fffaf1}.modal-text-input:focus,.modal-input-row input:focus,.icon-select-btn.active,.bank-select-btn.active{border-color:#ffa30db8}.icon-select-btn.active,.bank-select-btn.active,.sync-account{background:var(--accent-soft);color:#9b5a00}.btn-cancel{border-radius:var(--radius-pill);color:#7a6b5a;background:#fffaf1}.btn-confirm:disabled,.btn-confirm.btn-danger:disabled{color:#9a8c78;background:#eadfce}.btn-confirm.btn-danger,.btn-confirm.btn-danger:hover{background:linear-gradient(135deg,#ef6a5d,#d93b30)}@media (width<=640px){#root{padding-left:max(16px, env(safe-area-inset-left));padding-right:max(16px, env(safe-area-inset-right))}.app{padding-top:22px}header h1{font-size:22px}.header-actions{align-self:auto}}:root{--bg:#f5f6fa;--card-bg:#fff;--text:#2b2d31;--text-muted:#8b8f98;--border:#e4e7ee;--accent:#ff970f;--accent-strong:#ff6338;--accent-soft:#fff3dc;--shadow:0 1px 2px #171c260f, 0 8px 24px -20px #171c265c;--shadow-lg:0 16px 36px -28px #171c267a}body{background:var(--bg)}#root{max-width:none;padding:0}.app{max-width:none;padding:0 0 64px}header{border-bottom:2px solid var(--accent);min-height:56px;box-shadow:none;background:#fff;align-items:center;gap:12px;padding:0}.header-logo{gap:8px;min-height:54px;padding:0 16px 0 2px}.logo-icon{width:29px;height:29px;box-shadow:none;border-radius:6px;padding:6px}header h1{color:var(--text);padding:0;font-size:18px;line-height:1}.build-tag,.header-info{display:none}.header-actions{gap:8px;margin-left:auto;padding-right:10px}.settings-button,.sync-button{color:#555b66;width:38px;min-width:38px;height:38px;min-height:38px;box-shadow:none;background:#f7f8fb;border:1px solid #e9ebf1;border-radius:50%;justify-content:center;padding:0}.sync-button{gap:0}.sync-button.active{border-color:var(--accent);color:var(--accent);background:#fffaf1}.sync-label-full,.sync-label-short{display:none}.toast,.page-heading,.main-content-layout,footer{width:min(880px,100% - 32px);margin-left:auto;margin-right:auto}.toast{margin-top:18px}.page-heading{padding:36px 0 18px}.page-heading h2{color:var(--text);margin:0;font-size:28px;font-weight:800;line-height:1.2}.page-heading p{color:var(--text-muted);margin:10px 0 0;font-size:13px;font-weight:700}.main-content-layout{flex-direction:column;gap:24px;display:flex}.dashboard-total-card{color:#fff;background:linear-gradient(135deg,#ff9d13 0%,#ff8b14 42%,#ff6138 100%);border-radius:22px;min-height:252px;padding:27px 22px 24px;position:relative;overflow:hidden;box-shadow:0 18px 34px -28px #ff6338cc}.dashboard-total-content{z-index:1;max-width:460px;position:relative}.dashboard-total-label{align-items:center;gap:10px;font-size:13px;font-weight:800;display:flex}.dashboard-settings-link{color:#ffffffdb;font:inherit;cursor:pointer;background:0 0;border:none;align-items:center;gap:4px;padding:0;font-size:12px;font-weight:800;display:inline-flex}.dashboard-total-amount{letter-spacing:0;margin-top:12px;font-size:clamp(38px,7vw,46px);font-weight:800;line-height:1}.dashboard-total-caption{color:#ffffffc7;margin-top:18px;font-size:12px;font-weight:800}.dashboard-total-today{color:#ffffffe6;margin-top:8px;font-size:13px;font-weight:800}.dashboard-flow{color:#ffffffeb;background:#ffffff29;border-radius:999px;align-items:center;gap:7px;margin-top:16px;padding:7px 10px;font-size:12px;font-weight:800;display:inline-flex}.dashboard-total-stats{color:#ffffffc7;flex-wrap:wrap;gap:22px;margin-top:24px;font-size:12px;font-weight:700;display:flex}.dashboard-total-stats span{flex-direction:column;gap:5px;display:flex}.dashboard-total-stats strong{color:#fff;font-size:16px;line-height:1.1}.dashboard-total-stats strong.is-negative{color:#692512}.dashboard-total-actions{z-index:2;flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex;position:absolute;bottom:24px;right:23px}.dashboard-total-actions button{min-height:39px;color:var(--text);font:inherit;cursor:pointer;background:#fff;border:none;border-radius:999px;align-items:center;gap:7px;padding:0 17px;font-size:13px;font-weight:800;display:inline-flex}.dashboard-total-actions .dashboard-total-accent{color:#fff;background:#ffbd15}.dashboard-chart-section{margin:-8px 0 0;display:none}.dashboard-chart-section.is-open{display:block}.top-summary,.view-toggle-bar{display:none}.section{margin:0}.section h2{color:var(--text);margin:0 0 10px;font-size:15px}.section-count{color:#6f7480;background:#eef0f5;border-color:#e2e5ec;width:auto;min-width:24px;height:22px}.dashboard-cards-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.account-card,.add-account-card{border:1px solid var(--border);min-height:160px;box-shadow:var(--shadow);background:#fff;border-radius:10px}.account-card{padding:14px 14px 16px;border-left:1px solid var(--border)!important}.account-card.is-primary-bank{box-shadow:0 1px 2px #171c260f,0 14px 34px -26px #ff970f8f;border-color:#ff970f6b!important}.account-card:before{content:"";background:0 0;width:0;position:absolute;inset:0 auto 0 0}.account-card:hover,.account-card.is-editable:hover,.account-card.is-draggable:not(.is-dragging):hover{box-shadow:var(--shadow-lg);background:#fff;border-color:#dfe3eb;transform:translateY(-1px)}.card-header{align-items:flex-start}.card-title-group{flex-direction:column;align-items:flex-start;gap:5px}.card-title-line{align-items:center;gap:7px;max-width:100%;display:flex}.card-title-group .account-icon{display:none}.card-name{font-size:15px;font-weight:800;line-height:1.35}.card-role-badge{color:#717680;white-space:nowrap;background:#eef0f5;border-radius:999px;max-width:110px;padding:3px 8px;font-size:11px;font-weight:800;line-height:1.2}.card-role-badge.is-primary{color:#d57900;background:#fff3dc}.card-note{color:var(--text-muted);font-size:12px;font-weight:700;line-height:1.35}.card-tools{color:#a0a4ad}.card-icon-btn{opacity:.75;width:27px;height:27px}.bank-badge{color:#717680;background:#eef0f5;border:none;align-self:flex-start;margin-top:0;padding:3px 8px;font-size:11px}.card-balance{margin-top:auto;font-size:20px;font-weight:800;color:var(--text)!important}.card-share{margin-top:8px}.card-share-track{display:none}.card-share-pct{color:#4d535c;text-align:left;min-width:0;font-size:12px}.card-share-pct:before{content:"±"}.add-account-card{border:2px dashed var(--accent);color:var(--accent);min-height:160px;font:inherit;cursor:pointer;background:#fff;align-content:center;place-items:center;gap:12px;font-size:15px;font-weight:800;display:grid}.add-account-icon{background:#fff3dc;border:2px solid #ffd49a;border-radius:50%;place-items:center;width:48px;height:48px;display:grid}.btn-add{border:1px dashed var(--accent);width:auto;min-height:42px;color:var(--accent);background:#fff;margin-top:12px;padding:0 18px}.section-empty,.transfers{background:#fff;border-radius:10px}footer{text-align:right;margin-top:32px}@media (width<=720px){header{min-height:58px}.header-logo{padding-left:12px}header h1{font-size:16px}.header-actions{gap:6px}.settings-button,.sync-button{width:36px;min-width:36px;height:36px;min-height:36px}.page-heading{padding-top:28px}.page-heading h2{font-size:25px}.dashboard-total-card{min-height:330px;padding:24px 20px}.dashboard-total-actions{justify-content:flex-start;margin-top:24px;position:relative;bottom:auto;right:auto}.dashboard-cards-grid{grid-template-columns:1fr}}
