:root{
  --bg:#0b1220;
  --panel:#0f172a;
  --line:#243041;
  --text:#e5e7eb;
  --muted:#9ca3af;
  --accent:#60a5fa;
  --ok:#22c55e; --warn:#f59e0b; --bad:#ef4444;
}
*{box-sizing:border-box}
body .game-app{font-family:system-ui,Segoe UI,Roboto,Arial,sans-serif;color:var(--text)}
.game-app{padding-bottom:120px} /* كان 96px */

/* HUD */
.hud{position:sticky;top:0;z-index:5;background:linear-gradient(180deg,rgba(11,18,32,.95),rgba(11,18,32,.85));backdrop-filter:blur(6px);border-bottom:1px solid var(--line);padding:10px 12px}
.hud-res{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.res{display:flex;align-items:center;gap:6px;background:var(--panel);padding:8px;border:1px solid var(--line);border-radius:10px}
.res img{width:18px;height:18px;opacity:.9}
.res .val{font-weight:700}
.res .cap{margin-inline-start:auto;color:var(--muted);font-size:.85rem}
.hud-meta{margin-top:8px;display:flex;align-items:center;gap:10px}
.gold{display:flex;align-items:center;gap:6px;background:#1b1422;padding:6px 10px;border:1px solid #3d2a57;border-radius:999px}
.gold img{width:16px;height:16px}
.th{margin-inline-start:auto;color:var(--muted)}
.btn{appearance:none;border:0;border-radius:10px;padding:8px 12px;background:var(--accent);color:#001b3a;font-weight:700;cursor:pointer}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn-collect{background:#1f2937;color:#e5e7eb;border:1px solid var(--line)}
.btn-upgrade{background:var(--accent)}

/* Grid */
.grid{display:grid;grid-template-columns:1fr;gap:10px;padding:12px}
@media (min-width:480px){.grid{grid-template-columns:repeat(2,1fr)}}
@media (min-width:900px){.grid{grid-template-columns:repeat(3,1fr)}}
.card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:12px;display:flex;gap:12px;align-items:center}
.card .icon{width:40px;height:40px;border-radius:8px;display:grid;place-items:center;background:#0b1324;border:1px solid #1b2740}
.card .meta{flex:1}
.card .title{font-weight:800}
.card .sub{color:var(--muted);font-size:.9rem;margin-top:2px}
.card .act{display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.badge{padding:2px 8px;border-radius:999px;font-size:.8rem;border:1px solid var(--line);color:var(--muted)}
.badge.ok{color:#10b981;border-color:#1f684f}
.badge.warn{color:#f59e0b;border-color:#6b4e0d}

/* Queue Drawer */
.queue-drawer{position:fixed;bottom:0;left:0;right:0;background:linear-gradient(0deg,rgba(15,23,42,.98),rgba(15,23,42,.9));backdrop-filter:blur(6px);border-top:1px solid var(--line);padding:10px 12px;z-index:6}
.qd-title{font-weight:800;margin-bottom:6px}
.qd-items{display:flex;gap:10px;overflow-x:auto;padding-bottom:4px}
.qitem{min-width:220px;background:#0c172c;border:1px solid var(--line);border-radius:10px;padding:8px}
.qitem .q-top{display:flex;justify-content:space-between;align-items:center}
.qitem .q-bar{height:6px;border-radius:6px;background:#0a1020;border:1px solid #1e2a40;margin-top:6px;overflow:hidden}
.qitem .q-fill{height:100%;width:0;background:var(--accent);transition:width .3s}

/* Modal */
.modal{z-index:10000}
.modal{position:fixed;inset:0;display:none}
.modal.show{display:block}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.5)}
.modal-card{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:min(520px,92%);background:var(--panel);border:1px solid var(--line);border-radius:12px;overflow:hidden}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:12px;border-bottom:1px solid var(--line)}
.modal-body{padding:12px}
.modal-actions{padding:12px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:10px}
.modal-close{background:transparent;border:0;color:var(--text);font-size:20px;cursor:pointer}

/* Toasts */
/* توستات أسفل-المنتصف فوق الدروِر */
.toasts{
  position:fixed;
  bottom:96px;         /* فوق الدروِر */
  left:50%;
  transform:translateX(-50%);
  display:flex;flex-direction:column;gap:8px;
  z-index:10001;
  width:min(92%,520px);
}


.toast{padding:10px 12px;border:1px solid var(--line);background:#111827;color:#e5e7eb;border-radius:10px}
.toast.ok{border-color:#1f684f}
.toast.err{border-color:#5b1f1f}

/***** Game polish *****/
.text-muted { color:#9ca3af; }
.badge-outline { border-color:#243041; }
.card.border { border-color:#243041; }
.modal-box { max-height: calc(100dvh - 24px); }
