/* =========================================================================
   診断UI共通キット（dx-*）。各ブランドは base.css → diagnosis.css → 自身.css の順に読み、
   --accent / --accent-2 を上書きするだけで世界観を切り替える。
   ========================================================================= */

/* ---- 汎用エンブレム／マーク（make_oracles 生成の占い用） ---- */
.o-emblem { position: absolute; inset: 0; display: grid; place-items: center; }
.o-emblem .ring { position: absolute; inset: 5%; border-radius: 50%; border: 1px dashed var(--accent-soft); animation: dx-spin 32s linear infinite; }
.o-emblem .ring2 { position: absolute; inset: 17%; border-radius: 50%; border: 1px solid rgba(255,255,255,0.08); animation: dx-spin 52s linear infinite reverse; }
.o-emblem .core { width: 48%; height: 48%; border-radius: 50%; display: grid; place-items: center; font-size: clamp(2rem, 7vw, 3.2rem); color: var(--accent); background: radial-gradient(circle at 35% 30%, var(--accent-soft), transparent 72%); border: 1px solid var(--accent-soft); box-shadow: var(--glow); }
.o-mark-ic { width: 30px; height: 30px; border-radius: 50%; display: grid; place-items: center; font-size: 0.95rem; color: #160f2b; background: radial-gradient(circle at 35% 30%, #fff, var(--accent) 72%); box-shadow: 0 0 16px var(--accent-soft); }

/* ---- Hero ---- */
.dx-hero { text-align: center; padding: clamp(50px, 8vw, 100px) 0 clamp(22px, 4vw, 46px); }
.dx-hero h1 { font-family: var(--serif); font-weight: 800; font-size: clamp(2rem, 6vw, 3.3rem); margin: 12px 0 6px; letter-spacing: 0.07em; }
.dx-hero .sub { color: var(--ink-soft); max-width: 50ch; margin: 12px auto 0; }
.dx-emblem { width: clamp(120px, 22vw, 180px); height: clamp(120px, 22vw, 180px); margin: 0 auto 8px; position: relative; }

/* ブランドマーク（ヘッダー） */
.dx-mark { display: inline-flex; align-items: center; gap: 12px; }
.dx-mark .name { font-family: var(--serif); font-weight: 800; letter-spacing: 0.12em; font-size: 1.08rem; }
.dx-mark .name small { display: block; font-family: var(--display); letter-spacing: 0.26em; font-size: 0.55rem; color: var(--accent); }

/* ---- Form ---- */
.dx-card { max-width: 760px; margin: clamp(16px,4vw,38px) auto 0; padding: clamp(24px,4vw,42px); border-radius: var(--r-xl); }
.dx-people { display: grid; gap: 22px; grid-template-columns: 1fr auto 1fr; align-items: start; }
.dx-amp { align-self: center; font-family: var(--serif); font-size: 1.8rem; color: var(--accent); padding-top: 24px; }
.dx-person h3 { font-family: var(--serif); font-size: 1.02rem; margin: 0 0 14px; color: var(--accent); display: flex; align-items: center; gap: 8px; }
.dx-person h3 .ord { width: 24px; height: 24px; border-radius: 50%; display: grid; place-items: center; font-size: 0.74rem; border: 1px solid var(--accent-soft); }
.dx-field { margin-bottom: 14px; }
.dx-field label { display: block; font-size: 0.78rem; color: var(--ink-soft); margin-bottom: 6px; letter-spacing: 0.04em; }
.dx-field input, .dx-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;
}
.dx-field input:focus, .dx-field select:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
.dx-field .row { display: flex; gap: 8px; }
.dx-submit { text-align: center; margin-top: 26px; }
.dx-note { text-align: center; color: var(--ink-faint); font-size: 0.76rem; margin-top: 14px; }

/* ---- Casting ---- */
.dx-casting { text-align: center; padding: 58px 0; display: none; }
.dx-casting.on { display: block; }
.dx-spinner { width: 86px; height: 86px; margin: 0 auto 20px; border-radius: 50%; border: 2px solid var(--accent-soft); border-top-color: var(--accent); animation: dx-spin 1s linear infinite; }
@keyframes dx-spin { to { transform: rotate(360deg); } }
.dx-casting p { font-family: var(--serif); color: var(--accent); letter-spacing: 0.09em; }

/* ---- Result ---- */
.dx-result { display: none; }
.dx-result.on { display: block; }
.dx-score-card { text-align: center; padding: clamp(32px,5vw,54px); border-radius: var(--r-xl); position: relative; overflow: hidden; }
.dx-score-card::before { content: ""; position: absolute; inset: 0; background: radial-gradient(72% 90% at 50% 0%, var(--accent-soft), transparent 62%); }
.dx-score-card > * { position: relative; }
.dx-verdict-en { font-family: var(--display); letter-spacing: 0.28em; font-size: 0.74rem; color: var(--accent); }
.dx-verdict { font-family: var(--serif); font-weight: 800; font-size: clamp(1.7rem, 5vw, 2.7rem); margin: 8px 0 14px; }
.dx-gauge { width: min(270px, 68vw); margin: 0 auto 6px; }
.dx-score { font-family: var(--serif); font-weight: 800; font-size: clamp(3rem, 11vw, 5rem); line-height: 1; color: transparent; -webkit-background-clip: text; background-clip: text; background-image: linear-gradient(120deg, #fff, var(--accent) 52%, var(--accent-2)); }
.dx-score small { font-size: 0.3em; -webkit-text-fill-color: var(--ink-soft); margin-left: 4px; }

.dx-pair { display: flex; align-items: center; justify-content: center; gap: 20px; margin: 24px 0 6px; flex-wrap: wrap; }
.dx-pp { text-align: center; }
.dx-pp .ph { font-size: 2rem; line-height: 1; }
.dx-pp .nm { font-family: var(--serif); font-size: 1rem; margin-top: 6px; }
.dx-pp .mn { font-size: 0.76rem; color: var(--ink-soft); margin-top: 2px; }
.dx-link { color: var(--accent); font-size: 1.4rem; }

.dx-detail { display: grid; gap: 16px; grid-template-columns: repeat(auto-fit, minmax(245px, 1fr)); margin-top: 28px; }
.dx-block { padding: 25px; border-radius: var(--r-md); text-align: left; }
.dx-block h4 { font-family: var(--serif); font-size: 1.06rem; margin: 0 0 10px; color: var(--accent); display: flex; align-items: center; gap: 8px; }
.dx-block p { color: var(--ink-soft); font-size: 0.92rem; line-height: 1.85; margin: 0; }
.dx-stars { color: var(--accent); letter-spacing: 3px; margin-bottom: 8px; }
.dx-tag { display: inline-block; margin-top: 12px; padding: 6px 14px; border-radius: 100px; background: var(--accent-soft); color: var(--accent); font-weight: 700; font-size: 0.84rem; }

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

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