/* ============================================================
 * theme-jumei.css — 十命 JUMEI「夜・神秘」テーマ（styles.css の後に全面上書き）
 * ------------------------------------------------------------
 * 夜の藍墨 × 菫 × 金 × 朱の落款。明朝体＋Cormorant斜体。
 * 星屑キャンバス／カーソルの灯／粒状ノイズ／十命盤の曼荼羅は
 * jumei-atmosphere.js が描画（#starfield, #cursor-glow, .mandala-stage）。
 * ============================================================ */

:root {
  color-scheme: dark;
  --ink: #0b0814;          /* night ink — indigo-shifted */
  --ink-2: #120f22;        /* panel */
  --ink-3: #1a1633;        /* raised panel */
  --night-deep: #070510;
  --indigo: #2c2658;
  --violet: #8a76d8;
  --violet-2: #cdbaff;
  --paper: #f3ead8;        /* cream（本文） */
  --cream-2: #e7dcc3;
  --muted: #b3a98f;        /* cream-3（補助） */
  --panel: rgba(18, 15, 34, 0.72);
  --panel-strong: rgba(11, 8, 20, 0.9);
  --line: rgba(231, 220, 195, 0.16);
  --line-strong: rgba(231, 220, 195, 0.32);
  --line-violet: rgba(138, 118, 216, 0.25);
  --brass: #e0b652;        /* gold-2（金アクセント） */
  --gold: #c79a3a;
  --gold-deep: #8a6820;
  --vermilion: #c9472d;    /* crimson-2（落款・バッジ） */
  --jade: #7fc9b8;
  --danger: #c9472d;
  --radius: 1px;           /* JUMEI は角を立てる */
  --shadow: 0 22px 60px rgba(5, 3, 14, 0.55);

  --font-mincho: "Shippori Mincho", "Noto Serif JP", "游明朝", "Yu Mincho", serif;
  --font-serif-en: "Cormorant Garamond", "Shippori Mincho", serif;
  --font-mono: "JetBrains Mono", ui-monospace, monospace;
}

/* ---- 背景：夜空 ---- */
body {
  color: var(--paper);
  font-family: var(--font-mincho);
  letter-spacing: 0.02em;
  background:
    radial-gradient(ellipse 96% 62% at 50% 112%, rgba(44, 38, 88, 0.55), transparent 60%),
    radial-gradient(ellipse 60% 48% at 80% 12%, rgba(138, 118, 216, 0.13), transparent 60%),
    linear-gradient(180deg, #0b0814 0%, #070510 100%);
}

/* ベースのグリッド線オーバーレイは消し、粒状ノイズに置換 */
body::before {
  background-image: none;
  mask-image: none;
}

/* 粒状ノイズ（body.grain） */
.grain::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 100;
  opacity: 0.05;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 0.9 0 0 0 0 0.7 0 0 0 0.7 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

/* 旧シグナルキャンバスは使わない（星屑に置換） */
#signalCanvas { display: none !important; }

#starfield {
  position: fixed;
  inset: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
  pointer-events: none;
  opacity: 1;
}

#cursor-glow {
  position: fixed;
  width: 460px;
  height: 460px;
  border-radius: 50%;
  pointer-events: none;
  z-index: 0;
  transform: translate(-50%, -50%);
  mix-blend-mode: screen;
  background: radial-gradient(circle, rgba(138, 118, 216, 0.08) 0%, rgba(199, 154, 58, 0.05) 35%, transparent 70%);
}
@media (hover: none) {
  #cursor-glow { display: none; }
}

/* 文字選択 */
::selection { background: rgba(199, 154, 58, 0.35); }

/* ============ サイドバー（藍墨・物語性） ============ */
.side-panel {
  grid-template-rows: auto auto auto 1fr;
  background: linear-gradient(180deg, rgba(12, 9, 26, 0.92) 0%, rgba(7, 5, 16, 0.96) 100%);
  border-right: 1px solid var(--line);
  backdrop-filter: blur(14px);
}

.brand-block,
.payment-gate,
.mini-status,
.work-section,
.report-card,
.empty-report {
  border: 1px solid var(--line);
  background: var(--panel);
  box-shadow: none;
  border-radius: var(--radius);
}

/* ============ ブランド（十命 JUMEI） ============ */
.brand-block {
  padding: 30px 26px;
  text-align: left;
  background:
    radial-gradient(circle at 24% 8%, rgba(138, 118, 216, 0.16), transparent 60%),
    linear-gradient(160deg, rgba(199, 154, 58, 0.08), rgba(18, 15, 34, 0.4));
  border-color: var(--line);
}

.brand-icon svg { display: none; }
.brand-icon {
  display: grid;
  place-items: center;
  width: 50px;
  height: 50px;
  margin: 0 0 18px;
  border: 1px solid var(--gold);
  border-radius: 50%;
  color: var(--brass);
  font-family: var(--font-mincho);
  font-size: 24px;
  font-weight: 600;
  background: radial-gradient(circle at 30% 30%, rgba(224, 182, 82, 0.18), transparent 62%);
}
.brand-icon::before { content: "命"; }

.brand-block .kicker,
.section-label {
  color: var(--brass);
  font-family: var(--font-serif-en);
  font-style: italic;
  letter-spacing: 0.32em;
  text-transform: uppercase;
}
.kicker-ja,
.label-ja {
  color: var(--muted);
  font-style: normal;
  letter-spacing: 0.12em;
}

.brand-block h1 {
  font-family: var(--font-mincho);
  font-weight: 600;
  letter-spacing: 0.4em;
  color: #f5ecd6;
  margin: 6px 0 4px;
  font-size: 0;
}
/* 旧サービス名「十命術統合オンライン診断」→ 十命 にリブランド表示 */
.brand-block h1::before {
  content: "十命";
  font-size: 42px;
  letter-spacing: 0.42em;
}
.brand-block h1::after {
  content: "JUMEI — Ten Readings, One Truth";
  display: block;
  margin-top: 12px;
  font-family: var(--font-serif-en);
  font-style: italic;
  font-size: 11px;
  letter-spacing: 0.3em;
  color: var(--muted);
  text-transform: uppercase;
}
.brand-copy {
  color: var(--muted);
  line-height: 2;
  letter-spacing: 0.04em;
  font-size: 13px;
}

.side-panel h2 { color: #f5ecd6; font-family: var(--font-mincho); letter-spacing: 0.1em; }
.side-panel p,
.side-panel .plan-note,
.side-panel .plan-anchor,
.side-panel .access-message,
.side-panel #progressText,
.side-panel .gate-assure li,
.side-panel .purchase-steps li { color: var(--muted); }

/* ============ 決済ゲート ============ */
.payment-gate { padding: 26px; }
.plan-anchor { font-size: 12px; line-height: 1.9; }
.plan-anchor strong,
.gate-assure strong { color: var(--brass); }

/* プラン選択 */
.plan-picker-title { color: var(--muted); letter-spacing: 0.14em; }
.plan-option {
  background: rgba(255, 250, 235, 0.04);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  color: var(--cream-2);
}
.plan-option:hover { border-color: var(--gold-deep); }
.plan-option.is-selected {
  background: linear-gradient(180deg, rgba(199, 154, 58, 0.12), rgba(18, 15, 34, 0.5));
  border-color: var(--gold);
}
.plan-name { color: #f5ecd6; letter-spacing: 0.1em; }
.plan-price { color: var(--brass); font-family: var(--font-serif-en); font-size: 1.25em; }
.plan-desc { color: var(--muted); }
.plan-badge {
  background: var(--vermilion);
  color: #f5ecd6;
  letter-spacing: 0.24em;
  border-radius: 0;
}

/* 購入ステップ */
.purchase-steps li::marker { color: var(--brass); }

/* 入力欄（サイドバー） */
.side-panel input {
  color: #f5ecd6;
  background: rgba(255, 250, 235, 0.05);
  border-color: var(--line-strong);
  border-radius: var(--radius);
}
.side-panel input::placeholder { color: rgba(179, 169, 143, 0.5); }
.side-panel input:focus {
  border-color: var(--brass);
  box-shadow: 0 0 0 3px rgba(224, 182, 82, 0.16);
}
.quiet-button {
  color: var(--cream-2);
  background: rgba(255, 250, 235, 0.05);
  border: 1px solid var(--line-strong);
  border-radius: var(--radius);
  letter-spacing: 0.16em;
}
.quiet-button:hover { border-color: var(--brass); color: var(--brass); }
.returning-login > summary { color: var(--muted); }
.meter { background: rgba(255, 250, 235, 0.08); border-color: var(--line); }
#progressBar { background: linear-gradient(90deg, var(--gold), var(--brass)); }

/* サイドバー挿絵スロットは夜テーマでは使わない */
.side-art { display: none; }

/* ============ 購入CTA（金・最上位） ============ */
.pay-link {
  color: #14100a;
  background: var(--brass);
  border: 1px solid var(--brass);
  border-radius: var(--radius);
  font-weight: 600;
  letter-spacing: 0.18em;
  text-align: center;
}
.pay-link:hover {
  background: #ecc873;
  box-shadow: 0 10px 36px -8px rgba(224, 182, 82, 0.5);
}

/* ============ メイン領域 ============ */
/* ヒーロー上の曼荼羅ステージ（旧 hero-banner を置換） */
.mandala-stage {
  position: relative;
  display: grid;
  place-items: center;
  min-height: clamp(300px, 42vw, 460px);
  margin: 0 0 8px;
  background:
    radial-gradient(ellipse 70% 60% at 50% 50%, rgba(44, 38, 88, 0.35), transparent 70%);
}
.mandala-stage svg { width: min(520px, 86%); height: auto; overflow: visible; }
.mandala-stage::after { content: none; }

/* ツールヘッダー（ヒーロー） */
.tool-header { align-items: center; }
.tool-header .kicker {
  color: var(--brass);
  font-family: var(--font-serif-en);
  font-style: italic;
  letter-spacing: 0.34em;
}
.tool-header h2 {
  font-family: var(--font-mincho);
  font-weight: 400;
  letter-spacing: 0.04em;
  color: var(--paper);
  line-height: 1.5;
}
.tool-header h2 .accent,
.section-title .accent { color: var(--brass); }
.hero-copy { color: var(--cream-2); line-height: 2.2; letter-spacing: 0.04em; }
.hero-copy strong, .hero-copy em { color: var(--brass); font-style: normal; }
.hero-copy-sub { color: var(--muted); }

.price-chip {
  border: 1px solid var(--gold-deep);
  background: linear-gradient(180deg, rgba(199, 154, 58, 0.1), rgba(18, 15, 34, 0.4));
  border-radius: var(--radius);
}
.price-chip span { color: var(--muted); letter-spacing: 0.2em; }
.price-chip strong { color: var(--brass); font-family: var(--font-serif-en); }

/* 価値ストリップ */
.value-strip div {
  background: rgba(18, 15, 34, 0.5);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  position: relative;
}
.value-strip div::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 40px; height: 2px;
  background: var(--gold);
}
.vs-icon { color: var(--brass); }
.vs-num { color: var(--violet-2); font-family: var(--font-mono); letter-spacing: 0.2em; }
.value-strip strong { color: #f5ecd6; letter-spacing: 0.08em; }
.value-strip p { color: var(--muted); }

.price-rationale {
  color: var(--cream-2);
  font-family: var(--font-mincho);
  border-left: 2px solid var(--gold);
  letter-spacing: 0.04em;
}

/* ステップナビ */
.step-strip {
  background: rgba(11, 8, 20, 0.82);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}
.step-strip a { color: var(--cream-2); letter-spacing: 0.18em; }
.step-strip a:hover,
.step-strip a.is-active { color: var(--brass); background: rgba(199, 154, 58, 0.08); }

/* セクション見出し */
.section-label { color: var(--brass); }
.work-section h3,
.report-card h3,
.empty-report h3 {
  font-family: var(--font-mincho);
  font-weight: 500;
  letter-spacing: 0.1em;
  color: #f5ecd6;
}
.section-head p { color: var(--cream-2); }

/* フォーム入力（メイン） */
input,
textarea {
  color: var(--paper);
  background: rgba(11, 8, 20, 0.55);
  border-color: var(--line-strong);
  border-radius: var(--radius);
}
input:focus,
textarea:focus {
  border-color: var(--brass);
  background: rgba(11, 8, 20, 0.8);
  box-shadow: 0 0 0 3px rgba(224, 182, 82, 0.14);
}
input::placeholder, textarea::placeholder { color: rgba(179, 169, 143, 0.45); }
label > span { color: var(--cream-2); letter-spacing: 0.1em; }
.req { color: var(--vermilion); }
.opt { color: var(--muted); }

fieldset {
  background: rgba(18, 15, 34, 0.4);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}
legend { color: var(--brass); letter-spacing: 0.1em; }
.theme-fieldset label {
  background: rgba(18, 15, 34, 0.5);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  color: var(--cream-2);
}
.lookup-help {
  background: rgba(138, 118, 216, 0.08);
  border-left: 2px solid var(--violet);
  color: var(--cream-2);
}
.lookup-help-title { color: var(--violet-2); }
.expert-details { background: rgba(18, 15, 34, 0.4); border-radius: var(--radius); }
.expert-details > summary { color: var(--cream-2); }
.summary-sub { color: var(--muted); }

/* ボタン */
.primary-button,
.icon-button {
  color: #14100a;
  background: var(--brass);
  border: 1px solid var(--brass);
  border-radius: var(--radius);
  letter-spacing: 0.2em;
  font-weight: 600;
}
.primary-button:hover,
.icon-button:hover {
  background: #ecc873;
  transform: translateY(-2px);
  box-shadow: 0 10px 30px -8px rgba(224, 182, 82, 0.5);
}
.secondary-button,
.report-action {
  color: var(--cream-2);
  background: rgba(255, 250, 235, 0.04);
  border: 1px solid var(--line-strong);
  border-radius: var(--radius);
  letter-spacing: 0.12em;
}
.secondary-button:hover,
.report-action:hover { border-color: var(--brass); color: var(--brass); }
.action-section {
  background:
    linear-gradient(180deg, rgba(199, 154, 58, 0.08), rgba(18, 15, 34, 0.55));
}
.tool-note { color: var(--muted); }
.ai-action,
.sample-cta-button {
  color: #14100a;
  background: var(--brass);
  border: 1px solid var(--brass);
  border-radius: var(--radius);
  font-weight: 600;
}
.sample-cta {
  border: 1px solid var(--gold-deep);
  background: rgba(199, 154, 58, 0.08);
  border-radius: var(--radius);
}

/* ============ レポート ============ */
.confidence {
  border: 1px solid var(--gold-deep);
  background: rgba(199, 154, 58, 0.1);
  border-radius: var(--radius);
}
.confidence strong { color: var(--brass); }
.score-item {
  background: rgba(18, 15, 34, 0.5);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}
.bar-track { background: rgba(231, 220, 195, 0.12); }
.bar-track i { background: linear-gradient(90deg, var(--gold), var(--brass)); }
.report-block {
  background: rgba(18, 15, 34, 0.45);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}
.report-block h4 { color: #f5ecd6; font-family: var(--font-mincho); letter-spacing: 0.08em; }
.insight-block {
  border: 1px solid var(--line-violet);
  background: linear-gradient(135deg, rgba(138, 118, 216, 0.1), rgba(18, 15, 34, 0.5));
}
.insight-label { color: var(--violet-2); }
.expert-list li {
  background: rgba(18, 15, 34, 0.5);
  border-radius: var(--radius);
}
.expert-list li.active { border-left-color: var(--brass); }
.expert-list li.inactive { opacity: 0.5; border-left-color: var(--line); }
.ai-prompt {
  color: var(--cream-2);
  background: rgba(11, 8, 20, 0.7);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  font-family: var(--font-mono);
}
.month-list li strong { color: var(--brass); }
.calc-basis > summary { color: var(--violet-2); }
.compat-lead, .month-lead { color: var(--muted); }

/* 自動算出ステータス */
.auto-status {
  border: 1px solid var(--line-violet);
  background: rgba(138, 118, 216, 0.08);
  border-radius: var(--radius);
}
.auto-status-title { color: var(--violet-2); }
.auto-chip {
  background: rgba(199, 154, 58, 0.14);
  border: 1px solid var(--gold-deep);
  border-radius: var(--radius);
  color: var(--brass);
}

/* サンプル/ロック */
.sample-banner {
  color: var(--cream-2);
  background: rgba(199, 154, 58, 0.12);
  border: 1px solid var(--gold-deep);
  border-radius: var(--radius);
}
.locked-line { color: var(--muted); }
.lock-overlay {
  background: rgba(7, 5, 16, 0.6);
  backdrop-filter: blur(6px);
}

/* 発行コード */
.issued-code-value {
  color: var(--brass);
  background: rgba(7, 5, 16, 0.9);
  border: 1px solid var(--gold-deep);
  font-family: var(--font-mono);
}

/* ============ 10命術ガイド ============ */
.guide-card {
  background: rgba(18, 15, 34, 0.5);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}
.guide-card > summary { color: #f5ecd6; }
.guide-caution {
  background: rgba(11, 8, 20, 0.5);
  border-left: 2px solid var(--gold-deep);
}
.guide-foot-note { color: var(--muted); }

/* ============ フッター ============ */
.site-footer {
  color: var(--cream-2);
  background: linear-gradient(180deg, rgba(12, 9, 26, 0.9), rgba(7, 5, 16, 0.96));
  border-top: 1px solid var(--line);
}
.footer-disclaimer { color: var(--muted); }
.footer-links a { color: var(--brass); }
.footer-copy { color: var(--muted); }

/* ============ レスポンシブ ============ */
@media (max-width: 1080px) {
  .mandala-stage { min-height: clamp(260px, 60vw, 380px); }
}
