/* =====================================================================
   ¥Today 経営俯瞰ツール — cashflow/styles.css
   方向B：明朝・抑制トーン（styles_reference_v3.css 準拠）
   ※.phone はスクロール構造を維持（app.jsx の bodyRef.scrollTop に依存）
   ===================================================================== */

:root{
  /* ブランド基調（方向B・記事・ポータルと共通） */
  --ink:#1a1f24;
  --ink-soft:#444c54;
  --paper:#faf8f3;
  --surface:#ffffff;
  --line:#e3e0d8;
  --band:#f1ede3;
  --accent:#7a5c2e;
  --accent-soft:#9c804f;
  --accent-dark:#5e4622;

  /* 状態色（彩度を抑えた上品版） */
  --ok:#5e7a52;        --ok-light:#eef2ea;
  --warn:#8a6d3b;      --warn-light:#f5efe2;
  --danger:#9a5a4f;    --danger-light:#f3e9e6;
  --neutral-state:#6b6357;

  /* 旧変数エイリアス（JSXが参照しても壊れないよう橋渡し） */
  --primary:var(--accent);
  --primary-dark:var(--accent-dark);
  --primary-light:var(--band);
  --navy:var(--ink);
  --navy-2:var(--ink-soft);
  --gold:var(--accent);
  --gold-dark:var(--accent-dark);
  --accent-light:var(--ok-light);
  --warning:var(--warn);
  --warning-light:var(--warn-light);
  --special:var(--accent-soft);
  --neutral:var(--paper);
  --bg-app:var(--paper);
  --text:var(--ink);
  --text-2:var(--ink-soft);
  --border:var(--line);
  --white:var(--surface);

  /* フォント（視認性優先の使い分け） */
  --font-jp:"Hiragino Mincho ProN","Yu Mincho","Noto Serif JP",serif;
  --font-ui:"Hiragino Kaku Gothic ProN","Yu Gothic","Noto Sans JP",sans-serif;
  --font-num:"Montserrat","Hiragino Kaku Gothic ProN",sans-serif;
  --font-mono:var(--font-num);

  /* 形（抑制） */
  --r-sm:3px; --r-md:4px; --r-lg:6px;
  --shadow:0 1px 3px rgba(26,31,36,.06);
  --shadow-soft:0 2px 10px rgba(26,31,36,.05);

  /* 読み物コンテナ幅 */
  --maxw:720px;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--paper)}
body{
  font-family:var(--font-jp);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  line-height:1.85;
  min-height:100vh;
  padding:0;
}
::selection{background:rgba(122,92,46,.18)}

/* =========================================================
   フレーム  .phone
   ★スクロール構造は維持（app.jsx の bodyRef.scrollTop に依存）
   読み物コンテナ幅（最大720px）に拡大
   ========================================================= */
.phone{
  width:100%;
  max-width:var(--maxw);
  margin:0 auto;
  min-height:100vh;
  background:var(--paper);
  border-radius:0;
  overflow:visible;
  display:flex;
  flex-direction:column;
  position:relative;
  box-shadow:none;
}
@media(min-width:480px){ .phone{ min-height:100vh } }

/* ヘッダー（罫線基調・sticky） */
.hdr{
  padding:14px 20px;
  border-bottom:1px solid var(--line);
  background:var(--paper);
  flex-shrink:0;
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  position:sticky;top:0;z-index:10;
}
.hdr-back{font-size:12px;color:var(--accent);font-weight:700;cursor:pointer;background:none;border:none;font-family:var(--font-ui)}
.hdr-back:disabled{color:var(--line);cursor:default}
.hdr-logo{font-size:15px;font-weight:800;color:var(--accent);font-family:var(--font-ui);letter-spacing:.04em;display:flex;align-items:center}
.hdr-step{font-size:11px;color:var(--ink-soft);font-family:var(--font-ui);font-weight:600}
.badge,.tag{font-size:9px;background:var(--accent);color:#fff;padding:2px 8px;border-radius:var(--r-sm);margin-left:6px;font-family:var(--font-ui);font-weight:700;letter-spacing:.06em}

/* brand（cashflow ヘッダー用） */
.brand{display:flex;align-items:center;gap:4px}
.by{font-size:18px;font-weight:900;color:var(--accent);font-family:var(--font-num);line-height:1}
.bt{font-size:13px;font-weight:800;color:var(--ink);font-family:var(--font-num);letter-spacing:-.3px}
.btag{font-size:9px;color:var(--ink-soft);letter-spacing:1px;margin-left:5px;font-family:var(--font-ui);text-transform:uppercase}

/* progress bar（細く・抑制） */
.pbar{height:2px;background:var(--band)}
.pbar-fill{height:100%;background:var(--accent);transition:width .4s cubic-bezier(.4,0,.2,1)}

/* body / footer */
.body{
  flex:1;
  overflow-y:visible;
  overflow-x:hidden;
  padding:22px 20px 26px;
  display:flex;
  flex-direction:column;
  gap:14px;
  background:var(--paper);
  width:100%;
  max-width:var(--maxw);
  margin:0 auto;
}
.foot{
  padding:12px 20px;
  border-top:1px solid var(--line);
  background:var(--paper);
  font-size:11px;
  color:var(--ink-soft);
  text-align:left;
  flex-shrink:0;
  font-family:var(--font-ui);
  line-height:1.8;
}
.foot-note{font-size:11px;color:var(--ink-soft);font-family:var(--font-ui)}

/* =========================================================
   共通タイポ
   ========================================================= */
.eyebrow{font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:6px;font-family:var(--font-ui)}
.stitle,.qtitle{font-size:22px;font-weight:700;color:var(--ink);line-height:1.45;margin-bottom:6px;letter-spacing:.01em;font-family:var(--font-jp)}
.sub,.qsub{font-size:13px;color:var(--ink-soft);margin-bottom:6px;line-height:1.8;font-family:var(--font-jp)}
.sec-title{font-size:13px;font-weight:700;color:var(--ink);margin:8px 0 4px;padding:8px 14px;background:var(--surface);border-radius:var(--r-sm);border-left:3px solid var(--accent);font-family:var(--font-ui)}

/* =========================================================
   選択肢
   ========================================================= */
.choices{display:flex;flex-direction:column;gap:10px}
.choice{display:flex;align-items:flex-start;gap:12px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:14px 16px;cursor:pointer;transition:border-color .2s,background .2s;width:100%;text-align:left}
.choice:hover{border-color:var(--accent-soft)}
.choice.on{border-color:var(--accent);background:var(--band)}
.circle,.choice-check{width:20px;height:20px;border-radius:50%;border:1.5px solid var(--accent-soft);flex-shrink:0;margin-top:1px;display:flex;align-items:center;justify-content:center;background:#fff;font-size:11px;color:#fff}
.circle.on,.choice.on .choice-check{border-color:var(--accent);background:var(--accent);color:#fff}
.check{width:7px;height:7px;border-right:2px solid #fff;border-bottom:2px solid #fff;transform:rotate(45deg) translate(-1px,-2px)}
.choice-body{flex:1}
.clabel,.choice-label{font-size:14px;font-weight:700;color:var(--ink);line-height:1.45;display:block;font-family:var(--font-ui)}
.csub,.choice-sub{font-size:12px;color:var(--ink-soft);margin-top:3px;display:block;font-family:var(--font-ui)}
.choice.multi .circle,.choice.multi .choice-check{border-radius:var(--r-sm)}

/* =========================================================
   CTA
   ========================================================= */
.cta-zone{padding:14px 0 2px;display:flex;flex-direction:column;gap:8px}
.cta{width:100%;background:var(--accent);color:#fff;border:none;border-radius:var(--r-md);padding:15px;font-size:15px;font-weight:700;text-align:center;cursor:pointer;font-family:var(--font-ui);transition:background .15s;letter-spacing:.04em}
.cta:hover:not(:disabled){background:var(--accent-dark)}
.cta:disabled,.cta.disabled{background:var(--line);color:var(--ink-soft);cursor:not-allowed}
.cta.active{background:var(--accent);color:#fff}
.cta.gold{background:var(--accent);color:#fff}
.cta.gold:hover:not(:disabled){background:var(--accent-dark)}
.cta.ghost{background:none;color:var(--accent);border:1px solid var(--accent-soft)}
.cta.ghost:hover{border-color:var(--accent);background:var(--band)}

/* =========================================================
   数値入力
   cashflow: numrow は row（単位ラベルを右端に置くため）
   ========================================================= */
.numwrap{display:flex;align-items:center;gap:8px;position:relative}
.numrow{position:relative;display:flex;flex-direction:row;align-items:center;width:100%}
.numfield{
  font-size:15px;
  padding:10px 48px 10px 13px;
  border-radius:var(--r-sm);
  border:1px solid var(--line);
  width:100%;
  box-sizing:border-box;
  font-family:var(--font-num);
  font-weight:700;
  color:var(--ink);
  outline:none;
  transition:border-color .18s,box-shadow .18s;
  background:var(--surface);
}
.numfield:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(122,92,46,.12)}
.numfield::placeholder{color:#c7c0b2;font-weight:700}
.numunit{
  position:absolute;
  right:12px;
  top:50%;
  transform:translateY(-50%);
  font-size:12px;
  font-weight:600;
  color:var(--ink-soft);
  pointer-events:none;
  font-family:var(--font-ui);
}

/* =========================================================
   スライダー
   ========================================================= */
.slider-val{font-size:42px;font-weight:800;color:var(--ink);text-align:center;margin-bottom:14px;font-family:var(--font-num);letter-spacing:-.01em}
.slider-val .u{font-size:16px;color:var(--ink-soft);font-weight:400;font-family:var(--font-ui)}
.slider{-webkit-appearance:none;width:100%;height:7px;background:var(--band);border-radius:4px;outline:none;margin-bottom:8px}
.slider::-webkit-slider-thumb{-webkit-appearance:none;width:24px;height:24px;background:var(--accent);border:3px solid #fff;border-radius:50%;box-shadow:var(--shadow);cursor:pointer}
.slider::-moz-range-thumb{width:24px;height:24px;background:var(--accent);border:3px solid #fff;border-radius:50%;cursor:pointer}
.slider-row,.slider-range{display:flex;justify-content:space-between;font-size:11px;color:var(--ink-soft);font-family:var(--font-ui)}

/* =========================================================
   流動性メトリクス
   ========================================================= */
.metric{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;text-align:center;margin-bottom:14px}
.metric-val{font-size:52px;font-weight:800;color:var(--accent);font-family:var(--font-num);line-height:1;letter-spacing:-.02em}
.metric-cap{font-size:14px;font-weight:700;color:var(--accent);margin-bottom:16px;margin-top:4px;font-family:var(--font-ui)}
.metric-bar{height:10px;background:var(--band);border-radius:5px;margin-bottom:6px;overflow:hidden}
.metric-fill{height:100%;background:var(--accent);border-radius:5px;transition:width .5s}
.metric-zones{display:flex;justify-content:space-between;font-size:10px;color:var(--ink-soft);font-family:var(--font-ui)}

/* =========================================================
   バナー
   ========================================================= */
.banner{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:12px 14px;display:flex;gap:10px;font-size:12px;line-height:1.7;color:var(--ink);font-family:var(--font-jp)}
.banner.ok{border-color:var(--ok);background:var(--ok-light)}
.banner.warn{border-color:var(--warn);background:var(--warn-light)}
.bic,.banic,.banner-ic{width:20px;height:20px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0;margin-top:1px;font-family:var(--font-ui)}
.banner.warn .bic,.banner.warn .banic,.banner.warn .banner-ic{background:var(--warn)}
.banner.ok .banic,.banner.ok .bic{background:var(--ok)}

/* =========================================================
   シリアルリスト
   ========================================================= */
.serial-item{display:flex;align-items:flex-start;gap:10px;margin-bottom:10px}
.rank{width:24px;height:24px;border-radius:50%;background:var(--accent);color:#fff;font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:var(--font-num)}
.nm{font-size:14px;font-weight:700;color:var(--ink);font-family:var(--font-jp);line-height:1.6}
.ds{font-size:12px;color:var(--ink-soft);margin-top:2px;font-family:var(--font-jp);line-height:1.8}

/* =========================================================
   結果画面 / cashflow 結果セクション
   ========================================================= */
.result-wrap{padding:0}
.result{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px 18px;border-top:3px solid var(--accent)}
.result.r-accent{border-top-color:var(--accent)}
.result.r-primary{border-top-color:var(--accent)}
.result.r-danger{border-top-color:var(--danger)}
.result.r-warning{border-top-color:var(--warn)}
.result.r-neutral{border-top-color:var(--neutral-state)}
.result-badge{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);font-family:var(--font-ui);margin-bottom:10px}
.result-icon{font-size:32px;margin-bottom:10px;line-height:1}
.result-title{font-size:20px;font-weight:700;color:var(--ink);margin-bottom:12px;line-height:1.45;letter-spacing:.01em;font-family:var(--font-jp)}
.result-lead{font-size:13px;color:var(--ink-soft);line-height:1.9;margin-bottom:16px;font-family:var(--font-jp)}

.flow-boxes,.flow-diag{background:var(--band);color:var(--ink);border:1px solid var(--line);border-radius:var(--r-md);padding:14px;display:flex;align-items:center;justify-content:center;gap:12px;font-size:13px;font-weight:700;margin-bottom:16px;font-family:var(--font-ui);flex-wrap:wrap}
.flow-box{background:var(--surface);border:1px solid var(--line);padding:8px 14px;border-radius:var(--r-sm)}
.flow-arrow{opacity:.5;color:var(--accent)}

.r-section,.rsec{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);padding:14px;margin-bottom:14px;overflow:visible}
.r-section-h,.rsech{font-size:13px;font-weight:800;color:var(--ink);margin-bottom:10px;display:flex;align-items:center;gap:6px;font-family:var(--font-ui)}
.r-section-h .n,.nbadge{width:18px;height:18px;border-radius:50%;background:var(--accent);color:#fff;font-size:9px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:var(--font-num)}
.r-list{display:flex;flex-direction:column;gap:9px}
.r-li{display:flex;gap:10px;font-size:13px;color:var(--ink);line-height:1.75;font-family:var(--font-jp)}
.r-li .b{color:var(--accent);font-weight:800;flex-shrink:0}
.routes{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}
.route{background:var(--paper);border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:var(--r-md);padding:14px}
.route-tag{font-size:10px;font-weight:800;color:var(--accent);font-family:var(--font-ui);letter-spacing:.1em;text-transform:uppercase;margin-bottom:5px}
.route-h{font-size:15px;font-weight:700;color:var(--ink);margin-bottom:5px;font-family:var(--font-jp)}
.route-p{font-size:12px;color:var(--ink-soft);line-height:1.8;margin-bottom:7px;font-family:var(--font-jp)}
.route-up{font-size:12px;color:var(--ok);font-weight:700;font-family:var(--font-ui)}

.cv{background:var(--ink);border-radius:var(--r-md);padding:18px;color:#fff;margin-bottom:14px}
.cv-logo{font-family:var(--font-ui);font-weight:800;font-size:15px;margin-bottom:10px}
.cv-logo .y{color:var(--band);font-weight:900}
.cv-ey,.cv-eyebrow{font-size:10px;color:rgba(255,255,255,.5);margin-bottom:5px;font-family:var(--font-ui);letter-spacing:.1em;text-transform:uppercase}
.cv-h{font-size:13px;font-weight:700;line-height:1.65;margin-bottom:8px;font-family:var(--font-jp)}
.cv-p{font-size:12px;color:rgba(255,255,255,.75);line-height:1.8;margin-bottom:14px;font-family:var(--font-jp)}
.cv-btn{background:var(--accent);color:#fff;font-size:13px;font-weight:700;border-radius:var(--r-md);padding:13px;text-align:center;cursor:pointer;transition:background .2s;font-family:var(--font-ui)}
.cv-btn:hover{background:var(--accent-soft)}
.restart{text-align:center;margin-top:8px}
.restart button{background:none;border:none;color:var(--ink-soft);font-size:12px;cursor:pointer;text-decoration:underline;font-family:var(--font-ui)}

/* =========================================================
   cashflow 専用：rrow / タブ / ドーナツ / バー / 谷
   ========================================================= */
.rrow{display:flex;justify-content:space-between;align-items:center;font-size:12px;padding:4px 0;border-bottom:1px solid var(--line)}
.rrow:last-child{border-bottom:none}
.rlabel{color:var(--ink-soft)}
.rval{font-weight:700;font-family:var(--font-num);color:var(--ink)}
.badge-ok{background:var(--ok-light);color:var(--ok);font-size:9px;font-weight:700;padding:3px 8px;border-radius:20px}
.badge-ng{background:var(--danger-light);color:var(--danger);font-size:9px;font-weight:700;padding:3px 8px;border-radius:20px}
.acalc{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:4px}
.abox{border-radius:var(--r-sm);padding:6px 10px;font-size:12px;font-weight:700;font-family:var(--font-num)}
.tabs{display:flex;gap:2px;background:var(--band);border-radius:var(--r-sm);padding:3px;margin-bottom:10px}
.tab{flex:1;padding:5px 2px;font-size:10px;font-weight:500;color:var(--ink-soft);border:none;background:none;border-radius:var(--r-sm);cursor:pointer;text-align:center;transition:all .15s;font-family:var(--font-ui);white-space:nowrap}
.tab.active{background:var(--accent);color:#fff;font-weight:700}
.tab.trough{color:var(--danger);font-weight:700}
.tab.active.trough{background:var(--danger);color:#fff}
.drow{display:flex;gap:8px;margin-bottom:8px}
.dcol{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;gap:4px}
.dcollabel{font-size:9px;color:var(--ink-soft);text-align:center;line-height:1.35}
.dcollabel b{font-size:10px;font-weight:500;color:var(--ink);font-family:var(--font-num);display:block}
.donut{width:100%;max-width:104px}
.legend{width:100%;display:flex;flex-direction:column;gap:3px}
.leg{display:flex;align-items:center;gap:4px;font-size:9px}
.ldot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.lname{flex:1;color:var(--ink-soft)}
.lpct{font-family:var(--font-num);font-weight:500;color:var(--ink)}
.lspecial .lname,.lspecial .lpct{color:var(--accent-soft)}
.brow{display:flex;align-items:center;gap:6px;margin-bottom:5px}
.blabel{font-size:9px;color:var(--ink-soft);width:54px;text-align:right;flex-shrink:0}
.btrack{flex:1;height:14px;background:var(--band);border-radius:3px;overflow:hidden}
.bfill{height:100%;border-radius:3px}
.bval{font-size:9px;font-weight:700;width:48px;text-align:right;flex-shrink:0;font-family:var(--font-num)}
.mbar{height:10px;background:var(--band);border-radius:5px;overflow:hidden;margin:6px 0}
.mfill{height:100%;border-radius:5px}
.formula{font-size:9px;color:var(--ink-soft);background:var(--surface);border-radius:var(--r-sm);padding:5px 8px;font-family:var(--font-num);margin-bottom:6px;line-height:1.7}
.ctabox{border:1px solid var(--accent-soft);border-radius:var(--r-md);padding:14px;background:var(--band)}
.ctabox-title{font-size:11px;font-weight:700;color:var(--ink);margin-bottom:6px;display:flex;align-items:center;gap:6px;font-family:var(--font-ui)}
.ctabox-badge{width:16px;height:16px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;flex-shrink:0;color:#fff}
.ctabox-body{font-size:10.5px;color:var(--ink-soft);line-height:1.7;margin-bottom:6px;font-family:var(--font-jp)}
.ctabox-note{font-size:9.5px;color:var(--accent-soft);margin-bottom:9px;font-family:var(--font-ui)}
.twarn{background:var(--warn-light);border-radius:var(--r-sm);padding:8px 11px;font-size:10px;color:var(--warn);display:flex;gap:7px;margin-bottom:8px;line-height:1.5;border:1px solid var(--warn)}
.twarn-ic{width:15px;height:15px;border-radius:50%;background:var(--warn);color:#fff;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}

/* =========================================================
   関連する読み物
   ========================================================= */
.related-articles{margin-top:22px;padding-top:18px;border-top:1px solid var(--line)}
.related-articles-h{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);font-family:var(--font-ui);margin-bottom:10px}
.related-article-item{display:block;font-size:13px;color:var(--accent);font-family:var(--font-jp);line-height:1.75;padding:7px 0;border-bottom:1px solid var(--line);text-decoration:none}
.related-article-item:hover{color:var(--accent-dark);text-decoration:underline}
.related-article-item.disabled{color:var(--ink-soft);cursor:default;text-decoration:none}
.related-article-item:last-child{border-bottom:none}

/* =========================================================
   レスポンシブ
   ========================================================= */
@media(max-width:560px){
  .body{padding:16px 14px 20px;gap:10px}
  .hdr{padding:12px 14px}
  .stitle,.qtitle{font-size:19px}
  .result{padding:16px 14px}
  .result-title{font-size:18px}
  .metric{padding:20px 14px}
  .metric-val{font-size:42px}
  .slider-val{font-size:34px}
  .flow-boxes,.flow-diag{flex-direction:column;gap:8px}
}

/* =========================================================
   印刷 / PDF保存
   ========================================================= */
@media print{
  body{background:#fff;padding:0}
  .phone{box-shadow:none;border:none;max-width:none;min-height:unset}
  .hdr{position:static;border-bottom:1px solid #ccc}
  /* 操作系・CV・タブ切り替えは印刷しない */
  .cta-zone,.restart,.tabs,.cv,.cv-btn,.ctabox,.related-articles,
  form button[type="submit"]{display:none !important}
  /* グラフ・結果の色を維持 */
  *{-webkit-print-color-adjust:exact;print-color-adjust:exact}
  /* セクションが途中で切れないように */
  .result,.r-section,.rsec,.metric{break-inside:avoid;page-break-inside:avoid}
  /* フッターの印刷 */
  .foot{border-top:1px solid #ccc;font-size:10px;color:#666}
}
