/* =========================================================================
   月読の相性 — TSUKUYOMI （本格・神秘）
   ベースの宇宙トーンを継承しつつ、月と金の世界観へ。
   ========================================================================= */
:root {
  --accent: #e9c46a;
  --accent-2: #8c6be0;
  --accent-soft: rgba(233, 196, 106, 0.16);
  --glow: 0 0 50px rgba(233, 196, 106, 0.3);
}

/* ブランド固有ヘッダーの色味 */
.tsuki-mark { display: inline-flex; align-items: center; gap: 12px; }
.tsuki-mark .moon {
  width: 30px; height: 30px; border-radius: 50%;
  background: radial-gradient(circle at 35% 30%, #fff, #f1e3b6 40%, #c9a227);
  box-shadow: 0 0 22px rgba(233, 196, 106, 0.6), inset -6px -4px 10px rgba(120, 90, 20, 0.5);
}
.tsuki-mark .name { font-family: var(--serif); font-weight: 800; letter-spacing: 0.14em; font-size: 1.1rem; }
.tsuki-mark .name small { display: block; font-family: var(--display); letter-spacing: 0.34em; font-size: 0.56rem; color: var(--gold); }

/* ---- Hero ---- */
.t-hero { text-align: center; padding: clamp(56px, 9vw, 110px) 0 clamp(30px, 5vw, 60px); position: relative; }
.t-moon-stage { position: relative; width: clamp(150px, 26vw, 230px); height: clamp(150px, 26vw, 230px); margin: 0 auto 12px; }
.t-moon {
  position: absolute; inset: 0; border-radius: 50%;
  background:
    radial-gradient(circle at 36% 30%, #fffefb, #f4e7bd 38%, #d8b659 70%, #b9952f 100%);
  box-shadow: 0 0 90px rgba(233, 196, 106, 0.45), inset -24px -18px 50px rgba(90, 66, 14, 0.55);
}
.t-moon::after {
  content: ""; position: absolute; inset: 0; border-radius: 50%;
  background:
    radial-gradient(8px 8px at 60% 40%, rgba(120,90,30,0.35), transparent 70%),
    radial-gradient(14px 14px at 42% 62%, rgba(120,90,30,0.28), transparent 70%),
    radial-gradient(6px 6px at 70% 66%, rgba(120,90,30,0.3), transparent 70%);
  mix-blend-mode: multiply;
}
.t-halo { position: absolute; inset: -16%; border-radius: 50%; border: 1px solid var(--gold-soft); animation: spin 40s linear infinite; }
.t-halo::before { content: "✦"; position: absolute; top: -10px; left: 50%; transform: translateX(-50%); color: var(--gold); font-size: 0.8rem; }
@keyframes spin { to { transform: rotate(360deg); } }

.t-hero .eyebrow { margin-top: 6px; }
.t-hero h1 { font-family: var(--serif); font-weight: 800; font-size: clamp(2rem, 6vw, 3.4rem); margin: 14px 0 6px; letter-spacing: 0.08em; }
.t-hero .sub { color: var(--ink-soft); max-width: 50ch; margin: 12px auto 0; }

/* ---- フォーム ---- */
.t-form-wrap { max-width: 760px; margin: clamp(20px,4vw,40px) auto 0; padding: clamp(26px, 4vw, 44px); border-radius: var(--r-xl); }
.t-persons { display: grid; gap: 22px; grid-template-columns: 1fr auto 1fr; align-items: start; }
.t-amp { align-self: center; font-family: var(--serif); font-size: 2rem; color: var(--gold); padding-top: 26px; }
.t-person h3 { font-family: var(--serif); font-size: 1.05rem; margin: 0 0 14px; color: var(--gold); display: flex; align-items: center; gap: 8px; }
.t-person h3 .ord { width: 24px; height: 24px; border-radius: 50%; display: grid; place-items: center; font-size: 0.74rem; border: 1px solid var(--gold-soft); }
.field { margin-bottom: 14px; }
.field label { display: block; font-size: 0.78rem; color: var(--ink-soft); margin-bottom: 6px; letter-spacing: 0.04em; }
.field input, .field select {
  width: 100%; padding: 0.85em 1em; border-radius: var(--r-sm);
  background: rgba(0,0,0,0.25); border: 1px solid var(--line-strong); color: var(--ink);
  font-family: var(--sans); font-size: 0.96rem; transition: border-color 0.2s, box-shadow 0.2s;
}
.field input:focus, .field select:focus { outline: none; border-color: var(--gold); box-shadow: 0 0 0 3px var(--gold-soft); }
.field .row { display: flex; gap: 8px; }
.t-submit { text-align: center; margin-top: 26px; }
.t-note { text-align: center; color: var(--ink-faint); font-size: 0.76rem; margin-top: 14px; }

/* ---- 占い演出 ---- */
.t-casting { text-align: center; padding: 60px 0; display: none; }
.t-casting.on { display: block; }
.t-casting .ring { width: 90px; height: 90px; margin: 0 auto 22px; border-radius: 50%; border: 2px solid var(--gold-soft); border-top-color: var(--gold); animation: spin 1s linear infinite; }
.t-casting p { font-family: var(--serif); color: var(--gold); letter-spacing: 0.1em; }

/* ---- 結果 ---- */
.t-result { display: none; }
.t-result.on { display: block; }
.t-score-card { text-align: center; padding: clamp(34px, 5vw, 56px); border-radius: var(--r-xl); position: relative; overflow: hidden; }
.t-score-card::before { content: ""; position: absolute; inset: 0; background: radial-gradient(70% 90% at 50% 0%, var(--accent-soft), transparent 60%); }
.t-score-card > * { position: relative; }
.t-verdict-en { font-family: var(--display); letter-spacing: 0.3em; font-size: 0.74rem; color: var(--gold); }
.t-verdict { font-family: var(--serif); font-weight: 800; font-size: clamp(1.8rem, 5vw, 2.8rem); margin: 8px 0 18px; }

.t-gauge { width: min(280px, 70vw); margin: 0 auto 10px; }
.t-score-num { font-family: var(--serif); font-weight: 800; font-size: clamp(3rem, 11vw, 5rem); line-height: 1; color: transparent; background: linear-gradient(120deg, #fff, var(--gold) 55%, var(--accent-2)); -webkit-background-clip: text; background-clip: text; }
.t-score-num small { font-size: 0.3em; -webkit-text-fill-color: var(--ink-soft); margin-left: 4px; }

.t-pair { display: flex; align-items: center; justify-content: center; gap: 18px; margin: 22px 0 4px; flex-wrap: wrap; }
.t-pair .pp { text-align: center; }
.t-pair .pp .ph { font-size: 2rem; }
.t-pair .pp .nm { font-family: var(--serif); font-size: 1rem; margin-top: 4px; }
.t-pair .pp .mn { font-size: 0.74rem; color: var(--ink-soft); }
.t-pair .link { color: var(--gold); font-size: 1.4rem; }

.t-detail { display: grid; gap: 18px; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); margin-top: 30px; }
.t-block { padding: 26px; border-radius: var(--r-md); text-align: left; }
.t-block h4 { font-family: var(--serif); font-size: 1.1rem; margin: 0 0 10px; color: var(--gold); display: flex; align-items: center; gap: 8px; }
.t-block p { color: var(--ink-soft); font-size: 0.92rem; line-height: 1.85; margin: 0; }
.t-block .stars { color: var(--gold); letter-spacing: 3px; margin-bottom: 8px; }

.t-actions { text-align: center; margin-top: 32px; display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

@media (max-width: 680px) {
  .t-persons { grid-template-columns: 1fr; }
  .t-amp { display: none; }
  .t-person + .t-person { border-top: 1px solid var(--line); padding-top: 22px; }
}
