:root{font-family:IBM Plex Sans JP,BIZ UDPGothic,Hiragino Sans,Yu Gothic UI,sans-serif;line-height:1.6;color:#111827;background:#f7f9fc;--c-primary: #2563eb;--c-primary-dark: #1d4ed8;--c-text: #111827;--c-muted: #6b7280;--c-border: #e5e7eb;--c-card: #ffffff;--c-bg-soft: #f9fafb;--c-focus: #60a5fa}*{box-sizing:border-box}body{margin:0;background:transparent;color:var(--c-text)}#root{max-width:1160px;margin:0 auto;padding:1.25rem 1rem 3.5rem}.app-shell{display:flex;flex-direction:column;gap:1.15rem}button,input,select{font:inherit}button{cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,background-color .12s ease,color .12s ease}button:disabled{opacity:.55;cursor:not-allowed;transform:none}button:not(:disabled):hover{transform:translateY(-1px)}input:focus-visible,select:focus-visible,button:focus-visible{outline:2px solid var(--c-focus);outline-offset:2px}.hero{background:#fff;color:#0f172a;border:1px solid var(--c-border);border-radius:14px;padding:1.1rem 1.2rem .95rem;box-shadow:0 8px 20px #0f172a0d}.hero h1{margin:.08rem 0 .15rem;font-size:1.7rem;letter-spacing:.01em;font-weight:760}.hero p{margin:.2rem 0;color:#4b5563}.hero-sub{letter-spacing:.05em;font-size:.74rem;text-transform:uppercase;color:#2563eb;font-weight:700}.view-tabs{margin-top:.9rem;display:inline-flex;gap:.2rem;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:10px;padding:.2rem}.view-tabs button{border:1px solid transparent;border-radius:8px;padding:.4rem .88rem;font-weight:700;color:#4b5563;background:transparent}.view-tabs button.active{background:#fff;color:#1d4ed8;border-color:#dbeafe;box-shadow:0 4px 10px #2563eb1f}.status-bar{display:flex;align-items:center;justify-content:space-between;background:#fff;color:#374151;border:1px solid var(--c-border);border-radius:12px;padding:.68rem .82rem;gap:.6rem}.status-bar button{border:none;border-radius:8px;padding:.42rem .78rem;background:var(--c-primary);color:#fff;font-weight:700;font-size:.88rem}.status-bar button:not(:disabled):hover{background:var(--c-primary-dark)}.status-actions{display:inline-flex;align-items:center;gap:.48rem}.status-link{display:inline-flex;align-items:center;justify-content:center;min-height:34px;padding:.4rem .72rem;border:1px solid #d1d5db;border-radius:8px;background:#fff;color:#1d4ed8;text-decoration:none;font-size:.86rem;font-weight:700}.status-link:hover{background:#eff6ff}.global-error{margin:0;color:#b91c1c;background:#fee2e2;border-radius:10px;padding:.55rem .75rem}.editor-card,.transactions-card,.viz-card,.editor-placeholder,.simple-entry-card{background:var(--c-card);border:1px solid var(--c-border);border-radius:12px;padding:1.05rem;box-shadow:0 6px 16px #0f172a0a}.simple-entry-head{display:flex;align-items:center;justify-content:space-between;gap:.8rem;margin-bottom:.9rem}.simple-entry-head h2{margin:0;font-size:1.12rem;letter-spacing:.01em}.entry-mode-toggle{display:inline-flex;border:1px solid #d1d5db;border-radius:9px;overflow:hidden;background:#fff}.entry-mode-toggle button{border:0;background:transparent;color:#4b5563;padding:.44rem .88rem;font-weight:700;font-size:.9rem}.entry-mode-toggle button.active{background:#eff6ff;color:#1e40af}.simple-entry-card{background:linear-gradient(180deg,#fff,#fbfdff)}.simple-form{display:flex;flex-direction:column;gap:.86rem;max-width:760px}.simple-form label{display:flex;flex-direction:column;gap:.34rem;font-size:.88rem;color:#334155;font-weight:700}.simple-form input,.simple-form select{border:1px solid #d1d5db;border-radius:10px;padding:.62rem .68rem;font-size:.98rem;color:#0f172a;background:#fff;box-shadow:none}.simple-form input::placeholder{color:#9ca3af}.simple-form-actions{display:flex;justify-content:flex-end;margin-top:.45rem}.simple-form-actions button{border:none;border-radius:10px;padding:.58rem .95rem;font-weight:700;background:var(--c-primary);color:#fff}.simple-form-actions button:not(:disabled):hover{background:var(--c-primary-dark)}.editor-card__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.7rem}.editor-card__head h2,.transactions-card h2,.viz-card h2,.editor-placeholder h2{margin:0;font-size:1.05rem}.ghost{border:1px solid #cbd5e1;background:#f8fafc;border-radius:999px;padding:.35rem .8rem;color:#334155}.transaction-form{display:flex;flex-direction:column;gap:.85rem}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem}.form-grid label{display:flex;flex-direction:column;gap:.3rem;font-size:.92rem}.form-grid input,.form-grid select,.bulk-actions input,.bulk-actions select{border:1px solid #bfdbfe;border-radius:8px;padding:.45rem .6rem;font-size:.95rem;background:#fff}.inline-helper{margin-top:.25rem;width:fit-content;border:1px solid #cbd5e1;border-radius:6px;padding:.2rem .5rem;background:#f8fafc}.template-row,.suggest-row{display:flex;align-items:center;flex-wrap:wrap;gap:.4rem}.suggest-row button{border:1px solid #dbeafe;border-radius:999px;background:#f8fbff;color:#1d4ed8;padding:.25rem .68rem;font-size:.8rem}.template-row button{border:1px solid #d1d5db;border-radius:999px;background:#f9fafb;color:#374151;padding:.25rem .68rem}.posting-list{display:flex;flex-direction:column;gap:.55rem}.posting-list__header{display:flex;align-items:center;justify-content:space-between}.posting-list__header h3{margin:0;font-size:.96rem}.posting-header-buttons{display:flex;gap:.4rem}.posting-header-buttons button,.posting-row button,.form-submit button,.bulk-actions__right button,.conflict-retry button,.transaction-actions button{border:none;border-radius:8px;padding:.35rem .75rem;font-weight:700}.posting-header-buttons button{background:#e0f2fe;color:#0c4a6e}.posting-row{display:grid;grid-template-columns:minmax(220px,2fr) minmax(120px,1fr) minmax(100px,.8fr) minmax(90px,.7fr);gap:.45rem}.posting-row input{border:1px solid #bfdbfe;border-radius:8px;padding:.45rem .55rem}.posting-row select{border:1px solid #bfdbfe;border-radius:8px;padding:.45rem .55rem;background:#fff}.posting-row button{background:#fee2e2;color:#991b1b}.posting-group{display:flex;flex-direction:column;gap:.5rem;border:1px solid #dbeafe;border-radius:12px;padding:.72rem;background:#fbfdff}.posting-group h4{margin:0;font-size:.9rem;color:#334155}.posting-group-actions{display:flex;flex-wrap:wrap;gap:.4rem}.posting-group-actions button,.posting-footer-actions button{border:1px solid #bae6fd;border-radius:8px;padding:.32rem .72rem;font-weight:700;background:#f0f9ff;color:#0c4a6e}.posting-footer-actions{display:flex;flex-wrap:wrap;gap:.45rem}.posting-empty{margin:0;color:#64748b;font-size:.85rem}.form-submit{display:flex;justify-content:flex-end}.form-submit button{background:#0ea5e9;color:#fff}.edit-layout{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(0,1fr);gap:1rem}.transactions-card table{width:100%;border-collapse:collapse;font-size:.94rem}.transactions-card th,.transactions-card td{text-align:left;border-bottom:1px solid #eaf2ff;padding:.52rem .45rem;vertical-align:middle}.transactions-card thead th{font-size:.82rem;color:#475569;font-weight:700;text-transform:uppercase;letter-spacing:.03em}.transactions-card tbody tr:hover{background:#f8fbff}.transaction-list-head{margin-bottom:.5rem}.select-all-toggle{display:inline-flex;align-items:center;gap:.4rem;font-size:.86rem;color:#475569}.transaction-list{display:flex;flex-direction:column;gap:.62rem}.transaction-item{display:grid;grid-template-columns:auto 1fr auto;gap:.7rem;align-items:center;border:1px solid #e5e7eb;border-radius:12px;padding:.68rem .74rem;background:#fff;box-shadow:0 2px 8px #0f172a0a}.transaction-item__left{display:flex;align-items:center}.transaction-item__main{min-width:0;display:flex;flex-direction:column;gap:.18rem}.transaction-item__top{display:flex;align-items:center;gap:.5rem}.transaction-item__title{font-weight:700;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tx-type{display:inline-flex;align-items:center;border-radius:999px;padding:.12rem .5rem;font-size:.74rem;background:#eff6ff;color:#1e40af}.transaction-item__meta{display:flex;flex-wrap:wrap;gap:.45rem;font-size:.8rem;color:#64748b}.transaction-item__right{display:flex;flex-direction:column;align-items:flex-end;gap:.32rem}.transaction-item__right strong{font-size:.95rem}.bulk-actions{display:flex;flex-wrap:wrap;justify-content:space-between;gap:.5rem;margin-bottom:.65rem}.bulk-actions__left,.bulk-actions__right{display:flex;align-items:center;gap:.35rem;flex-wrap:wrap}.bulk-actions__right button{background:#e0f2fe;color:#0c4a6e}.bulk-actions__right button.danger{background:#fecaca;color:#991b1b}.transaction-actions{display:flex;align-items:center;gap:.45rem}.transaction-actions button{background:#e0ecff;color:#1d4ed8}.readonly-badge{display:inline-flex;align-items:center;border-radius:999px;padding:.18rem .6rem;background:#fef3c7;color:#92400e}.editor-placeholder p{margin-top:.55rem;color:#475569}.visualize-layout{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.9rem}.viz-filter{grid-column:1 / -1;background:linear-gradient(180deg,#fff,#f8fcff)}.viz-overview{grid-column:1 / -1;display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:.65rem}.viz-kpi{background:#fff;border:1px solid #dbeafe;border-radius:12px;padding:.62rem .68rem;display:flex;flex-direction:column;gap:.18rem}.viz-kpi span{font-size:.72rem;color:#6b7280;text-transform:uppercase;letter-spacing:.04em}.viz-kpi strong{font-size:1.08rem;color:#111827;line-height:1.25}.viz-card--wide{grid-column:1 / -1}.viz-filter-row{display:flex;flex-wrap:wrap;gap:.6rem;align-items:flex-end}.viz-filter-row label{display:flex;flex-direction:column;gap:.25rem;font-size:.79rem;color:#6b7280;font-weight:700;letter-spacing:.02em;text-transform:uppercase}.viz-filter-row select,.viz-filter-row input{border:1px solid #d1d5db;border-radius:8px;padding:.35rem .55rem;background:#fff;min-width:150px}.viz-card h2{margin-bottom:.72rem;font-size:1rem;letter-spacing:.01em}.sankey-graph svg,.moneytree-graph svg{width:100%;height:auto}.sankey-node{font-size:10px;font-weight:700;fill:#334155}.moneytree-label{font-size:11px;fill:#334155}.category-bars{display:flex;flex-direction:column;gap:.65rem}.category-head{display:flex;align-items:center;justify-content:space-between;font-size:.9rem;margin-bottom:.25rem}.category-track{height:12px;border-radius:999px;background:#e5edf7;overflow:hidden}.category-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,#2563eb,#0ea5e9)}.payee-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,#0f766e,#14b8a6)}.flow-bars{display:flex;flex-direction:column;gap:.7rem}.flow-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.2rem;font-size:.88rem}.flow-track{height:10px;border-radius:999px;background:#e2e8f0;overflow:hidden;margin-bottom:.18rem}.flow-income{height:100%;background:linear-gradient(90deg,#16a34a,#84cc16)}.flow-expense{height:100%;background:linear-gradient(90deg,#f59e0b,#f97316)}.payee-ranking{display:flex;flex-direction:column;gap:.6rem}.payee-head{display:flex;align-items:center;justify-content:space-between;font-size:.9rem;margin-bottom:.2rem}.heatmap-wrap{display:flex;flex-direction:column;gap:.6rem}.heatmap-grid{display:flex;flex-direction:column;gap:.28rem}.heatmap-row{display:grid;grid-template-columns:1.2rem 1fr;align-items:center;gap:.42rem}.heatmap-day{color:#64748b;font-size:.75rem}.heatmap-cells{display:grid;grid-auto-flow:column;grid-auto-columns:12px;gap:3px}.heatmap-cell{width:12px;height:12px;border:none;border-radius:3px;padding:0;display:inline-block}.heatmap-cell.l0{background:#e2e8f0}.heatmap-cell.l1{background:#d1fae5}.heatmap-cell.l2{background:#6ee7b7}.heatmap-cell.l3{background:#10b981}.heatmap-cell.l4{background:#047857}.heatmap-legend{display:flex;align-items:center;gap:.4rem;color:#475569;font-size:.78rem}.heatmap-legend-scale{display:inline-flex;gap:3px}.budget-chart{display:flex;flex-direction:column;gap:.78rem}.budget-row{display:flex;flex-direction:column;gap:.3rem}.budget-head{display:flex;align-items:center;justify-content:space-between;font-size:.9rem}.budget-track{position:relative;height:14px;border-radius:999px;background:#e5edf7;overflow:visible}.budget-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,#3b82f6,#0284c7)}.budget-fill.over{background:linear-gradient(90deg,#f97316,#dc2626)}.budget-forecast{position:absolute;top:-4px;width:2px;height:22px;background:#0f172a}.budget-forecast.over{background:#b91c1c}.budget-meta{display:flex;flex-wrap:wrap;gap:.65rem;font-size:.79rem;color:#475569}.sankey-graph,.moneytree-graph{overflow:hidden}.graph-empty{margin:0;color:#64748b}.conflict-retry{display:flex;justify-content:flex-start}.conflict-retry button{background:#fde68a;color:#92400e}@media (max-width: 980px){.edit-layout,.visualize-layout{grid-template-columns:1fr}.posting-row{grid-template-columns:repeat(2,minmax(120px,1fr))}.simple-entry-head{flex-direction:column;align-items:flex-start}.viz-filter-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem}.viz-filter-row button.ghost{justify-self:start}}@media (max-width: 640px){#root{padding:.8rem .6rem 2.2rem}.hero h1{font-size:1.45rem}.posting-row{grid-template-columns:1fr}.view-tabs{width:100%;justify-content:space-between}.view-tabs button{flex:1}.entry-mode-toggle{width:100%}.entry-mode-toggle button{flex:1}.status-bar{flex-direction:column;align-items:flex-start;gap:.45rem}.status-actions{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:.45rem}.status-link,.status-bar button{width:100%;min-height:40px}.transaction-item{grid-template-columns:auto 1fr;gap:.55rem;padding:.62rem}.transaction-item__right{grid-column:1 / -1;flex-direction:row;justify-content:space-between;align-items:center}.simple-form{gap:.68rem}.simple-form input,.simple-form select{min-height:42px}.simple-form-actions{justify-content:stretch}.simple-form-actions button{width:100%;min-height:42px}.bulk-actions{flex-direction:column;align-items:stretch}.bulk-actions__left,.bulk-actions__right{width:100%;display:grid;grid-template-columns:1fr;gap:.45rem}.bulk-actions__left input,.bulk-actions__left select,.bulk-actions__right button{width:100%;min-height:40px}.suggest-row,.template-row{overflow-x:auto;white-space:nowrap;padding-bottom:.1rem;-webkit-overflow-scrolling:touch}.suggest-row span,.template-row span{position:sticky;left:0;background:#fff;padding-right:.35rem}.viz-filter-row{grid-template-columns:1fr}.viz-filter-row input,.viz-filter-row select{width:100%;min-width:0;min-height:40px}.viz-filter-row button.ghost{min-height:40px}.viz-kpi{padding:.58rem .62rem}.heatmap-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.heatmap-grid{min-width:420px}.sankey-graph svg,.moneytree-graph svg{min-width:0}.sankey-node{font-size:8px}.moneytree-label{display:none}}@media (max-width: 420px){#root{padding:.7rem .5rem 1.8rem}.hero{padding:.95rem .9rem .85rem}.hero h1{font-size:1.38rem}.view-tabs button{padding:.38rem .45rem;font-size:.82rem}.transaction-actions{width:100%}.transaction-actions button{width:100%;min-height:38px}}:root{font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px}button{font-family:inherit;cursor:pointer}
