
/* =============================================================
   Sales Network — Persian Typography Hotfix
   بدون درخواست خارجی؛ آماده برای Vazirmatn لوکال در صورت اضافه شدن فایل‌ها
   ============================================================= */
:root{
  --sn-font: 'Vazirmatn','IRANSans','Segoe UI',Tahoma,Arial,sans-serif;
}
body,
.sn-admin,
.sn-panel,
.sn-app,
.sn-card,
.sn-table,
.sn-sidebar,
.sn-invoice-page,
.sn-auth-wrap,
.sn-myaccount-invoices,
.sn-panel input,
.sn-panel select,
.sn-panel textarea,
.sn-panel button,
.sn-admin input,
.sn-admin select,
.sn-admin textarea,
.sn-admin button{
  font-family: var(--sn-font) !important;
  letter-spacing: 0 !important;
}
.sn-card{font-weight:500;}
.sn-table th, .sn-admin table th{font-weight:700;}
.sn-title, .sn-panel-header h2, .sn-admin h1{font-weight:800;}
.sn-table td, .sn-table th, .sn-admin table td, .sn-admin table th{
  font-variant-numeric: tabular-nums;
}
.sn-code, .sn-invoice-code, .sn-table .code, .sn-table .amount, .sn-price, .sn-amount{
  font-family: var(--sn-font) !important;
  letter-spacing: 0 !important;
}

/* =============================================================
   Sales Network — Public Styles
   فونت: Vazirmatn لوکال (بدون درخواست به سرور خارجی)
   ============================================================= */

/* فونت‌ها از طریق wp_add_inline_style با مسیر مطلق تزریق می‌شوند */

/* ---------- Design Tokens ---------- */
:root {
  --sn-primary:      #4a6cf7;
  --sn-primary-dk:   #3a5ce4;
  --sn-primary-lt:   #eef1fe;
  --sn-success:      #16a34a;
  --sn-success-lt:   #f0fdf4;
  --sn-success-bd:   #bbf7d0;
  --sn-warning:      #ca8a04;
  --sn-warning-lt:   #fefce8;
  --sn-error:        #dc2626;
  --sn-error-lt:     #fef2f2;
  --sn-error-bd:     #fecaca;
  --sn-info:         #0284c7;
  --sn-info-lt:      #f0f9ff;
  --sn-border:       #e2e8f0;
  --sn-bg:           #f8fafc;
  --sn-white:        #ffffff;
  --sn-text:         #1e293b;
  --sn-text-muted:   #64748b;
  --sn-radius:       12px;
  --sn-radius-sm:    8px;
  --sn-radius-lg:    16px;
  --sn-shadow:       0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);
  --sn-shadow-md:    0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);
  --sn-font:         'Vazirmatn','IRANSans','Segoe UI',Tahoma,Arial,sans-serif;
}

/* ---------- Reset (scoped) ---------- */
.sn-panel *, .sn-invoice-page *, .sn-auth-wrap *,
.sn-myaccount-invoices * { box-sizing: border-box; }

/* ---------- Base Wrapper ---------- */
.sn-panel, .sn-invoice-page {
  direction: rtl;
  font-family: var(--sn-font);
  font-size: .9375rem;
  color: var(--sn-text);
  line-height: 1.6;
  max-width: 960px;
  margin: 24px auto;
  padding: 0 16px;
}

/* ---------- Panel Header ---------- */
.sn-panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 0 18px;
  border-bottom: 2px solid var(--sn-border);
  margin-bottom: 24px;
  gap: 12px;
  flex-wrap: wrap;
}
.sn-panel-header h2 { margin:0; font-size:1.25rem; font-weight:700; color:var(--sn-text); }

/* ---------- Badge ---------- */
.sn-badge {
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--sn-error); color: #fff;
  padding: 2px 12px; border-radius: 20px;
  font-size: .8rem; font-weight: 700; min-width: 28px;
}

/* ---------- Tabs ---------- */
.sn-tabs {
  display: flex; gap: 2px;
  border-bottom: 2px solid var(--sn-border);
  margin-bottom: 24px;
  overflow-x: auto; scrollbar-width: none;
}
.sn-tabs::-webkit-scrollbar { display: none; }
.sn-tab {
  padding: 10px 20px;
  background: none; border: none;
  border-bottom: 2px solid transparent;
  cursor: pointer;
  font-family: var(--sn-font); font-size: .9rem; font-weight: 500;
  color: var(--sn-text-muted);
  margin-bottom: -2px;
  transition: color .15s, border-color .15s;
  white-space: nowrap;
}
.sn-tab:hover { color: var(--sn-text); }
.sn-tab.active { color: var(--sn-primary); border-bottom-color: var(--sn-primary); font-weight: 700; }
.sn-tab-content { display: none !important; }
.sn-tab-content.active { display: block !important; }

/* ---------- Card ---------- */
.sn-card {
  background: var(--sn-white);
  border: 1px solid var(--sn-border);
  border-radius: var(--sn-radius-lg);
  padding: 24px; margin-bottom: 20px;
  box-shadow: var(--sn-shadow);
}
.sn-card h3 {
  margin: 0 0 20px; font-size: 1.05rem; font-weight: 700; color: var(--sn-text);
  display: flex; align-items: center; gap: 8px;
}
.sn-card h3::before {
  content: ''; display: block;
  width: 4px; height: 20px;
  background: var(--sn-primary); border-radius: 4px; flex-shrink: 0;
}

/* ---------- Form ---------- */
.sn-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 20px; }
.sn-full { grid-column: 1 / -1; }
.sn-field { display: flex; flex-direction: column; gap: 6px; }
.sn-field label { font-size: .85rem; font-weight: 600; color: var(--sn-text); }
.sn-field input, .sn-field select, .sn-field textarea {
  padding: 10px 14px;
  border: 1.5px solid var(--sn-border);
  border-radius: var(--sn-radius-sm);
  font-family: var(--sn-font); font-size: .9rem;
  color: var(--sn-text); background: var(--sn-white);
  transition: border-color .15s, box-shadow .15s;
  outline: none; direction: rtl;
}
.sn-field input:focus, .sn-field select:focus, .sn-field textarea:focus {
  border-color: var(--sn-primary);
  box-shadow: 0 0 0 3px rgb(74 108 247 / .12);
}
.sn-field input::placeholder, .sn-field textarea::placeholder { color: #94a3b8; }

/* ---------- Buttons ---------- */
.sn-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  padding: 10px 22px;
  border-radius: var(--sn-radius-sm); border: none;
  cursor: pointer;
  font-family: var(--sn-font); font-size: .9rem; font-weight: 700; line-height: 1;
  transition: background .15s, transform .1s, box-shadow .15s;
  text-decoration: none;
}
.sn-btn:active { transform: scale(.97); }
.sn-btn-primary {
  background: var(--sn-primary); color: #fff;
  box-shadow: 0 2px 8px rgb(74 108 247 / .25);
}
.sn-btn-primary:hover { background: var(--sn-primary-dk); box-shadow: 0 4px 12px rgb(74 108 247 / .3); }
.sn-btn-secondary { background: var(--sn-primary-lt); color: var(--sn-primary); }
.sn-btn-secondary:hover { background: #dde5fd; }
.sn-btn-ghost { background: transparent; color: var(--sn-text-muted); border: 1.5px solid var(--sn-border); }
.sn-btn-ghost:hover { background: var(--sn-bg); }
.sn-btn-sm { padding: 6px 14px; font-size: .82rem; }
.sn-btn:disabled { opacity: .55; cursor: not-allowed; transform: none; }

/* ---------- Notices ---------- */
.sn-notice {
  padding: 12px 16px; border-radius: var(--sn-radius-sm);
  margin-bottom: 16px; font-size: .9rem; font-weight: 500; line-height: 1.5;
}
.sn-success { background: var(--sn-success-lt); color: var(--sn-success); border: 1px solid var(--sn-success-bd); }
.sn-error   { background: var(--sn-error-lt);   color: var(--sn-error);   border: 1px solid var(--sn-error-bd); }
.sn-info    { background: var(--sn-info-lt);    color: var(--sn-info);    border: 1px solid #bae6fd; }
.sn-warning { background: var(--sn-warning-lt); color: var(--sn-warning); border: 1px solid #fde68a; }

/* ---------- Loading Spinner ---------- */
.sn-loading {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  padding: 48px; color: var(--sn-text-muted); font-size: .9rem;
}
.sn-loading::before {
  content: ''; width: 20px; height: 20px;
  border: 2.5px solid var(--sn-border); border-top-color: var(--sn-primary);
  border-radius: 50%; animation: sn-spin .7s linear infinite; flex-shrink: 0;
}
@keyframes sn-spin { to { transform: rotate(360deg); } }

/* ---------- Table ---------- */
.sn-table-wrap { overflow-x: auto; border-radius: var(--sn-radius); }
table.sn-table { width: 100%; border-collapse: collapse; font-size: .88rem; background: var(--sn-white); }
table.sn-table thead tr { background: var(--sn-bg); border-bottom: 2px solid var(--sn-border); }
table.sn-table th {
  padding: 12px 14px; text-align: right; font-weight: 700;
  color: var(--sn-text-muted); font-size: .82rem; white-space: nowrap;
}
table.sn-table td {
  padding: 12px 14px; border-bottom: 1px solid var(--sn-border);
  color: var(--sn-text); vertical-align: middle;
}
table.sn-table tbody tr:last-child td { border-bottom: none; }
table.sn-table tbody tr:hover td { background: #f8fafc; }

/* ---------- Status Badges ---------- */
.sn-status {
  display: inline-flex; align-items: center;
  padding: 3px 10px; border-radius: 20px;
  font-size: .78rem; font-weight: 700; white-space: nowrap;
}
.sn-status-unassigned       { background: #fef9c3; color: #854d0e; }
.sn-status-assigned         { background: #dbeafe; color: #1e40af; }
.sn-status-invoiced         { background: #dcfce7; color: #166534; }
.sn-status-pending          { background: #fef9c3; color: #854d0e; }
.sn-status-paid             { background: #dcfce7; color: #166534; }
.sn-status-receipt_uploaded { background: #e0f2fe; color: #075985; }
.sn-status-cancelled        { background: #fee2e2; color: #991b1b; }

/* ---------- Invoice Page ---------- */
.sn-invoice-page { max-width: 600px; }
.sn-invoice-card { max-width: 580px; margin: 0 auto; }
.sn-invoice-header {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 12px;
  padding-bottom: 18px; margin-bottom: 20px;
  border-bottom: 2px dashed var(--sn-border);
}
.sn-invoice-header h2 { margin: 0; font-size: 1.2rem; font-weight: 700; }
.sn-invoice-code {
  font-family: var(--sn-font); font-weight: 700; letter-spacing:0;
  background: var(--sn-primary-lt); color: var(--sn-primary);
  padding: 5px 14px; border-radius: var(--sn-radius-sm);
  font-size: .95rem; letter-spacing: 1px;
}
.sn-invoice-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 0; border-bottom: 1px solid var(--sn-bg); gap: 12px;
}
.sn-invoice-row span { color: var(--sn-text-muted); font-size: .88rem; }
.sn-invoice-row strong { font-weight: 600; }
.sn-invoice-total {
  padding: 14px 0 0; margin-top: 8px;
  border-top: 2px solid var(--sn-border); border-bottom: none; font-size: 1.1rem;
}
.sn-invoice-total strong { color: var(--sn-primary); font-weight: 700; }
.sn-payment-section { margin-top: 24px; }
.sn-payment-section h3 { font-size: 1rem; font-weight: 700; margin-bottom: 16px; }
.sn-pay-methods { display: flex; gap: 12px; flex-wrap: wrap; }
.sn-pay-methods .sn-btn { flex: 1; min-width: 150px; }
.sn-card-info {
  margin-top: 20px; background: var(--sn-bg);
  border-radius: var(--sn-radius); padding: 20px; border: 1px solid var(--sn-border);
}
.sn-card-number {
  font-size: 1.5rem; font-family: var(--sn-font); letter-spacing: 0;
  text-align: center; padding: 14px;
  background: var(--sn-white); border-radius: var(--sn-radius-sm);
  border: 2px solid var(--sn-primary); color: var(--sn-text);
  margin: 12px 0; font-weight: 700;
  cursor: pointer; user-select: all;
}
.sn-card-owner { text-align: center; color: var(--sn-text-muted); font-size: .9rem; margin-bottom: 16px; }
.sn-card-info hr { border: none; border-top: 1px solid var(--sn-border); margin: 16px 0; }
.sn-card-info input[type="file"] {
  width: 100%; padding: 10px;
  border: 1.5px dashed var(--sn-border); border-radius: var(--sn-radius-sm);
  cursor: pointer; background: var(--sn-white); margin: 10px 0;
  font-family: var(--sn-font);
}
.sn-card-info input[type="file"]:hover { border-color: var(--sn-primary); }

/* ---------- Auth ---------- */
.sn-auth-wrap {
  direction: rtl; font-family: var(--sn-font);
  max-width: 440px; margin: 40px auto; color: var(--sn-text);
}
.sn-auth-wrap .sn-card { padding: 32px; }

/* ---------- Checkbox / Radio ---------- */
.sn-checkbox-list {
  max-height: 220px; overflow-y: auto;
  border: 1.5px solid var(--sn-border); border-radius: var(--sn-radius-sm);
  padding: 10px; display: flex; flex-wrap: wrap; gap: 6px; background: var(--sn-bg);
}
.sn-checkbox-list label {
  display: inline-flex; align-items: center; gap: 6px; font-size: .87rem;
  background: var(--sn-white); padding: 6px 12px; border-radius: 6px;
  cursor: pointer; border: 1px solid var(--sn-border); transition: background .12s, border-color .12s;
}
.sn-checkbox-list label:hover { background: var(--sn-primary-lt); border-color: var(--sn-primary); }
.sn-radio-group { display: flex; gap: 20px; flex-wrap: wrap; }
.sn-radio-group label { display: inline-flex; align-items: center; gap: 6px; cursor: pointer; font-size: .9rem; }
.sn-phone-list {
  max-height: 240px; overflow-y: auto;
  border: 1.5px solid var(--sn-border); border-radius: var(--sn-radius-sm); background: var(--sn-bg);
}
.sn-phone-item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 12px; border-bottom: 1px solid var(--sn-border); font-size: .88rem;
}
.sn-phone-item:last-child { border-bottom: none; }
.sn-phone-item:hover { background: var(--sn-white); }

/* ---------- My Account ---------- */
.sn-myaccount-invoices { direction: rtl; font-family: var(--sn-font); }
.sn-myaccount-invoices h3 { margin-bottom: 20px; font-size: 1.1rem; font-weight: 700; }
.sn-myaccount-invoices table { width: 100%; border-collapse: collapse; font-size: .88rem; }
.sn-myaccount-invoices table th {
  background: var(--sn-bg); padding: 10px 14px; text-align: right;
  font-weight: 700; color: var(--sn-text-muted); border-bottom: 2px solid var(--sn-border);
}
.sn-myaccount-invoices table td { padding: 12px 14px; border-bottom: 1px solid var(--sn-border); vertical-align: middle; }
.sn-myaccount-invoices table tr:last-child td { border-bottom: none; }
.sn-myaccount-invoices .sn-sub-content {
  background: #f0fdf4; border-right: 4px solid #16a34a; padding: 14px 16px;
}
.sn-empty { text-align: center; padding: 48px 24px; color: var(--sn-text-muted); }
.sn-empty p { font-size: .95rem; margin: 0; }
.sn-divider { border: none; border-top: 1px solid var(--sn-border); margin: 20px 0; }

/* ---------- Responsive ---------- */
@media (max-width: 640px) {
  .sn-form-grid { grid-template-columns: 1fr; }
  .sn-full { grid-column: 1; }
  .sn-pay-methods { flex-direction: column; }
  .sn-tabs { gap: 0; }
  .sn-tab { padding: 8px 14px; font-size: .85rem; }
  .sn-card { padding: 16px; }
}

/* ========================================================
   Auth Form — فرم ورود و ثبت‌نام فروشنده
   ======================================================== */
.sn-auth-wrap {
  direction: rtl;
  font-family: var(--sn-font);
  max-width: 460px;
  margin: 48px auto;
  padding: 0 16px;
  color: var(--sn-text);
}

.sn-auth-wrap .sn-auth-logo {
  text-align: center;
  margin-bottom: 28px;
}
.sn-auth-wrap .sn-auth-logo h2 {
  font-size: 1.4rem;
  font-weight: 800;
  color: var(--sn-text);
  margin: 0 0 6px;
}
.sn-auth-wrap .sn-auth-logo p {
  color: var(--sn-text-muted);
  font-size: .88rem;
  margin: 0;
}

/* کارت فرم */
.sn-auth-wrap .sn-auth-card {
  background: var(--sn-white);
  border: 1px solid var(--sn-border);
  border-radius: 20px;
  box-shadow: 0 8px 32px rgb(74 108 247 / .08), 0 2px 8px rgb(0 0 0 / .04);
  overflow: hidden;
}

/* تب‌های ورود/ثبت‌نام */
.sn-auth-wrap .sn-auth-tabs {
  display: flex;
  border-bottom: 1px solid var(--sn-border);
  background: var(--sn-bg);
}
.sn-auth-wrap .sn-auth-tab {
  flex: 1;
  padding: 14px;
  background: none;
  border: none;
  font-family: var(--sn-font);
  font-size: .9rem;
  font-weight: 600;
  color: var(--sn-text-muted);
  cursor: pointer;
  transition: color .15s, background .15s;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
}
.sn-auth-wrap .sn-auth-tab:hover { color: var(--sn-primary); background: var(--sn-white); }
.sn-auth-wrap .sn-auth-tab.active {
  color: var(--sn-primary);
  background: var(--sn-white);
  border-bottom-color: var(--sn-primary);
  font-weight: 700;
}

/* بدنه فرم */
.sn-auth-wrap .sn-auth-body {
  padding: 28px 28px 24px;
}

/* فیلدها */
.sn-auth-wrap .sn-field {
  margin-bottom: 18px;
}
.sn-auth-wrap .sn-field label {
  display: block;
  font-size: .85rem;
  font-weight: 600;
  color: var(--sn-text);
  margin-bottom: 7px;
}
.sn-auth-wrap .sn-field input {
  width: 100%;
  padding: 11px 16px;
  border: 1.5px solid var(--sn-border);
  border-radius: 10px;
  font-family: var(--sn-font);
  font-size: .93rem;
  color: var(--sn-text);
  background: var(--sn-white);
  transition: border-color .15s, box-shadow .15s;
  outline: none;
  direction: rtl;
}
.sn-auth-wrap .sn-field input:focus {
  border-color: var(--sn-primary);
  box-shadow: 0 0 0 3px rgb(74 108 247 / .12);
}
.sn-auth-wrap .sn-field input::placeholder { color: #94a3b8; font-size: .88rem; }

/* دکمه ارسال */
.sn-auth-wrap .sn-auth-submit {
  width: 100%;
  padding: 13px;
  background: var(--sn-primary);
  color: #fff;
  border: none;
  border-radius: 10px;
  font-family: var(--sn-font);
  font-size: .95rem;
  font-weight: 700;
  cursor: pointer;
  transition: background .15s, box-shadow .15s, transform .1s;
  box-shadow: 0 4px 14px rgb(74 108 247 / .28);
  margin-top: 4px;
}
.sn-auth-wrap .sn-auth-submit:hover {
  background: var(--sn-primary-dk);
  box-shadow: 0 6px 18px rgb(74 108 247 / .35);
}
.sn-auth-wrap .sn-auth-submit:active { transform: scale(.98); }

/* پیام خطا */
.sn-auth-wrap .sn-auth-error {
  background: var(--sn-error-lt);
  border: 1px solid var(--sn-error-bd);
  color: var(--sn-error);
  padding: 11px 16px;
  border-radius: 10px;
  font-size: .88rem;
  font-weight: 500;
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.sn-auth-wrap .sn-auth-error::before { content: '⚠️'; font-size: 1rem; }

/* فوتر کارت */
.sn-auth-wrap .sn-auth-footer {
  text-align: center;
  padding: 16px 28px 20px;
  border-top: 1px solid var(--sn-border);
  background: var(--sn-bg);
  font-size: .83rem;
  color: var(--sn-text-muted);
}

@media (max-width: 480px) {
  .sn-auth-wrap { margin: 24px auto; }
  .sn-auth-wrap .sn-auth-body { padding: 20px; }
}

/* Supervisor seller profile accordion */
.sn-supervisor-sellers-table .sn-seller-profile-row > td {
  padding: 0 !important;
  border-top: 0 !important;
}
.sn-supervisor-sellers-table .sn-seller-profile-panel {
  padding: 14px;
  background: #f0f9ff;
  border-right: 3px solid #3b82f6;
}
.sn-supervisor-sellers-table .sn-seller-profile.active,
.sn-supervisor-sellers-table .sn-seller-profile[aria-expanded="true"] {
  background: #2563eb;
  border-color: #2563eb;
  color: #fff;
}
.sn-seller-profile-card {
  margin: 0;
  box-shadow: none;
}
.sn-profile-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.sn-mini-stat {
  background: #ffffff;
  border: 1px solid #dbeafe;
  border-radius: 10px;
  padding: 10px;
}
.sn-mini-stat b {
  display: block;
  color: #64748b;
  font-size: 12px;
  margin-bottom: 4px;
}
.sn-mini-stat span {
  font-weight: 800;
  color: #1e293b;
}


/* SN Jalali payment picker */
.sn-jalali-picker{background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;padding:10px;margin-top:6px}
.sn-jalali-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap;direction:rtl}
.sn-jalali-row select{min-width:68px;border:1px solid #cbd5e1;border-radius:10px;padding:8px;background:#fff;font-family:inherit}
.sn-jalali-row .sn-time-sep{margin-right:8px;color:#475569;font-size:12px}
.sn-jalali-picker small{display:block;margin-top:6px;color:#64748b}
.sn-row-done{background:#f0fdf4!important}.sn-row-rejected{background:#fef2f2!important}

/* SN verified Jalali picker */
.sn-jalali-picker-box{background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;padding:12px;margin-top:8px;direction:rtl}
.sn-jalali-title{font-weight:700;margin-bottom:10px;color:#0f172a}
.sn-jalali-row{display:flex;flex-wrap:wrap;gap:8px;align-items:end}
.sn-jalali-row label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:#475569}
.sn-jalali-row select{min-width:78px;border:1px solid #cbd5e1;border-radius:10px;padding:7px 8px;background:#fff;direction:rtl}
.sn-jalali-selected{margin-top:10px;color:#334155;font-size:13px}
.sn-info{background:#e0f2fe!important;color:#075985!important;border-color:#7dd3fc!important}

/* =============================================================
   Sales Network — Modern Portal Theme v3
   افزوده شده برای تبدیل پنل‌ها به پورتال مدرن RTL با سایدبار
   بدون وابستگی خارجی / بدون تغییر منطق PHP و AJAX
   ============================================================= */
:root{
  --sn-modern-bg:#eef3fb;
  --sn-modern-surface:rgba(255,255,255,.88);
  --sn-modern-sidebar:#0f172a;
  --sn-modern-sidebar-2:#1e293b;
  --sn-modern-accent:#6366f1;
  --sn-modern-accent-2:#06b6d4;
  --sn-modern-green:#10b981;
  --sn-modern-orange:#f59e0b;
  --sn-modern-red:#ef4444;
  --sn-modern-radius:22px;
  --sn-modern-shadow:0 24px 70px rgba(15,23,42,.12);
  --sn-modern-shadow-soft:0 12px 36px rgba(15,23,42,.08);
}
body .sn-panel,
body .sn-invoice-page,
body .sn-auth-wrap{
  font-feature-settings:"ss01";
}
body .sn-panel{
  max-width:1240px;
  margin:26px auto;
  padding:18px;
  background:
    radial-gradient(circle at 95% 0%, rgba(99,102,241,.18), transparent 28%),
    radial-gradient(circle at 5% 100%, rgba(6,182,212,.14), transparent 32%),
    linear-gradient(135deg,#f8fafc 0%,var(--sn-modern-bg) 100%);
  border:1px solid rgba(148,163,184,.22);
  border-radius:30px;
  box-shadow:var(--sn-modern-shadow);
  display:grid;
  grid-template-columns:282px minmax(0,1fr);
  grid-template-rows:auto 1fr;
  gap:18px;
  overflow:hidden;
  position:relative;
}
body .sn-panel::before{
  content:"";
  position:absolute;
  inset:-80px auto auto -80px;
  width:230px;height:230px;
  border-radius:50%;
  background:rgba(99,102,241,.11);
  pointer-events:none;
  filter:blur(3px);
}
body .sn-panel-header{
  grid-column:1 / -1;
  margin:0;
  padding:18px 20px;
  border:1px solid rgba(226,232,240,.84);
  border-radius:24px;
  background:rgba(255,255,255,.72);
  box-shadow:var(--sn-modern-shadow-soft);
  backdrop-filter:blur(14px);
  position:relative;
  z-index:1;
}
body .sn-panel-header h2{
  font-size:1.35rem;
  letter-spacing:-.02em;
  display:flex;
  align-items:center;
  gap:10px;
}
body .sn-panel-header h2::before{
  content:"";
  width:42px;height:42px;
  border-radius:16px;
  background:linear-gradient(135deg,var(--sn-modern-accent),var(--sn-modern-accent-2));
  box-shadow:0 12px 26px rgba(99,102,241,.26);
  display:inline-block;
}
body .sn-panel-header form{margin-inline-start:auto!important}
body .sn-panel-header .sn-btn,
body .sn-panel-header button{
  border-radius:14px!important;
}
body .sn-panel > .sn-tabs{
  grid-column:1;
  grid-row:2;
  display:flex;
  flex-direction:column;
  gap:8px;
  overflow:visible;
  border:0;
  margin:0;
  min-height:580px;
  padding:18px;
  border-radius:26px;
  background:
    linear-gradient(180deg,rgba(15,23,42,.96),rgba(30,41,59,.96)),
    radial-gradient(circle at 0 0,rgba(99,102,241,.28),transparent 38%);
  box-shadow:0 24px 60px rgba(15,23,42,.22);
  position:sticky;
  top:18px;
  align-self:start;
}
body .sn-panel > .sn-tabs::before{
  content:"شبکه فروش";
  color:#fff;
  font-weight:900;
  font-size:1.05rem;
  padding:12px 14px 16px;
  margin-bottom:6px;
  border-bottom:1px solid rgba(255,255,255,.11);
  display:block;
}
body #sn-supervisor-panel > .sn-tabs::before{content:"پنل سرپرست"}
body #sn-seller-panel > .sn-tabs::before{content:"پنل فروشنده"}
body .sn-panel > .sn-tabs .sn-tab{
  width:100%;
  margin:0;
  padding:14px 14px;
  border:1px solid transparent;
  border-radius:16px;
  color:rgba(255,255,255,.72);
  background:transparent;
  text-align:right;
  font-weight:800;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:10px;
  transition:all .18s ease;
}
body .sn-panel > .sn-tabs .sn-tab::before{
  content:"•";
  width:28px;height:28px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:11px;
  background:rgba(255,255,255,.09);
  color:#cbd5e1;
  font-size:18px;
  line-height:1;
}
body .sn-panel > .sn-tabs .sn-tab:nth-child(1)::before{content:"👥"}
body .sn-panel > .sn-tabs .sn-tab:nth-child(2)::before{content:"🧾"}
body .sn-panel > .sn-tabs .sn-tab:nth-child(3)::before{content:"📊"}
body .sn-panel > .sn-tabs .sn-tab:nth-child(4)::before{content:"💼"}
body .sn-panel > .sn-tabs .sn-tab:nth-child(5)::before{content:"💳"}
body .sn-panel > .sn-tabs .sn-tab:hover{
  color:#fff;
  background:rgba(255,255,255,.08);
  transform:translateX(-2px);
}
body .sn-panel > .sn-tabs .sn-tab.active{
  color:#fff;
  background:linear-gradient(135deg,var(--sn-modern-accent),#8b5cf6);
  border-color:rgba(255,255,255,.12);
  box-shadow:0 16px 34px rgba(99,102,241,.32);
}
body .sn-panel > .sn-tabs .sn-tab.active::before{
  background:rgba(255,255,255,.2);
  color:#fff;
}
body .sn-panel > .sn-tab-content{
  grid-column:2;
  grid-row:2;
  min-width:0;
  background:rgba(255,255,255,.52);
  border:1px solid rgba(226,232,240,.72);
  border-radius:26px;
  padding:20px;
  box-shadow:var(--sn-modern-shadow-soft);
  backdrop-filter:blur(10px);
}
body .sn-panel > .sn-tab-content.active{
  animation:sn-modern-fade .22s ease both;
}
@keyframes sn-modern-fade{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:translateY(0)}
}
body .sn-card,
body .sn-invoice-card,
body .sn-auth-card{
  border:1px solid rgba(226,232,240,.82)!important;
  border-radius:24px!important;
  background:var(--sn-modern-surface)!important;
  box-shadow:var(--sn-modern-shadow-soft)!important;
  backdrop-filter:blur(14px);
}
body .sn-card h3{
  font-size:1.08rem;
  letter-spacing:-.01em;
}
body .sn-card h3::before{
  width:8px;
  height:28px;
  border-radius:999px;
  background:linear-gradient(180deg,var(--sn-modern-accent),var(--sn-modern-accent-2));
}
body .sn-field label{
  color:#334155;
  font-weight:900;
  font-size:.83rem;
}
body .sn-field input,
body .sn-field select,
body .sn-field textarea,
body .sn-panel input:not([type="checkbox"]):not([type="radio"]),
body .sn-panel select,
body .sn-panel textarea,
body .sn-invoice-page input:not([type="checkbox"]):not([type="radio"]),
body .sn-invoice-page select,
body .sn-invoice-page textarea{
  border-radius:15px!important;
  border:1px solid rgba(148,163,184,.42)!important;
  background:rgba(255,255,255,.9)!important;
  min-height:42px;
  box-shadow:0 1px 0 rgba(15,23,42,.03);
}
body .sn-field input:focus,
body .sn-field select:focus,
body .sn-field textarea:focus,
body .sn-panel input:focus,
body .sn-panel select:focus,
body .sn-panel textarea:focus,
body .sn-invoice-page input:focus,
body .sn-invoice-page select:focus,
body .sn-invoice-page textarea:focus{
  border-color:var(--sn-modern-accent)!important;
  box-shadow:0 0 0 4px rgba(99,102,241,.13)!important;
}
body .sn-btn,
body .sn-panel button,
body .sn-invoice-page button{
  border-radius:15px!important;
  min-height:40px;
  font-weight:900!important;
}
body .sn-btn-primary,
body .sn-panel .sn-btn-primary,
body .sn-invoice-page .sn-btn-primary{
  background:linear-gradient(135deg,var(--sn-modern-accent),#8b5cf6)!important;
  box-shadow:0 14px 28px rgba(99,102,241,.25)!important;
}
body .sn-btn-secondary,
body .sn-panel .sn-btn-secondary,
body .sn-invoice-page .sn-btn-secondary{
  background:#e0f2fe!important;
  color:#0369a1!important;
  border:1px solid #bae6fd!important;
}
body .sn-btn:hover,
body .sn-panel button:hover,
body .sn-invoice-page button:hover{
  transform:translateY(-1px);
}
body .sn-badge{
  border-radius:999px;
  min-height:28px;
  padding:4px 12px;
  background:linear-gradient(135deg,var(--sn-modern-red),#fb7185);
  box-shadow:0 8px 18px rgba(239,68,68,.18);
}
body .sn-supervisor-summary-card .sn-badge,
body #sn-sum-total,
body #sn-sum-assigned,
body #sn-sum-unassigned,
body #sn-sum-range{
  background:linear-gradient(135deg,var(--sn-modern-accent),var(--sn-modern-accent-2));
  min-width:54px;
  font-size:.95rem;
}
body .sn-supervisor-summary-card .sn-grid > div:not(.sn-field){
  padding:14px;
  border-radius:20px;
  background:linear-gradient(180deg,#fff,rgba(248,250,252,.88));
  border:1px solid rgba(226,232,240,.85);
}
body .sn-table-wrap,
body table.sn-table{
  border-radius:20px!important;
  overflow:hidden;
}
body table.sn-table{
  box-shadow:0 10px 26px rgba(15,23,42,.06);
}
body table.sn-table thead tr{
  background:linear-gradient(180deg,#f8fafc,#eef2ff)!important;
}
body table.sn-table th{
  color:#475569!important;
  font-weight:900!important;
}
body table.sn-table td{
  border-bottom-color:#edf2f7!important;
}
body table.sn-table tbody tr:hover td{
  background:#f8fbff!important;
}
body .sn-status{
  padding:5px 11px;
  border-radius:999px;
  font-weight:900;
}
body .sn-notice{
  border-radius:18px!important;
  box-shadow:0 10px 24px rgba(15,23,42,.05);
}
body .sn-loading{
  background:rgba(255,255,255,.58);
  border:1px dashed rgba(148,163,184,.45);
  border-radius:22px;
}
body .sn-checkbox-list,
body .sn-phone-list,
body #sn-sellers-table,
body #sn-leads-list,
body #sn-invoices-list,
body #sn-supervisor-invoice-list{
  border-radius:20px;
}
body .sn-radio-group,
body .sn-pay-methods{
  padding:10px;
  border-radius:18px;
  background:#f8fafc;
  border:1px solid #e2e8f0;
}
body .sn-auth-wrap{
  max-width:480px;
}
body .sn-auth-card{
  overflow:hidden;
}
body .sn-auth-wrap .sn-auth-submit{
  background:linear-gradient(135deg,var(--sn-modern-accent),#8b5cf6)!important;
  border-radius:16px!important;
}
body .sn-invoice-page{
  max-width:760px;
  padding:18px;
  border-radius:30px;
  background:linear-gradient(135deg,#f8fafc,#eef2ff);
  box-shadow:var(--sn-modern-shadow);
}
body .sn-invoice-row{
  border-bottom-color:#edf2f7;
}
body .sn-card-number{
  direction:ltr;
  letter-spacing:2px;
  font-weight:900;
  border-radius:18px;
  background:linear-gradient(135deg,#0f172a,#334155)!important;
  color:#fff!important;
  padding:16px!important;
  text-align:center;
}
body .sn-jalali-picker,
body .sn-jalali-picker-box{
  border-radius:20px!important;
  background:linear-gradient(180deg,#fff,#f8fafc)!important;
}
body .sn-jalali-row select{
  border-radius:14px!important;
}
@media (max-width: 1024px){
  body .sn-panel{
    grid-template-columns:230px minmax(0,1fr);
    padding:14px;
  }
  body .sn-panel > .sn-tabs{padding:14px;min-height:520px}
  body .sn-panel > .sn-tab-content{padding:16px}
}
@media (max-width: 820px){
  body .sn-panel{
    display:block;
    border-radius:22px;
    margin:14px auto;
  }
  body .sn-panel-header{margin-bottom:14px}
  body .sn-panel > .sn-tabs{
    position:relative;
    top:auto;
    min-height:0;
    flex-direction:row;
    overflow-x:auto;
    border-radius:22px;
    margin-bottom:14px;
    padding:10px;
  }
  body .sn-panel > .sn-tabs::before{display:none}
  body .sn-panel > .sn-tabs .sn-tab{
    min-width:max-content;
    padding:11px 12px;
  }
  body .sn-panel > .sn-tab-content{
    border-radius:22px;
    padding:14px;
  }
  body .sn-form-grid{grid-template-columns:1fr}
}
@media (max-width: 520px){
  body .sn-panel{padding:10px;background:#f8fafc}
  body .sn-panel-header{padding:14px;border-radius:18px}
  body .sn-panel-header h2{font-size:1.06rem}
  body .sn-panel-header h2::before{width:34px;height:34px;border-radius:13px}
  body .sn-card{padding:16px!important;border-radius:18px!important}
  body .sn-pay-methods .sn-btn{min-width:100%}
}

/* ============================================================
   Sales Network Advanced UI Pack: KPI, Dark Mode, Sticky Tables,
   Mobile UX, Skeleton Loading - no CDN dependencies
   ============================================================ */
body .sn-ui-toolbar{
  display:flex;
  justify-content:flex-end;
  margin-bottom:12px;
}
body .sn-dark-toggle{
  appearance:none;
  border:1px solid rgba(148,163,184,.35);
  background:rgba(255,255,255,.74);
  color:#0f172a;
  padding:9px 14px;
  border-radius:999px;
  cursor:pointer;
  font-weight:900;
  box-shadow:0 10px 22px rgba(15,23,42,.08);
  transition:.18s ease;
  margin-inline-start:auto;
}
body .sn-panel-header .sn-dark-toggle{
  position:relative;
  z-index:2;
}
body .sn-dark-toggle:hover{transform:translateY(-1px);box-shadow:0 14px 26px rgba(15,23,42,.12)}

body .sn-kpi-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
  margin:0 0 18px;
}
body .sn-kpi-card{
  position:relative;
  overflow:hidden;
  min-height:112px;
  padding:18px 18px 14px;
  border-radius:24px;
  background:linear-gradient(145deg,rgba(255,255,255,.92),rgba(248,250,252,.82));
  border:1px solid rgba(226,232,240,.9);
  box-shadow:0 16px 38px rgba(15,23,42,.075);
  isolation:isolate;
}
body .sn-kpi-card::before{
  content:"";
  position:absolute;
  inset:auto auto -48px -48px;
  width:132px;
  height:132px;
  border-radius:999px;
  background:radial-gradient(circle,rgba(99,102,241,.18),rgba(99,102,241,0) 70%);
  z-index:-1;
}
body .sn-kpi-card::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg,rgba(255,255,255,.45),rgba(255,255,255,0) 42%);
  pointer-events:none;
}
body .sn-kpi-icon{
  width:40px;
  height:40px;
  border-radius:16px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,#eef2ff,#e0f2fe);
  box-shadow:inset 0 0 0 1px rgba(99,102,241,.12);
  font-size:1.2rem;
  margin-bottom:10px;
}
body .sn-kpi-card small{
  display:block;
  color:#64748b;
  font-weight:900;
  margin-bottom:5px;
}
body .sn-kpi-card strong{
  display:block;
  color:#0f172a;
  font-size:1.45rem;
  line-height:1.25;
  font-weight:1000;
  letter-spacing:-.02em;
}
body .sn-kpi-card em{
  display:block;
  margin-top:6px;
  color:#64748b;
  font-size:.82rem;
  font-style:normal;
  font-weight:800;
}
body .sn-kpi-money::before{background:radial-gradient(circle,rgba(16,185,129,.18),rgba(16,185,129,0) 70%)}
body .sn-kpi-money .sn-kpi-icon{background:linear-gradient(135deg,#dcfce7,#ecfdf5)}

body .sn-table-wrap{
  max-width:100%;
  overflow:auto;
  border-radius:22px;
  -webkit-overflow-scrolling:touch;
}
body table.sn-table{
  border-collapse:separate!important;
  border-spacing:0!important;
}
body table.sn-table thead th{
  position:sticky;
  top:0;
  z-index:4;
  backdrop-filter:blur(10px);
  background:rgba(248,250,252,.94)!important;
  box-shadow:0 1px 0 rgba(226,232,240,.9);
}
body .sn-table-wrap table.sn-table thead th:first-child{border-start-start-radius:18px}
body .sn-table-wrap table.sn-table thead th:last-child{border-start-end-radius:18px}

body .sn-skeleton-card{
  background:#fff;
  border:1px solid #e2e8f0;
  border-radius:22px;
  padding:10px;
  box-shadow:0 12px 26px rgba(15,23,42,.05);
}
body .sn-skeleton-table td{padding:14px!important;border-bottom:1px solid #f1f5f9!important}
body .sn-skeleton-line{
  display:block;
  width:100%;
  max-width:190px;
  height:14px;
  border-radius:999px;
  background:linear-gradient(90deg,#e2e8f0 0%,#f8fafc 42%,#e2e8f0 76%);
  background-size:220% 100%;
  animation:snSkeletonShimmer 1.25s ease-in-out infinite;
}
body .sn-skeleton-table td:nth-child(2) .sn-skeleton-line{max-width:120px}
body .sn-skeleton-table td:nth-child(3) .sn-skeleton-line{max-width:260px}
@keyframes snSkeletonShimmer{0%{background-position:120% 0}100%{background-position:-120% 0}}

/* Better mobile tables: horizontal card-like rows */
@media (max-width: 680px){
  body .sn-kpi-grid{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
  body .sn-kpi-card{min-height:96px;padding:14px;border-radius:20px}
  body .sn-kpi-card strong{font-size:1.05rem}
  body .sn-kpi-card em{font-size:.74rem}
  body .sn-kpi-icon{width:34px;height:34px;border-radius:13px;margin-bottom:7px}
  body .sn-table-wrap{border-radius:18px;margin-inline:-4px;padding-bottom:4px}
  body table.sn-table{min-width:720px}
  body .sn-panel input,
  body .sn-panel select,
  body .sn-panel textarea{font-size:16px!important}
  body .sn-btn{min-height:42px}
}
@media (max-width: 420px){
  body .sn-kpi-grid{grid-template-columns:1fr}
  body .sn-dark-toggle{width:100%;justify-content:center}
}

/* Dark mode */
body.sn-dark-mode{
  background:#07111f!important;
  color:#e5eefb!important;
}
body.sn-dark-mode .sn-panel,
body.sn-dark-mode .sn-invoice-page{
  background:linear-gradient(135deg,#07111f,#111827)!important;
  color:#e5eefb!important;
}
body.sn-dark-mode .sn-panel-header,
body.sn-dark-mode .sn-tab-content,
body.sn-dark-mode .sn-card,
body.sn-dark-mode .sn-auth-card,
body.sn-dark-mode .sn-skeleton-card,
body.sn-dark-mode .sn-kpi-card,
body.sn-dark-mode .sn-table-wrap,
body.sn-dark-mode #sn-leads-list,
body.sn-dark-mode #sn-invoices-list,
body.sn-dark-mode #sn-sellers-table,
body.sn-dark-mode #sn-supervisor-invoice-list{
  background:linear-gradient(145deg,rgba(15,23,42,.95),rgba(30,41,59,.88))!important;
  border-color:rgba(71,85,105,.85)!important;
  color:#e5eefb!important;
  box-shadow:0 20px 44px rgba(0,0,0,.34)!important;
}
body.sn-dark-mode .sn-panel > .sn-tabs{
  background:linear-gradient(180deg,#0f172a,#111827)!important;
  border-color:rgba(71,85,105,.75)!important;
}
body.sn-dark-mode .sn-panel > .sn-tabs .sn-tab{
  color:#cbd5e1!important;
}
body.sn-dark-mode .sn-panel > .sn-tabs .sn-tab.active{
  color:#fff!important;
  background:linear-gradient(135deg,#6366f1,#8b5cf6)!important;
}
body.sn-dark-mode table.sn-table,
body.sn-dark-mode table.sn-table td,
body.sn-dark-mode table.sn-table th{
  color:#e5eefb!important;
  border-color:rgba(71,85,105,.65)!important;
}
body.sn-dark-mode table.sn-table thead th{
  background:rgba(15,23,42,.96)!important;
  color:#cbd5e1!important;
}
body.sn-dark-mode table.sn-table tbody tr,
body.sn-dark-mode table.sn-table tbody tr td{
  background:rgba(15,23,42,.68)!important;
}
body.sn-dark-mode table.sn-table tbody tr:hover td{background:rgba(30,41,59,.92)!important}
body.sn-dark-mode input,
body.sn-dark-mode select,
body.sn-dark-mode textarea{
  background:#0f172a!important;
  color:#f8fafc!important;
  border-color:#475569!important;
}
body.sn-dark-mode input::placeholder,
body.sn-dark-mode textarea::placeholder{color:#94a3b8!important}
body.sn-dark-mode .sn-kpi-card small,
body.sn-dark-mode .sn-kpi-card em,
body.sn-dark-mode .sn-panel-header p,
body.sn-dark-mode .sn-notice{color:#cbd5e1!important}
body.sn-dark-mode .sn-kpi-card strong{color:#fff!important}
body.sn-dark-mode .sn-dark-toggle{
  background:#0f172a;
  color:#fff;
  border-color:#475569;
}
body.sn-dark-mode .sn-skeleton-line{background:linear-gradient(90deg,#1e293b 0%,#334155 42%,#1e293b 76%);background-size:220% 100%}

/* ============================================================
   KPI / Summary layout fix - 2026-05-03
   جلوگیری از کارت‌های باریک و عمودی در پنل فروشنده/سرپرست
   ============================================================ */
body #sn-seller-kpi-cards,
body #sn-supervisor-kpi-cards,
body .sn-kpi-host{
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
  margin:0 0 18px !important;
  grid-column:auto !important;
}

body .sn-kpi-grid,
body .sn-seller-kpis,
body .sn-supervisor-kpis{
  display:grid !important;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr)) !important;
  gap:16px !important;
  width:100% !important;
  align-items:stretch !important;
  margin:0 !important;
}

body .sn-kpi-card{
  min-width:0 !important;
  min-height:118px !important;
  padding:18px 18px !important;
  display:grid !important;
  grid-template-columns:52px minmax(0,1fr) !important;
  grid-template-areas:
    "icon label"
    "icon value"
    "icon hint" !important;
  column-gap:14px !important;
  row-gap:4px !important;
  align-items:center !important;
  text-align:right !important;
  white-space:normal !important;
}

body .sn-kpi-icon{
  grid-area:icon !important;
  width:52px !important;
  height:52px !important;
  margin:0 !important;
  border-radius:18px !important;
  flex:0 0 52px !important;
}

body .sn-kpi-card small{
  grid-area:label !important;
  margin:0 !important;
  font-size:.88rem !important;
  line-height:1.45 !important;
  white-space:normal !important;
}

body .sn-kpi-card strong{
  grid-area:value !important;
  margin:0 !important;
  font-size:1.55rem !important;
  line-height:1.3 !important;
  white-space:normal !important;
  overflow-wrap:anywhere !important;
}

body .sn-kpi-card em{
  grid-area:hint !important;
  margin:0 !important;
  font-size:.8rem !important;
  line-height:1.6 !important;
  white-space:normal !important;
}

body .sn-supervisor-summary-card{
  width:100% !important;
  margin:0 0 18px !important;
  box-sizing:border-box !important;
}

body .sn-supervisor-summary-card .sn-grid{
  grid-template-columns:repeat(auto-fit, minmax(210px, 1fr)) !important;
  gap:14px !important;
  align-items:end !important;
}

body .sn-supervisor-summary-card .sn-grid > div:not(.sn-field){
  min-height:88px !important;
  padding:16px !important;
  border-radius:20px !important;
  display:flex !important;
  flex-direction:column !important;
  justify-content:center !important;
  gap:8px !important;
  text-align:right !important;
}

body .sn-supervisor-summary-card .sn-badge{
  align-self:flex-start !important;
  min-width:48px !important;
  text-align:center !important;
}

body .sn-supervisor-summary-card input[type="date"],
body .sn-supervisor-summary-card input[type="time"]{
  direction:ltr !important;
  text-align:center !important;
  min-height:48px !important;
}

body.sn-dark-mode .sn-kpi-card{
  background:linear-gradient(145deg, rgba(30,41,59,.95), rgba(15,23,42,.9)) !important;
  border-color:rgba(148,163,184,.22) !important;
}
body.sn-dark-mode .sn-supervisor-summary-card .sn-grid > div:not(.sn-field){
  background:rgba(15,23,42,.72) !important;
  border-color:rgba(148,163,184,.22) !important;
}

@media (max-width: 980px){
  body .sn-kpi-grid,
  body .sn-seller-kpis,
  body .sn-supervisor-kpis{
    grid-template-columns:repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 560px){
  body .sn-kpi-grid,
  body .sn-seller-kpis,
  body .sn-supervisor-kpis{
    grid-template-columns:1fr !important;
  }
  body .sn-kpi-card{
    grid-template-columns:46px minmax(0,1fr) !important;
    min-height:104px !important;
    padding:15px !important;
  }
  body .sn-kpi-icon{width:46px !important;height:46px !important;flex-basis:46px !important}
  body .sn-supervisor-summary-card .sn-grid{
    grid-template-columns:1fr !important;
  }
}


/* ============================================================
   Full-width portal layout fix - 2026-05-04
   رفع مشکل فول نشدن پنل‌ها داخل قالب وردپرس و پنل‌های بدون تب
   ============================================================ */
body.sn-portal-page,
body.sn-portal-page #page,
body.sn-portal-page .site,
body.sn-portal-page .site-main,
body.sn-portal-page .content-area,
body.sn-portal-page .entry-content,
body.sn-portal-page .wp-site-blocks,
body.sn-portal-page .wp-block-post-content,
body.sn-portal-page .elementor,
body.sn-portal-page .elementor-section,
body.sn-portal-page .elementor-container,
body.sn-portal-page .elementor-widget-container{
  overflow-x:clip;
}
body.sn-portal-page .entry-content,
body.sn-portal-page .wp-block-post-content,
body.sn-portal-page .site-main > article,
body.sn-portal-page .page-content,
body.sn-portal-page .content-area,
body.sn-portal-page .elementor-container,
body.sn-portal-page .elementor-column,
body.sn-portal-page .elementor-widget-wrap{
  max-width:none !important;
  width:100% !important;
}
body.sn-portal-page .entry-content > .sn-panel,
body.sn-portal-page .wp-block-post-content > .sn-panel,
body.sn-portal-page .elementor-widget-container > .sn-panel,
body .sn-panel{
  width:min(1360px, calc(100vw - 48px)) !important;
  max-width:min(1360px, calc(100vw - 48px)) !important;
  box-sizing:border-box !important;
}
body .sn-panel > .sn-tab-content,
body .sn-panel > .sn-tab-content.active{
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
  box-sizing:border-box !important;
  overflow:visible !important;
}
body .sn-panel > .sn-tab-content > .sn-card,
body .sn-panel > .sn-tab-content > .sn-table-wrap,
body .sn-panel > .sn-tab-content > div[id$="-list"],
body .sn-panel > .sn-tab-content > div[id$="-loading"],
body .sn-panel > .sn-tab-content > form,
body .sn-panel .sn-card,
body .sn-panel .sn-wallet-card{
  width:100% !important;
  max-width:100% !important;
  box-sizing:border-box !important;
}
body .sn-panel table.sn-table,
body .sn-panel table.widefat,
body .sn-panel .sn-table-wrap table{
  width:100% !important;
}

/* پنل‌هایی مثل تایید مالی/خدمات پس از فروش که تب ندارند نباید مثل دو ستونه رندر شوند */
body .sn-panel.sn-no-sidebar,
body .sn-panel:not(:has(> .sn-tabs)){
  display:block !important;
  grid-template-columns:none !important;
  grid-template-rows:none !important;
  min-height:auto !important;
}
body .sn-panel.sn-no-sidebar > .sn-panel-header,
body .sn-panel:not(:has(> .sn-tabs)) > .sn-panel-header{
  display:flex !important;
  width:100% !important;
  margin-bottom:22px !important;
}
body .sn-panel.sn-no-sidebar > table,
body .sn-panel:not(:has(> .sn-tabs)) > table,
body .sn-panel.sn-no-sidebar > .widefat,
body .sn-panel:not(:has(> .sn-tabs)) > .widefat{
  width:100% !important;
  display:table !important;
  margin:0 !important;
  border-radius:22px !important;
  overflow:hidden !important;
}
body .sn-panel.sn-no-sidebar .widefat,
body .sn-panel.sn-no-sidebar .sn-table,
body .sn-panel:not(:has(> .sn-tabs)) .widefat,
body .sn-panel:not(:has(> .sn-tabs)) .sn-table{
  width:100% !important;
}

/* جلوگیری از فشرده شدن کارت کیف پول فروشنده */
body #sn-tab-wallet,
body #sn-tab-wallet.active{
  align-self:stretch !important;
}
body #sn-tab-wallet .sn-card,
body #sn-tab-wallet .sn-wallet-box,
body #sn-tab-wallet table{
  width:100% !important;
  max-width:100% !important;
}
body #sn-tab-wallet table{
  table-layout:auto !important;
}

/* جدول تایید مالی روی صفحه کامل و خواناتر */
body #sn-financial-panel .widefat,
body #sn-financial-panel .sn-table{
  border-collapse:separate !important;
  border-spacing:0 !important;
  font-size:14px !important;
}
body #sn-financial-panel .widefat th,
body #sn-financial-panel .widefat td{
  padding:14px 12px !important;
  vertical-align:middle !important;
  white-space:normal !important;
}
body #sn-financial-panel .widefat thead th{
  position:sticky !important;
  top:0 !important;
  z-index:3 !important;
}

@media (min-width: 1440px){
  body.sn-portal-page .entry-content > .sn-panel,
  body.sn-portal-page .wp-block-post-content > .sn-panel,
  body.sn-portal-page .elementor-widget-container > .sn-panel,
  body .sn-panel{
    width:min(1480px, calc(100vw - 64px)) !important;
    max-width:min(1480px, calc(100vw - 64px)) !important;
  }
}
@media (max-width: 980px){
  body.sn-portal-page .entry-content > .sn-panel,
  body.sn-portal-page .wp-block-post-content > .sn-panel,
  body.sn-portal-page .elementor-widget-container > .sn-panel,
  body .sn-panel{
    width:calc(100vw - 24px) !important;
    max-width:calc(100vw - 24px) !important;
    margin:12px auto !important;
  }
  body .sn-panel > .sn-tab-content{
    grid-column:1 !important;
    grid-row:auto !important;
  }
}
