/* ============================================================
   Life Design Studio — styles.css
   Sinobu Design System 準拠
   - Less, but better(ディーター・ラムス + Death Stranding + 任天堂 + ダ・ヴィンチ)
   - Light Cream テーマ(暖クリーム + amber 単色アクセント + 明朝/ゴシック/等幅)
   - WCAG 2.2 AA(本文 4.5:1、UI 3:1、タッチ 44x44、200% ズーム破綻なし)
   - iPhone SE (375px) から 4K (3840px) までレスポンシブ
   ============================================================ */

/* ============================================================
   1. Design Tokens (Single Source of Truth)
   ============================================================ */
:root {
  /* === Color: Light Cream ===
     純白 #FFF を避け、わずかに暖色を残したカード白を使う(Sinobu Design Taste 禁則)。 */
  --bg:           #F1ECDF;
  --bg-paper:     #FAF6EA;
  --bg-card:      #FDFAF1;

  --fg-primary:   #1A1D21;
  --fg-secondary: rgba(26, 29, 33, 0.78);  /* ~8.0:1  AAA */
  --fg-dim:       rgba(26, 29, 33, 0.62);  /* ~5.0:1  AA  最低限読ませる */
  --fg-faint:     rgba(26, 29, 33, 0.40);  /* ~3.0:1  装飾線専用、文字NG */
  --fg-disabled:  rgba(26, 29, 33, 0.28);

  --divider:      rgba(26, 29, 33, 0.10);
  --divider-strong: rgba(26, 29, 33, 0.20);

  --accent:        #BA7517;                /* amber 400  4.4:1 vs bg */
  --accent-soft:   rgba(186, 117, 23, 0.10);
  --accent-edge:   rgba(186, 117, 23, 0.40);
  --accent-strong: #8C5610;
  --accent-on:     #FAF6EA;                /* amber 上の文字 */

  --danger:        #A32D2D;                /* 5.4:1 vs bg */
  --danger-soft:   rgba(163, 45, 45, 0.10);
  --success:       #3B6D11;                /* 6.1:1 vs bg */

  --focus-ring:    #BA7517;

  /* === Typography === */
  --font-sans:    "Zen Kaku Gothic New", "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Yu Gothic", system-ui, sans-serif;
  --font-serif:   "Shippori Mincho", "Noto Serif JP", "Hiragino Mincho ProN", "Yu Mincho", serif;
  --font-mono:    "JetBrains Mono", "IBM Plex Mono", "SF Mono", Menlo, Consolas, monospace;

  --text-2xs:     0.6875rem;  /* 11px — 装飾極小のみ(letter-spacing 0.18em) */
  --text-xs:      0.8125rem;  /* 13px — mono ラベル(letter-spacing 0.05em+) */
  --text-sm:      0.875rem;   /* 14px — キャプション標準下限 */
  --text-base:    1rem;       /* 16px — 本文絶対最小 */
  --text-md:      1.125rem;   /* 18px — 本文(長文向き) */
  --text-lg:      1.25rem;    /* 20px — リード文・H3 */
  --text-xl:      1.5625rem;  /* 25px — H2 */
  --text-2xl:     1.9375rem;  /* 31px — H1 */
  --text-3xl:     2.4375rem;  /* 39px — セクションヒーロー */
  --text-4xl:     3.0625rem;  /* 49px — ページヒーロー */
  --text-5xl:     3.8125rem;  /* 61px — ヒーロー大 */
  --text-6xl:     4.75rem;    /* 76px — ヒーロー巨 */

  --weight-regular: 400;
  --weight-medium:  500;
  --weight-bold:    700;

  --lh-tight:    0.95;
  --lh-snug:     1.2;
  --lh-normal:   1.5;
  --lh-body:     1.6;
  --lh-body-jp:  1.8;

  --tracking-tight:   -0.02em;
  --tracking-normal:  0;
  --tracking-jp:      0.02em;
  --tracking-wide:    0.05em;
  --tracking-widest:  0.18em;

  /* === Spacing (8pt grid) === */
  --space-0:  0;
  --space-1:  4px;
  --space-2:  8px;
  --space-3:  16px;
  --space-4:  24px;
  --space-5:  32px;
  --space-6:  48px;
  --space-7:  64px;
  --space-8:  96px;
  --space-9:  128px;

  /* === Breakpoints (reference) === */
  --bp-sm:  375px;
  --bp-md:  640px;
  --bp-lg:  1024px;
  --bp-xl:  1440px;
  --bp-2xl: 1920px;

  /* === Accessibility constants === */
  --min-touch:    44px;
  --focus-width:  2px;
  --focus-offset: 2px;

  /* === Motion === */
  --dur-instant: 80ms;
  --dur-fast:    150ms;
  --dur-base:    200ms;
  --dur-medium:  300ms;
  --ease-out:    cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
  /* 静謐方針: bounce 系イージングは廃止。トグルも ease-out で滑らかに切替える。 */
  --ease-bounce: var(--ease-out);

  /* === Radius === */
  --radius-none: 0;
  --radius-xs:   2px;
  --radius-sm:   4px;
  --radius-md:   6px;
  --radius-pill: 9999px;

  /* === Shadow (Sinobu はほぼ使わない) === */
  --shadow-none:  none;
  --shadow-soft:  0 1px 2px rgba(0,0,0,0.04), 0 2px 8px rgba(0,0,0,0.04);
  --shadow-focus: 0 0 0 2px var(--bg), 0 0 0 4px var(--focus-ring);

  /* === Z-index === */
  --z-base:    0;
  --z-raised:  10;
  --z-sticky:  100;
  --z-overlay: 1000;

  /* === Layout === */
  --max-w-prose:       680px;
  --max-w-page-narrow: 960px;
  --max-w-page:        1200px;
  --max-w-app:         1440px;

  /* === Legacy alias (旧クラスの互換維持。新規は使わない) === */
  --bg-base:      var(--bg);
  --bg-elevated:  var(--bg-card);
  --bg-subtle:    var(--bg-paper);
  --text-primary:   var(--fg-primary);
  --text-secondary: var(--fg-secondary);
  --text-muted:     var(--fg-dim);
  --border:         var(--divider);
  --border-strong:  var(--divider-strong);
  --accent-hover:  var(--accent-strong);
  --accent-active: var(--accent-strong);
  --accent-text:   var(--accent-on);
  --warning:       var(--danger);
  --warning-soft:  var(--danger-soft);
  --success-soft:  rgba(59, 109, 17, 0.10);
  --info:          var(--accent);
  --info-soft:     var(--accent-soft);
  --width-prose: var(--max-w-prose);
  --width-app:   var(--max-w-app);
  --width-hero:  var(--max-w-app);
  --duration-fast: var(--dur-fast);
  --duration-base: var(--dur-base);
  --easing-standard: var(--ease-out);
  --leading-tight:   var(--lh-snug);
  --leading-snug:    var(--lh-snug);
  --leading-normal:  var(--lh-normal);
  --leading-relaxed: var(--lh-body-jp);
  --weight-semibold: var(--weight-medium);
  --radius-lg:   var(--radius-md);  /* 旧 16px → 6px に縮約 */
  --shadow-sm:   var(--shadow-soft);
  --shadow-md:   var(--shadow-soft);
  --shadow-lg:   var(--shadow-soft);
}

/* prefers-reduced-motion: WCAG 2.3.3 */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* ============================================================
   2. Reset / Base
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html {
  font-size: 16px;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}
body {
  background: var(--bg);
  color: var(--fg-primary);
  font-family: var(--font-sans);
  font-size: var(--text-base);
  line-height: var(--lh-body-jp);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  letter-spacing: var(--tracking-jp);
  text-rendering: optimizeLegibility;
  font-feature-settings: "palt" 1, "kern" 1;
}
img, svg { max-width: 100%; height: auto; display: block; }
button { font: inherit; color: inherit; background: none; border: none; padding: 0; cursor: pointer; }
input, select, textarea { font: inherit; color: inherit; }

a {
  color: var(--fg-primary);
  text-decoration: underline;
  text-decoration-color: var(--accent-edge);
  text-underline-offset: 0.25em;
  transition: text-decoration-color var(--dur-fast) var(--ease-out);
}
a:hover { text-decoration-color: var(--accent); }
:focus-visible {
  outline: var(--focus-width) solid var(--focus-ring);
  outline-offset: var(--focus-offset);
  border-radius: var(--radius-xs);
}

h1, h2, h3, h4, h5 {
  font-family: var(--font-serif);
  color: var(--fg-primary);
  line-height: var(--lh-snug);
  margin: 0 0 var(--space-3);
  font-weight: var(--weight-bold);
  letter-spacing: var(--tracking-jp);
  /* 明朝見出しの仮名と漢字の比率を整える(palt は約物のみ詰める) */
  font-feature-settings: "palt" 1;
  text-wrap: balance;
}
h1 { font-size: clamp(var(--text-2xl), 4vw + 1rem, var(--text-4xl)); line-height: var(--lh-snug); }
h2 { font-size: clamp(var(--text-xl), 2vw + 1rem, var(--text-2xl)); }
h3 { font-size: var(--text-lg); }
h4 { font-size: var(--text-base); font-weight: var(--weight-medium); }
p { margin: 0 0 var(--space-3); }
small { font-size: var(--text-sm); }
hr { border: 0; border-top: 1px solid var(--divider); margin: var(--space-5) 0; }

/* ============================================================
   3. Layout: Header / Footer / Container
   ============================================================ */
.site-header {
  background: rgba(241, 236, 223, 0.92);
  backdrop-filter: saturate(140%) blur(8px);
  -webkit-backdrop-filter: saturate(140%) blur(8px);
  border-bottom: 1px solid var(--divider);
  position: sticky;
  top: 0;
  z-index: var(--z-sticky);
}
.site-header__inner {
  max-width: var(--max-w-app);
  margin: 0 auto;
  padding: var(--space-3);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-2) var(--space-3);
  min-height: var(--min-touch);
}
@media (min-width: 640px) {
  .site-header__inner {
    padding: var(--space-3) var(--space-4);
    flex-wrap: nowrap;
    gap: var(--space-4);
  }
}
.site-header__brand {
  font-family: var(--font-serif);
  font-size: var(--text-base);
  font-weight: var(--weight-bold);
  color: var(--fg-primary);
  text-decoration: none;
  letter-spacing: 0.01em;
  white-space: nowrap;
}
@media (min-width: 640px) {
  .site-header__brand { font-size: var(--text-lg); }
}
.site-header__brand:hover { color: var(--fg-primary); text-decoration: none; }

.site-nav {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
  align-items: center;
}
@media (min-width: 640px) {
  .site-nav { gap: var(--space-4); }
}
.site-nav a {
  color: var(--fg-dim);
  text-decoration: none;
  font-size: var(--text-sm);
  padding: var(--space-2) 0;
  min-height: var(--min-touch);
  display: inline-flex;
  align-items: center;
  position: relative;
  transition: color var(--dur-fast) var(--ease-out);
}
.site-nav a:hover {
  color: var(--fg-primary);
  text-decoration: none;
}
.site-nav a[aria-current="page"] {
  color: var(--fg-primary);
  font-weight: var(--weight-medium);
}
.site-nav a[aria-current="page"]::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -2px;
  height: 1px;
  background: var(--accent);
}

.site-footer {
  border-top: 1px solid var(--divider);
  margin-top: var(--space-8);
  padding: var(--space-6) 0 var(--space-7);
}
.site-footer__inner {
  max-width: var(--max-w-app);
  margin: 0 auto;
  padding: 0 var(--space-4);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4) var(--space-5);
  justify-content: space-between;
  align-items: flex-start;
  font-size: var(--text-sm);
  color: var(--fg-dim);
}
.site-footer__links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3) var(--space-4);
}
.site-footer__links a {
  color: var(--fg-dim);
  text-decoration: none;
  min-height: var(--min-touch);
  display: inline-flex;
  align-items: center;
}
.site-footer__links a:hover { color: var(--fg-primary); }

.container {
  max-width: var(--max-w-prose);
  margin: 0 auto;
  padding: 0 var(--space-4);
}
.container--wide { max-width: var(--max-w-page-narrow); }

.section { padding: var(--space-7) 0; }

/* ============================================================
   4. Landing Page (Hero / Features / Neutrality)
   ============================================================ */
.hero {
  padding: var(--space-8) 0 var(--space-7);
  text-align: left;
}
@media (min-width: 640px) {
  .hero { padding: var(--space-9) 0 var(--space-8); }
}
.hero__eyebrow {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--fg-dim);
  margin-bottom: var(--space-3);
}
.hero__title {
  font-family: var(--font-serif);
  font-size: clamp(2rem, 6vw + 0.5rem, var(--text-5xl));
  font-weight: var(--weight-bold);
  line-height: var(--lh-snug);
  letter-spacing: var(--tracking-tight);
  margin: 0 0 var(--space-4);
  color: var(--fg-primary);
}
.hero__lead {
  font-size: var(--text-md);
  color: var(--fg-secondary);
  max-width: 36em;
  margin: 0 0 var(--space-6);
  line-height: var(--lh-body-jp);
}
.hero__cta {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
  align-items: center;
}

.features {
  display: grid;
  gap: var(--space-4);
  grid-template-columns: 1fr;
  margin: var(--space-6) 0;
}
@media (min-width: 640px) {
  .features { grid-template-columns: repeat(3, 1fr); gap: var(--space-5); }
}
.feature {
  padding: var(--space-5) var(--space-4);
  background: transparent;
  border: 0;
  border-top: 1px solid var(--divider-strong);
  border-radius: var(--radius-none);
}
.feature__num {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--accent);
  margin-bottom: var(--space-3);
  letter-spacing: var(--tracking-wide);
}
.feature h3 {
  font-family: var(--font-serif);
  font-size: var(--text-lg);
  margin-bottom: var(--space-2);
  letter-spacing: var(--tracking-jp);
}
.feature p {
  font-size: var(--text-base);
  color: var(--fg-secondary);
  margin: 0;
  line-height: var(--lh-body-jp);
}

.neutrality {
  background: var(--bg-paper);
  border: 1px solid var(--divider);
  border-left: 2px solid var(--accent);
  border-radius: var(--radius-none);
  padding: var(--space-4) var(--space-5);
  margin: var(--space-6) 0;
  font-size: var(--text-sm);
  color: var(--fg-secondary);
  line-height: var(--lh-body-jp);
}
.neutrality strong { color: var(--fg-primary); font-weight: var(--weight-medium); }
.neutrality a { color: var(--fg-primary); }

/* --- 4.x Prose flow (LP の「使い方」セクション) --- */
.prose-flow {
  counter-reset: flow;
  list-style: none;
  padding: 0;
  margin: var(--space-5) 0 0;
  display: grid;
  gap: var(--space-4);
}
.prose-flow > li {
  counter-increment: flow;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-2) var(--space-4);
  padding-top: var(--space-4);
  border-top: 1px solid var(--divider);
}
.prose-flow > li::before {
  content: counter(flow, decimal-leading-zero);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--accent);
  letter-spacing: var(--tracking-wide);
  grid-row: 1 / span 2;
  align-self: start;
  padding-top: 0.2em;
}
.prose-flow > li > strong {
  font-family: var(--font-serif);
  font-size: var(--text-lg);
  font-weight: var(--weight-bold);
  color: var(--fg-primary);
  letter-spacing: var(--tracking-jp);
  display: block;
}
.prose-flow > li > span {
  font-size: var(--text-base);
  color: var(--fg-secondary);
  line-height: var(--lh-body-jp);
  display: block;
}
.prose-flow__cta { margin-top: var(--space-6); }

/* ============================================================
   5. Buttons
   ============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  font-family: var(--font-sans);
  font-size: var(--text-base);
  font-weight: var(--weight-medium);
  letter-spacing: var(--tracking-jp);
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  cursor: pointer;
  text-decoration: none;
  min-height: var(--min-touch);
  min-width: var(--min-touch);
  transition:
    background var(--dur-fast) var(--ease-out),
    color var(--dur-fast) var(--ease-out),
    border-color var(--dur-fast) var(--ease-out),
    transform var(--dur-instant) var(--ease-out);
}
.btn:active { transform: translateY(1px); }
.btn--primary {
  background: var(--accent);
  color: var(--accent-on);
  border-color: var(--accent);
}
.btn--primary:hover {
  background: var(--accent-strong);
  border-color: var(--accent-strong);
  color: var(--accent-on);
  text-decoration: none;
}
.btn--ghost {
  background: transparent;
  color: var(--fg-primary);
  border-color: var(--divider-strong);
}
.btn--ghost:hover {
  background: var(--bg-paper);
  border-color: var(--fg-primary);
  color: var(--fg-primary);
  text-decoration: none;
}
.btn:disabled, .btn[aria-disabled="true"] {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
}

/* ============================================================
   6. Simulator (lp-* prefix, 見本資料からの移植を継承)
   ============================================================ */
body.sim-body { background: var(--bg); color: var(--fg-primary); }
/* シミュレーターでは集中体験のため、ヘッダーは sticky を外して
   lp-summary を主役にする(Frostpunk のコアアクティビティ原則) */
body.sim-body .site-header { position: static; }
.lp-display { font-family: var(--font-serif); letter-spacing: var(--tracking-jp); }
.lp-mono, .mono {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
}

.lp-shell {
  max-width: var(--max-w-app);
  margin: 0 auto;
  padding: var(--space-5) var(--space-3) var(--space-8);
}
@media (min-width: 640px) {
  .lp-shell { padding: var(--space-7) var(--space-4) var(--space-8); }
}
@media (min-width: 1024px) {
  .lp-shell { padding: var(--space-7) var(--space-5) var(--space-9); }
}

/* --- 6.1 Hero --- */
.lp-hero {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
  margin-bottom: var(--space-5);
}
@media (min-width: 640px) {
  .lp-hero {
    gap: var(--space-5);
    margin-bottom: var(--space-6);
  }
}
@media (min-width: 1024px) {
  .lp-hero {
    grid-template-columns: 1fr auto;
    align-items: end;
    gap: var(--space-7);
    margin-bottom: var(--space-7);
  }
}
.lp-hero__left { max-width: 36em; min-width: 0; }
.lp-hero__right { text-align: left; min-width: 0; }
@media (min-width: 1024px) {
  .lp-hero__right { text-align: right; }
}

.lp-micro {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--fg-dim);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  margin-bottom: var(--space-2);
}
.lp-h1 {
  font-family: var(--font-serif);
  font-size: clamp(2.25rem, 5vw + 1rem, var(--text-5xl));
  font-weight: var(--weight-bold);
  line-height: var(--lh-snug);
  margin: 0;
  letter-spacing: var(--tracking-tight);
  color: var(--fg-primary);
}
.lp-lead {
  font-size: var(--text-md);
  color: var(--fg-secondary);
  line-height: var(--lh-body-jp);
  margin: var(--space-4) 0 0;
  max-width: 36em;
}

.lp-age-range {
  display: inline-flex;
  align-items: baseline;
  gap: var(--space-3);
  font-family: var(--font-serif);
}
.lp-age-input {
  width: 3.5ch;
  text-align: right;
  font: inherit;
  font-size: clamp(var(--text-3xl), 4vw + 1rem, var(--text-4xl));
  font-weight: var(--weight-bold);
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--divider-strong);
  color: var(--fg-primary);
  padding: 2px 0;
  outline: none;
  -moz-appearance: textfield;
  appearance: textfield;
}
.lp-age-input::-webkit-outer-spin-button,
.lp-age-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.lp-age-input:focus { border-bottom-color: var(--accent); }
.lp-age-dash {
  font-size: clamp(var(--text-3xl), 4vw + 1rem, var(--text-4xl));
  color: var(--fg-dim);
  font-family: var(--font-serif);
}
.lp-age-note {
  font-size: var(--text-sm);
  color: var(--fg-dim);
  margin-top: var(--space-2);
  letter-spacing: var(--tracking-jp);
}

/* --- 6.2 Summary bar — アンビエントHUD層: 静謐 ---
   モバイル: 静的な概要ボード(縦に長くしすぎない)
   タブレット以上: sticky に格上げして常時参照可能に */
.lp-summary {
  position: static;
  z-index: var(--z-sticky);
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-3) var(--space-4);
  padding: var(--space-3) var(--space-4);
  background: var(--bg-paper);
  border-top: 1px solid var(--divider);
  border-bottom: 1px solid var(--divider);
  margin: 0 calc(var(--space-3) * -1) var(--space-5);
}
@media (min-width: 640px) {
  .lp-summary {
    position: sticky;
    top: 0;
    grid-template-columns: repeat(3, 1fr);
    align-items: center;
    gap: var(--space-3) var(--space-5);
    margin-left: calc(var(--space-4) * -1);
    margin-right: calc(var(--space-4) * -1);
    padding: var(--space-3) var(--space-5);
    background: rgba(241, 236, 223, 0.94);
    backdrop-filter: saturate(140%) blur(8px);
    -webkit-backdrop-filter: saturate(140%) blur(8px);
    margin-bottom: var(--space-6);
  }
}
@media (min-width: 1024px) {
  .lp-summary {
    margin-left: calc(var(--space-5) * -1);
    margin-right: calc(var(--space-5) * -1);
  }
}
.lp-summary__cell { min-width: 0; }
.lp-summary__sep { display: none; }

.lp-stat {
  font-family: var(--font-serif);
  font-size: var(--text-lg);
  font-weight: var(--weight-bold);
  line-height: var(--lh-tight);
  color: var(--fg-primary);
  font-variant-numeric: tabular-nums;
  letter-spacing: var(--tracking-tight);
  display: flex;
  align-items: baseline;
  gap: 0.2em;
  flex-wrap: nowrap;
  min-width: 0;
}
.lp-stat .num {
  font-family: var(--font-serif);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
}
.lp-stat .unit {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--fg-dim);
  font-weight: var(--weight-regular);
  letter-spacing: var(--tracking-jp);
  flex-shrink: 0;
}
.lp-stat.is-accent { color: var(--accent); }
.lp-stat.is-warn  { color: var(--danger); }
.lp-stat--md { font-size: var(--text-lg); }
.lp-stat--sm { font-size: var(--text-base); }
@media (min-width: 640px) {
  .lp-stat    { font-size: var(--text-xl); }
  .lp-stat--md{ font-size: var(--text-lg); }
}
@media (min-width: 1024px) {
  .lp-stat    { font-size: var(--text-2xl); }
  .lp-stat--md{ font-size: var(--text-xl); }
}

.lp-summary__warn {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3);
  border-left: 2px solid var(--danger);
  background: var(--danger-soft);
  min-width: 0;
}
@media (min-width: 640px) {
  .lp-summary__warn {
    padding: var(--space-2) var(--space-3);
  }
}
.lp-micro--warn { color: var(--danger); margin-bottom: var(--space-1); }
.lp-warn-text {
  font-family: var(--font-mono);
  font-size: var(--text-md);
  font-weight: var(--weight-medium);
  color: var(--fg-primary);
  font-variant-numeric: tabular-nums;
}
.lp-age-tag {
  margin-left: var(--space-2);
  font-size: var(--text-sm);
  font-weight: var(--weight-regular);
  color: var(--fg-dim);
  font-family: var(--font-sans);
}

/* --- 6.3 Grid (左:入力 / 右:結果) --- */
.lp-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  align-items: stretch;
}
@media (min-width: 1024px) {
  .lp-grid {
    grid-template-columns: minmax(360px, 1fr) minmax(0, 1.4fr);
    gap: var(--space-6);
  }
}
@media (min-width: 1440px) {
  .lp-grid {
    grid-template-columns: minmax(380px, 0.85fr) minmax(0, 1.4fr);
    gap: var(--space-7);
  }
}
.lp-input  {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  min-width: 0;
}
.lp-result {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  min-width: 0;
}

/* --- 6.3.1 右ペインの sticky グループ(マイルストーン + メイン航海図) ---
   左ペインの長いスクロール中に、右側に「資産の航海図」を残し続ける。
   モバイルでは sticky を外して通常フロー */
.lp-result__sticky {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  min-width: 0;
}
@media (min-width: 1024px) {
  .lp-result__sticky {
    position: sticky;
    top: var(--space-3);
    z-index: 1;
    gap: var(--space-4);
  }
  /* sticky 群全体がビューポートに収まるよう、メインチャートの高さを
     画面高さに追従させる(下限 280px、上限 480px) */
  .lp-result__sticky .lp-chart-wrap {
    height: clamp(280px, calc(100dvh - 220px), 480px);
  }
}

/* --- 6.4 Card (入力セクション) --- */
.lp-card {
  background: var(--bg-paper);
  padding: var(--space-4);
  border: 1px solid var(--divider);
  border-radius: var(--radius-none);
  min-width: 0;
}
@media (min-width: 640px) {
  .lp-card { padding: var(--space-5); }
}
@media (min-width: 1024px) {
  .lp-card { padding: var(--space-5) var(--space-5); }
}
.lp-section-head {
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
  padding-bottom: var(--space-3);
  margin-bottom: var(--space-5);
  border-bottom: 1px solid var(--divider-strong);
}
.lp-num {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--accent);
  font-variant-numeric: tabular-nums;
  letter-spacing: var(--tracking-wide);
}
.lp-h2 {
  font-family: var(--font-serif);
  font-size: var(--text-lg);
  font-weight: var(--weight-bold);
  margin: 0;
  color: var(--fg-primary);
  letter-spacing: var(--tracking-jp);
}
@media (min-width: 640px) {
  .lp-h2 { font-size: var(--text-xl); }
}
.lp-hint {
  font-size: var(--text-sm);
  color: var(--fg-dim);
  line-height: var(--lh-body-jp);
  margin: 0 0 var(--space-3);
}

/* --- 6.5 Field (NumberField 相当) ---
   ヒエラルキー方針:
   操作対象(ラベル + 数値) = 本文サイズ + primary 色 で「主役」
   補助説明(hint) = sm + dim 色 で「脇役」
   そのさらに上のサブグループ見出し(.lp-subblock 内の .lp-micro) は
   mono + widest tracking で記号化(下の lp-subblock 規則参照) */
.lp-field { margin-bottom: 12px; }
.lp-field:last-child { margin-bottom: 0; }
.lp-field__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
}
.lp-field__label {
  font-size: var(--text-base);
  font-weight: var(--weight-medium);
  color: var(--fg-primary);
  letter-spacing: var(--tracking-jp);
}
.lp-field__valuewrap {
  display: inline-flex;
  align-items: baseline;
  gap: var(--space-1);
}
.lp-field__num {
  width: 5.5ch;
  text-align: right;
  font-family: var(--font-mono);
  font-size: var(--text-base);
  font-weight: var(--weight-medium);
  color: var(--fg-primary);
  font-variant-numeric: tabular-nums;
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--divider-strong);
  padding: var(--space-1) 0;
  outline: none;
  min-height: 32px;
}
.lp-field__num:focus { border-bottom-color: var(--accent); }
.lp-field__unit {
  font-size: var(--text-sm);
  color: var(--fg-dim);
  letter-spacing: var(--tracking-jp);
}
.lp-field__hint {
  font-size: var(--text-sm);
  color: var(--fg-dim);
  margin: var(--space-1) 0 0;
  line-height: var(--lh-body-jp);
}

/* レンジ(スライダー): タッチターゲット 44 を確保 */
.lp-range {
  width: 100%;
  -webkit-appearance: none;
  appearance: none;
  background: transparent;
  cursor: pointer;
  height: 24px;
  margin: 0;
  padding: 0;
  display: block;
}
.lp-range::-webkit-slider-runnable-track {
  height: 1px;
  background: var(--divider-strong);
}
.lp-range::-moz-range-track {
  height: 1px;
  background: var(--divider-strong);
}
.lp-range::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 24px;
  height: 24px;
  background: var(--fg-primary);
  margin-top: -12px;
  border-radius: var(--radius-none);
  transition: background var(--dur-fast) var(--ease-out), transform var(--dur-instant) var(--ease-out);
}
.lp-range::-webkit-slider-thumb:hover {
  background: var(--accent);
  transform: scale(1.08);
}
.lp-range::-webkit-slider-thumb:active {
  background: var(--accent-strong);
  transform: scale(1.02);
}
.lp-range::-moz-range-thumb {
  width: 24px;
  height: 24px;
  background: var(--fg-primary);
  border: 0;
  border-radius: var(--radius-none);
  transition: background var(--dur-fast) var(--ease-out);
}
.lp-range::-moz-range-thumb:hover { background: var(--accent); }
.lp-range:focus-visible::-webkit-slider-thumb {
  box-shadow: 0 0 0 4px var(--accent-soft);
}
.lp-range:focus-visible::-moz-range-thumb {
  box-shadow: 0 0 0 4px var(--accent-soft);
}

/* --- 6.6 Timeline (収入の道のり) --- */
.lp-timeline { margin-bottom: var(--space-4); }
.lp-timeline__track {
  position: relative;
  height: 2px;
  background: var(--divider);
  margin-bottom: var(--space-3);
}
.lp-timeline__partTime {
  position: absolute;
  left: 0; top: 0; bottom: 0;
  background: var(--fg-faint);
}
.lp-timeline__employed {
  position: absolute;
  top: 0; bottom: 0;
  background: var(--accent);
}
.lp-timeline__nums {
  display: flex;
  justify-content: space-between;
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--fg-dim);
  font-variant-numeric: tabular-nums;
  letter-spacing: var(--tracking-wide);
}
.lp-timeline__nums .strong { color: var(--fg-primary); font-weight: var(--weight-medium); }
.lp-timeline__labels {
  display: flex;
  justify-content: space-between;
  font-size: var(--text-sm);
  color: var(--fg-dim);
  margin-top: var(--space-1);
  letter-spacing: var(--tracking-jp);
}
.lp-subblock {
  /* 上方向(前グループとの分離)は広く、下方向は通常 */
  padding: var(--space-5) 0 var(--space-4);
  border-top: 1px solid var(--divider);
}
.lp-subblock--top { padding-bottom: 0; }

/* サブグループ見出し: 「バイト期 ・ 18-22歳 (5年間)」のような
   セクション内の小ラベルを、設定項目ラベルと混同しないよう
   mono + widest tracking で装飾的に格下げ。
   直下の最初の項目ラベルとは近接させてグループ感を出す(8px)。 */
.lp-subblock > .lp-micro {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--fg-dim);
  letter-spacing: var(--tracking-widest);
  margin-bottom: var(--space-2);
  text-transform: uppercase;
}

/* --- 6.7 Toggle (任天堂的にコンパクト・静謐) --- */
.lp-toggle {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2) var(--space-2);
  background: transparent;
  border: 0;
  cursor: pointer;
  font-family: inherit;
  font-size: var(--text-sm);
  color: var(--fg-dim);
  letter-spacing: var(--tracking-jp);
  min-height: var(--min-touch);
  transition: color var(--dur-fast) var(--ease-out);
}
.lp-toggle[aria-pressed="true"] { color: var(--fg-primary); }
.lp-toggle__switch {
  position: relative;
  width: 32px;
  height: 16px;
  background: var(--divider-strong);
  border-radius: var(--radius-pill);
  transition: background var(--dur-fast) var(--ease-out);
  flex-shrink: 0;
}
.lp-toggle__switch::after {
  content: "";
  position: absolute;
  top: 2px;
  left: 2px;
  width: 12px;
  height: 12px;
  background: var(--bg-paper);
  border-radius: var(--radius-pill);
  transition: left var(--dur-fast) var(--ease-out);
}
.lp-toggle[aria-pressed="true"] .lp-toggle__switch { background: var(--accent); }
.lp-toggle[aria-pressed="true"] .lp-toggle__switch::after { left: 18px; }

/* --- 6.8 Sub-buttons (lp-btn / lp-tag) --- */
.lp-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  font-family: inherit;
  font-size: var(--text-sm);
  color: var(--fg-primary);
  background: transparent;
  border: 1px solid var(--divider-strong);
  border-radius: var(--radius-sm);
  cursor: pointer;
  min-height: var(--min-touch);
  transition: all var(--dur-fast) var(--ease-out);
  letter-spacing: var(--tracking-jp);
}
.lp-btn:hover {
  background: var(--fg-primary);
  color: var(--bg-paper);
  border-color: var(--fg-primary);
}
.lp-btn--ghost {
  border-style: dashed;
  color: var(--fg-dim);
}
.lp-btn--ghost:hover {
  border-style: solid;
  border-color: var(--accent);
  color: var(--accent);
  background: transparent;
}
.lp-tag {
  display: inline-flex;
  align-items: center;
  padding: var(--space-2) var(--space-3);
  font-family: inherit;
  font-size: var(--text-sm);
  color: var(--fg-secondary);
  background: transparent;
  border: 1px solid var(--divider-strong);
  border-radius: var(--radius-sm);
  cursor: pointer;
  margin: 0 var(--space-2) var(--space-2) 0;
  min-height: var(--min-touch);
  transition: all var(--dur-fast) var(--ease-out);
  letter-spacing: var(--tracking-jp);
}
.lp-tag:hover { border-color: var(--accent); color: var(--accent); }

/* --- 6.9 Rent / Living / Overhead --- */
.lp-rent { margin-bottom: var(--space-4); }
.lp-rent__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: var(--space-2);
}
.lp-label {
  font-size: var(--text-base);
  font-weight: var(--weight-medium);
  color: var(--fg-primary);
  letter-spacing: var(--tracking-jp);
}
.lp-stage-count {
  margin-left: var(--space-2);
  font-size: var(--text-sm);
  color: var(--fg-dim);
}
.lp-rent__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}
.lp-rent-entry {
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--divider);
}
.lp-rent-entry__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--fg-dim);
  letter-spacing: var(--tracking-wide);
}
.lp-rent-entry__remove {
  background: transparent;
  border: 0;
  cursor: pointer;
  color: var(--fg-dim);
  font-size: var(--text-md);
  padding: var(--space-1) var(--space-2);
  min-width: var(--min-touch);
  min-height: var(--min-touch);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: color var(--dur-fast) var(--ease-out);
}
.lp-rent-entry__remove:hover { color: var(--danger); }

.lp-living {
  /* 上方向は padding-top + border-top で分離するため、margin-top は 0 */
  margin: 0 0 var(--space-4);
  padding-top: var(--space-4);
  border-top: 1px solid var(--divider);
}
.lp-living__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
  margin-bottom: var(--space-2);
}
.lp-breakdown {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-3) var(--space-4);
  margin-top: var(--space-3);
}
@media (min-width: 480px) {
  .lp-breakdown { grid-template-columns: 1fr 1fr; }
}
.lp-breakdown-total {
  margin-top: var(--space-3);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--fg-secondary);
  text-align: right;
  letter-spacing: var(--tracking-wide);
}

/* --- 6.10 Overhead (臨時出費) --- */
.lp-ot-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
}
.lp-ot-entry {
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr) 80px auto;
  gap: var(--space-2);
  align-items: center;
  padding: var(--space-2) 0;
  border-bottom: 1px solid var(--divider);
}
@media (min-width: 480px) {
  .lp-ot-entry {
    grid-template-columns: minmax(70px, 80px) minmax(0, 1fr) minmax(80px, 100px) auto;
  }
}
.lp-ot-entry input[type="number"],
.lp-ot-entry input[type="text"] {
  width: 100%;
  min-width: 0;
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--divider-strong);
  padding: var(--space-1) 0;
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  outline: none;
  color: var(--fg-primary);
  min-height: 32px;
}
.lp-ot-entry input[type="text"] { font-family: inherit; }
.lp-ot-entry input[type="number"] { text-align: right; font-variant-numeric: tabular-nums; }
.lp-ot-entry input:focus { border-bottom-color: var(--accent); }
.lp-ot-entry__remove {
  background: transparent;
  border: 0;
  cursor: pointer;
  color: var(--fg-dim);
  font-size: var(--text-md);
  padding: var(--space-1);
  min-width: var(--min-touch);
  min-height: var(--min-touch);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: color var(--dur-fast) var(--ease-out);
}
.lp-ot-entry__remove:hover { color: var(--danger); }
.lp-ot-templates { margin-bottom: var(--space-3); }

/* --- 6.11 Detail / Mini chart ---
   トグル ↔ 展開された詳細フィールドは強い関係。
   合計 32px(16+16) で「展開された」感を出しつつ密接さも保つ */
.lp-detail {
  margin-top: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid var(--divider);
}
.lp-mini { margin-top: var(--space-4); }
.lp-mini__label {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--fg-dim);
  margin-bottom: var(--space-2);
  letter-spacing: var(--tracking-wide);
}
/* Chart.js の responsive + maintainAspectRatio:false は親要素の高さに従う。
   親 wrapper を position:relative + 固定 height で必ず囲うこと(囲まないと
   canvas が無限拡大してページが無限スクロールになる) */
.lp-mini__chart {
  position: relative;
  width: 100%;
  height: 120px;
}
.lp-mini__chart canvas {
  display: block;
}

/* --- 6.12 Events --- */
.lp-events { display: flex; flex-direction: column; }
.lp-event {
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--divider);
}
.lp-event:last-child { border-bottom: 0; }
.lp-event__head {
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
  cursor: pointer;
  flex-wrap: wrap;
  min-height: 36px;
}
.lp-event__title {
  font-family: var(--font-serif);
  font-size: var(--text-lg);
  font-weight: var(--weight-bold);
  color: var(--fg-dim);
  letter-spacing: var(--tracking-jp);
  transition: color var(--dur-fast) var(--ease-out);
}
.lp-event[data-enabled="true"] .lp-event__title { color: var(--fg-primary); }
.lp-event__age {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--fg-dim);
  font-variant-numeric: tabular-nums;
  letter-spacing: var(--tracking-wide);
}
.lp-event__body {
  margin-top: var(--space-3);
  padding-left: var(--space-3);
}
@media (min-width: 640px) {
  .lp-event__body { padding-left: var(--space-5); }
}

.lp-select {
  width: 100%;
  padding: var(--space-2) var(--space-3);
  font-family: inherit;
  font-size: var(--text-base);
  color: var(--fg-primary);
  background: var(--bg-card);
  border: 1px solid var(--divider-strong);
  border-radius: var(--radius-none);
  outline: none;
  min-height: var(--min-touch);
  transition: border-color var(--dur-fast) var(--ease-out);
}
.lp-select:focus { border-color: var(--accent); }
.lp-select-group {
  display: grid;
  gap: var(--space-3);
  margin-top: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid var(--divider);
}
.lp-select-group__label {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--fg-dim);
  margin-bottom: var(--space-1);
  letter-spacing: var(--tracking-wide);
}
.lp-summary-rows {
  margin-top: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid var(--divider);
}
.lp-summary-rows__row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--space-2);
  padding: var(--space-1) 0;
  font-size: var(--text-sm);
  color: var(--fg-secondary);
}
.lp-summary-rows__row.is-em {
  border-top: 1px solid var(--divider-strong);
  padding-top: var(--space-3);
  margin-top: var(--space-2);
  color: var(--fg-primary);
  font-weight: var(--weight-medium);
  font-size: var(--text-base);
}
.lp-summary-rows__val {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: var(--fg-primary);
  letter-spacing: var(--tracking-wide);
}

/* --- 6.13 Right pane: Milestones / Chart / Alerts --- */
.lp-milestones {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
  padding: var(--space-4) 0;
  border-top: 1px solid var(--divider-strong);
  border-bottom: 1px solid var(--divider-strong);
}
@media (min-width: 640px) {
  .lp-milestones { grid-template-columns: repeat(4, 1fr); gap: var(--space-5); }
}
.lp-milestone { min-width: 0; }

.lp-chart-card {
  background: var(--bg-paper);
  padding: var(--space-4);
  border: 1px solid var(--divider);
  border-radius: var(--radius-none);
}
@media (min-width: 640px) {
  .lp-chart-card { padding: var(--space-5); }
}
.lp-chart-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  flex-wrap: wrap;
  gap: var(--space-2) var(--space-4);
  margin-bottom: var(--space-4);
}
.lp-chart-wrap {
  position: relative;
  height: clamp(280px, 50vh, 480px);
  width: 100%;
}
.lp-chart-wrap--sm { height: clamp(160px, 24vh, 220px); }

.lp-legend {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-3);
  font-size: var(--text-sm);
  color: var(--fg-dim);
  letter-spacing: var(--tracking-jp);
}
.lp-legend__dot {
  display: inline-block;
  width: 16px; /* 8pt グリッド整合 */
  height: 2px;
  vertical-align: middle;
  margin-right: var(--space-2);
  background: var(--fg-dim);
}
.lp-legend__dot--cash    { background: var(--fg-secondary); }
.lp-legend__dot--invest  { background: var(--accent); }
.lp-legend__dot--noinvest{ background: var(--danger); }
.lp-legend__dot--warn    { background: var(--danger); }

/* --- 6.14 Alerts (3階層: amber 主体、純赤は danger のみ) --- */
.lp-alerts { display: flex; flex-direction: column; gap: var(--space-3); }
.lp-alert {
  padding: var(--space-3) var(--space-4);
  border-left: 2px solid var(--fg-dim);
  background: var(--bg-paper);
  font-size: var(--text-sm);
  line-height: var(--lh-body-jp);
  color: var(--fg-secondary);
}
.lp-alert--warning {
  border-left-color: var(--danger);
  background: var(--danger-soft);
  color: var(--fg-primary);
}
.lp-alert--success {
  border-left-color: var(--accent);
  background: var(--accent-soft);
  color: var(--fg-primary);
}
.lp-alert--suggest {
  border-left-color: var(--accent);
  background: var(--bg-paper);
  color: var(--fg-primary);
}

.lp-disclaimer {
  font-size: var(--text-sm);
  color: var(--fg-dim);
  margin-top: var(--space-7);
  line-height: var(--lh-body-jp);
  border-top: 1px solid var(--divider);
  padding-top: var(--space-4);
}
.lp-disclaimer a { color: var(--fg-primary); }

/* ============================================================
   7. Legacy Simulator (.sim-*) — index.html 用の旧クラス互換
   ============================================================ */
.sim-shell {
  display: grid;
  gap: var(--space-5);
  grid-template-columns: 1fr;
  padding: var(--space-5) 0 var(--space-7);
}
@media (min-width: 1024px) {
  .sim-shell { grid-template-columns: 380px 1fr; align-items: start; }
}
.sim-panel {
  background: var(--bg-paper);
  border: 1px solid var(--divider);
  border-radius: var(--radius-none);
  padding: var(--space-5);
}
.sim-panel h2 {
  font-family: var(--font-serif);
  font-size: var(--text-xl);
  margin-bottom: var(--space-4);
}
.sim-panel__intro {
  font-size: var(--text-sm);
  color: var(--fg-dim);
  margin-bottom: var(--space-4);
}
.field { margin-bottom: var(--space-4); }
.field__row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
}
.field__label {
  font-size: var(--text-sm);
  color: var(--fg-secondary);
}
.field__value {
  font-family: var(--font-mono);
  font-size: var(--text-base);
  font-weight: var(--weight-medium);
  color: var(--fg-primary);
  font-variant-numeric: tabular-nums;
}
.field__help {
  font-size: var(--text-sm);
  color: var(--fg-dim);
  margin-top: var(--space-1);
}

input[type="range"].slider {
  width: 100%;
  height: var(--min-touch);
  background: transparent;
  appearance: none;
  -webkit-appearance: none;
  outline: none;
  margin: 0;
  cursor: pointer;
}
input[type="range"].slider::-webkit-slider-runnable-track {
  height: 1px;
  background: var(--divider-strong);
}
input[type="range"].slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 16px;
  height: 16px;
  background: var(--fg-primary);
  margin-top: -8px;
  border: 0;
  border-radius: 0;
  cursor: grab;
  transition: background var(--dur-fast) var(--ease-out);
}
input[type="range"].slider::-webkit-slider-thumb:hover { background: var(--accent); }
input[type="range"].slider::-moz-range-track { height: 1px; background: var(--divider-strong); }
input[type="range"].slider::-moz-range-thumb {
  width: 16px;
  height: 16px;
  background: var(--fg-primary);
  border: 0;
  border-radius: 0;
  cursor: grab;
}
input[type="range"].slider:focus-visible::-webkit-slider-thumb {
  box-shadow: 0 0 0 4px var(--accent-soft);
}

.toggle-row { display: flex; gap: var(--space-2); flex-wrap: wrap; }
.toggle {
  flex: 1 1 0;
  min-width: 96px;
  min-height: var(--min-touch);
  padding: var(--space-2) var(--space-3);
  background: transparent;
  border: 1px solid var(--divider-strong);
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
  cursor: pointer;
  text-align: center;
  color: var(--fg-dim);
  transition: all var(--dur-fast) var(--ease-out);
}
.toggle[aria-pressed="true"] {
  background: var(--accent-soft);
  border-color: var(--accent);
  color: var(--accent-strong);
  font-weight: var(--weight-medium);
}
.toggle:hover { border-color: var(--fg-primary); color: var(--fg-primary); }

.sim-results { display: flex; flex-direction: column; gap: var(--space-4); }
.milestones {
  display: grid;
  gap: var(--space-3);
  grid-template-columns: 1fr;
}
@media (min-width: 640px) { .milestones { grid-template-columns: repeat(3, 1fr); } }
.milestone {
  background: var(--bg-paper);
  border: 1px solid var(--divider);
  border-radius: var(--radius-none);
  padding: var(--space-4);
}
.milestone__label {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--fg-dim);
  letter-spacing: var(--tracking-wide);
  margin-bottom: var(--space-2);
}
.milestone__age {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--fg-dim);
  font-variant-numeric: tabular-nums;
}
.milestone__amount {
  font-family: var(--font-mono);
  font-size: var(--text-xl);
  font-weight: var(--weight-medium);
  color: var(--fg-primary);
  font-variant-numeric: tabular-nums;
  line-height: var(--lh-tight);
  margin-top: var(--space-2);
}
.milestone__amount--surplus { color: var(--success); }
.milestone__amount--deficit { color: var(--danger); }

.chart-card {
  background: var(--bg-paper);
  border: 1px solid var(--divider);
  border-radius: var(--radius-none);
  padding: var(--space-4);
}
.chart-card h2 {
  font-family: var(--font-serif);
  font-size: var(--text-lg);
  margin-bottom: var(--space-3);
}
.chart-wrap {
  position: relative;
  width: 100%;
  height: clamp(280px, 50vh, 420px);
}

.alerts { display: flex; flex-direction: column; gap: var(--space-2); }
.alert {
  padding: var(--space-3) var(--space-4);
  border-left: 2px solid var(--fg-dim);
  background: var(--bg-paper);
  font-size: var(--text-sm);
  line-height: var(--lh-body-jp);
  color: var(--fg-primary);
}
.alert--warning { border-left-color: var(--danger); background: var(--danger-soft); }
.alert--suggestion { border-left-color: var(--accent); background: var(--accent-soft); }
.alert--success { border-left-color: var(--accent); background: var(--accent-soft); }

/* ============================================================
   8. Prose pages (about / how-it-works / privacy / terms / contact)
   ============================================================ */
.prose {
  padding: var(--space-6) 0 var(--space-8);
  font-size: var(--text-base);
  line-height: var(--lh-body-jp);
  color: var(--fg-primary);
}
.prose h1 {
  margin: 0 0 var(--space-5);
  font-size: clamp(var(--text-2xl), 4vw + 1rem, var(--text-4xl));
}
.prose h2 {
  margin: var(--space-7) 0 var(--space-3);
  padding-top: var(--space-4);
  border-top: 1px solid var(--divider);
  font-size: var(--text-xl);
}
.prose h2:first-of-type {
  border-top: 0;
  padding-top: 0;
  margin-top: var(--space-5);
}
.prose h3 {
  margin-top: var(--space-5);
  font-size: var(--text-lg);
}
.prose p { color: var(--fg-primary); line-height: var(--lh-body-jp); }
.prose strong { font-weight: var(--weight-medium); }
.prose ul, .prose ol {
  padding-left: 1.5em;
  line-height: var(--lh-body-jp);
  margin: 0 0 var(--space-3);
}
.prose li { margin-bottom: var(--space-2); }
.prose li::marker { color: var(--fg-dim); }

.prose table {
  width: 100%;
  border-collapse: collapse;
  margin: var(--space-3) 0 var(--space-4);
  font-size: var(--text-sm);
}
.prose th, .prose td {
  text-align: left;
  padding: var(--space-2) var(--space-3);
  border-bottom: 1px solid var(--divider);
  vertical-align: top;
}
.prose th {
  font-family: var(--font-serif);
  font-weight: var(--weight-bold);
  color: var(--fg-primary);
  background: transparent;
  border-bottom: 1px solid var(--divider-strong);
}
.prose code {
  font-family: var(--font-mono);
  background: var(--bg-paper);
  padding: 0.1em 0.4em;
  border-radius: var(--radius-xs);
  font-size: 0.9em;
  color: var(--fg-primary);
}
.prose pre {
  font-family: var(--font-mono);
  background: var(--bg-paper);
  border: 1px solid var(--divider);
  padding: var(--space-3) var(--space-4);
  overflow-x: auto;
  font-size: var(--text-sm);
  line-height: var(--lh-body);
}
.prose .note {
  background: var(--bg-paper);
  border-left: 2px solid var(--accent);
  padding: var(--space-3) var(--space-4);
  margin: var(--space-4) 0;
  font-size: var(--text-sm);
  color: var(--fg-secondary);
}

/* ============================================================
   9. Utility
   ============================================================ */
.visually-hidden {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}
.muted { color: var(--fg-dim); }
.dim   { color: var(--fg-dim); }
.text-sm { font-size: var(--text-sm); }

/* Skip link */
a.visually-hidden:focus,
a.visually-hidden:focus-visible {
  position: fixed;
  top: var(--space-3);
  left: var(--space-3);
  width: auto; height: auto;
  padding: var(--space-2) var(--space-3);
  clip: auto;
  background: var(--fg-primary);
  color: var(--bg);
  z-index: var(--z-overlay);
  font-size: var(--text-sm);
}

/* ============================================================
   10. Playfulness layer — sinobu-web-playfulness skill 適用
   2026-05-16 追加。骨格(Sections 1-9)が完成済みの上に、Layer C(反応) と
   LP の Layer B(スクロール) のみ追加。simulator.html は業務UI のため
   スクロール演出を入れない(scroll-motion.md 1.3 準拠)。
   ============================================================ */

/* --- 10.1 :focus-visible に "息" を入れる(Layer C) ---
   Tab 移動で focus が当たる瞬間、outline-offset が 0 → 2px へ軽く広がる。
   キーボード使用者への craft 最終層(micro-interactions.md 4.3)。 */
:focus-visible {
  animation: focus-rise var(--dur-fast) var(--ease-out);
}
@keyframes focus-rise {
  from { outline-offset: 0; }
  to   { outline-offset: var(--focus-offset); }
}

/* --- 10.2 site-nav リンクの underline 伸縮(Layer C) ---
   非 aria-current のリンクに、ホバーで左から右へ広がる 1px 線。
   外す時は逆方向(右へ消える)で連続感を作る。
   aria-current ページの ::after による固定 underline はそのまま維持。 */
.site-nav a:not([aria-current="page"])::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -2px;
  height: 1px;
  background: var(--accent);
  transform: scaleX(0);
  transform-origin: right;
  transition: transform var(--dur-medium) var(--ease-out);
  pointer-events: none;
}
.site-nav a:not([aria-current="page"]):hover::before,
.site-nav a:not([aria-current="page"]):focus-visible::before {
  transform: scaleX(1);
  transform-origin: left;
}

/* --- 10.3 feature カードのホバー反応(Layer C) ---
   静止画と区別がつかない状態を改善。border-top の色変化と translateY -2px。
   micro-interactions.md 3.3 のカードホバー定石。 */
.feature {
  transition:
    border-top-color var(--dur-base) var(--ease-out),
    transform var(--dur-base) var(--ease-out);
}
.feature:hover,
.feature:focus-within {
  border-top-color: var(--accent);
  transform: translateY(-2px);
}

/* --- 10.4 ヒーロー要素の stagger fade-in(Layer B、初回のみ) ---
   index.html のヒーロー 4 要素を 100ms 間隔で立ち上げる。
   要素単位 stagger のみ(文字単位 split-text は awwwards-traps.md 2.9 で禁則)。
   合計 800ms 以内で完了。 */
@keyframes hero-rise {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: none; }
}
.hero__eyebrow,
.hero__title,
.hero__lead,
.hero__cta {
  animation: hero-rise 500ms var(--ease-out) both;
}
.hero__eyebrow { animation-delay: 0ms; }
.hero__title   { animation-delay: 100ms; }
.hero__lead    { animation-delay: 200ms; }
.hero__cta     { animation-delay: 300ms; }

/* --- 10.5 features / prose-flow の in-view reveal(Layer B、1度きり) ---
   IntersectionObserver で is-in クラス付与(JS 側で実装)。
   1 ページ最大 2 箇所のステージ予算(scroll-motion.md 1.3)を遵守。
   JS が読み込まれた時のみ初期 opacity:0 にする(html.js ガード) — JS 無効
   環境では通常表示のままで見える。 */
html.js .feature,
html.js .prose-flow > li {
  opacity: 0;
  transform: translateY(16px);
  transition:
    opacity 600ms var(--ease-out),
    transform 600ms var(--ease-out);
}
html.js .feature.is-in,
html.js .prose-flow > li.is-in {
  opacity: 1;
  transform: none;
}
html.js .features .feature:nth-child(2),
html.js .prose-flow > li:nth-child(2) { transition-delay: 80ms; }
html.js .features .feature:nth-child(3),
html.js .prose-flow > li:nth-child(3) { transition-delay: 160ms; }

/* --- 10.6 simulator: 数値変化のフラッシュ(Layer C) ---
   .lp-stat .num の値が書き換わった瞬間、accent-soft で短く pulse。
   ユーザー起点の craft(スライダーを動かす → 数値が "確かに反応した") を返す。
   レイアウトをずらさないよう margin で padding を打ち消す。 */
.lp-stat .num {
  border-radius: var(--radius-xs);
  padding: 0 4px;
  margin: 0 -4px;
  transition: background-color var(--dur-medium) var(--ease-out);
}
.lp-stat .num.is-updated {
  background-color: var(--accent-soft);
}

/* --- 10.7 simulator: タイムライン width transition(Layer C) ---
   JS で style.width が書き換わるバーが、滑らかに伸び縮みする。
   業務UI でも craft を返す(年齢設定 → バーが連動して伸びる)。 */
.lp-timeline__partTime,
.lp-timeline__employed {
  transition:
    width var(--dur-medium) var(--ease-out),
    left var(--dur-medium) var(--ease-out);
}

/* --- 10.8 prefers-reduced-motion による無効化 ---
   セクション 1 のグローバル設定(transition/animation を 0.01ms に圧縮)に加え、
   reveal の初期状態 opacity:0 を最終状態に戻す。playfulness.js 側でも reduced
   時は is-in を即時付与し、観測者を起動しない。 */
@media (prefers-reduced-motion: reduce) {
  :focus-visible { animation: none; }
  .hero__eyebrow,
  .hero__title,
  .hero__lead,
  .hero__cta {
    animation: none;
    opacity: 1;
    transform: none;
  }
  html.js .feature,
  html.js .prose-flow > li {
    opacity: 1;
    transform: none;
    transition: none;
  }
  .lp-stat .num.is-updated { background-color: transparent; }
  .lp-timeline__partTime,
  .lp-timeline__employed { transition: none; }
  .feature,
  .feature:hover,
  .feature:focus-within { transform: none; transition: none; }
  .site-nav a::before { transition: none; transform: scaleX(0); }
}

/* ============================================================
   11. かんたん/くわしくモード切替 + 学生向け UI 追加要素
   - モード切替トグル (ヘッダー右)
   - 進路 5 択ピル (01 基本情報)
   - お天気サマリ + 貯蓄率→年数 1 行 (lp-summary 拡張)
   - lp-alert--note (ゲインフレーム用)
   - body.lp-mode--simple で「くわしく」要素を隠す
   ============================================================ */

/* 11.1 モード切替トグル */
.lp-mode-toggle {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-left: auto;
  padding: 4px;
  border: 1px solid rgba(26, 29, 33, 0.18);
  border-radius: 999px;
  background: rgba(248, 244, 233, 0.6);
  cursor: pointer;
  font: inherit;
  color: var(--fg);
}
.lp-mode-toggle__opt {
  padding: 4px 12px;
  border-radius: 999px;
  font-size: 13px;
  line-height: 1.2;
  transition: background-color var(--dur-base, 0.18s) ease, color var(--dur-base, 0.18s) ease;
}
body.lp-mode--simple .lp-mode-toggle__opt--simple,
body.lp-mode--detailed .lp-mode-toggle__opt--detailed {
  background: var(--accent, #BA7517);
  color: #FFF;
  font-weight: 700;
}

/* 11.2 進路ピル */
.lp-field--pills .lp-field__head { margin-bottom: 8px; }
.lp-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.lp-pill {
  padding: 8px 14px;
  border: 1px solid rgba(26, 29, 33, 0.22);
  border-radius: 999px;
  background: #FFF;
  cursor: pointer;
  font-size: 13px;
  line-height: 1.2;
  color: var(--fg, #1A1D21);
  transition: background-color var(--dur-base, 0.18s) ease, border-color var(--dur-base, 0.18s) ease, color var(--dur-base, 0.18s) ease;
}
.lp-pill:hover { border-color: rgba(186, 117, 23, 0.6); }
.lp-pill.is-selected {
  background: var(--accent, #BA7517);
  border-color: var(--accent, #BA7517);
  color: #FFF;
  font-weight: 700;
}

/* 11.3 お天気サマリ */
.lp-summary__weather {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 4px 0;
}
.lp-weather-text { display: flex; flex-direction: column; gap: 2px; }
.lp-weather-detail {
  font-size: 13px;
  color: rgba(26, 29, 33, 0.78);
}

/* 11.4 貯蓄率 → 経済自由までの年数 1 行 */
.lp-fi-line {
  margin: 12px 0 24px;
  padding: 12px 18px;
  background: rgba(186, 117, 23, 0.08);
  border-left: 3px solid var(--accent, #BA7517);
  font-size: 14px;
  color: var(--fg, #1A1D21);
}
.lp-fi-line strong {
  font-weight: 700;
  color: var(--accent, #BA7517);
  font-size: 18px;
  margin: 0 2px;
}

/* 11.5 lp-alert--note (中性的な注意喚起、ゲインフレーム用) */
.lp-alert--note {
  background: rgba(26, 29, 33, 0.04);
  border-left: 3px solid rgba(26, 29, 33, 0.3);
  color: rgba(26, 29, 33, 0.82);
}

/* 11.6 かんたんモード: くわしく専用要素を隠す
   - 04 臨時出費・05 副業・06 投資セクションは Card 単位で隠す
   - 03 暮らしの「内訳で入力」トグルも隠す
   - 02 収入の昇給率・正社員になる年齢 (=進路で決まる) も隠す
   - 08 老後の retirementBonus フィールドも隠す
   いずれも body.lp-mode--detailed のときは何もしない */
body.lp-mode--simple .lp-card:nth-of-type(4),  /* 04 臨時出費 */
body.lp-mode--simple .lp-card:nth-of-type(5),  /* 05 副業 */
body.lp-mode--simple #living-toggle,
body.lp-mode--simple .lp-field[data-field="salaryGrowth"],
body.lp-mode--simple .lp-field[data-field="employmentStartAge"],
body.lp-mode--simple .lp-field[data-field="retirementBonus"],
body.lp-mode--simple .lp-field[data-field="appliancesFund"],
body.lp-mode--simple .lp-field[data-field="savingGoal"],
body.lp-mode--simple #invest-detail .lp-field[data-field="investmentReturn"],
body.lp-mode--simple .lp-timeline {
  display: none !important;
}

/* かんたんモードで進路ピル直下のヒント文を少し控えめに */
body.lp-mode--simple #path-hint { color: rgba(26, 29, 33, 0.6); }

/* 小型ビューポートでヘッダーが詰まったらモードトグルだけ縮小 */
@media (max-width: 720px) {
  .lp-mode-toggle__opt { padding: 4px 8px; font-size: 12px; }
}

