:root{--bg:#f6f7f9;--card-bg:#fff;--text:#1f2937;--text-muted:#6b7280;--border:#e5e7eb;--shadow:0 1px 3px #0000001a;--radius:8px;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;font:16px/1.5 system-ui,-apple-system,sans-serif}@media (prefers-color-scheme:dark){:root{--bg:#111827;--card-bg:#1f2937;--text:#f3f4f6;--text-muted:#9ca3af;--border:#374151;--shadow:0 1px 3px #0006}}*{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;--shadow-sm:0 1px 2px #0f172a0f;--shadow:0 10px 24px #0f172a14;--shadow-lg:0 20px 50px #0f172a2e;--accent:#2563eb;--success:#059669;--danger:#dc2626;--font-sans:"Plus Jakarta Sans", "Outfit", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif}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;max-width:1080px;margin:0 auto;padding:20px 12px 40px}.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-direction:column;align-items:center;gap:10px;padding:16px 0 24px;display:flex}.header-logo{align-items:center;gap:8px;display:flex}.logo-icon{color:var(--accent);filter:drop-shadow(0 2px 8px #2563eb3d)}header h1{letter-spacing:0;color:var(--text);margin:0;font-size:26px;font-weight:800}.header-info{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);color:var(--text-muted);flex-wrap:wrap;justify-content:center;gap:12px;padding:7px 14px;font-size:12px;display:flex}.info-item{align-items:center;gap:6px;display:flex}.header-actions{justify-content:center;align-items:center;gap:8px;display:flex}.settings-button{border:1px solid var(--border);border-radius:var(--radius);background:var(--card-bg);box-shadow:var(--shadow-sm);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{border-color:var(--accent);color:var(--accent)}.sync-button{border:1px solid var(--border);border-radius:var(--radius);background:var(--card-bg);box-shadow:var(--shadow-sm);color:var(--text-muted);cursor:pointer;min-height:32px;font:inherit;align-items:center;gap:7px;padding:7px 12px;font-size:12px;font-weight:800;transition:background-color .2s,border-color .2s,color .2s;display:inline-flex}.sync-button.active{color:var(--success);background:#05966914;border-color:#0596693d}.sync-button.error{color:var(--danger);background:#dc262614;border-color:#dc26263d}.sync-button:hover{border-color:var(--accent);color:var(--accent)}.spin{animation:.9s linear infinite spin}.auth-gate{place-items:center;min-height:calc(100vh - 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-lg);flex-direction:column;align-items:stretch;gap:18px;padding:28px;display:flex}.auth-mark{border-radius:var(--radius);width:58px;height:58px;color:var(--accent);background:#2563eb1a;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(--text);color:var(--card-bg);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){transform:translateY(-1px)}.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);box-shadow:var(--shadow);margin-bottom:24px;padding:22px 20px;position:relative;overflow:hidden}.chart-section:before{content:none}.donut-chart-container{flex-flow:wrap;justify-content:center;align-items:center;gap:32px;display:flex}.donut-chart-container.empty{min-height:160px}.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}.chart-legend{flex-direction:column;flex:1;gap:8px;min-width:180px;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{cursor:pointer;border-radius:8px;align-items:center;padding:6px 8px;font-size:12px;transition:background-color .2s,transform .2s;display:flex}.legend-item:hover,.legend-item.active{background:#2563eb14;transform:translate(2px)}.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:12px;margin-bottom:24px;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:154px}.carry-over-card{background:var(--card-bg);border-radius:var(--radius);text-align:center;cursor:pointer;width:100%;box-shadow:var(--shadow);font:inherit;color:inherit;border:1px solid #2563eb38;flex-direction:column;justify-content:center;margin-bottom:20px;padding:18px 20px;transition:transform .2s,border-color .2s,background .2s;display:flex;position:relative;overflow:hidden}.carry-over-card:hover{border-color:var(--accent);background:#2563eb0a;transform:translateY(-2px)}.carry-over-label{color:var(--accent);justify-content:center;align-items:center;gap:6px;margin-bottom:6px;font-size:12px;font-weight:600;display:flex}.carry-over-edit{color:var(--text-muted)}.carry-over-amount{color:var(--text);letter-spacing:0;font-size:30px;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{border-left-width:6px;border-color:var(--success);background:#05966914}.free-section .account-card:hover{background:#0596691f}.free-section .card-balance{font-size:26px}.section{margin-bottom:28px}.section h2{letter-spacing:0;color:var(--text-muted);align-items:center;gap:6px;margin-bottom:12px;padding-left:6px;font-size:14px;font-weight:700;display:flex}.section-count{background:var(--card-bg);border:1px solid var(--border);min-width:22px;height:22px;color:var(--text);border-radius:999px;justify-content:center;align-items:center;padding:0 7px;font-size:12px;line-height:1;display:inline-flex}.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){.app{padding:14px 0 36px}header{padding:10px 0 18px}.header-info{width:100%}.sync-button{justify-content:center;width:100%;min-height:40px}.header-actions{width:100%}.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}.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:136px}.account-card{min-height:132px;padding:14px}.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);box-shadow:var(--shadow-sm);cursor:default;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;touch-action:none;border-left:5px solid #ccc;flex-direction:column;gap:12px;min-height:142px;padding:16px;transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s,background-color .2s;display:flex;position:relative;overflow:hidden}.account-card.is-draggable{cursor:grab;touch-action:none}.account-card.is-free{cursor:grab}.account-card.is-editable{cursor:pointer}.account-card.is-editable:focus-visible{outline-offset:3px;outline:3px solid #2563eb47}.account-card:hover{box-shadow:var(--shadow);background:color-mix(in srgb, var(--card-bg) 94%, var(--accent));transform:translateY(-3px)}.account-card.is-draggable:active{cursor:grabbing;transform:scale(.97)translateY(0)}.account-card.is-dragging{cursor:grabbing;opacity:.4;filter:grayscale(.4);border-style:dashed;transition:opacity .15s,transform .15s,filter .15s;transform:scale(.96)rotate(-1.5deg)}.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}.account-card.drag-over:after{content:"⇄ 資金移動";color:#fff;pointer-events:none;z-index:21;white-space:nowrap;background:#ec4899;border-radius:999px;padding:6px 12px;font-size:13px;font-weight:800;animation:.7s ease-in-out infinite dropLabelBob;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 4px 12px #ec48998c}@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}}@keyframes dropLabelBob{0%,to{transform:translate(-50%,-50%)scale(1)}50%{transform:translate(-50%,-50%)scale(1.12)}}.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}.account-card.drag-over-before:before,.account-card.drag-over-after:before{content:"↔ 並び替え";color:#fff;pointer-events:none;z-index:21;white-space:nowrap;background:#16a34a;border-radius:999px;padding:4px 10px;font-size:11px;font-weight:800;position:absolute;top:50%;transform:translateY(-50%);box-shadow:0 3px 10px #16a34a80}.account-card.drag-over-before:before{left:12px}.account-card.drag-over-after:before{right:12px}@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)}}.account-card.negative .card-balance{color:var(--danger)!important}.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:4px;display:flex}.card-reorder{background:var(--bg);border:1px solid var(--border);border-radius:7px;align-items:center;gap:2px;padding:2px;display:flex}.card-icon-btn{width:24px;height:24px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:0;transition:background-color .2s,color .2s;display:flex}.card-icon-btn:hover{background:var(--card-bg);color:var(--text)}.card-icon-btn:disabled{opacity:.3;cursor:not-allowed}.card-icon-btn:disabled:hover{color:var(--text-muted);background:0 0}.card-delete:hover{color:var(--danger);background:#fee2e2}.card-balance{letter-spacing:0;word-break:keep-all;margin:4px 0;font-size:20px;font-weight:800}.drag-handle{color:var(--text-muted);opacity:.55;cursor:grab;touch-action:none;justify-content:center;min-height:16px;margin-top:auto;display:flex}.btn-add{border:2px 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:var(--accent);color:var(--accent);background:#3b82f608;transform:translateY(-1px)}.transfers{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);flex-direction:column;display:flex;overflow:hidden}.transfer-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 16px;font-size:13px;transition:background-color .2s;display:flex}.transfer-row:hover{background:var(--border)}.transfer-row:last-child{border-bottom:none}.transfer-info{align-items:center;gap:8px;font-weight:600;display:flex}.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);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{color:var(--danger);background:#dc262614}footer{text-align:center;z-index:10;margin-top:40px;position:relative}.btn-reset{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;z-index:11;background:0 0;border-radius:8px;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{color:var(--danger);background:#dc262614;border-color:#dc26264d}.modal-overlay{-webkit-backdrop-filter:blur(8px);z-index:100;background:#0006;justify-content:center;align-items:center;padding:16px;animation:.25s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:350px;box-shadow:var(--shadow-lg);box-sizing:border-box;padding:24px;animation:.3s cubic-bezier(.34,1.56,.64,1) scaleUp;position:relative}.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;box-shadow:var(--shadow-sm);justify-content:center;align-items:center;gap:8px;font-size:13px;font-weight:800;display:inline-flex}.google-login-btn:hover{border-color:var(--accent);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-radius:var(--radius);color:var(--success);background:#05966914;border:1px solid #05966938;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{border-color:var(--accent);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:17px;font-weight:800}.modal-close{background:var(--border);cursor:pointer;width:28px;height:28px;color:var(--text-muted);border:none;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex}.modal-close:hover{background:var(--text);color:var(--bg)}.modal-desc{color:var(--text-muted);text-align:center;margin:0 0 16px;font-size:13px;line-height:1.5}.modal-route{background:var(--border);border-radius:8px;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);color:var(--text);border-radius:8px;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:1.5px solid var(--border);color:var(--text);box-sizing:border-box;border-radius:8px;outline:none;width:100%;padding:10px 14px;font-size:14px;font-weight:600;transition:border-color .2s}.modal-text-input:focus{border-color:var(--accent)}textarea.modal-text-input{resize:vertical;min-height:88px;line-height:1.45}.type-toggle{background:var(--border);border-radius:8px;gap:4px;padding:4px;display:flex}.type-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;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:var(--shadow-sm)}.icon-selector-grid{border:1px solid var(--border);background:var(--bg);border-radius:8px;grid-template-columns:repeat(5,1fr);gap:8px;max-height:150px;padding:4px;display:grid;overflow-y:auto}.icon-select-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:1.5px solid #0000;border-radius:8px;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:var(--border);color:var(--text)}.icon-select-btn.active{border-color:var(--accent);color:var(--accent);background:#3b82f614}.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:2px solid var(--border);background:var(--bg);min-width:0;max-width:280px;color:var(--text);border-radius:8px;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:var(--accent)}.modal-actions{gap:10px;margin-top:8px;display:flex}.modal-actions button{cursor:pointer;border:none;border-radius:8px;flex:1;padding:12px;font-size:14px;font-weight:700;transition:all .2s}.btn-cancel{background:var(--border);color:var(--text-muted)}.btn-cancel:hover{background:var(--text);color:var(--bg)}.btn-confirm{background:var(--accent);color:#fff;box-shadow:0 4px 12px #3b82f640}.btn-confirm:hover{background:#2563eb;transform:translateY(-1px)}.btn-confirm:disabled{background:var(--border);color:var(--text-muted);cursor:not-allowed;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)}}
