/* ===== Local fonts ===== */
@font-face{
  font-family:'IRANSans';
  src:url('../storage/fonts/IRANSans.woff2') format('woff2'),
      url('../storage/fonts/IRANSans.woff') format('woff');
  font-display:swap;
}
@font-face{
  font-family:'Vazir';
  src:url('../storage/fonts/Vazir.woff2') format('woff2'),
      url('../storage/fonts/Vazir.woff') format('woff');
  font-display:swap;
}

.ms-3gaam, .ms-3gaam *{ box-sizing: border-box; }
.ms-3gaam{
  font-family:'IRANSans','Vazir',Tahoma,Arial,sans-serif;
  color:#151a2b;
  padding: clamp(48px,6vw,2px) clamp(16px,4vw,24px);
  text-align: center;
  position: relative;
}

/* هدر بخش */
.ms-3gaam__kicker{
  display:inline-flex; gap:10px; align-items:center;
  color:#5b74ff; font-weight:800; font-size:.95rem;
  margin-bottom:8px;
}
.ms-3gaam__kicker::before,
.ms-3gaam__kicker::after{
  content:""; width:28px; height:2px; background:#e3e6ee; border-radius:2px;
}
.ms-3gaam__title{
  font-weight:900;
  font-size: clamp(22px,3.4vw,34px);
  margin: 0 0 8px;
}
.ms-3gaam__subtitle{
  margin: 0 auto 38px;
  color:#666d80;
  font-size: clamp(14px,1.1vw,16px);
  max-width: 60ch;
}

/* گام‌ها */
.ms-3gaam__steps{
  max-width: 1220px; margin: 0 auto; position:relative;
  display:grid; gap:28px;
  grid-template-columns: repeat(3, minmax(240px, 1fr));
}
@media (max-width: 960px){
  .ms-3gaam__steps{ grid-template-columns: 1fr; }
}

/* کارت هر گام */
.ms-3gaam__step{
  background:#fff; border-radius:20px; padding:28px 22px 24px;
  box-shadow: 0 10px 28px rgba(16,24,40,.08);
  position:relative; z-index:2;
  transition: transform .25s ease, box-shadow .25s ease;
}
.ms-3gaam__step:hover{
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(16,24,40,.12);
}

.ms-3gaam__iconwrap{
  width:92px; height:92px; margin: -60px auto 16px;
  border-radius:50%;
  display:grid; place-items:center;
  color:#fff; font-size:34px; position:relative; isolation:isolate;
  background: linear-gradient(135deg, #ffb86c, #ff6a39);
}
.ms-3gaam__iconwrap[data-step="2"]{ background: linear-gradient(135deg, #37d3b0, #12a7d9); }
.ms-3gaam__iconwrap[data-step="3"]{ background: linear-gradient(135deg, #7a5cff, #5f30ff); }

.ms-3gaam__halo{
  position:absolute; inset:-10px; border-radius:inherit; z-index:-1;
  box-shadow: 0 14px 26px rgba(0,0,0,.18);
}
.ms-3gaam__badge{
  position:absolute; bottom:-12px; right:-12px;
  width:42px; height:42px; border-radius:50%;
  background:#fff; color:#151a2b; font-weight:800; display:grid; place-items:center;
  box-shadow: 0 6px 18px rgba(0,0,0,.18); font-size:14px;
}

.ms-3gaam__heading{
  font-size: 18px; font-weight: 800; margin: 8px 0 10px;
}
.ms-3gaam__text{
  color:#4a5165; font-size:14px; line-height:1.8; margin: 0; max-width: 48ch; display:inline-block;
}

/* SVG مسیر اتصال */
.ms-3gaam__path{
  position:absolute; inset:auto 0 auto 0; height:110px; top: 96px;
  display:block; z-index:1; pointer-events:none;
}
.ms-3gaam__path path{
  stroke:#7c83a0; stroke-width:2; stroke-dasharray:7 9; fill:none;
  opacity:.65;
}

/* موبایل: مسیر مخفی شود و کارت‌ها زیگزاگ */
@media (max-width: 960px){
  .ms-3gaam__path{ display:none; }
  .ms-3gaam__step{ text-align:center; }
  .ms-3gaam__iconwrap{ margin-top:-46px; }
}

/* دارک‌مود */
@media (prefers-color-scheme: dark){
  .ms-3gaam{ color:#e6e7eb; }
  .ms-3gaam__subtitle{ color:#b7bdcf; }
  .ms-3gaam__step{ background:#0f1115; box-shadow:0 10px 28px rgba(0,0,0,.35); }
  .ms-3gaam__text{ color:#c3c8db; }
  .ms-3gaam__badge{ background:#151920; color:#e6e7eb; }
  .ms-3gaam__path path{ stroke:#99a1c3; opacity:.55; }
}
