/* =========================================================
   Saari 相性診断（KINO①）── diagnose.css
   器＝みんなの recruit-diagnose を流用／美学＝v4「ちいさな島」
   tokens.css・base.css・components.css に依存
   ========================================================= */

/* topbar */
.dx-topbar{border-bottom:1px solid var(--c-line);padding:16px 0}
.dx-topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.dx-bc{font-family:var(--ff-accent);font-style:italic;font-size:.86rem;letter-spacing:.08em;color:var(--c-greige-deep);display:flex;align-items:center;gap:8px}
.dx-bc a{color:var(--c-rose-deep)}
.dx-bc a:hover{opacity:.7}
.dx-bc-sep{color:var(--c-greige)}
.dx-bc-cur{color:var(--c-ink)}
.dx-home{font-size:.82rem;font-weight:var(--fw-medium);letter-spacing:.04em;color:var(--c-rose-deep);border:1px solid var(--c-rose);border-radius:999px;padding:7px 16px}
.dx-home:hover{background:var(--c-rose-soft);opacity:1}
/* 進捗バー内・常時見える「採用トップへ戻る」 */
.dx-back{flex:none;white-space:nowrap;font-size:.78rem;font-weight:var(--fw-medium);letter-spacing:.03em;color:var(--c-rose-deep);border:1px solid var(--c-line);border-radius:999px;padding:6px 13px}
.dx-back:hover{background:var(--c-rose-soft);border-color:var(--c-rose);opacity:1}
.dx-foot-link{display:inline-block;margin-bottom:16px;font-size:.88rem;font-weight:var(--fw-medium);color:var(--c-rose-deep);border-bottom:1px solid var(--c-rose);padding-bottom:2px}

/* progress */
.dx-progress{position:sticky;top:0;z-index:5;background:rgba(250,247,242,.92);backdrop-filter:blur(6px);border-bottom:1px solid var(--c-line);padding:12px 0}
.dx-progress .wrap{display:flex;align-items:center;gap:14px}
.dx-track{flex:1;height:3px;border-radius:999px;background:var(--c-paper-sand);overflow:hidden}
.dx-fill{height:100%;background:var(--c-rose);transform-origin:left;transform:scaleX(0);transition:transform .45s var(--ease-out)}
.dx-plabel{font-family:var(--ff-accent);font-style:italic;font-size:.78rem;letter-spacing:.1em;color:var(--c-greige-deep);white-space:nowrap}

/* steps */
.dx{padding:40px 0 72px}
.dx-step{display:none}
.dx-step.is-active{display:block;animation:dxfade .4s var(--ease-out)}
@keyframes dxfade{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.dx-eyebrow{font-family:var(--ff-accent);font-style:italic;font-size:.92rem;letter-spacing:.16em;color:var(--c-rose-deep);margin-bottom:16px}
.dx-qtitle{font-family:var(--ff-jp-serif);font-weight:var(--fw-regular);font-size:clamp(1.55rem,4vw,2.15rem);line-height:1.5;letter-spacing:var(--ls-jp);color:var(--c-ink);margin-bottom:10px}
.dx-qsub{font-size:var(--fs-sm);color:var(--c-ink-soft);margin-bottom:30px}

.dx-intro-stats{display:flex;gap:14px;margin:28px 0 32px;flex-wrap:wrap}
.dx-stat{padding:14px 18px;background:var(--c-paper-sand);border-left:2px solid var(--c-rose);min-width:120px}
.dx-stat .v{font-family:var(--ff-display);font-weight:var(--fw-light);font-size:1.7rem;line-height:1;color:var(--c-rose-deep)}
.dx-stat .l{font-family:var(--ff-accent);font-style:italic;font-size:.78rem;color:var(--c-greige-deep);margin-top:6px}

.dx-options{display:grid;gap:12px;margin-bottom:30px}
.dx-option{display:flex;align-items:flex-start;gap:14px;text-align:left;width:100%;cursor:pointer;
  padding:18px 20px;background:var(--c-white);border:1px solid var(--c-line);border-radius:var(--radius);transition:all .15s}
.dx-option:hover{border-color:var(--c-rose)}
.dx-option.is-selected{border-color:var(--c-rose-deep);background:rgba(207,155,156,.08);box-shadow:inset 0 0 0 1px var(--c-rose-deep)}
.dx-mark{flex:none;width:18px;height:18px;border-radius:999px;border:2px solid var(--c-line-strong,var(--c-greige));margin-top:3px}
.dx-option.is-selected .dx-mark{border-color:var(--c-rose-deep);background:radial-gradient(circle at center,var(--c-rose-deep) 0 5px,transparent 6px)}
.dx-otitle{display:block;font-size:.98rem;font-weight:var(--fw-medium);color:var(--c-ink)}
.dx-osub{display:block;font-size:.82rem;color:var(--c-ink-soft);margin-top:3px}
.dx-actions{display:flex;gap:12px;flex-wrap:wrap}

/* result */
.dx-reyebrow{font-family:var(--ff-accent);font-style:italic;font-size:.92rem;letter-spacing:.16em;color:var(--c-rose-deep);margin-bottom:14px}
.dx-rtitle{font-family:var(--ff-jp-serif);font-weight:var(--fw-regular);font-size:clamp(1.55rem,4vw,2.15rem);line-height:1.5;margin-bottom:10px;color:var(--c-ink)}
.dx-rsub{font-size:var(--fs-sm);color:var(--c-ink-soft);margin-bottom:24px}
.dx-summary{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:28px}
.dx-summary .key{font-family:var(--ff-accent);font-style:italic;font-size:.8rem;color:var(--c-greige-deep)}
.dx-pill{font-size:.78rem;padding:5px 13px;border-radius:999px;background:var(--c-paper-sand);border:1px solid var(--c-line);color:var(--c-ink)}

.dx-card{border:1px solid var(--c-rose);border-radius:var(--radius-lg);padding:28px 28px;background:linear-gradient(180deg,#fff,var(--c-paper-sand));margin-bottom:20px}
.dx-card .rank{font-family:var(--ff-accent);font-style:italic;font-size:.82rem;letter-spacing:.1em;color:var(--c-rose-deep);margin-bottom:8px}
.dx-card .type{font-family:var(--ff-jp-serif);font-weight:var(--fw-regular);font-size:1.55rem;letter-spacing:var(--ls-jp);color:var(--c-ink)}
.dx-card .tagline{font-size:var(--fs-sm);color:var(--c-ink-soft);margin:10px 0 14px}
.dx-card .why{font-size:.86rem;color:var(--c-rose-deep);line-height:1.85;margin-bottom:18px}
.dx-model{display:flex;align-items:center;gap:16px;padding-top:18px;border-top:1px dashed var(--c-line)}
.dx-model img{width:64px;height:64px;border-radius:999px;object-fit:cover;object-position:center 20%;flex:none}
.dx-model .m-name{font-weight:var(--fw-medium);font-size:.95rem;color:var(--c-ink)}
.dx-model .m-role{font-family:var(--ff-accent);font-style:italic;font-size:.78rem;color:var(--c-greige-deep);margin-left:8px}
.dx-model .m-note{font-size:.82rem;color:var(--c-ink-soft);line-height:1.7;margin-top:4px}

.dx-honest{background:rgba(156,90,82,.06);border-left:3px solid var(--c-clay);padding:18px 22px;margin-bottom:24px;font-size:.86rem;line-height:1.9;color:var(--c-ink-soft)}
.dx-honest strong{color:var(--c-ink)}
.dx-ractions{display:flex;gap:12px;flex-wrap:wrap}
.dx-rsub-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:12px}
.dx-back-line{margin-top:22px;text-align:center}
.dx-back-line a{font-size:.88rem;font-weight:var(--fw-medium);color:var(--c-rose-deep);border-bottom:1px solid var(--c-line);padding-bottom:2px}
.dx-back-line a:hover{border-color:var(--c-rose);opacity:1}

.dx-foot{border-top:1px solid var(--c-line);padding:28px 0;text-align:center}
.dx-foot .c{font-family:var(--ff-accent);font-style:italic;font-size:.78rem;color:var(--c-greige-deep)}
.dx-foot .stamp{font-family:var(--ff-accent);font-style:italic;font-size:.82rem;color:var(--c-rose-deep);margin-top:6px}

/* =========================================================
   インライン展開（オーバーレイ）── 別ページ遷移を廃止し index 内で開く
   2026-06-17 岩田さん方針「診断で別ページ遷移せず同一画面で展開」
   ========================================================= */
.dx-overlay{position:fixed;inset:0;z-index:140;display:flex;align-items:center;justify-content:center;
  padding:clamp(12px,3vw,32px);overflow:hidden;
  background:rgba(35,30,26,.46);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  opacity:0;pointer-events:none;transition:opacity .3s var(--ease-out);font-family:var(--ff-jp)}
.dx-overlay.is-open{opacity:1;pointer-events:auto}
/* モーダル＝縦flex（進捗バー固定＋本文だけスクロール）。sticky非依存で挙動が安定 */
.dx-modal{position:relative;width:100%;max-width:760px;max-height:calc(100dvh - 48px);
  display:flex;flex-direction:column;overflow:hidden;
  background:var(--c-paper);border-radius:var(--radius-lg);box-shadow:0 30px 80px rgba(120,80,70,.28);
  transform:translateY(20px);transition:transform .3s var(--ease-out)}
.dx-overlay.is-open .dx-modal{transform:none}
.dx-overlay .dx-progress{position:static;flex:none;border-bottom:1px solid var(--c-line);padding:14px 0;background:var(--c-paper);box-shadow:none}
.dx-overlay .dx-progress .wrap{display:flex;align-items:center;gap:14px}
.dx-scroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}
.dx-close{flex:none;width:34px;height:34px;border-radius:999px;cursor:pointer;
  border:1px solid var(--c-line);background:var(--c-white);color:var(--c-greige-deep);
  font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .2s}
.dx-close:hover{border-color:var(--c-rose);background:var(--c-rose-soft);color:var(--c-ink)}
.dx-overlay .dx{padding:32px 0 56px}
.dx-overlay .wrap{padding-left:clamp(20px,5vw,40px);padding-right:clamp(20px,5vw,40px)}
@media (max-width:540px){
  .dx-overlay{padding:0;align-items:stretch}
  .dx-modal{max-width:100%;max-height:100dvh;height:100dvh;border-radius:0}
}
body.dx-locked{overflow:hidden}
