:root{--bg:#f6f7f2;--surface:#fff;--soft:#f7faf8;--field:#fbfcfa;--line:#dfe6de;--line-strong:#c8d3c6;--ink:#162524;--muted:#64706d;--green:#1b6b54;--blue:#2f6fd6;--amber:#c77700;--berry:#8a2c62;--danger:#b3261e;--icon-bg:#edf6f1;--shadow:0 10px 28px #1521260f;color:var(--ink);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px;line-height:1.45}*{box-sizing:border-box}body{min-width:320px;margin:0}button,input,select{letter-spacing:0}button,select{-webkit-tap-highlight-color:transparent}.app-shell{min-height:100svh;padding:18px 18px 88px}.app-header{justify-content:space-between;align-items:center;max-width:1180px;margin:0 auto 18px;display:flex}.app-header h1{color:var(--ink);margin:4px 0 0;font-size:28px;line-height:1}.app-header-img{border-radius:8px;width:100%;height:auto;display:block}.eyebrow{color:var(--muted);letter-spacing:0;text-transform:uppercase;margin:0;font-size:12px;font-weight:750}main{max-width:1180px;margin:0 auto}.month-control{grid-template-columns:42px minmax(180px,260px) 42px;align-items:end;gap:8px;margin:0 0 12px;display:grid}.month-control label{margin:0}.month-control input{height:42px}.summary-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:12px;display:grid}.metric-card{background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:8px;gap:8px;min-height:116px;padding:16px;display:grid}.metric-card-primary{background:linear-gradient(135deg,#e8f4ef 0%,#fff7df 100%);border-color:#c9ddd5}.metric-card span,.breakdown span,.focus-strip span,.simulator span{color:var(--muted);font-size:12px;font-weight:700}.metric-card strong{color:var(--ink);font-size:clamp(22px,3.2vw,42px);line-height:1}.metric-icon{background:var(--icon-bg);color:var(--green);border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;display:inline-flex}.content-layout{grid-template-columns:repeat(3,minmax(0,1fr));align-items:start;gap:12px;display:grid}.content-layout>section[aria-label=固定費とローン]{grid-column:span 2}.content-layout>section[aria-label=貯金戦略メモ]{grid-area:2/3}.panel{background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:8px;padding:18px}.panel-heading{color:var(--green);justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.panel-heading h2{color:var(--ink);margin:4px 0 0;font-size:20px;line-height:1.1}.settings-grid,.inline-fields,.dual-column{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}label{gap:6px;display:grid}label span,.compact-form h3,.list-heading h3{color:var(--ink);margin:0;font-size:13px;font-weight:750}input,select,textarea{appearance:none;background:var(--field);border:1px solid var(--line-strong);color:var(--ink);font:inherit;border-radius:8px;outline:none;width:100%;min-height:42px;padding:9px 11px}input:focus,select:focus,textarea:focus,button:focus-visible{border-color:var(--blue);box-shadow:0 0 0 3px #2f6fd629}textarea{resize:vertical;min-height:104px}.breakdown{border-block:1px solid var(--line);grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:16px 0;padding:14px 0;display:grid}.breakdown div,.focus-strip div,.simulator div{gap:4px;display:grid}.breakdown strong,.focus-strip strong,.simulator strong{color:var(--ink);font-size:18px}.focus-strip,.simulator{background:var(--soft);border:1px solid var(--line);border-radius:8px;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;padding:14px;display:grid}.focus-strip.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.entry-form,.compact-form{gap:12px;display:grid}.amount-field input{height:64px;font-size:30px;font-weight:800}.segmented{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;display:grid}button{cursor:pointer;font:inherit;border:0;justify-content:center;align-items:center;display:inline-flex}.segmented button{background:var(--field);border:1px solid var(--line);color:var(--muted);border-radius:8px;min-height:42px;padding:8px;font-size:13px;font-weight:750}.segmented button.selected{color:#174e98;background:#e7f1ff;border-color:#a8c6f2}.primary-button,.secondary-button{border-radius:8px;gap:8px;min-height:46px;font-weight:800}.primary-button:disabled,.secondary-button:disabled{cursor:not-allowed;opacity:.45}.primary-button{background:var(--green);color:#fff}.secondary-button{color:#6f4700;background:#fff1cf}.icon-button{background:var(--surface);border:1px solid var(--line);color:var(--ink);border-radius:8px;width:42px;height:42px}.icon-button.subtle{box-shadow:none;color:var(--muted);background:0 0;width:36px;height:36px}.list-block{margin-top:18px}.list-heading{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.list-heading span,.empty-text,.item-main small,.simulator p{color:var(--muted);font-size:12px}.empty-text{background:var(--soft);border:1px dashed var(--line-strong);text-align:center;border-radius:8px;margin:0;padding:18px}.item-list{gap:8px;margin:0;padding:0;list-style:none;display:grid}.item-list li{background:var(--soft);border:1px solid var(--line);border-radius:8px;align-items:center;gap:10px;min-height:66px;padding:10px;display:flex}.stacked-item{flex-direction:column;align-items:stretch!important}.item-row{align-items:center;gap:10px;width:100%;display:flex}.item-main{flex:1;gap:3px;min-width:0;display:grid}.item-main span,.item-main strong,.item-main small{overflow-wrap:anywhere}.item-main span{color:var(--ink);font-weight:750}.item-main strong{color:var(--ink)}.plan-list{margin-top:12px}.check-button{color:var(--green);background:#e9f5ec;border-radius:8px;flex:0 0 38px;width:38px;height:38px}.mini-field{gap:6px;width:100%;display:grid}.mini-field span{color:var(--muted);font-size:12px;font-weight:700}.mini-field input,.mini-field select{min-height:38px}.edit-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;width:100%;display:grid}.full-span{grid-column:1/-1}.simulator{grid-template-columns:repeat(2,minmax(0,1fr));margin-top:12px}.simulator input{min-height:28px;padding:0}.simulator p{grid-column:1/-1;margin:0}.savings-progress-bar{background:var(--line);border-radius:4px;width:100%;height:6px;margin:4px 0 2px;overflow:hidden}.savings-progress-fill{background:var(--green);border-radius:4px;height:100%;transition:width .3s}.funded-button{background:var(--field);border:1px solid var(--line-strong);color:var(--muted);flex:0 0 34px;width:34px;height:34px}.funded-button.active{color:#8a6200;background:#fff7df;border-color:#e0c060}.funded-badge{color:#8a6200;vertical-align:middle;background:#fff7df;border:1px solid #e0c060;border-radius:4px;margin-left:6px;padding:1px 5px;font-size:11px;font-weight:700}.muted-text{text-decoration:line-through;color:var(--muted)!important}.strategy-panel{flex-direction:column;gap:16px;display:flex}.strategy-add-toggle{background:var(--green);color:#fff;border-radius:8px;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:800;display:inline-flex}.strategy-form{background:var(--soft);border:1px solid var(--line);border-radius:8px;gap:10px;padding:14px;display:grid}.strategy-form-title{font-size:16px;font-weight:750}.strategy-form-body{min-height:110px}.strategy-board{columns:2;gap:12px}.strategy-card{break-inside:avoid;background:#fffdf0;border:1px solid #e8d87a;border-radius:8px;flex-direction:column;gap:8px;margin-bottom:12px;padding:14px;display:flex}.strategy-card-title{color:var(--ink);min-height:unset;resize:none;white-space:pre-wrap;word-break:break-word;background:0 0;border:none;border-bottom:1px solid #e8d87a;border-radius:0;padding:0 0 8px;font-size:15px;font-weight:800;overflow:hidden}.strategy-card-title:focus{border-color:var(--blue);box-shadow:none;outline:none}.strategy-card-body{color:var(--ink);overflow-wrap:break-word;resize:none;white-space:pre-wrap;word-break:break-word;background:0 0;border:none;border-radius:0;min-height:60px;padding:0;font-size:14px;line-height:1.7;overflow:hidden}.strategy-card-body:focus{box-shadow:none;border:none;outline:none}.strategy-card-footer{justify-content:space-between;align-items:center;margin-top:4px;display:flex}.strategy-card-footer span{color:var(--muted);font-size:11px}.data-export-buttons{gap:8px;display:grid}.import-divider{align-items:center;gap:10px;margin-top:4px;display:flex}.import-divider:before,.import-divider:after{background:var(--line);content:"";flex:1;height:1px}.import-divider span{color:var(--muted);white-space:nowrap;font-size:12px;font-weight:700}.import-panel{background:var(--soft);border:1px solid var(--line);border-radius:8px;gap:10px;margin-top:16px;padding:14px;display:grid}.import-panel h3,.import-panel p{margin:0}.import-panel p,.import-message{color:var(--muted);font-size:12px}.danger-text{color:var(--danger)!important}.bottom-nav{border:1px solid var(--line);padding:8px 12px calc(8px + env(safe-area-inset-bottom));z-index:20;background:#ffffffeb;border-radius:8px 8px 0 0;gap:6px;display:none;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -16px 30px #15212614}.bottom-nav button{color:var(--muted);background:0 0;border-radius:8px;flex-direction:column;flex:1;gap:3px;min-height:54px;padding:6px 2px;font-size:11px;font-weight:750}.bottom-nav button.active{color:#174e98;background:#e7f1ff}@media (width<=920px){.app-shell{padding:14px 14px 90px}.summary-grid{grid-template-columns:1fr}.metric-card{grid-template-columns:36px 1fr;align-items:center;min-height:86px}.metric-card span,.metric-card strong{grid-column:2}.metric-icon{grid-row:1/span 2}.content-layout,.dual-column{grid-template-columns:1fr}.content-layout>section[aria-label=固定費とローン],.content-layout>section[aria-label=貯金戦略メモ]{grid-area:auto}.panel{display:none}.panel.active-panel{display:block}.bottom-nav{display:flex}main[data-tab=strategy] .month-control,main[data-tab=strategy] .summary-grid{display:none}main[data-tab=strategy] .content-layout{margin:0}main[data-tab=strategy] .strategy-panel{border-left:none;border-right:none;border-radius:0;min-height:calc(100svh - 130px);padding:14px}.strategy-board{columns:1}}@media (width<=560px){.app-header h1{font-size:24px}.app-header-img{width:100%;height:auto}.settings-grid,.inline-fields,.breakdown,.focus-strip,.simulator,.edit-grid{grid-template-columns:1fr}.month-control{grid-template-columns:42px minmax(0,1fr) 42px}.segmented{grid-template-columns:repeat(2,minmax(0,1fr))}}
