/* ═══════════════════════════════════════════════════════════
   戦国武将診断 v1.3 — 統合スタイルシート
   ライトベージュテーマ / 通常フロー方式
   ═══════════════════════════════════════════════════════════ */

/* ── CSS 変数 ───────────────────────────────────────────────── */
:root {
  --sd-ink:             #1a1208;
  --sd-ink-mid:         #3d2b1a;
  --sd-ink-light:       #6b4c2a;
  --sd-gold:            #b87800;
  --sd-gold-light:      #c8960a;
  --sd-gold-pale:       #f5e6c0;
  --sd-crimson:         #8b1a1a;
  --sd-crimson-dark:    #5a0e0e;
  --sd-crimson-hover:   #6b1010;
  --sd-parchment:       #f5edd8;
  --sd-parchment-dark:  #e8d8b0;
  --sd-parchment-mid:   #d4c090;
  --sd-bg:              #f2ede0;
  --sd-bg-card:         rgba(255,255,255,0.80);
  --sd-bg-card-alt:     rgba(255,255,255,0.65);
  --sd-border:          rgba(180,134,40,0.22);
  --sd-border-strong:   rgba(180,134,40,0.45);
}

/* ── アニメーション ─────────────────────────────────────────── */
@keyframes sd-fadeIn  { from { opacity: 0; }                             to { opacity: 1; } }
@keyframes sd-slideUp { from { opacity: 0; transform: translateY(20px);} to { opacity: 1; transform: translateY(0); } }
@keyframes sd-fadeUp  { from { opacity: 0; transform: translateY(14px);} to { opacity: 1; transform: translateY(0); } }

/* ════════════════════════════════════════════════════════════
   オーバーレイ本体
   通常フロー（AFFINGER ヘッダー・フッターを残す）
   ════════════════════════════════════════════════════════════ */
.sd-overlay {
  position: relative;
  width: 100%;
  background: var(--sd-bg) !important;
  font-family: 'Noto Sans JP', 'Helvetica Neue', Arial, sans-serif !important;
  color: var(--sd-ink) !important;
  box-sizing: border-box !important;
  overflow-x: hidden;
}

/* オーバーレイ内の全要素をリセット */
.sd-overlay *, .sd-overlay *::before, .sd-overlay *::after {
  box-sizing: border-box;
}
.sd-overlay a            { text-decoration: none; }
.sd-overlay button       { font-family: inherit; }
.sd-overlay h1, .sd-overlay h2, .sd-overlay h3,
.sd-overlay h4, .sd-overlay h5, .sd-overlay h6 {
  font-weight: inherit;
  margin: 0;
  padding: 0;
  background: transparent;
  border: none;
  color: inherit;
}
.sd-overlay p, .sd-overlay ul, .sd-overlay li,
.sd-overlay span, .sd-overlay div {
  padding: 0;
}
.sd-overlay img { max-width: 100%; display: block; }

@media print, screen and (min-width: 960px) {
    #wrapper:not(.colum1) #content-w, header + #content-w {
        padding-top: 0px !important;
    }
}

/* ── 背景テクスチャ（start 画面） ───────────────────────────── */
.sd-overlay--start::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    repeating-linear-gradient(
      0deg,
      transparent,
      transparent 3px,
      rgba(180,134,40,0.025) 3px,
      rgba(180,134,40,0.025) 6px
    ),
    radial-gradient(ellipse at 20% 50%, rgba(139,26,26,0.07) 0%, transparent 60%),
    radial-gradient(ellipse at 80% 20%, rgba(184,120,0,0.05) 0%, transparent 50%),
    radial-gradient(ellipse at 60% 80%, rgba(139,26,26,0.05) 0%, transparent 50%);
  pointer-events: none;
  z-index: 0;
}

/* ── 背景グラデ（form・result 画面） ────────────────────────── */
.sd-overlay--form::before,
.sd-overlay--result::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 15% 40%, rgba(139,26,26,0.06) 0%, transparent 55%),
    radial-gradient(ellipse at 85% 70%, rgba(184,120,0,0.04) 0%, transparent 50%);
  pointer-events: none;
  z-index: 0;
}

/* ════════════════════════════════════════════════════════════
   共通ラッパー
   ════════════════════════════════════════════════════════════ */
.sd-wrap {
  position: relative;
  z-index: 1;
  max-width: 720px !important;
  margin: 0 auto;
  padding: 3rem 1.5rem 4rem!important;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.sd-wrap--form,
.sd-wrap--result {
  max-width: 680px;
  padding: 2rem 1.5rem 4rem !important;
}

/* ── ヘッダー（form・result 共通） ──────────────────────────── */
.sd-header {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.8rem;
}
.sd-header__logo {
  font-size: .72rem;
  letter-spacing: .25em;
  color: var(--sd-gold);
  opacity: .85;
}
.sd-header__step { font-size: .72rem; letter-spacing: .1em; color: var(--sd-ink-light); }
.sd-header__tag  {
  font-size: .68rem;
  letter-spacing: .12em;
  color: var(--sd-ink-light);
  border: 1px solid var(--sd-border-strong);
  padding: .2em .7em !important;
}

/* ════════════════════════════════════════════════════════════
   START 画面
   ════════════════════════════════════════════════════════════ */

/* 家紋 */
.sd-kamon {
  width: 72px;
  height: 72px;
  margin-bottom: 2rem;
  opacity: .75;
  animation: sd-fadeIn 1.2s ease both;
}

/* タイトルブロック */
.sd-title-block {
  text-align: center;
  margin-bottom: 2.5rem;
  animation: sd-slideUp .9s ease both;
  animation-delay: .2s;
}
.sd-sub-label {
  display: inline-block;
  font-size: 1rem;
  font-weight: 400;
  letter-spacing: .35em;
  color: var(--sd-gold);
  border-top: 1px solid var(--sd-gold);
  border-bottom: 1px solid var(--sd-gold);
  padding: .3em 1.2em;
  margin-bottom: 1.4rem;
  opacity: .9;
}
.sd-main-catch {
  font-family: 'Noto Serif JP', serif;
  font-size: clamp(2rem, 6vw, 3.2rem);
  font-weight: 900;
  line-height: 1.2;
  letter-spacing: .05em;
  color: var(--sd-ink);
  margin-bottom: .6rem;
}
.sd-main-catch em   { font-style: normal; color: var(--sd-gold); }
.sd-main-catch .sd-comma { color: var(--sd-gold); opacity: .7; }

.sd-title-deco {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .8rem;
  margin: 1rem 0 1.4rem;
}
.sd-title-deco::before,
.sd-title-deco::after {
  content: '';
  flex: 1;
  max-width: 80px;
  height: 1px;
  background: linear-gradient(to right, transparent, var(--sd-gold));
}
.sd-title-deco::after { background: linear-gradient(to left, transparent, var(--sd-gold)); }
.sd-title-deco span  { color: var(--sd-gold); font-size: .9rem; opacity: .8; }

.sd-tool-title {
  font-family: 'Noto Serif JP', serif;
  font-size: clamp(1.1rem, 3vw, 1.4rem);
  font-weight: 700;
  letter-spacing: .12em;
  color: var(--sd-ink-mid);
}
.sd-sub-catch {
  font-size: .85rem;
  font-weight: 400;
  letter-spacing: .1em;
  color: var(--sd-ink-light);
  margin-top: .8rem;
}

/* プロローグカード */
.sd-prologue-card {
  width: 100%;
  background: var(--sd-bg-card);
  border: 1px solid var(--sd-border);
  border-top: 2px solid var(--sd-gold);
  padding: 2rem 2rem 1.8rem!important;
  margin-bottom: 2.5rem;
  position: relative;
  animation: sd-slideUp .9s ease both;
  animation-delay: .4s;
  box-shadow: 0 2px 12px rgba(100,70,20,0.08);
}
.sd-prologue-card::before {
  content: 'プロローグ';
  position: absolute;
  top: -.75rem;
  left: 50%;
  transform: translateX(-50%);
  letter-spacing: .2em;
  color: var(--sd-gold);
  background: var(--sd-bg);
  padding: 0 .8em;
}
.sd-prologue-text {
  line-height: 2.1;
  color: var(--sd-ink-mid);
  white-space: pre-line;
  text-align: left;
}
.sd-prologue-text .sd-hi { color: var(--sd-ink); font-weight: 700; }

/* 診断情報バッジ */
.sd-info-badges {
  display: flex;
  gap: .8rem;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 2rem;
  animation: sd-slideUp .9s ease both;
  animation-delay: .5s;
}
.sd-badge {
  font-size: .72rem;
  letter-spacing: .1em;
  color: var(--sd-gold);
  border: 1px solid var(--sd-border-strong);
  padding: .3em .9em;
  white-space: nowrap;
}

/* スタートボタン */
.sd-btn-wrap {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  animation: sd-slideUp .9s ease both;
  animation-delay: .6s;
}
.sd-btn-start {
  display: inline-block;
  width: 100%;
  max-width: 360px;
  padding: 1.1rem 2rem;
  background: var(--sd-crimson);
  border: none;
  color: var(--sd-parchment) !important;
  font-family: 'Noto Serif JP', serif;
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: .2em;
  cursor: pointer;
  text-align: center;
  text-decoration: none !important;
  position: relative;
  overflow: hidden;
  transition: background .25s, transform .15s;
  box-shadow: 0 3px 12px rgba(139,26,26,0.25);
}
.sd-btn-start::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,.1) 0%, transparent 50%);
  pointer-events: none;
}
.sd-btn-start::after {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: rgba(255,255,255,.25);
}
.sd-btn-start:hover { background: var(--sd-crimson-dark); transform: translateY(-1px); color: var(--sd-parchment) !important; }
.sd-btn-start:active { transform: translateY(0); }
.sd-btn-arrow {
  display: inline-block;
  margin-left: .5em;
  color: var(--sd-parchment-dark);
  transition: transform .2s;
}
.sd-btn-start:hover .sd-btn-arrow { transform: translateX(4px); }
.sd-time-note {
  font-size: .75rem;
  color: var(--sd-ink-light);
  letter-spacing: .05em;
  opacity: .7;
}

/* フッター装飾 */
.sd-footer-deco {
  margin-top: 3rem;
  display: flex;
  align-items: center;
  gap: 1rem;
  opacity: .3;
  animation: sd-fadeIn 1.5s ease both;
  animation-delay: .8s;
}
.sd-footer-deco::before,
.sd-footer-deco::after { content: ''; flex: 1; height: 1px; background: var(--sd-gold); }
.sd-footer-deco span { font-size: .65rem; letter-spacing: .3em; color: var(--sd-gold); }

/* ════════════════════════════════════════════════════════════
   FORM 画面（質問フォーム）
   ════════════════════════════════════════════════════════════ */

/* プログレス */
.sd-progress-wrap  { width: 100%; margin-bottom: 2rem; }
.sd-progress-label {
  display: flex;
  justify-content: space-between;
  font-size: .68rem;
  letter-spacing: .08em;
  color: var(--sd-gold);
  opacity: .85;
  margin-bottom: .5rem;
}
.sd-progress-track {
  width: 100%;
  height: 3px;
  background: rgba(184,120,0,.15);
  position: relative;
}
.sd-progress-fill {
  height: 100%;
  background: var(--sd-gold);
  transition: width .6s ease;
}
.sd-progress-nodes {
  display: flex;
  justify-content: space-between;
  margin-top: .4rem;
}
.sd-node {
  width: 8px;
  height: 8px;
  border: 1px solid rgba(184,120,0,.35);
  background: transparent;
  transform: rotate(45deg);
  transition: background .4s, border-color .4s;
}
.sd-node.done    { background: var(--sd-gold); border-color: var(--sd-gold); }
.sd-node.current { background: transparent; border-color: var(--sd-gold-light); box-shadow: 0 0 4px rgba(200,150,10,.35); }

/* シナリオカード */
.sd-scene-card {
  width: 100%;
  background: var(--sd-bg-card);
  border: 1px solid var(--sd-border);
  border-top: 2px solid var(--sd-gold);
  padding: 1.8rem 2rem 1.5rem!important;
  margin-bottom: 1.6rem;
  position: relative;
  animation: sd-fadeUp .5s ease both;
  box-shadow: 0 2px 10px rgba(100,70,20,0.07);
}
.sd-scene-header {
  display: flex;
  align-items: center;
  gap: .8rem;
  margin-bottom: 1.2rem;
}
.sd-scene-num {
  color: var(--sd-gold);
  border: 1px solid var(--sd-border-strong);
  padding: .2em .7em!important;
  white-space: nowrap;
}
.sd-scene-title {
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: .1em;
  color: var(--sd-ink);
}
.sd-scene-divider {
  width: 100%;
  height: 1px;
  background: linear-gradient(to right, rgba(184,120,0,.35), transparent);
  margin-bottom: 1.2rem;
}
.sd-branch-intro {
  line-height: 1.8;
  color: var(--sd-gold);
  font-style: italic;
  margin-bottom: 1rem;
  padding-left: .8rem;
  border-left: 2px solid rgba(184,120,0,.4);
  animation: sd-fadeIn .8s ease both;
}
.sd-scenario-text {
  line-height: 2.1;
  color: var(--sd-ink-mid);
  white-space: pre-line;
  margin-bottom: 1.2rem;
}
.sd-question-ask {
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: .06em;
  color: var(--sd-ink);
  padding-top: 1rem!important;
  border-top: 1px solid rgba(184,120,0,.18);
}

/* 選択肢 */
.sd-choices {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: .7rem;
  margin-bottom: 1.5rem;
  animation: sd-fadeUp .5s ease both;
  animation-delay: .15s;
}
.sd-choice-btn {
  width: 100%;
  background: var(--sd-bg-card-alt);
  border: 1px solid var(--sd-border);
  padding: 1rem 1.2rem;
  display: flex;
  align-items: flex-start;
  gap: .9rem;
  cursor: pointer;
  text-align: left;
  transition: background .2s, border-color .2s, transform .15s;
  position: relative;
  overflow: hidden;
  box-shadow: 0 1px 4px rgba(100,70,20,0.05);
}
.sd-choice-btn:hover {
  background: rgba(255,255,255,0.95);
  border-color: var(--sd-border-strong);
  transform: translateX(3px);
}
.sd-choice-btn.selected {
  background: rgba(139,26,26,.06);
  border-color: var(--sd-crimson);
}
.sd-choice-btn.selected .sd-choice-label {
  background: var(--sd-crimson);
  color: var(--sd-parchment);
  border-color: var(--sd-crimson);
}
.sd-choice-label {
  flex-shrink: 0;
  width: 1.6rem;
  height: 1.6rem;
  border: 2px solid var(--sd-border-strong);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .75rem;
  font-weight: 700;
  color: var(--sd-gold);
  transition: background .2s, color .2s;
  margin-top: .05rem;
}
.sd-choice-text {
  font-size: .88rem;
  line-height: 1.8;
  color: var(--sd-ink-mid);
  flex: 1;
}
.sd-choice-btn:hover .sd-choice-text { color: var(--sd-ink); }

/* ナビゲーション */
.sd-nav {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  animation: sd-fadeUp .5s ease both;
  animation-delay: .25s;
}
.sd-btn-back {
  font-family: 'Noto Serif JP', serif;
  font-size: .8rem;
  letter-spacing: .1em;
  color: var(--sd-ink-light);
  background: none;
  border: none;
  cursor: pointer;
  opacity: .6;
  transition: opacity .2s;
  padding: .4rem 0;
}
.sd-btn-back:hover { opacity: 1; }

.sd-btn-next {
  font-family: 'Noto Serif JP', serif;
  font-size: .9rem;
  font-weight: 700;
  letter-spacing: .18em;
  color: var(--sd-parchment);
  background: var(--sd-crimson);
  border: none;
  padding: .85rem 2rem;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  transition: background .2s, transform .15s;
  opacity: .35;
  pointer-events: none;
}
.sd-btn-next.active { opacity: 1; pointer-events: auto; box-shadow: 0 3px 12px rgba(139,26,26,0.22); }
.sd-btn-next.active:hover { background: var(--sd-crimson-hover); transform: translateY(-1px); }
.sd-btn-next-arr {
  display: inline-block;
  margin-left: .4em;
  color: var(--sd-parchment-dark);
  transition: transform .2s;
}
.sd-btn-next.active:hover .sd-btn-next-arr { transform: translateX(3px); }

.sd-footer-note {
  margin-top: 2rem;
  font-size: .68rem;
  letter-spacing: .06em;
  color: rgba(107,76,42,.35);
  text-align: center;
}

/* ════════════════════════════════════════════════════════════
   RESULT 画面
   ════════════════════════════════════════════════════════════ */

.sd-result-label {
  font-weight: 700;
  font-size: 1.2em;
  letter-spacing: .35em;
  color: var(--sd-gold);
  border-top: 1px solid var(--sd-gold);
  border-bottom: 1px solid var(--sd-gold);
  padding: .3em 1.4em;
  margin-bottom: 1.6rem;
  opacity: .9;
  animation: sd-fadeIn 1s ease both;
}

/* 武将ビジュアル */
.sd-warrior-visual {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 1.8rem;
  animation: sd-slideUp .8s ease both;
  animation-delay: .2s;
}
.sd-warrior-img-frame {
  width: 300px;
  height: 300px;
  border: 1px solid var(--sd-border-strong);
  border-top: 3px solid var(--sd-gold);
  border-bottom: 3px solid var(--sd-gold);
  position: relative;
  overflow: hidden;
  background: rgba(200,180,140,0.25);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.2rem;
  box-shadow: 0 4px 16px rgba(100,70,20,0.12);
}
.sd-warrior-img-frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  inset: 0;
}
.sd-warrior-img-frame::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 60%, rgba(200,180,140,0.4));
  pointer-events: none;
  z-index: 1;
}
.sd-img-placeholder {
  font-family: 'Noto Serif JP', serif;
  font-size: .75rem;
  letter-spacing: .15em;
  color: var(--sd-gold);
  opacity: .5;
}

/* バッジ */
.sd-type-badges {
  display: flex;
  gap: .5rem;
  margin-bottom: 1rem;
}
.sd-badge-mbti {
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: .12em;
  color: var(--sd-gold);
  border: 1px solid var(--sd-border-strong);
  padding: .3em .9em!important;
  background: rgba(255,255,255,0.7);
}
.sd-badge-chi {
  font-weight: 700;
  font-size: 1rem;
  letter-spacing: .1em;
  padding: .3em .9em!important;
  background: rgba(220,235,250,0.8);
  border: 1px solid rgba(56,108,180,.3);
  color: #2a5a9a;
}
.sd-badge-bu {
  font-weight: 700;
  font-size: 1rem;
  letter-spacing: .1em;
  padding: .3em .9em!important;
  background: rgba(255,235,230,0.8);
  border: 1px solid rgba(180,56,56,.3);
  color: var(--sd-crimson);
}

/* 武将名ルビ */
.sd-warrior-name ruby { display: inline-grid-lanes; }
.sd-warrior-name rt {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: .32em;
  font-weight: 400;
  letter-spacing: .12em;
  color: var(--sd-ink-light);
  opacity: .85;
}

/* 武将名・タイプラベル */
.sd-warrior-name {
  font-family: 'Noto Serif JP', serif;
  margin-top: 0 !important;
  padding: 1.3rem !important;
  font-size: clamp(2rem, 5vw, 2.8rem)!important;
  font-weight: 900!important;
  letter-spacing: .15em;
  color: var(--sd-ink);
  text-align: center;
  margin-bottom: .3rem!important;
  animation: sd-slideUp .8s ease both;
  animation-delay: .3s;
}
.sd-warrior-type-label {
  font-family: 'Noto Serif JP', serif;
  font-size: 1.1rem;
  font-weight: 700;
  letter-spacing: .2em;
  color: var(--sd-gold);
  text-align: center;
  margin-bottom: .5rem;
  animation: sd-slideUp .8s ease both;
  animation-delay: .35s;
}

/* 区切り線 */
.sd-divider {
  width: 100%;
  display: flex;
  align-items: center;
  gap: .8rem;
  margin: 1.4rem 0;
  animation: sd-fadeIn .8s ease both;
  animation-delay: .4s;
}
.sd-divider::before,
.sd-divider::after { content: ''; flex: 1; height: 1px; background: linear-gradient(to right, transparent, rgba(184,120,0,.35)); }
.sd-divider::after { background: linear-gradient(to left, transparent, rgba(184,120,0,.35)); }
.sd-divider span   { color: var(--sd-gold); font-size: .75rem; opacity: .75; flex-shrink: 0; }

/* 説明文カード */
.sd-desc-card {
  width: 100%;
  background: var(--sd-bg-card);
  border: 1px solid var(--sd-border);
  border-left: 3px solid var(--sd-gold);
  padding: 1.6rem 1.8rem !important;
  margin-bottom: 1.4rem;
  animation: sd-slideUp .8s ease both;
  animation-delay: .45s;
  box-shadow: 0 2px 8px rgba(100,70,20,0.06);
}
.sd-desc-text {
  font-size: 1rem;
  line-height: 2.1;
  color: var(--sd-ink-mid);
}

/* 特徴リスト */
.sd-traits-card {
  width: 100%;
  background: var(--sd-bg-card-alt);
  border: 1px solid var(--sd-border);
  padding: 1.4rem 1.8rem !important;
  margin-bottom: 1.4rem;
  animation: sd-slideUp .8s ease both;
  animation-delay: .5s;
  box-shadow: 0 2px 8px rgba(100,70,20,0.05);
}
.sd-traits-title {
  letter-spacing: .25em;
  color: var(--sd-gold);
  opacity: .9;
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  gap: .6rem;
}
.sd-traits-title::after { content: ''; flex: 1; height: 1px; background: rgba(184,120,0,.2); }
.sd-trait-item {
  display: flex;
  align-items: flex-start;
  gap: .7rem;
  padding: .5rem 0;
  border-bottom: 1px solid rgba(184,120,0,.1);
}
.sd-trait-item:last-child { border-bottom: none; }
.sd-trait-icon {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  margin-top: .4rem;
  border: 1px solid var(--sd-border-strong);
  transform: rotate(45deg);
  display: flex;
  align-items: center;
  justify-content: center;
}
.sd-trait-icon::after {
  content: '';
  width: 6px;
  height: 6px;
  background: var(--sd-gold);
  opacity: .7;
}
.sd-trait-text {
  font-size: 1rem !important;
  font-weight: 600;
  line-height: 1.7;
  color: var(--sd-ink-mid);
}

/* スコアバー */
.sd-scores-card {
  width: 100%;
  background: var(--sd-bg-card-alt);
  border: 1px solid var(--sd-border);
  padding: 1.4rem 1.8rem !important;
  margin-bottom: 1.8rem;
  animation: sd-slideUp .8s ease both;
  animation-delay: .55s;
  box-shadow: 0 2px 8px rgba(100,70,20,0.05);
}
.sd-scores-title {
  font-size: .72rem;
  letter-spacing: .25em;
  color: var(--sd-gold);
  opacity: .9;
  margin-bottom: 1.1rem;
  display: flex;
  align-items: center;
  gap: .6rem;
}
.sd-scores-title::after { content: ''; flex: 1; height: 1px; background: rgba(184,120,0,.2); }
.sd-score-row {
  display: flex;
  align-items: center;
  gap: .8rem;
  margin-bottom: .8rem;
}
.sd-score-row:last-child { margin-bottom: 0; }
.sd-score-label-l,
.sd-score-label-r {
  font-size: .72rem;
  color: var(--sd-ink-light);
  width: 2.8rem;
  flex-shrink: 0;
}
.sd-score-label-r { text-align: right; }
.sd-score-track {
  flex: 1;
  height: 6px;
  background: rgba(0,0,0,0.08);
  position: relative;
}
.sd-score-bar {
  height: 100%;
  background: var(--sd-gold);
  transition: width 1s ease;
}
.sd-score-dot {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 10px;
  height: 10px;
  background: var(--sd-gold);
  border-radius: 50%;
  transition: left 1s ease;
  margin-left: -5px;
}

/* アクションボタン */
.sd-actions {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .9rem;
  margin-bottom: 2rem;
  animation: sd-slideUp .8s ease both;
  animation-delay: .6s;
}

/* SNS シェアボタン群 */
.sd-share-label {
  font-size: 1rem;
  letter-spacing: .2em;
  color: var(--sd-gold);
  opacity: .85;
  margin-bottom: .6rem;
  text-align: center;
  width: 100%;
  max-width: 360px;
}
.sd-share-btns {
  display: flex;
  gap: .5rem;
  flex-wrap: wrap;
  justify-content: center;
  width: 100%;
  max-width: 360px;
}
.sd-share-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: .65rem 1rem;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: .8rem;
  font-weight: 700;
  text-decoration: none !important;
  color: #fff !important;
  border: none;
  cursor: pointer;
  transition: opacity .2s, transform .15s;
  flex: 1 1 calc(50% - .25rem);
  justify-content: center;
  min-width: 0;
}
.sd-share-btn:hover  { opacity: .8; transform: translateY(-1px); color: #fff !important; }
.sd-share-btn:active { transform: translateY(0); }
.sd-share-btn--x        { background: #000; }
.sd-share-btn--facebook { background: #1877f2; }
.sd-share-btn--line     { background: #06c755; }
.sd-share-btn--hatena   { background: #00a4de; }
.sd-share-btn__icon { display: flex; align-items: center; flex-shrink: 0; }
.sd-share-btn__hatena-icon { font-size: .9rem; font-weight: 900; }

/* 再診断ボタン */
.sd-btn-retry {
  max-width: 360px;
  width: 100%;
  padding: .85rem 1.5rem;
  font-family: 'Noto Serif JP', serif;
  font-size: .9rem;
  font-weight: 700;
  letter-spacing: .15em;
  cursor: pointer;
  text-align: center;
  background: transparent;
  color: var(--sd-ink-light) !important;
  border: 1px solid var(--sd-border-strong);
  text-decoration: none !important;
  transition: border-color .2s, color .2s, background .2s;
  display: block;
}
.sd-btn-retry:hover {
  border-color: var(--sd-gold);
  color: var(--sd-ink) !important;
  background: rgba(255,255,255,0.6);
}

/* 関連記事リンク */
.sd-article-link {
  width: 100%;
  background: var(--sd-bg-card-alt);
  border: 1px solid var(--sd-border);
  border-top: 2px solid var(--sd-gold);
  padding: 1.2rem 1.6rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  text-decoration: none !important;
  transition: background .2s, border-color .2s;
  animation: sd-slideUp .8s ease both;
  animation-delay: .65s;
  box-shadow: 0 2px 8px rgba(100,70,20,0.06);
}
.sd-article-link:hover { background: rgba(255,255,255,0.95); border-color: var(--sd-border-strong); }
.sd-article-link-label {
  font-size: .65rem;
  letter-spacing: .2em;
  color: var(--sd-gold);
  opacity: .8;
  margin-bottom: .3rem;
}
.sd-article-link-title {
  font-family: 'Noto Serif JP', serif;
  font-size: .9rem;
  font-weight: 700;
  color: var(--sd-ink);
}
.sd-article-link-arr {
  color: var(--sd-gold);
  font-size: 1.1rem;
  flex-shrink: 0;
  transition: transform .2s;
}
.sd-article-link:hover .sd-article-link-arr { transform: translateX(4px); }

/* フッター装飾（result） */
.sd-footer-deco-result {
  margin-top: 3rem;
  display: flex;
  align-items: center;
  gap: .8rem;
  opacity: .22;
}
.sd-footer-deco-result::before,
.sd-footer-deco-result::after { content: ''; flex: 1; height: 1px; background: var(--sd-gold); }
.sd-footer-deco-result span { font-size: .6rem; letter-spacing: .3em; color: var(--sd-gold); }

/* ════════════════════════════════════════════════════════════
   武将パレード（START 画面）
   ════════════════════════════════════════════════════════════ */

/* コンテナ（.sd-wrap の幅制約を破る） */
.sd-parade-wrap {
  width: 100%;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
  overflow: hidden;
  margin: 1.8rem 0 0;
  padding: .6rem 0;
  -webkit-mask-image: linear-gradient(to right, transparent 0%, black 8%, black 92%, transparent 100%);
          mask-image: linear-gradient(to right, transparent 0%, black 8%, black 92%, transparent 100%);
}

/* スクロールトラック */
.sd-parade-track {
  --item-w: 96px;
  --item-gap: 12px;
  display: flex;
  gap: var(--item-gap);
  width: max-content;
  /* --sd-parade-count はインラインで 6000 を指定 → ゆっくりスクロール */
  animation: sd-parade calc( var(--sd-parade-count, 6000) * 0.028s ) linear infinite;
  will-change: transform;
}

.sd-parade-wrap:hover .sd-parade-track { animation-play-state: paused; }

@keyframes sd-parade {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* 個別カード（画像のみ） */
.sd-parade-card {
  width: 116px;
  height: 116px;
  flex-shrink: 0;
  overflow: hidden;
  border: 1px solid var(--sd-border);
  border-top: 2px solid var(--sd-gold);
  box-shadow: 0 2px 6px rgba(100,70,20,0.08);
  background: rgba(200,180,140,0.2);
  transition: box-shadow .2s, transform .2s;
}
.sd-parade-card:hover {
  box-shadow: 0 4px 14px rgba(100,70,20,0.18);
  transform: translateY(-2px);
}
.sd-parade-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  display: block;
}

/* ════════════════════════════════════════════════════════════
   キーワードカード（RESULT 画面）
   ════════════════════════════════════════════════════════════ */
.sd-keywords-card {
  width: 100%;
  background: var(--sd-bg-card-alt);
  border: 1px solid var(--sd-border);
  padding: 1.2rem 1.8rem !important;
  margin-bottom: 1.4rem;
  animation: sd-slideUp .8s ease both;
  animation-delay: .51s;
  box-shadow: 0 2px 8px rgba(100,70,20,0.05);
}
.sd-keywords-title {
  letter-spacing: .25em;
  color: var(--sd-gold);
  opacity: .9;
  margin-bottom: .9rem;
  display: flex;
  align-items: center;
  gap: .6rem;
}
.sd-keywords-title::after { content: ''; flex: 1; height: 1px; background: rgba(184,120,0,.2); }
.sd-keywords-list {
  display: flex;
  gap: .7rem;
  flex-wrap: wrap;
  justify-content: center;
}
.sd-keyword {
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: .12em;
  color: var(--sd-ink-mid);
  background: rgba(255,255,255,0.85);
  border: 1px solid var(--sd-border-strong);
  border-bottom: 2px solid var(--sd-gold);
  padding: .45em 1.1em!important;
  white-space: nowrap;
}

/* ════════════════════════════════════════════════════════════
   MBTI 解説カード（RESULT 画面）
   ════════════════════════════════════════════════════════════ */
.sd-mbti-card {
  width: 100%;
  background: var(--sd-bg-card);
  border: 1px solid var(--sd-border);
  border-left: 3px solid var(--sd-crimson);
  padding: 1.4rem 1.8rem !important;
  margin-bottom: 1.4rem;
  animation: sd-slideUp .8s ease both;
  animation-delay: .52s;
  box-shadow: 0 2px 8px rgba(100,70,20,0.06);
}
.sd-mbti-card__title {
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: .12em;
  color: var(--sd-ink);
  margin-bottom: .9rem;
  padding-bottom: .6rem;
  border-bottom: 1px solid rgba(184,120,0,.15);
  display: flex;
  align-items: center;
  gap: .5rem;
}
.sd-mbti-card__title::before {
  content: '';
  width: 4px;
  height: 1.1em;
  background: var(--sd-crimson);
  flex-shrink: 0;
  border-radius: 2px;
}
.sd-mbti-card__text {
  line-height: 2.0;
  color: var(--sd-ink-mid);
}
.sd-mbti-card__text + .sd-mbti-card__text {
  margin-top: .8rem;
}

/* ════════════════════════════════════════════════════════════
   レスポンシブ
   ════════════════════════════════════════════════════════════ */
@media (max-width: 480px) {
  .sd-wrap { padding: 2rem 1.2rem 3rem; }
  .sd-prologue-card { padding: 1.5rem 1.2rem; }
  .sd-prologue-text { font-size: .85rem; line-height: 2; }
  .sd-scene-card { padding: 1.4rem 1.2rem; }
  .sd-btn-next { padding: .75rem 1.4rem; font-size: .82rem; }
  .sd-warrior-img-frame { width: 160px; height: 192px; }
  .sd-share-btn { flex: 1 1 calc(50% - .25rem); }
}
