/* =========================================================
   PIF Wizard Form — PRO LIGHT REDESIGN (2026)
   - Clean, modern, high-contrast, mobile-first
   - Keeps your existing class names
   ========================================================= */

:root {
  --pif-font: "PasargadFont", "IRANSansX", "Inter", system-ui, -apple-system, sans-serif;

  /* Colors */
  --pif-bg: #f6f7fb;
  --pif-surface: #ffffff;
  --pif-surface-2: #fbfcff;

  --pif-text: #0f172a;
  --pif-text-2: #334155;
  --pif-muted: #64748b;

  --pif-border: rgba(148, 163, 184, 0.55);
  --pif-border-2: rgba(204, 225, 203, 0.9);

  --pif-primary: #49eb25;  /* blue */
  --pif-primary-2: #06d493; /* cyan */
  --pif-success: #10b981;
  --pif-danger: #ef4444;

  --pif-focus: 0 0 0 4px rgba(37, 99, 235, 0.18);

  /* Radius */
  --pif-r-xl: 18px;
  --pif-r-lg: 14px;
  --pif-r-md: 12px;
  --pif-r-sm: 10px;

  /* Shadow (soft & premium) */
  --pif-shadow-1: 0 6px 18px rgba(15, 23, 42, 0.06);
  --pif-shadow-2: 0 18px 40px rgba(15, 23, 42, 0.10);
  --pif-shadow-3: 0 30px 70px rgba(15, 23, 42, 0.10);

  /* Motion */
  --pif-t-fast: 140ms;
  --pif-t-mid: 220ms;
  --pif-ease: cubic-bezier(.2,.8,.2,1);
}

/* ---------------------------------------------------------
   1) Wrapper
---------------------------------------------------------- */

.pif-wizard {
  position: relative;
  direction: rtl;
  max-width: 1080px;
  width: 100%;
  margin: 22px auto;
  padding: 20px;
  font-family: var(--pif-font);

  color: var(--pif-text);
  background: radial-gradient(900px 360px at 80% -10%, rgba(37, 99, 235, 0.10), transparent 55%),
              radial-gradient(700px 300px at 10% 20%, rgba(6, 182, 212, 0.10), transparent 55%),
              var(--pif-bg);

  border: 1px solid rgba(203, 213, 225, 0.7);
  border-radius: var(--pif-r-xl);
  box-shadow: var(--pif-shadow-3);
  overflow: hidden;
}

/* subtle "paper" overlay */
.pif-wizard::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.70), rgba(255,255,255,0.45)),
    radial-gradient(800px 300px at 50% 0%, rgba(255,255,255,0.90), transparent 60%);
  pointer-events: none;
  z-index: 0;
}

/* ---------------------------------------------------------
   2) Header
---------------------------------------------------------- */

.pif-wizard-header {
  position: relative;
  z-index: 1;
justify-content: center;
  display: flex;
  align-items: flex-start;
  gap: 14px;

  padding: 6px 6px 14px;
  margin-bottom: 10px;
}

.pif-wizard-title {
  font-size: 20px;
  font-weight: 900;
  letter-spacing: -0.2px;
  color: var(--pif-text);
}

.pif-wizard-subtitle {
  margin-top: 4px;
  font-size: 13px;
  color: var(--pif-muted);
}

/* Optional theme toggle button (if exists) */
.pif-theme-toggle {
  display: inline-flex;
  align-items: center;
  gap: 10px;

  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid var(--pif-border-2);
  background: rgba(255, 255, 255, 0.75);
  box-shadow: var(--pif-shadow-1);

  color: var(--pif-text-2);
  cursor: pointer;
  user-select: none;

  transition: transform var(--pif-t-fast) var(--pif-ease),
              box-shadow var(--pif-t-fast) var(--pif-ease);
}

.pif-theme-toggle:hover {
  transform: translateY(-1px);
  box-shadow: var(--pif-shadow-2);
}

.pif-theme-toggle:focus-visible {
  outline: none;
  box-shadow: var(--pif-shadow-2), var(--pif-focus);
}

.pif-theme-toggle__text {
  font-size: 12px;
  font-weight: 800;
}

/* ---------------------------------------------------------
   3) Stepper (Modern pill cards)
---------------------------------------------------------- */

.pif-stepper {
  position: relative;
  z-index: 1;

  margin-top: 6px;
  padding: 12px;
  border-radius: var(--pif-r-lg);

  background: rgba(255, 255, 255, 0.78);
  border: 1px solid rgba(203, 213, 225, 0.9);
  box-shadow: var(--pif-shadow-1);
}

.pif-stepper-track {
  display: grid;
  grid-auto-flow: column;
  grid-template-columns: repeat(3, minmax(0, 1fr));

  gap: 10px;
  align-items: stretch;
}

.pif-stepper-item {
  position: relative;

  border-radius: 14px;
  padding: 12px 12px 12px 14px;

  background: linear-gradient(180deg, #ffffff, #f9fbff);
  border: 1px solid rgba(203, 213, 225, 0.95);

  transition: transform var(--pif-t-fast) var(--pif-ease),
              box-shadow var(--pif-t-fast) var(--pif-ease),
              border-color var(--pif-t-fast) var(--pif-ease);
}

.pif-stepper-item::after {
  content: "";
  position: absolute;
  top: 24px;
  left: -10px;
  width: 10px;
  height: 2px;
  background: rgba(148, 163, 184, 0.55);
}

.pif-stepper-item:last-child::after { display: none; }

.pif-stepper-dot {
  width: 28px;
  height: 28px;
  border-radius: 999px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  font-weight: 900;
  font-size: 12px;

  color: var(--pif-muted);
  border: 1px solid rgba(148, 163, 184, 0.45);
  background: #ffffff;
  box-shadow: 0 10px 18px rgba(15, 23, 42, 0.06);
}

.pif-stepper-title {
  display: block;
  margin-top: 8px;
  font-size: 12.5px;
  font-weight: 850;
  color: var(--pif-text);
  line-height: 1.35;
}

/* Active */
.pif-stepper-item.is-active {
  border-color: rgba(37, 99, 235, 0.55);
  box-shadow: var(--pif-shadow-2);
  transform: translateY(-1px);
}

.pif-stepper-item.is-active .pif-stepper-dot {
  color: #0b1220;
  border-color: rgba(37, 99, 235, 0.55);
  background: linear-gradient(135deg, rgba(37, 99, 235, 0.14), rgba(6, 182, 212, 0.10));
}

/* Done */
.pif-stepper-item.is-done {
  border-color: rgba(16, 185, 129, 0.45);
}

.pif-stepper-item.is-done .pif-stepper-dot {
  border-color: rgba(16, 185, 129, 0.55);
  color: #065f46;
  background: rgba(16, 185, 129, 0.12);
}

/* ---------------------------------------------------------
   4) Step label + progress
---------------------------------------------------------- */

.pif-wizard-steps {
  min-width: 160px;
}

.pif-wizard-step-label {
  display: flex;
  align-items: baseline;
  gap: 6px;
  justify-content: flex-end;

  font-weight: 800;
  color: var(--pif-text-2);
  margin: 12px 2px 8px;
}

.pif-wizard-step-current {
  font-size: 18px;
  color: var(--pif-primary);
}

.pif-wizard-step-total::before {
  content: "/";
  margin: 0 4px;
  color: var(--pif-muted);
}

.pif-wizard-progress-wrap {
  width: 100%;
  height: 8px;
  border-radius: 999px;
  overflow: hidden;

  background: rgba(226, 232, 240, 0.9);
  border: 1px solid rgba(203, 213, 225, 0.95);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.8);
}

.pif-wizard-progress {
  height: 100%;
  width: 0;
  background: linear-gradient(90deg, var(--pif-primary), var(--pif-primary-2));
  transition: width 220ms var(--pif-ease);
}

/* ---------------------------------------------------------
   5) Form surface
---------------------------------------------------------- */

.pif-wizard-form {
  position: relative;
  z-index: 1;

  margin-top: 12px;
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid rgba(203, 213, 225, 0.95);
  border-radius: var(--pif-r-lg);
  box-shadow: var(--pif-shadow-2);

  padding: 16px;
}

.pif-wizard-steps-wrap {
  position: relative;
  min-height: 300px;
}

.pif-step { display: none; }

.pif-step.is-active {
  display: block;
  animation: pifStepIn 260ms var(--pif-ease);
}

/* directional animations if you set data-step-dir on .pif-wizard */
.pif-wizard[data-step-dir="forward"] .pif-step.is-active {
  animation: pifStepInRight 260ms var(--pif-ease);
}
.pif-wizard[data-step-dir="back"] .pif-step.is-active {
  animation: pifStepInLeft 260ms var(--pif-ease);
}

.pif-step-title {
  font-weight: 900;
  font-size: 14px;
  margin: 2px 0 14px;
  color: var(--pif-text);
}

/* ---------------------------------------------------------
   6) Fields (Pro input design)
---------------------------------------------------------- */

.pif-field {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;

  font-size: 14px;
  color: var(--pif-text);
}

.pif-field span {
  font-size: 12.5px;
  font-weight: 800;
  color: var(--pif-text-2);
  white-space: nowrap;
  min-width: 120px;
}

/* Inputs */
.pif-field input,
.pif-field select,
.pif-field textarea {
  width: 100%;
  appearance: none;

  background: #ffffff;
  border: 1px solid rgba(148, 163, 184, 0.55);
  border-radius: 12px;

  color: var(--pif-text);
  padding: 12px 12px;
  font-size: 14px;

  box-shadow: 0 1px 0 rgba(255,255,255,0.9),
              0 10px 18px rgba(15, 23, 42, 0.04);

  transition: border-color var(--pif-t-fast) var(--pif-ease),
              box-shadow var(--pif-t-fast) var(--pif-ease),
              transform var(--pif-t-fast) var(--pif-ease);
}

.pif-field textarea {
  min-height: 120px;
  resize: vertical;
}

.pif-field input::placeholder,
.pif-field textarea::placeholder {
  color: rgba(100, 116, 139, 0.75);
}

.pif-field input[name="phone"] {
  direction: rtl;
  text-align: right;
}

.pif-field input[name="phone"]::placeholder {
  direction: rtl;
  text-align: right;
}

.pif-field input:hover,
.pif-field select:hover,
.pif-field textarea:hover {
  border-color: rgba(100, 116, 139, 0.75);
}

.pif-field input:focus,
.pif-field select:focus,
.pif-field textarea:focus {
  outline: none;
  border-color: rgba(37, 99, 235, 0.65);
  box-shadow: var(--pif-focus), 0 16px 28px rgba(15, 23, 42, 0.08);
  transform: translateY(-1px);
}

.pif-domain-other[hidden] {
  display: none;
}

.pif-howknow-other[hidden] {
  display: none;
}

.pif-attachments {
  width: 100%;
}

.pif-attach-input {
  display: none;
}

.pif-attachments input[type="file"] {
  display: none !important;
  width: 0 !important;
  height: 0 !important;
  opacity: 0 !important;
  overflow: hidden !important;
  pointer-events: none !important;
}

.pif-attach-list {
  margin-top: 8px;
  display: grid;
  gap: 6px;
}

.pif-attach-row {
  padding: 8px 10px;
  border: 1px solid rgba(148, 163, 184, 0.45);
  border-radius: 10px;
  background: #fff;
  font-size: 12px;
  color: var(--pif-text-2);
}

/* Invalid */
.pif-field input[aria-invalid="true"],
.pif-field select[aria-invalid="true"],
.pif-field textarea[aria-invalid="true"] {
  border-color: rgba(239, 68, 68, 0.65);
  box-shadow: 0 0 0 4px rgba(239, 68, 68, 0.12);
}

/* ---------------------------------------------------------
   7) Alert (Success / Error)
---------------------------------------------------------- */

.pif-alert {
  position: relative;
  z-index: 1;

  margin: 12px 0 6px;
  padding: 12px 12px;

  border-radius: 14px;
  font-size: 13px;
  line-height: 1.7;

  background: rgba(255, 255, 255, 0.88);
  border: 1px solid rgba(203, 213, 225, 0.95);
  box-shadow: var(--pif-shadow-1);

  color: var(--pif-text-2);
  display: none;
}

.pif-alert.is-error {
  display: block;
  border-color: rgba(239, 68, 68, 0.35);
  background: rgba(239, 68, 68, 0.08);
  color: #7f1d1d;
}

.pif-alert.is-success {
  display: block;
  border-color: rgba(16, 185, 129, 0.35);
  background: rgba(16, 185, 129, 0.08);
  color: #064e3b;
}

/* ---------------------------------------------------------
   8) Actions / Buttons
---------------------------------------------------------- */

.pif-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 14px;
}

.pif-actions-right {
  display: flex;
  gap: 8px;
}

/* Base button */
.pif-btn {
  border: 1px solid rgba(148, 163, 184, 0.55);
  border-radius: 12px;

  padding: 11px 14px;
  min-width: 120px;

  font-weight: 900;
  font-size: 13px;

  cursor: pointer;
  user-select: none;

  background: linear-gradient(180deg, #ffffff, #f3f6ff);
  color: var(--pif-text);

  box-shadow: var(--pif-shadow-1);
  transition: transform var(--pif-t-fast) var(--pif-ease),
              box-shadow var(--pif-t-fast) var(--pif-ease),
              border-color var(--pif-t-fast) var(--pif-ease);
}

.pif-btn:hover {
  transform: translateY(-1px);
  box-shadow: var(--pif-shadow-2);
  border-color: rgba(37, 99, 235, 0.35);
}

.pif-btn:focus-visible {
  outline: none;
  box-shadow: var(--pif-shadow-2), var(--pif-focus);
}

.pif-btn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

/* Primary */
.pif-btn.primary {
  border: none;
  background: linear-gradient(90deg, var(--pif-primary), var(--pif-primary-2));
  color: #ffffff;
  box-shadow: 0 18px 40px rgba(37, 99, 235, 0.18);
}

.pif-btn.primary:hover {
  box-shadow: 0 22px 55px rgba(37, 99, 235, 0.22);
}

/* Ghost */
.pif-btn.ghost {
  background: rgba(255, 255, 255, 0.78);
  border: 1px solid rgba(203, 213, 225, 0.95);
  color: var(--pif-text-2);
}

/* ---------------------------------------------------------
   9) Summary
---------------------------------------------------------- */

.pif-summary-hint {
  color: var(--pif-muted);
  margin-bottom: 12px;
  font-size: 13px;
  font-weight: 700;
}

.pif-summary-box {
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid rgba(203, 213, 225, 0.95);
  border-radius: 14px;
  padding: 12px;
  box-shadow: var(--pif-shadow-1);

  color: var(--pif-text);
  font-size: 14px;
  display: grid;
  gap: 10px;
}

.pif-summary-box div {
  display: flex;
  justify-content: space-between;
  gap: 10px;

  border-bottom: 1px dashed rgba(148, 163, 184, 0.55);
  padding-bottom: 8px;
}
.pif-summary-box div:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.pif-summary-key {
  color: var(--pif-text-2);
  font-weight: 800;
}
.pif-summary-val {
  color: var(--pif-text);
  font-weight: 900;
}

.pif-success {
  display: none;
  margin-top: 14px;
  padding: 14px;
  border-radius: var(--pif-radius);
  border: 1px solid var(--pif-success-border);
  background: var(--pif-success-bg);
  color: var(--pif-success-text);
}

.pif-success-title {
  font-weight: 900;
  margin-bottom: 6px;
}

.pif-success-text {
  font-size: 13px;
  margin-bottom: 10px;
  color: var(--pif-text-2);
}

.pif-success-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.pif-success-actions .pif-btn {
  min-width: 140px;
  text-align: center;
  text-decoration: none;
}

.pif-result-popup {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 99999;
}

.pif-result-popup.is-open {
  display: flex;
}

.pif-result-popup-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.45);
  backdrop-filter: blur(2px);
}

.pif-result-popup-card {
  position: relative;
  z-index: 1;
  width: min(92vw, 460px);
  border-radius: 16px;
  background: #fff;
  border: 1px solid rgba(203, 213, 225, 0.95);
  box-shadow: var(--pif-shadow-3);
  padding: 18px;
  text-align: center;
}

.pif-result-popup-actions {
  margin-top: 12px;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: center;
}

.pif-result-popup-actions .pif-btn {
  min-width: 130px;
  text-decoration: none;
}

.pif-result-popup-close {
  position: absolute;
  top: 8px;
  left: 8px;
  width: 32px;
  height: 32px;
  border-radius: 999px;
  border: 1px solid rgba(148, 163, 184, 0.4);
  background: #fff;
  color: var(--pif-text-2);
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
}

.pif-result-popup-icon {
  width: 56px;
  height: 56px;
  margin: 4px auto 10px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  font-weight: 900;
}

.pif-result-popup-title {
  font-size: 18px;
  font-weight: 900;
  color: var(--pif-text);
  margin-bottom: 8px;
}

.pif-result-popup-text {
  font-size: 14px;
  color: var(--pif-text-2);
  line-height: 1.8;
  margin-bottom: 12px;
}

.pif-result-popup.is-success .pif-result-popup-icon {
  color: #065f46;
  background: rgba(16, 185, 129, 0.16);
  border: 1px solid rgba(16, 185, 129, 0.4);
}

.pif-result-popup.is-error .pif-result-popup-icon {
  color: #991b1b;
  background: rgba(239, 68, 68, 0.16);
  border: 1px solid rgba(239, 68, 68, 0.4);
}

/* ---------------------------------------------------------
   10) Animations
---------------------------------------------------------- */

@keyframes pifStepIn {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes pifStepInRight {
  from { opacity: 0; transform: translateX(-14px); }
  to   { opacity: 1; transform: translateX(0); }
}

@keyframes pifStepInLeft {
  from { opacity: 0; transform: translateX(14px); }
  to   { opacity: 1; transform: translateX(0); }
}

@media (prefers-reduced-motion: reduce) {
  .pif-step.is-active { animation: none !important; }
  .pif-btn, .pif-field input, .pif-field select, .pif-field textarea, .pif-stepper-item {
    transition: none !important;
  }
}

/* ---------------------------------------------------------
   11) Responsive (Pro)
---------------------------------------------------------- */

@media (max-width: 920px) {
  .pif-stepper-track {
    grid-auto-columns: minmax(120px, 1fr);
  }
}

@media (max-width: 640px) {
  .pif-wizard {
    padding: 16px;
    border-radius: 16px;
  }

  .pif-wizard-header {
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
  }

  .pif-stepper-track {
    grid-auto-flow: row;
    grid-auto-columns: auto;
  }

  .pif-stepper-item::after {
    display: none;
  }

  .pif-field {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
  }

  .pif-field span {
    min-width: 0;
  }

  /* Sticky actions (best UX on mobile) */
  .pif-actions {
    position: sticky;
    bottom: 0;
    z-index: 2;

    margin-top: 16px;
    padding-top: 10px;

    background: linear-gradient(180deg, rgba(246, 247, 251, 0), rgba(246, 247, 251, 0.95) 40%);
    backdrop-filter: blur(8px);
  }

  .pif-actions-right {
    width: 100%;
  }

  .pif-actions-right .pif-btn {
    flex: 1;
    min-width: 0;
  }

  .pif-btn {
    padding: 12px 14px;
    border-radius: 14px;
  }
}

/* Touch devices: bigger tap targets */
@media (pointer: coarse) {
  .pif-btn { padding: 13px 14px; }
}

/* ---------------------------------------------------------
   12) Small nice extras (optional)
---------------------------------------------------------- */

/* nicer select arrow */
.pif-field select {
  background-image:
    linear-gradient(45deg, transparent 50%, rgba(100, 116, 139, 0.9) 50%),
    linear-gradient(135deg, rgba(100, 116, 139, 0.9) 50%, transparent 50%),
    linear-gradient(to right, transparent, transparent);
  background-position:
    calc(12px + 10px) calc(50% - 2px),
    calc(12px + 5px) calc(50% - 2px),
    0 0;
  background-size:
    5px 5px,
    5px 5px,
    100% 100%;
  background-repeat: no-repeat;
  padding-left: 40px;
}
/* =========================================================
   MOBILE COMPACT PATCH (Add at end of CSS)
   - Stepper: horizontal + scroll
   - Fields: label+input in one row, compact sizes
   ========================================================= */

@media (max-width: 640px) {
  /* --- Stepper: keep it on one row --- */
  .pif-stepper {
    padding: 10px;
  }

  .pif-stepper-track {
    grid-auto-flow: column !important;
    grid-auto-columns: max-content !important;
    gap: 8px !important;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    padding-bottom: 6px;
  }

  .pif-stepper-track::-webkit-scrollbar {
    height: 6px;
  }
  .pif-stepper-track::-webkit-scrollbar-thumb {
    background: rgba(148, 163, 184, 0.45);
    border-radius: 999px;
  }
  .pif-stepper-track::-webkit-scrollbar-track {
    background: rgba(226, 232, 240, 0.6);
    border-radius: 999px;
  }

  .pif-stepper-item {
    scroll-snap-align: start;
    padding: 10px 10px 10px 12px;
    min-width: 150px;   /* compact chip size */
    max-width: 210px;
  }

  .pif-stepper-item::after {
    display: none !important; /* no connectors on mobile */
  }

  .pif-stepper-dot {
    width: 24px;
    height: 24px;
    font-size: 11px;
  }

  .pif-stepper-title {
    margin-top: 6px;
    font-size: 12px;
    line-height: 1.25;
    white-space: nowrap;         /* keep single line */
    overflow: hidden;
    text-overflow: ellipsis;     /* cut long titles nicely */
    max-width: 180px;
  }

  /* --- Fields: compact, mostly single-row --- */
  .pif-field {
    flex-direction: row !important;
    align-items: center !important;
    gap: 10px !important;
    margin-bottom: 10px;
  }

  .pif-field span {
    margin: 0 !important;
    min-width: 92px;            /* fixed label width */
    max-width: 110px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-size: 12px;
  }

  .pif-field input,
  .pif-field select,
  .pif-field textarea {
    padding: 10px 10px;          /* smaller */
    font-size: 13px;
    border-radius: 12px;
    box-shadow: none;            /* less visual noise on mobile */
  }

  .pif-field textarea {
    min-height: 92px;            /* reduce height */
  }

  /* If a field is really narrow, allow wrap gracefully */
  .pif-field.is-wrap {
    flex-wrap: wrap;
  }
  .pif-field.is-wrap span {
    min-width: 100%;
    max-width: 100%;
  }

  /* --- Actions: still sticky but tighter --- */
  .pif-actions {
    padding-top: 8px;
    margin-top: 12px;
  }

  .pif-btn {
    min-width: 0;
    padding: 11px 12px;
    font-size: 13px;
  }
}
/* =========================================================
   MOBILE STEPPER — COMPACT + NO OVERFLOW (override)
   ========================================================= */
@media (max-width: 640px) {
  /* keep stepper inside box */
  .pif-stepper{
    padding: 10px !important;
    overflow: hidden;            /* مهم: بیرون نزنه */
  }

  /* make steps fit in one row (or wrap nicely) */
  .pif-stepper-track{
    display: grid !important;
    gap: 6px !important;

    overflow: hidden !important; /* اسکرول و بیرون‌زدگی قطع */
    padding: 0 !important;
    margin: 0 !important;
  }

  .pif-stepper-item{
    min-width: 0 !important;     /* مهم: عرض اجباری نداشته باشه */
    max-width: 100% !important;
    padding: 8px 8px 8px 10px !important;
    border-radius: 12px !important;
    box-shadow: none !important;
  }

  .pif-stepper-item::after{
    display: none !important;    /* خط اتصال حذف */
  }

  .pif-stepper-dot{
    width: 22px !important;
    height: 22px !important;
    font-size: 11px !important;
  }

  .pif-stepper-title{
    margin-top: 6px !important;
    font-size: 11px !important;
    line-height: 1.2 !important;

    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important; /* عنوان‌ها کوتاه دیده میشن */
    max-width: 100% !important;
  }
}

/* خیلی کوچک‌ها: فقط نقطه/شماره رو نشان بده تا فوق‌العاده جمع شود */
@media (max-width: 380px) {
  .pif-stepper-title{
    display: none !important;
  }
  .pif-stepper-item{
    padding: 8px !important;
    text-align: center;
  }
}
