/* ===========================================
   TMNT: Splintered Fate - CSS Variables
   Game-constant element colors, spacing, typography
   =========================================== */

:root {
  /* Element Type Colors (game-constant, not themed) */
  --el-water: #1a8fc4;
  --el-water-bg: rgba(26, 143, 196, 0.12);
  --el-water-border: rgba(26, 143, 196, 0.35);

  --el-flame: #d94e1f;
  --el-flame-bg: rgba(217, 78, 31, 0.12);
  --el-flame-border: rgba(217, 78, 31, 0.35);

  --el-ooze: #5fa31e;
  --el-ooze-bg: rgba(95, 163, 30, 0.12);
  --el-ooze-border: rgba(95, 163, 30, 0.35);

  --el-utrom: #8b5cf6;
  --el-utrom-bg: rgba(139, 92, 246, 0.12);
  --el-utrom-border: rgba(139, 92, 246, 0.35);

  --el-ninja: #888888;
  --el-ninja-bg: rgba(136, 136, 136, 0.12);
  --el-ninja-border: rgba(136, 136, 136, 0.35);

  --el-light: #d4a017;
  --el-light-bg: rgba(212, 160, 23, 0.12);
  --el-light-border: rgba(212, 160, 23, 0.35);

  --el-dark: #9333ea;
  --el-dark-bg: rgba(147, 51, 234, 0.12);
  --el-dark-border: rgba(147, 51, 234, 0.35);

  --el-robotics: #3b82f6;
  --el-robotics-bg: rgba(59, 130, 246, 0.12);
  --el-robotics-border: rgba(59, 130, 246, 0.35);

  --el-legendary: #b8860b;
  --el-legendary-bg: rgba(184, 134, 11, 0.12);
  --el-legendary-border: rgba(184, 134, 11, 0.35);

  /* Gameplay Mechanic Tag Colors */
  --el-attack: #e05a3a;
  --el-attack-bg: rgba(224, 90, 58, 0.12);
  --el-attack-border: rgba(224, 90, 58, 0.35);

  --el-crit: #b83a2a;
  --el-crit-bg: rgba(184, 58, 42, 0.12);
  --el-crit-border: rgba(184, 58, 42, 0.35);

  --el-dash: #14b8a6;
  --el-dash-bg: rgba(20, 184, 166, 0.12);
  --el-dash-border: rgba(20, 184, 166, 0.35);

  --el-speed: #0f8c7f;
  --el-speed-bg: rgba(15, 140, 127, 0.12);
  --el-speed-border: rgba(15, 140, 127, 0.35);

  --el-special: #d97706;
  --el-special-bg: rgba(217, 119, 6, 0.12);
  --el-special-border: rgba(217, 119, 6, 0.35);

  --el-tool: #4a90d9;
  --el-tool-bg: rgba(74, 144, 217, 0.12);
  --el-tool-border: rgba(74, 144, 217, 0.35);

  --el-shuriken: #c4543e;
  --el-shuriken-bg: rgba(196, 84, 62, 0.12);
  --el-shuriken-border: rgba(196, 84, 62, 0.35);

  --el-defense: #4a8c6e;
  --el-defense-bg: rgba(74, 140, 110, 0.12);
  --el-defense-border: rgba(74, 140, 110, 0.35);

  --el-health: #22a55a;
  --el-health-bg: rgba(34, 165, 90, 0.12);
  --el-health-border: rgba(34, 165, 90, 0.35);

  --el-boss: #a83240;
  --el-boss-bg: rgba(168, 50, 64, 0.12);
  --el-boss-border: rgba(168, 50, 64, 0.35);

  --el-barrier: #8a6d3b;
  --el-barrier-bg: rgba(138, 109, 59, 0.12);
  --el-barrier-border: rgba(138, 109, 59, 0.35);

  --el-general: #7a7a7a;
  --el-general-bg: rgba(122, 122, 122, 0.12);
  --el-general-border: rgba(122, 122, 122, 0.35);

  --el-astral: #a78bfa;
  --el-astral-bg: rgba(167, 139, 250, 0.12);
  --el-astral-border: rgba(167, 139, 250, 0.35);

  --el-multi-hit: #6366f1;
  --el-multi-hit-bg: rgba(99, 102, 241, 0.12);
  --el-multi-hit-border: rgba(99, 102, 241, 0.35);

  --el-economy: #d4a017;
  --el-economy-bg: rgba(212, 160, 23, 0.12);
  --el-economy-border: rgba(212, 160, 23, 0.35);

  --el-scrap: #8b7355;
  --el-scrap-bg: rgba(139, 115, 85, 0.12);
  --el-scrap-border: rgba(139, 115, 85, 0.35);

  --el-luck: #10b981;
  --el-luck-bg: rgba(16, 185, 129, 0.12);
  --el-luck-border: rgba(16, 185, 129, 0.35);

  --el-boost: #f59e0b;
  --el-boost-bg: rgba(245, 158, 11, 0.12);
  --el-boost-border: rgba(245, 158, 11, 0.35);

  --el-duration: #8b5cf6;
  --el-duration-bg: rgba(139, 92, 246, 0.12);
  --el-duration-border: rgba(139, 92, 246, 0.35);

  --el-risk: #dc2626;
  --el-risk-bg: rgba(220, 38, 38, 0.12);
  --el-risk-border: rgba(220, 38, 38, 0.35);

  --el-stun: #eab308;
  --el-stun-bg: rgba(234, 179, 8, 0.12);
  --el-stun-border: rgba(234, 179, 8, 0.35);

  --el-physical: #9ca3af;
  --el-physical-bg: rgba(156, 163, 175, 0.12);
  --el-physical-border: rgba(156, 163, 175, 0.35);

  /* Contextual element color (set via data-type attribute) */
  --el-color: var(--el-water);
  --el-bg: var(--el-water-bg);
  --el-border: var(--el-water-border);

  /* Typography */
  --font-display: 'Bangers', cursive;
  --font-body: 'DM Sans', sans-serif;
  --text-xs: 0.7rem;
  --text-sm: 0.8rem;
  --text-base: 0.9rem;
  --text-md: 1rem;
  --text-lg: 1.15rem;
  --text-xl: 1.4rem;
  --text-2xl: 1.8rem;
  --text-3xl: 2.2rem;

  /* Spacing Scale */
  --sp-1: 4px;
  --sp-2: 8px;
  --sp-3: 12px;
  --sp-4: 16px;
  --sp-5: 20px;
  --sp-6: 24px;
  --sp-8: 32px;
  --sp-10: 40px;
  --sp-12: 48px;

  /* Layout */
  --sidebar-width: 320px;
  --topbar-height: 80px;
  --tab-bar-height: 48px;
  --filter-bar-height: 52px;

  /* Transitions */
  --transition-fast: 0.12s ease;
  --transition-base: 0.2s ease;
  --transition-slow: 0.3s ease;

  /* Shadows */
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.15);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.2);
  --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.25);

  /* Z-Index Scale */
  --z-base: 1;
  --z-sticky: 10;
  --z-sidebar: 20;
  --z-modal-overlay: 50;
  --z-modal: 60;
  --z-tooltip: 70;
}

/* Element type attribute selectors */
[data-type="water"] {
  --el-color: var(--el-water);
  --el-bg: var(--el-water-bg);
  --el-border: var(--el-water-border);
}

[data-type="flame"] {
  --el-color: var(--el-flame);
  --el-bg: var(--el-flame-bg);
  --el-border: var(--el-flame-border);
}

[data-type="ooze"] {
  --el-color: var(--el-ooze);
  --el-bg: var(--el-ooze-bg);
  --el-border: var(--el-ooze-border);
}

[data-type="utrom"] {
  --el-color: var(--el-utrom);
  --el-bg: var(--el-utrom-bg);
  --el-border: var(--el-utrom-border);
}

[data-type="ninja"] {
  --el-color: var(--el-ninja);
  --el-bg: var(--el-ninja-bg);
  --el-border: var(--el-ninja-border);
}

[data-type="light"] {
  --el-color: var(--el-light);
  --el-bg: var(--el-light-bg);
  --el-border: var(--el-light-border);
}

[data-type="dark"] {
  --el-color: var(--el-dark);
  --el-bg: var(--el-dark-bg);
  --el-border: var(--el-dark-border);
}

[data-type="robotics"] {
  --el-color: var(--el-robotics);
  --el-bg: var(--el-robotics-bg);
  --el-border: var(--el-robotics-border);
}

[data-type="legendary"] {
  --el-color: var(--el-legendary);
  --el-bg: var(--el-legendary-bg);
  --el-border: var(--el-legendary-border);
}

/* Gameplay mechanic tag selectors */
[data-type="attack"] {
  --el-color: var(--el-attack);
  --el-bg: var(--el-attack-bg);
  --el-border: var(--el-attack-border);
}

[data-type="crit"] {
  --el-color: var(--el-crit);
  --el-bg: var(--el-crit-bg);
  --el-border: var(--el-crit-border);
}

[data-type="dash"] {
  --el-color: var(--el-dash);
  --el-bg: var(--el-dash-bg);
  --el-border: var(--el-dash-border);
}

[data-type="speed"] {
  --el-color: var(--el-speed);
  --el-bg: var(--el-speed-bg);
  --el-border: var(--el-speed-border);
}

[data-type="special"] {
  --el-color: var(--el-special);
  --el-bg: var(--el-special-bg);
  --el-border: var(--el-special-border);
}

[data-type="tool"] {
  --el-color: var(--el-tool);
  --el-bg: var(--el-tool-bg);
  --el-border: var(--el-tool-border);
}

[data-type="shuriken"] {
  --el-color: var(--el-shuriken);
  --el-bg: var(--el-shuriken-bg);
  --el-border: var(--el-shuriken-border);
}

[data-type="defense"] {
  --el-color: var(--el-defense);
  --el-bg: var(--el-defense-bg);
  --el-border: var(--el-defense-border);
}

[data-type="health"] {
  --el-color: var(--el-health);
  --el-bg: var(--el-health-bg);
  --el-border: var(--el-health-border);
}

[data-type="boss"] {
  --el-color: var(--el-boss);
  --el-bg: var(--el-boss-bg);
  --el-border: var(--el-boss-border);
}

[data-type="barrier"] {
  --el-color: var(--el-barrier);
  --el-bg: var(--el-barrier-bg);
  --el-border: var(--el-barrier-border);
}

[data-type="general"] {
  --el-color: var(--el-general);
  --el-bg: var(--el-general-bg);
  --el-border: var(--el-general-border);
}

[data-type="astral"] {
  --el-color: var(--el-astral);
  --el-bg: var(--el-astral-bg);
  --el-border: var(--el-astral-border);
}

[data-type="multi-hit"] {
  --el-color: var(--el-multi-hit);
  --el-bg: var(--el-multi-hit-bg);
  --el-border: var(--el-multi-hit-border);
}

[data-type="economy"] {
  --el-color: var(--el-economy);
  --el-bg: var(--el-economy-bg);
  --el-border: var(--el-economy-border);
}

[data-type="coins"] {
  --el-color: var(--el-economy);
  --el-bg: var(--el-economy-bg);
  --el-border: var(--el-economy-border);
}

[data-type="currency"] {
  --el-color: var(--el-economy);
  --el-bg: var(--el-economy-bg);
  --el-border: var(--el-economy-border);
}

[data-type="scrap"] {
  --el-color: var(--el-scrap);
  --el-bg: var(--el-scrap-bg);
  --el-border: var(--el-scrap-border);
}

[data-type="luck"] {
  --el-color: var(--el-luck);
  --el-bg: var(--el-luck-bg);
  --el-border: var(--el-luck-border);
}

[data-type="upgrades"] {
  --el-color: var(--el-boost);
  --el-bg: var(--el-boost-bg);
  --el-border: var(--el-boost-border);
}

[data-type="boost"] {
  --el-color: var(--el-boost);
  --el-bg: var(--el-boost-bg);
  --el-border: var(--el-boost-border);
}

[data-type="buff"] {
  --el-color: var(--el-boost);
  --el-bg: var(--el-boost-bg);
  --el-border: var(--el-boost-border);
}

[data-type="duration"] {
  --el-color: var(--el-duration);
  --el-bg: var(--el-duration-bg);
  --el-border: var(--el-duration-border);
}

[data-type="dodge"] {
  --el-color: var(--el-dash);
  --el-bg: var(--el-dash-bg);
  --el-border: var(--el-dash-border);
}

[data-type="damage"] {
  --el-color: var(--el-attack);
  --el-bg: var(--el-attack-bg);
  --el-border: var(--el-attack-border);
}

[data-type="revive"] {
  --el-color: var(--el-health);
  --el-bg: var(--el-health-bg);
  --el-border: var(--el-health-border);
}

[data-type="healing"] {
  --el-color: var(--el-health);
  --el-bg: var(--el-health-bg);
  --el-border: var(--el-health-border);
}

[data-type="survivability"] {
  --el-color: var(--el-defense);
  --el-bg: var(--el-defense-bg);
  --el-border: var(--el-defense-border);
}

[data-type="risk"] {
  --el-color: var(--el-risk);
  --el-bg: var(--el-risk-bg);
  --el-border: var(--el-risk-border);
}

[data-type="stun"] {
  --el-color: var(--el-stun);
  --el-bg: var(--el-stun-bg);
  --el-border: var(--el-stun-border);
}

[data-type="control"] {
  --el-color: var(--el-stun);
  --el-bg: var(--el-stun-bg);
  --el-border: var(--el-stun-border);
}

[data-type="random"] {
  --el-color: var(--el-astral);
  --el-bg: var(--el-astral-bg);
  --el-border: var(--el-astral-border);
}

[data-type="physical"] {
  --el-color: var(--el-physical);
  --el-bg: var(--el-physical-bg);
  --el-border: var(--el-physical-border);
}
