/* ============================================================
   وناااسة — Token shims + new-screen helpers
   Defines aliases used across shop/legal/auth that were missing,
   plus shared utilities for the new screens (account/error/payment).
   ============================================================ */

:root,
html[data-theme="site"] {
  /* Aliases used across older files — keep these stable */
  --surface:    var(--bg-card);     /* white card */
  --surface-2:  var(--t-cream);     /* warm cream */
  --ink-2:      var(--ink-muted);   /* muted ink */
  --ink-3:      rgba(0,0,0,.12);
  --t-danger:   var(--t-warn);      /* alias for the red warn color */
  --content-max: 1240px;
}

/* ─── Shared block: page hero variants on cream / white / ink ─── */
.wa-pagehead--cream { background: var(--surface-2); border: var(--bd-thick); border-radius: 28px; padding: clamp(36px, 6vw, 64px) clamp(24px, 4vw, 48px); box-shadow: 8px 8px 0 var(--ink); }
.wa-pagehead--ink { background: var(--ink); color: #fff; border: var(--bd-thick); border-radius: 28px; padding: clamp(36px, 6vw, 64px) clamp(24px, 4vw, 48px); box-shadow: 8px 8px 0 var(--cta); }
.wa-pagehead--ink .wa-pagehead-title, .wa-pagehead--ink h1 { color: #fff; }
.wa-pagehead--ink .wa-pagehead-sub { color: rgba(255,255,255,.78); }

/* ─── Status icon (big circle) — used in success/fail/empty ─── */
.wa-statusicon {
  width: clamp(96px, 14vw, 140px); height: clamp(96px, 14vw, 140px);
  border-radius: 50%; border: var(--bd-thick); box-shadow: 6px 6px 0 var(--ink);
  display: grid; place-items: center;
  margin: 0 auto 28px;
}
.wa-statusicon svg { width: 56%; height: 56%; }
.wa-statusicon--success { background: var(--t-success); color: #fff; }
.wa-statusicon--fail    { background: var(--t-warn); color: #fff; }
.wa-statusicon--info    { background: var(--cta); color: var(--ink); }
.wa-statusicon--mute    { background: var(--surface-2); color: var(--ink); }

/* ─── Centered single-card layouts (forgot/reset/error/maintenance) ─── */
.wa-stage {
  min-height: calc(100vh - 220px);
  display: grid; place-items: center;
  padding: clamp(28px, 5vw, 64px) var(--pad-x);
}
.wa-stage-card {
  width: 100%;
  max-width: 540px;
  background: var(--surface);
  border: var(--bd-thick);
  border-radius: 26px;
  box-shadow: 8px 8px 0 var(--ink);
  padding: clamp(32px, 4vw, 48px);
  text-align: center;
}
.wa-stage-title { font-family: var(--font-display); font-weight: 900; font-size: clamp(28px, 4vw, 40px); line-height: 1.15; margin: 0 0 12px; color: var(--ink); letter-spacing: -.01em; }
.wa-stage-sub   { font-size: clamp(15px, 1.5vw, 17px); line-height: 1.6; color: var(--ink-2); margin: 0 0 24px; }

/* ─── Pill chips (status, eyebrow on hero) ─── */
.wa-chip { display: inline-flex; align-items: center; gap: 8px; padding: 6px 14px; border-radius: 999px; border: 2px solid var(--ink); font-weight: 800; font-size: 13px; }
.wa-chip--cta     { background: var(--cta); color: var(--ink); }
.wa-chip--cream   { background: var(--surface-2); color: var(--ink); }
.wa-chip--ink     { background: var(--ink); color: #fff; }
.wa-chip--success { background: var(--t-success); color: #fff; border-color: var(--ink); }
.wa-chip--warn    { background: var(--t-warn); color: #fff; border-color: var(--ink); }

/* ─── Inline action row (used in cards) ─── */
.wa-actions { display: flex; gap: 10px; flex-wrap: wrap; justify-content: center; margin-top: 20px; }
.wa-actions--start { justify-content: flex-start; }

/* ─── Secondary button (white, thick border) ─── */
.btn-sec {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 22px;
  background: var(--surface);
  border: var(--bd-thick);
  border-radius: 14px;
  box-shadow: var(--sh-2);
  font-family: inherit; font-weight: 800; font-size: 15px; color: var(--ink);
  transition: transform .2s var(--ease-spring), box-shadow .2s var(--ease-spring);
  cursor: pointer; text-decoration: none;
}
.btn-sec:hover { transform: translate(-2px, -2px); box-shadow: var(--sh-3); }
.btn-sec:active { transform: translate(2px, 2px); box-shadow: 2px 2px 0 var(--ink); }
.btn-sec--sm { padding: 9px 16px; font-size: 14px; }

.btn-ghost {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 18px;
  background: transparent;
  border: 2px dashed var(--ink-2);
  border-radius: 12px;
  font-family: inherit; font-weight: 800; font-size: 14px; color: var(--ink-2);
  cursor: pointer; text-decoration: none;
  transition: color .2s, border-color .2s, background .2s;
}
.btn-ghost:hover { color: var(--ink); border-color: var(--ink); background: var(--surface-2); }

.btn-link { color: var(--t-primary); font-weight: 800; text-decoration: underline; text-underline-offset: 3px; text-decoration-thickness: 2px; text-decoration-color: var(--cta); }
.btn-link:hover { text-decoration-color: var(--t-primary); }

/* ─── Shared footer (injected by wa-shell.js) ─── */
.wa-footer { background: var(--ink); color: #fff; padding: clamp(40px,6vw,72px) 0 24px; margin-top: clamp(40px,6vw,80px); }
.wa-footer-inner { max-width: var(--content-max,1240px); margin: 0 auto; padding: 0 clamp(20px,4vw,40px); }
.wa-footer-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 40px; padding-bottom: 32px; border-bottom: 2px solid rgba(255,255,255,.12); }
@media (max-width: 800px) { .wa-footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; } .wa-footer-grid > :first-child { grid-column: 1 / -1; } }
.wa-footer-brand { font-family: 'Blabeloo', sans-serif; font-size: 32px; font-weight: 900; color: var(--cta); margin: 0 0 10px; letter-spacing: -.02em; }
.wa-footer-tag { color: rgba(255,255,255,.7); font-size: 14px; line-height: 1.5; margin: 0 0 16px; }
.wa-footer-socials { display: flex; gap: 8px; }
.wa-footer-soc {
  width: 40px; height: 40px;
  flex: 0 0 40px;
  display: inline-grid; place-items: center;
  background: rgba(255,255,255,.08);
  border-radius: 12px; color: #fff;
  transition: background .25s, transform .2s var(--ease-spring), color .25s;
  text-decoration: none;
}
.wa-footer-soc:hover { background: var(--cta); color: var(--ink); transform: translateY(-2px); }
.wa-footer-soc svg { width: 18px; height: 18px; flex-shrink: 0; }
.wa-footer-col h4 { font-family: 'Blabeloo', sans-serif; font-size: 14px; letter-spacing: .04em; text-transform: uppercase; color: var(--cta); margin: 0 0 14px; }
.wa-footer-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.wa-footer-col a { color: rgba(255,255,255,.75); text-decoration: none; font-size: 14px; transition: color .2s; }
.wa-footer-col a:hover { color: var(--cta); }
.wa-footer-bot { padding-top: 22px; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 14px; font-size: 13px; color: rgba(255,255,255,.5); }
.wa-footer-bot-links { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; }
.wa-footer-bot-links a { color: rgba(255,255,255,.6); text-decoration: none; }
.wa-footer-bot-links a:hover { color: var(--cta); }

/* ─── Receipt / row patterns (used in account + payment-success) ─── */
.wa-receipt {
  background: var(--surface-2);
  border: 2px solid var(--ink);
  border-radius: 16px;
  padding: 18px 22px;
  display: flex; flex-direction: column; gap: 10px;
  text-align: start;
}
.wa-receipt-row { display: flex; justify-content: space-between; align-items: baseline; gap: 14px; font-size: 14.5px; }
.wa-receipt-row b { font-weight: 800; color: var(--ink); }
.wa-receipt-row span { color: var(--ink-2); }
.wa-receipt-divider { height: 2px; background: rgba(0,0,0,.1); border-radius: 2px; margin: 4px 0; }
.wa-receipt-total { display: flex; justify-content: space-between; align-items: center; gap: 14px; font-family: var(--font-display); font-weight: 900; font-size: 22px; color: var(--ink); }
.wa-receipt-total .num { font-size: 28px; }

/* ─── Account-page layout (sidebar + main) ─── */
.acc-shell {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: clamp(20px, 2.5vw, 32px);
  margin-top: clamp(24px, 4vw, 40px);
}
@media (max-width: 880px) { .acc-shell { grid-template-columns: 1fr; } }

.acc-side {
  background: var(--surface);
  border: var(--bd-thick);
  border-radius: 22px;
  box-shadow: 6px 6px 0 var(--ink);
  padding: 18px;
  height: fit-content;
  position: sticky; top: 90px;
}
@media (max-width: 880px) { .acc-side { position: static; } }
.acc-user {
  display: flex; align-items: center; gap: 14px;
  padding: 6px 6px 18px;
  border-bottom: 2px dashed rgba(0,0,0,.1);
  margin-bottom: 12px;
}
.acc-avatar {
  width: 56px; height: 56px;
  background: var(--cta);
  border: 2.5px solid var(--ink);
  border-radius: 14px;
  display: grid; place-items: center;
  font-family: var(--font-display); font-weight: 900; font-size: 28px;
  box-shadow: 3px 3px 0 var(--ink);
  flex-shrink: 0;
}
.acc-user-meta { min-width: 0; }
.acc-user-name { font-family: var(--font-display); font-weight: 900; font-size: 18px; color: var(--ink); margin: 0; }
.acc-user-tier { font-size: 12.5px; color: var(--ink-2); margin-top: 2px; }
.acc-nav { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 4px; }
.acc-nav a {
  display: flex; align-items: center; gap: 12px;
  padding: 11px 14px;
  border-radius: 12px;
  font-weight: 800; font-size: 14.5px; color: var(--ink-2);
  border: 2px solid transparent;
  transition: all .2s;
}
.acc-nav a:hover { background: var(--surface-2); color: var(--ink); }
.acc-nav a.is-active { background: var(--ink); color: #fff; border-color: var(--ink); box-shadow: 2px 2px 0 var(--cta); }
.acc-nav a.is-active .acc-nav-ico { background: var(--cta); color: var(--ink); border-color: var(--cta); }
.acc-nav-ico {
  width: 28px; height: 28px;
  display: grid; place-items: center;
  background: var(--surface-2);
  border: 1.5px solid var(--ink);
  border-radius: 8px; flex-shrink: 0;
}
.acc-nav-ico svg { width: 16px; height: 16px; }
.acc-nav-end { margin-top: 10px; padding-top: 10px; border-top: 2px dashed rgba(0,0,0,.1); }
.acc-nav .danger { color: var(--t-warn); }
.acc-nav .danger:hover { background: rgba(198,40,40,.08); color: var(--t-warn); }

.acc-main { display: flex; flex-direction: column; gap: clamp(18px, 2vw, 28px); }
.acc-card {
  background: var(--surface);
  border: var(--bd-thick);
  border-radius: 22px;
  box-shadow: 6px 6px 0 var(--ink);
  padding: clamp(22px, 3vw, 32px);
}
.acc-card h2 { font-family: var(--font-display); font-weight: 900; font-size: clamp(22px, 2.5vw, 28px); margin: 0 0 6px; color: var(--ink); letter-spacing: -.01em; }
.acc-card-sub { font-size: 14px; color: var(--ink-2); margin: 0 0 22px; }
.acc-card-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 18px; margin-bottom: 22px; flex-wrap: wrap; }
.acc-card-head > div:first-child { flex: 1; min-width: 200px; }

/* Balance hero */
.acc-balance {
  display: flex; align-items: center; justify-content: space-between; gap: 18px; flex-wrap: wrap;
  background: var(--ink); color: #fff;
  border: var(--bd-thick); border-radius: 22px;
  box-shadow: 6px 6px 0 var(--cta);
  padding: clamp(22px, 3vw, 30px);
  position: relative; overflow: hidden;
}
.acc-balance::after {
  content: "✦"; position: absolute; bottom: -20px; left: -10px;
  font-size: 160px; color: rgba(249,216,46,.08); pointer-events: none;
}
.acc-balance-num { font-family: var(--font-display); font-weight: 900; font-size: clamp(64px, 9vw, 92px); line-height: 1; color: var(--cta); letter-spacing: -.04em; }
.acc-balance-lbl { font-weight: 800; font-size: 14px; color: rgba(255,255,255,.78); margin-top: 4px; letter-spacing: .04em; text-transform: uppercase; }
.acc-balance-meta { display: flex; flex-direction: column; gap: 4px; }
.acc-balance-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.acc-balance .btn-pri { background: var(--cta); color: var(--ink); border-color: var(--cta); box-shadow: 4px 4px 0 #fff; }
.acc-balance .btn-pri:hover { box-shadow: 6px 6px 0 #fff; }
.acc-balance .btn-sec { background: rgba(255,255,255,.08); color: #fff; border-color: rgba(255,255,255,.22); box-shadow: 4px 4px 0 rgba(0,0,0,.4); }
.acc-balance .btn-sec:hover { background: rgba(255,255,255,.16); }

/* Info rows (data fields, read-only) */
.acc-fieldgrid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 12px; }
.acc-field {
  background: var(--surface-2);
  border: 2px solid var(--ink);
  border-radius: 14px;
  padding: 14px 16px;
  display: flex; flex-direction: column; gap: 4px;
}
.acc-field-lbl { font-size: 11.5px; font-weight: 800; color: var(--ink-2); letter-spacing: .04em; text-transform: uppercase; }
.acc-field-val { font-weight: 700; font-size: 15px; color: var(--ink); display: flex; align-items: center; gap: 8px; min-height: 22px; word-break: break-word; }
.acc-field-val .ltr { direction: ltr; unicode-bidi: isolate; }
.acc-field-tag { padding: 2px 8px; background: var(--t-success); color: #fff; border-radius: 999px; font-size: 11px; font-weight: 800; }
.acc-field-tag--mute { background: var(--surface); color: var(--ink-2); border: 1.5px solid var(--ink-2); }

/* Transaction list */
.acc-tx { display: flex; flex-direction: column; gap: 10px; }
.acc-tx-row {
  display: grid;
  grid-template-columns: 44px 1fr auto auto;
  gap: 14px;
  align-items: center;
  padding: 14px 16px;
  background: var(--surface-2);
  border: 2px solid var(--ink);
  border-radius: 14px;
}
@media (max-width: 540px) { .acc-tx-row { grid-template-columns: 44px 1fr auto; } .acc-tx-row > .acc-tx-date { grid-column: 2 / 4; opacity: .7; font-size: 12px; } }
.acc-tx-ico {
  width: 44px; height: 44px;
  display: grid; place-items: center;
  background: var(--surface);
  border: 2px solid var(--ink);
  border-radius: 12px;
  flex-shrink: 0;
}
.acc-tx-ico svg { width: 20px; height: 20px; }
.acc-tx-ico--in { background: var(--t-success); color: #fff; }
.acc-tx-ico--out { background: var(--t-warn); color: #fff; }
.acc-tx-ico--free { background: var(--cta); color: var(--ink); }
.acc-tx-body { min-width: 0; }
.acc-tx-title { font-weight: 800; font-size: 14.5px; color: var(--ink); margin: 0; line-height: 1.3; }
.acc-tx-meta { font-size: 12.5px; color: var(--ink-2); margin-top: 3px; }
.acc-tx-amt { font-family: var(--font-display); font-weight: 900; font-size: 18px; letter-spacing: -.01em; }
.acc-tx-amt--in { color: var(--t-success); }
.acc-tx-amt--out { color: var(--t-warn); }
.acc-tx-date { font-size: 12.5px; color: var(--ink-2); font-weight: 700; min-width: 80px; text-align: end; }

/* Game history rows */
.acc-game { display: grid; grid-template-columns: 64px 1fr auto; gap: 14px; align-items: center; padding: 12px; background: var(--surface-2); border: 2px solid var(--ink); border-radius: 14px; }
.acc-game-cover { width: 64px; height: 64px; border-radius: 10px; border: 2px solid var(--ink); object-fit: cover; background: var(--cta); }
.acc-game-name { font-weight: 800; font-size: 15px; color: var(--ink); margin: 0; }
.acc-game-meta { font-size: 12.5px; color: var(--ink-2); margin-top: 3px; }
.acc-game-cta { padding: 9px 14px; font-size: 13.5px; }

/* Settings toggles (placeholder) */
.acc-toggle-row { display: flex; align-items: center; justify-content: space-between; padding: 14px 0; gap: 14px; border-bottom: 1.5px dashed rgba(0,0,0,.1); }
.acc-toggle-row:last-child { border-bottom: 0; }
.acc-toggle-row .lbl { font-weight: 800; font-size: 15px; color: var(--ink); }
.acc-toggle-row .sub { font-size: 13px; color: var(--ink-2); margin-top: 2px; }
.acc-toggle {
  width: 52px; height: 30px; border-radius: 999px;
  background: var(--surface-2); border: 2px solid var(--ink);
  position: relative; cursor: pointer; flex-shrink: 0;
  transition: background .2s;
}
.acc-toggle::after {
  content: ""; position: absolute; top: 2px; left: 2px;
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--ink); transition: left .25s var(--ease-spring);
}
.acc-toggle.is-on { background: var(--t-success); }
.acc-toggle.is-on::after { left: 26px; background: #fff; }
[dir="rtl"] .acc-toggle::after { left: auto; right: 2px; transition: right .25s var(--ease-spring); }
[dir="rtl"] .acc-toggle.is-on::after { right: 26px; left: auto; }

/* ─── 404 / maintenance giant numbers ─── */
.wa-giant {
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(120px, 22vw, 240px);
  line-height: .9; letter-spacing: -.05em;
  color: var(--cta);
  -webkit-text-stroke: 4px var(--ink);
  text-shadow: 8px 8px 0 var(--ink);
  margin: 0 0 14px;
  display: inline-block;
}

/* ─── Small visible scrollbar fix ─── */
@media (max-width: 540px) {
  .acc-card { padding: 18px; }
}
