/* ===================================================================
   sim-hikaku.online — Renewal 2026 (5-Pillar UI/UX Components)
   競合10社分析（2026-04-22）の統合ベストプラクティス
   ===================================================================
   Pillar 1: 30-second Diagnostic Wizard (モバレコ + モバイルDASH融合)
   Pillar 2: Quality × Price 2-axis Scatter (ショーケース独自)
   Pillar 3: 5-axis Radar Chart (All-Connect / LiPro)
   Pillar 4: 3-tier Multi-table (LiPro選抜→全社→条件別)
   Pillar 5: Accordion (LiPro折りたたみ)
   Plus: Campaign Badge, PR明示, Large CTA, Update Log
   =================================================================== */

/* --- Noto Sans JP import --- */
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;600;700;800&display=swap');

/* --- Token Overrides (Orange → Blue+Green) --- */
:root {
  --sim-blue:           #0066CC;
  --sim-blue-hover:     #0052A3;
  --sim-blue-soft:      #e8f0fe;
  --sim-green:          #34C759;
  --sim-green-hover:    #2db84d;
  --sim-green-soft:     #e8f7ed;
  --sim-amber:          #FF9500;
  --sim-red:            #FF3B30;
  --sim-ink:            #1d1d1f;
  --sim-ink-2:          #3a3a3c;
  --sim-ink-3:          #6e6e73;
  --sim-ink-4:          #86868b;
  --sim-rule:           #d2d2d7;
  --sim-rule-soft:      #e5e5ea;
  --sim-bg:             #f5f5f7;
  --sim-bg-2:           #fafafc;
  --sim-card:           #ffffff;
  --sim-font-jp:        'Noto Sans JP', -apple-system, BlinkMacSystemFont, 'Hiragino Kaku Gothic ProN', 'Hiragino Sans', Meiryo, sans-serif;
  --sim-r-sm:           8px;
  --sim-r-md:           12px;
  --sim-r-lg:           16px;
  --sim-r-xl:           24px;
  --sim-shadow-sm:      0 1px 3px rgba(0,0,0,0.06);
  --sim-shadow:         0 2px 12px rgba(0,0,0,0.08);
  --sim-shadow-lg:      0 12px 40px rgba(0,0,0,0.18);
}

body {
  font-family: var(--sim-font-jp) !important;
}

/* ============================================
   PR / 編集部独立ランキング Label (透明性)
   ============================================ */
.sim-pr-label {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: #fff;
  background: var(--sim-ink-3);
  padding: 2px 8px;
  border-radius: 4px;
  vertical-align: middle;
  margin-right: 6px;
  text-transform: uppercase;
}
.sim-pr-label--edit {
  background: var(--sim-blue);
}

/* ============================================
   Campaign Badge (価格.com / モバイルDASH 方式)
   ============================================ */
.sim-campaign-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 700;
  color: #fff;
  background: linear-gradient(135deg, var(--sim-red) 0%, #ff6b60 100%);
  padding: 4px 10px;
  border-radius: 6px;
  box-shadow: 0 1px 4px rgba(255,59,48,0.3);
  letter-spacing: 0.01em;
}
.sim-campaign-badge::before {
  content: "🔥";
  font-size: 11px;
}
.sim-campaign-badge--limit {
  background: linear-gradient(135deg, var(--sim-amber) 0%, #ffb13d 100%);
  box-shadow: 0 1px 4px rgba(255,149,0,0.3);
}
.sim-campaign-badge--limit::before {
  content: "⏰";
}
.sim-campaign-badge--new {
  background: linear-gradient(135deg, var(--sim-green) 0%, #5ad77a 100%);
  box-shadow: 0 1px 4px rgba(52,199,89,0.3);
}
.sim-campaign-badge--new::before {
  content: "✨";
}

/* ============================================
   Large CTA Button (テキストリンク撲滅)
   ============================================ */
.sim-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 16px 32px;
  border-radius: 980px;
  font-family: var(--sim-font-jp);
  font-size: 16px;
  font-weight: 700;
  text-decoration: none !important;
  letter-spacing: 0.02em;
  transition: all 0.3s ease;
  cursor: pointer;
  border: none;
  white-space: nowrap;
  line-height: 1;
}
.sim-btn--primary {
  background: var(--sim-blue) !important;
  color: #fff !important;
  box-shadow: 0 4px 12px rgba(0,102,204,0.25);
}
.sim-btn--primary:hover {
  background: var(--sim-blue-hover) !important;
  color: #fff !important;
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(0,102,204,0.35);
}
.sim-btn--cv {
  background: linear-gradient(135deg, var(--sim-green) 0%, #5ad77a 100%) !important;
  color: #fff !important;
  box-shadow: 0 4px 14px rgba(52,199,89,0.35);
  padding: 18px 36px;
  font-size: 17px;
}
.sim-btn--cv:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 22px rgba(52,199,89,0.45);
  color: #fff !important;
}
.sim-btn--outline {
  background: transparent !important;
  color: var(--sim-blue) !important;
  border: 2px solid var(--sim-blue);
}
.sim-btn--outline:hover {
  background: var(--sim-blue) !important;
  color: #fff !important;
}
.sim-btn--block {
  width: 100%;
}
.sim-btn__sub {
  display: block;
  font-size: 11px;
  font-weight: 500;
  opacity: 0.85;
  margin-top: 2px;
  letter-spacing: 0.05em;
}

/* ============================================
   Pillar 1: Diagnostic Wizard (30秒診断)
   ============================================ */
.sim-wizard-trigger {
  display: block;
  background: linear-gradient(135deg, var(--sim-blue) 0%, #4a9eff 100%);
  color: #fff;
  border-radius: var(--sim-r-xl);
  padding: 40px 32px;
  text-align: center;
  text-decoration: none !important;
  box-shadow: 0 12px 30px rgba(0,102,204,0.25);
  transition: transform 0.3s ease;
  max-width: 720px;
  margin: 0 auto;
}
.sim-wizard-trigger:hover {
  transform: translateY(-3px);
  color: #fff;
}
.sim-wizard-trigger__kicker {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.15em;
  opacity: 0.85;
  margin-bottom: 10px;
}
.sim-wizard-trigger__headline {
  font-size: 26px;
  font-weight: 800;
  margin-bottom: 14px;
  letter-spacing: -0.01em;
  line-height: 1.35;
}
.sim-wizard-trigger__sub {
  font-size: 14px;
  opacity: 0.9;
  margin-bottom: 22px;
  line-height: 1.7;
}
.sim-wizard-trigger__cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: #fff;
  color: var(--sim-blue);
  font-size: 15px;
  font-weight: 700;
  padding: 12px 28px;
  border-radius: 980px;
}

/* Wizard modal */
.sim-wizard-modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9999;
  align-items: center;
  justify-content: center;
  padding: 16px;
}
.sim-wizard-modal__overlay {
  position: absolute;
  inset: 0;
  background: rgba(20,20,22,0.65);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.sim-wizard-modal__panel {
  position: relative;
  background: var(--sim-card);
  border-radius: var(--sim-r-xl);
  max-width: 560px;
  width: 100%;
  padding: 40px 32px 32px;
  box-shadow: var(--sim-shadow-lg);
  max-height: 90vh;
  overflow-y: auto;
}
.sim-wizard-modal__close {
  position: absolute;
  top: 14px;
  right: 14px;
  background: transparent;
  border: none;
  font-size: 26px;
  line-height: 1;
  color: var(--sim-ink-3);
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 6px;
}
.sim-wizard-modal__close:hover {
  background: var(--sim-rule-soft);
  color: var(--sim-ink);
}

.sim-wizard-progress {
  height: 4px;
  background: var(--sim-rule-soft);
  border-radius: 4px;
  margin-bottom: 28px;
  overflow: hidden;
}
.sim-wizard-progress__bar {
  height: 100%;
  background: linear-gradient(90deg, var(--sim-blue) 0%, var(--sim-green) 100%);
  width: 25%;
  transition: width 0.4s ease;
  border-radius: 4px;
}
.sim-wizard-step {
  display: none;
}
.sim-wizard-step.is-active {
  display: block;
  animation: simFadeIn 0.3s ease;
}
@keyframes simFadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}
.sim-wizard-step__q {
  font-size: 20px;
  font-weight: 700;
  color: var(--sim-ink);
  margin-bottom: 8px;
  line-height: 1.5;
}
.sim-wizard-step__hint {
  font-size: 13px;
  color: var(--sim-ink-4);
  margin-bottom: 20px;
  line-height: 1.7;
}
.sim-wizard-options {
  display: grid;
  gap: 10px;
}
.sim-wizard-option {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  background: var(--sim-bg);
  border: 2px solid transparent;
  border-radius: var(--sim-r-md);
  font-size: 15px;
  font-weight: 600;
  color: var(--sim-ink);
  cursor: pointer;
  transition: all 0.2s ease;
  text-align: left;
  font-family: var(--sim-font-jp);
  line-height: 1.4;
}
.sim-wizard-option:hover {
  border-color: var(--sim-blue);
  background: var(--sim-blue-soft);
}
.sim-wizard-option.is-selected {
  border-color: var(--sim-blue);
  background: var(--sim-blue-soft);
}
.sim-wizard-option__icon {
  font-size: 22px;
  flex-shrink: 0;
}
.sim-wizard-option__body {
  flex: 1;
}
.sim-wizard-option__title {
  font-size: 15px;
  font-weight: 700;
}
.sim-wizard-option__hint {
  font-size: 12px;
  font-weight: 500;
  color: var(--sim-ink-4);
  margin-top: 2px;
}

/* Wizard result cards */
.sim-wizard-result {
  display: none;
}
.sim-wizard-result.is-active {
  display: block;
  animation: simFadeIn 0.4s ease;
}
.sim-wizard-result__title {
  font-size: 18px;
  font-weight: 700;
  color: var(--sim-ink);
  margin-bottom: 6px;
  text-align: center;
}
.sim-wizard-result__lead {
  font-size: 13px;
  color: var(--sim-ink-4);
  text-align: center;
  margin-bottom: 22px;
}
.sim-wizard-result__cards {
  display: grid;
  gap: 12px;
  margin-bottom: 20px;
}
.sim-result-card {
  display: block;
  background: var(--sim-card);
  border: 1px solid var(--sim-rule);
  border-radius: var(--sim-r-md);
  padding: 18px 20px;
  text-decoration: none !important;
  color: var(--sim-ink) !important;
  transition: all 0.2s ease;
  position: relative;
}
.sim-result-card:hover {
  border-color: var(--sim-blue);
  background: var(--sim-blue-soft);
  transform: translateY(-1px);
}
.sim-result-card__rank {
  position: absolute;
  top: 12px;
  right: 16px;
  font-size: 11px;
  font-weight: 700;
  color: var(--sim-ink-4);
  letter-spacing: 0.08em;
}
.sim-result-card__name {
  font-size: 17px;
  font-weight: 800;
  margin-bottom: 4px;
}
.sim-result-card__tagline {
  font-size: 12px;
  color: var(--sim-ink-4);
  margin-bottom: 10px;
  line-height: 1.7;
}
.sim-result-card__cta {
  display: inline-block;
  font-size: 13px;
  font-weight: 700;
  color: var(--sim-blue);
}

/* ============================================
   Pillar 2: Quality × Price 2-axis Scatter
   ============================================ */
.sim-scatter-wrap {
  background: var(--sim-card);
  border-radius: var(--sim-r-lg);
  padding: 28px 24px;
  box-shadow: var(--sim-shadow);
  max-width: 800px;
  margin: 0 auto;
}
.sim-scatter-title {
  font-size: 18px;
  font-weight: 700;
  color: var(--sim-ink);
  margin-bottom: 6px;
  text-align: center;
}
.sim-scatter-sub {
  font-size: 12px;
  color: var(--sim-ink-4);
  text-align: center;
  margin-bottom: 20px;
}
.sim-scatter-canvas {
  width: 100%;
  max-height: 420px;
}
.sim-scatter-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
  margin-top: 16px;
  font-size: 12px;
  color: var(--sim-ink-3);
}
.sim-scatter-legend__quadrant {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.sim-scatter-legend__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
}

/* ============================================
   Pillar 3: 5-axis Radar Chart
   ============================================ */
.sim-radar-wrap {
  background: var(--sim-bg);
  border-radius: var(--sim-r-lg);
  padding: 20px;
  margin: 24px 0;
}
.sim-radar-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--sim-ink);
  margin-bottom: 12px;
}
.sim-radar-canvas {
  width: 100%;
  max-width: 360px;
  max-height: 360px;
  margin: 0 auto;
}

/* ============================================
   Pillar 4: 3-tier Multi-table
   ============================================ */
.sim-mtable {
  background: var(--sim-card);
  border-radius: var(--sim-r-lg);
  overflow: hidden;
  box-shadow: var(--sim-shadow);
  margin: 24px 0;
}
.sim-mtable__tabs {
  display: flex;
  background: var(--sim-bg);
  border-bottom: 1px solid var(--sim-rule);
}
.sim-mtable__tab {
  flex: 1;
  padding: 14px 16px;
  text-align: center;
  font-size: 13px;
  font-weight: 700;
  color: var(--sim-ink-3);
  background: transparent;
  border: none;
  cursor: pointer;
  transition: all 0.2s ease;
  font-family: var(--sim-font-jp);
  border-bottom: 3px solid transparent;
}
.sim-mtable__tab:hover {
  color: var(--sim-ink);
  background: rgba(0,0,0,0.03);
}
.sim-mtable__tab.is-active {
  color: var(--sim-blue);
  background: var(--sim-card);
  border-bottom-color: var(--sim-blue);
}
.sim-mtable__panel {
  display: none;
  padding: 0;
}
.sim-mtable__panel.is-active {
  display: block;
  animation: simFadeIn 0.3s ease;
}
.sim-mtable table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
}
.sim-mtable th,
.sim-mtable td {
  padding: 12px 14px;
  text-align: left;
  border-bottom: 1px solid var(--sim-rule-soft);
  vertical-align: middle;
}
.sim-mtable thead th {
  background: var(--sim-ink);
  color: #fff;
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.03em;
  text-align: center;
}
.sim-mtable td.sim-mtable__rank {
  font-weight: 800;
  color: var(--sim-blue);
  text-align: center;
  width: 36px;
}
.sim-mtable td.sim-mtable__name {
  font-weight: 700;
}
.sim-mtable td.sim-mtable__price {
  font-weight: 700;
  color: var(--sim-green);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.sim-mtable tr.sim-mtable__row--highlight {
  background: var(--sim-blue-soft);
}
.sim-mtable__cell-note {
  display: block;
  font-size: 11px;
  color: var(--sim-ink-4);
  font-weight: 500;
  margin-top: 2px;
}
@media (max-width: 640px) {
  .sim-mtable {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .sim-mtable table {
    min-width: 640px;
  }
}

/* ============================================
   Pillar 5: Accordion (details/summary)
   ============================================ */
.sim-accordion {
  background: var(--sim-card);
  border: 1px solid var(--sim-rule);
  border-radius: var(--sim-r-md);
  margin: 12px 0;
  overflow: hidden;
}
.sim-accordion[open] {
  box-shadow: var(--sim-shadow);
  border-color: var(--sim-blue);
}
.sim-accordion__summary {
  list-style: none;
  cursor: pointer;
  padding: 18px 22px;
  font-size: 15px;
  font-weight: 700;
  color: var(--sim-ink);
  display: flex;
  align-items: center;
  gap: 10px;
  transition: background 0.2s ease;
  user-select: none;
}
.sim-accordion__summary::-webkit-details-marker {
  display: none;
}
.sim-accordion__summary:hover {
  background: var(--sim-bg);
}
.sim-accordion__summary::after {
  content: "＋";
  margin-left: auto;
  font-size: 18px;
  font-weight: 400;
  color: var(--sim-ink-3);
  transition: transform 0.3s ease;
}
.sim-accordion[open] .sim-accordion__summary::after {
  content: "−";
  color: var(--sim-blue);
}
.sim-accordion__body {
  padding: 4px 22px 22px;
  font-size: 14px;
  line-height: 1.85;
  color: var(--sim-ink-2);
  border-top: 1px solid var(--sim-rule-soft);
}

/* ============================================
   Update Log (ショーケース方式)
   ============================================ */
.sim-update-log {
  background: var(--sim-bg);
  border-left: 3px solid var(--sim-blue);
  padding: 16px 20px;
  margin: 32px 0;
  border-radius: 0 var(--sim-r-sm) var(--sim-r-sm) 0;
  font-size: 13px;
}
.sim-update-log__title {
  font-weight: 700;
  color: var(--sim-ink);
  margin-bottom: 8px;
}
.sim-update-log__item {
  color: var(--sim-ink-3);
  margin-bottom: 4px;
  display: flex;
  gap: 8px;
}
.sim-update-log__date {
  font-variant-numeric: tabular-nums;
  color: var(--sim-blue);
  font-weight: 700;
  min-width: 90px;
}

/* ============================================
   Score Score-bar (6軸配分開示 LiPro方式)
   ============================================ */
.sim-score-breakdown {
  background: var(--sim-card);
  border-radius: var(--sim-r-md);
  padding: 20px;
  margin: 20px 0;
  border: 1px solid var(--sim-rule);
}
.sim-score-breakdown__title {
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 14px;
}
.sim-score-bar {
  display: grid;
  grid-template-columns: 110px 1fr 50px;
  gap: 12px;
  align-items: center;
  margin-bottom: 10px;
  font-size: 13px;
}
.sim-score-bar__label {
  color: var(--sim-ink-2);
  font-weight: 600;
}
.sim-score-bar__track {
  height: 10px;
  background: var(--sim-rule-soft);
  border-radius: 5px;
  overflow: hidden;
}
.sim-score-bar__fill {
  height: 100%;
  background: linear-gradient(90deg, var(--sim-blue) 0%, var(--sim-green) 100%);
  border-radius: 5px;
}
.sim-score-bar__pct {
  font-weight: 700;
  color: var(--sim-blue);
  text-align: right;
  font-variant-numeric: tabular-nums;
}

/* ============================================
   Mobile Refinements
   ============================================ */
@media screen and (max-width: 768px) {
  .sim-wizard-trigger {
    padding: 32px 20px;
  }
  .sim-wizard-trigger__headline {
    font-size: 21px;
  }
  .sim-wizard-modal__panel {
    padding: 32px 20px 24px;
  }
  .sim-wizard-step__q {
    font-size: 17px;
  }
  .sim-scatter-wrap {
    padding: 20px 14px;
  }
  .sim-mtable__tabs {
    font-size: 12px;
  }
  .sim-mtable__tab {
    padding: 12px 8px;
    font-size: 12px;
  }
  .sim-btn {
    padding: 14px 24px;
    font-size: 15px;
  }
  .sim-btn--cv {
    padding: 16px 28px;
    font-size: 16px;
  }
}

/* ============================================
   v3 Components (2026-04-22 分かりやすさ版)
   ============================================ */

/* --- Type-based Instant Pick Board (Hero直後の最重要ボード) --- */
.sim-type-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 22px;
}
.sim-type-card {
  background: var(--sim-card);
  border: 1px solid var(--sim-rule);
  border-radius: var(--sim-r-lg);
  padding: 28px 26px 26px;
  display: flex;
  flex-direction: column;
  transition: all 0.25s ease;
  position: relative;
  box-shadow: var(--sim-shadow-sm);
}
.sim-type-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--sim-shadow);
  border-color: var(--sim-blue);
}
.sim-type-card__kicker {
  display: inline-block;
  font-size: 13px;
  font-weight: 700;
  color: var(--sim-blue);
  letter-spacing: 0.02em;
  margin-bottom: 10px;
}
.sim-type-card__name {
  font-size: 26px;
  font-weight: 800;
  color: var(--sim-ink);
  letter-spacing: -0.01em;
  margin-bottom: 8px;
  line-height: 1.25;
}
.sim-type-card__plan {
  font-size: 15px;
  color: var(--sim-ink-2);
  margin-bottom: 4px;
}
.sim-type-card__plan strong {
  font-size: 22px;
  font-weight: 800;
  color: var(--sim-green);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.02em;
}
.sim-type-card__unit {
  font-size: 12px;
  color: var(--sim-ink-4);
  font-weight: 500;
}
.sim-type-card__why {
  font-size: 13.5px;
  line-height: 1.75;
  color: var(--sim-ink-2);
  margin: 14px 0 16px;
  flex-grow: 1;
}
.sim-type-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 18px;
}
.sim-type-card__tag {
  display: inline-block;
  font-size: 11px;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: 100px;
  background: var(--sim-bg);
  color: var(--sim-ink-3);
  letter-spacing: 0.01em;
}
.sim-type-card__tag--accent {
  background: var(--sim-green-soft);
  color: #2a7d3d;
}

@media (max-width: 720px) {
  .sim-type-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .sim-type-card {
    padding: 24px 22px 22px;
  }
  .sim-type-card__name {
    font-size: 22px;
  }
}

/* --- Simple Comparison Table (3軸のみ) --- */
.sim-simple-table-wrap {
  background: var(--sim-card);
  border-radius: var(--sim-r-lg);
  overflow: hidden;
  box-shadow: var(--sim-shadow);
}
.sim-simple-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
}
.sim-simple-table th {
  background: var(--sim-ink);
  color: #fff;
  padding: 14px 16px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-align: center;
}
.sim-simple-table td {
  padding: 14px 16px;
  text-align: center;
  border-bottom: 1px solid var(--sim-rule-soft);
  vertical-align: middle;
}
.sim-simple-table td.sim-simple-table__name {
  text-align: left;
  font-weight: 700;
  color: var(--sim-ink);
}
.sim-simple-table td.sim-simple-table__price {
  font-weight: 800;
  color: var(--sim-green);
  font-variant-numeric: tabular-nums;
  font-size: 15px;
  white-space: nowrap;
}
.sim-simple-table tr:nth-child(even) td {
  background: var(--sim-bg-2);
}
.sim-simple-table tr:hover td {
  background: var(--sim-blue-soft);
}
.sim-simple-table td:last-child {
  text-align: left;
  color: var(--sim-ink-3);
  font-size: 13px;
}
@media (max-width: 640px) {
  .sim-simple-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .sim-simple-table {
    min-width: 560px;
  }
}

/* --- 3-Step Selection Guide --- */
.sim-steps {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.sim-step {
  display: flex;
  gap: 24px;
  align-items: flex-start;
  background: var(--sim-card);
  border-radius: var(--sim-r-lg);
  padding: 28px 28px 26px;
  box-shadow: var(--sim-shadow-sm);
  border: 1px solid var(--sim-rule-soft);
}
.sim-step__num {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--sim-blue) 0%, var(--sim-green) 100%);
  color: #fff;
  font-size: 22px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  font-variant-numeric: tabular-nums;
  box-shadow: 0 2px 8px rgba(0,102,204,0.25);
}
.sim-step__body {
  flex: 1;
}
.sim-step__title {
  font-size: 17px;
  font-weight: 700;
  color: var(--sim-ink);
  margin: 4px 0 8px;
  border: none !important;
  padding: 0 !important;
  line-height: 1.45;
}
.sim-step__text {
  font-size: 14px;
  line-height: 1.85;
  color: var(--sim-ink-2);
  margin: 0;
}
@media (max-width: 640px) {
  .sim-step {
    gap: 16px;
    padding: 22px 20px;
  }
  .sim-step__num {
    width: 40px;
    height: 40px;
    font-size: 18px;
  }
}

/* --- Mini Glossary --- */
.sim-glossary {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  margin: 0;
}
.sim-glossary__item {
  background: var(--sim-bg);
  border-radius: var(--sim-r-md);
  padding: 18px 20px;
  border-left: 3px solid var(--sim-blue);
}
.sim-glossary__term {
  font-size: 15px;
  font-weight: 800;
  color: var(--sim-blue);
  margin-bottom: 6px;
  letter-spacing: 0.01em;
}
.sim-glossary__def {
  font-size: 13px;
  line-height: 1.75;
  color: var(--sim-ink-2);
  margin: 0;
}
@media (max-width: 720px) {
  .sim-glossary {
    grid-template-columns: 1fr;
    gap: 12px;
  }
}

/* ============================================
   CRITICAL: Cocoon .entry-content a override
   Cocoon 親テーマが `.entry-content a { color: var(--color-primary) !important }` を
   出力しており、これが私のボタン/ウィザードの白文字指定より特異性が高いため、
   青背景×青文字の「文字が見えない」状態になる。ここで特異性 (0,2,1) で明示的に上書き。
   ============================================ */

/* Buttons: force white text on primary/cv, blue text on outline */
.entry-content a.sim-btn,
.entry-content a.sim-btn--primary,
.entry-content a.sim-btn--cv,
.nao-full a.sim-btn,
.nao-full a.sim-btn--primary,
.nao-full a.sim-btn--cv {
  text-decoration: none !important;
}

.entry-content a.sim-btn--primary,
.entry-content a.sim-btn--cv,
.nao-full a.sim-btn--primary,
.nao-full a.sim-btn--cv,
body a.sim-btn--primary,
body a.sim-btn--cv {
  color: #ffffff !important;
}
.entry-content a.sim-btn--primary:hover,
.entry-content a.sim-btn--cv:hover,
.nao-full a.sim-btn--primary:hover,
.nao-full a.sim-btn--cv:hover {
  color: #ffffff !important;
}

.entry-content a.sim-btn--outline,
.nao-full a.sim-btn--outline {
  color: var(--sim-blue) !important;
}
.entry-content a.sim-btn--outline:hover,
.nao-full a.sim-btn--outline:hover {
  color: #ffffff !important;
}

/* Wizard trigger: whole card is an <a>, force white text on all internal div children */
.entry-content a.sim-wizard-trigger,
.nao-full a.sim-wizard-trigger,
body a.sim-wizard-trigger {
  color: #ffffff !important;
  text-decoration: none !important;
}
.entry-content a.sim-wizard-trigger .sim-wizard-trigger__kicker,
.entry-content a.sim-wizard-trigger .sim-wizard-trigger__headline,
.entry-content a.sim-wizard-trigger .sim-wizard-trigger__sub,
.nao-full a.sim-wizard-trigger .sim-wizard-trigger__kicker,
.nao-full a.sim-wizard-trigger .sim-wizard-trigger__headline,
.nao-full a.sim-wizard-trigger .sim-wizard-trigger__sub {
  color: #ffffff !important;
}
/* The inner white pill CTA keeps blue text (on white bg) */
.entry-content a.sim-wizard-trigger .sim-wizard-trigger__cta,
.nao-full a.sim-wizard-trigger .sim-wizard-trigger__cta {
  color: var(--sim-blue) !important;
  background: #ffffff !important;
}

/* Result cards (inside wizard modal) — dark text on white bg */
.entry-content a.sim-result-card,
.nao-full a.sim-result-card {
  color: var(--sim-ink) !important;
  text-decoration: none !important;
}
.entry-content a.sim-result-card .sim-result-card__name,
.entry-content a.sim-result-card .sim-result-card__tagline,
.nao-full a.sim-result-card .sim-result-card__name,
.nao-full a.sim-result-card .sim-result-card__tagline {
  color: var(--sim-ink) !important;
}
.entry-content a.sim-result-card .sim-result-card__cta,
.nao-full a.sim-result-card .sim-result-card__cta {
  color: var(--sim-blue) !important;
}

/* Type card internal anchors (just in case) */
.entry-content .sim-type-card a.sim-btn--primary,
.nao-full .sim-type-card a.sim-btn--primary {
  color: #ffffff !important;
}

/* ============================================
   v4 Additions (2026-04-22 夜 フルパッケージ)
   ============================================ */

/* --- Hero trust badges --- */
.sim-trust-badges {
  display: flex;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 28px;
}
.sim-trust-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(255,255,255,0.85);
  backdrop-filter: saturate(180%) blur(12px);
  -webkit-backdrop-filter: saturate(180%) blur(12px);
  padding: 8px 14px;
  border-radius: 100px;
  font-size: 12px;
  font-weight: 700;
  color: var(--sim-ink);
  border: 1px solid rgba(0,102,204,0.15);
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
.sim-trust-badge__icon {
  font-size: 14px;
}
.sim-trust-badge__num {
  color: var(--sim-blue);
  font-weight: 800;
}

/* --- Carrier logo strip (Hero bottom) --- */
.sim-carrier-strip {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 28px;
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
}
.sim-carrier-strip__label {
  font-size: 11px;
  font-weight: 600;
  color: var(--sim-ink-4);
  letter-spacing: 0.05em;
  width: 100%;
  text-align: center;
  margin-bottom: 6px;
}
.sim-carrier-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 12px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 700;
  background: #fff;
  border: 1.5px solid transparent;
  color: #1d1d1f;
  letter-spacing: -0.01em;
  white-space: nowrap;
  min-width: 86px;
}

/* --- Type card v4 enhancements (medal, big price, brand ring) --- */
.sim-type-card--medal {
  position: relative;
}
.sim-type-card__medal {
  position: absolute;
  top: -10px;
  right: -10px;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 800;
  color: #fff;
  box-shadow: 0 3px 10px rgba(0,0,0,0.2);
  z-index: 2;
}
.sim-type-card__medal--gold {
  background: linear-gradient(135deg, #ffd700 0%, #ff9500 100%);
  border: 2px solid #fff;
}
.sim-type-card__medal--silver {
  background: linear-gradient(135deg, #c0c0c0 0%, #808080 100%);
  border: 2px solid #fff;
}
.sim-type-card__medal--bronze {
  background: linear-gradient(135deg, #cd7f32 0%, #8b4513 100%);
  border: 2px solid #fff;
}
.sim-type-card__medal--star {
  background: linear-gradient(135deg, var(--sim-blue) 0%, var(--sim-green) 100%);
  border: 2px solid #fff;
}

.sim-type-card__plan--big strong {
  font-size: 32px;
  letter-spacing: -0.02em;
}
.sim-type-card__brand-ring {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  border-radius: var(--sim-r-lg) var(--sim-r-lg) 0 0;
}

/* --- Trust signal section (3 reasons) --- */
.sim-trust-section {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  max-width: 1040px;
  margin: 0 auto;
}
.sim-trust-card {
  background: #fff;
  border-radius: var(--sim-r-lg);
  padding: 36px 28px 30px;
  text-align: center;
  box-shadow: var(--sim-shadow-sm);
  border: 1px solid var(--sim-rule-soft);
}
.sim-trust-card__icon {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--sim-blue) 0%, var(--sim-green) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  margin: 0 auto 18px;
  color: #fff;
  box-shadow: 0 4px 14px rgba(0,102,204,0.25);
}
.sim-trust-card__num {
  font-size: 36px;
  font-weight: 800;
  color: var(--sim-blue);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.02em;
  line-height: 1;
  margin-bottom: 6px;
}
.sim-trust-card__label {
  font-size: 13px;
  font-weight: 700;
  color: var(--sim-ink);
  margin-bottom: 10px;
}
.sim-trust-card__desc {
  font-size: 13px;
  line-height: 1.8;
  color: var(--sim-ink-3);
  margin: 0;
}
@media (max-width: 720px) {
  .sim-trust-section {
    grid-template-columns: 1fr;
    gap: 14px;
  }
  .sim-trust-card {
    padding: 28px 22px 24px;
  }
}

/* --- 5-card grid layout (flex-based for natural centering) --- */
.sim-type-grid--5 {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 22px;
}
.sim-type-grid--5 .sim-type-card {
  flex: 0 1 calc((100% - 44px) / 3);
  min-width: 260px;
  max-width: 340px;
}
@media (max-width: 720px) {
  .sim-type-grid--5 {
    flex-direction: column;
    gap: 16px;
  }
  .sim-type-grid--5 .sim-type-card {
    flex: 1 1 100%;
    max-width: none;
  }
}
