/* マイページ - 扶養診断タブ専用CSS */

/* 2カラムレイアウト（PC幅） */
#mypage-tab-fuyo-check .mypage-content-grid {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 24px;
  align-items: start;
}

/* 右カラムのカード縦積み */
#mypage-tab-fuyo-check .settings-section {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* アコーディオンラッパー */
#mypage-tab-fuyo-check .fuyo-detail-accordion-wrapper {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* カード間の余白統一 */
#mypage-tab-fuyo-check .card {
  margin-top: 0;
}

/* hidden制御 */
#mypage-tab-fuyo-check .is-hidden {
  display: none !important;
}

/* disabled状態 */
#mypage-tab-fuyo-check .fuyo-step.is-disabled {
  opacity: 0.55;
  pointer-events: none;
}

#mypage-tab-fuyo-check .fuyo-step.is-disabled .pill-row {
  pointer-events: none;
}

#mypage-tab-fuyo-check .fuyo-step-disabled-note {
  font-size: var(--fs-12);
  color: var(--text-sub);
  margin-top: 8px;
  font-style: italic;
}

/* マイページ内の扶養診断パネルにスコープ */
#mypage-tab-fuyo-check .fuyo-step {
  margin-bottom: 24px;
}

#mypage-tab-fuyo-check .fuyo-step:last-child {
  margin-bottom: 0;
}

#mypage-tab-fuyo-check .fuyo-step-title {
  font-size: var(--fs-15);
  font-weight: 600;
  color: var(--text-main);
  margin-bottom: 12px;
  line-height: 1.5;
}

/* pill-rowとpillはbase.cssで定義されているので、必要に応じて上書き */
#mypage-tab-fuyo-check .pill-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 8px;
}

#mypage-tab-fuyo-check .pill {
  transition: all 0.2s ease;
}

#mypage-tab-fuyo-check .pill:hover {
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(140, 160, 190, 0.2);
}

#mypage-tab-fuyo-check .pill.active {
  background: linear-gradient(135deg, rgba(94, 200, 216, 0.15), rgba(143, 140, 243, 0.12));
  border-color: rgba(94, 200, 216, 0.4);
  color: var(--text-main);
  font-weight: 600;
  box-shadow: 0 2px 8px rgba(94, 200, 216, 0.25);
}

/* 結果表示エリア */
#mypage-tab-fuyo-check .fuyo-result-content {
  margin-top: 12px;
}

#mypage-tab-fuyo-check .fuyo-result-text {
  font-size: var(--fs-14);
  color: var(--text-main);
  line-height: 1.6;
}

/* まとめカード */
#mypage-tab-fuyo-check .fuyo-summary-content {
  font-size: var(--fs-14);
  color: var(--text-main);
  line-height: 1.6;
  margin-top: 12px;
}

/* ===== 立ち位置カード（見やすさだけ付与） ===== */
#mypage-tab-fuyo-check .fuyo-card__head {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

#mypage-tab-fuyo-check .fuyo-card__title {
  font-size: var(--fs-16);
  font-weight: 600;
  color: var(--text-main);
  margin: 0;
}

#mypage-tab-fuyo-check .fuyo-card__sub {
  font-size: 12.5px;
  opacity: 0.75;
  margin: 0;
  color: var(--text-sub);
}

#mypage-tab-fuyo-check .fuyo-card__note {
  margin-top: 16px;
  padding-top: 12px;
  border-top: 1px solid rgba(226, 232, 240, 0.6);
}

#mypage-tab-fuyo-check .fuyo-card__note p {
  font-size: 11.5px;
  color: var(--text-sub);
  line-height: 1.5;
  margin: 0;
}

#mypage-tab-fuyo-check .fuyo-position {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-top: 16px;
}

#mypage-tab-fuyo-check .fuyo-position__section {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

#mypage-tab-fuyo-check .fuyo-position__label {
  font-weight: 700;
  font-size: 12.5px;
  opacity: 0.8;
  color: var(--text-main);
}

/* チップ（参考イメージとして控えめに表示） */
#mypage-tab-fuyo-check .fuyo-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

#mypage-tab-fuyo-check .fuyo-chip {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px;
  border-radius: 6px;
  font-size: 12px;
  border: none;
  background: rgba(245, 248, 255, 0.6);
  color: var(--text-sub);
  font-weight: 500;
  line-height: 1.4;
  transition: none;
  cursor: default;
  pointer-events: none;
}

/* 箇条書き */
#mypage-tab-fuyo-check .fuyo-bullets {
  margin: 0;
  padding-left: 18px;
  list-style-type: disc;
}

#mypage-tab-fuyo-check .fuyo-bullets li {
  margin: 6px 0;
  font-size: var(--fs-13);
  color: var(--text-main);
  line-height: 1.6;
}

/* ===== バッジ（safe/border/out 薄い背景） ===== */
#mypage-tab-fuyo-check .fuyo-position__badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 12px;
  font-weight: 800;
  font-size: var(--fs-14);
  line-height: 1.35;
  border: 1px solid rgba(120, 140, 160, 0.28);
}

/* Keipyトンマナに合わせた色（ミント/ラベンダー/コーラル） */
#mypage-tab-fuyo-check .fuyo-position__badge.is-safe {
  background: rgba(94, 200, 216, 0.12);
  border-color: rgba(94, 200, 216, 0.22);
  color: rgba(94, 200, 216, 0.95);
}

#mypage-tab-fuyo-check .fuyo-position__badge.is-border {
  background: rgba(255, 201, 214, 0.14);
  border-color: rgba(255, 201, 214, 0.24);
  color: rgba(180, 96, 120, 0.95);
}

#mypage-tab-fuyo-check .fuyo-position__badge.is-out {
  background: rgba(143, 140, 243, 0.12);
  border-color: rgba(143, 140, 243, 0.22);
  color: rgba(143, 140, 243, 0.95);
}

/* ダーク背景等で浮きすぎる場合に備えて、過度な主張はしない（影は付けない） */

#mypage-tab-fuyo-check .fuyo-disclaimer-text {
  font-size: var(--fs-12);
  color: var(--text-sub);
  line-height: 1.6;
  text-align: center;
}

#mypage-tab-fuyo-check .fuyo-next-action-text {
  font-size: var(--fs-14);
  color: var(--text-main);
  line-height: 1.6;
  margin-bottom: 12px;
}

/* 扶養ライン説明 */
#mypage-tab-fuyo-check .fuyo-line-item {
  margin-top: 16px;
  padding: 14px 16px;
  background: rgba(245, 248, 255, 0.6);
  border-radius: 10px;
  border-left: 3px solid rgba(94, 200, 216, 0.3);
}

#mypage-tab-fuyo-check .fuyo-line-item:first-child {
  margin-top: 0;
}

#mypage-tab-fuyo-check .fuyo-line-title {
  font-size: var(--fs-15);
  font-weight: 600;
  color: var(--text-main);
  margin-bottom: 8px;
}

#mypage-tab-fuyo-check .fuyo-line-subtitle {
  font-size: var(--fs-13);
  color: var(--text-sub);
  margin-bottom: 10px;
}

#mypage-tab-fuyo-check .fuyo-line-description {
  font-size: var(--fs-13);
  color: var(--text-main);
  line-height: 1.6;
}

/* 次の行動ボタン */
#mypage-tab-fuyo-check .btn-primary {
  width: 100%;
  padding: 0.75rem 1.5rem;
  background: linear-gradient(135deg, rgba(94, 200, 216, 0.15), rgba(143, 140, 243, 0.12));
  border: 1px solid rgba(94, 200, 216, 0.3);
  border-radius: 8px;
  color: rgba(94, 200, 216, 0.9);
  font-size: var(--fs-14);
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  font-family: inherit;
}

#mypage-tab-fuyo-check .btn-primary:hover {
  background: linear-gradient(135deg, rgba(94, 200, 216, 0.2), rgba(143, 140, 243, 0.15));
  border-color: rgba(94, 200, 216, 0.4);
  box-shadow: 0 2px 8px rgba(94, 200, 216, 0.25);
  transform: translateY(-1px);
}

#mypage-tab-fuyo-check .btn-primary:active {
  transform: translateY(0);
}

/* Pro版：2つの道の地図 */
#mypage-tab-fuyo-check .fuyo-pro-map-section {
  margin-top: 40px;
}

#mypage-tab-fuyo-check .fuyo-pro-map-section.is-hidden {
  display: none !important;
}

#mypage-tab-fuyo-check .fuyo-comparison-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

#mypage-tab-fuyo-check .fuyo-path-content {
  font-size: var(--fs-14);
  color: var(--text-main);
  line-height: 1.8;
}

#mypage-tab-fuyo-check .fuyo-path-status {
  padding: 12px 14px;
  background: rgba(245, 248, 255, 0.6);
  border-radius: 8px;
  border-left: 3px solid rgba(94, 200, 216, 0.3);
  margin-top: 16px;
}

#mypage-tab-fuyo-check .fuyo-path-status-text {
  font-size: var(--fs-13);
  color: var(--text-main);
  line-height: 1.6;
}

#mypage-tab-fuyo-check .fuyo-path-cost {
  padding: 12px 14px;
  background: rgba(245, 248, 255, 0.6);
  border-radius: 8px;
  border-left: 3px solid rgba(94, 200, 216, 0.3);
  margin-top: 16px;
}

#mypage-tab-fuyo-check .fuyo-important-note {
  font-size: var(--fs-14);
  color: var(--text-main);
  line-height: 1.6;
}

#mypage-tab-fuyo-check .fuyo-decision-axis {
  font-size: var(--fs-14);
  color: var(--text-main);
  line-height: 1.8;
}

#mypage-tab-fuyo-check .fuyo-keipy-message {
  font-size: var(--fs-14);
  color: var(--text-main);
  line-height: 1.6;
  text-align: center;
}

/* アコーディオン（details/summary） - 軽い見た目＋グラデーション */
#mypage-tab-fuyo-check .fuyo-detail-accordion-item {
  border: 1px solid rgba(226, 232, 240, 0.6);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.5);
  overflow: hidden;
  position: relative;
  transition: all 0.2s ease;
}

/* 開いた時に左端にグラデーションを追加 */
#mypage-tab-fuyo-check .fuyo-detail-accordion-item::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 4px;
  background: linear-gradient(180deg, 
    rgba(94, 200, 216, 0.5) 0%,
    rgba(143, 140, 243, 0.5) 100%);
  opacity: 0;
  transition: opacity 0.2s ease;
  z-index: 1;
}

/* 開いた時のスタイル（details[open]で判定） */
#mypage-tab-fuyo-check .fuyo-detail-accordion-item:has(.fuyo-detail-accordion[open])::before,
#mypage-tab-fuyo-check .fuyo-detail-accordion-item.is-open::before {
  opacity: 1;
}

#mypage-tab-fuyo-check .fuyo-detail-accordion-item:has(.fuyo-detail-accordion[open]),
#mypage-tab-fuyo-check .fuyo-detail-accordion-item.is-open {
  background: linear-gradient(to right,
    rgba(94, 200, 216, 0.1) 0%,
    rgba(94, 200, 216, 0.05) 4px,
    rgba(255, 255, 255, 0.7) 4px);
  border-color: rgba(94, 200, 216, 0.35);
  box-shadow: 0 2px 10px rgba(94, 200, 216, 0.15);
}

#mypage-tab-fuyo-check .fuyo-detail-accordion {
  display: block;
  margin: 0;
  padding: 0;
  position: relative;
}

#mypage-tab-fuyo-check .fuyo-detail-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  list-style: none;
  font-size: var(--fs-14);
  font-weight: 600;
  color: var(--text-main);
  padding: 10px 12px;
  transition: background-color 0.2s ease, color 0.2s ease;
  user-select: none;
  gap: 8px;
  position: relative;
  z-index: 2;
}

#mypage-tab-fuyo-check .fuyo-detail-summary::-webkit-details-marker {
  display: none;
}

#mypage-tab-fuyo-check .fuyo-detail-summary::marker {
  display: none;
}

#mypage-tab-fuyo-check .fuyo-detail-summary-title {
  flex: 1;
}

#mypage-tab-fuyo-check .fuyo-detail-summary-tag {
  font-size: var(--fs-12);
  font-weight: 500;
  color: var(--text-sub);
  padding: 3px 8px;
  background: rgba(245, 248, 255, 0.6);
  border-radius: 4px;
  white-space: nowrap;
  transition: background-color 0.2s ease;
}

/* 開いた時のタグの色も変える */
#mypage-tab-fuyo-check .fuyo-detail-accordion[open] .fuyo-detail-summary-tag {
  background: linear-gradient(135deg, rgba(94, 200, 216, 0.15), rgba(143, 140, 243, 0.12));
  color: var(--text-main);
}

#mypage-tab-fuyo-check .fuyo-detail-summary::after {
  content: "▼";
  font-size: var(--fs-11);
  color: var(--text-sub);
  transition: transform 0.2s ease, color 0.2s ease;
  flex-shrink: 0;
  margin-left: 4px;
}

#mypage-tab-fuyo-check .fuyo-detail-accordion[open] .fuyo-detail-summary::after {
  transform: rotate(180deg);
  color: var(--mint);
}

#mypage-tab-fuyo-check .fuyo-detail-summary:hover {
  background: rgba(245, 248, 255, 0.4);
}

/* 開いた時のsummaryも強調 */
#mypage-tab-fuyo-check .fuyo-detail-accordion[open] .fuyo-detail-summary {
  background: rgba(94, 200, 216, 0.05);
  color: var(--text-main);
}

#mypage-tab-fuyo-check .fuyo-detail-content {
  padding: 12px;
  padding-top: 12px;
  border-top: 1px solid rgba(226, 232, 240, 0.4);
  background: transparent;
  position: relative;
  z-index: 2;
}

#mypage-tab-fuyo-check .fuyo-detail-section {
  margin-bottom: 12px;
}

#mypage-tab-fuyo-check .fuyo-detail-section:last-child {
  margin-bottom: 0;
}

#mypage-tab-fuyo-check .fuyo-detail-section-title {
  font-size: var(--fs-13);
  font-weight: 600;
  color: var(--text-main);
  margin-bottom: 6px;
}

#mypage-tab-fuyo-check .fuyo-detail-section-text {
  font-size: var(--fs-13);
  color: var(--text-main);
  line-height: 1.6;
  margin: 0;
}

#mypage-tab-fuyo-check .fuyo-detail-section-list {
  margin: 0;
  padding-left: 18px;
  list-style-type: disc;
  font-size: var(--fs-13);
  color: var(--text-main);
  line-height: 1.6;
}

#mypage-tab-fuyo-check .fuyo-detail-section-list li {
  margin: 4px 0;
}

/* 補足テキスト */
#mypage-tab-fuyo-check .fuyo-detail-note {
  margin-top: 4px;
  padding: 8px 12px;
  background: rgba(245, 248, 255, 0.3);
  border-radius: 6px;
  border: 1px solid rgba(226, 232, 240, 0.4);
}

/* Q&Aセクション（右カラム） */
#mypage-tab-fuyo-check .fuyo-qa-wrapper {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 12px;
}

#mypage-tab-fuyo-check .fuyo-qa-item {
  border: none;
  border-radius: 8px;
  background: transparent;
  overflow: hidden;
  position: relative;
  transition: all 0.2s ease;
  margin-bottom: 8px;
}

#mypage-tab-fuyo-check .fuyo-qa-accordion {
  display: block;
  margin: 0;
  padding: 0;
  position: relative;
}

#mypage-tab-fuyo-check .fuyo-qa-summary {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  cursor: pointer;
  list-style: none;
  font-size: var(--fs-14);
  font-weight: 600;
  color: #ffffff;
  padding: 12px 16px;
  background: linear-gradient(135deg, 
    rgba(94, 200, 216, 0.85) 0%,
    rgba(143, 140, 243, 0.85) 100%);
  border-radius: 8px;
  transition: all 0.2s ease;
  user-select: none;
  gap: 12px;
  position: relative;
  z-index: 2;
  line-height: 1.5;
  box-shadow: 0 2px 8px rgba(94, 200, 216, 0.2);
}

/* summary内のコンテンツラッパー */
#mypage-tab-fuyo-check .fuyo-qa-summary-content {
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
  min-width: 0;
}

#mypage-tab-fuyo-check .fuyo-qa-summary:hover {
  background: linear-gradient(135deg, 
    rgba(94, 200, 216, 0.95) 0%,
    rgba(143, 140, 243, 0.95) 100%);
  box-shadow: 0 4px 12px rgba(94, 200, 216, 0.3);
  transform: translateY(-1px);
}

#mypage-tab-fuyo-check .fuyo-qa-summary::-webkit-details-marker {
  display: none;
}

#mypage-tab-fuyo-check .fuyo-qa-summary::marker {
  display: none;
}

/* Qアイコン */
#mypage-tab-fuyo-check .fuyo-qa-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.25);
  color: #ffffff;
  font-size: var(--fs-14);
  font-weight: 700;
  flex-shrink: 0;
  border: 2px solid rgba(255, 255, 255, 0.4);
}

#mypage-tab-fuyo-check .fuyo-qa-summary-text {
  color: #ffffff;
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
  line-height: 1.5;
}

#mypage-tab-fuyo-check .fuyo-qa-summary-tag {
  font-size: var(--fs-12);
  font-weight: 500;
  color: #ffffff;
  padding: 4px 10px;
  background: rgba(255, 255, 255, 0.25);
  border-radius: 12px;
  white-space: nowrap;
  transition: background-color 0.2s ease;
  align-self: flex-start;
  border: 1px solid rgba(255, 255, 255, 0.3);
}

#mypage-tab-fuyo-check .fuyo-qa-accordion[open] .fuyo-qa-summary-tag {
  background: rgba(255, 255, 255, 0.35);
}

/* 開閉アイコン（+と-） */
#mypage-tab-fuyo-check .fuyo-qa-summary::after {
  content: "+";
  font-size: var(--fs-18);
  font-weight: 300;
  color: #ffffff;
  transition: transform 0.2s ease, content 0.2s ease;
  flex-shrink: 0;
  margin-left: 8px;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

#mypage-tab-fuyo-check .fuyo-qa-accordion[open] .fuyo-qa-summary::after {
  content: "−";
  transform: none;
}

#mypage-tab-fuyo-check .fuyo-qa-content {
  padding: 16px;
  padding-left: 48px;
  margin-top: 8px;
  border-radius: 8px;
  background: rgba(245, 248, 255, 0.6);
  position: relative;
  z-index: 2;
  border: 1px solid rgba(226, 232, 240, 0.4);
}

/* Aアイコン */
#mypage-tab-fuyo-check .fuyo-qa-answer-icon {
  position: absolute;
  left: 16px;
  top: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: rgba(94, 200, 216, 0.2);
  color: rgba(94, 200, 216, 0.9);
  font-size: var(--fs-14);
  font-weight: 700;
  border: 2px solid rgba(94, 200, 216, 0.3);
}

#mypage-tab-fuyo-check .fuyo-qa-section {
  margin-bottom: 14px;
}

#mypage-tab-fuyo-check .fuyo-qa-section:last-child {
  margin-bottom: 0;
}

#mypage-tab-fuyo-check .fuyo-qa-section-title {
  font-size: var(--fs-14);
  font-weight: 600;
  color: var(--text-main);
  margin-bottom: 8px;
}

#mypage-tab-fuyo-check .fuyo-qa-section-text {
  font-size: var(--fs-13);
  color: var(--text-main);
  line-height: 1.6;
  margin: 0;
}

#mypage-tab-fuyo-check .fuyo-qa-section-list {
  margin: 0;
  padding-left: 18px;
  list-style-type: disc;
  font-size: var(--fs-13);
  color: var(--text-main);
  line-height: 1.6;
}

#mypage-tab-fuyo-check .fuyo-qa-section-list li {
  margin: 4px 0;
}

/* 補足テキスト */
#mypage-tab-fuyo-check .fuyo-qa-note {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid rgba(226, 232, 240, 0.4);
}

#mypage-tab-fuyo-check .fuyo-qa-note-text {
  font-size: var(--fs-12);
  color: var(--text-sub);
  line-height: 1.6;
  margin: 0;
}

/* ミニサマリー（右カラム） */
#mypage-tab-fuyo-check .fuyo-mini-summary-badge {
  font-size: var(--fs-14);
  font-weight: 600;
  color: var(--text-main);
  margin-bottom: 8px;
  padding: 8px 12px;
  border-radius: 8px;
  border: 1px solid rgba(120, 140, 160, 0.28);
}

#mypage-tab-fuyo-check .fuyo-mini-summary-badge.is-safe {
  background: rgba(94, 200, 216, 0.12);
  border-color: rgba(94, 200, 216, 0.22);
  color: rgba(94, 200, 216, 0.95);
}

#mypage-tab-fuyo-check .fuyo-mini-summary-badge.is-border {
  background: rgba(255, 201, 214, 0.14);
  border-color: rgba(255, 201, 214, 0.24);
  color: rgba(180, 96, 120, 0.95);
}

#mypage-tab-fuyo-check .fuyo-mini-summary-badge.is-out {
  background: rgba(143, 140, 243, 0.12);
  border-color: rgba(143, 140, 243, 0.22);
  color: rgba(143, 140, 243, 0.95);
}

#mypage-tab-fuyo-check .fuyo-mini-summary-text {
  font-size: var(--fs-13);
  color: var(--text-sub);
  line-height: 1.5;
  margin: 0;
}

/* レスポンシブ */
@media (max-width: 1024px) {
  #mypage-tab-fuyo-check .mypage-content-grid {
    grid-template-columns: 1fr;
  }

  #mypage-tab-fuyo-check .fuyo-comparison-grid {
    grid-template-columns: 1fr;
  }

  /* モバイルでは右カラムのstickyを解除 */
  #mypage-tab-fuyo-check #fuyo-mini-summary-card {
    position: static;
  }
}

