/* Tsubaki Trading Insights — 構造観測デッキ。
   思想: 「少ないが、貧しくない」。墨地 × 和紙の読値 × 椿クリムゾン一点。
   署名 = 過去1年DVOL分布の中に現在値を置く温度計。 */

:root {
  /* sumi / washi / camellia — アクセントは椿1色に集約 */
  --sumi:        #0d0d0f;   /* 背景（純黒を避けた深い墨） */
  --sumi-rise:   #131316;   /* パネル面 */
  --sumi-line:   #26242a;   /* ヘアライン */
  --washi:       #ece4d6;   /* 主役の読値（生成り） */
  --washi-soft:  #b7b0a4;   /* 副次テキスト */
  --washi-dim:   #6f6a62;   /* ラベル・目盛り */
  --camellia:    #c8102e;   /* 椿クリムゾン＝観測の"今"マーカーのみ（赤の役割を限定） */
  --camellia-lo: rgba(200, 16, 46, .30);
  /* 金＝ブランドの顔（ヘッダーのロゴ/社名のみ）。落ち着いたアンティーク金・ギラつかせない */
  --gold:        #c9a24b;
  --gold-dim:    rgba(201, 162, 75, .58);
  --gold-faint:  rgba(201, 162, 75, .26);

  /* 8px グリッド */
  --s1: 8px;  --s2: 16px; --s3: 24px; --s4: 32px;
  --s6: 48px; --s8: 64px; --s10: 80px; --s12: 96px;

  --serif: "Shippori Mincho", "Hiragino Mincho ProN", serif;
  --grotesk: "Space Grotesk", system-ui, sans-serif;
  --mono: "IBM Plex Mono", ui-monospace, "SFMono-Regular", monospace;
}

* { box-sizing: border-box; }

html, body { margin: 0; }

body {
  min-height: 100vh;
  background: var(--sumi);
  color: var(--washi);
  font-family: var(--mono);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* 墨地の素材感: ごく僅かな縦グラデ＋中央のほのかな明かり（ベタ黒回避） */
.vignette {
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(120% 80% at 50% 22%, #161519 0%, var(--sumi) 60%),
    linear-gradient(180deg, #101013 0%, var(--sumi) 30%);
}
body > * { position: relative; z-index: 1; }

/* ---- masthead ---- */
.masthead {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: var(--s4); flex-wrap: wrap;
  padding: var(--s6) clamp(var(--s4), 6vw, var(--s12)) 0;
}
.wordmark { display: flex; align-items: center; gap: var(--s2); }
.seal {
  width: 48px; height: 48px; display: grid; place-items: center;
  filter: drop-shadow(0 0 9px rgba(201, 162, 75, .15));
}
.seal-mark { width: 100%; height: 100%; display: block; }
.wm-text { display: flex; flex-direction: column; }
.wm-name {
  font-family: var(--serif); font-weight: 700; font-size: 21px;
  letter-spacing: .30em; color: var(--gold);
}
.wm-sub {
  font-family: var(--mono); font-size: 10px; letter-spacing: .34em;
  color: var(--gold-dim); margin-top: 4px;
}
.tagline {
  font-family: var(--serif); font-size: 14px; letter-spacing: .04em;
  color: var(--washi-soft); margin: 0;
}

/* ---- deck ---- 中央 65% に抑え、両サイドに意図的な余白 ---- */
.deck {
  max-width: 1040px;
  margin: 0 auto;
  padding: var(--s10) clamp(var(--s4), 6vw, var(--s12)) var(--s8);
}

.eyebrow {
  display: flex; justify-content: space-between; align-items: center;
  border-top: 1px solid var(--sumi-line);
  padding-top: var(--s2); margin-bottom: var(--s8);
}
.eyebrow-label, .eyebrow-index {
  font-family: var(--mono); font-size: 11px; letter-spacing: .3em;
  color: var(--washi-dim); text-transform: uppercase;
}

/* ---- the fear panel ---- 左:計器(濃密)  右:読値(静か) ---- */
.stage { position: relative; }
.panel {
  display: none;
  grid-template-columns: 300px 1fr;
  gap: clamp(var(--s6), 7vw, var(--s12));
  align-items: center;
}
.panel.is-active { display: grid; }
.instrument { margin: 0; }
#fear-svg { width: 100%; height: auto; display: block; overflow: visible; }

.readout { min-width: 0; }
.panel-eyebrow {
  font-family: var(--serif); font-weight: 700; font-size: 21px;
  letter-spacing: .14em; color: var(--washi); margin: 0 0 var(--s1);
}
.panel-title {
  font-family: var(--grotesk); font-weight: 500; font-size: 13px;
  letter-spacing: .42em; color: var(--washi-dim);
  margin: 0 0 var(--s6); text-transform: uppercase;
}
.title-jp {
  font-family: var(--mono); letter-spacing: .12em; font-size: 11px;
  display: block; margin-top: 6px; color: var(--washi-dim);
}

/* 主役の数値: 大きく、tabular */
.metric { display: flex; align-items: flex-end; gap: var(--s3); }
.metric-value {
  font-family: var(--grotesk); font-weight: 700;
  font-size: clamp(72px, 13vw, 124px); line-height: .82;
  letter-spacing: -.02em; color: var(--washi);
  font-variant-numeric: tabular-nums;
}
.metric-value .ordinal { font-size: .34em; vertical-align: super;
  color: var(--washi-soft); margin-left: .06em; letter-spacing: 0; }
.metric-value .dim { color: var(--washi-dim); }
/* ③ レジーム語(明朝・言葉が主役) / ④ 価格(やや小さく) のヒーロー変種 */
.metric-word { font-family: var(--serif); font-weight: 700;
  font-size: clamp(46px, 6.5vw, 64px); letter-spacing: .08em;
  line-height: 1; white-space: nowrap; }
.metric-price { font-size: clamp(48px, 8vw, 80px); }
/* 言葉ヒーローはラベルを「脇」でなく「真下」に積む(①②④と同じ階層秩序) */
.metric--word { flex-direction: column; align-items: flex-start; gap: var(--s2); }
.metric--word .metric-unit { padding-bottom: 0; }
.metric-unit { padding-bottom: var(--s2); }
.ord {
  display: block; font-family: var(--grotesk); font-size: 15px;
  letter-spacing: .26em; color: var(--washi-soft); text-transform: uppercase;
}
.metric-note {
  display: block; font-family: var(--mono); font-size: 11px;
  letter-spacing: .06em; color: var(--washi-dim); margin-top: 6px;
}

.facts {
  display: flex; gap: var(--s6); margin: var(--s6) 0 0;
  padding-top: var(--s3); border-top: 1px solid var(--sumi-line);
}
.fact dt {
  font-family: var(--mono); font-size: 10px; letter-spacing: .26em;
  color: var(--washi-dim); text-transform: uppercase; margin-bottom: 6px;
}
.fact dd {
  margin: 0; font-family: var(--mono); font-size: 19px; font-weight: 500;
  color: var(--washi); font-variant-numeric: tabular-nums;
}

.reading {
  font-family: var(--serif); font-size: 16px; line-height: 1.85;
  letter-spacing: .03em; color: var(--washi-soft);
  margin: var(--s6) 0 0; max-width: 34em;
}
.disclaimer {
  font-family: var(--mono); font-size: 10px; letter-spacing: .18em;
  color: var(--washi-dim); margin: var(--s3) 0 0; text-transform: uppercase;
}

/* ---- deck index (4観測の真の集合・1のみ稼働) ---- */
.deck-index {
  display: flex; flex-wrap: wrap; gap: var(--s2) var(--s6);
  margin-top: var(--s12); padding-top: var(--s3);
  border-top: 1px solid var(--sumi-line);
}
.di-item {
  font-family: var(--mono); font-size: 12px; letter-spacing: .12em;
  color: var(--washi-dim); background: none; border: 0; padding: 4px 0;
  cursor: pointer; transition: color .25s ease;
}
.di-item:hover { color: var(--washi-soft); }
.di-item.is-active { color: var(--washi); }
.di-item.is-active::before {
  content: ""; display: inline-block; width: 6px; height: 6px;
  border-radius: 50%; background: var(--camellia); margin-right: 9px;
  vertical-align: middle; box-shadow: 0 0 9px var(--camellia-lo);
}

/* ---- SVG instrument styling ---- */
.violin { fill: var(--washi); fill-opacity: .055; stroke: var(--washi);
  stroke-opacity: .12; stroke-width: 1; }
.violin-fill { fill: var(--washi); fill-opacity: .07; }
.axis-line { stroke: var(--sumi-line); stroke-width: 1; }
.axis-tick { fill: var(--washi-dim); font-family: var(--mono);
  font-size: 10px; letter-spacing: .08em; }
.trace { fill: none; stroke: var(--washi-soft); stroke-opacity: .5;
  stroke-width: 1.4; stroke-linecap: round; stroke-linejoin: round; }
.now-line { stroke: var(--camellia); stroke-width: 1.5; }
.now-dot { fill: var(--camellia); filter: url(#camGlow); }
.now-label { fill: var(--washi); font-family: var(--grotesk);
  font-weight: 700; font-size: 14px; font-variant-numeric: tabular-nums; }
.now-label-sub { fill: var(--washi-soft); font-family: var(--mono);
  font-size: 9px; letter-spacing: .14em; }
.scale-cap { fill: var(--washi-dim); font-family: var(--mono);
  font-size: 9px; letter-spacing: .22em; }

/* ③ dealer: 縦のフリップ偏差ゲージ(中央=flip・上抑制/下増幅) */
.gauge-track { fill: var(--washi); fill-opacity: .03;
  stroke: var(--washi); stroke-opacity: .1; stroke-width: 1; }
.gauge-fill { fill: var(--washi); fill-opacity: .08;
  opacity: 0; animation: fade 1s ease .2s forwards; }
.flip-mark { stroke: var(--washi-dim); stroke-width: 1; stroke-dasharray: 3 4; }
.flip-cap { fill: var(--washi-soft); font-family: var(--mono); font-size: 10px;
  letter-spacing: .1em; }

/* ④ levels: 価格軸上のレベル */
.level-line { stroke-width: 1; }
.level-line.res { stroke: var(--washi); stroke-opacity: .34; }
.level-line.sup { stroke: var(--washi); stroke-opacity: .34; stroke-dasharray: 2 3; }
.level-strike { fill: var(--washi-soft); font-family: var(--mono); font-size: 11px;
  font-variant-numeric: tabular-nums; }
.level-tag { fill: var(--washi-dim); font-family: var(--mono); font-size: 8.5px;
  letter-spacing: .14em; }

/* ---- load motion (椿マーカー登場・fillせり上がり) ---- */
.violin { opacity: 0; animation: fade .9s ease forwards; }
.violin-fill { transform-origin: bottom; transform: scaleY(0);
  animation: rise 1.1s cubic-bezier(.2,.7,.2,1) .15s forwards; }
.trace { stroke-dasharray: 1000; stroke-dashoffset: 1000;
  animation: draw 1.4s ease .3s forwards; }
.now-group { opacity: 0; animation: fade .6s ease .95s forwards; }
.now-dot { transform-box: fill-box; transform-origin: center;
  transform: scale(0); animation: pop .5s cubic-bezier(.2,1.4,.3,1) 1s forwards; }
@keyframes fade { to { opacity: 1; } }
@keyframes rise { to { transform: scaleY(1); } }
@keyframes draw { to { stroke-dashoffset: 0; } }
@keyframes pop  { to { transform: scale(1); } }

@media (prefers-reduced-motion: reduce) {
  .violin, .violin-fill, .gauge-fill, .trace, .now-group, .now-dot {
    animation: none; opacity: 1; transform: none; stroke-dashoffset: 0; }
}

/* ---- responsive ---- */
@media (max-width: 760px) {
  .panel { grid-template-columns: 1fr; gap: var(--s6);
    justify-items: center; text-align: left; }
  .instrument { width: 240px; }
  .deck { padding-top: var(--s8); }
  .metric-value { font-size: clamp(64px, 22vw, 96px); }
}

/* focus floor */
:focus-visible { outline: 2px solid var(--camellia); outline-offset: 3px; }

/* ---- 公開(概況)版の追加: 強弱の3ゾーン帯 / 価格帯のゾーン矩形 ---- */
.zband { fill: var(--washi); fill-opacity: .03; }
.zband-line { stroke: var(--sumi-line); stroke-width: 1; stroke-dasharray: 2 4; }
.zband-cap { fill: var(--washi-dim); font-family: var(--mono); font-size: 10px;
  letter-spacing: .14em; }
.pband { fill: var(--washi); fill-opacity: .06; }
.pband.res { fill-opacity: .045; }
.pband-cap { fill: var(--washi-soft); font-family: var(--mono); font-size: 10px;
  letter-spacing: .06em; }
.public-tag { font-family: var(--mono); font-size: 10px; letter-spacing: .28em;
  color: var(--washi-dim); border: 1px solid var(--sumi-line); border-radius: 999px;
  padding: 4px 12px; text-transform: uppercase; }
.guard-note { font-family: var(--mono); font-size: 10px; letter-spacing: .14em;
  color: var(--washi-dim); margin: var(--s1) 0 0; opacity: .8; }
.fresh-note { font-family: var(--mono); font-size: 10px; letter-spacing: .12em;
  color: var(--washi-dim); margin: var(--s2) 0 0; opacity: .75; }
