/* ═══════════════════════════════════════════════
   0x5 Hub — v5.0  Black × Gold Premium
   Inspired by the coin logo: deep black + warm gold
   ═══════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;600;700;800&family=Tajawal:wght@400;500;700;800;900&family=Inter:wght@400;500;600;700;800;900&display=swap');

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

:root {
  /* ── Core Black ──────────────────── */
  --black:   #07080c;
  --black2:  #0c0d14;
  --black3:  #111219;
  --black4:  #171820;
  --black5:  #1c1e28;

  /* ── Gold Palette ────────────────── */
  --gold:     #d4a843;
  --gold-l:   #f0c060;
  --gold-ll:  #ffe4a0;
  --gold-d:   #a07828;
  --gold-dim: rgba(212,168,67,0.12);
  --gold-glow:rgba(212,168,67,0.35);
  --gold-border:rgba(212,168,67,0.22);

  /* ── Text ────────────────────────── */
  --t1: #f5f0e8;
  --t2: rgba(245,240,232,0.62);
  --t3: rgba(245,240,232,0.32);
  --t4: rgba(245,240,232,0.12);

  /* ── Borders ─────────────────────── */
  --b1: rgba(255,255,255,0.06);
  --b2: rgba(212,168,67,0.20);
  --b3: rgba(212,168,67,0.40);

  /* ── Accent colors (kept subtle) ─── */
  --green:  #22c55e;
  --red:    #ef4444;
  --blue:   #60a5fa;
  --teal:   #2dd4bf;
  --orange: #f97316;
  --orange-l: #fb923c;
  --indigo:   #6c63ff;
  --indigo-l: #a5b4fc;

  /* ── Gradients ───────────────────── */
  --gg:  linear-gradient(135deg, #d4a843 0%, #f0c060 50%, #a07828 100%);
  --gg2: linear-gradient(135deg, #ffe4a0 0%, #d4a843 100%);
  --gg3: linear-gradient(135deg, #a07828 0%, #d4a843 60%, #f0c060 100%);
  --gb:  linear-gradient(135deg, #0c0d14 0%, #171820 100%);

  --radius: 10px;
  --radius-lg: 16px;
  --radius-xl: 22px;
  --trans: all 0.22s cubic-bezier(0.4,0,0.2,1);
}

html { scroll-behavior: smooth; }
body {
  background: var(--black);
  color: var(--t1);
  font-family: 'Tajawal','Inter',system-ui,sans-serif;
  min-height: 100vh;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  cursor: none;
}
body * { cursor: none; }

/* ── SCROLLBAR ─────────────────────────────── */
::-webkit-scrollbar { width: 4px; }
::-webkit-scrollbar-track { background: var(--black2); }
::-webkit-scrollbar-thumb { background: var(--gold-d); border-radius: 2px; }

/* ── CURSOR ────────────────────────────────── */
.cur-ring {
  position: fixed; width: 28px; height: 28px; border-radius: 50%;
  border: 1.5px solid rgba(212,168,67,0.7); pointer-events: none; z-index: 999999;
  transform: translate(-50%,-50%); transition: width .2s, height .2s, border-color .2s, background .2s;
}
.cur-ring.hov { width: 44px; height: 44px; border-color: var(--gold-l); background: rgba(212,168,67,0.06); }
.cur-ring.clk { width: 20px; height: 20px; background: rgba(212,168,67,0.15); }
.cur-dot {
  position: fixed; width: 4px; height: 4px; background: var(--gold); border-radius: 50%;
  pointer-events: none; z-index: 999999; transform: translate(-50%,-50%);
  box-shadow: 0 0 8px var(--gold), 0 0 16px rgba(212,168,67,0.4);
}

/* ── BG ─────────────────────────────────────── */
#bg-canvas { position: fixed; inset: 0; z-index: 0; pointer-events: none; opacity: 0.5; }
.grid-bg {
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background-image:
    linear-gradient(rgba(212,168,67,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(212,168,67,0.04) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image: radial-gradient(ellipse 70% 60% at 50% 0%, black, transparent);
}
.vignette {
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background: radial-gradient(ellipse 80% 70% at 50% 15%, transparent 40%, rgba(7,8,12,0.85) 100%);
}

/* ── ANIMATIONS ─────────────────────────────── */
@keyframes fadeUp   { from{opacity:0;transform:translateY(18px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeIn   { from{opacity:0} to{opacity:1} }
@keyframes scaleIn  { from{opacity:0;transform:scale(0.94)} to{opacity:1;transform:scale(1)} }
@keyframes float    { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)} }
@keyframes spin     { to{transform:rotate(360deg)} }
@keyframes goldPulse{ 0%,100%{box-shadow:0 0 20px var(--gold-glow)} 50%{box-shadow:0 0 40px var(--gold-glow),0 0 70px rgba(212,168,67,0.15)} }
@keyframes shimmer  { 0%{background-position:-200% center} 100%{background-position:200% center} }
@keyframes blink    { 0%,100%{opacity:1} 50%{opacity:0.3} }
@keyframes stripe   { 0%{background-position:0 0} 100%{background-position:40px 40px} }
@keyframes coinSpin { 0%{transform:rotateY(0deg)} 100%{transform:rotateY(360deg)} }

/* ── UTILS ──────────────────────────────────── */
.hide { display: none !important; }
.zr   { position: relative; z-index: 1; }

/* ═══════════════════════════════════════════
   TOPBAR
═══════════════════════════════════════════ */
.topbar {
  position: sticky; top: 0; z-index: 1000;
  display: flex; align-items: center; gap: 10px;
  padding: 0 24px; height: 58px;
  background: rgba(7,8,12,0.9);
  border-bottom: 1px solid var(--gold-border);
  backdrop-filter: blur(20px);
  transition: box-shadow .3s;
}
.topbar.scrolled { box-shadow: 0 4px 30px rgba(0,0,0,0.5), 0 1px 0 var(--gold-border); }

.topbar-logo {
  display: flex; align-items: center; gap: 10px;
  text-decoration: none; flex-shrink: 0;
  cursor: pointer;
}
.logo-coin {
  width: 38px; height: 38px; border-radius: 50%;
  overflow: hidden; border: 1.5px solid var(--gold-border);
  box-shadow: 0 0 16px rgba(212,168,67,0.2);
  flex-shrink: 0; position: relative;
}
.logo-coin img { width: 100%; height: 100%; object-fit: cover; }
.logo-text { line-height: 1; }
.logo-name {
  font-family: 'JetBrains Mono', monospace; font-weight: 800; font-size: 15px;
  background: var(--gg); -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text; letter-spacing: 0.5px;
}
.logo-sub { font-size: 9px; color: var(--t3); letter-spacing: 2px; font-family: 'JetBrains Mono',monospace; margin-top: 1px; }

.topbar-space { flex: 1; }

/* Nav */
.nav-pills { display: flex; align-items: center; gap: 2px; }
.npill {
  display: flex; align-items: center; gap: 6px;
  padding: 6px 14px; border-radius: 8px; font-size: 13px; font-weight: 600;
  background: none; border: none; color: var(--t3); cursor: pointer;
  transition: var(--trans); white-space: nowrap; font-family: 'Tajawal','Inter',sans-serif;
}
.npill:hover  { color: var(--t1); background: rgba(255,255,255,0.06); }
.npill.active {
  color: var(--gold-l); background: var(--gold-dim);
  border: 1px solid var(--gold-border);
}
.npill.fix-pill.active { color: var(--orange); background: rgba(249,115,22,0.1); border-color: rgba(249,115,22,0.2); }
.npill.admin-pill { color: var(--gold); }
.npill i { font-size: 12px; }
.nd { width: 1px; height: 20px; background: var(--b1); }

/* Online badge */
.ob {
  display: flex; align-items: center; gap: 5px;
  font-size: 10px; color: var(--green); font-family: 'JetBrains Mono',monospace;
  padding: 4px 10px; background: rgba(34,197,94,0.07); border: 1px solid rgba(34,197,94,0.18); border-radius: 99px;
}
.ob-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--green); animation: blink 2s infinite; }

/* User pill */
.upill {
  display: flex; align-items: center; gap: 8px;
  padding: 4px 10px 4px 5px; border-radius: 99px;
  background: var(--black4); border: 1px solid var(--gold-border);
  cursor: pointer; transition: var(--trans);
}
.upill:hover { border-color: var(--gold); background: var(--black5); }
.upill img { width: 26px; height: 26px; border-radius: 50%; border: 1.5px solid var(--gold-border); }
.upill .un  { font-size: 12px; font-weight: 700; color: var(--t1); }
.plan-chip  {
  font-size: 9px; padding: 2px 8px; border-radius: 99px; font-weight: 800;
  font-family: 'JetBrains Mono',monospace; letter-spacing: 0.5px;
  background: var(--gold-dim); color: var(--gold-l); border: 1px solid var(--gold-border);
}
.plan-chip.free    { background: rgba(255,255,255,0.06); color: var(--t3); border-color: var(--b1); }
.plan-chip.staff   { background: rgba(239,68,68,0.1); color: #ff8080; border-color: rgba(239,68,68,0.2); }
.plan-chip.teal    { background: rgba(45,212,191,0.1); color: var(--teal); border-color: rgba(45,212,191,0.2); }
.plan-chip.gold    { background: var(--gold-dim); color: var(--gold-l); border-color: var(--gold-border); }
.plan-chip.premium { background: rgba(167,139,250,0.1); color: #c4b5fd; border-color: rgba(167,139,250,0.2); }

.logout-btn {
  width: 30px; height: 30px; border-radius: 50%; background: var(--black4);
  border: 1px solid var(--b1); color: var(--t3); cursor: pointer;
  display: flex; align-items: center; justify-content: center; font-size: 12px; transition: var(--trans);
}
.logout-btn:hover { background: rgba(239,68,68,0.1); border-color: rgba(239,68,68,0.3); color: var(--red); }

.login-topbar-btn {
  display: flex; align-items: center; gap: 7px;
  padding: 7px 16px; border-radius: 8px; font-size: 13px; font-weight: 700;
  background: var(--gg); border: none; color: var(--black); cursor: pointer;
  transition: var(--trans); font-family: 'Tajawal','Inter',sans-serif;
}
.login-topbar-btn:hover { opacity: 0.85; transform: translateY(-1px); box-shadow: 0 4px 18px var(--gold-glow); }

.lang-btn {
  width: 34px; height: 34px; border-radius: 8px; border: 1px solid var(--gold-border);
  background: var(--gold-dim); color: var(--gold-l); cursor: pointer;
  display: flex; align-items: center; justify-content: center; font-size: 13px; transition: var(--trans);
}
.lang-btn:hover { background: rgba(212,168,67,0.2); border-color: var(--gold); }

/* Announcement */
.ann-bar {
  position: sticky; top: 58px; z-index: 999;
  display: flex; align-items: center; gap: 10px; padding: 10px 24px; font-size: 13px;
}
.ann-bar.info    { background:rgba(96,165,250,0.08); border-bottom:1px solid rgba(96,165,250,0.2); color:#93c5fd; }
.ann-bar.warn    { background:rgba(212,168,67,0.08); border-bottom:1px solid var(--gold-border); color:var(--gold-l); }
.ann-bar.success { background:rgba(34,197,94,0.08); border-bottom:1px solid rgba(34,197,94,0.2); color:#86efac; }
.ann-bar.error   { background:rgba(239,68,68,0.08); border-bottom:1px solid rgba(239,68,68,0.2); color:#fca5a5; }
.ann-close { margin-left:auto; background:none; border:none; color:inherit; opacity:.5; cursor:pointer; padding:2px 6px; }

/* ═══════════════════════════════════════════
   TABS
═══════════════════════════════════════════ */
.main { position: relative; z-index: 1; }
.tab { display: none; }
.tab.active { display: block; animation: fadeUp .28s ease; }

/* ═══════════════════════════════════════════
   HOME — HERO
═══════════════════════════════════════════ */
.hero {
  padding: 72px 28px 56px;
  max-width: 820px; margin: 0 auto; text-align: center;
  position: relative;
}
.hero-coin-bg {
  position: absolute; top: -60px; left: 50%; transform: translateX(-50%);
  width: 600px; height: 600px; border-radius: 50%;
  background: radial-gradient(ellipse, rgba(212,168,67,0.07) 0%, transparent 70%);
  pointer-events: none;
}
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 10px; letter-spacing: 3px; font-family: 'JetBrains Mono',monospace;
  color: var(--gold-d); text-transform: uppercase; margin-bottom: 18px;
}
.hero-eyebrow::before, .hero-eyebrow::after {
  content: ''; width: 24px; height: 1px; background: var(--gold-border);
}
.hero-live {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 14px; border-radius: 99px; font-size: 11px; font-weight: 700;
  background: rgba(34,197,94,0.08); border: 1px solid rgba(34,197,94,0.2);
  color: var(--green); margin-bottom: 22px; font-family: 'JetBrains Mono',monospace;
}
.hero-live-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--green); animation: blink 1.8s infinite; }

.hero-title {
  font-size: clamp(34px,5.5vw,64px); font-weight: 900; line-height: 1.08;
  letter-spacing: -2.5px; margin-bottom: 16px;
  background: linear-gradient(135deg, var(--gold-ll) 0%, var(--gold-l) 40%, var(--gold) 75%, var(--gold-d) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.hero-sub {
  font-size: 15px; color: var(--t2); line-height: 1.7; margin-bottom: 32px;
  max-width: 560px; margin-left: auto; margin-right: auto;
}
.hero-btns { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; margin-bottom: 44px; }

/* Buttons */
.btn-gold {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 26px; border-radius: var(--radius); font-size: 14px; font-weight: 800;
  background: var(--gg); border: none; color: var(--black); cursor: pointer;
  transition: var(--trans); font-family: 'Tajawal','Inter',sans-serif;
}
.btn-gold:hover { transform: translateY(-2px); box-shadow: 0 8px 28px var(--gold-glow); opacity: .9; }

.btn-outline-gold {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 26px; border-radius: var(--radius); font-size: 14px; font-weight: 700;
  background: var(--gold-dim); border: 1px solid var(--gold-border); color: var(--gold-l);
  cursor: pointer; transition: var(--trans); font-family: 'Tajawal','Inter',sans-serif;
}
.btn-outline-gold:hover { background: rgba(212,168,67,0.18); border-color: var(--gold); transform: translateY(-1px); }

.btn-ghost {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 26px; border-radius: var(--radius); font-size: 14px; font-weight: 600;
  background: rgba(255,255,255,0.05); border: 1px solid var(--b1); color: var(--t2);
  cursor: pointer; transition: var(--trans); font-family: 'Tajawal','Inter',sans-serif;
}
.btn-ghost:hover { background: rgba(255,255,255,0.09); border-color: rgba(255,255,255,0.14); transform: translateY(-1px); }

/* ── STATS ─────────────────────────────────── */
.stats-strip {
  display: grid; grid-template-columns: repeat(4,1fr); gap: 1px;
  background: var(--b1); border-top: 1px solid var(--gold-border); border-bottom: 1px solid var(--b1);
}
.stat-block { padding: 24px 16px; background: var(--black); text-align: center; transition: background .2s; }
.stat-block:hover { background: var(--black2); }
.stat-n {
  display: block; font-size: 28px; font-weight: 900;
  font-family: 'JetBrains Mono',monospace; letter-spacing: -1px; margin-bottom: 4px;
  background: var(--gg); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.stat-n.green { background: linear-gradient(135deg,#22c55e,#86efac); -webkit-background-clip:text; background-clip:text; }
.stat-n.blue  { background: linear-gradient(135deg,#60a5fa,#a78bfa); -webkit-background-clip:text; background-clip:text; }
.stat-l { font-size: 10px; color: var(--t3); letter-spacing: 2px; font-family: 'JetBrains Mono',monospace; }

/* ── SECTION ───────────────────────────────── */
.section { padding: 0 28px; max-width: 1160px; margin: 0 auto 60px; }
.sec-head { display: flex; align-items: center; gap: 14px; margin-bottom: 28px; }
.sec-tag {
  font-size: 9px; letter-spacing: 3px; font-family: 'JetBrains Mono',monospace;
  color: var(--gold-d); text-transform: uppercase; white-space: nowrap;
}
.sec-title { font-size: 20px; font-weight: 800; white-space: nowrap; color: var(--t1); }
.sec-line { flex: 1; height: 1px; background: var(--b1); }

/* ── FEATURE CARDS ─────────────────────────── */
.feat-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 14px; }
.feat-card {
  background: var(--black2); border: 1px solid var(--b1); border-radius: var(--radius-lg);
  padding: 28px; cursor: pointer; transition: var(--trans); position: relative; overflow: hidden;
}
.feat-card::before {
  content: ''; position: absolute; inset: 0; opacity: 0; transition: opacity .3s;
  background: radial-gradient(ellipse 60% 50% at 30% 30%, rgba(212,168,67,0.06), transparent);
}
.feat-card:hover { border-color: var(--gold-border); transform: translateY(-4px); box-shadow: 0 12px 40px rgba(0,0,0,0.4); }
.feat-card:hover::before { opacity: 1; }
.feat-card.fix-card:hover { border-color: rgba(249,115,22,0.3); }
.feat-card.fix-card:hover::before { background: radial-gradient(ellipse 60% 50% at 30% 30%, rgba(249,115,22,0.06), transparent); }

.fc-tag {
  font-size: 9px; letter-spacing: 2px; font-family: 'JetBrains Mono',monospace; font-weight: 800;
  padding: 3px 10px; border-radius: 99px; display: inline-block; margin-bottom: 14px; position: relative; z-index: 1;
  background: var(--gold-dim); color: var(--gold-l); border: 1px solid var(--gold-border);
}
.fc-tag.fix { background: rgba(249,115,22,0.1); color: #fb923c; border-color: rgba(249,115,22,0.2); }

.fc-ico {
  width: 52px; height: 52px; border-radius: 14px; display: flex; align-items: center; justify-content: center;
  font-size: 22px; margin-bottom: 14px; position: relative; z-index: 1;
  background: var(--gold-dim); color: var(--gold-l); border: 1px solid var(--gold-border);
}
.fc-ico.fix { background: rgba(249,115,22,0.1); color: #fb923c; border-color: rgba(249,115,22,0.2); }
.fc-ico img { width: 26px; height: 26px; object-fit: contain; }

.fc-title { font-size: 17px; font-weight: 800; margin-bottom: 8px; position: relative; z-index: 1; }
.fc-desc  { font-size: 13px; color: var(--t2); line-height: 1.6; position: relative; z-index: 1; }

/* ── STEPS ─────────────────────────────────── */
.steps-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; }
.step-card {
  background: var(--black2); border: 1px solid var(--b1); border-radius: var(--radius-lg);
  padding: 22px 18px; text-align: center; transition: var(--trans);
}
.step-card:hover { border-color: var(--gold-border); transform: translateY(-3px); }
.step-num {
  width: 34px; height: 34px; border-radius: 10px; background: var(--gg);
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 800; font-family: 'JetBrains Mono',monospace;
  color: var(--black); margin: 0 auto 12px; box-shadow: 0 0 14px var(--gold-glow);
}
.step-title { font-size: 13px; font-weight: 700; margin-bottom: 5px; }
.step-desc  { font-size: 11px; color: var(--t3); line-height: 1.5; }

/* ── PLANS ─────────────────────────────────── */
.plans-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 14px; }
.plan-card {
  background: var(--black2); border: 1px solid var(--b1); border-radius: var(--radius-xl);
  padding: 26px; transition: var(--trans); position: relative; overflow: hidden;
}
.plan-card:hover { transform: translateY(-4px); box-shadow: 0 12px 40px rgba(0,0,0,0.4); }
.plan-card.popular { border-color: var(--gold-border); background: linear-gradient(135deg,rgba(212,168,67,0.05),var(--black2)); }
.plan-card.popular:hover { box-shadow: 0 12px 40px var(--gold-glow); }
.plan-pop { position:absolute; top:0; right:20px; font-size:9px; font-weight:800; letter-spacing:1.5px;
  padding:4px 12px; background:var(--gg); color:var(--black); border-radius:0 0 8px 8px; font-family:'JetBrains Mono',monospace; }
.plan-name  { font-size:12px; font-weight:700; color:var(--t2); margin-bottom:10px; }
.plan-price { font-size:34px; font-weight:900; font-family:'JetBrains Mono',monospace; letter-spacing:-2px; margin-bottom:3px;
  background:var(--gg); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.plan-per   { font-size:11px; color:var(--t3); margin-bottom:20px; }
.plan-feats { display:flex; flex-direction:column; gap:7px; margin-bottom:20px; }
.pf         { display:flex; align-items:center; gap:8px; font-size:12px; }
.pf i       { font-size:10px; width:14px; }
.pf.yes i   { color:var(--green); }
.pf.no      { color:var(--t3); }
.pf.no i    { color:var(--t4); }
.plan-btn {
  width:100%; padding:11px; border-radius:var(--radius); font-size:13px; font-weight:800;
  border:1px solid var(--gold-border); background:var(--gold-dim); color:var(--gold-l);
  cursor:pointer; transition:var(--trans); font-family:'Tajawal','Inter',sans-serif;
}
.plan-btn:hover { background:rgba(212,168,67,0.2); border-color:var(--gold); }
.plan-btn.g { background:var(--gg); border:none; color:var(--black); }
.plan-btn.g:hover { opacity:.88; box-shadow:0 6px 20px var(--gold-glow); }

/* ═══════════════════════════════════════════
   LOGIN PAGE
═══════════════════════════════════════════ */
.login-page {
  min-height: 100vh; display: flex; align-items: center; justify-content: center;
  padding: 20px; position: relative; z-index: 1;
}
.login-wrap { width: 100%; max-width: 420px; animation: scaleIn .45s cubic-bezier(0.34,1.56,0.64,1); }

/* Coin logo on login */
.login-coin {
  width: 82px; height: 82px; border-radius: 50%; margin: 0 auto 16px;
  border: 2px solid var(--gold-border); overflow: hidden;
  box-shadow: 0 0 40px var(--gold-glow), 0 0 80px rgba(212,168,67,0.1);
  animation: goldPulse 3s ease-in-out infinite;
}
.login-coin img { width: 100%; height: 100%; object-fit: cover; }
.login-logo-text { text-align: center; margin-bottom: 32px; }
.login-brand {
  font-family: 'JetBrains Mono',monospace; font-size: 26px; font-weight: 900;
  background: var(--gg); -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text; letter-spacing: 1px; display: block; margin-bottom: 4px;
}
.login-tagline { font-size: 13px; color: var(--t3); }

/* Lang picker on login */
.lang-row { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; margin-bottom: 24px; }
.lang-card {
  padding: 12px 8px; border-radius: var(--radius); background: var(--black3);
  border: 1.5px solid var(--b1); cursor: pointer; text-align: center; transition: var(--trans);
}
.lang-card:hover { border-color: var(--gold-border); background: var(--gold-dim); transform: translateY(-2px); }
.lang-card.active { border-color: var(--gold); background: var(--gold-dim); box-shadow: 0 0 14px var(--gold-glow); }
.lang-flag { font-size: 22px; display: block; margin-bottom: 5px; }
.lang-name { font-size: 12px; font-weight: 700; }
.lang-name-sub { font-size: 10px; color: var(--t3); margin-top: 1px; }

/* Login box */
.login-box {
  background: var(--black2); border: 1px solid var(--gold-border); border-radius: var(--radius-xl);
  padding: 28px; position: relative; overflow: hidden;
}
.login-box::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
}
.login-box-title { font-size: 16px; font-weight: 800; margin-bottom: 5px; }
.login-box-sub   { font-size: 12px; color: var(--t2); line-height: 1.6; margin-bottom: 22px; }

.dc-btn {
  width: 100%; display: flex; align-items: center; justify-content: center; gap: 10px;
  padding: 14px 24px; border-radius: var(--radius); font-size: 14px; font-weight: 800;
  background: #5865F2; border: none; color: white; cursor: pointer;
  transition: var(--trans); font-family: 'Tajawal','Inter',sans-serif; position: relative; overflow: hidden;
}
.dc-btn::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(90deg,transparent 40%,rgba(255,255,255,0.12) 50%,transparent 60%);
  transform: translateX(-100%); transition: transform .6s ease;
}
.dc-btn:hover { background: #4752c4; transform: translateY(-2px); box-shadow: 0 8px 24px rgba(88,101,242,0.4); }
.dc-btn:hover::after { transform: translateX(100%); }

.login-div {
  text-align: center; font-size: 10px; color: var(--t3); letter-spacing: 2px;
  margin: 18px 0; position: relative;
}
.login-div::before, .login-div::after {
  content: ''; position: absolute; top: 50%; height: 1px; background: var(--b1); width: calc(50% - 36px);
}
.login-div::before { left: 0; } .login-div::after { right: 0; }

.login-feats { display: flex; flex-direction: column; gap: 8px; }
.login-feat {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px; border-radius: var(--radius); background: rgba(255,255,255,0.02); border: 1px solid var(--b1);
}
.lf-ico {
  width: 30px; height: 30px; border-radius: 8px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center; font-size: 13px;
}
.lf-ico.gold { background: var(--gold-dim); color: var(--gold-l); }
.lf-ico.fix  { background: rgba(249,115,22,0.1); color: #fb923c; }
.lf-ico.teal { background: rgba(45,212,191,0.1); color: var(--teal); }
.lf-label    { font-size: 12px; font-weight: 600; }
.lf-sub      { font-size: 10px; color: var(--t3); margin-top: 1px; }

.login-footer { text-align: center; margin-top: 16px; font-size: 11px; color: var(--t3); }
.login-footer a { color: var(--gold-l); text-decoration: none; }
.login-footer a:hover { text-decoration: underline; }

.login-err {
  margin-top: 14px; padding: 11px 14px; border-radius: var(--radius);
  background: rgba(239,68,68,0.08); border: 1px solid rgba(239,68,68,0.25);
  color: #fca5a5; font-size: 12px; text-align: center; display: none;
}

/* ═══════════════════════════════════════════
   APP PANELS
═══════════════════════════════════════════ */
.panel { padding: 28px; max-width: 1100px; margin: 0 auto; }
.panel-hdr {
  display: flex; align-items: center; gap: 14px; margin-bottom: 28px;
  padding-bottom: 18px; border-bottom: 1px solid var(--b1);
}
.panel-ico {
  width: 46px; height: 46px; border-radius: 13px;
  display: flex; align-items: center; justify-content: center; font-size: 20px; flex-shrink: 0;
  background: var(--gold-dim); color: var(--gold-l); border: 1px solid var(--gold-border);
}
.panel-ico.fix  { background:rgba(249,115,22,0.1); color:#fb923c; border-color:rgba(249,115,22,0.2); }
.panel-ico.file { background:rgba(45,212,191,0.1); color:var(--teal); border-color:rgba(45,212,191,0.2); }
.panel-ico.adm  { background:var(--gold-dim); color:var(--gold); border-color:var(--gold-border); }
.panel-title { font-size: 20px; font-weight: 900; }
.panel-sub   { font-size: 11px; color: var(--t3); font-family:'JetBrains Mono',monospace; margin-top:2px; }

/* Two-col */
.tcol { display: grid; grid-template-columns: 1fr 300px; gap: 18px; align-items: start; }

/* Card */
.card {
  background: var(--black2); border: 1px solid var(--b1); border-radius: var(--radius-lg);
  padding: 22px; margin-bottom: 14px;
}
.card:last-child { margin-bottom: 0; }
.card-title {
  font-size: 13px; font-weight: 700; display: flex; align-items: center; gap: 7px;
  margin-bottom: 14px; color: var(--t1);
}
.card-sub { font-size: 11px; color: var(--t3); margin-top: -8px; margin-bottom: 12px; }

/* ── UPLOAD ZONE ───────────────────────────── */
.upzone {
  border: 2px dashed rgba(212,168,67,0.15); border-radius: var(--radius-lg);
  padding: 36px 20px; text-align: center; cursor: pointer; transition: var(--trans);
  background: rgba(212,168,67,0.02);
}
.upzone:hover, .upzone.drag { border-color: var(--gold-border); background: var(--gold-dim); }
.upzone.fix-z:hover, .upzone.fix-z.drag { border-color: rgba(249,115,22,0.35); background:rgba(249,115,22,0.04); }
.upzone input[type=file] { display: none; }
.upzone-ico { font-size: 30px; margin-bottom: 10px; display: block; }
.upzone-ico.g { color: var(--gold-l); }
.upzone-ico.o { color: #fb923c; }
.upzone-title { font-size: 13px; font-weight: 700; margin-bottom: 4px; }
.upzone-sub   { font-size: 11px; color: var(--t3); }

/* Chosen file */
.file-chosen {
  display: none; align-items: center; gap: 10px;
  padding: 10px 14px; background: rgba(255,255,255,0.03); border-radius: var(--radius);
  border: 1px solid var(--b1); margin-top: 10px;
}
.file-chosen.show { display: flex; }
.fci {
  width: 34px; height: 34px; border-radius: 9px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center; font-size: 15px;
}
.fci.g { background:var(--gold-dim); color:var(--gold-l); }
.fci.o { background:rgba(249,115,22,0.1); color:#fb923c; }
.f-name { font-size: 12px; font-weight: 700; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; flex:1; }
.f-size { font-size: 10px; color: var(--t3); font-family:'JetBrains Mono',monospace; margin-top:2px; }
.f-clear {
  width: 26px; height: 26px; border-radius: 50%; background: rgba(255,255,255,0.05);
  border: 1px solid var(--b1); color: var(--t3); cursor: pointer;
  display: flex; align-items: center; justify-content: center; flex-shrink:0; transition:var(--trans); font-size: 10px;
}
.f-clear:hover { background:rgba(239,68,68,0.1); border-color:rgba(239,68,68,0.3); color:var(--red); }

/* Key methods */
.km-list { display: flex; flex-direction: column; gap: 6px; }
.km {
  display: flex; align-items: center; gap: 10px; padding: 12px 14px;
  border-radius: var(--radius); border: 1.5px solid var(--b1);
  cursor: pointer; transition: var(--trans); background: rgba(255,255,255,0.02);
}
.km:hover, .km.sel { border-color:var(--gold-border); background:var(--gold-dim); }
.km-ico {
  width: 32px; height: 32px; border-radius: 8px; display: flex; align-items: center;
  justify-content: center; font-size: 13px; flex-shrink:0;
}
.km-name { font-size: 12px; font-weight: 700; }
.km-hint { font-size: 10px; color: var(--t3); font-family:'JetBrains Mono',monospace; margin-top:2px; }
.km-inp  { margin-top: 8px; display:none; }
.km-inp.show { display: block; }

/* Inputs */
.inp {
  width: 100%; padding: 9px 12px; border-radius: var(--radius); font-size: 12px;
  background: var(--black3); border: 1px solid var(--b1); color: var(--t1);
  font-family: 'JetBrains Mono',monospace; outline: none; transition: var(--trans);
}
.inp:focus { border-color: var(--gold-border); box-shadow: 0 0 0 3px rgba(212,168,67,0.08); }
.inp-lbl { font-size: 11px; color: var(--t3); margin-bottom: 5px; display: block; }

/* Action btn */
.act-btn {
  width: 100%; padding: 13px 22px; border-radius: var(--radius); font-size: 14px; font-weight: 800;
  border: none; color: var(--black); cursor: pointer; transition: var(--trans);
  display: flex; align-items: center; justify-content: center; gap: 8px;
  font-family: 'Tajawal','Inter',sans-serif; margin-top: 14px; background: var(--gg);
}
.act-btn:not(:disabled):hover { transform: translateY(-2px); box-shadow: 0 8px 24px var(--gold-glow); opacity: .9; }
.act-btn:disabled { opacity: 0.35; cursor: not-allowed; }
.act-btn.fix-act { background: linear-gradient(135deg,#f97316,#fb923c); }
.act-btn.fix-act:not(:disabled):hover { box-shadow: 0 8px 24px rgba(249,115,22,0.35); }

/* Progress */
.prog-wrap { display: none; margin-top: 14px; }
.prog-wrap.show { display: block; }
.prog-row { display: flex; justify-content: space-between; margin-bottom: 6px; }
.prog-stage { font-size: 11px; color: var(--t2); font-family:'JetBrains Mono',monospace; }
.prog-pct   { font-size: 11px; color: var(--gold-l); font-family:'JetBrains Mono',monospace; }
.prog-track { height: 5px; background: rgba(255,255,255,0.06); border-radius: 99px; overflow: hidden; margin-bottom: 10px; }
.prog-fill  { height: 100%; border-radius: 99px; background: var(--gg); transition: width .3s ease; }
.prog-fill.fx { background: linear-gradient(90deg,#f97316,#fb923c); }
.prog-log {
  max-height: 110px; overflow-y: auto; font-size: 10px; font-family:'JetBrains Mono',monospace;
  background: rgba(0,0,0,0.4); border-radius: 8px; padding: 8px 10px; border: 1px solid var(--b1);
}
.log-l       { padding: 1px 0; border-bottom: 1px solid rgba(255,255,255,0.02); }
.log-l:last-child { border-bottom: none; }
.log-l.ok    { color: var(--green); }
.log-l.err   { color: var(--red); }
.log-l.inf   { color: var(--t2); }
.log-l.warn  { color: var(--gold-l); }

/* Result */
.result-box { display: none; margin-top: 14px; border-radius: var(--radius-lg); padding: 18px; border: 1px solid; }
.result-box.show { display: block; animation: scaleIn .3s ease; }
.result-box.d { background:rgba(212,168,67,0.05); border-color:var(--gold-border); }
.result-box.f { background:rgba(249,115,22,0.05); border-color:rgba(249,115,22,0.25); }
.res-title { font-size: 14px; font-weight: 800; display: flex; align-items: center; gap: 7px; margin-bottom: 12px; }
.res-title i { color: var(--green); }
.dl-row {
  display: flex; align-items: center; gap: 7px;
  background: rgba(0,0,0,0.3); border-radius: var(--radius); padding: 9px 12px; border: 1px solid var(--b1);
}
.dl-url {
  flex:1; font-size:11px; font-family:'JetBrains Mono',monospace; color:var(--gold-l);
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap; text-decoration:none;
}
.dl-copy, .dl-dl {
  padding: 5px 12px; border-radius: 7px; font-size: 11px; font-weight: 700; cursor: pointer;
  transition: var(--trans); border: 1px solid; flex-shrink:0; text-decoration:none;
  display:inline-flex; align-items:center; gap:4px; font-family:'Tajawal','Inter',sans-serif;
}
.dl-copy { background:var(--gold-dim); border-color:var(--gold-border); color:var(--gold-l); }
.dl-copy:hover { background:rgba(212,168,67,0.22); }
.dl-dl   { background:rgba(34,197,94,0.1); border-color:rgba(34,197,94,0.25); color:var(--green); }
.dl-dl:hover { background:rgba(34,197,94,0.2); }

/* ── SIDEBAR ───────────────────────────────── */
.sc {
  background: var(--black2); border: 1px solid var(--b1); border-radius: var(--radius-lg);
  padding: 18px; margin-bottom: 14px;
}
.sc:last-child { margin-bottom: 0; }
.sc-title {
  font-size: 10px; font-weight: 800; color: var(--t3); text-transform: uppercase;
  letter-spacing: 1.5px; display: flex; align-items: center; gap: 6px; margin-bottom: 12px;
  font-family: 'JetBrains Mono',monospace;
}
.sc-plan-name { font-size: 18px; font-weight: 900; color: var(--gold-l); margin-bottom: 8px; }
.sc-limit { font-size: 11px; color: var(--t2); line-height: 2; font-family:'JetBrains Mono',monospace; }
.sc-bar-wrap { height: 3px; background: rgba(255,255,255,0.06); border-radius:99px; margin: 8px 0 4px; overflow: hidden; }
.sc-bar      { height: 100%; background: var(--gg); border-radius:99px; transition: width .5s ease; }

/* History */
.hist-list { display: flex; flex-direction: column; gap: 5px; }
.hist-item {
  display: flex; align-items: center; gap: 8px; padding: 8px 10px;
  border-radius: var(--radius); background: rgba(255,255,255,0.02); border: 1px solid var(--b1);
  transition: var(--trans);
}
.hist-item:hover { background: rgba(255,255,255,0.04); border-color:var(--gold-border); }
.hi-ico { width: 26px; height: 26px; border-radius: 7px; display:flex; align-items:center; justify-content:center; font-size:11px; flex-shrink:0; }
.hi-ico.g { background:var(--gold-dim); color:var(--gold-l); }
.hi-ico.o { background:rgba(249,115,22,0.1); color:#fb923c; }
.hi-name { font-size: 11px; font-weight: 700; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; flex:1; }
.hi-time { font-size: 9px; color: var(--t3); font-family:'JetBrains Mono',monospace; white-space:nowrap; }
.hi-dl   {
  width: 22px; height: 22px; border-radius: 6px; background: rgba(255,255,255,0.04);
  border: 1px solid var(--b1); display:flex; align-items:center; justify-content:center;
  font-size: 9px; color: var(--t3); text-decoration:none; transition:var(--trans); flex-shrink:0;
}
.hi-dl:hover { background:var(--gold-dim); border-color:var(--gold-border); color:var(--gold-l); }
.empty-s { text-align:center; padding:24px 16px; font-size:11px; color:var(--t3); }
.empty-s i { font-size:20px; display:block; margin-bottom:8px; opacity:.3; }

/* ── FILES TABLE ───────────────────────────── */
.ftable { width:100%; border-collapse:collapse; }
.ftable th {
  font-size:10px; color:var(--t3); letter-spacing:1.5px; text-transform:uppercase;
  padding:10px 14px; text-align:right; border-bottom:1px solid var(--b1); font-family:'JetBrains Mono',monospace;
}
html[dir=ltr] .ftable th { text-align:left; }
.ftable td { padding:10px 14px; border-bottom:1px solid rgba(255,255,255,0.025); font-size:12px; vertical-align:middle; }
.ftable tr:hover td { background:rgba(255,255,255,0.02); }
.f-type-chip {
  font-size:9px; padding:2px 8px; border-radius:99px; font-weight:800; font-family:'JetBrains Mono',monospace;
}
.f-type-chip.g { background:var(--gold-dim); color:var(--gold-l); }
.f-type-chip.o { background:rgba(249,115,22,0.1); color:#fb923c; }
.f-type-chip.t { background:rgba(45,212,191,0.1); color:var(--teal); }
.icon-btn {
  width:30px; height:30px; border-radius:8px; background:rgba(255,255,255,0.04);
  border:1px solid var(--b1); color:var(--t3); cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center; font-size:11px;
  transition:var(--trans); text-decoration:none;
}
.icon-btn:hover { background:var(--gold-dim); border-color:var(--gold-border); color:var(--gold-l); }
.icon-btn.del:hover { background:rgba(239,68,68,0.1); border-color:rgba(239,68,68,0.25); color:var(--red); }

/* General upload zone in files tab */
.gen-up-zone {
  border: 2px dashed rgba(45,212,191,0.15); border-radius:var(--radius-lg);
  padding:24px; text-align:center; cursor:pointer; transition:var(--trans);
  background:rgba(45,212,191,0.02); margin-bottom:16px;
}
.gen-up-zone:hover, .gen-up-zone.drag { border-color:rgba(45,212,191,0.35); background:rgba(45,212,191,0.04); }
.gen-up-zone input { display:none; }

/* ── ADMIN ─────────────────────────────────── */
.admin-stats { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; margin-bottom:20px; }
.astat {
  background:var(--black2); border:1px solid var(--b1); border-radius:var(--radius-lg);
  padding:16px; display:flex; align-items:center; gap:12px;
}
.astat-ico { width:38px; height:38px; border-radius:11px; display:flex; align-items:center; justify-content:center; font-size:16px; flex-shrink:0; }
.astat-n   { font-size:20px; font-weight:900; font-family:'JetBrains Mono',monospace; }
.astat-l   { font-size:10px; color:var(--t3); margin-top:1px; }
.toggle-row {
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 0; border-bottom:1px solid var(--b1);
}
.toggle-row:last-child { border-bottom:none; padding-bottom:0; }
.tg-lbl { font-size:13px; font-weight:700; }
.tg-sub { font-size:11px; color:var(--t3); font-family:'JetBrains Mono',monospace; margin-top:2px; }
.tgsw {
  width:40px; height:22px; border-radius:99px; background:rgba(255,255,255,0.08);
  border:1.5px solid var(--b1); cursor:pointer; position:relative; transition:var(--trans); flex-shrink:0;
}
.tgsw::after {
  content:''; position:absolute; top:2px; left:2px; width:14px; height:14px;
  border-radius:50%; background:var(--t3); transition:var(--trans);
}
.tgsw.on { background:rgba(34,197,94,0.15); border-color:rgba(34,197,94,0.35); }
.tgsw.on::after { left:20px; background:var(--green); box-shadow:0 0 8px var(--green); }

.btn-sm {
  padding:8px 16px; border-radius:var(--radius); font-size:12px; font-weight:800;
  border:none; cursor:pointer; transition:var(--trans); font-family:'Tajawal','Inter',sans-serif;
}
.btn-sm.g    { background:var(--gg); color:var(--black); }
.btn-sm.g:hover { opacity:.85; }
.btn-sm.red  { background:var(--red); color:white; }
.btn-sm.red:hover { opacity:.85; }
.btn-sm.grn  { background:var(--green); color:var(--black); }
.btn-sm.grn:hover { opacity:.85; }
.btn-sm.out  { background:rgba(255,255,255,0.05); border:1px solid var(--b1); color:var(--t1); }
.btn-sm.out:hover { background:rgba(255,255,255,0.1); }

/* ── LOGIN GATE ────────────────────────────── */
.gate-wrap {
  display:flex; align-items:center; justify-content:center; min-height:60vh; padding:40px 20px;
}
.gate-box {
  text-align:center; max-width:380px; padding:40px 32px;
  background:var(--black2); border:1px solid var(--gold-border); border-radius:var(--radius-xl);
  box-shadow: 0 0 40px rgba(0,0,0,0.4);
}
.gate-ico {
  width:64px; height:64px; border-radius:18px; margin:0 auto 18px;
  display:flex; align-items:center; justify-content:center; font-size:26px;
  background:var(--gold-dim); color:var(--gold-l); border:1px solid var(--gold-border);
  box-shadow: 0 0 24px var(--gold-glow);
}
.gate-title { font-size:18px; font-weight:800; margin-bottom:8px; }
.gate-sub   { font-size:13px; color:var(--t2); margin-bottom:22px; line-height:1.6; }

/* ── TOAST ─────────────────────────────────── */
#toast-wrap { position:fixed; bottom:22px; right:22px; z-index:99999; display:flex; flex-direction:column; gap:7px; pointer-events:none; }
.toast {
  display:flex; align-items:center; gap:9px; padding:11px 16px; border-radius:var(--radius-lg);
  font-size:12px; font-weight:700; pointer-events:all; backdrop-filter:blur(16px);
  opacity:0; transform:translateX(16px); transition:all .28s ease; max-width:300px;
}
.toast.show { opacity:1; transform:translateX(0); }
.toast.ok   { background:rgba(34,197,94,0.12); border:1px solid rgba(34,197,94,0.28); color:#86efac; }
.toast.err  { background:rgba(239,68,68,0.12); border:1px solid rgba(239,68,68,0.28); color:#fca5a5; }
.toast.inf  { background:var(--gold-dim); border:1px solid var(--gold-border); color:var(--gold-l); }
.toast.warn { background:rgba(249,115,22,0.1); border:1px solid rgba(249,115,22,0.25); color:#fb923c; }

/* ── PAGE LOADER ───────────────────────────── */
#pg-load {
  position:fixed; inset:0; z-index:99999; background:var(--black);
  display:flex; align-items:center; justify-content:center; flex-direction:column; gap:18px;
  transition:opacity .5s, visibility .5s;
}
#pg-load.hide { opacity:0; visibility:hidden; pointer-events:none; }
.pl-logo {
  font-family:'JetBrains Mono',monospace; font-size:22px; font-weight:900;
  background:var(--gg); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.pl-spin {
  width:44px; height:44px; border-radius:50%;
  border:3px solid rgba(212,168,67,0.12); border-top-color:var(--gold); animation:spin 1s linear infinite;
}
.pl-txt { font-size:10px; color:var(--t3); font-family:'JetBrains Mono',monospace; letter-spacing:3px; }

/* ── MOBILE ─────────────────────────────────── */
@media (max-width:768px) {
  .topbar { padding:0 14px; }
  .tcol   { grid-template-columns:1fr; }
  .stats-strip { grid-template-columns:repeat(2,1fr); }
  .feat-grid { grid-template-columns:1fr; }
  .steps-grid { grid-template-columns:repeat(2,1fr); }
  .plans-grid { grid-template-columns:1fr; }
  .admin-stats { grid-template-columns:repeat(2,1fr); }
  .hero-btns { flex-direction:column; align-items:center; }
  .panel { padding:16px; }
  .section { padding:0 16px; }
  body { cursor:auto; } body * { cursor:auto; }
  .cur-ring, .cur-dot { display:none; }
}
@media (max-width:480px) {
  .nav-pills .npill span { display:none; }
  .steps-grid { grid-template-columns:1fr; }
  .ftable th:nth-child(3), .ftable td:nth-child(3),
  .ftable th:nth-child(4), .ftable td:nth-child(4) { display:none; }
}
/* ─── Missing dynamic classes ─────────────────────────────────────── */
.hist-icon { width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:13px; }
.hist-name { flex:1;font-size:12px;font-weight:600;color:var(--t1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0; }
.hist-time { font-size:10px;color:var(--t3);white-space:nowrap;font-family:'JetBrains Mono',monospace; }
.hist-dl   { display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;background:rgba(45,212,191,0.08);border:1px solid rgba(45,212,191,0.2);color:var(--teal);font-size:11px;text-decoration:none;transition:background .15s; }
.hist-dl:hover { background:rgba(45,212,191,0.16); }

/* Files table */
.files-table { width:100%;border-collapse:collapse;font-size:12px; }
.files-table th { padding:8px 10px;text-align:left;color:var(--t3);font-weight:600;font-size:10px;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--b1); }
.files-table td { padding:8px 10px;border-bottom:1px solid rgba(255,255,255,0.04);color:var(--t2);vertical-align:middle; }
.files-table tr:last-child td { border-bottom:none; }
.files-table tr:hover td { background:rgba(255,255,255,0.02); }
.file-row-name  { display:flex;align-items:center;gap:8px;font-weight:600;color:var(--t1); }
.file-row-icon  { width:26px;height:26px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:11px;flex-shrink:0; }
.file-type-chip { display:inline-block;padding:2px 8px;border-radius:99px;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.06em; }
.file-type-chip.decrypt { background:rgba(108,99,255,0.1);color:var(--indigo-l);border:1px solid rgba(108,99,255,0.2); }
.file-type-chip.fix     { background:rgba(249,115,22,0.1);color:var(--orange-l);border:1px solid rgba(249,115,22,0.2); }
.file-type-chip.upload  { background:rgba(45,212,191,0.08);color:var(--teal);border:1px solid rgba(45,212,191,0.2); }

/* Empty state */
.empty-state { display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--t3);font-size:12px;padding:40px;text-align:center; }
.empty-state i { font-size:28px;opacity:.4; }

/* Admin user lookup */
.user-lookup-result { display:flex;flex-wrap:wrap;gap:8px;padding:10px;background:rgba(255,255,255,0.03);border:1px solid var(--b1);border-radius:12px;margin-top:8px; }
.user-lookup-stat   { display:flex;align-items:center;gap:6px;font-size:12px;color:var(--t2);padding:4px 10px;background:rgba(255,255,255,0.04);border-radius:8px; }
.user-lookup-stat i { font-size:11px; }

/* ─── Quota bars (plan info section) ────────────────────────────────────── */
.qrow  { display:flex;align-items:center;gap:6px;margin-top:6px;font-size:11px; }
.qlbl  { color:var(--t3);min-width:56px;font-size:10px; }
.qbar-wrap { flex:1;height:5px;background:rgba(255,255,255,0.06);border-radius:99px;overflow:hidden; }
.qbar-fill { height:100%;border-radius:99px;transition:width .5s ease; }
.qbar-txt  { color:var(--t2);font-size:10px;font-family:'JetBrains Mono',monospace;white-space:nowrap;min-width:42px;text-align:right; }

/* ─── Quota widget ──────────────────────────────────────────────────────── */
#quota-widget  { background:rgba(255,255,255,0.025);border:1px solid var(--b1);border-radius:12px;padding:12px 14px; }
.qw-title { font-size:11px;font-weight:700;color:var(--t1);margin-bottom:8px;display:flex;align-items:center;gap:6px; }
.qw-row   { display:flex;justify-content:space-between;align-items:center;margin-top:6px;font-size:11px; }
.qw-lbl   { color:var(--t3); }
.qw-val   { color:var(--t1);font-family:'JetBrains Mono',monospace;font-size:11px; }
.qw-barwrap { height:4px;background:rgba(255,255,255,0.06);border-radius:99px;overflow:hidden;margin:4px 0 8px; }
.qw-bar   { height:100%;border-radius:99px;transition:width .5s ease; }
.qw-reset { font-size:9px;color:var(--t3);margin-top:8px;text-align:center; }
