/* ════════ DESIGN TOKENS ════════ */
:root,[data-theme="dark"]{
  --bg:#141416;--bg2:#0e0e10;
  --card:#1e1e22;--card2:#28282f;--card3:#303038;
  --border:rgba(255,255,255,.08);--border2:rgba(255,255,255,.14);
  --shadow:0 2px 16px rgba(0,0,0,.5);
  --text:#f2f2f7;--text2:#aeaeb2;--text3:#636366;
  --nav-bg:rgba(20,20,22,.96);--hdr-bg:rgba(20,20,22,.92);
  --tx-date-bg:#0e0e10;--toggle-bg:#2c2c2e;
  color-scheme:dark;
}
[data-theme="light"]{
  --bg:#f2f2f7;--bg2:#e5e5ea;
  --card:#ffffff;--card2:#f2f2f7;--card3:#e5e5ea;
  --border:rgba(0,0,0,.07);--border2:rgba(0,0,0,.12);
  --shadow:0 2px 12px rgba(0,0,0,.08);
  --text:#1c1c1e;--text2:#3c3c43;--text3:#8e8e93;
  --nav-bg:rgba(242,242,247,.96);--hdr-bg:rgba(242,242,247,.92);
  --tx-date-bg:#f2f2f7;--toggle-bg:#e5e5ea;
  color-scheme:light;
}
:root{
  --orange:#ff9500;--orange-bg:rgba(255,149,0,.12);
  --green:#32d74b;--red:#ff453a;
  --blue:#0a84ff;--purple:#bf5af2;--gold:#ffd60a;
  --mono:'DM Mono',monospace;
  --sans:'Noto Sans JP',sans-serif;
  --hdr-h:52px;--nav-h:56px;
  --radius:16px;--radius-sm:10px;
}

/* ════════ BASE ════════ */
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html{height:100%}
body{
  height:100%;background:var(--bg);color:var(--text);
  font-family:var(--sans);font-size:17px;line-height:1.55;
  overscroll-behavior:none;
  -webkit-overflow-scrolling:touch;
}

/* ════════ HEADER ════════ */
header{
  position:fixed;top:0;left:0;right:0;height:var(--hdr-h);
  display:flex;align-items:center;padding:0 16px;
  background:var(--hdr-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:.5px solid var(--border2);z-index:200;gap:10px;
}
.hdr-back{display:none;align-items:center;font-size:1.05rem;color:var(--orange);cursor:pointer;min-width:56px;gap:2px;font-weight:500}
.hdr-back.visible{display:flex}
.hdr-title{flex:1;font-size:1.05rem;font-weight:700;color:var(--text);text-align:center}
.hdr-right{display:flex;align-items:center;gap:8px;min-width:56px;justify-content:flex-end}
.hdr-date{font-size:.75rem;color:var(--text3);font-family:var(--mono);white-space:nowrap}

/* ════════ THEME SEG ════════ */
.theme-seg{display:flex;align-items:center;background:var(--toggle-bg);border-radius:10px;padding:3px;gap:2px;border:.5px solid var(--border2);flex-shrink:0}
.theme-seg-btn{display:flex;align-items:center;justify-content:center;width:28px;height:22px;border-radius:7px;cursor:pointer;font-size:.78rem;color:var(--text3);transition:background .2s,color .2s,box-shadow .2s;user-select:none}
.theme-seg-btn:hover{color:var(--text2)}
.theme-seg-btn.active{background:var(--card);color:var(--orange);box-shadow:0 1px 4px rgba(0,0,0,.2)}
.seg-label{font-size:.6rem;font-family:var(--mono);font-weight:500;letter-spacing:.02em}

/* ════════ LAYOUT ════════ */
main{
  padding-top:var(--hdr-h);
  padding-bottom:calc(var(--nav-h) + env(safe-area-inset-bottom,0px));
  overflow-y:auto;
  height:100vh;
  -webkit-overflow-scrolling:touch;
  scroll-behavior:smooth;
}
.page{display:none;padding:14px 14px 20px;max-width:480px;margin:0 auto}
.page.active{display:block}

/* ════════ BOTTOM NAV ════════ */
nav{
  position:fixed;bottom:0;left:0;right:0;
  height:calc(var(--nav-h) + env(safe-area-inset-bottom,0px));
  background:var(--nav-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-top:.5px solid var(--border2);
  display:flex;align-items:flex-start;padding-top:6px;
  padding-bottom:env(safe-area-inset-bottom,0);z-index:200;
}
.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:2px 0;color:var(--text3);cursor:pointer;text-decoration:none;transition:color .18s}
.nav-item.active{color:var(--orange)}
.nav-item.active .nav-icon-bg{background:var(--orange-bg);transform:scale(1.08)}
.nav-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center}
.nav-icon svg{width:26px;height:26px;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;transition:stroke .18s}
.nav-item.active svg{stroke:var(--orange)}
.nav-icon-bg{width:36px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:10px;transition:background .18s,transform .18s}
.nav-label{font-size:.7rem;font-weight:600;letter-spacing:.01em}

/* ════════ OVERLAY ════════ */
.overlay{
  position:fixed;top:0;left:0;right:0;bottom:0;
  background:var(--bg);z-index:150;
  transform:translateX(100%);
  transition:transform .3s cubic-bezier(.25,.46,.45,.94);
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  padding-top:var(--hdr-h);
  padding-bottom:calc(var(--nav-h) + env(safe-area-inset-bottom,0px));
}
.overlay.open{transform:translateX(0)}
.overlay-inner{padding:14px 14px 0;max-width:480px;margin:0 auto}

/* ════════ CARD ════════ */
.card{background:var(--card);border-radius:var(--radius);margin-bottom:12px;box-shadow:var(--shadow);overflow:hidden}
.card-head{display:flex;align-items:center;padding:15px 16px 10px;gap:6px}
.card-title{font-size:1rem;font-weight:700;color:var(--text);flex:1}
.card-sub{font-size:.82rem;color:var(--text3);font-family:var(--mono)}
.card-body{padding:0 16px 16px}
.card-body-flush{padding:0}
.card-arrow{font-size:1.1rem;color:var(--text3)}
.tap-card{cursor:pointer;transition:opacity .15s}
.tap-card:active{opacity:.7}

/* ════════ HERO CARD ════════ */
.hero-card{
  background:linear-gradient(135deg,var(--card) 0%,var(--card2) 100%);
  border-radius:var(--radius);margin-bottom:12px;
  box-shadow:var(--shadow);padding:20px 18px 16px;cursor:pointer;transition:opacity .15s;
  border:.5px solid var(--border2);
}
.hero-card:active{opacity:.85}
.hero-top{display:flex;align-items:center;margin-bottom:4px}
.hero-label{font-size:.85rem;color:var(--text3);font-weight:500;flex:1}
.hero-num{font-size:2.6rem;font-weight:700;color:var(--text);letter-spacing:-.03em;margin-bottom:12px;font-family:var(--mono);line-height:1.1}
.hero-num.up{color:var(--green)}
.hero-num.dn{color:var(--red)}

/* ──眼アイコン── */
.eye-btn{background:none;border:none;cursor:pointer;font-size:1rem;padding:4px 6px;border-radius:6px;color:var(--text3);transition:background .15s,color .15s;margin-left:4px}
.eye-btn:hover{background:var(--card2);color:var(--text2)}

/* ── 資産バー ── */
.asset-bar{display:flex;height:6px;border-radius:3px;overflow:hidden;gap:2px;margin-bottom:8px}
.asset-bar-seg{border-radius:3px;transition:flex .4s}
.asset-legend{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:12px}
.asset-leg-item{display:flex;align-items:center;gap:5px;font-size:.8rem;color:var(--text2)}
.leg-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}

/* ── hero sub-row ── */
.hero-divider{width:.5px;background:var(--border2);align-self:stretch;margin:2px 0}
.hero-sub{display:flex;gap:0;border-top:.5px solid var(--border2);padding-top:12px;margin-top:2px}
.hero-sub-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px}
.hero-sub-label{font-size:.75rem;color:var(--text3)}
.hero-sub-val{font-size:.92rem;font-weight:600;color:var(--text);font-family:var(--mono)}
.hero-sub-val.dn{color:var(--red)}
.hero-sub-val.muted{color:var(--text3);font-weight:400}

/* ════════ AMOUNTS HIDDEN ════════ */
body.amounts-hidden .amount{filter:blur(8px);user-select:none;pointer-events:none}

/* ════════ HOME CARDS ════════ */
.balance-row{display:flex;gap:0}
.balance-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px 0}
.bl-label{font-size:.78rem;color:var(--text3)}
.bl-val{font-size:1.12rem;font-weight:700;font-family:var(--mono);color:var(--text)}
.bl-val.up{color:var(--green)}.bl-val.dn{color:var(--red)}
.kv-list{list-style:none}
.kv-row{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:.5px solid var(--border)}
.kv-row:last-child{border-bottom:none}
.kv-label{font-size:.9rem;color:var(--text2)}
.kv-val{font-size:1rem;font-weight:600;font-family:var(--mono);color:var(--text)}
.kv-val.up{color:var(--green)}.kv-val.dn{color:var(--red)}.kv-val.gold{color:var(--orange)}
.chart-wrap{position:relative}
.chart-wrap.h160{height:160px}
.chart-wrap.h180{height:180px}
.chart-wrap.h200{height:200px}

/* ════════ KAKEIBO ════════ */
.kk-header{display:flex;align-items:center;margin-bottom:10px;gap:8px}
.kk-month-nav{display:flex;align-items:center;gap:2px;flex:1;justify-content:center}
.kk-month-btn{background:none;border:none;cursor:pointer;font-size:1.4rem;color:var(--text3);padding:4px 10px;border-radius:8px;transition:background .15s,color .15s;line-height:1}
.kk-month-btn:hover{background:var(--card2);color:var(--text)}
.kk-month-label{font-size:1.05rem;font-weight:700;color:var(--text);min-width:90px;text-align:center}
.kk-action-btn{background:none;border:none;cursor:pointer;font-size:1.15rem;padding:6px;border-radius:8px;color:var(--text3);transition:background .15s,color .15s}
.kk-action-btn:hover{background:var(--card2);color:var(--text2)}

.kk-summary{background:var(--card);border-radius:var(--radius);margin-bottom:12px;padding:12px 16px;display:flex;gap:0;box-shadow:var(--shadow)}
.kk-sum-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px}
.kk-sum-divider{width:.5px;background:var(--border2);margin:2px 0}
.kk-sum-label{font-size:.78rem;color:var(--text3)}
.kk-sum-val{font-size:1.08rem;font-weight:700;font-family:var(--mono);color:var(--text)}
.kk-sum-val.up{color:var(--green)}.kk-sum-val.dn{color:var(--red)}

/* ドーナツエリア */
.kk-donut-card{background:var(--card);border-radius:var(--radius);margin-bottom:12px;box-shadow:var(--shadow);overflow:hidden;touch-action:pan-y}
.kk-donut-toggle{display:flex;background:var(--card2);border-radius:var(--radius-sm);padding:3px;margin:12px 16px 0;gap:2px}
.kk-toggle-btn{flex:1;text-align:center;padding:8px;font-size:.88rem;font-weight:500;color:var(--text3);border-radius:8px;cursor:pointer;transition:all .18s}
.kk-toggle-btn.active{background:var(--card);color:var(--text);box-shadow:0 1px 6px rgba(0,0,0,.18)}
.kk-donut-wrap{display:flex;align-items:center;padding:14px 16px;gap:12px}
.kk-donut-chart{position:relative;width:160px;height:160px;flex-shrink:0}
.kk-donut-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;pointer-events:none}
.kk-donut-center-label{font-size:.72rem;color:var(--text3);margin-bottom:1px}
.kk-donut-center-num{font-size:1.08rem;font-weight:700;color:var(--text);font-family:var(--mono)}
.kk-donut-legend{flex:1;display:flex;flex-direction:column;gap:6px;overflow:hidden}
.kk-leg-item{display:flex;align-items:center;gap:7px;font-size:.85rem;cursor:pointer;padding:3px 5px;border-radius:6px;transition:background .15s}
.kk-leg-item:hover{background:var(--card2)}
.kk-leg-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.kk-leg-name{flex:1;color:var(--text2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.kk-leg-pct{font-size:.78rem;color:var(--text3);font-family:var(--mono)}

/* カテゴリリスト */
.cat-list{list-style:none}
.cat-row{display:flex;align-items:center;padding:11px 16px;border-bottom:.5px solid var(--border);cursor:pointer;transition:background .15s;gap:10px}
.cat-row:last-child{border-bottom:none}
.cat-row:hover{background:var(--card2)}
.cat-row:active{background:var(--card3)}
.cat-icon-wrap{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:1.15rem;flex-shrink:0}
.cat-name{flex:1;font-size:.95rem;font-weight:500;color:var(--text)}
.cat-right{display:flex;flex-direction:column;align-items:flex-end;gap:2px}
.cat-amount{font-size:1rem;font-weight:700;font-family:var(--mono);color:var(--text)}
.cat-pct{font-size:.75rem;color:var(--text3);font-family:var(--mono)}
.cat-chevron{font-size:.9rem;color:var(--text3);margin-left:4px}

/* カテゴリ詳細 */
.cat-detail-header{padding:16px 16px 12px;border-bottom:.5px solid var(--border2)}
.cat-detail-title{font-size:1.2rem;font-weight:700;color:var(--text);display:flex;align-items:center;gap:8px}
.cat-detail-total{font-size:.9rem;color:var(--text3);margin-top:3px}
.sub-cat-list{list-style:none;margin-bottom:8px}
.sub-cat-row{display:flex;align-items:center;padding:10px 16px;border-bottom:.5px solid var(--border);gap:10px}
.sub-cat-row:last-child{border-bottom:none}
.sub-cat-name{flex:1;font-size:.88rem;color:var(--text2)}
.sub-cat-bar-wrap{flex:1;height:4px;background:var(--card3);border-radius:2px;overflow:hidden}
.sub-cat-bar{height:100%;border-radius:2px}
.sub-cat-amount{font-size:.88rem;font-weight:600;font-family:var(--mono);color:var(--text);min-width:70px;text-align:right}

/* ════════ INVEST ════════ */
.tabs{display:flex;gap:0;background:var(--card2);border-radius:var(--radius-sm);padding:3px;margin-bottom:12px;border:.5px solid var(--border)}
.tab{flex:1;padding:9px 4px;text-align:center;font-size:.84rem;font-weight:500;color:var(--text3);cursor:pointer;border-radius:8px;transition:all .18s}
.tab.active{background:var(--card);color:var(--text);box-shadow:0 1px 6px rgba(0,0,0,.18)}
.tab-panel{display:none}.tab-panel.active{display:block}

/* KUMA/LIN broker sub-tabs */
.broker-tabs{display:flex;gap:6px;margin-bottom:12px}
.broker-tab{padding:6px 14px;border-radius:20px;font-size:.82rem;font-weight:500;cursor:pointer;
  border:.5px solid var(--border2);color:var(--text3);background:var(--card2);transition:all .15s}
.broker-tab.active{background:var(--orange-bg);color:var(--orange);border-color:rgba(255,149,0,.3)}

/* VA purchase plan table */
.va-header{display:flex;align-items:center;justify-content:space-between;padding:10px 0 6px}
.va-month-badge{font-size:.75rem;background:var(--orange-bg);color:var(--orange);
  padding:3px 10px;border-radius:20px;font-weight:600}
.va-method-badge{font-size:.65rem;padding:2px 6px;border-radius:4px;font-weight:600}
.va-method-snapshot{background:rgba(50,215,75,.15);color:var(--green)}
.va-method-approx{background:rgba(255,149,0,.12);color:var(--orange)}
.va-table{width:100%;border-collapse:collapse}
.va-table th{font-size:.7rem;font-weight:600;color:var(--text3);text-align:right;
  padding:5px 8px;border-bottom:.5px solid var(--border2);white-space:nowrap}
.va-table th:first-child{text-align:left}
.va-table td{font-size:.82rem;padding:10px 8px;border-bottom:.5px solid var(--border);
  font-family:var(--mono);color:var(--text);text-align:right;vertical-align:middle}
.va-table td:first-child{text-align:left;font-family:var(--sans);font-weight:500}
.va-table tr:last-child td{border-bottom:none}
.va-table tr:hover td{background:var(--card2)}
.va-adj-pos{color:var(--green)}.va-adj-neg{color:var(--red)}
.va-total-row td{font-weight:700;background:var(--card2);font-size:.88rem}
.va-ticker-name{font-size:.82rem;color:var(--text);font-weight:500;line-height:1.3}
.va-ticker-sub{font-size:.7rem;color:var(--text3);margin-top:1px}
.va-freq-badge{font-size:.65rem;padding:2px 7px;border-radius:4px;font-weight:600;
  background:var(--card3);color:var(--text3)}

/* Alloc donut */
.donut-wrap{position:relative}
.donut-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;pointer-events:none}
.donut-center-num{font-size:1.05rem;font-weight:700;color:var(--text);font-family:var(--mono)}
.donut-center-sub{font-size:.7rem;color:var(--text3)}
.alloc-legend{margin-top:12px;display:flex;flex-direction:column;gap:6px}
.alloc-leg-item{display:flex;align-items:center;gap:8px}
.alloc-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.alloc-name{flex:1;font-size:.82rem;color:var(--text2)}
.alloc-right{display:flex;gap:8px;align-items:center}
.alloc-jpy{font-size:.82rem;font-family:var(--mono);color:var(--text)}
.alloc-pct{font-size:.75rem;color:var(--text3);font-family:var(--mono);min-width:30px;text-align:right}

/* Progress bars */
.prog-row{margin-bottom:10px}
.prog-top{display:flex;align-items:center;margin-bottom:4px;gap:6px}
.prog-name{font-size:.82rem;color:var(--text2);flex:1}
.prog-nums{display:flex;gap:6px;font-size:.75rem;font-family:var(--mono);align-items:center}
.prog-track{height:5px;background:var(--card3);border-radius:3px;overflow:hidden}
.prog-fill{height:100%;border-radius:3px;transition:width .5s}

/* Stocks */
.chip-row{display:flex;gap:6px;margin-bottom:12px;flex-wrap:wrap}
.chip{padding:5px 12px;border-radius:20px;font-size:.78rem;font-weight:500;background:var(--card2);color:var(--text3);cursor:pointer;transition:all .18s;border:.5px solid var(--border)}
.chip.active{background:var(--orange-bg);color:var(--orange);border-color:rgba(255,149,0,.3)}
.stocks-list{list-style:none}
.stock-row{display:flex;align-items:center;padding:11px 0;border-bottom:.5px solid var(--border);gap:10px;cursor:pointer}
.stock-row:last-child{border-bottom:none}
.stock-row:active{background:var(--card2)}
.stock-ticker{font-size:.88rem;font-weight:700;font-family:var(--mono);color:var(--orange);min-width:52px}
.stock-name{font-size:.82rem;color:var(--text3);line-height:1.4;flex:1}
.stock-right{display:flex;flex-direction:column;align-items:flex-end;gap:2px}
.stock-val{font-size:.95rem;font-weight:700;font-family:var(--mono);color:var(--text)}
.stock-pnl{font-size:.8rem;font-family:var(--mono)}
.stock-pnl.up{color:var(--green)}.stock-pnl.dn{color:var(--red)}
.stock-cost{font-size:.72rem;color:var(--text3);font-family:var(--mono)}
.badge{display:inline-block;padding:1px 6px;border-radius:4px;font-size:.65rem;font-weight:600;letter-spacing:.02em}
.badge-green{background:rgba(50,215,75,.15);color:var(--green)}
.badge-orange{background:rgba(255,149,0,.15);color:var(--orange)}
.badge-gray{background:var(--card2);color:var(--text3)}
.badge-red{background:rgba(255,69,58,.15);color:var(--red)}

/* Sim params */
.sim-param-row{display:flex;justify-content:space-between;padding:7px 0;border-bottom:.5px solid var(--border);font-size:.85rem}
.sim-param-row:last-child{border-bottom:none}
.sim-param-label{color:var(--text2)}

/* Stock detail overlay */
.stock-detail-header{display:flex;align-items:center;gap:12px;padding:4px 0 16px}
.stock-detail-ticker{font-size:1.4rem;font-weight:700;color:var(--orange);font-family:var(--mono)}
.stock-detail-name{font-size:.88rem;color:var(--text3);flex:1}
.stock-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}
.stock-detail-item{background:var(--card2);border-radius:10px;padding:10px 14px}
.stock-detail-label{font-size:.7rem;color:var(--text3);margin-bottom:3px}
.stock-detail-val{font-size:1rem;font-weight:700;font-family:var(--mono);color:var(--text)}
/* ════════ PROPERTY ════════ */
.re-hero{background:linear-gradient(135deg,var(--card),var(--card2));border-radius:var(--radius);margin-bottom:12px;padding:18px 18px 14px;box-shadow:var(--shadow);border:.5px solid var(--border2)}
.re-hero-label{font-size:.75rem;color:var(--text3);margin-bottom:4px}
.re-hero-num{font-size:2rem;font-weight:700;font-family:var(--mono);color:var(--text);margin-bottom:12px}
.re-hero-num.up{color:var(--green)}.re-hero-num.dn{color:var(--red)}
.re-stats{display:flex;gap:0;border-top:.5px solid var(--border2);padding-top:12px}
.re-stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px}
.re-stat-label{font-size:.7rem;color:var(--text3)}
.re-stat-val{font-size:.88rem;font-weight:600;font-family:var(--mono);color:var(--text)}
.re-stat-val.up{color:var(--green)}.re-stat-val.dn{color:var(--red)}
.detail-row{display:flex;justify-content:space-between;padding:7px 0;border-bottom:.5px solid var(--border);font-size:.85rem}
.detail-row:last-child{border-bottom:none}
.detail-key{color:var(--text2)}
.detail-val{font-family:var(--mono);color:var(--text);font-weight:500}

/* ════════ ASSETS ════════ */
.assets-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 16px;gap:12px;color:var(--text3);text-align:center}
.assets-placeholder-icon{font-size:3rem;opacity:.4}
.assets-placeholder-title{font-size:1rem;font-weight:600;color:var(--text2)}
.assets-placeholder-sub{font-size:.82rem;line-height:1.6}

/* ════════ TX LIST ════════ */
.tx-date-header{font-size:.8rem;font-weight:600;color:var(--text3);background:var(--tx-date-bg);padding:6px 16px;font-family:var(--mono)}
.tx-row{display:flex;align-items:center;padding:11px 16px;gap:10px;border-bottom:.5px solid var(--border)}
.tx-row:last-child{border-bottom:none}
.tx-icon{width:36px;height:36px;border-radius:10px;background:var(--card2);display:flex;align-items:center;justify-content:center;font-size:1.05rem;flex-shrink:0}
.tx-info{flex:1;min-width:0}
.tx-desc{font-size:.92rem;font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tx-cat{font-size:.75rem;color:var(--text3);margin-top:1px}
.tx-amount{font-size:.95rem;font-weight:700;font-family:var(--mono);color:var(--red);white-space:nowrap}
.tx-amount.up{color:var(--green)}

/* ════════ UTILS ════════ */
.up{color:var(--green)}.dn{color:var(--red)}.gold{color:var(--orange)}.muted{color:var(--text3)}
.empty{text-align:center;padding:36px 0;color:var(--text3);font-size:.88rem}
.section-title{font-size:.78rem;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;padding:16px 0 8px}

/* ════════ 振替セクション ════════ */
.transfer-section{margin-top:4px}
.transfer-header{display:flex;align-items:center;gap:8px;padding:10px 16px 6px;cursor:pointer;user-select:none}
.transfer-header-label{font-size:.8rem;font-weight:600;color:var(--text3);flex:1}
.transfer-badge{font-size:.72rem;background:var(--card2);color:var(--text3);padding:2px 8px;border-radius:20px;font-family:var(--mono)}
.transfer-chevron{font-size:.8rem;color:var(--text3);transition:transform .2s}
.transfer-chevron.open{transform:rotate(90deg)}
.transfer-body{display:none}
.transfer-body.open{display:block}
.transfer-row{display:flex;align-items:center;padding:9px 16px;border-bottom:.5px solid var(--border);gap:10px;opacity:.7}
.transfer-row:last-child{border-bottom:none}
.transfer-icon{width:28px;height:28px;border-radius:8px;background:var(--card3);display:flex;align-items:center;justify-content:center;font-size:.85rem;flex-shrink:0}
.transfer-desc{flex:1;font-size:.85rem;color:var(--text2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.transfer-cat{font-size:.72rem;color:var(--text3)}
.transfer-amount{font-size:.88rem;font-family:var(--mono);color:var(--text3);white-space:nowrap}

/* ════════ カテゴリ修正 ════════ */
/* ロングプレス or 長押しアイコン */
.tx-reclassify-btn{
  display:none;background:none;border:none;cursor:pointer;
  font-size:.8rem;padding:3px 6px;border-radius:6px;
  color:var(--text3);margin-left:4px;flex-shrink:0;
  transition:background .15s,color .15s;
}
.tx-row:hover .tx-reclassify-btn,
.tx-row:focus-within .tx-reclassify-btn{display:block}
.tx-reclassify-btn:hover{background:var(--orange-bg);color:var(--orange)}

/* モーダル */
.modal-backdrop{
  position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:400;
  display:flex;align-items:flex-end;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .25s;
}
.modal-backdrop.open{opacity:1;pointer-events:all}
.modal-sheet{
  background:var(--card);border-radius:20px 20px 0 0;
  width:100%;max-width:480px;max-height:82vh;
  display:flex;flex-direction:column;
  transform:translateY(40px);transition:transform .25s;
  overflow:hidden;
}
.modal-backdrop.open .modal-sheet{transform:translateY(0)}
.modal-handle{width:36px;height:4px;background:var(--border2);border-radius:2px;margin:12px auto 4px}
.modal-title{font-size:1rem;font-weight:700;padding:8px 20px 12px;border-bottom:.5px solid var(--border2)}
.modal-tx-info{padding:12px 20px;background:var(--card2);border-bottom:.5px solid var(--border)}
.modal-tx-desc{font-size:.92rem;font-weight:600;color:var(--text);margin-bottom:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.modal-tx-meta{font-size:.78rem;color:var(--text3)}
.modal-body{overflow-y:auto;-webkit-overflow-scrolling:touch;flex:1;padding:8px 0}
.cat-picker-group{padding:6px 0}
.cat-picker-group-label{font-size:.72rem;font-weight:600;color:var(--text3);padding:4px 20px 2px;text-transform:uppercase;letter-spacing:.06em}
.cat-picker-item{display:flex;align-items:center;padding:11px 20px;gap:12px;cursor:pointer;transition:background .12s}
.cat-picker-item:hover{background:var(--card2)}
.cat-picker-item.selected{background:var(--orange-bg)}
.cat-picker-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.cat-picker-name{flex:1;font-size:.95rem;color:var(--text)}
.cat-picker-check{font-size:1rem;color:var(--orange)}
.modal-footer{padding:12px 20px;border-top:.5px solid var(--border2);display:flex;gap:10px}
.modal-btn{flex:1;padding:13px;border-radius:12px;border:none;cursor:pointer;font-size:.95rem;font-weight:600;transition:opacity .15s}
.modal-btn:active{opacity:.75}
.modal-btn-primary{background:var(--orange);color:#fff}
.modal-btn-cancel{background:var(--card2);color:var(--text2)}

/* 未適用ルール バナー */
.pending-rules-banner{
  background:var(--orange-bg);border:1px solid rgba(255,149,0,.25);
  border-radius:12px;padding:12px 16px;margin-bottom:12px;
  display:none;
}
.pending-rules-banner.visible{display:block}
.pending-rules-title{font-size:.88rem;font-weight:700;color:var(--orange);margin-bottom:4px}
.pending-rules-body{font-size:.8rem;color:var(--text2);line-height:1.6}
.pending-rules-cmd{
  font-family:var(--mono);font-size:.78rem;
  background:rgba(0,0,0,.2);border-radius:6px;
  padding:6px 10px;margin-top:6px;white-space:pre;overflow-x:auto;
  color:var(--text);cursor:pointer;
}
.pending-rules-cmd:hover{background:rgba(255,149,0,.15)}
.pending-rules-copy{font-size:.72rem;color:var(--orange);margin-top:4px;text-align:right}

/* ════════ PHASE 2: 検索・フィルター ════════ */
.search-bar-wrap{position:sticky;top:0;z-index:10;background:var(--bg);padding:10px 14px 6px}
.search-bar{
  display:flex;align-items:center;gap:8px;
  background:var(--card2);border-radius:12px;
  padding:9px 14px;border:.5px solid var(--border);
}
.search-bar svg{width:16px;height:16px;stroke:var(--text3);fill:none;flex-shrink:0}
.search-bar input{
  flex:1;background:none;border:none;outline:none;
  font-size:.95rem;color:var(--text);caret-color:var(--orange);
  font-family:var(--sans);
}
.search-bar input::placeholder{color:var(--text3)}
.search-bar-clear{background:none;border:none;cursor:pointer;font-size:1rem;
  color:var(--text3);padding:0 2px;display:none}
.search-bar-clear.visible{display:block}

.filter-chips-row{
  display:flex;gap:6px;padding:0 14px 8px;overflow-x:auto;
  scrollbar-width:none;-webkit-overflow-scrolling:touch;
}
.filter-chips-row::-webkit-scrollbar{display:none}
.filter-chip{
  display:inline-flex;align-items:center;gap:5px;
  white-space:nowrap;font-size:.8rem;font-weight:500;
  padding:5px 12px;border-radius:20px;cursor:pointer;
  border:.5px solid var(--border2);background:var(--card2);color:var(--text3);
  transition:all .15s;flex-shrink:0;
}
.filter-chip.active{background:var(--orange-bg);color:var(--orange);border-color:rgba(255,149,0,.3)}
.filter-chip.has-filter{background:var(--orange-bg);color:var(--orange);border-color:rgba(255,149,0,.3)}
.filter-chip-count{font-size:.7rem;background:var(--orange);color:#fff;
  border-radius:10px;padding:1px 5px;margin-left:2px}

.ledger-result-info{
  font-size:.78rem;color:var(--text3);padding:0 16px 6px;
  display:flex;align-items:center;justify-content:space-between;
}
.ledger-empty{text-align:center;padding:48px 0;color:var(--text3)}
.ledger-empty-icon{font-size:2rem;margin-bottom:8px}
.ledger-empty-msg{font-size:.9rem}

/* ════════ FILTER MODAL ════════ */
.filter-modal-backdrop{
  position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:500;
  display:flex;align-items:flex-end;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .25s;
}
.filter-modal-backdrop.open{opacity:1;pointer-events:all}
.filter-modal-sheet{
  background:var(--card);border-radius:20px 20px 0 0;
  width:100%;max-width:480px;
  transform:translateY(40px);transition:transform .25s;
  overflow:hidden;display:flex;flex-direction:column;max-height:88vh;
}
.filter-modal-backdrop.open .filter-modal-sheet{transform:translateY(0)}
.filter-modal-body{overflow-y:auto;-webkit-overflow-scrolling:touch;flex:1;padding:0 0 8px}

.filter-section{padding:16px 20px 0}
.filter-section-label{
  font-size:.75rem;font-weight:700;color:var(--text3);
  text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;
}
.filter-option-grid{display:flex;flex-wrap:wrap;gap:8px}
.filter-option{
  padding:7px 14px;border-radius:20px;font-size:.85rem;cursor:pointer;
  border:.5px solid var(--border2);color:var(--text2);background:var(--card2);
  transition:all .15s;
}
.filter-option.selected{
  background:var(--orange-bg);color:var(--orange);
  border-color:rgba(255,149,0,.35);font-weight:600;
}

.filter-date-row{display:flex;align-items:center;gap:10px}
.filter-date-input{
  flex:1;background:var(--card2);border:.5px solid var(--border2);
  border-radius:10px;padding:8px 12px;color:var(--text);font-size:.88rem;
  font-family:var(--sans);outline:none;
}
.filter-date-input:focus{border-color:var(--orange)}
.filter-date-sep{color:var(--text3);font-size:.9rem}

/* ════════ PHASE 2: 月次レポート ════════ */
.report-section{margin-bottom:14px}
.report-month-bar{
  display:flex;align-items:center;padding:8px 0;gap:10px;
  border-bottom:.5px solid var(--border);
}
.report-month-bar:last-child{border-bottom:none}
.report-bar-label{font-size:.82rem;color:var(--text2);min-width:52px}
.report-bar-track{flex:1;height:7px;background:var(--card2);border-radius:4px;overflow:hidden}
.report-bar-fill{height:100%;border-radius:4px;transition:width .4s cubic-bezier(.25,.46,.45,.94)}
.report-bar-val{font-size:.82rem;font-family:var(--mono);color:var(--text);min-width:68px;text-align:right}

/* ════════ PHASE 2: 年表示トグル ════════ */
.kk-view-toggle{
  display:flex;background:var(--card2);border-radius:10px;
  padding:3px;gap:2px;border:.5px solid var(--border);margin-right:6px;flex-shrink:0;
}
.kk-view-btn{
  padding:5px 12px;border-radius:8px;font-size:.8rem;font-weight:500;
  color:var(--text3);cursor:pointer;border:none;background:none;transition:all .18s;
}
.kk-view-btn.active{background:var(--card);color:var(--text);box-shadow:0 1px 4px rgba(0,0,0,.18)}
/* ════════ PHASE 4: 暗号資産 ════════ */
/* ════════ PHASE 4 REVISED: 暗号資産 ════════ */
/* ヒーローサマリー */
.crypto-hero-row{display:flex;align-items:center;gap:6px;padding:4px 0}
.crypto-hero-item{flex:1;text-align:center}
.crypto-hero-label{font-size:.7rem;color:var(--text3);margin-bottom:3px}
.crypto-hero-val{font-size:1rem;font-weight:700;font-family:var(--mono);color:var(--text)}
.crypto-hero-pct{font-size:.75rem;font-family:var(--mono);margin-top:2px}
.crypto-hero-sep{font-size:.9rem;color:var(--text3);flex-shrink:0}

/* コインカード */
.crypto-coin-card .card-body{padding:12px 14px}
.crypto-coin-header{display:flex;align-items:center;gap:6px;margin-bottom:6px}
.crypto-coin-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.crypto-coin-name{font-size:.88rem;font-weight:700;color:var(--text)}
.crypto-coin-qty{font-size:.82rem;font-family:var(--mono);color:var(--text3);margin-bottom:10px}
.crypto-coin-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.crypto-coin-label{font-size:.68rem;color:var(--text3);margin-bottom:1px}
.crypto-coin-val{font-size:.82rem;font-weight:600;font-family:var(--mono);color:var(--text)}

/* チャートチップ（ヘッダー内） */
.card-head .chip-row .chip{padding:3px 10px!important;font-size:.75rem!important}

@media(max-width:380px){.hero-num{font-size:2rem}.re-hero-num{font-size:1.7rem}}

/* ════════ PHASE 5: 不動産シミュレーター ════════ */
/* ヒーロー拡張 */
.re-kpi-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}
.re-kpi-card{background:var(--card2);border-radius:12px;padding:10px 12px;border:.5px solid var(--border)}
.re-kpi-label{font-size:.68rem;color:var(--text3);margin-bottom:3px}
.re-kpi-val{font-size:.92rem;font-weight:700;font-family:var(--mono);color:var(--text)}
.re-kpi-sub{font-size:.68rem;color:var(--text3);margin-top:2px}

/* 3シナリオ凡例 */
.scenario-legend{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:8px}
.scenario-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:3px}
.scenario-item{display:flex;align-items:flex-start;gap:5px;font-size:.75rem;color:var(--text2)}

/* 売却スライダー */
.sale-slider-wrap{padding:4px 0 8px}
.sale-slider{-webkit-appearance:none;appearance:none;width:100%;height:4px;border-radius:2px;background:var(--border2);outline:none;margin:8px 0}
.sale-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--orange);border:2px solid #fff;cursor:pointer;box-shadow:0 1px 4px rgba(0,0,0,.2)}
.sale-year-label{display:flex;justify-content:space-between;font-size:.72rem;color:var(--text3);margin-top:2px}

/* IRR・指標カード */
.irr-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}
.irr-card{background:var(--card2);border-radius:12px;padding:14px;border:.5px solid var(--border);text-align:center}
.irr-card.highlight{border-color:var(--orange);background:rgba(255,149,0,.06)}
.irr-label{font-size:.72rem;color:var(--text3);margin-bottom:6px}
.irr-val{font-size:1.5rem;font-weight:700;font-family:var(--mono);color:var(--text)}
.irr-val.up{color:var(--green)}.irr-val.dn{color:var(--red)}
.irr-sub{font-size:.72rem;color:var(--text3);margin-top:4px}

/* 売却シナリオテーブル */
.sale-table{width:100%;border-collapse:collapse;font-size:.8rem}
.sale-table th{font-size:.7rem;font-weight:600;color:var(--text3);padding:6px 8px;text-align:right;border-bottom:.5px solid var(--border)}
.sale-table th:first-child{text-align:left}
.sale-table td{padding:7px 8px;border-bottom:.5px solid var(--border2);text-align:right;font-family:var(--mono);color:var(--text2)}
.sale-table td:first-child{text-align:left;font-weight:600;color:var(--text);font-family:inherit}
.sale-table tr.sale-selected td{background:rgba(255,149,0,.07);color:var(--text)}
.sale-table tr.sale-selected td:first-child{color:var(--orange)}

/* CF内訳バー */
.cf-stack-row{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.cf-stack-label{font-size:.72rem;color:var(--text3);width:60px;flex-shrink:0;text-align:right}
.cf-stack-bar{flex:1;height:14px;border-radius:4px;overflow:hidden;background:var(--card2);display:flex}
.cf-stack-seg{height:100%;transition:width .3s}
.cf-stack-val{font-size:.72rem;font-family:var(--mono);color:var(--text3);width:56px;text-align:right;flex-shrink:0}


/* ════════ PHASE 6: 資産タブ ════════ */
.asset-row{display:flex;align-items:center;padding:10px 0;border-bottom:.5px solid var(--border2);gap:10px}
.asset-row:last-child{border-bottom:none}
.asset-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.asset-row-label{flex:1;font-size:.84rem;color:var(--text2);line-height:1.3}
.asset-row-sub{font-size:.7rem;color:var(--text3)}
.asset-row-right{text-align:right}
.asset-row-val{font-size:.88rem;font-weight:600;font-family:var(--mono);color:var(--text)}
.asset-row-pct{font-size:.7rem;color:var(--text3)}
.asset-row.total-row{border-top:.5px solid var(--border);border-bottom:none;padding-top:12px;margin-top:2px}
.asset-row.total-row .asset-row-val{font-size:1rem;color:var(--orange)}
.asset-nw-bar{height:10px;border-radius:5px;overflow:hidden;display:flex;margin:10px 0 8px;gap:1px}
.asset-nw-seg{height:100%;transition:flex .4s}
.asset-nw-legend{display:flex;flex-wrap:wrap;gap:6px 12px}
.asset-nw-leg{display:flex;align-items:center;gap:4px;font-size:.72rem;color:var(--text2)}
.asset-nw-leg-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}

/* ポートフォリオ（統合PF） */
.pf-section-head{display:flex;justify-content:space-between;align-items:center;padding:8px 0 6px;border-bottom:.5px solid var(--border)}
.pf-section-name{font-size:.78rem;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.04em}
.pf-section-val{font-size:.82rem;font-family:var(--mono);font-weight:600;color:var(--text)}
.pf-row{display:flex;align-items:center;padding:7px 0 7px 8px;border-bottom:.5px solid var(--border2);gap:8px}
.pf-row:last-child{border-bottom:none}
.pf-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.pf-name{flex:1;font-size:.8rem;color:var(--text2)}
.pf-val{font-size:.8rem;font-family:var(--mono);color:var(--text);text-align:right}
.pf-pct{font-size:.7rem;color:var(--text3);text-align:right;min-width:34px}
.pf-bar-bg{flex-basis:60px;flex-shrink:0;height:4px;background:var(--card2);border-radius:2px;overflow:hidden}
.pf-bar-fill{height:100%;border-radius:2px}

/* 配当カレンダー */
.div-summary-row{display:flex;gap:10px;margin-bottom:12px}
.div-summary-card{flex:1;background:var(--card2);border-radius:12px;padding:10px 12px;border:.5px solid var(--border);text-align:center}
.div-summary-label{font-size:.68rem;color:var(--text3);margin-bottom:3px}
.div-summary-val{font-size:1.1rem;font-weight:700;font-family:var(--mono);color:var(--orange)}
.div-cal{display:grid;grid-template-columns:repeat(4,1fr);gap:5px;margin-bottom:14px}
.div-cal-cell{background:var(--card2);border-radius:9px;padding:8px 4px;text-align:center;border:.5px solid var(--border)}
.div-cal-cell.has-div{border-color:var(--orange);background:rgba(255,149,0,.08)}
.div-cal-mo{font-size:.65rem;color:var(--text3);margin-bottom:2px}
.div-cal-val{font-size:.74rem;font-weight:600;font-family:var(--mono);color:var(--text)}
.div-cal-cell.has-div .div-cal-val{color:var(--orange)}
.div-ticker-row{display:flex;align-items:center;padding:8px 0;border-bottom:.5px solid var(--border2);gap:8px}
.div-ticker-row:last-child{border-bottom:none}
.div-ticker-label{flex:1}
.div-ticker-name{font-size:.82rem;font-weight:600;color:var(--text)}
.div-ticker-sub{font-size:.7rem;color:var(--text3)}
.div-ticker-yield{font-size:.75rem;font-family:var(--mono);color:var(--text3);text-align:right}
.div-ticker-annual{font-size:.84rem;font-weight:700;font-family:var(--mono);color:var(--orange);min-width:64px;text-align:right}



/* ════════ LOGIN SCREEN ════════ */
.folia-login{position:fixed;inset:0;background:var(--bg);z-index:9999;display:flex;align-items:center;justify-content:center;padding:24px}
.login-card{background:var(--card);border-radius:24px;padding:40px 32px;width:100%;max-width:360px;box-shadow:0 8px 32px rgba(0,0,0,.12);display:flex;flex-direction:column;align-items:center;gap:12px}
.login-logo{font-size:3rem}
.login-title{font-size:1.6rem;font-weight:800;color:var(--text)}
.login-sub{font-size:.85rem;color:var(--text3);margin-bottom:8px}
.login-input{width:100%;padding:14px 16px;border-radius:14px;border:1.5px solid var(--border2);background:var(--card2);color:var(--text);font-size:.95rem;outline:none;transition:border .2s}
.login-input:focus{border-color:var(--orange)}
.login-btn{width:100%;padding:14px;border-radius:14px;border:none;background:var(--orange);color:#fff;font-size:.95rem;font-weight:700;cursor:pointer;transition:opacity .2s;margin-top:4px}
.login-btn:hover{opacity:.85}
.login-btn:disabled{opacity:.4;cursor:not-allowed}
.login-msg{font-size:.82rem;color:var(--text3);text-align:center;min-height:1.4em}
.login-msg.ok{color:var(--green)}
.login-msg.err{color:var(--red)}

/* ════════ PHASE 7: KV / 資産推移 ════════ */
.kv-status-bar{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--card2);border-radius:10px;font-size:.75rem;margin-bottom:12px;border:.5px solid var(--border)}
.kv-status-dot{width:7px;height:7px;border-radius:50%;background:var(--border2);flex-shrink:0;transition:background .3s}
.kv-status-dot.ok{background:#32d74b}
.kv-status-dot.err{background:#ff453a}
.kv-status-dot.loading{background:#ff9500;animation:pulse 1s infinite}
.kv-status-text{flex:1;color:var(--text2)}
.kv-sync-btn{font-size:.72rem;padding:3px 10px;border-radius:6px;border:.5px solid var(--border2);background:var(--card);color:var(--text2);cursor:pointer;transition:all .15s}
.kv-sync-btn:hover{background:var(--orange);color:#fff;border-color:var(--orange)}
.kv-sync-btn:disabled{opacity:.4;cursor:not-allowed}
.snap-save-btn{width:100%;padding:12px;border-radius:12px;border:none;background:var(--orange);color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;margin-top:10px;transition:opacity .2s}
.snap-save-btn:hover{opacity:.85}
.snap-save-btn:disabled{opacity:.4;cursor:not-allowed}
.snap-save-result{font-size:.78rem;text-align:center;margin-top:6px;min-height:1.2em;color:var(--text3)}
.trend-empty{display:flex;flex-direction:column;align-items:center;padding:48px 0;gap:10px;color:var(--text3)}
.trend-empty-icon{font-size:2.5rem;opacity:.4}
.trend-empty-title{font-size:.9rem;font-weight:600;color:var(--text2)}
.trend-empty-sub{font-size:.78rem;text-align:center;line-height:1.6}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

