/* ═══════════════════════════════════════════
   MOJAHID TECH — Arsenal + Tool Widget CSS
═══════════════════════════════════════════ */
:root {
  --p:#237292; --s:#0B7F95; --dk:#0A0F1C; --dk2:#0d1528;
  --lt:#F5F7FA; --ac:#00E5FF;
  --green:#00ff9d; --yellow:#ffc107; --red:#ff5f57; --purple:#c792ea;
}

/* ══ Rarity vars ══ */
.rc-common    { --rc:#9e9e9e; }
.rc-uncommon  { --rc:#4caf50; }
.rc-rare      { --rc:#2196F3; }
.rc-epic      { --rc:#9c27b0; }
.rc-legendary { --rc:#ffc107; }

/* ════════════════════════════
   ARSENAL LIST PAGE
════════════════════════════ */
.ar-wrap { min-height:100vh; background:var(--dk); color:var(--lt);
  direction:rtl; font-family:'Tajawal',sans-serif; padding-top:70px; }

.ar-hero { padding:60px 60px 36px; text-align:center; position:relative; overflow:hidden; }
.ar-hero::before { content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 65% 50% at 50% 35%, rgba(35,114,146,.12) 0%, transparent 65%);
  pointer-events:none; }
.ar-title { font-size:clamp(1.9rem,3.5vw,3rem); font-weight:900; margin-bottom:10px; }
.ar-title span { background:linear-gradient(135deg,var(--p),var(--ac));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.ar-sub { font-size:.92rem; color:rgba(245,247,250,.52); margin-bottom:10px; line-height:1.7; }

.ar-grid { max-width:1200px; margin:0 auto;
  padding:28px 60px 80px;
  display:grid; grid-template-columns:repeat(auto-fill, minmax(270px, 1fr)); gap:18px; }

/* ── Tool card ── */
.ar-card { background:rgba(13,21,40,.8); border:2px solid rgba(35,114,146,.15);
  border-radius:16px; padding:22px; cursor:pointer;
  transition:all .4s cubic-bezier(.34,1.56,.64,1);
  opacity:0; transform:translateY(20px);
  text-decoration:none; color:var(--lt); display:block; position:relative; overflow:hidden; }
.ar-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg, var(--rc, #237292), transparent); }
.ar-card.show { opacity:1; transform:translateY(0); }
.ar-card:hover { transform:translateY(-8px); border-color:rgba(35,114,146,.4);
  box-shadow:0 16px 50px rgba(35,114,146,.18); }
.ar-card-top { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:14px; }
.ar-emoji { font-size:2.2rem; }
.ar-rarity { padding:3px 10px; border-radius:100px; font-size:.63rem; font-weight:700;
  border:1px solid rgba(255,255,255,.12); color:var(--rc, #9e9e9e); background:rgba(0,0,0,.2); }
.ar-name { font-size:1rem; font-weight:800; margin-bottom:3px; }
.ar-name-en { font-family:'Space Mono',monospace; font-size:.68rem; color:var(--ac); margin-bottom:7px; }
.ar-weapon { font-size:.77rem; color:rgba(245,247,250,.45); font-style:italic; margin-bottom:10px; }
.ar-desc { font-size:.78rem; color:rgba(245,247,250,.5); line-height:1.55; margin-bottom:14px; }
.ar-power { display:flex; align-items:center; gap:6px;
  font-family:'Space Mono',monospace; font-size:.72rem; color:var(--yellow); }

/* ════════════════════════════
   TOOL DETAIL PAGE
════════════════════════════ */
.td-wrap { min-height:100vh; background:var(--dk); color:var(--lt);
  direction:rtl; font-family:'Tajawal',sans-serif; padding-top:70px; }
.td-layout { max-width:880px; margin:0 auto; padding:40px 60px 100px; }
.td-crumb { font-size:.76rem; color:rgba(245,247,250,.38); margin-bottom:20px; }
.td-crumb a { color:var(--p); text-decoration:none; }
.td-crumb a:hover { color:var(--ac); }

/* Weapon hero card */
.td-hero { background:linear-gradient(135deg, rgba(13,21,40,.97), rgba(35,114,146,.1));
  border:2px solid rgba(35,114,146,.25); border-radius:20px; padding:36px; margin-bottom:32px;
  position:relative; overflow:hidden; }
.td-hero::before { content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg, var(--rc,var(--p)), var(--ac), var(--rc,var(--p)));
  background-size:200%; animation:td-sh 3s linear infinite; }
@keyframes td-sh { 0%{background-position:0%} 100%{background-position:200%} }
.td-hero-top { display:flex; align-items:center; gap:22px; margin-bottom:18px; flex-wrap:wrap; }
.td-emoji { font-size:4rem; animation:td-fl 3s ease-in-out infinite; }
@keyframes td-fl { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }
.td-weapon-title { font-size:1.7rem; font-weight:900; margin-bottom:4px; }
.td-weapon-en { font-family:'Space Mono',monospace; font-size:.82rem; color:var(--ac); margin-bottom:8px; }
.td-badges { display:flex; gap:8px; flex-wrap:wrap; }
.td-rar-badge { padding:4px 12px; border-radius:100px; font-size:.7rem; font-weight:700; }
.td-pow-badge { padding:4px 12px; border-radius:100px; font-size:.7rem;
  background:rgba(255,193,7,.1); border:1px solid rgba(255,193,7,.25);
  color:var(--yellow); font-family:'Space Mono',monospace; }

.td-story { background:rgba(35,114,146,.06); border-right:3px solid var(--p);
  border-radius:0 12px 12px 0; padding:16px 18px; margin-bottom:24px;
  font-size:.92rem; color:rgba(245,247,250,.75); line-height:1.85;
  white-space:pre-line; font-style:italic; }

/* Section heading */
.td-sec { margin-bottom:24px; }
.td-sec-title { font-size:.7rem; font-family:'Space Mono',monospace; color:var(--p);
  letter-spacing:2px; text-transform:uppercase; margin-bottom:10px;
  display:flex; align-items:center; gap:8px; }
.td-sec-title::after { content:''; flex:1; height:1px; background:rgba(35,114,146,.15); }

/* Code block */
.td-code { background:rgba(10,15,28,.95); border:1px solid rgba(35,114,146,.22);
  border-radius:12px; overflow:hidden; }
.td-code-hdr { display:flex; justify-content:space-between; align-items:center;
  padding:9px 14px; border-bottom:1px solid rgba(35,114,146,.1);
  background:rgba(35,114,146,.05); }
.td-code-dots { display:flex; gap:5px; }
.td-code-dots span { width:9px; height:9px; border-radius:50%; }
.td-code-dots span:nth-child(1){background:#ff5f57}
.td-code-dots span:nth-child(2){background:#febc2e}
.td-code-dots span:nth-child(3){background:#28c840}
.td-code-lbl { font-family:'Space Mono',monospace; font-size:.64rem;
  color:rgba(245,247,250,.35); letter-spacing:1px; }
.td-code-body { padding:16px; font-family:'Space Mono',monospace; font-size:.8rem;
  color:rgba(245,247,250,.88); white-space:pre; direction:ltr; text-align:left;
  line-height:1.75; overflow-x:auto; }

.td-explanation { background:rgba(13,21,40,.7); border:1px solid rgba(35,114,146,.14);
  border-radius:12px; padding:18px; font-size:.88rem;
  color:rgba(245,247,250,.75); line-height:1.85; white-space:pre-line; }

.td-examples { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.td-ex-label { font-size:.75rem; color:rgba(245,247,250,.42); margin-bottom:7px; padding-right:2px; }

.td-pro { background:rgba(255,193,7,.05); border:1px solid rgba(255,193,7,.18);
  border-radius:12px; padding:16px 18px;
  font-size:.86rem; color:rgba(245,247,250,.75); line-height:1.75; white-space:pre-line; }

.td-nav { display:flex; justify-content:space-between; gap:14px;
  margin-top:36px; padding-top:22px; border-top:1px solid rgba(35,114,146,.1); }
.td-nav-btn { display:flex; flex-direction:column; padding:12px 18px;
  background:rgba(13,21,40,.8); border:1px solid rgba(35,114,146,.15);
  border-radius:12px; cursor:pointer; transition:all .3s;
  text-decoration:none; color:var(--lt); flex:1; max-width:220px; }
.td-nav-btn:hover { border-color:rgba(35,114,146,.38); background:rgba(35,114,146,.1); }
.td-nav-lbl { font-size:.65rem; color:rgba(245,247,250,.35); font-family:'Space Mono',monospace; margin-bottom:3px; }
.td-nav-name { font-size:.85rem; font-weight:700; }

/* ════════════════════════════
   TOOL WIDGET (Overlay Panel)
════════════════════════════ */
#gtw-overlay { position:fixed; inset:0; z-index:9600; pointer-events:none; }
#gtw-overlay.open { pointer-events:all; }

#gtw-backdrop { position:absolute; inset:0;
  background:rgba(10,15,28,.55); backdrop-filter:blur(5px);
  opacity:0; transition:opacity .35s ease; }
#gtw-overlay.open #gtw-backdrop { opacity:1; }

#gtw-panel { position:absolute; top:0; bottom:0; left:0;
  width:min(380px, 92vw);
  background:rgba(11,18,30,.98);
  border-right:1px solid rgba(35,114,146,.3);
  box-shadow:6px 0 40px rgba(0,0,0,.6);
  transform:translateX(-100%);
  transition:transform .4s cubic-bezier(.34,1.56,.64,1);
  display:flex; flex-direction:column; overflow:hidden; }
#gtw-overlay.open #gtw-panel { transform:translateX(0); }

.gtw-head { display:flex; justify-content:space-between; align-items:center;
  padding:14px 18px; border-bottom:1px solid rgba(35,114,146,.15);
  background:rgba(13,21,40,.9); flex-shrink:0; }
.gtw-head-title { font-family:'Space Mono',monospace; font-size:.75rem;
  color:var(--ac); letter-spacing:1px; }
.gtw-x { width:28px; height:28px; background:rgba(245,247,250,.07);
  border:1px solid rgba(245,247,250,.1); border-radius:7px;
  cursor:pointer; display:flex; align-items:center; justify-content:center;
  color:rgba(245,247,250,.55); font-size:1.1rem; transition:all .2s; }
.gtw-x:hover { background:rgba(245,247,250,.14); color:var(--lt); }

.gtw-scroll { flex:1; overflow-y:auto; padding:18px; }
.gtw-scroll::-webkit-scrollbar { width:4px; }
.gtw-scroll::-webkit-scrollbar-track { background:transparent; }
.gtw-scroll::-webkit-scrollbar-thumb { background:rgba(35,114,146,.35); border-radius:2px; }

.gtw-top { display:flex; align-items:center; gap:14px; margin-bottom:14px; }
.gtw-big-emoji { font-size:2.8rem; }
.gtw-name { font-size:1.1rem; font-weight:800; margin-bottom:2px; }
.gtw-name-en { font-family:'Space Mono',monospace; font-size:.68rem; color:var(--ac); }
.gtw-weapon-lbl { font-size:.72rem; color:rgba(245,247,250,.4); font-style:italic; margin-top:2px; }

.gtw-story { background:rgba(35,114,146,.07); border-right:2px solid var(--p);
  border-radius:0 8px 8px 0; padding:11px 14px; margin-bottom:14px;
  font-size:.8rem; color:rgba(245,247,250,.7); line-height:1.8;
  white-space:pre-line; font-style:italic; }

.gtw-section { margin-bottom:13px; }
.gtw-sec-lbl { font-size:.63rem; font-family:'Space Mono',monospace;
  color:var(--p); letter-spacing:2px; text-transform:uppercase; margin-bottom:7px; }
.gtw-code { background:rgba(10,15,28,.9); border:1px solid rgba(35,114,146,.18);
  border-radius:8px; padding:11px; font-family:'Space Mono',monospace;
  font-size:.73rem; color:rgba(245,247,250,.85); white-space:pre;
  direction:ltr; text-align:left; line-height:1.65; overflow-x:auto; }
.gtw-text { font-size:.81rem; color:rgba(245,247,250,.7); line-height:1.78; white-space:pre-line; }
.gtw-tip { background:rgba(255,193,7,.05); border:1px solid rgba(255,193,7,.15);
  border-radius:8px; padding:10px 13px;
  font-size:.78rem; color:rgba(245,247,250,.68); line-height:1.7; white-space:pre-line; }

.gtw-link { display:block; margin-top:14px; padding:10px;
  text-align:center; background:rgba(35,114,146,.14);
  border:1px solid rgba(35,114,146,.25); border-radius:9px;
  color:var(--ac); text-decoration:none; font-size:.8rem; font-weight:700;
  transition:all .25s; }
.gtw-link:hover { background:rgba(35,114,146,.28); }

/* Loading spinner in widget */
.gtw-loading { display:flex; align-items:center; justify-content:center;
  gap:10px; padding:40px; color:rgba(245,247,250,.35); font-size:.85rem; }
.gtw-spinner { width:18px; height:18px; border:2px solid rgba(35,114,146,.2);
  border-top-color:var(--p); border-radius:50%;
  animation:gtw-spin .7s linear infinite; }
@keyframes gtw-spin { to{transform:rotate(360deg)} }

/* Tool buttons on level page */
.gl-tool-strip { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:16px; }
.gl-tool-chip { display:inline-flex; align-items:center; gap:6px;
  padding:7px 14px; background:rgba(35,114,146,.1);
  border:1px solid rgba(35,114,146,.22); border-radius:100px;
  cursor:pointer; transition:all .3s; font-size:.78rem;
  font-family:'Tajawal',sans-serif; color:rgba(245,247,250,.7); }
.gl-tool-chip:hover { background:rgba(35,114,146,.24); border-color:var(--p);
  color:var(--ac); transform:scale(1.05); }
.gl-tool-chip-emoji { font-size:.9rem; }

/* ════════════════════════════
   LEVEL PAGE — DESKTOP 2-COL
════════════════════════════ */
@media (min-width: 1100px) {
  .gl-layout { max-width:1240px; padding:36px 40px 100px; }
  .gl-two-col { display:grid; grid-template-columns:1fr 1fr; gap:30px; align-items:start; }
  .gl-col-left { position:sticky; top:84px; }
  .gl-col-right {}
}
@media (max-width: 1099px) {
  .gl-two-col { display:block; }
}

/* Responsive */
@media (max-width:900px) {
  .ar-hero,.ar-grid { padding-left:18px; padding-right:18px; }
  .ar-grid { grid-template-columns:1fr; padding-bottom:60px; }
  .td-layout { padding:28px 18px 80px; }
  .td-examples { grid-template-columns:1fr; }
}

/* ════════════════════════════
   TOOL MODAL — centered popup
════════════════════════════ */
#tool-modal-overlay {
  animation: modal-bg-in .25s ease;
}
@keyframes modal-bg-in {
  from { opacity:0; }
  to   { opacity:1; }
}
#tool-modal {
  animation: modal-in .32s cubic-bezier(.34,1.56,.64,1);
}
@keyframes modal-in {
  from { opacity:0; transform:scale(.88) translateY(20px); }
  to   { opacity:1; transform:scale(1)   translateY(0); }
}
/* Scrollbar for modal body */
#tool-modal-body::-webkit-scrollbar { width:4px; }
#tool-modal-body::-webkit-scrollbar-track { background:transparent; }
#tool-modal-body::-webkit-scrollbar-thumb { background:rgba(35,114,146,.35); border-radius:2px; }

/* ── strip shimmer reuse ── */
@keyframes td-sh { 0%{background-position:0%} 100%{background-position:200%} }
