:root{color-scheme:light;--bg: #f5f2ec;--bg-alt: #eef5f4;--card: #ffffff;--text: #1f2a2b;--muted: #6b7a7a;--primary: #0f3d3e;--accent: #ff9f68;--accent-2: #4fa9a1;--danger: #cc3d3d;--shadow: 0 20px 45px rgba(15, 61, 62, .12);--radius: 20px;--space-2xs: clamp(6px, .6vw, 10px);--space-xs: clamp(8px, .9vw, 12px);--space-sm: clamp(12px, 1.2vw, 16px);--space-md: clamp(16px, 1.6vw, 22px);--space-lg: clamp(20px, 2vw, 28px);--space-xl: clamp(28px, 3vw, 40px)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Noto Sans JP,Hiragino Kaku Gothic ProN,Yu Gothic,sans-serif;font-size:clamp(14px,1.05vw,16px);background:radial-gradient(circle at top,#e2f0ef,transparent 55%),linear-gradient(180deg,var(--bg),var(--bg-alt));color:var(--text);min-height:100vh}.login-screen{min-height:100vh;display:grid;place-items:center;padding:var(--space-lg)}.login-card{width:min(420px,92vw);background:var(--card);border-radius:24px;padding:28px;box-shadow:var(--shadow);display:grid;gap:18px}.login-brand{display:flex;align-items:center;gap:14px}.login-card form{display:grid;gap:12px}.login-card label{display:grid;gap:6px;font-size:12px;color:var(--muted)}.login-card input{padding:10px 12px;border-radius:12px;border:1px solid #d7e2e1}.app{max-width:1200px;margin:0 auto;padding:var(--space-lg) var(--space-md) calc(var(--space-xl) + 56px)}.app-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--space-sm);margin-bottom:var(--space-lg)}.brand{display:flex;align-items:center;gap:16px}.logo{width:52px;height:52px;border-radius:16px;display:grid;place-items:center;background:var(--primary);color:#fff;font-weight:700;font-size:22px;box-shadow:var(--shadow)}.brand h1{font-size:24px}.brand p{color:var(--muted);font-size:14px}.header-actions{display:flex;flex-wrap:wrap;gap:var(--space-xs);align-items:center}.month-toolbar{display:flex;justify-content:flex-end;margin-bottom:var(--space-md)}.month-picker{display:grid;gap:4px;font-size:12px;color:var(--muted)}.month-picker input{padding:8px 12px;border-radius:10px;border:1px solid #d3dfde;background:#fff}button{border:none;border-radius:12px;padding:10px 16px;cursor:pointer;font-weight:600}button.primary{background:var(--primary);color:#fff;box-shadow:var(--shadow)}button.ghost{background:transparent;border:1px solid #cedad9;color:var(--text)}button.danger{background:transparent;border:1px solid var(--danger);color:var(--danger)}.grid{display:grid;gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.card{background:var(--card);border-radius:var(--radius);padding:var(--space-md);box-shadow:var(--shadow)}.card h2{font-size:18px;margin-bottom:12px}.summary{grid-column:span 2;display:grid;gap:16px}.summary-header{display:flex;align-items:center;justify-content:space-between}.pill{background:var(--bg-alt);padding:6px 12px;border-radius:999px;font-size:12px;color:var(--muted)}.summary-cards{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.mini{background:#f9f7f3;border-radius:14px;padding:12px;display:grid;gap:4px}.mini span{font-size:12px;color:var(--muted)}.mini strong{font-size:18px}.mini.emphasis{background:#0f3d3e;color:#fff}.mini .savings-label{font-size:11px;color:#ffffffbf}.progress{height:8px;border-radius:999px;background:#e5eceb;overflow:hidden;margin-top:6px}.progress-bar{height:100%;width:0;background:linear-gradient(90deg,var(--accent-2),var(--accent))}.section-header{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:12px}.header-actions-inline{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.section-header h2{flex:1 1 140px}.filters{display:flex;gap:8px;align-items:center;flex-wrap:wrap;flex:1 1 260px}.filters input,.filters select{padding:8px 10px;border-radius:10px;border:1px solid #d3dfde;background:#fff}.filter-panel{margin:10px 0 14px;padding:14px;border:1px solid #e3e8e4;border-radius:16px;background:#f8faf8;display:grid;gap:12px}.filter-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.filter-grid label{display:grid;gap:6px}.filter-grid label span{font-size:12px;color:var(--muted)}.filter-grid input,.filter-grid select{padding:8px 10px;border-radius:10px;border:1px solid #d3dfde;background:#fff}.filter-actions{display:flex;justify-content:flex-end}.result-summary{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:14px}.result-pill{min-width:110px;padding:10px 12px;border-radius:14px;background:#f5f2eb;border:1px solid #ece2d4;display:grid;gap:3px}.result-pill span{font-size:12px;color:var(--muted)}.reports{grid-column:span 2;display:grid;gap:16px}.chart-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.chart-card{background:#f8f6f2;border-radius:16px;padding:14px;border:1px solid #efe7dd}.chart-card h3{font-size:14px;margin-bottom:8px}.bar-chart{display:grid;grid-auto-flow:column;gap:8px;align-items:end;height:160px}.bar{display:grid;gap:6px;align-items:end;text-align:center;font-size:11px;color:var(--muted)}.bar span{font-size:10px}.bar .bar-fill{width:100%;border-radius:8px 8px 4px 4px;background:linear-gradient(180deg,var(--accent-2),var(--accent));min-height:6px}.bar .bar-value{font-weight:600;color:var(--text);font-size:11px}.calendar{background:#fff;border-radius:16px;padding:14px;border:1px solid #eff2f1}.calendar-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px}.calendar-legend{display:flex;align-items:center;gap:6px;color:var(--muted);font-size:11px}.legend-dot{width:10px;height:10px;border-radius:50%;display:inline-block;background:#e5eceb}.legend-dot.level-1{background:#c5ddd9}.legend-dot.level-2{background:#7fc4bc}.legend-dot.level-3{background:#2b7f7a}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}.calendar-day{background:#f7f5f1;border-radius:12px;padding:10px;min-height:84px;display:grid;gap:4px;font-size:11px;color:var(--muted);min-width:0}.calendar-day header{font-size:12px;font-weight:600;color:var(--text)}.calendar-day[data-level="1"]{background:#ecf4f3}.calendar-day[data-level="2"]{background:#d6ebe7}.calendar-day[data-level="3"]{background:#b0d8d2}.calendar-day .amount{font-size:10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.calendar-day .amount.income{color:#1f7a5e}.calendar-day .amount.expense{color:#b42318}.calendar-day.empty{background:transparent;border:1px dashed #e2e6e5}.calendar-day.weekday{background:transparent;border:none;min-height:auto;padding:4px;text-align:center;font-size:11px;color:var(--muted)}.calendar-day[role=button]{cursor:pointer}.calendar-day[role=button]:focus-visible{outline:2px solid #2b7f7a;outline-offset:2px}.tx-list{display:grid;gap:10px;list-style:none}.tx-item{display:grid;grid-template-columns:1fr auto;gap:10px;padding:12px;border-radius:14px;background:#faf9f6;border:1px solid #edf1f0}.tx-meta{display:grid;gap:4px}.tx-meta span{font-size:12px;color:var(--muted)}.sync-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 6px;border-radius:999px;font-style:normal;font-size:11px;font-weight:600;border:1px solid transparent}.sync-pending{color:#8a5b2c;background:#fff1e0;border-color:#f3d7b4}.sync-synced{color:#1c6b4b;background:#e3f7ec;border-color:#bfe7d5}.sync-failed{color:#8a1f2b;background:#ffe5e9;border-color:#f6b8c1}.toast-container{position:fixed;top:18px;left:50%;transform:translate(-50%);display:grid;gap:10px;z-index:999;pointer-events:none}.toast{min-width:240px;max-width:min(360px,92vw);padding:12px 16px;border-radius:999px;background:#f3f4f6;color:#111827;border:1px solid #e5e7eb;box-shadow:0 16px 30px #1118171f;font-size:13px;display:inline-flex;align-items:center;gap:8px;opacity:0;transform:translateY(-8px);animation:toast-in .25s ease forwards,toast-out .35s ease forwards 2.3s}.toast.success{background:#ecfdf3;color:#166534;border-color:#bbf7d0}.toast.error{background:#fef2f2;color:#b91c1c;border-color:#fecaca}.toast.info{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}@keyframes toast-in{to{opacity:1;transform:translateY(0)}}@keyframes toast-out{to{opacity:0;transform:translateY(-18px)}}.tx-actions{display:flex;gap:6px;align-items:center}.tx-amount{font-weight:700}.budget-list{display:grid;gap:12px}.payment-method-list{display:grid;gap:10px}.payment-method-row{padding:12px 14px;border-radius:14px;border:1px solid #e6efec;background:#fbfcfb}.asset-total{display:grid;gap:4px;margin-bottom:14px;padding:14px;border-radius:16px;background:linear-gradient(180deg,#f8fbfa,#eef5f3);border:1px solid #e3ece9}.asset-total span{font-size:12px;color:var(--muted)}.asset-total strong{font-size:24px}.asset-list,.transfer-list{display:grid;gap:10px}.asset-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;padding:12px 14px;border-radius:14px;border:1px solid #e6efec;background:#fbfcfb}.transfer-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;width:100%;text-align:left;padding:12px 14px;border-radius:14px;border:1px solid #e6efec;background:#fbfcfb}.transfer-row strong{display:block;font-size:15px}.transfer-row span{display:block;margin-top:4px;font-size:12px;color:var(--muted)}.asset-row strong{display:block;font-size:15px}.asset-row span{display:block;margin-top:4px;font-size:12px;color:var(--muted)}.asset-balance{font-weight:700;font-size:16px;white-space:nowrap}.asset-balance.negative{color:#b42318}.asset-empty{padding:16px;border-radius:14px;border:1px dashed #dce6e3;color:var(--muted);text-align:center;background:#fbfcfb}.budget-row{display:grid;gap:8px}.budget-row header{display:flex;justify-content:space-between;font-size:14px}.budget-row small{color:var(--muted)}.sync-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;font-size:10px;margin-left:6px;border:1px solid transparent}.sync-pending{color:#8a5b2c;background:#fbf1e6;border-color:#f3d7b4}.sync-synced{color:#1c6b4b;background:#e9f7f0;border-color:#bfe7d5}.sync-failed{color:#8a1f2b;background:#fdecef;border-color:#f6b8c1}.api-error{position:fixed;right:16px;bottom:90px;background:#1f2a2b;color:#f5f7f6;padding:10px 14px;border-radius:12px;font-size:12px;box-shadow:var(--shadow);z-index:50}.bottom-nav{position:fixed;bottom:16px;left:50%;transform:translate(-50%);display:grid;grid-auto-flow:column;gap:10px;background:#fff;border-radius:999px;padding:8px;box-shadow:var(--shadow)}.nav-item{background:transparent;padding:10px 16px;border-radius:999px;font-size:13px;text-decoration:none;color:inherit;display:inline-flex;align-items:center;justify-content:center}.nav-item.active{background:var(--primary);color:#fff}.modal{border:none;border-radius:20px;padding:0;width:min(640px,92vw);box-shadow:var(--shadow)}.modal::backdrop{background:#18181866}.modal form{padding:20px;display:grid;gap:16px}.modal header{display:flex;justify-content:space-between;align-items:center}.modal-header{display:flex;justify-content:space-between;align-items:center}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#18181873;display:grid;place-items:center;z-index:1000;padding:24px 16px}.modal-card{width:min(640px,92vw);background:var(--card);border-radius:20px;padding:20px;box-shadow:var(--shadow);display:grid;gap:16px;max-height:calc(100vh - 96px);overflow:auto}.modal-card-wide{width:min(860px,94vw)}.modal-actions{display:flex;justify-content:space-between;align-items:center}.day-summary{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));background:#f8f6f2;border:1px solid #efe7dd;border-radius:12px;padding:12px;font-size:12px}.day-summary strong{display:block;font-size:16px;margin-top:4px}.day-list{display:grid;gap:10px;list-style:none;padding:0;margin:0}.day-item{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;padding:10px 12px;border-radius:12px;border:1px solid #edf1f0;background:#faf9f6;font-size:13px}.day-item span{display:block;font-size:12px;color:var(--muted);margin-top:4px}.day-amount{font-weight:700;white-space:nowrap}.day-amount.income{color:#2b7f7a}.day-amount.expense{color:#8a1f2b}.form-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.form-grid label{display:grid;gap:6px;font-size:12px;color:var(--muted)}.form-grid input,.form-grid select{padding:10px 12px;border-radius:12px;border:1px solid #d7e2e1}.form-grid select:disabled{background:#f1f1f1;color:#9aa4a4;border-color:#e1e1e1}.form-grid .full{grid-column:1 / -1}.modal footer{display:flex;justify-content:space-between;align-items:center}.category-editor,.asset-editor,.payment-method-editor{display:grid;gap:10px}.payment-method-editor-row{display:grid;gap:10px;grid-template-columns:1fr auto;align-items:center;background:#f8fbfa;padding:10px;border-radius:12px;border:1px solid #e6efec}.payment-method-editor-row input{padding:8px 10px;border-radius:10px;border:1px solid #d7e2e1}.asset-editor-row{display:grid;gap:10px;grid-template-columns:.9fr 1.2fr 1.2fr .9fr auto;align-items:center;background:#f8fbfa;padding:10px;border-radius:12px;border:1px solid #e6efec}.asset-editor-row input,.asset-editor-row select{padding:8px 10px;border-radius:10px;border:1px solid #d7e2e1}.category-tabs{display:flex;gap:8px}.tab-button{border:1px solid #d7e2e1;background:#fff;padding:8px 14px;border-radius:12px;font-size:12px;color:var(--muted);cursor:pointer;box-shadow:0 8px 18px #0f3d3e14}.tab-button.active{background:var(--primary);border-color:var(--primary);color:#fff}.category-row{display:grid;gap:10px;grid-template-columns:1.4fr .8fr .5fr auto;align-items:center;background:#f8f6f2;padding:10px;border-radius:12px;border:1px solid #ede7dd}.category-row input,.category-row select{padding:8px 10px;border-radius:10px;border:1px solid #d7e2e1}.category-row input[type=color]{padding:0;width:40px;height:32px;border:none;background:transparent}.hint{font-size:12px;color:var(--muted)}body{background:radial-gradient(1200px 480px at 12% -5%,#d6efe8 0%,transparent 70%),radial-gradient(900px 420px at 92% 8%,#f5e9d8 0%,transparent 68%),linear-gradient(180deg,#f7f4ee,#eef5f3)}.app{max-width:1080px;padding-top:var(--space-md);padding-bottom:132px}.app-header{position:sticky;top:8px;z-index:20;background:#ffffffdb;border:1px solid #e5ecea;border-radius:20px;padding:12px 14px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);margin-bottom:var(--space-md);box-shadow:0 12px 28px #0f3d3e1a}.logo{background:linear-gradient(150deg,#0f3d3e,#1d7771)}button{transition:transform .16s ease,box-shadow .16s ease,background-color .16s ease}button:active{transform:translateY(1px) scale(.99)}button.primary{background:linear-gradient(135deg,#0f3d3e,#1d7771);box-shadow:0 10px 20px #166c6747}button.ghost{background:#fff}.month-toolbar{justify-content:center;align-items:end;flex-wrap:wrap;gap:8px;margin-bottom:var(--space-lg)}.month-picker{padding:10px 12px;background:#fff;border:1px solid #d9e5e2;border-radius:14px}.month-picker input{border:none;padding:0;min-height:24px}.month-shift,.month-current{min-height:44px}.card{border:1px solid #e8efed;box-shadow:0 18px 36px #1143421a;animation:card-rise .26s ease}@keyframes card-rise{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.summary{background:linear-gradient(180deg,#fff,#f7fbfa)}.summary-cards .mini{border:1px solid #ecf0ed}.tx-item{border-radius:16px;border:1px solid #e8efed;background:linear-gradient(180deg,#fff,#f8fbfa)}.tx-meta strong{font-size:15px}.tx-amount{font-size:17px}.bottom-nav{width:min(560px,calc(100% - 24px));padding:7px;border:1px solid #e4ecea;box-shadow:0 18px 34px #153c3b2e}.nav-item{display:grid;text-align:center;gap:2px;min-width:0;padding:8px 10px}.nav-main{font-size:12px;line-height:1.15;font-weight:700}.nav-sub{font-size:10px;opacity:.72;line-height:1.1}.nav-item.active .nav-sub{opacity:.86}.fab-add{position:fixed;right:max(16px,calc(50% - 520px));bottom:98px;width:58px;height:58px;border-radius:50%;border:none;font-size:30px;line-height:1;color:#fff;background:linear-gradient(140deg,#f09252,#ec6b5e);box-shadow:0 16px 26px #ec6b5e5c;z-index:80}.fab-add:hover{transform:translateY(-1px)}@media (max-width: 768px){.app-header{align-items:flex-start}.header-actions{width:100%;justify-content:flex-start}.summary,.reports{grid-column:span 1}.grid{grid-template-columns:1fr}.summary-cards{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.chart-grid{grid-template-columns:1fr}.bar-chart{overflow-x:auto;padding-bottom:6px}.bar{min-width:42px}.calendar-grid{gap:6px}.calendar-day{min-height:auto;aspect-ratio:1 / 1;padding:6px}.tx-item{grid-template-columns:1fr}.tx-actions{justify-content:space-between;flex-wrap:wrap}.bottom-nav{width:calc(100% - 20px);justify-content:space-between}.fab-add{right:16px;width:54px;height:54px;font-size:28px}}@media (max-width: 390px){.app{padding-bottom:132px}.brand{flex-wrap:wrap;gap:10px}.logo{width:44px;height:44px;border-radius:12px;font-size:18px}.section-header{align-items:flex-start}.summary-row{flex-direction:column;align-items:flex-start}.filters{width:100%}.filters input,.filters select{flex:1 1 140px}.filter-grid{grid-template-columns:1fr}.filter-actions{justify-content:stretch}.filter-actions button{width:100%}.result-pill{flex:1 1 calc(50% - 6px);min-width:0}.bottom-nav{padding:6px;gap:6px}.nav-item{padding:7px 8px}.nav-main{font-size:11px}.nav-sub{font-size:9px}.category-row,.asset-editor-row{grid-template-columns:1fr}.page-calendar .reports{padding:0;background:transparent;box-shadow:none;border:none}.page-calendar .calendar{border-radius:0;padding:12px;border:none}.page-calendar .calendar-grid{gap:6px}.calendar-day .amount{display:none}}
