
:root{
  --bg:#f6f8fc;
  --panel:#ffffff;
  --panel-2:#f9fbff;
  --text:#0f172a;
  --muted:#667085;
  --line:#e5eaf2;
  --primary:#2f4bff;
  --primary-2:#6b35ff;
  --primary-soft:#eef1ff;
  --success:#12b76a;
  --success-soft:#e9f8ef;
  --warning:#f79009;
  --warning-soft:#fff4e5;
  --danger:#f04438;
  --danger-soft:#ffefef;
  --info:#0ea5e9;
  --info-soft:#e7f7ff;
  --dark:#06152f;
  --dark-2:#0b1f45;
  --shadow:0 18px 40px rgba(16,24,40,.08);
  --shadow-sm:0 8px 22px rgba(16,24,40,.07);
  --radius:22px;
  --radius-sm:14px;
  --sidebar:280px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Tahoma, Arial, system-ui, sans-serif;
  direction:rtl;
  background:radial-gradient(circle at top left, rgba(47,75,255,.08), transparent 34%), var(--bg);
  color:var(--text);
}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font-family:inherit}
button{cursor:pointer;border:0}

html.modal-open,body.modal-open{overflow:hidden!important}
body.modal-open{position:fixed;width:100%;left:0;right:0}
.modal-backdrop{overscroll-behavior:contain}
.modal{overscroll-behavior:contain}
.layout{min-height:100vh;display:flex}
.sidebar{
  width:var(--sidebar);
  min-height:100vh;
  position:fixed;
  right:0;
  top:0;
  padding:24px 18px;
  color:#fff;
  background:
    radial-gradient(circle at 25% 10%, rgba(79,114,255,.36), transparent 24%),
    linear-gradient(180deg,#071735 0%,#061023 100%);
  overflow-y:auto;
  box-shadow:-18px 0 40px rgba(2,8,23,.08);
  z-index:30;
}
.brand{display:flex;align-items:center;gap:12px;margin-bottom:26px;padding:0 6px}
.brand-mark{width:42px;height:42px;border-radius:15px;background:linear-gradient(135deg,var(--primary),var(--primary-2));display:grid;place-items:center;box-shadow:0 12px 30px rgba(47,75,255,.35)}
.brand-mark svg{width:24px;height:24px}
.brand-title{font-size:23px;font-weight:800;letter-spacing:.5px}
.brand-title span{color:#6680ff}
.brand-subtitle{font-size:12px;color:#bac5d8;margin-top:4px}
.sidebar-user{display:flex;align-items:center;gap:12px;padding:14px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.05);border-radius:18px;margin-bottom:18px}
.avatar{width:38px;height:38px;border-radius:14px;background:linear-gradient(135deg,#fff,#bdc8ff);color:#0d1b3a;display:grid;place-items:center;font-weight:800}
.sidebar-user strong{display:block;font-size:13px}
.sidebar-user small{color:#aab7cc;font-size:11px}
.nav-section{margin-top:16px;color:#71809b;font-size:11px;padding:0 12px 8px}
.nav{display:grid;gap:6px}
.nav a{display:flex;align-items:center;gap:11px;padding:12px 13px;border-radius:15px;color:#d6def2;font-size:14px;transition:.2s ease}
.nav a:hover,.nav a.active{background:linear-gradient(90deg,rgba(47,75,255,.98),rgba(107,53,255,.82));color:#fff;box-shadow:0 12px 24px rgba(47,75,255,.22)}
.nav svg{width:18px;height:18px;flex:0 0 auto;stroke-width:2}
.sidebar-footer{margin-top:24px;padding:16px;border-radius:20px;background:linear-gradient(135deg,rgba(47,75,255,.16),rgba(255,255,255,.05));border:1px solid rgba(255,255,255,.1)}
.sidebar-footer h4{margin:0 0 8px;font-size:14px}
.sidebar-footer p{margin:0;color:#b7c2d6;font-size:12px;line-height:1.8}
.main{margin-right:var(--sidebar);width:calc(100% - var(--sidebar));padding:24px}
.topbar{height:74px;display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px}
.page-title h1{font-size:25px;margin:0 0 7px;font-weight:850;letter-spacing:-.5px}
.page-title p{margin:0;color:var(--muted);font-size:13px}
.top-actions{display:flex;align-items:center;gap:10px}
.search{height:44px;min-width:260px;border:1px solid var(--line);border-radius:16px;background:#fff;padding:0 16px;color:var(--text);box-shadow:0 8px 24px rgba(16,24,40,.04)}
.icon-btn{width:44px;height:44px;border-radius:16px;background:#fff;color:var(--text);border:1px solid var(--line);display:grid;place-items:center;box-shadow:0 8px 24px rgba(16,24,40,.04)}
.primary-btn,.secondary-btn,.danger-btn,.ghost-btn{height:44px;border-radius:15px;padding:0 17px;font-weight:800;display:inline-flex;align-items:center;gap:9px;justify-content:center;transition:.2s ease;white-space:nowrap}
.primary-btn{background:linear-gradient(90deg,var(--primary),var(--primary-2));color:#fff;box-shadow:0 14px 24px rgba(47,75,255,.22)}
.primary-btn:hover{transform:translateY(-1px);box-shadow:0 18px 30px rgba(47,75,255,.27)}
.secondary-btn{background:#fff;color:var(--primary);border:1px solid #dce2ff}
.danger-btn{background:var(--danger-soft);color:var(--danger)}
.ghost-btn{background:transparent;color:var(--muted)}
.menu-toggle{display:none}
.grid{display:grid;gap:18px}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.card{background:rgba(255,255,255,.92);border:1px solid rgba(229,234,242,.9);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:20px;backdrop-filter:blur(14px)}
.card.tight{padding:16px}
.card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:16px}
.card-title{margin:0;font-size:17px;font-weight:850;letter-spacing:-.2px}
.card-subtitle{margin:6px 0 0;color:var(--muted);font-size:12px;line-height:1.6}
.metric{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;min-height:126px;position:relative;overflow:hidden}
.metric-icon{width:48px;height:48px;border-radius:17px;background:var(--primary-soft);color:var(--primary);display:grid;place-items:center}
.metric-icon.success{background:var(--success-soft);color:var(--success)}
.metric-icon.warning{background:var(--warning-soft);color:var(--warning)}
.metric-icon.danger{background:var(--danger-soft);color:var(--danger)}
.metric-label{font-size:12px;color:var(--muted);margin-bottom:9px}
.metric-value{font-size:25px;font-weight:900;margin-bottom:8px;letter-spacing:-.6px}
.metric-change{font-size:12px;color:var(--success);font-weight:700}
.metric-change.down{color:var(--danger)}
.chart-wrap{height:260px;position:relative}
canvas{max-width:100%}
.table-wrap{overflow:auto;border-radius:18px;border:1px solid var(--line)}
table{width:100%;border-collapse:collapse;min-width:760px;background:#fff}
th,td{padding:14px 16px;text-align:right;border-bottom:1px solid var(--line);font-size:13px;white-space:nowrap}
th{background:#f8faff;color:#667085;font-size:12px;font-weight:800}
tr:last-child td{border-bottom:0}
tbody tr:hover{background:#fbfcff}
.status{display:inline-flex;align-items:center;gap:7px;border-radius:999px;padding:7px 11px;font-size:12px;font-weight:850}
.status:before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor}
.status.paid,.status.success{color:var(--success);background:var(--success-soft)}
.status.pending{color:var(--warning);background:var(--warning-soft)}
.status.failed,.status.expired{color:var(--danger);background:var(--danger-soft)}
.status.created,.status.info{color:var(--info);background:var(--info-soft)}
.status.cancelled{color:#667085;background:#f1f3f8}
.filters{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.input,.select,.textarea{width:100%;min-height:46px;border:1px solid var(--line);background:#fff;border-radius:15px;padding:0 14px;color:var(--text);outline:none;transition:.2s ease}
.textarea{padding:12px 14px;min-height:104px;resize:vertical;line-height:1.7}
.input:focus,.select:focus,.textarea:focus{border-color:#b6c0ff;box-shadow:0 0 0 4px rgba(47,75,255,.08)}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.form-group label{display:block;margin:0 0 8px;color:#344054;font-size:13px;font-weight:850}
.form-group small{display:block;margin-top:7px;color:var(--muted);font-size:11px;line-height:1.5}
.summary-box{background:linear-gradient(135deg,#f8faff,#fff);border:1px solid var(--line);border-radius:20px;padding:18px}
.summary-row{display:flex;align-items:center;justify-content:space-between;padding:11px 0;border-bottom:1px dashed #d8deea;font-size:13px;gap:14px}
.summary-row:last-child{border-bottom:0}
.summary-row strong{font-size:18px}
.code-card{background:#071327;color:#d8e9ff;border-radius:18px;padding:18px;direction:ltr;text-align:left;overflow:auto;border:1px solid rgba(255,255,255,.08);box-shadow:inset 0 0 0 1px rgba(255,255,255,.04)}
.code-card pre{margin:0;font-family:Consolas,Monaco,monospace;font-size:12px;line-height:1.75;white-space:pre-wrap}
.copyable{position:relative}
.copy-btn{position:absolute;top:12px;left:12px;height:34px;border-radius:11px;background:rgba(255,255,255,.1);color:#fff;padding:0 12px;font-size:12px}
.timeline{position:relative;display:grid;gap:14px}
.timeline-item{display:grid;grid-template-columns:34px 1fr;gap:12px;align-items:flex-start}
.timeline-dot{width:32px;height:32px;border-radius:12px;background:var(--primary-soft);color:var(--primary);display:grid;place-items:center;font-size:13px;font-weight:900}
.timeline-content{border:1px solid var(--line);border-radius:17px;padding:13px;background:#fff}
.timeline-content strong{display:block;font-size:13px;margin-bottom:5px}
.timeline-content p{margin:0;color:var(--muted);font-size:12px;line-height:1.7}
.progress{display:flex;align-items:center;gap:8px;margin-top:16px;overflow:auto;padding-bottom:4px}
.step{display:flex;align-items:center;gap:8px;color:#98a2b3;font-size:12px;font-weight:800;white-space:nowrap}
.step .circle{width:30px;height:30px;border-radius:50%;background:#edf1f7;display:grid;place-items:center}
.step.done{color:var(--success)}.step.done .circle{background:var(--success-soft)}
.step.active{color:var(--primary)}.step.active .circle{background:var(--primary-soft)}
.step-line{width:54px;height:2px;background:#e4e7ec;flex:0 0 auto}.step-line.done{background:var(--success)}
.checkout-page{min-height:100vh;display:grid;grid-template-columns:1fr 460px;background:linear-gradient(135deg,#f8faff 0%,#eef3ff 100%);direction:rtl}
.checkout-hero{padding:48px;display:flex;flex-direction:column;justify-content:space-between;background:
radial-gradient(circle at 20% 20%, rgba(47,75,255,.18), transparent 28%),
linear-gradient(180deg,#071735,#061023);color:#fff;min-height:100vh}
.checkout-hero .brand-title{font-size:36px}.checkout-hero p{color:#c6d0e4;line-height:1.9;max-width:520px}
.security-list{display:grid;gap:16px;margin-top:34px}
.security-item{display:flex;gap:12px;align-items:flex-start;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.10);padding:15px;border-radius:18px}
.security-item strong{display:block;margin-bottom:5px}.security-item small{color:#b7c3d8;line-height:1.6}
.checkout-panel{padding:40px;display:flex;align-items:center;justify-content:center}
.checkout-card{width:100%;max-width:440px;background:#fff;border-radius:28px;padding:25px;border:1px solid #e5eaf2;box-shadow:0 30px 80px rgba(16,24,40,.14)}
.pay-method{display:flex;align-items:center;justify-content:space-between;padding:16px;border:1px solid #d7ddff;border-radius:18px;margin-top:12px;background:#fbfcff}
.pay-method.selected{border-color:var(--primary);box-shadow:0 0 0 4px rgba(47,75,255,.08)}
.provider-logo{width:44px;height:44px;border-radius:16px;background:linear-gradient(135deg,#10b981,#20d0ff);display:grid;place-items:center;color:#fff;font-size:11px;font-weight:900}
.result-success{display:none;text-align:center;padding:20px 0}.result-success.show{display:block}.pay-form.hide{display:none}
.big-check{width:78px;height:78px;margin:0 auto 16px;border-radius:50%;background:var(--success-soft);color:var(--success);display:grid;place-items:center;font-size:40px;font-weight:900}
.kpi-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.kpi-mini{padding:14px;border:1px solid var(--line);border-radius:17px;background:#fff}.kpi-mini span{display:block;color:var(--muted);font-size:11px;margin-bottom:7px}.kpi-mini strong{font-size:17px}
.modal-backdrop{position:fixed;inset:0;background:rgba(2,8,23,.45);z-index:90;display:none;align-items:center;justify-content:center;padding:22px}.modal-backdrop.show{display:flex}
.modal{width:min(620px,100%);background:#fff;border-radius:26px;padding:22px;box-shadow:0 30px 90px rgba(2,8,23,.28)}
.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.modal-header h3{margin:0}.close-modal{width:38px;height:38px;border-radius:13px;background:#f2f4f7}
.toast{position:fixed;bottom:24px;left:24px;background:#071327;color:#fff;padding:13px 16px;border-radius:16px;box-shadow:0 18px 40px rgba(2,8,23,.25);z-index:120;opacity:0;transform:translateY(16px);transition:.25s}.toast.show{opacity:1;transform:translateY(0)}
.empty-state{text-align:center;padding:36px;color:var(--muted)}
.badge{display:inline-flex;align-items:center;gap:6px;padding:7px 10px;border-radius:999px;background:var(--primary-soft);color:var(--primary);font-weight:850;font-size:12px}
.alert{padding:14px 16px;border-radius:17px;line-height:1.8;font-size:13px}.alert.info{background:var(--info-soft);color:#0369a1}.alert.warning{background:var(--warning-soft);color:#9a5700}.alert.success{background:var(--success-soft);color:#087443}
.api-key-box{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#f8faff;border:1px dashed #b8c2ff;border-radius:18px;padding:14px;direction:ltr;text-align:left}
.api-key-box code{font-family:Consolas,Monaco,monospace;color:#0f172a;font-size:12px;word-break:break-all}
.login-page{min-height:100vh;display:grid;place-items:center;padding:22px;background:
radial-gradient(circle at 20% 20%,rgba(47,75,255,.18),transparent 28%),linear-gradient(135deg,#071735,#061023)}
.login-card{width:min(440px,100%);background:#fff;border-radius:28px;padding:28px;box-shadow:0 30px 90px rgba(0,0,0,.25)}
.login-card .brand{color:#071327;justify-content:center;margin-bottom:24px}.login-card h1{text-align:center;margin:0 0 8px}.login-card p{text-align:center;margin:0 0 24px;color:var(--muted)}
@media(max-width:1180px){.grid-4{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(2,1fr)}.checkout-page{grid-template-columns:1fr}.checkout-hero{min-height:auto}.checkout-panel{padding:24px}}
@media(max-width:880px){:root{--sidebar:0px}.sidebar{transform:translateX(105%);transition:.25s;width:280px}.sidebar.open{transform:translateX(0)}.main{margin-right:0;width:100%;padding:18px}.menu-toggle{display:grid}.topbar{height:auto;align-items:flex-start}.top-actions{flex-wrap:wrap;justify-content:flex-end}.search{min-width:100%;order:3}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.form-grid{grid-template-columns:1fr}.checkout-hero{padding:32px 22px}.checkout-panel{padding:22px}.kpi-row{grid-template-columns:1fr}.page-title h1{font-size:21px}}
@media(max-width:540px){.topbar{flex-direction:column}.top-actions{width:100%}.primary-btn,.secondary-btn,.danger-btn{width:100%}.card{padding:16px}.checkout-card{padding:18px;border-radius:22px}.sidebar{width:86vw}.main{padding:14px}.checkout-hero .brand-title{font-size:28px}}


/* --- Modal-first creation updates --- */
.nav button{width:100%;border:0;background:transparent;color:#c9d5ea;display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:15px;font-weight:800;cursor:pointer;font:inherit;text-align:right;transition:.2s ease}
.nav button svg{width:20px;height:20px;stroke-width:2}.nav button:hover{background:rgba(255,255,255,.08);color:#fff}
.modal.large{width:min(920px,100%)}.modal-scroll{max-height:calc(100vh - 120px);overflow:auto;padding-left:4px}.modal-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-start;margin-top:16px}.readonly-chip{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 15px;background:#f8faff;border:1px solid #d9e3ff;border-radius:16px;color:#18345f;font-weight:850}.readonly-chip small{font-weight:700;color:var(--muted)}
.inline-note{padding:12px 14px;border-radius:16px;background:#f8fafc;border:1px dashed #d0d5dd;color:#475467;line-height:1.8}.table-actions{display:flex;gap:8px;flex-wrap:wrap}.export-btn{background:#ecfdf3;color:#047857;border:1px solid #bbf7d0}.export-btn:hover{background:#dcfce7}.section-spacer{margin-top:18px}
.mini-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}.mini-tab{border:1px solid var(--border);background:#fff;color:#344054;border-radius:999px;padding:9px 14px;font-weight:850}.mini-tab.active{background:#eef2ff;color:#2538d8;border-color:#c7d2fe}


/* --- index.html refinements --- */
.notification-btn{position:relative}.notification-dot{position:absolute;top:-5px;left:-5px;min-width:19px;height:19px;padding:0 5px;border-radius:999px;background:var(--danger);color:#fff;border:2px solid #fff;display:grid;place-items:center;font-size:10px;font-weight:900;line-height:1}.notification-dot.is-hidden{display:none}
.daily-revenue-card{position:relative;overflow:hidden;background:linear-gradient(135deg,#ffffff 0%,#f4f7ff 52%,#eef4ff 100%)}.daily-revenue-card:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 12% 20%,rgba(47,75,255,.15),transparent 26%),radial-gradient(circle at 88% 12%,rgba(14,165,233,.13),transparent 24%);pointer-events:none}.daily-revenue-card>*{position:relative;z-index:1}.daily-revenue-card .chart-wrap{background:rgba(255,255,255,.66);border:1px solid rgba(199,210,254,.75);border-radius:22px;padding:12px}.revenue-card-body{display:grid;grid-template-columns:190px 1fr;gap:14px;align-items:stretch}.revenue-total{border:1px solid rgba(199,210,254,.85);background:rgba(255,255,255,.78);border-radius:22px;padding:18px;display:flex;flex-direction:column;justify-content:center;gap:7px}.revenue-total span{font-size:12px;color:var(--muted);font-weight:800}.revenue-total strong{font-size:22px;line-height:1.35}.revenue-total small{color:var(--success);font-weight:800;line-height:1.6}.notifications-list{display:grid;gap:10px}.notification-item{display:grid;grid-template-columns:42px 1fr;gap:12px;align-items:flex-start;border:1px solid var(--line);background:#fff;border-radius:18px;padding:13px}.notification-item.unread{background:#f8faff;border-color:#dbe3ff}.notification-icon{width:40px;height:40px;border-radius:15px;display:grid;place-items:center;font-weight:900}.notification-icon.danger{background:var(--danger-soft);color:var(--danger)}.notification-icon.success{background:var(--success-soft);color:var(--success)}.notification-icon.info{background:var(--info-soft);color:var(--info)}.notification-item strong{display:block;margin-bottom:5px;font-size:13px}.notification-item p{margin:0 0 5px;color:var(--muted);line-height:1.7;font-size:12px}.notification-item small{color:#98a2b3;font-size:11px}
@media(max-width:720px){.revenue-card-body{grid-template-columns:1fr}.revenue-total strong{font-size:19px}}

/* --- merchants.html advanced merchant modal controls --- */
.is-hidden{display:none!important}
.conditional-box{padding:16px;border:1px solid var(--line);border-radius:20px;background:linear-gradient(180deg,#fff,#f9fbff)}
.section-mini-title{font-weight:900;color:#101828;margin-bottom:13px;display:flex;align-items:center;gap:8px}
.section-mini-title:before{content:"";width:9px;height:9px;border-radius:999px;background:linear-gradient(135deg,var(--primary),var(--primary-2));box-shadow:0 0 0 5px rgba(47,75,255,.08)}
.link-btn{border:0;background:transparent;color:var(--primary);font-weight:900;padding:0 4px;text-decoration:underline;text-underline-offset:4px}
.small-muted{color:var(--muted);font-size:12px;margin-top:8px;line-height:1.7}
.gateway-summary{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border:1px dashed #c6d0f7;border-radius:16px;background:#fff}
.gateway-summary span{font-size:13px;color:#344054;font-weight:800;line-height:1.6}
.tier-rows,.gateway-methods{display:grid;gap:12px}
.tier-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr)) auto;gap:12px;align-items:end;padding:14px;border:1px solid var(--line);border-radius:18px;background:#fbfcff}
.tier-remove{height:44px;align-self:end}
.gateway-method-card{padding:16px;border:1px solid var(--line);border-radius:20px;background:#fbfcff;box-shadow:0 10px 24px rgba(16,24,40,.04)}
.gateway-method-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.gateway-method-head strong{font-size:14px}
@media(max-width:900px){.tier-row{grid-template-columns:1fr 1fr}.tier-remove{grid-column:1/-1;width:100%}.gateway-summary{align-items:flex-start;flex-direction:column}.gateway-summary .secondary-btn{width:100%}}
@media(max-width:540px){.tier-row{grid-template-columns:1fr}}

/* v6: commission per payment method */
.modal.xl{width:min(1120px,100%)}
.badge.soft{background:#f2f4f7;color:#344054;white-space:normal;border-radius:12px;line-height:1.5}
.gateway-summary.always-visible{display:flex}
.gateway-method-head small{display:block;color:var(--muted);font-size:12px;margin-top:4px}
.gateway-tier-box{margin-top:14px;padding:13px;border:1px dashed #b8c4ff;border-radius:16px;background:#f8faff;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.gateway-tier-box small{display:block;color:var(--muted);margin-top:4px}
.gateway-credentials{margin-top:14px;padding:14px;border:1px solid #fedf89;border-radius:18px;background:#fffbeb}
.gateway-credentials .section-mini-title{margin-bottom:6px}
.gateway-credentials small{color:#92400e;font-weight:700}
@media(max-width:760px){.modal.xl{width:100%}.gateway-tier-box{align-items:flex-start;flex-direction:column}.gateway-tier-box .secondary-btn{width:100%}}

/* v7: stacked modal fix - keep commission tiers modal above payment methods / merchant modal */
#createMerchantModal.show{z-index:110}
#merchantGatewayModal.show{z-index:130}
#tieredCommissionModal.show{z-index:170;background:rgba(2,8,23,.58)}
#tieredCommissionModal .modal{box-shadow:0 36px 110px rgba(2,8,23,.38)}


/* v9: invoice bulk upload screen */
.bulk-steps .step-card{display:flex;align-items:flex-start;gap:14px;padding:18px}.step-card span{width:38px;height:38px;border-radius:14px;display:grid;place-items:center;background:#f2f4f7;color:#344054;font-weight:900;flex:0 0 auto}.step-card.active span{background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff}.step-card strong{display:block;margin-bottom:6px}.step-card p{margin:0;color:var(--muted);line-height:1.7;font-size:12px}
.upload-dropzone{border:1.5px dashed #b8c5ff;background:linear-gradient(135deg,#fbfcff,#f4f7ff);border-radius:24px;padding:30px;text-align:center;display:grid;justify-items:center;gap:10px;transition:.2s ease}.upload-dropzone.drag-over{background:#eef2ff;border-color:var(--primary);transform:translateY(-1px)}.upload-dropzone h3{margin:4px 0 0}.upload-dropzone p{margin:0;color:var(--muted);line-height:1.8}.upload-icon{width:62px;height:62px;border-radius:22px;display:grid;place-items:center;background:#fff;color:var(--primary);box-shadow:var(--shadow-sm)}.upload-icon svg{width:30px;height:30px;stroke-width:2}.selected-file{margin-top:8px;padding:10px 13px;border-radius:14px;background:#fff;border:1px solid #d9e3ff;color:#18345f;font-weight:850;direction:ltr;text-align:left;max-width:100%;word-break:break-word}.upload-progress{height:10px;background:#eef2ff;border-radius:999px;overflow:hidden;margin-top:14px}.upload-progress span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--primary),var(--primary-2));transition:.45s ease;border-radius:999px}.column-map{display:grid;gap:10px}.column-map>div{padding:13px 14px;border:1px solid var(--line);border-radius:16px;background:#fff;display:flex;align-items:center;justify-content:space-between;gap:12px}.column-map strong{direction:ltr;text-align:left;font-family:Consolas,Monaco,monospace;color:#0f172a}.column-map small{color:var(--muted);line-height:1.7;text-align:right}.mini-stat{padding:18px}.mini-stat span{color:var(--muted);font-size:12px;font-weight:850}.mini-stat strong{display:block;font-size:25px;margin:8px 0 4px}.mini-stat small{color:var(--muted)}.mini-stat.success strong{color:var(--success)}.mini-stat.warning strong{color:var(--warning)}.row-error-note{color:var(--danger);font-weight:800}.row-valid-note{color:var(--success);font-weight:800}.bulk-row-error{background:#fffafa}.bulk-row-valid{background:#fcfffd}
@media(max-width:760px){.column-map>div{align-items:flex-start;flex-direction:column}.bulk-steps .step-card{align-items:flex-start}.upload-dropzone{padding:22px}.mini-stat strong{font-size:21px}}


/* v10: bulk import result download modal */
.result-download-card{display:grid;grid-template-columns:74px 1fr auto;gap:16px;align-items:center;padding:18px;border:1px solid #c7d2fe;border-radius:22px;background:linear-gradient(135deg,#f8faff,#eef4ff);box-shadow:var(--shadow-sm)}
.result-file-icon{width:64px;height:64px;border-radius:20px;display:grid;place-items:center;background:#fff;color:var(--primary);font-weight:950;letter-spacing:.5px;box-shadow:var(--shadow-sm)}
.result-download-card strong{display:block;margin-bottom:6px;font-size:15px}.result-download-card p{margin:0 0 5px;color:var(--muted);line-height:1.7}.result-download-card small{color:#475467;font-weight:800}
#bulkImportResultModal.show{z-index:150;background:rgba(2,8,23,.54)}
@media(max-width:760px){.result-download-card{grid-template-columns:1fr;text-align:center}.result-file-icon{margin:auto}.result-download-card .primary-btn{width:100%}}


/* v11: modal scrolling fix + bulk operation workflow */
.modal-backdrop.show{display:flex;overflow-y:auto;align-items:flex-start;justify-content:center}
.modal-backdrop.show .modal{max-height:calc(100vh - 44px);overflow-y:auto;margin:22px 0}
.modal-backdrop.show .modal .modal-scroll{max-height:none;overflow:visible}
.operation-overview .operation-guide-card{position:relative;overflow:hidden;min-height:150px}.operation-guide-no{width:42px;height:42px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;font-weight:950;margin-bottom:14px}.operation-guide-card h3{margin:0 0 8px;font-size:16px}.operation-guide-card p{margin:0;color:var(--muted);line-height:1.8;font-size:13px}.operation-hero{display:flex;align-items:center;justify-content:space-between;gap:18px;background:radial-gradient(circle at 15% 15%,rgba(47,75,255,.12),transparent 28%),linear-gradient(135deg,#fff,#f8faff)}.operation-hero h2{margin:10px 0 8px;font-size:24px}.operation-hero p{margin:0;color:var(--muted);line-height:1.8}.operation-hero-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.badge{display:inline-flex;align-items:center;gap:7px;border-radius:999px;padding:8px 12px;background:#eef2ff;color:var(--primary);font-weight:900;font-size:12px}.table-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
@media(max-width:760px){.operation-hero{align-items:flex-start;flex-direction:column}.operation-hero-actions{width:100%}.operation-hero-actions .secondary-btn{width:100%}.modal-backdrop{padding:14px}.modal-backdrop.show .modal{max-height:calc(100vh - 28px);margin:14px 0}}

/* v14: keep upload labels and history filters on one line */
.upload-format-badge{white-space:nowrap;flex-shrink:0}
.upload-history-header{align-items:center}
.upload-history-filters{margin:0;flex-wrap:nowrap;justify-content:flex-end;min-width:460px}
.upload-history-filters .input{width:260px;max-width:260px;flex:0 0 260px}
.upload-history-filters .select{width:180px;max-width:180px;flex:0 0 180px}
@media(max-width:980px){.upload-history-header{align-items:flex-start;flex-direction:column}.upload-history-filters{width:100%;min-width:0;justify-content:flex-start}.upload-history-filters .input{width:260px;flex:0 0 260px}.upload-history-filters .select{width:180px;flex:0 0 180px}}
@media(max-width:520px){.upload-history-filters{flex-wrap:wrap}.upload-history-filters .input,.upload-history-filters .select{width:100%;max-width:none;flex:1 1 100%}}

/* v17: merchant actions dropdown + API keys modal */
.merchant-actions-table{overflow:visible}
.action-dropdown{position:relative;display:inline-flex;justify-content:flex-end}
.action-toggle span{font-size:14px;line-height:1;transform:translateY(-1px)}
.action-menu{position:absolute;top:calc(100% + 8px);left:0;min-width:210px;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:0 18px 45px rgba(16,24,40,.16);padding:8px;display:none;z-index:80;text-align:right}
.action-dropdown.open .action-menu{display:grid;gap:4px}
.action-menu a,.action-menu button{width:100%;min-height:38px;border-radius:12px;background:transparent;color:#344054;font-weight:800;font-size:13px;padding:0 12px;display:flex;align-items:center;justify-content:flex-start;text-align:right;white-space:nowrap}
.action-menu a:hover,.action-menu button:hover{background:#f8faff;color:var(--primary)}
.action-menu button.danger{color:var(--danger)}
.action-menu button.danger:hover{background:var(--danger-soft);color:var(--danger)}
.api-keys-table-wrap table{min-width:700px}
@media(max-width:760px){.merchant-actions-table{overflow:auto}.action-menu{left:auto;right:0}}


/* v18: SMS settings screen */
.sms-overview{margin-bottom:18px}
.sms-provider-form{display:grid;gap:16px}
.sms-test-box{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px;border:1px dashed #c7d2fe;border-radius:18px;background:linear-gradient(135deg,#fff,#f8faff)}
.sms-test-box strong{display:block;margin-bottom:5px}.sms-test-box p{margin:0;color:var(--muted);font-size:12px;line-height:1.7}
.sms-template-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.sms-template-card{border:1px solid var(--line);border-radius:22px;background:linear-gradient(180deg,#fff,#fbfcff);padding:18px;box-shadow:0 10px 26px rgba(16,24,40,.04)}
.sms-template-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:14px}.sms-template-head h3{margin:0 0 6px;font-size:16px}.sms-template-head p{margin:0;color:var(--muted);font-size:12px;line-height:1.7}
.switch{position:relative;display:inline-flex;align-items:center;cursor:pointer}.switch input{display:none}.switch span{width:54px;height:30px;border-radius:999px;background:#e4e7ec;display:block;position:relative;transition:.2s}.switch span:before{content:"";position:absolute;width:24px;height:24px;border-radius:50%;background:#fff;top:3px;right:3px;box-shadow:0 4px 12px rgba(16,24,40,.18);transition:.2s}.switch input:checked+span{background:linear-gradient(90deg,var(--primary),var(--primary-2))}.switch input:checked+span:before{right:27px}
.sms-variables{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.variable-chip{height:34px;border-radius:999px;background:#eef2ff;color:var(--primary);padding:0 12px;font-size:12px;font-weight:900;border:1px solid #dbe3ff}.variable-chip:hover{background:#e0e7ff}
.sms-template-text{min-height:132px}.sms-template-footer{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:10px}.sms-template-footer span{font-size:12px;color:var(--muted);font-weight:800}
.sms-preview{margin-top:12px;padding:13px;border-radius:17px;background:#f8faff;border:1px solid #dbe3ff;color:#344054;line-height:1.8;font-size:13px;min-height:52px}.sms-preview:empty:before{content:"المعاينة ستظهر هنا بعد الضغط على زر معاينة";color:#98a2b3}
#smsConnectionResultModal.show{z-index:140;background:rgba(2,8,23,.52)}
@media(max-width:980px){.sms-template-grid{grid-template-columns:1fr}.sms-test-box{align-items:flex-start;flex-direction:column}.sms-test-box .secondary-btn{width:100%}}
@media(max-width:540px){.sms-template-head{align-items:flex-start}.sms-template-footer{align-items:flex-start;flex-direction:column}.sms-template-footer .secondary-btn{width:100%}}

/* v19: Fix sidebar/menu scrolling */
.sidebar{
  height:100vh;
  max-height:100dvh;
  overflow-y:auto;
  overflow-x:hidden;
  overscroll-behavior:contain;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:thin;
  scrollbar-color:rgba(255,255,255,.28) transparent;
}
.sidebar::-webkit-scrollbar{width:8px}
.sidebar::-webkit-scrollbar-track{background:transparent}
.sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.22);border-radius:999px}
.sidebar::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.34)}
.nav{padding-bottom:10px}
@media(max-width:880px){
  .sidebar{height:100dvh;max-height:100dvh;overflow-y:auto}
}

/* v21: Users and permissions screen */
.users-header{align-items:center}
.users-filters{margin:0;justify-content:flex-end;flex-wrap:nowrap;min-width:620px}
.users-filters .input{width:260px;max-width:260px;flex:0 0 260px}
.users-filters .select{width:170px;max-width:170px;flex:0 0 170px}
.user-cell{display:flex;align-items:center;gap:10px}.avatar.sm{width:34px;height:34px;border-radius:12px;font-size:11px}.user-cell strong{display:block;margin-bottom:3px}.user-cell small{display:block;color:var(--muted);font-size:11px;direction:ltr;text-align:right}.secondary-btn.small,.primary-btn.small,.danger-btn.small{min-height:34px;padding:0 11px;border-radius:12px;font-size:12px}.users-table-wrap table{min-width:1120px}
.role-card{display:grid;grid-template-columns:52px 1fr auto;gap:14px;align-items:center}.role-card h3{margin:0 0 6px;font-size:15px}.role-card p{margin:0;color:var(--muted);font-size:12px;line-height:1.7}.role-icon{width:52px;height:52px;border-radius:18px;display:grid;place-items:center;font-weight:950;color:#fff;box-shadow:var(--shadow-sm)}.role-icon.admin{background:linear-gradient(135deg,var(--primary),var(--primary-2))}.role-icon.support{background:linear-gradient(135deg,#0ea5e9,#2563eb)}.role-icon.merchant{background:linear-gradient(135deg,#12b76a,#0ea5e9)}
.permission-matrix{display:grid;gap:8px;overflow:auto}.permission-row{display:grid;grid-template-columns:1.3fr repeat(4,120px);gap:8px;align-items:center;min-width:760px}.permission-row>span:first-child{font-weight:850;color:#344054}.permission-head{padding:0 0 7px;border-bottom:1px solid var(--line);color:var(--muted);font-size:12px;font-weight:900}.permission-head span:not(:first-child){text-align:center}.permission-pill{height:36px;border-radius:999px;font-size:12px;font-weight:900;border:1px solid transparent}.permission-pill.allowed{color:var(--success);background:var(--success-soft);border-color:#b8f2d1}.permission-pill.denied{color:var(--danger);background:var(--danger-soft);border-color:#ffd0d0}.permission-checks{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:16px}.permission-checks label,.check-line{display:flex;align-items:center;gap:8px;padding:12px 13px;border:1px solid var(--line);background:#fff;border-radius:15px;color:#344054;font-weight:800;font-size:13px}.danger-dot{background:var(--danger-soft)!important;color:var(--danger)!important}.warning-dot{background:var(--warning-soft)!important;color:var(--warning)!important}.login-attempts-list .timeline-content{min-height:70px}
@media(max-width:1120px){.users-header{align-items:flex-start;flex-direction:column}.users-filters{width:100%;min-width:0;justify-content:flex-start}.users-filters .input{width:260px;flex:0 0 260px}.users-filters .select{width:170px;flex:0 0 170px}.role-card{grid-template-columns:52px 1fr}.role-card .status{grid-column:1/-1;width:max-content}}
@media(max-width:640px){.users-filters{flex-wrap:wrap}.users-filters .input,.users-filters .select{width:100%;max-width:none;flex:1 1 100%}.permission-checks{grid-template-columns:1fr}.role-card{grid-template-columns:1fr}.role-icon{margin-bottom:4px}}
/* v23: direct per-user permissions without roles */
.permission-summary-card{display:grid;grid-template-columns:52px 1fr auto;gap:14px;align-items:center}.permission-summary-card h3{margin:0 0 6px;font-size:15px}.permission-summary-card p{margin:0;color:var(--muted);font-size:12px;line-height:1.7}.users-filters.no-role-filter{min-width:620px}.users-table-wrap table{min-width:1040px}.permission-tags{display:flex;align-items:center;gap:7px;flex-wrap:wrap}.permission-tags span{display:inline-flex;align-items:center;min-height:28px;padding:4px 10px;border-radius:999px;background:#f2f4f7;border:1px solid var(--line);color:#344054;font-size:12px;font-weight:850}.permission-options-preview{display:grid;gap:14px}.permission-section{padding:14px;border:1px solid var(--line);border-radius:18px;background:linear-gradient(180deg,#fff,#f8fafc)}.permission-section h3{margin:0 0 10px;font-size:14px;color:#101828}.permission-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:18px 0 12px;padding:12px 14px;border:1px solid var(--line);border-radius:18px;background:#f8fafc}.permission-toolbar h4{margin:0;font-size:15px}.toolbar-actions{display:flex;gap:8px;flex-wrap:wrap}.permission-groups{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.permission-group{padding:14px;border:1px solid var(--line);border-radius:18px;background:#fff}.permission-group h4{margin:0 0 10px;color:#101828;font-size:14px}.permission-group label{display:flex;align-items:center;gap:8px;padding:10px 0;color:#344054;font-size:13px;font-weight:800;border-bottom:1px dashed #eaecf0}.permission-group label:last-child{border-bottom:0}.permission-group input[type="checkbox"],.permission-toolbar input[type="checkbox"]{width:16px;height:16px;accent-color:var(--primary)}
@media(max-width:1120px){.permission-summary-card{grid-template-columns:52px 1fr}.permission-summary-card .status{grid-column:1/-1;width:max-content}.users-filters.no-role-filter{min-width:0}.permission-groups{grid-template-columns:1fr}}
@media(max-width:640px){.permission-summary-card{grid-template-columns:1fr}.permission-toolbar{align-items:flex-start;flex-direction:column}.toolbar-actions{width:100%}.toolbar-actions .secondary-btn{flex:1}}

/* v24: users table action dropdown */
.users-actions-table{overflow:visible}
.users-actions-table table{min-width:940px}
.users-actions-table .action-dropdown{width:100%;justify-content:flex-start}
@media(max-width:760px){.users-actions-table{overflow:auto}.users-actions-table .action-menu{left:auto;right:0}}


/* v25: user action confirmation */
.user-confirm-modal{z-index:105}
.confirm-warning{margin-top:14px;padding:13px 14px;border:1px solid #ffd7a8;background:#fff8ed;color:#9a5b00;border-radius:16px;font-weight:800;font-size:13px;line-height:1.8}
.user-confirm-modal .modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:16px;flex-wrap:wrap}
@media(max-width:540px){.user-confirm-modal .modal-actions .primary-btn,.user-confirm-modal .modal-actions .danger-btn,.user-confirm-modal .modal-actions .secondary-btn{width:100%}}


/* v27: forced password change after first login */
.force-password-page{min-height:100vh;display:grid;place-items:center;padding:28px;background:radial-gradient(circle at 18% 12%,rgba(47,75,255,.18),transparent 30%),linear-gradient(135deg,#071327 0%,#0a1c3d 45%,#f6f8fc 45%,#eef3ff 100%)}
.force-password-card{width:min(1120px,100%);display:grid;grid-template-columns:430px 1fr;background:#fff;border-radius:32px;overflow:hidden;box-shadow:0 34px 90px rgba(2,8,23,.28);border:1px solid rgba(255,255,255,.42)}
.force-password-aside{padding:34px;background:radial-gradient(circle at 20% 20%,rgba(102,128,255,.32),transparent 28%),linear-gradient(180deg,#071735,#061023);color:#fff;display:flex;flex-direction:column;gap:18px;min-height:620px}
.force-brand{margin:0 0 14px;color:#fff}.force-password-aside h1{margin:12px 0 0;font-size:30px;line-height:1.35;letter-spacing:-.8px}.force-password-aside p{margin:0;color:#c2cce0;line-height:1.9;font-size:14px}.security-badge{display:inline-flex;width:max-content;align-items:center;border-radius:999px;padding:9px 13px;background:rgba(255,255,255,.11);border:1px solid rgba(255,255,255,.14);font-weight:900;font-size:12px;color:#e9edff}.force-security-list{display:grid;gap:12px;margin-top:6px}.force-security-list div{display:grid;grid-template-columns:42px 1fr;gap:10px;align-items:flex-start;padding:14px;border-radius:18px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.10)}.force-security-list span{width:34px;height:34px;border-radius:13px;display:grid;place-items:center;background:linear-gradient(135deg,var(--primary),var(--primary-2));font-weight:950}.force-security-list strong{display:block;font-size:13px;margin-bottom:4px}.force-security-list small{display:block;color:#b9c6dc;line-height:1.6;font-size:11px}.force-password-form-wrap{padding:34px}.force-password-header{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:22px}.force-password-header h2{margin:0 0 7px;font-size:24px}.force-password-header p{margin:0;color:var(--muted);line-height:1.7}.user-chip{display:flex;align-items:center;gap:10px;border:1px solid var(--line);background:#f8faff;border-radius:18px;padding:10px 12px;white-space:nowrap}.user-chip>span{width:38px;height:38px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;font-weight:950}.user-chip strong{display:block;font-size:13px}.user-chip small{display:block;color:var(--muted);font-size:11px;margin-top:3px}.password-field{position:relative}.password-field .input{padding-left:78px}.password-eye{position:absolute;left:8px;bottom:8px;height:30px;border-radius:11px;background:#f3f6ff;color:var(--primary);font-weight:900;font-size:12px;padding:0 11px}.password-strength-card{border:1px solid var(--line);background:linear-gradient(135deg,#fbfcff,#fff);border-radius:22px;padding:18px}.strength-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.strength-head span{font-size:12px;color:var(--muted);font-weight:900}.strength-bar{height:10px;background:#eef2ff;border-radius:999px;overflow:hidden}.strength-bar span{display:block;width:0;height:100%;background:#98a2b3;border-radius:999px;transition:.25s ease}.strength-bar span.weak{background:var(--danger);width:25%}.strength-bar span.medium{background:var(--warning);width:55%}.strength-bar span.good{background:var(--info);width:78%}.strength-bar span.strong{background:var(--success);width:100%}.password-rules{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:14px}.password-rules span{border:1px solid var(--line);background:#fff;border-radius:14px;padding:10px 12px;color:var(--muted);font-weight:850;font-size:12px}.password-rules span.valid{color:var(--success);background:var(--success-soft);border-color:#b8f2d1}.password-rules span.invalid{color:var(--danger);background:var(--danger-soft);border-color:#ffd0d0}.force-note{display:flex;gap:12px;border:1px solid #c7d2fe;background:#f6f8ff;border-radius:18px;padding:14px}.force-note strong{color:var(--primary);font-size:13px;white-space:nowrap}.force-note p{margin:0;color:#475467;line-height:1.8;font-size:12px}.force-actions{justify-content:flex-start}
@media(max-width:900px){.force-password-card{grid-template-columns:1fr}.force-password-aside{min-height:auto}.force-password-header{flex-direction:column}.user-chip{width:100%}.password-rules{grid-template-columns:1fr}.force-password-page{padding:14px;background:#eef3ff}.force-password-aside h1{font-size:24px}}


/* v30 additional screens only - existing v28 pages are preserved */
.inline-filters,.report-filters{display:flex;align-items:center;gap:10px;flex-wrap:nowrap;margin:14px 0}.inline-filters .input{min-width:260px}.inline-filters .select{min-width:170px}.code-box{border:1px solid var(--line);background:#0b1220;color:#e6edf7;border-radius:18px;padding:14px;overflow:auto;direction:ltr;text-align:left}.code-box strong{display:block;color:#fff;margin-bottom:10px;direction:rtl;text-align:right}.code-box pre{margin:0;white-space:pre-wrap;line-height:1.7;font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:12px}.support-search-hero{display:grid;grid-template-columns:1fr minmax(360px,520px);gap:18px;align-items:center;background:linear-gradient(135deg,#081a3f,#112d64);color:#fff}.support-search-hero h2{margin:0 0 8px;font-size:24px}.support-search-hero p{margin:0;color:#d8e1ff;line-height:1.8}.support-search-box{display:flex;gap:10px}.support-search-box .input{background:#fff}.quick-links-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.quick-card{display:flex;align-items:center;justify-content:center;min-height:74px;padding:14px;border:1px solid var(--line);border-radius:18px;background:#f8faff;color:#1f2a44;font-weight:900;text-align:center}.quick-card:hover{border-color:#b7c4ff;background:#eef3ff}.trace-timeline .timeline-dot{background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff}.merchant-profile-card{text-align:center;display:grid;place-items:center;gap:10px}.profile-logo{width:86px;height:86px;border-radius:28px;display:grid;place-items:center;background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;font-size:28px;font-weight:950;box-shadow:var(--shadow)}.merchant-profile-card h2{margin:0}.merchant-profile-card p{margin:0;color:var(--muted)}.payment-status-page{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at 20% 10%,rgba(47,75,255,.18),transparent 32%),linear-gradient(135deg,#eef3ff,#ffffff);padding:24px}.payment-status-card{width:min(560px,100%);background:#fff;border:1px solid var(--line);box-shadow:0 30px 80px rgba(15,23,42,.18);border-radius:32px;padding:34px;text-align:center}.payment-status-card h1{margin:14px 0 8px;font-size:28px}.payment-status-card p{color:var(--muted);line-height:1.8;margin:0 0 18px}.payment-status-mark{width:88px;height:88px;margin:0 auto;border-radius:30px;display:grid;place-items:center;color:#fff;font-size:40px;font-weight:950}.payment-status-mark.success{background:linear-gradient(135deg,#12b76a,#069455)}.payment-status-mark.danger{background:linear-gradient(135deg,#f04438,#b42318)}.payment-status-mark.warning{background:linear-gradient(135deg,#f79009,#b54708)}.payment-status-mark.info{background:linear-gradient(135deg,#0ea5e9,#2563eb)}.status-safe-note{margin-top:18px;color:var(--muted);font-size:12px;line-height:1.8}.readonly-chip{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:12px 14px;border:1px solid var(--line);background:#f8fafc;border-radius:16px}.readonly-chip span{font-weight:900}.readonly-chip small{color:var(--muted)}
@media(max-width:900px){.support-search-hero{grid-template-columns:1fr}.support-search-box{flex-direction:column}.inline-filters,.report-filters{flex-wrap:wrap}.inline-filters .input,.inline-filters .select,.report-filters .input,.report-filters .select{min-width:0;width:100%;flex:1 1 100%}.quick-links-grid{grid-template-columns:1fr}.payment-status-card{padding:24px}.payment-status-card h1{font-size:22px}}

/* v31: grouped support menu without changing existing icon style */
.nav-group{border-radius:15px;color:#d6def2}
.nav-parent{display:flex;align-items:center;gap:11px;padding:12px 13px;border-radius:15px;color:#d6def2;font-size:14px;transition:.2s ease;cursor:pointer;user-select:none;list-style:none}
.nav-parent::-webkit-details-marker{display:none}
.nav-parent:hover,.nav-group[open]>.nav-parent{background:linear-gradient(90deg,rgba(47,75,255,.98),rgba(107,53,255,.82));color:#fff;box-shadow:0 12px 24px rgba(47,75,255,.22)}
.nav-parent svg:not(.nav-chevron){width:18px;height:18px;flex:0 0 auto;stroke-width:2}
.nav-parent span{flex:1}
.nav-chevron{width:16px!important;height:16px!important;flex:0 0 auto;transition:.2s ease;opacity:.75}
.nav-group[open] .nav-chevron{transform:rotate(180deg)}
.nav-submenu{display:grid;gap:4px;margin:6px 0 6px;padding:7px;background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.08);border-radius:16px}
.nav-submenu a{padding:10px 11px;font-size:12.5px;border-radius:13px}
.nav-submenu a svg{width:16px;height:16px}
.nav-sub-label{padding:10px 11px 4px;color:#8fa0bd;font-size:11px;font-weight:900}
.nav-submenu a.active{background:rgba(47,75,255,.75);color:#fff;box-shadow:none}

.row-actions{display:flex;align-items:center;gap:8px;flex-wrap:nowrap}.row-actions .primary-btn,.row-actions .secondary-btn{white-space:nowrap}
@media(max-width:700px){.row-actions{flex-wrap:wrap}}
/* v33: ترتيب المنيو حسب أقسام الإدارة والتاجر */
.nav .nav-inline-section{
  margin-top:10px;
  padding-top:10px;
  border-top:1px solid rgba(255,255,255,.08);
}
.nav .nav-inline-section:first-child{
  margin-top:0;
  padding-top:0;
  border-top:0;
}

/* Force password screen: keep requested titles on one line */
.force-password-header h2,
.force-security-list strong{
  white-space: nowrap;
}
.force-security-list strong{
  font-size: 12.5px;
}
@media(max-width:520px){
  .force-password-header h2{font-size: 20px;}
  .force-security-list strong{font-size: 12px;}
}


/* v35: stronger forced-password no-wrap fixes */
.force-nowrap,
.force-nowrap-title{
  white-space: nowrap !important;
  word-break: keep-all !important;
  overflow-wrap: normal !important;
}
.force-security-list div{
  grid-template-columns: 34px minmax(0,1fr);
}
.force-security-list strong.force-nowrap{
  font-size: 12px;
  letter-spacing: -.2px;
}
.force-password-header h2.force-nowrap-title{
  font-size: 22px;
  line-height: 1.4;
}
@media(max-width:520px){
  .force-security-list div{grid-template-columns: 30px minmax(0,1fr);padding:12px;gap:8px;}
  .force-security-list span{width:28px;height:28px;border-radius:10px;}
  .force-security-list strong.force-nowrap{font-size:11px;}
  .force-password-header h2.force-nowrap-title{font-size:19px;}
}

/* v36: fix force-change-password security steps text layout */
.force-security-list div{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) 42px !important;
  grid-template-areas:
    "title num"
    "desc num" !important;
  align-items:start !important;
  column-gap:12px !important;
  row-gap:4px !important;
  direction:ltr;
}
.force-security-list div > span{
  grid-area:num !important;
  justify-self:end;
}
.force-security-list div > strong{
  grid-area:title !important;
  text-align:right;
  direction:rtl;
  min-width:0;
  margin-bottom:0 !important;
  white-space:nowrap !important;
  word-break:keep-all !important;
}
.force-security-list div > small{
  grid-area:desc !important;
  text-align:right;
  direction:rtl;
  min-width:0;
  line-height:1.75 !important;
  white-space:normal !important;
  word-break:normal !important;
  overflow-wrap:normal !important;
}
@media(max-width:520px){
  .force-security-list div{
    grid-template-columns:minmax(0,1fr) 34px !important;
    column-gap:9px !important;
  }
  .force-security-list div > strong{font-size:11.5px !important;}
  .force-security-list div > small{font-size:10.5px !important;}
}


/* v39: merchant SaaS domain field */
.domain-input-wrap{
  display:flex;
  align-items:center;
  gap:0;
  border:1px solid var(--line);
  border-radius:14px;
  background:#fff;
  overflow:hidden;
}
.domain-input-wrap .input{
  border:0 !important;
  border-radius:0 !important;
  flex:1;
  min-width:0;
  direction:ltr;
  text-align:left;
}
.domain-input-wrap span{
  align-self:stretch;
  display:flex;
  align-items:center;
  padding:0 14px;
  border-right:1px solid var(--line);
  background:#f6f8ff;
  color:var(--muted);
  font-weight:900;
  direction:ltr;
  white-space:nowrap;
}
.field-hint{
  display:block;
  margin-top:7px;
  color:var(--muted);
  font-size:11px;
  line-height:1.7;
}


/* v40: merchant SaaS domain field inside generated merchant modal */
.domain-input-wrap{
  display:flex;
  align-items:center;
  gap:0;
  border:1px solid var(--line);
  border-radius:14px;
  background:#fff;
  overflow:hidden;
}
.domain-input-wrap .input{
  border:0 !important;
  border-radius:0 !important;
  flex:1;
  min-width:0;
  direction:ltr;
  text-align:left;
}
.domain-input-wrap span{
  align-self:stretch;
  display:flex;
  align-items:center;
  padding:0 14px;
  border-right:1px solid var(--line);
  background:#f6f8ff;
  color:var(--muted);
  font-weight:900;
  direction:ltr;
  white-space:nowrap;
}
.field-hint{
  display:block;
  margin-top:7px;
  color:var(--muted);
  font-size:11px;
  line-height:1.7;
}


/* v6 merchant action confirm polish */
#merchantActionConfirmModal .modal.small{
  max-width:440px;
}
#merchantActionConfirmModal .modal-actions{
  justify-content:flex-start;
}


/* v7: merchants table width fix */
.main{min-width:0;overflow-x:hidden}
.card{min-width:0}
.table-wrap{max-width:100%;overflow-x:auto}
.merchant-actions-table{
  max-width:100%;
  overflow-x:auto !important;
  overflow-y:visible;
  -webkit-overflow-scrolling:touch;
}
.merchant-actions-table table{
  min-width:1180px;
}
.merchant-actions-table .action-dropdown{
  position:relative;
}
.merchant-actions-table .action-menu{
  z-index:140;
}
@media(max-width:760px){
  .merchant-actions-table table{min-width:1080px}
}


/* v11: server-side ajax filters */
#merchantRows.is-loading{
  opacity:.55;
  pointer-events:none;
  transition:.18s ease;
}
#merchantPagination nav{
  overflow-x:auto;
}


/* v12: global database operations loader */
.global-page-loader{
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  background:rgba(7,19,39,.38);
  backdrop-filter:blur(5px);
  z-index:9999;
  padding:20px;
}
.global-page-loader.show{
  display:flex;
}
.global-page-loader-card{
  min-width:280px;
  max-width:420px;
  border:1px solid rgba(229,234,242,.92);
  background:#fff;
  border-radius:24px;
  box-shadow:0 28px 80px rgba(2,8,23,.28);
  padding:24px;
  display:grid;
  justify-items:center;
  gap:10px;
  text-align:center;
}
.global-page-loader-card strong{
  font-size:16px;
  color:var(--text);
}
.global-page-loader-card small{
  color:var(--muted);
  font-weight:800;
  line-height:1.7;
}
.global-loader-spinner{
  width:42px;
  height:42px;
  border-radius:50%;
  border:4px solid #e8edff;
  border-top-color:var(--primary);
  animation:hi5-spin .8s linear infinite;
}
@keyframes hi5-spin{
  to{transform:rotate(360deg)}
}
.primary-btn[disabled],
.secondary-btn[disabled],
.danger-btn[disabled]{
  opacity:.65;
  cursor:not-allowed;
}


/* v14: merchant actions polish + hide API merchant id */
.actions-cell{min-width:136px}
.merchant-row-actions{width:100%;justify-content:center}
.action-pill{
  height:38px;
  min-width:104px;
  border:1px solid #d9e2f3;
  background:#fff;
  color:#344054;
  border-radius:14px;
  padding:0 12px;
  font-weight:900;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  box-shadow:0 8px 18px rgba(16,24,40,.06);
}
.action-pill:hover{
  border-color:#b9c7ff;
  color:var(--primary);
  background:#f8faff;
}
.action-dots{
  width:22px;
  height:22px;
  border-radius:8px;
  background:#eef3ff;
  color:var(--primary);
  display:inline-grid;
  place-items:center;
  line-height:1;
  font-size:18px;
  transform:translateY(-1px);
}
.merchant-action-menu{
  min-width:238px;
  padding:8px;
  border-radius:18px;
}
.action-menu .action-menu-item{
  display:grid;
  grid-template-columns:30px 1fr;
  gap:9px;
  align-items:center;
  justify-content:stretch;
  min-height:42px;
  padding:0 10px;
  border-radius:13px;
  text-align:right;
}
.action-menu .action-menu-item .action-icon{
  width:28px;
  height:28px;
  border-radius:10px;
  background:#f1f5ff;
  color:var(--primary);
  display:grid;
  place-items:center;
  font-weight:950;
  font-size:14px;
  line-height:1;
}
.action-menu .action-menu-item:hover .action-icon{
  background:var(--primary-soft);
}
.action-menu .action-menu-item.danger .action-icon,
.action-menu button.danger .action-icon{
  background:var(--danger-soft);
  color:var(--danger);
}
.action-menu .action-menu-item.danger:hover{
  background:var(--danger-soft);
}
.api-keys-table-wrap code{
  max-width:360px;
  overflow:hidden;
  text-overflow:ellipsis;
  vertical-align:middle;
}
@media(max-width:760px){
  .action-pill{min-width:96px}
  .merchant-action-menu{min-width:220px}
}


/* v15: unified icon-only action menu across project */
.action-pill.icon-only{
  width:42px;
  min-width:42px;
  height:38px;
  padding:0;
}
.action-pill.icon-only .action-dots{
  margin:0;
}
.users-actions-table .action-dropdown,
.merchant-actions-table .action-dropdown{
  width:100%;
  justify-content:center;
}
.users-actions-table .action-menu{
  min-width:238px;
  padding:8px;
  border-radius:18px;
}
.action-menu .action-menu-item{
  display:grid;
  grid-template-columns:30px 1fr;
  gap:9px;
  align-items:center;
  justify-content:stretch;
  min-height:42px;
  padding:0 10px;
  border-radius:13px;
  text-align:right;
}
.action-menu .action-menu-item .action-icon{
  width:28px;
  height:28px;
  border-radius:10px;
  background:#f1f5ff;
  color:var(--primary);
  display:grid;
  place-items:center;
  font-weight:950;
  font-size:14px;
  line-height:1;
}
.action-menu .action-menu-item:hover .action-icon{
  background:var(--primary-soft);
}
.action-menu .action-menu-item.danger .action-icon,
.action-menu button.danger .action-icon{
  background:var(--danger-soft);
  color:var(--danger);
}
.action-menu .action-menu-item.danger:hover{
  background:var(--danger-soft);
  color:var(--danger);
}


/* v16: merchant users permissions ajax loading */
#usersRows.is-loading{
  opacity:.55;
  pointer-events:none;
  transition:.18s ease;
}
#usersPagination nav{
  overflow-x:auto;
}
#loginAttemptsRows .empty-state{
  padding:14px;
}


/* v20: logout button in sidebar */
.nav-logout-form{
  margin:0;
}
.nav-logout-btn{
  width:100%;
  border:0;
  background:transparent;
  color:inherit;
  font:inherit;
  cursor:pointer;
  display:flex;
  align-items:center;
  gap:10px;
  padding:11px 12px;
  border-radius:14px;
  text-align:right;
  font-weight:900;
}
.nav-logout-btn svg{
  width:20px;
  height:20px;
}
.nav-logout-btn:hover{
  background:var(--danger-soft);
  color:var(--danger);
}


/* v22: unified sidebar account card */
.sidebar-account-card{
  min-height:68px;
  padding:12px 14px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.075);
  display:flex;
  align-items:center;
  gap:12px;
  flex-direction:row-reverse;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}
.sidebar-account-card .sidebar-account-avatar{
  width:38px;
  height:38px;
  min-width:38px;
  border-radius:14px;
  background:#f1f4ff;
  color:#172554;
  font-weight:950;
  display:grid;
  place-items:center;
  box-shadow:none;
}
.sidebar-account-info{
  flex:1;
  min-width:0;
  text-align:right;
}
.sidebar-account-info strong{
  display:block;
  color:#fff;
  font-size:13px;
  font-weight:950;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  margin-bottom:5px;
}
.sidebar-account-info small{
  display:block;
  color:rgba(226,232,240,.78);
  font-size:11px;
  font-weight:800;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}


/* v28: action dropdowns escape table overflow */
.action-menu.is-fixed{
  position:fixed!important;
  z-index:6500!important;
  overflow-y:auto;
  overscroll-behavior:contain;
}
.action-dropdown.open .action-menu.is-fixed{
  display:grid;
  gap:4px;
}
.table-wrap .action-menu.is-fixed,
.merchant-actions-table .action-menu.is-fixed,
.users-actions-table .action-menu.is-fixed{
  position:fixed!important;
}


/* v29: merchant invoices screen */
#merchantInvoiceRows.is-loading{
  opacity:.55;
  pointer-events:none;
  transition:.18s ease;
}
.merchant-invoices-table table{
  min-width:1120px;
}
#merchantInvoiceDetailsModal .modal-actions .is-hidden{
  display:none!important;
}


/* v32: invoice URL format + demo style invoice modal */
.invoice-demo-modal-layout .invoice-details-demo-grid{
  align-items:start;
}
.invoice-detail-card{
  box-shadow:0 12px 28px rgba(16,24,40,.05);
}
.invoice-progress{
  margin-top:16px;
}
.invoice-demo-modal-layout .code-card{
  direction:ltr;
  text-align:left;
  max-height:330px;
  overflow:auto;
}
.invoice-demo-modal-layout .timeline{
  display:grid;
  gap:10px;
  max-height:330px;
  overflow:auto;
  padding-inline-end:4px;
}
.invoice-demo-modal-layout .timeline-item{
  border:1px solid var(--line);
  border-radius:16px;
  padding:12px;
  background:#fbfcff;
}
.invoice-demo-modal-layout .timeline-item strong{
  display:block;
  font-size:13px;
  color:var(--text);
  margin-bottom:5px;
}
.invoice-demo-modal-layout .timeline-item p{
  margin:0 0 5px;
  color:#344054;
  font-size:12px;
  line-height:1.7;
}
.invoice-demo-modal-layout .timeline-item small{
  color:var(--muted);
  font-size:11px;
}
@media(max-width:900px){
  .invoice-demo-modal-layout .grid-2{
    grid-template-columns:1fr;
  }
}


/* v33: invoice links from invoice number + polished invoice timeline */
.invoice-timeline-card{
  overflow:hidden;
}
.invoice-timeline{
  position:relative;
  display:grid;
  gap:14px;
  max-height:390px;
  overflow:auto;
  padding:4px 6px 4px 0;
}
.invoice-timeline:before{
  content:"";
  position:absolute;
  right:18px;
  top:10px;
  bottom:10px;
  width:2px;
  background:linear-gradient(180deg,#dbe4ff,#eef2ff);
  border-radius:999px;
}
.invoice-timeline-item{
  position:relative;
  display:grid;
  grid-template-columns:38px 1fr;
  gap:12px;
  align-items:start;
}
.invoice-timeline-dot{
  position:relative;
  z-index:1;
  width:16px;
  height:16px;
  border-radius:50%;
  margin:10px auto 0;
  background:var(--info);
  box-shadow:0 0 0 6px var(--info-soft), 0 8px 16px rgba(14,165,233,.22);
}
.invoice-timeline-dot.paid,
.invoice-timeline-dot.success{
  background:var(--success);
  box-shadow:0 0 0 6px var(--success-soft), 0 8px 16px rgba(18,183,106,.22);
}
.invoice-timeline-dot.pending,
.invoice-timeline-dot.created{
  background:var(--warning);
  box-shadow:0 0 0 6px var(--warning-soft), 0 8px 16px rgba(247,144,9,.18);
}
.invoice-timeline-dot.failed,
.invoice-timeline-dot.expired{
  background:var(--danger);
  box-shadow:0 0 0 6px var(--danger-soft), 0 8px 16px rgba(240,68,56,.18);
}
.invoice-timeline-dot.cancelled{
  background:#667085;
  box-shadow:0 0 0 6px #f1f3f8, 0 8px 16px rgba(102,112,133,.16);
}
.invoice-timeline-content{
  border:1px solid var(--line);
  border-radius:18px;
  background:linear-gradient(180deg,#fff,#fbfcff);
  padding:13px 14px;
  box-shadow:0 8px 18px rgba(16,24,40,.045);
}
.invoice-timeline-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:8px;
}
.invoice-timeline-head strong{
  font-size:13px;
  color:var(--text);
  direction:ltr;
  text-align:left;
}
.invoice-timeline-content p{
  margin:0 0 9px;
  color:#344054;
  font-size:12px;
  line-height:1.8;
}
.invoice-timeline-meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.invoice-timeline-meta span{
  display:inline-flex;
  align-items:center;
  min-height:24px;
  padding:0 9px;
  border-radius:999px;
  background:#f4f7fb;
  color:var(--muted);
  font-size:11px;
  font-weight:800;
}
.invoice-demo-modal-layout .summary-row strong[style*="word-break"]{
  max-width:100%;
}


/* v34: fullscreen invoice details modal + actor in timeline */
.invoice-details-fullscreen-backdrop{
  padding:14px!important;
  align-items:stretch!important;
  justify-content:center!important;
}
.invoice-details-fullscreen-modal{
  width:calc(100vw - 28px)!important;
  max-width:none!important;
  height:calc(100vh - 28px)!important;
  max-height:none!important;
  display:flex!important;
  flex-direction:column;
  margin:0!important;
  border-radius:22px!important;
}
.invoice-details-fullscreen-modal > .modal-header{
  flex:0 0 auto;
}
.invoice-details-fullscreen-modal > .modal-scroll,
.invoice-details-fullscreen-modal #merchantInvoiceDetailsBody{
  flex:1 1 auto;
  max-height:none!important;
  overflow:auto;
}
.invoice-details-fullscreen-modal > .modal-actions{
  flex:0 0 auto;
}
.invoice-details-fullscreen-modal .invoice-details-demo-grid{
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.invoice-details-fullscreen-modal .invoice-detail-card{
  min-height:100%;
}
.invoice-timeline-actor{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:28px;
  padding:0 10px;
  border-radius:999px;
  background:#eef3ff;
  color:var(--primary);
  font-size:12px;
  font-weight:900;
  margin-bottom:10px;
}
.invoice-timeline-actor span{
  color:#667085;
  font-weight:800;
}
.invoice-timeline-actor strong{
  color:var(--primary);
  font-weight:950;
}
@media(max-width:900px){
  .invoice-details-fullscreen-backdrop{
    padding:8px!important;
  }
  .invoice-details-fullscreen-modal{
    width:calc(100vw - 16px)!important;
    height:calc(100vh - 16px)!important;
    border-radius:18px!important;
  }
  .invoice-details-fullscreen-modal .invoice-details-demo-grid{
    grid-template-columns:1fr;
  }
}


/* v35: merchant bulk invoices */
#bulkOperationRows.is-loading,
#bulkInvoiceItemRows.is-loading{
  opacity:.55;
  pointer-events:none;
  transition:.18s ease;
}
.operation-overview .operation-guide-card{
  min-height:150px;
}
.operation-guide-card p{
  color:var(--muted);
  line-height:1.8;
}
#bulkOperationRows small,
#bulkInvoiceItemRows small{
  color:var(--muted);
  word-break:break-all;
}


/* v36: bulk Excel upload UI + action dropdown alignment */
.bulk-file-field{
  grid-column:span 1;
}
.bulk-file-picker{
  min-height:116px;
  border:1.5px dashed #c7d2fe;
  border-radius:18px;
  background:linear-gradient(180deg,#fff,#f8faff);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:8px;
  padding:18px;
  cursor:pointer;
  transition:.18s ease;
  text-align:center;
}
.bulk-file-picker:hover{
  border-color:var(--primary);
  background:#f5f7ff;
}
.bulk-file-picker input{
  display:none;
}
.bulk-file-icon{
  width:42px;
  height:42px;
  border-radius:15px;
  display:grid;
  place-items:center;
  background:var(--primary-soft);
  color:var(--primary);
  font-weight:950;
  font-size:20px;
}
.bulk-file-picker strong{
  font-size:13px;
  color:var(--text);
}
.bulk-file-picker small{
  max-width:100%;
  color:var(--muted);
  font-size:12px;
  direction:ltr;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
#bulkOperationRows .status.success{
  color:var(--success);
  background:var(--success-soft);
}
.action-menu.is-fixed{
  transform:none!important;
}


/* v37: prevent action dropdown jitter while scrolling */
.action-menu.is-fixed{
  will-change:auto!important;
  contain:layout paint;
  backface-visibility:hidden;
}
.action-dropdown.open{
  transform:none!important;
}


/* v38: render action menu in body portal to prevent table jitter */
.action-dropdown.open > .action-menu{
  display:none!important;
}
.action-menu-portal{
  position:fixed!important;
  z-index:9000!important;
  min-width:220px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  box-shadow:0 18px 45px rgba(16,24,40,.18);
  padding:8px;
  display:grid;
  gap:4px;
  text-align:right;
  overflow-y:auto;
  overscroll-behavior:contain;
  contain:layout paint;
}
.action-menu-portal a,
.action-menu-portal button{
  width:100%;
  min-height:38px;
  border-radius:12px;
  background:transparent;
  color:#344054;
  font-weight:800;
  font-size:13px;
  padding:0 12px;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:8px;
  text-align:right;
  white-space:nowrap;
}
.action-menu-portal a:hover,
.action-menu-portal button:hover{
  background:#f8faff;
  color:var(--primary);
}
.action-menu-portal button.danger,
.action-menu-portal .danger{
  color:var(--danger);
}
.action-menu-portal button.danger:hover,
.action-menu-portal .danger:hover{
  background:var(--danger-soft);
  color:var(--danger);
}


/* v39: action dropdown same style as invoices, no portal */
.action-menu-portal{
  display:none!important;
}
.action-dropdown{
  position:relative;
  display:inline-flex;
  justify-content:flex-end;
  vertical-align:middle;
}
.action-dropdown .action-menu{
  position:absolute!important;
  top:calc(100% + 8px)!important;
  left:0!important;
  right:auto!important;
  bottom:auto!important;
  min-width:220px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  box-shadow:0 18px 45px rgba(16,24,40,.16);
  padding:8px;
  display:none!important;
  z-index:5000;
  text-align:right;
  overflow-y:auto;
}
.action-dropdown.open > .action-menu{
  display:grid!important;
  gap:4px;
}
.action-dropdown .action-menu.drop-up{
  top:auto!important;
  bottom:calc(100% + 8px)!important;
}
.action-dropdown .action-menu a,
.action-dropdown .action-menu button{
  width:100%;
  min-height:38px;
  border-radius:12px;
  background:transparent;
  color:#344054;
  font-weight:800;
  font-size:13px;
  padding:0 12px;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:8px;
  text-align:right;
  white-space:nowrap;
}
.action-dropdown .action-menu a:hover,
.action-dropdown .action-menu button:hover{
  background:#f8faff;
  color:var(--primary);
}
.action-dropdown .action-menu .danger,
.action-dropdown .action-menu button.danger{
  color:var(--danger);
}
.action-dropdown .action-menu .danger:hover,
.action-dropdown .action-menu button.danger:hover{
  background:var(--danger-soft);
  color:var(--danger);
}
.table-wrap:has(.action-dropdown.open){
  overflow:visible!important;
}
.card:has(.action-dropdown.open),
.section-spacer:has(.action-dropdown.open){
  overflow:visible!important;
}


/* v40: stable action dropdown final override */
.action-menu-portal{
  display:none!important;
}
.action-dropdown{
  position:relative!important;
  display:inline-flex!important;
  justify-content:flex-end!important;
  vertical-align:middle!important;
}
.action-dropdown > .action-menu{
  position:absolute!important;
  top:calc(100% + 8px)!important;
  left:0!important;
  right:auto!important;
  bottom:auto!important;
  min-width:220px!important;
  width:max-content;
  max-width:min(320px, calc(100vw - 24px));
  background:#fff!important;
  border:1px solid var(--line)!important;
  border-radius:16px!important;
  box-shadow:0 18px 45px rgba(16,24,40,.18)!important;
  padding:8px!important;
  display:none!important;
  z-index:9999!important;
  text-align:right!important;
  overflow-y:auto!important;
  transform:none!important;
}
.action-dropdown.open > .action-menu{
  display:grid!important;
  gap:4px!important;
}
.action-dropdown > .action-menu.drop-up{
  top:auto!important;
  bottom:calc(100% + 8px)!important;
}
.action-dropdown > .action-menu a,
.action-dropdown > .action-menu button{
  width:100%!important;
  min-height:38px!important;
  border-radius:12px!important;
  background:transparent!important;
  color:#344054!important;
  font-weight:800!important;
  font-size:13px!important;
  padding:0 12px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:flex-start!important;
  gap:8px!important;
  text-align:right!important;
  white-space:nowrap!important;
}
.action-dropdown > .action-menu a:hover,
.action-dropdown > .action-menu button:hover{
  background:#f8faff!important;
  color:var(--primary)!important;
}
.action-dropdown > .action-menu .danger,
.action-dropdown > .action-menu button.danger{
  color:var(--danger)!important;
}
.action-dropdown > .action-menu .danger:hover,
.action-dropdown > .action-menu button.danger:hover{
  background:var(--danger-soft)!important;
  color:var(--danger)!important;
}
.table-wrap{
  overflow-x:auto;
}
.table-wrap:has(.action-dropdown.open){
  overflow:visible!important;
}
.actions-cell{
  position:relative;
  overflow:visible!important;
}


/* v41 final forced action dropdown override */
.action-dropdown.force-open{
  position:relative!important;
  overflow:visible!important;
}
.action-dropdown.force-open > .action-menu{
  display:grid!important;
  visibility:visible!important;
  opacity:1!important;
  pointer-events:auto!important;
  position:absolute!important;
  top:calc(100% + 8px)!important;
  left:0!important;
  right:auto!important;
  bottom:auto!important;
  min-width:220px!important;
  max-width:min(340px, calc(100vw - 24px))!important;
  background:#fff!important;
  border:1px solid var(--line)!important;
  border-radius:16px!important;
  box-shadow:0 18px 45px rgba(16,24,40,.20)!important;
  padding:8px!important;
  z-index:2147483000!important;
  text-align:right!important;
  overflow-y:auto!important;
  gap:4px!important;
}
.action-dropdown.force-open > .action-menu.drop-up{
  top:auto!important;
  bottom:calc(100% + 8px)!important;
}
.action-dropdown.force-open > .action-menu a,
.action-dropdown.force-open > .action-menu button{
  width:100%!important;
  min-height:38px!important;
  border-radius:12px!important;
  background:transparent!important;
  color:#344054!important;
  font-weight:800!important;
  font-size:13px!important;
  padding:0 12px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:flex-start!important;
  gap:8px!important;
  text-align:right!important;
  white-space:nowrap!important;
}
.action-dropdown.force-open > .action-menu a:hover,
.action-dropdown.force-open > .action-menu button:hover{
  background:#f8faff!important;
  color:var(--primary)!important;
}
.action-dropdown.force-open > .action-menu .danger,
.action-dropdown.force-open > .action-menu button.danger{
  color:var(--danger)!important;
}
.table-wrap:has(.action-dropdown.force-open),
.card:has(.action-dropdown.force-open),
.section-spacer:has(.action-dropdown.force-open){
  overflow:visible!important;
}


/* v42: gateway method template fallback */
.gateway-methods{
  display:grid;
  gap:14px;
}
.gateway-method-card{
  border:1px solid var(--line);
  border-radius:18px;
  background:#fff;
  padding:14px;
  box-shadow:0 8px 18px rgba(16,24,40,.045);
}
.gateway-method-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}
.gateway-method-head strong{
  display:block;
  font-size:13px;
  color:var(--text);
}
.gateway-method-head small{
  color:var(--muted);
  font-size:11px;
}
.gateway-method-remove{
  min-height:34px;
  padding-inline:12px;
}
