/* =====================================================================
   ¥Today デザインシステム v3  —  styles.css【リファレンス実装・デザインの正】
   方向B：明朝・抑制トーンで「信頼できる相談先」の品位に統一。
   - 既存クラス名は全維持（JSXが参照するため構造は変えない）。中身のみ刷新。
   - 本文・見出し＝明朝／数字・ボタン・選択肢ラベル・進捗＝ゴシック（視認性優先）。
   - レスポンシブ（B-1）：.phone の固定420px枠を撤廃し、最大720pxの読み物コンテナへ。
     スマホ幅では自然に1カラム。
   - 広い幅を活かし、メトリクス・スライダー・フロー図など数値/グラフ類を大きく。
   - 配色は記事・ポータル（明朝・茶系）と同一トークン。診断の状態色は彩度を抑えて残す。
   ===================================================================== */

:root{
  --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;
  --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",serif;
  --font-ui:"Hiragino Kaku Gothic ProN","Yu Gothic",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（B-1：固定枠撤廃→読み物コンテナ）
   ========================================================= */
.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;
}

/* ===== ヘッダー ===== */
.hdr{
  padding:18px 22px;
  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:13px;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,.hdr-brand{font-size:16px;font-weight:700;color:var(--accent);font-family:var(--font-ui);letter-spacing:.04em;display:flex;align-items:center}
.hdr-logo .y,.hdr-brand .y{color:var(--accent);font-weight:800}
.hdr-step{font-size:12px;color:var(--ink-soft);font-family:var(--font-ui);font-weight:600;letter-spacing:.06em}
.hdr-row{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%}
.badge,.tag{font-size:10px;background:var(--accent);color:#fff;padding:2px 9px;border-radius:var(--r-sm);margin-left:6px;font-family:var(--font-ui);font-weight:700;letter-spacing:.08em}

/* 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:34px 22px 40px;
  display:flex;
  flex-direction:column;
  gap:18px;
  background:var(--paper);
  width:100%;
  max-width:var(--maxw);
  margin:0 auto;
}
.foot{
  padding:22px;
  border-top:1px solid var(--line);
  background:var(--paper);
  font-size:12px;
  color:var(--ink-soft);
  text-align:left;
  flex-shrink:0;
  font-family:var(--font-ui);
  line-height:1.8;
}
.foot-note{font-size:12px;color:var(--ink-soft)}

/* =========================================================
   共通タイポ
   ========================================================= */
.eyebrow,.q-eyebrow{font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:8px;font-family:var(--font-ui)}
.stitle,.qtitle,.q-title{font-size:25px;font-weight:700;color:var(--ink);line-height:1.5;margin-bottom:8px;letter-spacing:.01em;font-family:var(--font-jp)}
.sub,.qsub,.q-sub{font-size:15px;color:var(--ink-soft);margin-bottom:8px;line-height:1.85;font-family:var(--font-jp)}
.sec-title{font-size:14px;font-weight:700;color:var(--ink);margin:14px 0 6px;padding:10px 16px;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:12px}
.choice{display:flex;align-items:flex-start;gap:14px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:18px 20px;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:22px;height:22px;border-radius:50%;border:1.5px solid var(--accent-soft);flex-shrink:0;margin-top:2px;display:flex;align-items:center;justify-content:center;background:#fff;font-size:12px;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:16px;font-weight:700;color:var(--ink);line-height:1.55;display:block;font-family:var(--font-ui)}
.csub,.choice-sub{font-size:13px;color:var(--ink-soft);margin-top:5px;display:block;line-height:1.7;font-family:var(--font-ui)}
.choice.multi .circle,.choice.multi .choice-check{border-radius:var(--r-sm)}

/* =========================================================
   CTA
   ========================================================= */
.cta-zone{padding:18px 0 2px;display:flex;flex-direction:column;gap:10px}
.cta{width:100%;background:var(--accent);color:#fff;border:none;border-radius:var(--r-md);padding:17px;font-size:16px;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:#a8a294;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)}

/* =========================================================
   数値入力
   ========================================================= */
.numwrap{display:flex;align-items:center;gap:8px;position:relative}
.numrow{position:relative;display:flex;flex-direction:column;width:100%}
.numfield{
  font-size:19px;
  padding:14px 52px 14px 16px;
  border-radius:var(--r-md);
  border:1px solid var(--line);
  width:100%;
  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:14px;font-size:13px;font-weight:600;color:var(--ink-soft);pointer-events:none;font-family:var(--font-ui)}

.sel-box{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:16px;font-size:15px;color:var(--ink-soft);display:flex;justify-content:space-between;cursor:pointer;font-family:var(--font-ui)}
.sel-box:focus-within,.sel-box:hover{border-color:var(--accent)}

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

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

/* =========================================================
   バナー
   ========================================================= */
.banner{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:15px 17px;display:flex;gap:12px;font-size:14px;line-height:1.75;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:22px;height:22px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;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:14px;margin-bottom:14px}
.rank{width:28px;height:28px;border-radius:50%;background:var(--accent);color:#fff;font-size:13px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:var(--font-num)}
.nm{font-size:16px;font-weight:700;color:var(--ink);font-family:var(--font-jp);line-height:1.6}
.ds{font-size:14px;color:var(--ink-soft);margin-top:3px;font-family:var(--font-jp);line-height:1.8}

/* =========================================================
   結果画面
   ========================================================= */
.result-wrap{padding:0}
.result{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:34px 30px;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:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-family:var(--font-ui);margin-bottom:14px}
.result-icon{font-size:40px;margin-bottom:14px;line-height:1}
.result-title{font-size:26px;font-weight:700;color:var(--ink);margin-bottom:16px;line-height:1.5;letter-spacing:.01em;font-family:var(--font-jp)}
.result-lead{font-size:16px;color:var(--ink-soft);line-height:1.95;margin-bottom:24px;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:20px;display:flex;align-items:center;justify-content:center;gap:16px;font-size:15px;font-weight:700;margin-bottom:22px;font-family:var(--font-ui);flex-wrap:wrap}
.flow-box{background:var(--surface);border:1px solid var(--line);padding:12px 20px;border-radius:var(--r-sm)}
.flow-arrow{opacity:.5;color:var(--accent)}

.r-section{margin-bottom:24px;overflow:visible}
.r-section-h{font-size:15px;font-weight:800;color:var(--ink);margin-bottom:14px;font-family:var(--font-ui)}
.r-list{display:flex;flex-direction:column;gap:12px}
.r-li{display:flex;gap:12px;font-size:16px;color:var(--ink);line-height:1.85;font-family:var(--font-jp)}
.r-li .b{color:var(--accent);font-weight:800;flex-shrink:0}

.routes{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}
.route{background:var(--paper);border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:var(--r-md);padding:22px}
.route-tag{font-size:11px;font-weight:800;color:var(--accent);font-family:var(--font-ui);letter-spacing:.12em;text-transform:uppercase;margin-bottom:8px}
.route-h{font-size:19px;font-weight:700;color:var(--ink);margin-bottom:8px;font-family:var(--font-jp)}
.route-p{font-size:15px;color:var(--ink-soft);line-height:1.9;margin-bottom:10px;font-family:var(--font-jp)}
.route-up{font-size:14px;color:var(--ok);font-weight:700;font-family:var(--font-ui)}

.cv{background:var(--ink);border-radius:var(--r-md);padding:24px;color:#fff;margin-bottom:18px}
.cv-logo{font-family:var(--font-ui);font-weight:800;font-size:16px;margin-bottom:12px}
.cv-logo .y{color:var(--band);font-weight:900}
.cv-ey,.cv-eyebrow{font-size:11px;color:rgba(255,255,255,.5);margin-bottom:6px;font-family:var(--font-ui);letter-spacing:.12em;text-transform:uppercase}
.cv-h{font-size:16px;font-weight:700;line-height:1.7;margin-bottom:10px;font-family:var(--font-jp)}
.cv-p{font-size:14px;color:rgba(255,255,255,.75);line-height:1.9;margin-bottom:18px;font-family:var(--font-jp)}
.cv-btn{background:var(--accent);color:#fff;font-size:15px;font-weight:700;border-radius:var(--r-md);padding:15px;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:10px}
.restart button{background:none;border:none;color:var(--ink-soft);font-size:13px;cursor:pointer;text-decoration:underline;font-family:var(--font-ui)}

/* =========================================================
   イントロ画面
   ========================================================= */
.intro{background:var(--ink);border-radius:var(--r-lg);padding:44px 30px;text-align:center;position:relative;overflow:hidden}
.intro>*{position:relative;z-index:2}
.intro-logo{font-size:38px;font-weight:800;color:var(--band);font-family:var(--font-ui);line-height:1}
.intro-logo .y,.intro-logo .t{display:inline}
.intro-tag{font-size:12px;color:rgba(255,255,255,.5);letter-spacing:.18em;margin-bottom:26px;font-family:var(--font-ui);text-transform:uppercase}
.intro-h{font-size:27px;font-weight:700;color:#fff;line-height:1.6;margin-bottom:16px;letter-spacing:.01em;font-family:var(--font-jp)}
.intro-h em{color:var(--band);font-style:normal}
.intro-p{font-size:15px;color:rgba(255,255,255,.75);line-height:1.95;margin-bottom:22px;font-family:var(--font-jp)}
.intro-anon{font-size:12px;color:rgba(255,255,255,.55);border:1px solid rgba(255,255,255,.14);border-radius:var(--r-sm);padding:14px;line-height:1.8;display:flex;gap:10px;align-items:flex-start;text-align:left;font-family:var(--font-ui)}
.intro-anon .lock{flex-shrink:0}

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

/* グラフ描画領域 */
.chart-area,.graph-area,.cashflow-chart{
  width:100%;
  max-width:var(--maxw);
  margin:0 auto 18px;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:24px 20px;
}

/* =========================================================
   関連する読み物（診断着地点からコラムへの担控めリンク）
   ========================================================= */
.related-articles{
  margin-top:28px;
  padding-top:22px;
  border-top:1px solid var(--line);
}
.related-articles-h{
  font-size:12px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--ink-soft);
  font-family:var(--font-ui);
  margin-bottom:12px;
}
.related-article-item{
  display:block;
  font-size:14px;
  color:var(--accent);
  font-family:var(--font-jp);
  line-height:1.75;
  padding:8px 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}
