/* PersianToxic Dashboard — system fonts only (no Google CDN) */
:root,[data-theme="dark"]{
  --bg-0:#0b0d12;--bg-1:#11141b;--bg-2:#161a23;--bg-3:#1d212c;--bg-4:#252a36;
  --line-1:rgba(255,255,255,.06);--line-2:rgba(255,255,255,.10);--line-3:rgba(255,255,255,.16);
  --text-1:#f1f3f7;--text-2:#b6bcc9;--text-3:#7c8395;--text-4:#525868;
  --brand-red:#cf2424;--brand-amber:#f3c66d;--brand-lime:#46d67e;
  --brand-grad:linear-gradient(90deg,#cf2424,#f3c66d);
  --success:#46d67e;--warning:#f3c66d;--danger:#ef4444;--info:#5a9cff;
  --success-bg:rgba(70,214,126,.12);--warning-bg:rgba(243,198,109,.13);
  --danger-bg:rgba(239,68,68,.12);--info-bg:rgba(90,156,255,.12);
  --shadow-1:0 1px 3px rgba(0,0,0,.30);--shadow-2:0 8px 24px rgba(0,0,0,.45);
  --radius:10px;--radius-sm:7px;--radius-lg:14px;
  --ease:cubic-bezier(.2,.85,.25,1);
  --sidebar-w:240px;--sidebar-w-collapsed:70px;--topbar-h:60px;--bottomnav-h:58px;
}
[data-theme="light"]{
  --bg-0:#f7f8fb;--bg-1:#fff;--bg-2:#fff;--bg-3:#f1f3f7;--bg-4:#e7eaf0;
  --line-1:rgba(15,18,25,.06);--line-2:rgba(15,18,25,.10);--line-3:rgba(15,18,25,.18);
  --text-1:#11141b;--text-2:#3a4050;--text-3:#6b7180;--text-4:#99a0ae;
  --shadow-1:0 1px 2px rgba(15,18,25,.04);--shadow-2:0 6px 18px rgba(15,18,25,.08);
}

*,*::before,*::after{box-sizing:border-box}
html{background:var(--bg-0);color-scheme:dark}
[data-theme="light"] html{color-scheme:light}
body{margin:0;font-family:'Plus Jakarta Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;font-size:14px;line-height:1.5;color:var(--text-2);background:var(--bg-0);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body.lang-fa{font-family:'Vazirmatn','Plus Jakarta Sans',-apple-system,'Segoe UI',Tahoma,sans-serif;font-feature-settings:"ss01","ss02","ss03"}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer}
img{max-width:100%;display:block}
[hidden]{display:none!important}
::selection{background:var(--brand-amber);color:#1a0f0a}
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:99px}
::-webkit-scrollbar-thumb:hover{background:var(--line-3)}

.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh;background:var(--bg-0)}
.main{background:var(--bg-0)}
.app.is-collapsed{grid-template-columns:var(--sidebar-w-collapsed) 1fr}

.sidebar{position:sticky;top:0;height:100vh;background:var(--bg-1);border-right:1px solid var(--line-1);display:flex;flex-direction:column;z-index:50}
[dir="rtl"] .sidebar{border-right:0;border-left:1px solid var(--line-1)}
.sidebar__brand{display:flex;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid var(--line-1);color:var(--text-1);min-height:var(--topbar-h)}
.sidebar__logo{width:30px;height:30px;flex-shrink:0}
.sidebar__name{font-weight:800;font-size:13px;letter-spacing:.8px;white-space:nowrap;overflow:hidden}
.app.is-collapsed .sidebar__name{display:none}
.sidebar__nav{flex:1;padding:10px 8px;overflow-y:auto}
.sidebar__group{margin-bottom:14px}
.sidebar__groupLbl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-4);padding:6px 10px}
body.lang-fa .sidebar__groupLbl{text-transform:none;letter-spacing:0;font-size:11px}
.app.is-collapsed .sidebar__groupLbl{display:none}
.sidebar__item{display:flex;align-items:center;gap:11px;padding:9px 10px;border-radius:var(--radius-sm);color:var(--text-2);font-size:13px;font-weight:500;position:relative;transition:background .15s var(--ease),color .15s var(--ease),transform .15s var(--ease)}
.sidebar__item:hover{background:var(--bg-3);color:var(--text-1);transform:translateX(2px)}
[dir="rtl"] .sidebar__item:hover{transform:translateX(-2px)}
.sidebar__item.is-active{background:var(--bg-3);color:var(--text-1);font-weight:600}
.sidebar__item.is-active::before{content:"";position:absolute;left:-8px;top:50%;transform:translateY(-50%);width:3px;height:60%;background:var(--brand-grad);border-radius:0 4px 4px 0}
[dir="rtl"] .sidebar__item.is-active::before{left:auto;right:-8px;border-radius:4px 0 0 4px}
.sidebar__icon{width:18px;height:18px;flex-shrink:0}
.sidebar__lbl{white-space:nowrap;overflow:hidden;flex:1}
.app.is-collapsed .sidebar__lbl{display:none}
.app.is-collapsed .sidebar__item{justify-content:center;padding:9px}
.sidebar__badge{background:var(--danger);color:#fff;font-size:9px;font-weight:700;padding:1px 6px;border-radius:99px;margin-left:auto;min-width:16px;text-align:center}
[dir="rtl"] .sidebar__badge{margin-left:0;margin-right:auto}
.app.is-collapsed .sidebar__badge{display:none}
.sidebar__user{border-top:1px solid var(--line-1);padding:10px;display:flex;align-items:center;gap:10px}
.sidebar__avatar{width:34px;height:34px;border-radius:8px;flex-shrink:0;overflow:hidden;display:grid;place-items:center;background:var(--brand-grad);color:#1a0f0a;font-weight:800;font-size:12px;letter-spacing:.4px}
.sidebar__userInfo{flex:1;min-width:0;overflow:hidden}
.sidebar__userName{font-size:13px;font-weight:600;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;direction:ltr;unicode-bidi:isolate}
.sidebar__userMeta{font-size:11px;color:var(--text-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-variant-numeric:tabular-nums;direction:ltr;unicode-bidi:isolate}
.app.is-collapsed .sidebar__userInfo{display:none}

.topbar{position:sticky;top:0;height:var(--topbar-h);background:var(--bg-1);border-bottom:1px solid var(--line-1);display:flex;align-items:center;gap:12px;padding:0 20px;z-index:40}
.topbar__hamb{display:none;width:36px;height:36px;background:var(--bg-3);border:1px solid var(--line-2);border-radius:var(--radius-sm);color:var(--text-2);align-items:center;justify-content:center}
.topbar__pageTitle{font-weight:700;font-size:16px;color:var(--text-1);margin:0}
.topbar__spacer{flex:1}
.topbar__actions{display:flex;align-items:center;gap:6px}

.iconBtn{width:36px;height:36px;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--text-2);display:grid;place-items:center;position:relative;transition:background .15s var(--ease),color .15s var(--ease),border-color .15s var(--ease),transform .12s var(--ease)}
.iconBtn:hover{background:var(--bg-3);color:var(--text-1);border-color:var(--line-2)}
.iconBtn:active{transform:scale(.94)}
.iconBtn svg{width:17px;height:17px}
.iconBtn__dot{position:absolute;top:7px;right:8px;width:7px;height:7px;background:var(--danger);border-radius:50%;border:2px solid var(--bg-1)}
[dir="rtl"] .iconBtn__dot{right:auto;left:8px}

.langPill{display:inline-flex;align-items:center;padding:3px;background:var(--bg-3);border:1px solid var(--line-2);border-radius:99px}
.langPill__opt{padding:4px 10px;font-size:11px;font-weight:700;color:var(--text-3);border-radius:99px;cursor:pointer;transition:all .15s var(--ease)}
.langPill__opt.is-active{background:var(--bg-1);color:var(--brand-amber);box-shadow:var(--shadow-1)}

.userBtn{display:inline-flex;align-items:center;gap:8px;padding:4px 12px 4px 4px;background:var(--bg-3);border:1px solid var(--line-2);border-radius:99px;color:var(--text-1);font-size:13px;font-weight:600;transition:all .15s var(--ease)}
[dir="rtl"] .userBtn{padding:4px 4px 4px 12px}
.userBtn:hover{background:var(--bg-4);border-color:var(--line-3)}
.userBtn__avatar{width:26px;height:26px;border-radius:6px;background:var(--brand-grad);color:#1a0f0a;display:grid;place-items:center;font-size:10px;font-weight:800;flex-shrink:0;overflow:hidden}
.userBtn__name{max-width:110px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;direction:ltr;unicode-bidi:isolate}

.menu__pos{position:relative}
.menu{position:absolute;top:calc(100% + 6px);right:0;background:var(--bg-2);border:1px solid var(--line-2);border-radius:var(--radius);box-shadow:var(--shadow-2);min-width:220px;padding:5px;z-index:100;opacity:0;transform:translateY(-4px) scale(.97);pointer-events:none;transition:opacity .15s var(--ease),transform .15s var(--ease)}
.menu.is-open{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
[dir="rtl"] .menu{right:auto;left:0}
.menu__item{display:flex;align-items:center;gap:10px;padding:8px 11px;border-radius:var(--radius-sm);color:var(--text-2);font-size:13px;background:transparent;border:0;width:100%;text-align:start;transition:background .12s var(--ease),color .12s var(--ease)}
.menu__item:hover{background:var(--bg-3);color:var(--text-1)}
.menu__item--danger{color:var(--danger)}
.menu__item--danger:hover{background:var(--danger-bg);color:var(--danger)}
.menu__item svg{width:15px;height:15px;flex-shrink:0}
.menu__sep{height:1px;background:var(--line-1);margin:5px 4px}
.menu__head{padding:9px 11px 5px;font-size:11px;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.5px}
body.lang-fa .menu__head{text-transform:none;letter-spacing:0;font-size:12px}

.main{min-width:0;display:flex;flex-direction:column}
.page{flex:1;padding:22px 26px 50px;animation:pageIn .25s var(--ease)}
@keyframes pageIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
@media(max-width:900px){.page{padding:16px 14px calc(var(--bottomnav-h) + 22px)}}
.page__head{margin:0 0 20px}
.page__title{font-weight:700;font-size:22px;color:var(--text-1);margin:0 0 4px}
.page__sub{color:var(--text-3);font-size:13px;margin:0}

.card{background:var(--bg-2);border:1px solid var(--line-1);border-radius:var(--radius-lg);overflow:hidden;transition:border-color .2s var(--ease)}
.card:hover{border-color:var(--line-2)}
.card__head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;border-bottom:1px solid var(--line-1)}
.card__title{font-weight:700;font-size:14px;color:var(--text-1);margin:0}
.card__sub{font-size:12px;color:var(--text-3);margin:2px 0 0}
.card__body{padding:16px 18px}
.card__action{font-size:12px;color:var(--brand-amber);font-weight:600;display:inline-flex;align-items:center;gap:4px;transition:gap .15s var(--ease)}
.card__action:hover{gap:6px}

.stat{background:var(--bg-2);border:1px solid var(--line-1);border-radius:var(--radius-lg);padding:16px 18px;transition:border-color .2s var(--ease),transform .2s var(--ease)}
.stat:hover{border-color:var(--line-2);transform:translateY(-1px)}
.stat__lbl{font-size:11px;color:var(--text-3);font-weight:600;margin:0 0 8px;text-transform:uppercase;letter-spacing:.5px}
body.lang-fa .stat__lbl{text-transform:none;letter-spacing:0;font-size:12px}
.stat__icon{width:32px;height:32px;background:var(--bg-3);border-radius:var(--radius-sm);display:grid;place-items:center;color:var(--brand-amber);margin-bottom:10px}
.stat__icon svg{width:16px;height:16px}
.stat__val{font-size:24px;font-weight:700;color:var(--text-1);line-height:1.1;display:flex;align-items:baseline;gap:5px;font-variant-numeric:tabular-nums;direction:ltr;unicode-bidi:isolate}
.stat__valSm{font-size:12px;color:var(--text-3);font-weight:500}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px 14px;border-radius:var(--radius-sm);border:1px solid transparent;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s var(--ease),color .15s var(--ease),border-color .15s var(--ease),transform .1s var(--ease),box-shadow .15s var(--ease);white-space:nowrap;font-family:inherit}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0) scale(.98)}
.btn svg{width:14px;height:14px;flex-shrink:0}
.btn--primary{background:var(--brand-grad);color:#1a0f0a}
.btn--primary:hover{box-shadow:0 6px 16px rgba(207,36,36,.30);filter:brightness(1.05)}
.btn--ghost{background:var(--bg-3);color:var(--text-1);border-color:var(--line-2)}
.btn--ghost:hover{background:var(--bg-4);border-color:var(--line-3)}
.btn--outline{background:transparent;color:var(--text-2);border-color:var(--line-2)}
.btn--outline:hover{background:var(--bg-3);color:var(--text-1)}
.btn--danger{background:var(--danger-bg);color:var(--danger);border-color:rgba(239,68,68,.30)}
.btn--danger:hover{background:rgba(239,68,68,.18)}
.btn--sm{padding:6px 11px;font-size:12px;gap:5px}
.btn--lg{padding:11px 18px;font-size:14px}
.btn--block{width:100%}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}

.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:99px;font-size:11px;font-weight:600;background:var(--bg-3);color:var(--text-2);border:1px solid var(--line-1);white-space:nowrap}
.badge--success{background:var(--success-bg);color:var(--success);border-color:rgba(70,214,126,.25)}
.badge--warning{background:var(--warning-bg);color:var(--brand-amber);border-color:rgba(243,198,109,.25)}
.badge--danger{background:var(--danger-bg);color:var(--danger);border-color:rgba(239,68,68,.25)}
.badge--info{background:var(--info-bg);color:var(--info);border-color:rgba(90,156,255,.25)}
.badge--soon{background:rgba(180,180,180,.10);color:var(--text-3);border-color:var(--line-2)}
.badge__dot{width:6px;height:6px;border-radius:50%;background:currentColor}

.field{display:flex;flex-direction:column;gap:5px}
.field__lbl{font-size:12px;font-weight:600;color:var(--text-2)}
.input,.select,.textarea{width:100%;background:var(--bg-1);border:1px solid var(--line-2);border-radius:var(--radius-sm);color:var(--text-1);padding:10px 12px;font:inherit;font-size:13px;transition:border-color .15s var(--ease),background .15s var(--ease);font-family:inherit}
[data-theme="light"] .input,[data-theme="light"] .select,[data-theme="light"] .textarea{background:var(--bg-3)}
.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--brand-amber)}
.input:disabled,.select:disabled{background:var(--bg-3);color:var(--text-3);cursor:not-allowed}
.field__hint{font-size:11px;color:var(--text-3)}
.field__row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:600px){.field__row{grid-template-columns:1fr}}

.switch{position:relative;display:inline-block;width:36px;height:20px;flex-shrink:0}
.switch input{opacity:0;width:0;height:0}
.switch__slider{position:absolute;inset:0;background:var(--bg-4);border-radius:99px;border:1px solid var(--line-2);cursor:pointer;transition:background .2s var(--ease),border-color .2s var(--ease)}
.switch__slider::before{content:"";position:absolute;width:14px;height:14px;left:2px;top:50%;transform:translateY(-50%);background:var(--text-2);border-radius:50%;transition:transform .2s var(--ease),background .2s var(--ease)}
.switch input:checked + .switch__slider{background:var(--brand-amber);border-color:var(--brand-amber)}
.switch input:checked + .switch__slider::before{transform:translateY(-50%) translateX(16px);background:#1a0f0a}
[dir="rtl"] .switch__slider::before{left:auto;right:2px}
[dir="rtl"] .switch input:checked + .switch__slider::before{transform:translateY(-50%) translateX(-16px)}

.table{width:100%;border-collapse:collapse;font-size:13px}
.table th,.table td{padding:11px 14px;text-align:start;vertical-align:middle}
.table thead th{background:var(--bg-3);color:var(--text-3);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--line-1)}
body.lang-fa .table thead th{text-transform:none;letter-spacing:0;font-size:12px}
.table tbody tr{border-bottom:1px solid var(--line-1);transition:background .12s var(--ease)}
.table tbody tr:hover{background:var(--bg-3)}
.table tbody tr:last-child{border-bottom:0}
.table td.is-num{font-variant-numeric:tabular-nums;direction:ltr;unicode-bidi:isolate;font-weight:600}
.table__wrap{overflow-x:auto}

.empty{text-align:center;padding:40px 20px;color:var(--text-3)}
.empty__icon{width:50px;height:50px;margin:0 auto 12px;background:var(--bg-3);border-radius:50%;display:grid;place-items:center;color:var(--text-3)}
.empty__icon svg{width:22px;height:22px}
.empty__title{color:var(--text-1);font-weight:600;font-size:14px;margin-bottom:3px}
.empty__sub{font-size:13px}

.alert{display:flex;gap:12px;padding:13px 15px;border-radius:var(--radius);border:1px solid;margin-bottom:16px}
.alert__icon{flex-shrink:0;width:22px;height:22px;display:grid;place-items:center}
.alert__icon svg{width:18px;height:18px}
.alert__body{flex:1;min-width:0}
.alert__title{font-weight:600;color:var(--text-1);font-size:13px;margin-bottom:2px}
.alert__msg{font-size:12.5px;color:var(--text-2)}
.alert--success{background:var(--success-bg);border-color:rgba(70,214,126,.22)}
.alert--success .alert__icon{color:var(--success)}
.alert--warning{background:var(--warning-bg);border-color:rgba(243,198,109,.30)}
.alert--warning .alert__icon{color:var(--brand-amber)}
.alert--danger{background:var(--danger-bg);border-color:rgba(239,68,68,.30)}
.alert--danger .alert__icon{color:var(--danger)}
.alert--info{background:var(--info-bg);border-color:rgba(90,156,255,.25)}
.alert--info .alert__icon{color:var(--info)}

.progress{height:6px;background:var(--bg-3);border-radius:99px;overflow:hidden}
.progress__fill{height:100%;background:var(--brand-grad);border-radius:99px;transition:width .5s var(--ease)}

.grid{display:grid;gap:14px}
.grid--stats{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.grid--2{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}

.rankChip{display:inline-flex;align-items:center;padding:3px 10px;border-radius:99px;font-size:11px;font-weight:700;letter-spacing:.3px;unicode-bidi:isolate}
.rankChip--vip{background:rgba(90,156,255,.15);color:#5a9cff}
.rankChip--vipplus{background:rgba(70,214,126,.15);color:var(--success)}
.rankChip--mvp{background:rgba(243,198,109,.18);color:var(--brand-amber)}
.rankChip--toxic{background:rgba(239,68,68,.15);color:#ff6b6b}
.rankChip--sponsor{background:linear-gradient(90deg,rgba(207,36,36,.15),rgba(243,198,109,.20));color:var(--brand-amber)}
.rankChip--none{background:var(--bg-3);color:var(--text-3)}

.defaultAvatar{background:linear-gradient(135deg,#cf2424 0%,#1a0f0a 50%,#f3c66d 100%);position:relative;overflow:hidden;display:grid;place-items:center}
.defaultAvatar::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.15),transparent 50%)}
.defaultAvatar__logo{width:60%;height:60%;position:relative;z-index:1;filter:drop-shadow(0 2px 6px rgba(0,0,0,.35))}

.welcome{display:flex;align-items:center;gap:16px;padding:18px 20px;background:linear-gradient(120deg,rgba(207,36,36,.10),rgba(243,198,109,.06) 70%),var(--bg-2);border:1px solid var(--line-1);border-radius:var(--radius-lg);margin-bottom:16px}
.welcome__avatar{width:60px;height:60px;border-radius:12px;flex-shrink:0;overflow:hidden}
.welcome__copy{flex:1;min-width:0}
.welcome__hi{font-size:12px;color:var(--text-3);margin:0 0 2px}
.welcome__name{font-size:19px;font-weight:700;color:var(--text-1);margin:0;direction:ltr;unicode-bidi:isolate}
.welcome__meta{font-size:12px;color:var(--text-3);margin-top:4px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.welcome__actions{display:flex;gap:8px;flex-shrink:0}
@media(max-width:720px){.welcome{flex-direction:column;align-items:flex-start}.welcome__actions{width:100%}.welcome__actions .btn{flex:1}}

.linkedItem{display:flex;align-items:center;gap:14px;padding:13px 16px;border-bottom:1px solid var(--line-1)}
.linkedItem:last-child{border-bottom:0}
.linkedItem__icon{width:38px;height:38px;border-radius:9px;background:var(--bg-3);display:grid;place-items:center;flex-shrink:0}
.linkedItem__icon svg{width:18px;height:18px}
.linkedItem__info{flex:1;min-width:0}
.linkedItem__name{font-weight:600;color:var(--text-1);font-size:13px}
.linkedItem__val{font-size:12px;color:var(--text-3);margin-top:1px;direction:ltr;unicode-bidi:isolate;font-variant-numeric:tabular-nums}
.linkedItem__val--placeholder{font-style:italic}

.rankTile{background:var(--bg-2);border:1px solid var(--line-1);border-radius:var(--radius-lg);padding:16px;display:flex;flex-direction:column;gap:12px;transition:border-color .2s var(--ease),transform .2s var(--ease)}
.rankTile:hover{border-color:var(--line-2);transform:translateY(-2px)}
.rankTile--active{border-color:rgba(243,198,109,.30);background:linear-gradient(180deg,rgba(243,198,109,.05),transparent),var(--bg-2)}
.rankTile__head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.rankTile__name{font-size:16px;font-weight:700;color:var(--text-1);margin:0;unicode-bidi:isolate}
.rankTile__sub{font-size:12px;color:var(--text-3);margin-top:2px}
.rankTile__time{display:flex;justify-content:space-between;font-size:12px}
.rankTile__timeLbl{color:var(--text-3)}
.rankTile__timeVal{color:var(--text-1);font-weight:600;font-variant-numeric:tabular-nums;direction:ltr;unicode-bidi:isolate}
.rankTile__actions{display:flex;gap:8px}
.rankTile__actions .btn{flex:1}
.rankTile__autoRenew{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;background:var(--bg-3);border-radius:var(--radius-sm);font-size:12px}
.rankTile__autoRenewLbl{color:var(--text-2);font-weight:500;flex:1}

.cartItem{display:grid;grid-template-columns:auto 1fr auto auto auto;gap:12px;align-items:center;padding:14px;border:1px solid var(--line-1);border-radius:var(--radius);background:var(--bg-2);transition:border-color .15s var(--ease)}
.cartItem:hover{border-color:var(--line-2)}
.cartItem__chip{flex-shrink:0}
.cartItem__info{min-width:0}
.cartItem__name{font-weight:600;color:var(--text-1);font-size:14px;margin-bottom:3px;unicode-bidi:isolate}
.cartItem__meta{font-size:12px;color:var(--text-3)}
.cartItem__qty{display:inline-flex;align-items:center;background:var(--bg-3);border:1px solid var(--line-2);border-radius:99px;overflow:hidden}
.cartItem__qtyBtn{width:28px;height:28px;background:transparent;border:0;color:var(--text-2);display:grid;place-items:center;cursor:pointer;transition:background .12s var(--ease),color .12s var(--ease)}
.cartItem__qtyBtn:hover{background:var(--bg-4);color:var(--text-1)}
.cartItem__qtyBtn:disabled{opacity:.3;cursor:not-allowed}
.cartItem__qtyBtn svg{width:12px;height:12px}
.cartItem__qtyVal{min-width:26px;text-align:center;font-size:13px;font-weight:700;color:var(--text-1);font-variant-numeric:tabular-nums}
.cartItem__price{font-size:14px;font-weight:700;color:var(--text-1);font-variant-numeric:tabular-nums;direction:ltr;unicode-bidi:isolate;text-align:end;white-space:nowrap}
.cartItem__remove{background:transparent;border:0;color:var(--text-3);width:30px;height:30px;border-radius:var(--radius-sm);display:grid;place-items:center;transition:background .12s var(--ease),color .12s var(--ease)}
.cartItem__remove:hover{background:var(--danger-bg);color:var(--danger)}
.cartItem__remove svg{width:15px;height:15px}
@media(max-width:600px){
  .cartItem{grid-template-columns:auto 1fr auto;grid-template-areas:"chip info remove" "qty qty price";row-gap:10px}
  .cartItem__chip{grid-area:chip}.cartItem__info{grid-area:info}.cartItem__qty{grid-area:qty;justify-self:start}.cartItem__price{grid-area:price;justify-self:end}.cartItem__remove{grid-area:remove}
}

.summary__row{display:flex;justify-content:space-between;padding:7px 0;font-size:13px;color:var(--text-2)}
.summary__row--total{border-top:1px solid var(--line-1);margin-top:8px;padding-top:13px;font-size:15px;font-weight:700;color:var(--text-1)}
.summary__val{font-variant-numeric:tabular-nums;direction:ltr;unicode-bidi:isolate}

.walletCard{background:radial-gradient(circle at 80% 0%,rgba(243,198,109,.18),transparent 50%),radial-gradient(circle at 0% 100%,rgba(207,36,36,.16),transparent 50%),var(--bg-2);border:1px solid rgba(243,198,109,.20);border-radius:var(--radius-lg);padding:22px;position:relative;overflow:hidden}
.walletCard__lbl{font-size:11px;text-transform:uppercase;letter-spacing:.8px;color:var(--text-3);font-weight:700;margin:0 0 8px}
body.lang-fa .walletCard__lbl{text-transform:none;letter-spacing:0;font-size:12px}
.walletCard__amount{font-size:30px;font-weight:800;color:var(--text-1);font-variant-numeric:tabular-nums;direction:ltr;unicode-bidi:isolate;margin:0 0 4px;display:flex;align-items:baseline;gap:6px}
.walletCard__currency{font-size:14px;color:var(--text-3);font-weight:600}
.walletCard__sub{font-size:12px;color:var(--text-3);margin:0 0 16px}
.walletCard__actions{display:flex;gap:8px}
.walletCard__actions .btn{flex:1}

.notif{display:flex;gap:11px;padding:13px 16px;border-bottom:1px solid var(--line-1);position:relative}
.notif:last-child{border-bottom:0}
.notif--unread{background:rgba(243,198,109,.04)}
.notif__icon{width:34px;height:34px;border-radius:50%;background:var(--bg-3);display:grid;place-items:center;flex-shrink:0;color:var(--brand-amber)}
.notif__icon svg{width:16px;height:16px}
.notif__body{flex:1;min-width:0}
.notif__title{font-weight:600;color:var(--text-1);font-size:13px;margin-bottom:2px}
.notif__msg{font-size:12.5px;color:var(--text-2);margin-bottom:3px}
.notif__time{font-size:11px;color:var(--text-3);font-variant-numeric:tabular-nums}

.ticket{display:grid;grid-template-columns:auto 1fr auto;gap:12px;padding:13px 16px;border-bottom:1px solid var(--line-1);align-items:center;cursor:pointer;transition:background .12s var(--ease)}
.ticket:hover{background:var(--bg-3)}
.ticket:last-child{border-bottom:0}
.ticket__avatar{width:34px;height:34px;background:var(--bg-3);border-radius:50%;display:grid;place-items:center;color:var(--brand-amber)}
.ticket__avatar svg{width:15px;height:15px}
.ticket__info{min-width:0}
.ticket__title{font-weight:600;color:var(--text-1);font-size:13px;margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ticket__sub{font-size:12px;color:var(--text-3);display:flex;gap:8px;flex-wrap:wrap}
.ticket__time{color:var(--text-3);font-size:12px;flex-shrink:0}

.toast{position:fixed;bottom:22px;right:22px;background:var(--bg-2);border:1px solid var(--line-2);border-radius:var(--radius);box-shadow:var(--shadow-2);padding:11px 14px;display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-1);z-index:200;opacity:0;transform:translateY(8px);transition:opacity .2s var(--ease),transform .2s var(--ease);max-width:320px}
.toast.is-visible{opacity:1;transform:translateY(0)}
[dir="rtl"] .toast{right:auto;left:22px}
.toast__icon{color:var(--success);flex-shrink:0;display:grid;place-items:center}
.toast__icon svg{width:17px;height:17px}

.bottomnav{display:none}
.sideBackdrop{display:none}
@media(max-width:900px){
  .app{grid-template-columns:1fr!important}
  .sidebar{position:fixed;top:0;left:0;width:var(--sidebar-w);height:100vh;transform:translateX(-100%);transition:transform .25s var(--ease);box-shadow:var(--shadow-2)}
  [dir="rtl"] .sidebar{left:auto;right:0;transform:translateX(100%)}
  .sidebar.is-open{transform:translateX(0)!important}
  .topbar__hamb{display:inline-flex}
  .bottomnav{display:flex;position:fixed;bottom:0;left:0;right:0;height:var(--bottomnav-h);background:var(--bg-1);border-top:1px solid var(--line-1);z-index:30;padding-bottom:env(safe-area-inset-bottom)}
  .bottomnav__item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:var(--text-3);font-size:10px;font-weight:500;transition:color .12s var(--ease)}
  .bottomnav__item.is-active{color:var(--brand-amber)}
  .bottomnav__item svg{width:19px;height:19px}
  .sideBackdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:49}
  .sideBackdrop.is-visible{display:block}
}
@media(max-width:600px){
  .topbar{padding:0 12px;gap:6px}
  .userBtn__name{display:none}
  .page__title{font-size:19px}
}

.authPage{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;background:var(--bg-0)}
@media(max-width:900px){.authPage{grid-template-columns:1fr}}
.authPage__hero{position:relative;background:radial-gradient(800px 600px at 30% 20%,rgba(207,36,36,.18),transparent 60%),radial-gradient(700px 500px at 80% 80%,rgba(243,198,109,.12),transparent 60%),#0a0b0f;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between;padding:40px;color:#fff}
@media(max-width:900px){.authPage__hero{display:none}}
.authPage__heroBg{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:50px 50px;pointer-events:none}
.authPage__brand{display:flex;align-items:center;gap:12px;position:relative;z-index:1}
.authPage__brand img{width:38px;height:38px}
.authPage__brandName{font-weight:800;font-size:16px;letter-spacing:1px}
.authPage__center{position:relative;z-index:1;max-width:460px}
.authPage__title{font-size:36px;font-weight:800;line-height:1.15;margin:0 0 14px}
body.lang-fa .authPage__title{font-size:32px}
.authPage__lead{font-size:14px;color:rgba(255,255,255,.65);line-height:1.6;margin:0}
.authPage__features{display:flex;flex-direction:column;gap:12px;margin-top:22px;list-style:none;padding:0}
.authPage__feature{display:flex;align-items:center;gap:10px;font-size:13px;color:rgba(255,255,255,.78)}
.authPage__featureIcon{width:28px;height:28px;background:rgba(243,198,109,.15);border-radius:8px;display:grid;place-items:center;color:var(--brand-amber);flex-shrink:0}
.authPage__featureIcon svg{width:14px;height:14px}
.authPage__copyright{position:relative;z-index:1;font-size:11px;color:rgba(255,255,255,.35)}
.authPage__form{display:flex;align-items:center;justify-content:center;padding:40px 30px}
.authForm{width:100%;max-width:420px}
.authForm__head{margin-bottom:24px;text-align:center}
.authForm__brand{display:none;align-items:center;justify-content:center;gap:10px;margin-bottom:18px}
.authForm__brand img{width:38px;height:38px}
.authForm__brandName{font-weight:800;font-size:14px;letter-spacing:1px;color:var(--text-1)}
@media(max-width:900px){.authForm__brand{display:flex}}
.authForm__title{font-size:24px;font-weight:700;color:var(--text-1);margin:0 0 6px}
.authForm__sub{font-size:13px;color:var(--text-3);margin:0}
.authForm__body{display:flex;flex-direction:column;gap:14px}
.authForm__foot{text-align:center;margin-top:18px;font-size:13px;color:var(--text-3)}
.authForm__foot a{color:var(--brand-amber);font-weight:600;margin-left:4px}
.authForm__foot a:hover{text-decoration:underline}
[dir="rtl"] .authForm__foot a{margin-left:0;margin-right:4px}
.otpRow{display:flex;gap:8px;justify-content:center;direction:ltr}
.otpInput{width:48px;height:56px;background:var(--bg-1);border:1px solid var(--line-2);border-radius:var(--radius-sm);color:var(--text-1);text-align:center;font-size:20px;font-weight:700;font-variant-numeric:tabular-nums;transition:border-color .15s var(--ease),background .15s var(--ease);font-family:inherit}
[data-theme="light"] .otpInput{background:var(--bg-3)}
.otpInput:focus{outline:none;border-color:var(--brand-amber)}

.adminTab{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--text-3);font-size:13px;font-weight:600;font-family:inherit}
.adminTab:hover{background:var(--bg-3);color:var(--text-1)}
.adminTab.is-active{background:var(--bg-3);color:var(--brand-amber);border-color:rgba(243,198,109,.30)}
.adminTab svg{width:14px;height:14px}
.adminTabs{display:flex;gap:4px;margin-bottom:18px;border-bottom:1px solid var(--line-1);padding-bottom:14px;flex-wrap:wrap}

/* === v2 layer: avatar round, bidi, server pill, lang loading, admin banner, order method, payment radio === */

/* Round avatars in topbar/sidebar/welcome */
.userBtn__avatar{border-radius:50%}
.sidebar__avatar{border-radius:50%}
.welcome__avatar{border-radius:50%}
.defaultAvatar{background:radial-gradient(circle at 50% 45%,#f3c66d 0%,#cf2424 70%,#1a0f0a 100%);border:1px solid rgba(243,198,109,.35)}
.defaultAvatar::before{display:none}
.defaultAvatar__logo{width:62%;height:62%;filter:drop-shadow(0 1px 2px rgba(0,0,0,.5))}

/* Bidi isolation for any field that may contain mixed FA/EN/digits */
.cartItem__name,.rankTile__name,.ticket__title,.ticket__sub,.notif__title,.notif__msg,
.welcome__name,.userBtn__name,.sidebar__userName,.linkedItem__val,
.acct__field-val,.orderRow__id,.orderRow__name,.serverPill__val,.adminBanner__track,
.empty__title,.empty__sub,.sidebar__userMeta{unicode-bidi:isolate}
/* Force LTR ONLY for fields holding pure latin/numeric data (phone, ids, counts) */
.sidebar__userMeta,.linkedItem__val,.serverPill__val,.orderRow__id{direction:ltr}

/* Lang pill: cursor pointer on whole pill (not just opts) */
.langPill{cursor:pointer;user-select:none}
.langPill__opt{cursor:pointer}

/* Lang switching loading overlay */
.langLoading{position:fixed;inset:0;background:rgba(11,13,18,.55);backdrop-filter:blur(2px);
  display:grid;place-items:center;z-index:300;opacity:0;transition:opacity .18s var(--ease)}
[data-theme="light"] .langLoading{background:rgba(247,248,251,.65)}
.langLoading.is-visible{opacity:1}
.langLoading__spin{width:34px;height:34px;border:3px solid rgba(243,198,109,.22);
  border-top-color:var(--brand-amber);border-radius:50%;animation:ptSpin .7s linear infinite}
@keyframes ptSpin{to{transform:rotate(360deg)}}

/* Server players pill in topbar */
.serverPill{display:inline-flex;align-items:center;gap:8px;padding:5px 11px;background:var(--bg-3);
  border:1px solid var(--line-2);border-radius:99px;font-size:12px;color:var(--text-2);
  font-weight:600;line-height:1;transition:border-color .15s var(--ease),background .15s var(--ease)}
.serverPill:hover{border-color:var(--line-3);background:var(--bg-4)}
.serverPill__dot{width:7px;height:7px;border-radius:50%;background:var(--success);
  box-shadow:0 0 0 3px rgba(70,214,126,.18);flex-shrink:0;animation:ptPulse 2s ease-in-out infinite}
@keyframes ptPulse{0%,100%{opacity:1}50%{opacity:.55}}
/* Server pill states — colour follows real liveness, not the player count */
.serverPill--online .serverPill__dot{background:var(--success);box-shadow:0 0 0 3px rgba(70,214,126,.18)}
.serverPill--offline{border-color:rgba(220,38,38,.30)}
.serverPill--offline .serverPill__dot{background:var(--danger);box-shadow:0 0 0 3px rgba(220,38,38,.18);animation:none}
.serverPill--offline .serverPill__val{color:var(--text-3)}
.serverPill--loading{border-color:rgba(236,72,153,.32)}
.serverPill--loading .serverPill__dot{background:#ec4899;box-shadow:0 0 0 3px rgba(236,72,153,.20)}
.serverPill--loading .serverPill__val,.serverPill--loading .serverPill__lbl{color:#ec4899}
.serverPill__lbl{color:var(--text-3);font-size:11px;font-weight:600}
.serverPill__val{color:var(--text-1);font-variant-numeric:tabular-nums;font-weight:700}
@media(max-width:760px){
  .serverPill__lbl{display:none}
  .serverPill{padding:5px 9px;gap:6px}
}
@media(max-width:480px){
  .serverPill{font-size:11px}
}

/* Stat cards: clickable variant */
.stat--clickable{cursor:pointer;text-decoration:none;color:inherit;display:block}
.stat--clickable:hover{border-color:rgba(243,198,109,.35);box-shadow:0 0 0 3px rgba(243,198,109,.08)}
.stat--clickable:active{transform:translateY(0) scale(.985)}

/* Admin marquee banner — single message that slides in one edge, out the other, then loops */
.adminBanner{display:block;position:relative;background:var(--danger);color:#fff;height:36px;
  overflow:hidden;border-bottom:1px solid rgba(0,0,0,.2);z-index:35}
.adminBanner__track{display:inline-block;white-space:nowrap;padding-left:100%;
  line-height:36px;vertical-align:middle;font-size:13px;font-weight:600;letter-spacing:.2px;
  will-change:transform;animation:ptMarquee 28s linear infinite}
[dir="rtl"] .adminBanner__track{animation-name:ptMarqueeRtl}
@keyframes ptMarquee{0%{transform:translateX(0)}100%{transform:translateX(-100%)}}
@keyframes ptMarqueeRtl{0%{transform:translateX(-100%)}100%{transform:translateX(0)}}
.adminBanner__close{position:absolute;top:0;bottom:0;right:0;width:36px;background:rgba(0,0,0,.12);border:0;color:#fff;
  display:grid;place-items:center;cursor:pointer;opacity:.85;transition:opacity .15s var(--ease);z-index:1}
.adminBanner__close:hover{opacity:1;background:rgba(0,0,0,.28)}
.adminBanner__close svg{width:16px;height:16px}

/* Order/payment method chip */
.methodChip{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:99px;
  font-size:11px;font-weight:600;background:var(--bg-3);color:var(--text-2);border:1px solid var(--line-2)}
.methodChip svg{width:11px;height:11px}
.methodChip--wallet{color:var(--brand-amber);border-color:rgba(243,198,109,.30);background:var(--warning-bg)}
.methodChip--online{color:var(--info);border-color:rgba(90,156,255,.25);background:var(--info-bg)}
.methodChip--autorenew{color:var(--success);border-color:rgba(70,214,126,.25);background:var(--success-bg)}

/* Modal generic */
.modalBackdrop{position:fixed;inset:0;background:rgba(11,13,18,.65);backdrop-filter:blur(3px);
  z-index:200;display:none;opacity:0;transition:opacity .2s var(--ease)}
[data-theme="light"] .modalBackdrop{background:rgba(15,18,25,.45)}
.modalBackdrop.is-open{display:grid;place-items:center}
.modalBackdrop.is-visible{opacity:1}
.modal{width:min(520px,94vw);max-height:90vh;overflow:auto;background:var(--bg-2);border:1px solid var(--line-2);
  border-radius:var(--radius-lg);box-shadow:var(--shadow-2);transform:translateY(8px);transition:transform .2s var(--ease)}
.modalBackdrop.is-visible .modal{transform:translateY(0)}
.modal__head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;
  border-bottom:1px solid var(--line-1)}
.modal__title{font-weight:700;color:var(--text-1);font-size:15px;margin:0}
.modal__close{background:transparent;border:0;color:var(--text-3);width:30px;height:30px;border-radius:var(--radius-sm);
  display:grid;place-items:center;cursor:pointer;transition:background .12s var(--ease),color .12s var(--ease)}
.modal__close:hover{background:var(--bg-3);color:var(--text-1)}
.modal__close svg{width:16px;height:16px}
.modal__body{padding:18px}
.modal__foot{display:flex;gap:8px;justify-content:flex-end;padding:12px 18px;border-top:1px solid var(--line-1)}

/* Phone editable inline UI in profile */
.phoneEdit{display:flex;gap:8px}
.phoneEdit .input{flex:1}

/* Image preview thumb (ticket attachment) */
.imgThumb{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;background:var(--bg-3);
  border:1px solid var(--line-2);border-radius:var(--radius-sm);font-size:12px}
.imgThumb img{width:36px;height:36px;object-fit:cover;border-radius:5px}

/* Page-level checkout/payment-result layout (no shell) */
.checkoutPage{min-height:100vh;background:var(--bg-0);display:flex;flex-direction:column}
.checkoutPage__top{height:60px;border-bottom:1px solid var(--line-1);background:var(--bg-1);
  display:flex;align-items:center;padding:0 22px;gap:12px;position:sticky;top:0;z-index:20}
.checkoutPage__brand{display:flex;align-items:center;gap:10px;color:var(--text-1);font-weight:800;letter-spacing:.6px;font-size:13px}
.checkoutPage__brand img{width:30px;height:30px}
.checkoutPage__main{flex:1;padding:28px 22px;display:grid;place-items:start center}
.checkoutPage__inner{width:min(720px,100%)}
.payMethod{display:flex;flex-direction:column;gap:10px;margin:14px 0}
.payOpt{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--bg-2);
  border:1px solid var(--line-2);border-radius:var(--radius);cursor:pointer;transition:border-color .15s var(--ease)}
.payOpt:hover{border-color:var(--line-3)}
.payOpt.is-selected{border-color:var(--brand-amber);background:linear-gradient(0deg,rgba(243,198,109,.06),rgba(243,198,109,.06)),var(--bg-2)}
.payOpt input[type="radio"]{accent-color:var(--brand-amber);width:16px;height:16px;flex-shrink:0}
.payOpt__logo{flex-shrink:0;width:64px;height:32px;background:var(--bg-3);border-radius:6px;display:grid;place-items:center;
  font-size:11px;font-weight:800;color:var(--text-2);letter-spacing:.6px}
.payOpt__name{font-size:13px;font-weight:600;color:var(--text-1)}
.payOpt__sub{font-size:11px;color:var(--text-3)}

/* Payment result icon */
.payResultIcon{width:96px;height:96px;border-radius:50%;display:grid;place-items:center;margin:0 auto 18px}
.payResultIcon--ok{background:rgba(70,214,126,.14);color:var(--success);border:2px solid rgba(70,214,126,.30)}
.payResultIcon--fail{background:rgba(239,68,68,.14);color:var(--danger);border:2px solid rgba(239,68,68,.30)}
.payResultIcon svg{width:48px;height:48px}

/* Collapsing margins around topbar -> banner -> page */
.adminBanner + .page{padding-top:14px}

/* === v3 layer: in-dashboard store, tickets modal, payment chips, hide bottomnav on page-level === */

/* In-dashboard store */
.dashStore__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}
.rankCardD{background:var(--bg-2);border:1px solid var(--line-2);border-radius:var(--radius-lg);overflow:hidden;
  transition:border-color .18s var(--ease),transform .18s var(--ease),box-shadow .18s var(--ease);display:flex;flex-direction:column}
.rankCardD:hover{border-color:rgba(243,198,109,.45);transform:translateY(-2px);box-shadow:0 12px 30px rgba(0,0,0,.35)}
.rankCardD__media{aspect-ratio:16/10;background:linear-gradient(135deg,#1a1d27,#0f1118);display:grid;place-items:center;
  position:relative;border-bottom:1px solid var(--line-1)}
.rankCardD__media img{width:62%;height:62%;object-fit:contain;filter:drop-shadow(0 6px 14px rgba(0,0,0,.45))}
.rankCardD__placeholder{font-size:34px;font-weight:900;letter-spacing:1px;color:var(--brand-amber);
  text-shadow:0 2px 6px rgba(0,0,0,.5);font-family:'Plus Jakarta Sans',sans-serif}
.rankCardD__body{padding:14px 14px 16px;display:flex;flex-direction:column;gap:8px;flex:1}
.rankCardD__nameRow{display:flex;align-items:center;justify-content:space-between;gap:8px}
.rankCardD__name{font-size:18px;font-weight:800;color:var(--text-1);margin:0;direction:ltr;unicode-bidi:isolate}
.rankCardD__dur{font-size:11px;color:var(--text-3);background:var(--bg-3);padding:3px 8px;border-radius:99px;
  border:1px solid var(--line-2);font-weight:600}
.rankCardD__priceRow{display:flex;align-items:baseline;gap:5px;margin-top:auto}
.rankCardD__price{font-size:20px;font-weight:800;color:var(--text-1);direction:ltr;unicode-bidi:isolate}
.rankCardD__currency{font-size:11px;color:var(--text-3);font-weight:600}
.rankCardD__actions{display:flex;gap:6px;margin-top:10px}
.rankCardD__actions .btn{flex:1;padding:8px 10px;font-size:12px}

/* Featured rank highlight */
.rankCardD--featured{position:relative;border-color:rgba(243,198,109,.45)}
.rankCardD--featured::before{content:"★";position:absolute;top:8px;right:8px;background:var(--brand-amber);color:#1a0f0a;
  width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-size:13px;font-weight:900;z-index:2}
[dir="rtl"] .rankCardD--featured::before{right:auto;left:8px}

/* Rank detail modal: bigger, kit grid */
.modal--lg{width:min(720px,96vw)}
.rankDetail__head{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.rankDetail__media{width:84px;height:84px;border-radius:var(--radius);background:linear-gradient(135deg,#1a1d27,#0f1118);
  display:grid;place-items:center;flex-shrink:0;border:1px solid var(--line-1)}
.rankDetail__media img{width:70%;height:70%;object-fit:contain}
.rankDetail__title{font-size:22px;font-weight:800;color:var(--text-1);margin:0 0 4px;direction:ltr;unicode-bidi:isolate}
.rankDetail__price{font-size:14px;color:var(--brand-amber);font-weight:700;direction:ltr;unicode-bidi:isolate}
.rankDetail__tabs{display:flex;gap:6px;border-bottom:1px solid var(--line-1);margin-bottom:14px}
.rankDetail__tab{padding:8px 14px;background:transparent;border:0;color:var(--text-3);font-size:13px;font-weight:600;
  cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s var(--ease),border-color .15s var(--ease)}
.rankDetail__tab.is-active{color:var(--text-1);border-bottom-color:var(--brand-amber)}
.kitsList{display:flex;flex-direction:column;gap:10px;max-height:340px;overflow-y:auto}
.kitItem{padding:10px 12px;background:var(--bg-3);border:1px solid var(--line-1);border-radius:var(--radius-sm);display:flex;justify-content:space-between;gap:10px}
.kitItem__name{font-size:13px;font-weight:700;color:var(--text-1);direction:ltr;unicode-bidi:isolate}
.kitItem__meta{display:flex;gap:10px;font-size:11px;color:var(--text-3);font-variant-numeric:tabular-nums}
.kitItem__meta b{color:var(--text-2)}
.capsList{display:flex;flex-direction:column;gap:8px}
.capsList li{padding:8px 12px;background:var(--bg-3);border-radius:var(--radius-sm);font-size:13px;color:var(--text-2);list-style:none;display:flex;gap:8px;align-items:flex-start}
.capsList li::before{content:"";width:6px;height:6px;background:var(--brand-amber);border-radius:50%;margin-top:8px;flex-shrink:0}

/* Quantity stepper */
.qtyStep{display:inline-flex;align-items:center;gap:0;border:1px solid var(--line-2);border-radius:var(--radius-sm);overflow:hidden}
.qtyStep button{width:30px;height:30px;background:var(--bg-3);border:0;color:var(--text-1);font-size:15px;font-weight:700;cursor:pointer}
.qtyStep button:hover{background:var(--bg-4)}
.qtyStep input{width:40px;height:30px;text-align:center;background:var(--bg-2);border:0;color:var(--text-1);font-weight:700;font-variant-numeric:tabular-nums}
.qtyStep input:focus{outline:0}

/* Ticket type radio cards */
.typeOpts{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:6px 0 14px}
.typeOpt{padding:10px 12px;background:var(--bg-3);border:1px solid var(--line-2);border-radius:var(--radius-sm);
  cursor:pointer;display:flex;gap:8px;align-items:flex-start;transition:border-color .15s var(--ease),background .15s var(--ease)}
.typeOpt:hover{border-color:var(--line-3)}
.typeOpt.is-selected{border-color:var(--brand-amber);background:linear-gradient(0deg,rgba(243,198,109,.06),rgba(243,198,109,.06)),var(--bg-3)}
.typeOpt input{accent-color:var(--brand-amber);margin-top:2px;flex-shrink:0}
.typeOpt__txt{font-size:12px;font-weight:600;color:var(--text-1);line-height:1.3}
@media(max-width:560px){.typeOpts{grid-template-columns:1fr}}

/* Image attach button + preview */
.fileChooser{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-3);
  border:1px dashed var(--line-3);border-radius:var(--radius-sm);cursor:pointer;font-size:12px;color:var(--text-2);
  transition:border-color .15s var(--ease)}
.fileChooser:hover{border-color:var(--brand-amber);color:var(--text-1)}
.fileChooser input{display:none}
.fileChooser svg{width:14px;height:14px}

/* Page-level: hide app shell components */
body.page--checkout .sidebar,body.page--checkout .topbar,body.page--checkout .bottomnav,body.page--checkout .sideBackdrop,
body.page--payresult .sidebar,body.page--payresult .topbar,body.page--payresult .bottomnav,body.page--payresult .sideBackdrop{display:none!important}
body.page--checkout .app,body.page--payresult .app{display:block}
body.page--checkout .main,body.page--payresult .main{margin:0!important;padding:0!important;min-height:100vh}

/* Wallet input formatted state */
.input.is-error{border-color:rgba(239,68,68,.45);background:rgba(239,68,68,.04)}
.field__hint.is-error{color:var(--danger)}

/* Order method extras */
.orderRow__method{display:inline-flex;align-items:center;gap:6px}

/* Compact list layout for store tab inside dashboard */
.dashStore__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:8px}

/* Marquee toggle in admin */
.adminBanner__preview{padding:12px 14px;background:var(--bg-3);border:1px dashed var(--line-2);border-radius:var(--radius-sm);
  display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-3)}
.adminBanner__preview::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--danger);flex-shrink:0}

/* === v2 final bidi overrides — pure-latin name fields should isolate but follow paragraph dir for alignment === */
body.lang-fa .welcome__name,
body.lang-fa .userBtn__name,
body.lang-fa .sidebar__userName,
body.lang-fa .cartItem__name,
body.lang-fa .rankTile__name,
body.lang-fa .ticket__title,
body.lang-fa .ticket__sub,
body.lang-fa .notif__title,
body.lang-fa .notif__msg{direction:rtl;unicode-bidi:isolate}

/* === v2 capsList/kitItem bidi fix === */
.capsList li, .kitItem__name{unicode-bidi:isolate}

/* capabilities list contains LTR english text - force LTR direction */
.capsList li{direction:ltr;text-align:start;unicode-bidi:isolate}
.kitItem__name{direction:ltr;unicode-bidi:isolate}

/* === final small fixes === */
/* In FA, capsList items still LTR for the latin text but flip the bullet to the right */
body.lang-fa .capsList li{flex-direction:row-reverse;text-align:right}
body.lang-fa .kitItem{flex-direction:row-reverse;text-align:right}

/* Give userBtn name more room and trim earlier instead of cutting at the right */
.userBtn__name{max-width:140px;text-overflow:ellipsis;overflow:hidden}
@media(min-width:1100px){.userBtn__name{max-width:170px}}
@media(max-width:600px){.userBtn__name{display:none}}

/* In RTL the close icon of admin banner should sit on the start side properly */
[dir="rtl"] .adminBanner{direction:ltr}
[dir="rtl"] .adminBanner__track{direction:rtl;text-align:right}

/* === linked accounts: in FA, the value (phone/id/etc) sits on the right under the name === */
body.lang-fa .linkedItem__val{direction:rtl;text-align:right;unicode-bidi:isolate}
body.lang-fa .linkedItem__name{text-align:right}
body.lang-fa .linkedItem__info{text-align:right}

/* === Ticket status badges with distinct colors === */
.statusBadge{
  display:inline-flex;
  align-items:center;
  gap:5px;
  padding:3px 10px;
  font-size:11px;
  font-weight:700;
  border-radius:999px;
  letter-spacing:.2px;
  border:1px solid transparent;
  white-space:nowrap;
}
.statusBadge::before{
  content:"";
  width:6px;
  height:6px;
  border-radius:50%;
  background:currentColor;
  flex-shrink:0;
}
.statusBadge--open         { color:#22c55e; background:rgba(34,197,94,.10);  border-color:rgba(34,197,94,.28) }
.statusBadge--customer     { color:#3b82f6; background:rgba(59,130,246,.10); border-color:rgba(59,130,246,.30) }
.statusBadge--admin        { color:#f3c66d; background:rgba(243,198,109,.10); border-color:rgba(243,198,109,.32) }
.statusBadge--review       { color:#a78bfa; background:rgba(167,139,250,.10); border-color:rgba(167,139,250,.30) }
.statusBadge--closed       { color:#9ca3af; background:rgba(156,163,175,.10); border-color:rgba(156,163,175,.26) }

/* === Ticket list (clickable rows) === */
.ticketRow{
  display:flex; align-items:center; gap:14px;
  padding:14px 16px;
  border-bottom:1px solid var(--line-1);
  text-decoration:none;
  color:inherit;
  transition:background .15s;
  cursor:pointer;
}
.ticketRow:hover{ background:var(--bg-3) }
.ticketRow__icon{
  width:36px; height:36px; border-radius:50%;
  background:var(--bg-3); border:1px solid var(--line-1);
  display:grid; place-items:center; flex-shrink:0;
  color:var(--brand-amber);
}
.ticketRow__icon svg{ width:16px; height:16px }
.ticketRow__main{ flex:1; min-width:0 }
.ticketRow__title{ font-size:14px; font-weight:600; color:var(--text-1); margin:0 0 3px; unicode-bidi:isolate }
.ticketRow__meta{ display:flex; gap:8px; align-items:center; flex-wrap:wrap; font-size:11px; color:var(--text-3) }
.ticketRow__id{ direction:ltr; unicode-bidi:isolate; font-variant-numeric:tabular-nums }
.ticketRow__lastReply{ display:flex; flex-direction:column; align-items:flex-end; gap:4px; flex-shrink:0; max-width:240px }
.ticketRow__lastTxt{ font-size:11px; color:var(--text-3); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:240px; unicode-bidi:isolate }
@media (max-width: 720px){
  .ticketRow{ flex-wrap:wrap }
  .ticketRow__lastReply{ max-width:100% }
}

/* === Ticket detail page (chat layout) === */
.ticketChat{ display:flex; flex-direction:column; gap:10px; padding:18px; max-height:540px; overflow-y:auto }
.chatBubble{ max-width:75%; padding:10px 14px; border-radius:14px; font-size:13px; line-height:1.55; word-wrap:break-word }
.chatBubble__meta{ font-size:10px; opacity:.6; margin-top:4px; font-variant-numeric:tabular-nums }
.chatBubble--user{ align-self:flex-end; background:var(--brand-amber); color:#1a1408; border-bottom-right-radius:4px }
.chatBubble--admin{ align-self:flex-start; background:var(--bg-3); color:var(--text-1); border:1px solid var(--line-1); border-bottom-left-radius:4px }
[dir="rtl"] .chatBubble--user{ border-bottom-right-radius:14px; border-bottom-left-radius:4px }
[dir="rtl"] .chatBubble--admin{ border-bottom-left-radius:14px; border-bottom-right-radius:4px }
.chatBubble__img{ display:block; max-width:100%; max-height:240px; border-radius:8px; margin-top:6px }

.chatComposer{ display:flex; gap:10px; padding:14px; border-top:1px solid var(--line-1); background:var(--bg-2) }
.chatComposer textarea{
  flex:1; padding:10px 14px; border-radius:10px;
  background:var(--bg-1); border:1px solid var(--line-1);
  color:var(--text-1); font-family:inherit; font-size:13px;
  resize:none; min-height:42px; max-height:120px;
}
.chatComposer textarea:focus{ outline:none; border-color:var(--brand-amber) }

.ticketHeader{
  display:flex; align-items:center; gap:14px;
  padding:16px 20px;
  border-bottom:1px solid var(--line-1);
  flex-wrap:wrap;
}
.ticketHeader__main{ flex:1; min-width:200px }
.ticketHeader__id{ font-size:11px; color:var(--text-3); direction:ltr; unicode-bidi:isolate; font-variant-numeric:tabular-nums }
.ticketHeader__title{ font-size:16px; font-weight:700; color:var(--text-1); margin:2px 0 6px; unicode-bidi:isolate }
.ticketHeader__chips{ display:flex; gap:6px; flex-wrap:wrap }

.statusPicker{
  display:flex; align-items:center; gap:8px;
  padding:8px 12px; background:var(--bg-3); border:1px solid var(--line-1); border-radius:10px;
  margin:14px 18px;
}
.statusPicker__lbl{ font-size:12px; color:var(--text-2); font-weight:600 }
.statusPicker select{
  padding:6px 10px; border-radius:6px; background:var(--bg-1); border:1px solid var(--line-1);
  color:var(--text-1); font-family:inherit; font-size:12px; cursor:pointer;
}

/* ============================================================
   v2 — FORUM-STYLE TICKETS (full redesign)
   ============================================================ */

/* === Tickets list (forum sections) === */
.ticketAlertBar{
  margin: 0 0 18px;
  padding: 14px 18px;
  background: linear-gradient(180deg, rgba(239,68,68,.10), rgba(239,68,68,.04));
  border: 1px solid rgba(239,68,68,.32);
  border-radius: 10px;
  color: #ffd7d7;
  font-size: 13px;
  line-height: 1.7;
  text-align: center;
}
[data-theme="light"] .ticketAlertBar{
  background: linear-gradient(180deg, rgba(239,68,68,.08), rgba(239,68,68,.02));
  color: #b91c1c;
}

.forumHead{
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom: 14px;
}
.forumHead__title{
  font-size: 18px;
  font-weight: 800;
  color: var(--brand-amber);
  margin: 0;
}

.forumList{
  display:flex; flex-direction:column;
  background: linear-gradient(180deg, rgba(243,198,109,.04), rgba(243,198,109,.01));
  border: 1px solid var(--line-1);
  border-radius: 12px;
  overflow: hidden;
}
.forumRow{
  display:flex; align-items:center; gap:14px;
  padding: 18px 20px;
  border-bottom: 1px solid var(--line-1);
  text-decoration: none;
  color: inherit;
  transition: background .15s;
}
.forumRow:last-child{ border-bottom: none }
.forumRow:hover{ background: rgba(243,198,109,.05) }
.forumRow__icon{
  width: 36px; height: 36px;
  display: grid; place-items: center;
  color: var(--brand-amber);
  flex-shrink: 0;
}
.forumRow__icon svg{ width: 22px; height: 22px }
.forumRow__main{ flex:1; min-width:0 }
.forumRow__title{
  font-size: 15px; font-weight: 700;
  color: var(--brand-amber);
  margin: 0 0 4px;
  unicode-bidi: isolate;
}
.forumRow__sub{
  font-size: 12px;
  color: var(--text-3);
  margin: 0;
  unicode-bidi: isolate;
}
.forumRow__count{
  flex-shrink: 0;
  background: var(--bg-3);
  border: 1px solid var(--line-1);
  border-radius: 999px;
  padding: 4px 11px;
  font-size: 11px;
  color: var(--text-2);
  font-variant-numeric: tabular-nums;
  font-weight: 600;
}
.forumRow__chev{
  width: 16px; height: 16px;
  color: var(--text-3);
  flex-shrink: 0;
}

/* === Ticket detail (forum-style) === */
.ticketLayout{
  display:grid;
  grid-template-columns: 1fr 280px;
  gap: 18px;
}
[dir="rtl"] .ticketLayout{ grid-template-columns: 280px 1fr }

@media (max-width: 900px){
  .ticketLayout{ grid-template-columns: 1fr !important }
}

.ticketSide{
  background: var(--bg-2);
  border: 1px solid var(--line-1);
  border-radius: 12px;
  overflow: hidden;
  align-self: flex-start;
  position: sticky;
  top: 80px;
}
.ticketSide__head{
  padding: 12px 16px;
  background: var(--bg-3);
  border-bottom: 1px solid var(--line-1);
  font-size: 13px;
  font-weight: 700;
  color: var(--brand-amber);
}
.ticketSide__row{
  padding: 12px 16px;
  border-bottom: 1px solid var(--line-1);
  display: flex; flex-direction: column; gap: 4px;
}
.ticketSide__row:last-child{ border-bottom: none }
.ticketSide__rowLbl{ font-size: 11px; color: var(--text-3); font-weight: 600 }
.ticketSide__rowVal{ font-size: 13px; color: var(--text-1); font-weight: 600; unicode-bidi: isolate }
.ticketSide__rowVal--num{ font-variant-numeric: tabular-nums; direction: ltr; unicode-bidi: isolate }
.ticketSide__actions{
  padding: 12px 16px;
  display: flex; gap: 8px;
}
.ticketSide__actions .btn{ flex: 1 }

/* Composer panel (collapsible) */
.replyPanel{
  background: var(--bg-2);
  border: 1px solid var(--line-1);
  border-radius: 12px;
  margin-bottom: 16px;
  overflow: hidden;
}
.replyPanel__toggle{
  display:flex; align-items:center; justify-content:space-between;
  padding: 14px 18px;
  cursor: pointer;
  user-select: none;
  border: none; background: transparent;
  color: var(--brand-amber);
  font-size: 14px; font-weight: 700;
  width: 100%;
  font-family: inherit;
}
.replyPanel__toggle svg{ width: 16px; height: 16px; transition: transform .25s }
.replyPanel.is-open .replyPanel__toggle svg{ transform: rotate(180deg) }
.replyPanel__body{
  padding: 0 18px 18px;
  display: none;
}
.replyPanel.is-open .replyPanel__body{ display: block }
.replyPanel__field{ margin-bottom: 12px }
.replyPanel__lbl{
  display: block;
  font-size: 12px; font-weight: 600;
  color: var(--text-2);
  margin-bottom: 6px;
}
.replyPanel__textarea{
  width: 100%;
  min-height: 200px;
  padding: 12px 14px;
  background: var(--bg-1);
  border: 1px solid var(--line-1);
  border-radius: 8px;
  color: var(--text-1);
  font-family: inherit;
  font-size: 13px;
  line-height: 1.7;
  resize: vertical;
}
.replyPanel__textarea:focus{ outline: none; border-color: var(--brand-amber) }
.replyPanel__file{
  display: flex; gap: 8px; align-items: center;
}
.replyPanel__filebtn{
  padding: 8px 14px;
  background: var(--bg-3);
  border: 1px solid var(--line-1);
  border-radius: 6px;
  color: var(--text-1);
  font-size: 12px;
  cursor: pointer;
  font-weight: 600;
}
.replyPanel__filebtn:hover{ border-color: var(--brand-amber); color: var(--brand-amber) }
.replyPanel__filename{ font-size: 12px; color: var(--text-3) }
.replyPanel__hint{
  font-size: 11px; color: var(--text-3); margin-top: 6px;
  unicode-bidi: isolate;
}
.replyPanel__actions{
  display: flex; gap: 8px; justify-content: flex-end;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--line-1);
}

/* === Message cards === */
.msgCard{
  background: var(--bg-2);
  border: 1px solid var(--line-1);
  border-radius: 10px;
  margin-bottom: 12px;
  overflow: hidden;
}
.msgCard--admin{ border-inline-start: 3px solid var(--brand-amber) }
.msgCard--user { border-inline-start: 3px solid #5a9cff }

.msgCard__head{
  display: flex; align-items: center; gap: 14px;
  padding: 12px 18px;
  border-bottom: 1px solid var(--line-1);
  flex-wrap: wrap;
}
.msgCard__author{
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; font-weight: 700;
  color: var(--brand-amber);
}
.msgCard--user .msgCard__author{ color: #6da9ff }
.msgCard__roleTag{
  font-size: 10px;
  font-weight: 600;
  color: var(--text-3);
  margin-inline-start: 6px;
}
.msgCard__time{
  margin-inline-start: auto;
  font-size: 11px;
  color: var(--text-3);
  font-variant-numeric: tabular-nums;
  direction: ltr;
  unicode-bidi: isolate;
}
.msgCard__body{
  padding: 16px 18px;
  font-size: 14px;
  line-height: 1.85;
  color: var(--text-1);
  unicode-bidi: isolate;
  white-space: pre-wrap;
  word-wrap: break-word;
}
.msgCard__body a{ color: var(--brand-amber); text-decoration: none }
.msgCard__body a:hover{ text-decoration: underline }
.msgCard__img{
  display: block;
  max-width: 100%;
  max-height: 320px;
  border-radius: 8px;
  margin-top: 12px;
  border: 1px solid var(--line-1);
}

/* Closed-ticket banner inside detail */
.closedBanner{
  background: rgba(90,156,255,.08);
  border: 1px solid rgba(90,156,255,.30);
  color: #a6c4ff;
  padding: 12px 16px;
  border-radius: 8px;
  font-size: 13px;
  text-align: center;
  margin-bottom: 14px;
}
[data-theme="light"] .closedBanner{ color: #1d4ed8 }

/* New ticket modal: section pick step */
.sectionPicker{
  display:flex; flex-direction:column; gap:10px;
}
.sectionPicker__opt{
  display:flex; align-items:center; gap:14px;
  padding: 14px 16px;
  background: var(--bg-3);
  border: 1px solid var(--line-1);
  border-radius: 10px;
  cursor: pointer;
  transition: border-color .15s;
}
.sectionPicker__opt:hover{ border-color: var(--brand-amber) }
.sectionPicker__opt.is-selected{ border-color: var(--brand-amber); background: rgba(243,198,109,.06) }
.sectionPicker__opt svg{ width: 20px; height: 20px; color: var(--brand-amber); flex-shrink: 0 }
.sectionPicker__optTitle{ font-size: 13px; font-weight: 700; color: var(--text-1); margin: 0 }
.sectionPicker__optSub{ font-size: 11px; color: var(--text-3); margin: 2px 0 0 }
.sectionPicker__opt input{ display: none }


/* === Forum-style ticket detail layout === */
.ticketView{
  display:grid;
  grid-template-columns: 1fr 280px;
  gap:18px;
}
.ticketView__main{ min-width:0 }
.ticketView__side{ display:flex; flex-direction:column; gap:12px }
@media (max-width: 880px){
  .ticketView{ grid-template-columns: 1fr }
  .ticketView__side{ order: 0 }
  .ticketView__main{ order: 1 }
}

/* Ticket banner (title + status) */
.ticketBanner{
  background:var(--bg-2);
  border:1px solid var(--line-1);
  border-radius:var(--radius);
  padding:18px 20px;
  margin-bottom:14px;
}
.ticketBanner__id{
  font-size:11px; color:var(--text-3);
  direction:ltr; unicode-bidi:isolate;
  font-variant-numeric:tabular-nums;
  letter-spacing:.4px;
}
.ticketBanner__title{
  font-size:20px; font-weight:800; color:var(--text-1);
  margin:4px 0 10px; line-height:1.4;
  unicode-bidi:isolate;
}
.ticketBanner__chips{ display:flex; flex-wrap:wrap; gap:6px; align-items:center }

/* Closed banner */
.ticketClosedNote{
  background:rgba(156,163,175,.08);
  border:1px solid rgba(156,163,175,.22);
  color:var(--text-2);
  border-radius:var(--radius);
  padding:12px 16px;
  font-size:13px;
  margin-bottom:14px;
  display:flex; align-items:center; gap:10px;
}
.ticketClosedNote svg{ width:16px; height:16px; color:#9ca3af; flex-shrink:0 }

/* Forum-style message card */
.msgCard{
  background:var(--bg-2);
  border:1px solid var(--line-1);
  border-radius:var(--radius);
  margin-bottom:12px;
  overflow:hidden;
  position:relative;
}
.msgCard::before{
  content:"";
  position:absolute;
  inset-inline-start:0;
  top:0; bottom:0;
  width:3px;
}
.msgCard--user::before  { background:var(--brand-amber) }
.msgCard--admin::before { background:var(--brand-red) }

.msgCard__head{
  display:flex; align-items:center; gap:10px;
  padding:12px 16px;
  border-bottom:1px solid var(--line-1);
  background:var(--bg-1);
  flex-wrap:wrap;
}
.msgCard__avatar{
  width:30px; height:30px; border-radius:50%;
  display:grid; place-items:center;
  font-size:14px; font-weight:700;
  flex-shrink:0;
}
.msgCard__avatar svg{ width:14px; height:14px }
.msgCard--user .msgCard__avatar  { background:rgba(243,198,109,.14); color:var(--brand-amber); border:1px solid rgba(243,198,109,.30) }
.msgCard--admin .msgCard__avatar { background:rgba(207,36,36,.14); color:var(--brand-red); border:1px solid rgba(207,36,36,.30) }

.msgCard__who{ display:flex; flex-direction:column; gap:1px; min-width:0 }
.msgCard__name{
  font-size:13px; font-weight:700;
  unicode-bidi:isolate;
}
.msgCard--user .msgCard__name  { color:var(--brand-amber) }
.msgCard--admin .msgCard__name { color:var(--brand-red) }
.msgCard__role{
  font-size:11px; color:var(--text-3); font-weight:500;
}
.msgCard__time{
  margin-inline-start:auto;
  font-size:11px; color:var(--text-3);
  font-variant-numeric:tabular-nums;
  direction:ltr; unicode-bidi:isolate;
  display:flex; flex-direction:column; align-items:flex-end; gap:1px;
}
.msgCard__time small{ font-size:10px; opacity:.7 }

.msgCard__body{
  padding:14px 16px 16px;
  font-size:13px;
  line-height:1.75;
  color:var(--text-1);
  word-wrap:break-word;
  white-space:pre-wrap;
  unicode-bidi:isolate;
}
.msgCard__body img{
  max-width:100%; max-height:300px;
  border-radius:8px; margin-top:8px; display:block;
}

/* Reply composer */
.replyBox{
  background:var(--bg-2);
  border:1px solid var(--line-1);
  border-radius:var(--radius);
  margin-top:14px;
  overflow:hidden;
}
.replyBox__head{
  padding:10px 16px;
  background:var(--bg-1);
  border-bottom:1px solid var(--line-1);
  font-size:13px; font-weight:600; color:var(--brand-amber);
  display:flex; align-items:center; gap:8px;
}
.replyBox__head svg{ width:14px; height:14px }
.replyBox__body{ padding:14px 16px }
.replyBox textarea{
  width:100%; min-height:90px; max-height:220px;
  padding:10px 14px;
  border-radius:8px;
  background:var(--bg-1);
  border:1px solid var(--line-1);
  color:var(--text-1);
  font-family:inherit; font-size:13px; line-height:1.6;
  resize:vertical; box-sizing:border-box;
  unicode-bidi:isolate;
}
.replyBox textarea:focus{ outline:none; border-color:var(--brand-amber) }
.replyBox__actions{
  display:flex; gap:8px; justify-content:flex-end;
  padding:10px 16px;
  background:var(--bg-1);
  border-top:1px solid var(--line-1);
}

/* Side panel: ticket info */
.ticketInfo{
  background:var(--bg-2);
  border:1px solid var(--line-1);
  border-radius:var(--radius);
  overflow:hidden;
}
.ticketInfo__head{
  padding:12px 16px;
  border-bottom:1px solid var(--line-1);
  background:var(--bg-1);
  font-size:13px; font-weight:700; color:var(--text-1);
}
.ticketInfo__row{
  padding:12px 16px;
  border-bottom:1px solid var(--line-1);
}
.ticketInfo__row:last-child{ border-bottom:0 }
.ticketInfo__lbl{
  font-size:10px; color:var(--text-3); font-weight:600;
  text-transform:uppercase; letter-spacing:.6px;
  margin-bottom:4px;
}
.ticketInfo__val{
  font-size:13px; color:var(--text-1); font-weight:500;
  word-break:break-word;
  unicode-bidi:isolate;
}
.ticketInfo__val--id{ direction:ltr; font-variant-numeric:tabular-nums }

/* Side panel actions */
.ticketActions{
  display:flex; flex-direction:column; gap:8px;
}

/* Owner badge */
.ownerBadge{
  display:inline-flex; align-items:center;
  padding:1px 7px;
  border-radius:4px;
  background:rgba(70,214,126,.12);
  color:var(--success);
  font-size:10px; font-weight:700;
  margin-inline-start:6px;
  border:1px solid rgba(70,214,126,.24);
}

/* === Ticket detail v2 — forum-style layout (like screenshots) === */
.ticketLayout{
  display:grid;
  grid-template-columns: 1fr 280px;
  gap:18px;
  align-items:start;
}
[dir="rtl"] .ticketLayout{ grid-template-columns: 280px 1fr }
@media (max-width: 900px){
  .ticketLayout{ grid-template-columns: 1fr }
  [dir="rtl"] .ticketLayout{ grid-template-columns: 1fr }
}

.ticketAlert{
  background: linear-gradient(180deg, rgba(207,36,36,.10), rgba(207,36,36,.04));
  border: 1px solid rgba(207,36,36,.34);
  color: #ffb4b4;
  padding: 12px 16px;
  border-radius: 10px;
  font-size: 12px;
  line-height: 1.7;
  text-align: center;
  margin-bottom: 14px;
}
[data-theme="light"] .ticketAlert{ color:#8b1a1a; background: rgba(207,36,36,.06) }

.ticketClosedNote{
  background: rgba(90,156,255,.10);
  border: 1px solid rgba(90,156,255,.30);
  color: #a8c8ff;
  padding: 11px 14px;
  border-radius: 10px;
  font-size: 13px;
  margin-bottom: 14px;
}
[data-theme="light"] .ticketClosedNote{ color:#1d4ed8; background:rgba(90,156,255,.10) }

/* Right-side info card */
.ticketInfo{ position:sticky; top:80px }
.ticketInfo__head{
  background: var(--bg-2);
  border: 1px solid var(--line-1);
  border-radius: var(--radius) var(--radius) 0 0;
  padding: 12px 16px;
  font-weight: 700;
  color: var(--brand-amber);
  font-size: 14px;
}
.ticketInfo__body{
  background: var(--bg-2);
  border: 1px solid var(--line-1);
  border-top: none;
  border-radius: 0 0 var(--radius) var(--radius);
  padding: 4px 0 12px;
}
.ticketInfo__row{
  padding: 12px 16px;
  border-top: 1px solid var(--line-1);
}
.ticketInfo__row:first-child{ border-top: none }
.ticketInfo__lbl{ font-size: 11px; color: var(--text-3); margin-bottom: 4px; font-weight:600 }
.ticketInfo__val{ font-size: 13px; color: var(--text-1); font-weight: 600; display:flex; align-items:center; gap:8px; flex-wrap:wrap }
.ticketInfo__val--num{ direction:ltr; unicode-bidi:isolate; font-variant-numeric:tabular-nums }
.ticketInfo__role{
  display:inline-flex; align-items:center; padding: 2px 8px;
  border-radius: 4px; font-size: 10px; font-weight: 700;
  background: rgba(70,214,126,.15); color: #46d67e; border: 1px solid rgba(70,214,126,.30);
}
.ticketInfo__role--operator{ background:rgba(243,198,109,.14); color:#f3c66d; border-color:rgba(243,198,109,.30) }

.ticketInfo__actions{
  display:flex; gap:8px; padding: 14px 16px 4px;
}
.ticketInfo__actions .btn{ flex:1 }

/* Reply collapsed button */
.replyToggle{
  background: var(--bg-2);
  border: 1px solid var(--line-1);
  border-radius: var(--radius);
  padding: 14px 18px;
  display: flex; align-items: center; justify-content: space-between;
  cursor: pointer;
  margin-bottom: 14px;
  user-select: none;
  transition: background .15s, border-color .15s;
}
.replyToggle:hover{ background: var(--bg-3); border-color: var(--brand-amber) }
.replyToggle__lbl{ display:flex; align-items:center; gap:8px; color: var(--brand-amber); font-weight:700; font-size:14px }
.replyToggle__chev{ width:14px; height:14px; color: var(--text-3); transition: transform .2s }
.replyToggle.is-open .replyToggle__chev{ transform: rotate(180deg) }

/* Composer expanded */
.replyForm{
  background: var(--bg-2);
  border: 1px solid var(--line-1);
  border-radius: var(--radius);
  padding: 0;
  margin-bottom: 14px;
  display: none;
}
.replyForm.is-open{ display: block }
.replyForm__head{
  display:flex; align-items:center; justify-content:space-between;
  padding: 12px 16px;
  border-bottom: 1px solid var(--line-1);
  font-size: 13px; font-weight: 700; color: var(--text-1);
}
.replyForm__lbl{ display:flex; align-items:center; gap:8px; color: var(--brand-amber) }
.replyForm__body{ padding: 14px 16px }
.replyForm__textarea{
  width: 100%;
  background: var(--bg-1);
  border: 1px solid var(--line-1);
  border-radius: 8px;
  color: var(--text-1);
  padding: 12px 14px;
  min-height: 140px;
  font-family: inherit;
  font-size: 13px;
  line-height: 1.7;
  resize: vertical;
}
.replyForm__textarea:focus{ outline: none; border-color: var(--brand-amber) }
.replyForm__row{
  display:flex; gap:10px; align-items:center; margin-top:12px; flex-wrap:wrap;
}
.replyForm__attach{
  display:inline-flex; align-items:center; gap:8px; cursor: pointer;
  padding: 8px 14px; border-radius: 8px;
  background: var(--bg-3); border: 1px solid var(--line-1);
  color: var(--text-2); font-size:12px;
}
.replyForm__attach input{ display:none }
.replyForm__attach:hover{ border-color: var(--brand-amber); color: var(--text-1) }
.replyForm__foot{
  display:flex; gap:10px; padding: 12px 16px;
  border-top: 1px solid var(--line-1);
  justify-content: flex-end;
}

/* Forum-style messages */
.fmsg{
  background: var(--bg-2);
  border: 1px solid var(--line-1);
  border-radius: var(--radius);
  margin-bottom: 12px;
  border-inline-start: 3px solid var(--brand-amber);
  overflow: hidden;
}
.fmsg--admin{ border-inline-start-color: var(--brand-amber) }
.fmsg--user{ border-inline-start-color: #5a9cff }
.fmsg__head{
  display:flex; align-items:center; justify-content:space-between;
  padding: 12px 16px;
  background: var(--bg-3);
  border-bottom: 1px solid var(--line-1);
  font-size: 12px;
  flex-wrap: wrap; gap: 8px;
}
.fmsg__author{ display:flex; align-items:center; gap:8px }
.fmsg__authorIcon{
  width:18px; height:18px; border-radius:50%;
  background: var(--bg-1); border:1px solid var(--line-1);
  display:grid; place-items:center; color:var(--text-3);
}
.fmsg__authorIcon svg{ width:11px; height:11px }
.fmsg__authorName{ font-weight:700; color:var(--brand-amber); font-size:13px }
.fmsg__authorRole{ font-size:11px; color:var(--text-3) }
.fmsg__time{ color:var(--text-3); font-size:11px; direction:ltr; unicode-bidi:isolate; font-variant-numeric:tabular-nums }
.fmsg__body{
  padding: 16px;
  color: var(--text-1);
  font-size: 13px;
  line-height: 1.85;
  word-wrap: break-word;
}
.fmsg__body img{ max-width:100%; max-height:300px; border-radius:8px; margin-top:6px; display:block }
.fmsg__body a{ color: var(--brand-amber); text-decoration: none }
.fmsg__body a:hover{ text-decoration: underline }
.fmsg__rate{
  padding: 8px 16px;
  border-top: 1px solid var(--line-1);
  display:flex; gap:4px; color: var(--text-4);
}
.fmsg__star{ width:14px; height:14px; cursor: pointer; transition: color .15s }
.fmsg__star:hover, .fmsg__star.is-on{ color: var(--brand-amber) }


/* Cart badge in sidebar (added v3) */
.sidebar__badge {
  display: none;          /* JS sets display:inline-block when count > 0 */
  margin-inline-start: auto;
  background: #cf2424;
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  border-radius: 99px;
  padding: 2px 7px;
  min-width: 18px;
  text-align: center;
  font-variant-numeric: tabular-nums;
  line-height: 1;
}

/* ===== Game-link modal (added v3) ===== */
#gameLinkModal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
#gameLinkModal .gameLinkModal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.78);
  backdrop-filter: blur(4px);
}
#gameLinkModal .gameLinkModal__inner {
  position: relative;
  width: 100%;
  max-width: 440px;
  background: var(--bg-1);
  border: 1px solid var(--line-1);
  border-radius: 14px;
  padding: 32px 28px 24px;
  box-shadow: 0 30px 80px rgba(0,0,0,.5);
  animation: gameLinkIn 220ms ease-out;
}
@keyframes gameLinkIn {
  from { opacity: 0; transform: translateY(8px) scale(.98); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}
.gameLinkModal__close {
  position: absolute;
  top: 12px;
  inset-inline-end: 12px;
  width: 32px; height: 32px;
  border: 0; background: transparent;
  color: var(--text-3); cursor: pointer; font-size: 16px;
  border-radius: 6px;
}
.gameLinkModal__close:hover { background: var(--bg-2); color: var(--text-1); }
.gameLinkModal__brand { text-align: center; margin-bottom: 14px; }
.gameLinkModal__title {
  text-align: center;
  font-size: 18px;
  margin: 0 0 8px;
  color: var(--text-1);
  font-weight: 700;
}
.gameLinkModal__sub {
  text-align: center;
  font-size: 13px;
  color: var(--text-3);
  margin: 0 0 20px;
}
.gameLinkModal__cmd {
  display: flex;
  gap: 8px;
  align-items: stretch;
  margin-bottom: 14px;
}
.gameLinkModal__cmd code {
  flex: 1;
  background: var(--bg-2);
  border: 1px solid var(--line-1);
  border-radius: 8px;
  padding: 12px 14px;
  font-size: 15px;
  font-family: 'JetBrains Mono', 'Fira Code', monospace;
  color: var(--brand-amber);
  font-weight: 600;
  letter-spacing: 1px;
  direction: ltr;
  unicode-bidi: isolate;
  text-align: center;
}
.gameLinkModal__meta {
  text-align: center;
  font-size: 12px;
  color: var(--text-3);
  margin-bottom: 8px;
}
.gameLinkModal__meta strong {
  color: var(--text-1);
  font-variant-numeric: tabular-nums;
}
.gameLinkModal__hint {
  text-align: center;
  font-size: 11px;
  color: var(--text-3);
  margin: 8px 0 0;
}

/* ============================================================
   MOBILE RESPONSIVE FIXES — comprehensive pass for the dashboard
   on phones (≤640px wide). Fixes inline-styled grids that didn't
   collapse, summary cards that were sticky off-screen, button rows
   that overflowed, topbar density, and the checkout/cart/payment
   pages specifically.
   ============================================================ */
@media (max-width: 768px){

  /* ---- 1. Cart page ----
     The cart grid is inline-styled `2fr 1fr` which won't collapse
     without help. Force it to a single column. Also kill the sticky
     position on the summary card so the user reaches the buttons by
     scrolling normally instead of fighting a half-stuck panel. */
  #cartGrid{
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }
  #cartGrid > section{
    position: static !important;   /* was: sticky top:80px */
    top: auto !important;
  }

  /* ---- 2. Checkout page summary card ----
     Already had a media query at 780px collapsing the grid, but the
     summary card on the right needs the same de-stickying treatment. */
  .checkoutPage__grid > section{
    position: static !important;
    top: auto !important;
  }

  /* ---- 3. Cart / checkout / wallet buttons ----
     The big primary + outline buttons stacked vertically in summary
     cards. On small screens they could be too tall, so size them down
     and tighten the gap. */
  .card__body .btn--block.btn--lg{
    padding: 12px 14px !important;
    font-size: 14px !important;
    min-height: 44px;
  }

  /* ---- 4. Topbar tightening ----
     The topbar on a phone is cramped: brand title + serverPill + lang
     pill + userBtn. Hide low-value bits and shrink padding. */
  .topbar{
    padding: 0 10px !important;
    gap: 6px !important;
    min-height: 56px;
  }
  .topbar__pageTitle{
    font-size: 14px !important;
    max-width: 38vw;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  /* Hide the server-pill text label, keep dot + numbers */
  [data-server-pill] .serverPill__lbl{ display: none !important; }
  [data-server-pill] .serverPill{
    padding: 5px 9px !important;
    gap: 5px !important;
    font-size: 11.5px;
  }
  /* User name truncated; the button itself becomes mostly the avatar */
  .userBtn{
    padding: 3px 6px 3px 3px !important;
  }
  [dir="rtl"] .userBtn{
    padding: 3px 3px 3px 6px !important;
  }
  .userBtn__name{ display: none !important; }
  .userBtn svg{ display: none; }    /* hide caret arrow on phone */

  /* Lang pill smaller */
  .langPill{ padding: 2px !important; }
  .langPill__opt{
    padding: 3px 7px !important;
    font-size: 10px !important;
  }

  /* ---- 5. Notifications bell button ----
     Make sure the bell stays visible and tappable (44×44 min). */
  .topbar [data-notif-btn]{
    width: 38px !important;
    height: 38px !important;
  }

  /* ---- 6. Page heading sizes ---- */
  .page__title{ font-size: 20px !important; }
  .page__sub  { font-size: 12.5px !important; }
  .page__head { margin-bottom: 14px !important; }

  /* ---- 7. Section card padding ----
     Big top/side paddings eat the small viewport. */
  .card__head{ padding: 12px 14px !important; }
  .card__body{ padding: 12px 14px !important; }
  .card__title{ font-size: 14px !important; }

  /* ---- 8. Payment result page ----
     Hero icon and headline scaled down to fit. */
  .payResultIcon{
    width: 64px !important;
    height: 64px !important;
  }
  .payResultIcon svg{
    width: 32px !important;
    height: 32px !important;
  }
  .payResultTitle{ font-size: 20px !important; }
  .payResultDesc{ font-size: 13px !important; }

  /* ---- 9. Pay method options (Zibal etc.) ----
     Single column, smaller padding. */
  .payMethod{
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
  }
  .payOpt{
    padding: 10px 12px !important;
    gap: 10px !important;
  }
  .payOpt__logo{
    width: 36px !important;
    height: 36px !important;
    font-size: 14px !important;
  }
  .payOpt__name{ font-size: 13px !important; }
  .payOpt__sub{ font-size: 11px !important; }

  /* ---- 10. Summary rows in cart/checkout/wallet ---- */
  .summary__row{
    padding: 8px 0 !important;
    font-size: 13px !important;
  }
  .summary__row--total{
    font-size: 15px !important;
  }

  /* ---- 11. Use-wallet toggle row on checkout (was inline padded) ---- */
  #cUseWallet ~ div,
  [for="cUseWallet"] ~ div{
    font-size: 11px !important;
  }

  /* ---- 12. Orders list table — already responsive but force any
        leftover wide grid to wrap. */
  .ordersGrid{ overflow-x: auto; }

  /* ---- 13. Store rank cards: tighter on phones ---- */
  .storeGrid{
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }
  .rankCardS{ padding: 14px !important; }
  .rankCardS__name{ font-size: 16px !important; }

  /* ---- 14. Bottom-nav offset — page already has bottom padding for
        the bottom nav, but for cart/checkout the action buttons need
        extra breathing room so users don't tap through to the nav. */
  body.has-bottomnav .page{
    padding-bottom: calc(var(--bottomnav-h, 58px) + 28px) !important;
  }

  /* ---- 15. Wallet top-up amount input — bigger tap target ---- */
  #topUpAmount,
  input[type="number"].field__input{
    font-size: 16px !important;   /* prevents iOS auto-zoom */
    padding: 12px 14px !important;
  }

  /* ---- 16. Modal cards (rank details, game-link etc.) ----
        Full-screen with safe-area insets on small phones. */
  .rdModal__panel,
  .gameLinkModal__panel{
    width: 100% !important;
    max-width: 100% !important;
    border-radius: 16px !important;
    margin: 8px !important;
  }
}

/* Extra-small phones (≤380px) — really tight */
@media (max-width: 380px){
  .topbar__pageTitle{ font-size: 13px !important; max-width: 32vw; }
  .userBtn__avatar{ width: 24px !important; height: 24px !important; font-size: 9px !important; }
  .langPill__opt{ padding: 2px 6px !important; }
}

/* ============================================================
   Round 2 — additional mobile fixes for stand-alone pages
   (checkout, payment-result) which use their own layout shell
   instead of the sidebar/topbar. These have separate headers
   that need their own responsive tuning.
   ============================================================ */
@media (max-width: 768px){

  /* Checkout/payment top bar — tighter padding, smaller brand */
  .checkoutPage__top{
    height: 54px !important;
    padding: 0 12px !important;
    gap: 8px !important;
  }
  .checkoutPage__brand img{ width: 24px !important; height: 24px !important; }
  .checkoutPage__brand span{ font-size: 11px !important; letter-spacing: .4px !important; }

  /* "Back to dashboard" button — make it icon-only on phones to save space */
  .checkoutPage__top .btn--ghost.btn--sm span:not([class]){ display: none !important; }
  .checkoutPage__top .btn--ghost.btn--sm{
    padding: 6px 8px !important;
    margin-inline-start: 4px !important;
  }
  .checkoutPage__top .btn--ghost.btn--sm svg{ margin: 0 !important; }

  /* Checkout main padding */
  .checkoutPage__main{
    padding: 16px 12px !important;
  }
  .checkoutPage__inner h1{
    font-size: 19px !important;
    margin-bottom: 4px !important;
  }
  .checkoutPage__inner > p{
    font-size: 12px !important;
    margin-bottom: 14px !important;
  }

  /* Stack the iconBtn theme toggle smaller */
  .checkoutPage__top .iconBtn{
    width: 34px !important;
    height: 34px !important;
  }
  .checkoutPage__top .iconBtn svg{ width: 16px !important; height: 16px !important; }
}

/* ============================================================
   PWA install banner — slides up from the bottom of the
   dashboard when the browser allows installation. The user can
   tap "Install" to add PersianToxic as an app, or × to dismiss.
   Hidden by default; revealed by [data-pwa-install] handler in
   pwa-register.js setting body.pwa-installable.
   ============================================================ */
.pwaInstallBanner{
  position: fixed;
  bottom: calc(var(--bottomnav-h, 0px) + 14px);
  left: 50%;
  transform: translateX(-50%) translateY(20px);
  width: min(380px, calc(100vw - 24px));
  z-index: 60;
  background: linear-gradient(180deg, rgba(207,36,36,.95), rgba(160,24,24,.95));
  border: 1px solid rgba(243,198,109,.35);
  border-radius: 14px;
  padding: 12px 14px;
  display: flex;
  align-items: center;
  gap: 10px;
  box-shadow: 0 18px 40px rgba(0,0,0,.45), 0 0 0 1px rgba(255,255,255,.05) inset;
  opacity: 0;
  pointer-events: none;
  transition: opacity .35s var(--ease), transform .35s var(--ease);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.pwaInstallBanner__icon{
  width: 38px; height: 38px;
  border-radius: 10px;
  background: rgba(0,0,0,.25);
  display: grid; place-items: center;
  flex-shrink: 0;
}
.pwaInstallBanner__icon img{ width: 24px; height: 24px; }
.pwaInstallBanner__txt{
  flex: 1;
  color: #fff;
  font-size: 13px;
  line-height: 1.35;
  font-weight: 600;
  letter-spacing: .1px;
}
.pwaInstallBanner__txt small{
  display: block;
  font-size: 11px;
  font-weight: 500;
  opacity: .82;
  margin-top: 1px;
}
.pwaInstallBanner__cta{
  background: #fff;
  color: #cf2424;
  border: none;
  padding: 7px 13px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
  white-space: nowrap;
  letter-spacing: .2px;
  transition: transform .15s var(--ease);
}
.pwaInstallBanner__cta:hover{ transform: scale(1.04); }
.pwaInstallBanner__close{
  background: rgba(0,0,0,.2);
  border: none;
  color: rgba(255,255,255,.85);
  width: 28px; height: 28px;
  border-radius: 50%;
  cursor: pointer;
  display: grid; place-items: center;
  flex-shrink: 0;
  font-size: 16px;
  line-height: 1;
}
.pwaInstallBanner__close:hover{ background: rgba(0,0,0,.35); color: #fff; }

/* Reveal only when:  body.pwa-installable AND not body.pwa-banner-dismissed */
body.pwa-installable:not(.pwa-banner-dismissed) .pwaInstallBanner{
  opacity: 1;
  transform: translateX(-50%) translateY(0);
  pointer-events: auto;
}
/* Hide in standalone (already installed) */
html.pwa-standalone .pwaInstallBanner{ display: none !important; }
