/* ═══════════════════════════════════════════════════════════════════
   Flazza DDS · Design Tokens  (Milestone 0)
   ─────────────────────────────────────────────────────────────────────
   طبقة أساس رقيقة تُحمَّل قبل quiz-themes-engine.css، تضبط القيم
   الافتراضية لكل توكن مُعلَن في ThemeRegistry::tokenSchema().

   مبدأ التشغيل:
     1. هذا الملف = Single Source of Truth للقيم الافتراضية (classic).
     2. engine.css بعده = فروق الثيمات الجوهرية (سلوك + هوية).
     3. Milestone 1 سيحقن ثالثة inline <style id="qzt-overrides"> بعدهما
        فتسود تعديلات المحرّر.

   قاعدة صارمة: لا تُضاف هنا أي قيمة إلا لتوكن موجود في الـ Schema،
   ولا تُستخدم في غيرها من ملفات CSS إلا عبر اسم الـ variable كي يصل
   أثر المحرر لحظياً (Zero-Refresh).
   ═══════════════════════════════════════════════════════════════════ */

:root {
  /* ── Stage ───────────────────────────────────────────── */
  --qzt-stage-bg-color: #0b1023;
  --qzt-stage-bg-gradient: linear-gradient(180deg, #0b1023 0%, #1a1f3a 100%);
  --qzt-stage-bg-image: none;
  --qzt-stage-bg-pattern: none;
  --qzt-stage-vignette: radial-gradient(120% 80% at 50% 0%, transparent 60%, rgba(0, 0, 0, 0.18) 100%);
  --qzt-stage-padding-x: 48px;
  --qzt-stage-padding-y: 40px;
  --qzt-safe-zone-x: 40px;
  --qzt-safe-zone-y: 32px;

  /* ── Typography ──────────────────────────────────────── */
  --qzt-font-family-primary: 'Tajawal', system-ui, sans-serif;
  --qzt-font-family-display: 'Tajawal', system-ui, sans-serif;
  --qzt-font-family-mono: ui-monospace, 'SFMono-Regular', monospace;
  --qzt-text-scale: 1;
  --qzt-letter-spacing: 0;
  --qzt-text-weight-body: 500;
  --qzt-text-weight-display: 800;
  --qzt-text-color-primary: #f8fafc;
  --qzt-text-color-muted: rgba(248, 250, 252, 0.72);
  --qzt-text-shadow-display: 0 2px 16px rgba(0, 0, 0, 0.35);

  /* ── Palette ─────────────────────────────────────────── */
  --qzt-color-accent: #8b5cf6;
  --qzt-color-accent-2: #06b6d4;
  --qzt-color-success: #10b981;
  --qzt-color-warn: #f59e0b;
  --qzt-color-danger: #ef4444;
  --qzt-color-surface: rgba(255, 255, 255, 0.06);
  --qzt-color-surface-raised: rgba(255, 255, 255, 0.10);
  --qzt-color-border: rgba(255, 255, 255, 0.12);

  /* ── Spacing & Radius ────────────────────────────────── */
  --qzt-density: 1;
  --qzt-radius-scale: 1;
  --qzt-radius-sm: 8px;
  --qzt-radius-md: 14px;
  --qzt-radius-lg: 22px;
  --qzt-border-width: 1px;

  /* ── Motion ──────────────────────────────────────────── */
  --qzt-motion-duration: 1;
  --qzt-motion-ease: cubic-bezier(.4, 0, .2, 1);
  --qzt-motion-stagger: 60ms;
  --qzt-motion-scale-impact: 1;

  /* ── Effects ─────────────────────────────────────────── */
  --qzt-glow-strength: 0;
  --qzt-accent-pulse: 0 0 0 0 rgba(139, 92, 246, 0);
  --qzt-shadow-soft: 0 6px 16px rgba(0, 0, 0, 0.18);
  --qzt-shadow-raised: 0 14px 30px rgba(0, 0, 0, 0.24);
  --qzt-shadow-dramatic: 0 24px 48px rgba(0, 0, 0, 0.42);
  --qzt-backdrop-blur: 0px;
  --qzt-backdrop-saturation: 1;

  /* ── Timer ───────────────────────────────────────────── */
  --qzt-timer-track-bg: rgba(255, 255, 255, 0.08);
  --qzt-timer-fill-color: #8b5cf6;
  --qzt-timer-fill-urgent: #ef4444;
  --qzt-timer-height: 8px;
  --qzt-timer-radius: 999px;
  --qzt-timer-label-color: #f8fafc;
  --qzt-timer-label-size: 1rem;
  --qzt-timer-ease: linear;

  /* ── Answer Tile ─────────────────────────────────────── */
  --qzt-tile-bg: rgba(255, 255, 255, 0.06);
  --qzt-tile-border: rgba(255, 255, 255, 0.16);
  --qzt-tile-bg-correct: rgba(16, 185, 129, 0.22);
  --qzt-tile-bg-wrong: rgba(239, 68, 68, 0.22);
  --qzt-tile-text-color: #f8fafc;
  --qzt-tile-text-size: 1.1rem;
  --qzt-tile-padding: 18px;
  --qzt-tile-radius: 16px;
  --qzt-tile-shadow: 0 6px 16px rgba(0, 0, 0, 0.18);
  --qzt-tile-badge-bg: #8b5cf6;
  --qzt-tile-badge-color: #ffffff;

  /* ── Leaderboard ─────────────────────────────────────── */
  --qzt-lb-row-bg: rgba(255, 255, 255, 0.05);
  --qzt-lb-row-border: rgba(255, 255, 255, 0.10);
  --qzt-lb-row-radius: 14px;
  --qzt-lb-row-height: 56px;
  --qzt-lb-row-top1-bg: rgba(250, 204, 21, 0.18);
  --qzt-lb-row-top2-bg: rgba(203, 213, 225, 0.16);
  --qzt-lb-row-top3-bg: rgba(217, 119, 6, 0.18);
  --qzt-lb-name-color: #f8fafc;
  --qzt-lb-score-color: #fde68a;
  --qzt-lb-avatar-ring: rgba(139, 92, 246, 0.60);
  --qzt-lb-rank-bg: #8b5cf6;
  --qzt-lb-rank-color: #ffffff;

  /* ── QR / Join ───────────────────────────────────────── */
  --qzt-qr-bg: #ffffff;
  --qzt-qr-fg: #0b1023;
  --qzt-qr-frame: rgba(255, 255, 255, 0.25);
  --qzt-qr-radius: 20px;
  --qzt-qr-size: 180px;
  --qzt-pin-bg: rgba(255, 255, 255, 0.12);
  --qzt-pin-color: #f8fafc;
  --qzt-pin-size: 2.2rem;

  /* ── Lobby ───────────────────────────────────────────── */
  --qzt-lobby-title-color: #f8fafc;
  --qzt-lobby-title-size: 2.6rem;
  --qzt-lobby-eyebrow-color: #a78bfa;
  --qzt-lobby-player-bg: rgba(255, 255, 255, 0.08);
  --qzt-lobby-player-color: #f8fafc;
  --qzt-lobby-player-radius: 12px;

  /* ── Celebration ─────────────────────────────────────── */
  --qzt-celeb-accent: #fbbf24;
  --qzt-celeb-bg: radial-gradient(120% 80% at 50% 30%, rgba(251, 191, 36, 0.22) 0%, transparent 60%);
  --qzt-celeb-confetti-density: 1;
  --qzt-celeb-trophy-scale: 1;
}

/* ═══════════════════════════════════════════════════════════════════
   Per-Theme Overrides (Component tokens)
   ─────────────────────────────────────────────────────────────────────
   engine.css مسؤول عن الـ base-behavior tokens (density, motion…).
   نحن هنا نُكمل عبر توكنز المكوّنات (timer / tile / lb / qr / lobby…)
   حتى لا يتضخّم engine.css. كل ثيم يلمس ما يُحدث فرقاً في شخصيته.
   ═══════════════════════════════════════════════════════════════════ */

/* ── Kids: ألوان زاهية، بطاقات رحبة، أرقام مرحة ─────────────────── */
html[data-quiz-theme="kids"] {
  --qzt-color-accent: #fbbf24;
  --qzt-color-accent-2: #f97316;
  --qzt-tile-bg: #ffffff;
  --qzt-tile-border: rgba(251, 146, 60, 0.35);
  --qzt-tile-text-color: #1f2937;
  --qzt-tile-text-size: 1.25rem;
  --qzt-tile-radius: 24px;
  --qzt-tile-badge-bg: #f97316;
  --qzt-tile-badge-color: #ffffff;
  --qzt-timer-fill-color: #fbbf24;
  --qzt-timer-height: 14px;
  --qzt-timer-radius: 999px;
  --qzt-lb-rank-bg: #f97316;
  --qzt-lobby-title-color: #fffbeb;
  --qzt-lobby-eyebrow-color: #fde68a;
  --qzt-celeb-accent: #fde047;
  --qzt-celeb-confetti-density: 1.5;
}

/* ── Esports: قاتم + Neon، زوايا حادة، تباين عالٍ ─────────────── */
html[data-quiz-theme="esports"] {
  --qzt-color-accent: #22d3ee;
  --qzt-color-accent-2: #a855f7;
  --qzt-tile-bg: rgba(2, 6, 23, 0.85);
  --qzt-tile-border: rgba(34, 211, 238, 0.45);
  --qzt-tile-text-color: #e0f2fe;
  --qzt-tile-radius: 6px;
  --qzt-tile-badge-bg: #0ea5e9;
  --qzt-tile-badge-color: #0b1023;
  --qzt-timer-track-bg: rgba(255, 255, 255, 0.05);
  --qzt-timer-fill-color: #22d3ee;
  --qzt-timer-fill-urgent: #f43f5e;
  --qzt-timer-radius: 2px;
  --qzt-lb-row-bg: rgba(2, 6, 23, 0.6);
  --qzt-lb-row-radius: 4px;
  --qzt-lb-name-color: #e0f2fe;
  --qzt-lb-score-color: #22d3ee;
  --qzt-lb-rank-bg: #a855f7;
  --qzt-qr-bg: #e0f2fe;
  --qzt-qr-fg: #020617;
  --qzt-celeb-accent: #22d3ee;
}

/* ── Academy: هادئ، محترم، زوايا معتدلة، تباين قراءة عالٍ ──────── */
html[data-quiz-theme="academy"] {
  --qzt-color-accent: #0ea5e9;
  --qzt-color-accent-2: #1d4ed8;
  --qzt-tile-bg: #ffffff;
  --qzt-tile-border: rgba(30, 64, 175, 0.15);
  --qzt-tile-text-color: #0f172a;
  --qzt-tile-text-size: 1.05rem;
  --qzt-tile-radius: 10px;
  --qzt-tile-shadow: 0 2px 8px rgba(15, 23, 42, 0.08);
  --qzt-tile-badge-bg: #1d4ed8;
  --qzt-tile-badge-color: #ffffff;
  --qzt-timer-fill-color: #1d4ed8;
  --qzt-timer-height: 6px;
  --qzt-lb-row-bg: #ffffff;
  --qzt-lb-row-border: rgba(15, 23, 42, 0.08);
  --qzt-lb-name-color: #0f172a;
  --qzt-lb-score-color: #1d4ed8;
  --qzt-lb-rank-bg: #1d4ed8;
  --qzt-qr-bg: #f8fafc;
  --qzt-qr-fg: #0f172a;
  --qzt-lobby-title-color: #0f172a;
  --qzt-lobby-eyebrow-color: #1d4ed8;
  --qzt-lobby-player-bg: rgba(30, 64, 175, 0.08);
  --qzt-lobby-player-color: #0f172a;
  --qzt-celeb-accent: #1d4ed8;
  --qzt-celeb-confetti-density: 0.4;
}

/* ── Gala: فخم، ذهبي، زوايا نبيلة ─────────────────────────────── */
html[data-quiz-theme="gala"] {
  --qzt-color-accent: #fbbf24;
  --qzt-color-accent-2: #f59e0b;
  --qzt-tile-bg: rgba(28, 13, 54, 0.75);
  --qzt-tile-border: rgba(251, 191, 36, 0.35);
  --qzt-tile-text-color: #fef3c7;
  --qzt-tile-text-size: 1.15rem;
  --qzt-tile-radius: 14px;
  --qzt-tile-shadow: 0 18px 36px rgba(251, 191, 36, 0.18);
  --qzt-tile-badge-bg: #fbbf24;
  --qzt-tile-badge-color: #1c0d36;
  --qzt-timer-fill-color: #fbbf24;
  --qzt-timer-height: 10px;
  --qzt-lb-row-bg: rgba(28, 13, 54, 0.55);
  --qzt-lb-row-border: rgba(251, 191, 36, 0.20);
  --qzt-lb-name-color: #fef3c7;
  --qzt-lb-score-color: #fde68a;
  --qzt-lb-rank-bg: #fbbf24;
  --qzt-lb-rank-color: #1c0d36;
  --qzt-lb-row-top1-bg: rgba(251, 191, 36, 0.28);
  --qzt-qr-bg: #fef3c7;
  --qzt-qr-fg: #1c0d36;
  --qzt-lobby-eyebrow-color: #fde68a;
  --qzt-celeb-accent: #fbbf24;
  --qzt-celeb-trophy-scale: 1.2;
}

/* ═══════════════════════════════════════════════════════════════════
   A11y Fallback: يحترم prefers-reduced-motion بصرف النظر عن التخصيص
   (حارس لا يمكن تعطيله من المحرر — Budget مفروض)
   ═══════════════════════════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  :root {
    --qzt-motion-duration: 0.6;
    --qzt-motion-scale-impact: 0;
    --qzt-celeb-confetti-density: 0;
  }
}
