diff --git a/team-Krantikari/.gitignore b/team-Krantikari/.gitignore
new file mode 100644
index 000000000..a547bf36d
--- /dev/null
+++ b/team-Krantikari/.gitignore
@@ -0,0 +1,24 @@
+# Logs
+logs
+*.log
+npm-debug.log*
+yarn-debug.log*
+yarn-error.log*
+pnpm-debug.log*
+lerna-debug.log*
+
+node_modules
+dist
+dist-ssr
+*.local
+
+# Editor directories and files
+.vscode/*
+!.vscode/extensions.json
+.idea
+.DS_Store
+*.suo
+*.ntvs*
+*.njsproj
+*.sln
+*.sw?
diff --git a/team-Krantikari/README.md b/team-Krantikari/README.md
new file mode 100644
index 000000000..a36934d87
--- /dev/null
+++ b/team-Krantikari/README.md
@@ -0,0 +1,16 @@
+# React + Vite
+
+This template provides a minimal setup to get React working in Vite with HMR and some ESLint rules.
+
+Currently, two official plugins are available:
+
+- [@vitejs/plugin-react](https://github.com/vitejs/vite-plugin-react/blob/main/packages/plugin-react) uses [Oxc](https://oxc.rs)
+- [@vitejs/plugin-react-swc](https://github.com/vitejs/vite-plugin-react/blob/main/packages/plugin-react-swc) uses [SWC](https://swc.rs/)
+
+## React Compiler
+
+The React Compiler is not enabled on this template because of its impact on dev & build performances. To add it, see [this documentation](https://react.dev/learn/react-compiler/installation).
+
+## Expanding the ESLint configuration
+
+If you are developing a production application, we recommend using TypeScript with type-aware lint rules enabled. Check out the [TS template](https://github.com/vitejs/vite/tree/main/packages/create-vite/template-react-ts) for information on how to integrate TypeScript and [`typescript-eslint`](https://typescript-eslint.io) in your project.
diff --git a/team-Krantikari/eslint.config.js b/team-Krantikari/eslint.config.js
new file mode 100644
index 000000000..4fa125da2
--- /dev/null
+++ b/team-Krantikari/eslint.config.js
@@ -0,0 +1,29 @@
+import js from '@eslint/js'
+import globals from 'globals'
+import reactHooks from 'eslint-plugin-react-hooks'
+import reactRefresh from 'eslint-plugin-react-refresh'
+import { defineConfig, globalIgnores } from 'eslint/config'
+
+export default defineConfig([
+ globalIgnores(['dist']),
+ {
+ files: ['**/*.{js,jsx}'],
+ extends: [
+ js.configs.recommended,
+ reactHooks.configs.flat.recommended,
+ reactRefresh.configs.vite,
+ ],
+ languageOptions: {
+ ecmaVersion: 2020,
+ globals: globals.browser,
+ parserOptions: {
+ ecmaVersion: 'latest',
+ ecmaFeatures: { jsx: true },
+ sourceType: 'module',
+ },
+ },
+ rules: {
+ 'no-unused-vars': ['error', { varsIgnorePattern: '^[A-Z_]' }],
+ },
+ },
+])
diff --git a/team-Krantikari/index.html b/team-Krantikari/index.html
new file mode 100644
index 000000000..ff43d7aa3
--- /dev/null
+++ b/team-Krantikari/index.html
@@ -0,0 +1,15 @@
+
+
+
+
+
+
+
+
+ Pokédex — Team Krantikari
+
+
+
+
+
+
diff --git a/team-Krantikari/jsconfig.json b/team-Krantikari/jsconfig.json
new file mode 100644
index 000000000..abe04df57
--- /dev/null
+++ b/team-Krantikari/jsconfig.json
@@ -0,0 +1,8 @@
+{
+ "compilerOptions": {
+ "baseUrl": ".",
+ "paths": {
+ "@/*": ["./src/*"]
+ }
+ }
+}
diff --git a/team-Krantikari/package-lock.json b/team-Krantikari/package-lock.json
new file mode 100644
index 000000000..d6ceb1a40
--- /dev/null
+++ b/team-Krantikari/package-lock.json
@@ -0,0 +1,2909 @@
+{
+ "name": "team-krantikari",
+ "version": "0.0.0",
+ "lockfileVersion": 3,
+ "requires": true,
+ "packages": {
+ "": {
+ "name": "team-krantikari",
+ "version": "0.0.0",
+ "dependencies": {
+ "@tailwindcss/vite": "^4.2.2",
+ "class-variance-authority": "^0.7.1",
+ "clsx": "^2.1.1",
+ "lucide-react": "^1.7.0",
+ "react": "^19.2.4",
+ "react-dom": "^19.2.4",
+ "tailwind-merge": "^3.5.0",
+ "tailwindcss": "^4.2.2"
+ },
+ "devDependencies": {
+ "@eslint/js": "^9.39.4",
+ "@types/react": "^19.2.14",
+ "@types/react-dom": "^19.2.3",
+ "@vitejs/plugin-react": "^6.0.1",
+ "eslint": "^9.39.4",
+ "eslint-plugin-react-hooks": "^7.0.1",
+ "eslint-plugin-react-refresh": "^0.5.2",
+ "globals": "^17.4.0",
+ "vite": "^8.0.1"
+ }
+ },
+ "node_modules/@babel/code-frame": {
+ "version": "7.29.0",
+ "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.29.0.tgz",
+ "integrity": "sha512-9NhCeYjq9+3uxgdtp20LSiJXJvN0FeCtNGpJxuMFZ1Kv3cWUNb6DOhJwUvcVCzKGR66cw4njwM6hrJLqgOwbcw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/helper-validator-identifier": "^7.28.5",
+ "js-tokens": "^4.0.0",
+ "picocolors": "^1.1.1"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/compat-data": {
+ "version": "7.29.0",
+ "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.29.0.tgz",
+ "integrity": "sha512-T1NCJqT/j9+cn8fvkt7jtwbLBfLC/1y1c7NtCeXFRgzGTsafi68MRv8yzkYSapBnFA6L3U2VSc02ciDzoAJhJg==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/core": {
+ "version": "7.29.0",
+ "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.29.0.tgz",
+ "integrity": "sha512-CGOfOJqWjg2qW/Mb6zNsDm+u5vFQ8DxXfbM09z69p5Z6+mE1ikP2jUXw+j42Pf1XTYED2Rni5f95npYeuwMDQA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/code-frame": "^7.29.0",
+ "@babel/generator": "^7.29.0",
+ "@babel/helper-compilation-targets": "^7.28.6",
+ "@babel/helper-module-transforms": "^7.28.6",
+ "@babel/helpers": "^7.28.6",
+ "@babel/parser": "^7.29.0",
+ "@babel/template": "^7.28.6",
+ "@babel/traverse": "^7.29.0",
+ "@babel/types": "^7.29.0",
+ "@jridgewell/remapping": "^2.3.5",
+ "convert-source-map": "^2.0.0",
+ "debug": "^4.1.0",
+ "gensync": "^1.0.0-beta.2",
+ "json5": "^2.2.3",
+ "semver": "^6.3.1"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/babel"
+ }
+ },
+ "node_modules/@babel/generator": {
+ "version": "7.29.1",
+ "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.29.1.tgz",
+ "integrity": "sha512-qsaF+9Qcm2Qv8SRIMMscAvG4O3lJ0F1GuMo5HR/Bp02LopNgnZBC/EkbevHFeGs4ls/oPz9v+Bsmzbkbe+0dUw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/parser": "^7.29.0",
+ "@babel/types": "^7.29.0",
+ "@jridgewell/gen-mapping": "^0.3.12",
+ "@jridgewell/trace-mapping": "^0.3.28",
+ "jsesc": "^3.0.2"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-compilation-targets": {
+ "version": "7.28.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.28.6.tgz",
+ "integrity": "sha512-JYtls3hqi15fcx5GaSNL7SCTJ2MNmjrkHXg4FSpOA/grxK8KwyZ5bubHsCq8FXCkua6xhuaaBit+3b7+VZRfcA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/compat-data": "^7.28.6",
+ "@babel/helper-validator-option": "^7.27.1",
+ "browserslist": "^4.24.0",
+ "lru-cache": "^5.1.1",
+ "semver": "^6.3.1"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-globals": {
+ "version": "7.28.0",
+ "resolved": "https://registry.npmjs.org/@babel/helper-globals/-/helper-globals-7.28.0.tgz",
+ "integrity": "sha512-+W6cISkXFa1jXsDEdYA8HeevQT/FULhxzR99pxphltZcVaugps53THCeiWA8SguxxpSp3gKPiuYfSWopkLQ4hw==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-module-imports": {
+ "version": "7.28.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.28.6.tgz",
+ "integrity": "sha512-l5XkZK7r7wa9LucGw9LwZyyCUscb4x37JWTPz7swwFE/0FMQAGpiWUZn8u9DzkSBWEcK25jmvubfpw2dnAMdbw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/traverse": "^7.28.6",
+ "@babel/types": "^7.28.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-module-transforms": {
+ "version": "7.28.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.28.6.tgz",
+ "integrity": "sha512-67oXFAYr2cDLDVGLXTEABjdBJZ6drElUSI7WKp70NrpyISso3plG9SAGEF6y7zbha/wOzUByWWTJvEDVNIUGcA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/helper-module-imports": "^7.28.6",
+ "@babel/helper-validator-identifier": "^7.28.5",
+ "@babel/traverse": "^7.28.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0"
+ }
+ },
+ "node_modules/@babel/helper-string-parser": {
+ "version": "7.27.1",
+ "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.27.1.tgz",
+ "integrity": "sha512-qMlSxKbpRlAridDExk92nSobyDdpPijUq2DW6oDnUqd0iOGxmQjyqhMIihI9+zv4LPyZdRje2cavWPbCbWm3eA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-validator-identifier": {
+ "version": "7.28.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.28.5.tgz",
+ "integrity": "sha512-qSs4ifwzKJSV39ucNjsvc6WVHs6b7S03sOh2OcHF9UHfVPqWWALUsNUVzhSBiItjRZoLHx7nIarVjqKVusUZ1Q==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-validator-option": {
+ "version": "7.27.1",
+ "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.27.1.tgz",
+ "integrity": "sha512-YvjJow9FxbhFFKDSuFnVCe2WxXk1zWc22fFePVNEaWJEu8IrZVlda6N0uHwzZrUM1il7NC9Mlp4MaJYbYd9JSg==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helpers": {
+ "version": "7.29.2",
+ "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.29.2.tgz",
+ "integrity": "sha512-HoGuUs4sCZNezVEKdVcwqmZN8GoHirLUcLaYVNBK2J0DadGtdcqgr3BCbvH8+XUo4NGjNl3VOtSjEKNzqfFgKw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/template": "^7.28.6",
+ "@babel/types": "^7.29.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/parser": {
+ "version": "7.29.2",
+ "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.29.2.tgz",
+ "integrity": "sha512-4GgRzy/+fsBa72/RZVJmGKPmZu9Byn8o4MoLpmNe1m8ZfYnz5emHLQz3U4gLud6Zwl0RZIcgiLD7Uq7ySFuDLA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/types": "^7.29.0"
+ },
+ "bin": {
+ "parser": "bin/babel-parser.js"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@babel/template": {
+ "version": "7.28.6",
+ "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.28.6.tgz",
+ "integrity": "sha512-YA6Ma2KsCdGb+WC6UpBVFJGXL58MDA6oyONbjyF/+5sBgxY/dwkhLogbMT2GXXyU84/IhRw/2D1Os1B/giz+BQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/code-frame": "^7.28.6",
+ "@babel/parser": "^7.28.6",
+ "@babel/types": "^7.28.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/traverse": {
+ "version": "7.29.0",
+ "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.29.0.tgz",
+ "integrity": "sha512-4HPiQr0X7+waHfyXPZpWPfWL/J7dcN1mx9gL6WdQVMbPnF3+ZhSMs8tCxN7oHddJE9fhNE7+lxdnlyemKfJRuA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/code-frame": "^7.29.0",
+ "@babel/generator": "^7.29.0",
+ "@babel/helper-globals": "^7.28.0",
+ "@babel/parser": "^7.29.0",
+ "@babel/template": "^7.28.6",
+ "@babel/types": "^7.29.0",
+ "debug": "^4.3.1"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/types": {
+ "version": "7.29.0",
+ "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.29.0.tgz",
+ "integrity": "sha512-LwdZHpScM4Qz8Xw2iKSzS+cfglZzJGvofQICy7W7v4caru4EaAmyUuO6BGrbyQ2mYV11W0U8j5mBhd14dd3B0A==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/helper-string-parser": "^7.27.1",
+ "@babel/helper-validator-identifier": "^7.28.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@emnapi/core": {
+ "version": "1.9.2",
+ "resolved": "https://registry.npmjs.org/@emnapi/core/-/core-1.9.2.tgz",
+ "integrity": "sha512-UC+ZhH3XtczQYfOlu3lNEkdW/p4dsJ1r/bP7H8+rhao3TTTMO1ATq/4DdIi23XuGoFY+Cz0JmCbdVl0hz9jZcA==",
+ "license": "MIT",
+ "optional": true,
+ "dependencies": {
+ "@emnapi/wasi-threads": "1.2.1",
+ "tslib": "^2.4.0"
+ }
+ },
+ "node_modules/@emnapi/runtime": {
+ "version": "1.9.2",
+ "resolved": "https://registry.npmjs.org/@emnapi/runtime/-/runtime-1.9.2.tgz",
+ "integrity": "sha512-3U4+MIWHImeyu1wnmVygh5WlgfYDtyf0k8AbLhMFxOipihf6nrWC4syIm/SwEeec0mNSafiiNnMJwbza/Is6Lw==",
+ "license": "MIT",
+ "optional": true,
+ "dependencies": {
+ "tslib": "^2.4.0"
+ }
+ },
+ "node_modules/@emnapi/wasi-threads": {
+ "version": "1.2.1",
+ "resolved": "https://registry.npmjs.org/@emnapi/wasi-threads/-/wasi-threads-1.2.1.tgz",
+ "integrity": "sha512-uTII7OYF+/Mes/MrcIOYp5yOtSMLBWSIoLPpcgwipoiKbli6k322tcoFsxoIIxPDqW01SQGAgko4EzZi2BNv2w==",
+ "license": "MIT",
+ "optional": true,
+ "dependencies": {
+ "tslib": "^2.4.0"
+ }
+ },
+ "node_modules/@eslint-community/eslint-utils": {
+ "version": "4.9.1",
+ "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.9.1.tgz",
+ "integrity": "sha512-phrYmNiYppR7znFEdqgfWHXR6NCkZEK7hwWDHZUjit/2/U0r6XvkDl0SYnoM51Hq7FhCGdLDT6zxCCOY1hexsQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "eslint-visitor-keys": "^3.4.3"
+ },
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ },
+ "funding": {
+ "url": "https://opencollective.com/eslint"
+ },
+ "peerDependencies": {
+ "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0"
+ }
+ },
+ "node_modules/@eslint-community/eslint-utils/node_modules/eslint-visitor-keys": {
+ "version": "3.4.3",
+ "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz",
+ "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ },
+ "funding": {
+ "url": "https://opencollective.com/eslint"
+ }
+ },
+ "node_modules/@eslint-community/regexpp": {
+ "version": "4.12.2",
+ "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.12.2.tgz",
+ "integrity": "sha512-EriSTlt5OC9/7SXkRSCAhfSxxoSUgBm33OH+IkwbdpgoqsSsUg7y3uh+IICI/Qg4BBWr3U2i39RpmycbxMq4ew==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": "^12.0.0 || ^14.0.0 || >=16.0.0"
+ }
+ },
+ "node_modules/@eslint/config-array": {
+ "version": "0.21.2",
+ "resolved": "https://registry.npmjs.org/@eslint/config-array/-/config-array-0.21.2.tgz",
+ "integrity": "sha512-nJl2KGTlrf9GjLimgIru+V/mzgSK0ABCDQRvxw5BjURL7WfH5uoWmizbH7QB6MmnMBd8cIC9uceWnezL1VZWWw==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "dependencies": {
+ "@eslint/object-schema": "^2.1.7",
+ "debug": "^4.3.1",
+ "minimatch": "^3.1.5"
+ },
+ "engines": {
+ "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
+ }
+ },
+ "node_modules/@eslint/config-helpers": {
+ "version": "0.4.2",
+ "resolved": "https://registry.npmjs.org/@eslint/config-helpers/-/config-helpers-0.4.2.tgz",
+ "integrity": "sha512-gBrxN88gOIf3R7ja5K9slwNayVcZgK6SOUORm2uBzTeIEfeVaIhOpCtTox3P6R7o2jLFwLFTLnC7kU/RGcYEgw==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "dependencies": {
+ "@eslint/core": "^0.17.0"
+ },
+ "engines": {
+ "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
+ }
+ },
+ "node_modules/@eslint/core": {
+ "version": "0.17.0",
+ "resolved": "https://registry.npmjs.org/@eslint/core/-/core-0.17.0.tgz",
+ "integrity": "sha512-yL/sLrpmtDaFEiUj1osRP4TI2MDz1AddJL+jZ7KSqvBuliN4xqYY54IfdN8qD8Toa6g1iloph1fxQNkjOxrrpQ==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "dependencies": {
+ "@types/json-schema": "^7.0.15"
+ },
+ "engines": {
+ "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
+ }
+ },
+ "node_modules/@eslint/eslintrc": {
+ "version": "3.3.5",
+ "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-3.3.5.tgz",
+ "integrity": "sha512-4IlJx0X0qftVsN5E+/vGujTRIFtwuLbNsVUe7TO6zYPDR1O6nFwvwhIKEKSrl6dZchmYBITazxKoUYOjdtjlRg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "ajv": "^6.14.0",
+ "debug": "^4.3.2",
+ "espree": "^10.0.1",
+ "globals": "^14.0.0",
+ "ignore": "^5.2.0",
+ "import-fresh": "^3.2.1",
+ "js-yaml": "^4.1.1",
+ "minimatch": "^3.1.5",
+ "strip-json-comments": "^3.1.1"
+ },
+ "engines": {
+ "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
+ },
+ "funding": {
+ "url": "https://opencollective.com/eslint"
+ }
+ },
+ "node_modules/@eslint/eslintrc/node_modules/globals": {
+ "version": "14.0.0",
+ "resolved": "https://registry.npmjs.org/globals/-/globals-14.0.0.tgz",
+ "integrity": "sha512-oahGvuMGQlPw/ivIYBjVSrWAfWLBeku5tpPE2fOPLi+WHffIWbuh2tCjhyQhTBPMf5E9jDEH4FOmTYgYwbKwtQ==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=18"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/@eslint/js": {
+ "version": "9.39.4",
+ "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.39.4.tgz",
+ "integrity": "sha512-nE7DEIchvtiFTwBw4Lfbu59PG+kCofhjsKaCWzxTpt4lfRjRMqG6uMBzKXuEcyXhOHoUp9riAm7/aWYGhXZ9cw==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
+ },
+ "funding": {
+ "url": "https://eslint.org/donate"
+ }
+ },
+ "node_modules/@eslint/object-schema": {
+ "version": "2.1.7",
+ "resolved": "https://registry.npmjs.org/@eslint/object-schema/-/object-schema-2.1.7.tgz",
+ "integrity": "sha512-VtAOaymWVfZcmZbp6E2mympDIHvyjXs/12LqWYjVw6qjrfF+VK+fyG33kChz3nnK+SU5/NeHOqrTEHS8sXO3OA==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "engines": {
+ "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
+ }
+ },
+ "node_modules/@eslint/plugin-kit": {
+ "version": "0.4.1",
+ "resolved": "https://registry.npmjs.org/@eslint/plugin-kit/-/plugin-kit-0.4.1.tgz",
+ "integrity": "sha512-43/qtrDUokr7LJqoF2c3+RInu/t4zfrpYdoSDfYyhg52rwLV6TnOvdG4fXm7IkSB3wErkcmJS9iEhjVtOSEjjA==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "dependencies": {
+ "@eslint/core": "^0.17.0",
+ "levn": "^0.4.1"
+ },
+ "engines": {
+ "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
+ }
+ },
+ "node_modules/@humanfs/core": {
+ "version": "0.19.1",
+ "resolved": "https://registry.npmjs.org/@humanfs/core/-/core-0.19.1.tgz",
+ "integrity": "sha512-5DyQ4+1JEUzejeK1JGICcideyfUbGixgS9jNgex5nqkW+cY7WZhxBigmieN5Qnw9ZosSNVC9KQKyb+GUaGyKUA==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "engines": {
+ "node": ">=18.18.0"
+ }
+ },
+ "node_modules/@humanfs/node": {
+ "version": "0.16.7",
+ "resolved": "https://registry.npmjs.org/@humanfs/node/-/node-0.16.7.tgz",
+ "integrity": "sha512-/zUx+yOsIrG4Y43Eh2peDeKCxlRt/gET6aHfaKpuq267qXdYDFViVHfMaLyygZOnl0kGWxFIgsBy8QFuTLUXEQ==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "dependencies": {
+ "@humanfs/core": "^0.19.1",
+ "@humanwhocodes/retry": "^0.4.0"
+ },
+ "engines": {
+ "node": ">=18.18.0"
+ }
+ },
+ "node_modules/@humanwhocodes/module-importer": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz",
+ "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "engines": {
+ "node": ">=12.22"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/nzakas"
+ }
+ },
+ "node_modules/@humanwhocodes/retry": {
+ "version": "0.4.3",
+ "resolved": "https://registry.npmjs.org/@humanwhocodes/retry/-/retry-0.4.3.tgz",
+ "integrity": "sha512-bV0Tgo9K4hfPCek+aMAn81RppFKv2ySDQeMoSZuvTASywNTnVJCArCZE2FWqpvIatKu7VMRLWlR1EazvVhDyhQ==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "engines": {
+ "node": ">=18.18"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/nzakas"
+ }
+ },
+ "node_modules/@jridgewell/gen-mapping": {
+ "version": "0.3.13",
+ "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.13.tgz",
+ "integrity": "sha512-2kkt/7niJ6MgEPxF0bYdQ6etZaA+fQvDcLKckhy1yIQOzaoKjBBjSj63/aLVjYE3qhRt5dvM+uUyfCg6UKCBbA==",
+ "license": "MIT",
+ "dependencies": {
+ "@jridgewell/sourcemap-codec": "^1.5.0",
+ "@jridgewell/trace-mapping": "^0.3.24"
+ }
+ },
+ "node_modules/@jridgewell/remapping": {
+ "version": "2.3.5",
+ "resolved": "https://registry.npmjs.org/@jridgewell/remapping/-/remapping-2.3.5.tgz",
+ "integrity": "sha512-LI9u/+laYG4Ds1TDKSJW2YPrIlcVYOwi2fUC6xB43lueCjgxV4lffOCZCtYFiH6TNOX+tQKXx97T4IKHbhyHEQ==",
+ "license": "MIT",
+ "dependencies": {
+ "@jridgewell/gen-mapping": "^0.3.5",
+ "@jridgewell/trace-mapping": "^0.3.24"
+ }
+ },
+ "node_modules/@jridgewell/resolve-uri": {
+ "version": "3.1.2",
+ "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz",
+ "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@jridgewell/sourcemap-codec": {
+ "version": "1.5.5",
+ "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.5.5.tgz",
+ "integrity": "sha512-cYQ9310grqxueWbl+WuIUIaiUaDcj7WOq5fVhEljNVgRfOUhY9fy2zTvfoqWsnebh8Sl70VScFbICvJnLKB0Og==",
+ "license": "MIT"
+ },
+ "node_modules/@jridgewell/trace-mapping": {
+ "version": "0.3.31",
+ "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.31.tgz",
+ "integrity": "sha512-zzNR+SdQSDJzc8joaeP8QQoCQr8NuYx2dIIytl1QeBEZHJ9uW6hebsrYgbz8hJwUQao3TWCMtmfV8Nu1twOLAw==",
+ "license": "MIT",
+ "dependencies": {
+ "@jridgewell/resolve-uri": "^3.1.0",
+ "@jridgewell/sourcemap-codec": "^1.4.14"
+ }
+ },
+ "node_modules/@napi-rs/wasm-runtime": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/@napi-rs/wasm-runtime/-/wasm-runtime-1.1.2.tgz",
+ "integrity": "sha512-sNXv5oLJ7ob93xkZ1XnxisYhGYXfaG9f65/ZgYuAu3qt7b3NadcOEhLvx28hv31PgX8SZJRYrAIPQilQmFpLVw==",
+ "license": "MIT",
+ "optional": true,
+ "dependencies": {
+ "@tybys/wasm-util": "^0.10.1"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/Brooooooklyn"
+ },
+ "peerDependencies": {
+ "@emnapi/core": "^1.7.1",
+ "@emnapi/runtime": "^1.7.1"
+ }
+ },
+ "node_modules/@oxc-project/types": {
+ "version": "0.122.0",
+ "resolved": "https://registry.npmjs.org/@oxc-project/types/-/types-0.122.0.tgz",
+ "integrity": "sha512-oLAl5kBpV4w69UtFZ9xqcmTi+GENWOcPF7FCrczTiBbmC0ibXxCwyvZGbO39rCVEuLGAZM84DH0pUIyyv/YJzA==",
+ "license": "MIT",
+ "funding": {
+ "url": "https://github.com/sponsors/Boshen"
+ }
+ },
+ "node_modules/@rolldown/binding-android-arm64": {
+ "version": "1.0.0-rc.12",
+ "resolved": "https://registry.npmjs.org/@rolldown/binding-android-arm64/-/binding-android-arm64-1.0.0-rc.12.tgz",
+ "integrity": "sha512-pv1y2Fv0JybcykuiiD3qBOBdz6RteYojRFY1d+b95WVuzx211CRh+ytI/+9iVyWQ6koTh5dawe4S/yRfOFjgaA==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "android"
+ ],
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ }
+ },
+ "node_modules/@rolldown/binding-darwin-arm64": {
+ "version": "1.0.0-rc.12",
+ "resolved": "https://registry.npmjs.org/@rolldown/binding-darwin-arm64/-/binding-darwin-arm64-1.0.0-rc.12.tgz",
+ "integrity": "sha512-cFYr6zTG/3PXXF3pUO+umXxt1wkRK/0AYT8lDwuqvRC+LuKYWSAQAQZjCWDQpAH172ZV6ieYrNnFzVVcnSflAg==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ }
+ },
+ "node_modules/@rolldown/binding-darwin-x64": {
+ "version": "1.0.0-rc.12",
+ "resolved": "https://registry.npmjs.org/@rolldown/binding-darwin-x64/-/binding-darwin-x64-1.0.0-rc.12.tgz",
+ "integrity": "sha512-ZCsYknnHzeXYps0lGBz8JrF37GpE9bFVefrlmDrAQhOEi4IOIlcoU1+FwHEtyXGx2VkYAvhu7dyBf75EJQffBw==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ }
+ },
+ "node_modules/@rolldown/binding-freebsd-x64": {
+ "version": "1.0.0-rc.12",
+ "resolved": "https://registry.npmjs.org/@rolldown/binding-freebsd-x64/-/binding-freebsd-x64-1.0.0-rc.12.tgz",
+ "integrity": "sha512-dMLeprcVsyJsKolRXyoTH3NL6qtsT0Y2xeuEA8WQJquWFXkEC4bcu1rLZZSnZRMtAqwtrF/Ib9Ddtpa/Gkge9Q==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "freebsd"
+ ],
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ }
+ },
+ "node_modules/@rolldown/binding-linux-arm-gnueabihf": {
+ "version": "1.0.0-rc.12",
+ "resolved": "https://registry.npmjs.org/@rolldown/binding-linux-arm-gnueabihf/-/binding-linux-arm-gnueabihf-1.0.0-rc.12.tgz",
+ "integrity": "sha512-YqWjAgGC/9M1lz3GR1r1rP79nMgo3mQiiA+Hfo+pvKFK1fAJ1bCi0ZQVh8noOqNacuY1qIcfyVfP6HoyBRZ85Q==",
+ "cpu": [
+ "arm"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ }
+ },
+ "node_modules/@rolldown/binding-linux-arm64-gnu": {
+ "version": "1.0.0-rc.12",
+ "resolved": "https://registry.npmjs.org/@rolldown/binding-linux-arm64-gnu/-/binding-linux-arm64-gnu-1.0.0-rc.12.tgz",
+ "integrity": "sha512-/I5AS4cIroLpslsmzXfwbe5OmWvSsrFuEw3mwvbQ1kDxJ822hFHIx+vsN/TAzNVyepI/j/GSzrtCIwQPeKCLIg==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ }
+ },
+ "node_modules/@rolldown/binding-linux-arm64-musl": {
+ "version": "1.0.0-rc.12",
+ "resolved": "https://registry.npmjs.org/@rolldown/binding-linux-arm64-musl/-/binding-linux-arm64-musl-1.0.0-rc.12.tgz",
+ "integrity": "sha512-V6/wZztnBqlx5hJQqNWwFdxIKN0m38p8Jas+VoSfgH54HSj9tKTt1dZvG6JRHcjh6D7TvrJPWFGaY9UBVOaWPw==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ }
+ },
+ "node_modules/@rolldown/binding-linux-ppc64-gnu": {
+ "version": "1.0.0-rc.12",
+ "resolved": "https://registry.npmjs.org/@rolldown/binding-linux-ppc64-gnu/-/binding-linux-ppc64-gnu-1.0.0-rc.12.tgz",
+ "integrity": "sha512-AP3E9BpcUYliZCxa3w5Kwj9OtEVDYK6sVoUzy4vTOJsjPOgdaJZKFmN4oOlX0Wp0RPV2ETfmIra9x1xuayFB7g==",
+ "cpu": [
+ "ppc64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ }
+ },
+ "node_modules/@rolldown/binding-linux-s390x-gnu": {
+ "version": "1.0.0-rc.12",
+ "resolved": "https://registry.npmjs.org/@rolldown/binding-linux-s390x-gnu/-/binding-linux-s390x-gnu-1.0.0-rc.12.tgz",
+ "integrity": "sha512-nWwpvUSPkoFmZo0kQazZYOrT7J5DGOJ/+QHHzjvNlooDZED8oH82Yg67HvehPPLAg5fUff7TfWFHQS8IV1n3og==",
+ "cpu": [
+ "s390x"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ }
+ },
+ "node_modules/@rolldown/binding-linux-x64-gnu": {
+ "version": "1.0.0-rc.12",
+ "resolved": "https://registry.npmjs.org/@rolldown/binding-linux-x64-gnu/-/binding-linux-x64-gnu-1.0.0-rc.12.tgz",
+ "integrity": "sha512-RNrafz5bcwRy+O9e6P8Z/OCAJW/A+qtBczIqVYwTs14pf4iV1/+eKEjdOUta93q2TsT/FI0XYDP3TCky38LMAg==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ }
+ },
+ "node_modules/@rolldown/binding-linux-x64-musl": {
+ "version": "1.0.0-rc.12",
+ "resolved": "https://registry.npmjs.org/@rolldown/binding-linux-x64-musl/-/binding-linux-x64-musl-1.0.0-rc.12.tgz",
+ "integrity": "sha512-Jpw/0iwoKWx3LJ2rc1yjFrj+T7iHZn2JDg1Yny1ma0luviFS4mhAIcd1LFNxK3EYu3DHWCps0ydXQ5i/rrJ2ig==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ }
+ },
+ "node_modules/@rolldown/binding-openharmony-arm64": {
+ "version": "1.0.0-rc.12",
+ "resolved": "https://registry.npmjs.org/@rolldown/binding-openharmony-arm64/-/binding-openharmony-arm64-1.0.0-rc.12.tgz",
+ "integrity": "sha512-vRugONE4yMfVn0+7lUKdKvN4D5YusEiPilaoO2sgUWpCvrncvWgPMzK00ZFFJuiPgLwgFNP5eSiUlv2tfc+lpA==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "openharmony"
+ ],
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ }
+ },
+ "node_modules/@rolldown/binding-wasm32-wasi": {
+ "version": "1.0.0-rc.12",
+ "resolved": "https://registry.npmjs.org/@rolldown/binding-wasm32-wasi/-/binding-wasm32-wasi-1.0.0-rc.12.tgz",
+ "integrity": "sha512-ykGiLr/6kkiHc0XnBfmFJuCjr5ZYKKofkx+chJWDjitX+KsJuAmrzWhwyOMSHzPhzOHOy7u9HlFoa5MoAOJ/Zg==",
+ "cpu": [
+ "wasm32"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "dependencies": {
+ "@napi-rs/wasm-runtime": "^1.1.1"
+ },
+ "engines": {
+ "node": ">=14.0.0"
+ }
+ },
+ "node_modules/@rolldown/binding-win32-arm64-msvc": {
+ "version": "1.0.0-rc.12",
+ "resolved": "https://registry.npmjs.org/@rolldown/binding-win32-arm64-msvc/-/binding-win32-arm64-msvc-1.0.0-rc.12.tgz",
+ "integrity": "sha512-5eOND4duWkwx1AzCxadcOrNeighiLwMInEADT0YM7xeEOOFcovWZCq8dadXgcRHSf3Ulh1kFo/qvzoFiCLOL1Q==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ }
+ },
+ "node_modules/@rolldown/binding-win32-x64-msvc": {
+ "version": "1.0.0-rc.12",
+ "resolved": "https://registry.npmjs.org/@rolldown/binding-win32-x64-msvc/-/binding-win32-x64-msvc-1.0.0-rc.12.tgz",
+ "integrity": "sha512-PyqoipaswDLAZtot351MLhrlrh6lcZPo2LSYE+VDxbVk24LVKAGOuE4hb8xZQmrPAuEtTZW8E6D2zc5EUZX4Lw==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ }
+ },
+ "node_modules/@rolldown/pluginutils": {
+ "version": "1.0.0-rc.7",
+ "resolved": "https://registry.npmjs.org/@rolldown/pluginutils/-/pluginutils-1.0.0-rc.7.tgz",
+ "integrity": "sha512-qujRfC8sFVInYSPPMLQByRh7zhwkGFS4+tyMQ83srV1qrxL4g8E2tyxVVyxd0+8QeBM1mIk9KbWxkegRr76XzA==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/@tailwindcss/node": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@tailwindcss/node/-/node-4.2.2.tgz",
+ "integrity": "sha512-pXS+wJ2gZpVXqFaUEjojq7jzMpTGf8rU6ipJz5ovJV6PUGmlJ+jvIwGrzdHdQ80Sg+wmQxUFuoW1UAAwHNEdFA==",
+ "license": "MIT",
+ "dependencies": {
+ "@jridgewell/remapping": "^2.3.5",
+ "enhanced-resolve": "^5.19.0",
+ "jiti": "^2.6.1",
+ "lightningcss": "1.32.0",
+ "magic-string": "^0.30.21",
+ "source-map-js": "^1.2.1",
+ "tailwindcss": "4.2.2"
+ }
+ },
+ "node_modules/@tailwindcss/oxide": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@tailwindcss/oxide/-/oxide-4.2.2.tgz",
+ "integrity": "sha512-qEUA07+E5kehxYp9BVMpq9E8vnJuBHfJEC0vPC5e7iL/hw7HR61aDKoVoKzrG+QKp56vhNZe4qwkRmMC0zDLvg==",
+ "license": "MIT",
+ "engines": {
+ "node": ">= 20"
+ },
+ "optionalDependencies": {
+ "@tailwindcss/oxide-android-arm64": "4.2.2",
+ "@tailwindcss/oxide-darwin-arm64": "4.2.2",
+ "@tailwindcss/oxide-darwin-x64": "4.2.2",
+ "@tailwindcss/oxide-freebsd-x64": "4.2.2",
+ "@tailwindcss/oxide-linux-arm-gnueabihf": "4.2.2",
+ "@tailwindcss/oxide-linux-arm64-gnu": "4.2.2",
+ "@tailwindcss/oxide-linux-arm64-musl": "4.2.2",
+ "@tailwindcss/oxide-linux-x64-gnu": "4.2.2",
+ "@tailwindcss/oxide-linux-x64-musl": "4.2.2",
+ "@tailwindcss/oxide-wasm32-wasi": "4.2.2",
+ "@tailwindcss/oxide-win32-arm64-msvc": "4.2.2",
+ "@tailwindcss/oxide-win32-x64-msvc": "4.2.2"
+ }
+ },
+ "node_modules/@tailwindcss/oxide-android-arm64": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-android-arm64/-/oxide-android-arm64-4.2.2.tgz",
+ "integrity": "sha512-dXGR1n+P3B6748jZO/SvHZq7qBOqqzQ+yFrXpoOWWALWndF9MoSKAT3Q0fYgAzYzGhxNYOoysRvYlpixRBBoDg==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "android"
+ ],
+ "engines": {
+ "node": ">= 20"
+ }
+ },
+ "node_modules/@tailwindcss/oxide-darwin-arm64": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-darwin-arm64/-/oxide-darwin-arm64-4.2.2.tgz",
+ "integrity": "sha512-iq9Qjr6knfMpZHj55/37ouZeykwbDqF21gPFtfnhCCKGDcPI/21FKC9XdMO/XyBM7qKORx6UIhGgg6jLl7BZlg==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": ">= 20"
+ }
+ },
+ "node_modules/@tailwindcss/oxide-darwin-x64": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-darwin-x64/-/oxide-darwin-x64-4.2.2.tgz",
+ "integrity": "sha512-BlR+2c3nzc8f2G639LpL89YY4bdcIdUmiOOkv2GQv4/4M0vJlpXEa0JXNHhCHU7VWOKWT/CjqHdTP8aUuDJkuw==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": ">= 20"
+ }
+ },
+ "node_modules/@tailwindcss/oxide-freebsd-x64": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-freebsd-x64/-/oxide-freebsd-x64-4.2.2.tgz",
+ "integrity": "sha512-YUqUgrGMSu2CDO82hzlQ5qSb5xmx3RUrke/QgnoEx7KvmRJHQuZHZmZTLSuuHwFf0DJPybFMXMYf+WJdxHy/nQ==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "freebsd"
+ ],
+ "engines": {
+ "node": ">= 20"
+ }
+ },
+ "node_modules/@tailwindcss/oxide-linux-arm-gnueabihf": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-linux-arm-gnueabihf/-/oxide-linux-arm-gnueabihf-4.2.2.tgz",
+ "integrity": "sha512-FPdhvsW6g06T9BWT0qTwiVZYE2WIFo2dY5aCSpjG/S/u1tby+wXoslXS0kl3/KXnULlLr1E3NPRRw0g7t2kgaQ==",
+ "cpu": [
+ "arm"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">= 20"
+ }
+ },
+ "node_modules/@tailwindcss/oxide-linux-arm64-gnu": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-linux-arm64-gnu/-/oxide-linux-arm64-gnu-4.2.2.tgz",
+ "integrity": "sha512-4og1V+ftEPXGttOO7eCmW7VICmzzJWgMx+QXAJRAhjrSjumCwWqMfkDrNu1LXEQzNAwz28NCUpucgQPrR4S2yw==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">= 20"
+ }
+ },
+ "node_modules/@tailwindcss/oxide-linux-arm64-musl": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-linux-arm64-musl/-/oxide-linux-arm64-musl-4.2.2.tgz",
+ "integrity": "sha512-oCfG/mS+/+XRlwNjnsNLVwnMWYH7tn/kYPsNPh+JSOMlnt93mYNCKHYzylRhI51X+TbR+ufNhhKKzm6QkqX8ag==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">= 20"
+ }
+ },
+ "node_modules/@tailwindcss/oxide-linux-x64-gnu": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-linux-x64-gnu/-/oxide-linux-x64-gnu-4.2.2.tgz",
+ "integrity": "sha512-rTAGAkDgqbXHNp/xW0iugLVmX62wOp2PoE39BTCGKjv3Iocf6AFbRP/wZT/kuCxC9QBh9Pu8XPkv/zCZB2mcMg==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">= 20"
+ }
+ },
+ "node_modules/@tailwindcss/oxide-linux-x64-musl": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-linux-x64-musl/-/oxide-linux-x64-musl-4.2.2.tgz",
+ "integrity": "sha512-XW3t3qwbIwiSyRCggeO2zxe3KWaEbM0/kW9e8+0XpBgyKU4ATYzcVSMKteZJ1iukJ3HgHBjbg9P5YPRCVUxlnQ==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">= 20"
+ }
+ },
+ "node_modules/@tailwindcss/oxide-wasm32-wasi": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-wasm32-wasi/-/oxide-wasm32-wasi-4.2.2.tgz",
+ "integrity": "sha512-eKSztKsmEsn1O5lJ4ZAfyn41NfG7vzCg496YiGtMDV86jz1q/irhms5O0VrY6ZwTUkFy/EKG3RfWgxSI3VbZ8Q==",
+ "bundleDependencies": [
+ "@napi-rs/wasm-runtime",
+ "@emnapi/core",
+ "@emnapi/runtime",
+ "@tybys/wasm-util",
+ "@emnapi/wasi-threads",
+ "tslib"
+ ],
+ "cpu": [
+ "wasm32"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "dependencies": {
+ "@emnapi/core": "^1.8.1",
+ "@emnapi/runtime": "^1.8.1",
+ "@emnapi/wasi-threads": "^1.1.0",
+ "@napi-rs/wasm-runtime": "^1.1.1",
+ "@tybys/wasm-util": "^0.10.1",
+ "tslib": "^2.8.1"
+ },
+ "engines": {
+ "node": ">=14.0.0"
+ }
+ },
+ "node_modules/@tailwindcss/oxide-win32-arm64-msvc": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-win32-arm64-msvc/-/oxide-win32-arm64-msvc-4.2.2.tgz",
+ "integrity": "sha512-qPmaQM4iKu5mxpsrWZMOZRgZv1tOZpUm+zdhhQP0VhJfyGGO3aUKdbh3gDZc/dPLQwW4eSqWGrrcWNBZWUWaXQ==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">= 20"
+ }
+ },
+ "node_modules/@tailwindcss/oxide-win32-x64-msvc": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-win32-x64-msvc/-/oxide-win32-x64-msvc-4.2.2.tgz",
+ "integrity": "sha512-1T/37VvI7WyH66b+vqHj/cLwnCxt7Qt3WFu5Q8hk65aOvlwAhs7rAp1VkulBJw/N4tMirXjVnylTR72uI0HGcA==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">= 20"
+ }
+ },
+ "node_modules/@tailwindcss/vite": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@tailwindcss/vite/-/vite-4.2.2.tgz",
+ "integrity": "sha512-mEiF5HO1QqCLXoNEfXVA1Tzo+cYsrqV7w9Juj2wdUFyW07JRenqMG225MvPwr3ZD9N1bFQj46X7r33iHxLUW0w==",
+ "license": "MIT",
+ "dependencies": {
+ "@tailwindcss/node": "4.2.2",
+ "@tailwindcss/oxide": "4.2.2",
+ "tailwindcss": "4.2.2"
+ },
+ "peerDependencies": {
+ "vite": "^5.2.0 || ^6 || ^7 || ^8"
+ }
+ },
+ "node_modules/@tybys/wasm-util": {
+ "version": "0.10.1",
+ "resolved": "https://registry.npmjs.org/@tybys/wasm-util/-/wasm-util-0.10.1.tgz",
+ "integrity": "sha512-9tTaPJLSiejZKx+Bmog4uSubteqTvFrVrURwkmHixBo0G4seD0zUxp98E1DzUBJxLQ3NPwXrGKDiVjwx/DpPsg==",
+ "license": "MIT",
+ "optional": true,
+ "dependencies": {
+ "tslib": "^2.4.0"
+ }
+ },
+ "node_modules/@types/estree": {
+ "version": "1.0.8",
+ "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.8.tgz",
+ "integrity": "sha512-dWHzHa2WqEXI/O1E9OjrocMTKJl2mSrEolh1Iomrv6U+JuNwaHXsXx9bLu5gG7BUWFIN0skIQJQ/L1rIex4X6w==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/@types/json-schema": {
+ "version": "7.0.15",
+ "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.15.tgz",
+ "integrity": "sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/@types/react": {
+ "version": "19.2.14",
+ "resolved": "https://registry.npmjs.org/@types/react/-/react-19.2.14.tgz",
+ "integrity": "sha512-ilcTH/UniCkMdtexkoCN0bI7pMcJDvmQFPvuPvmEaYA/NSfFTAgdUSLAoVjaRJm7+6PvcM+q1zYOwS4wTYMF9w==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "csstype": "^3.2.2"
+ }
+ },
+ "node_modules/@types/react-dom": {
+ "version": "19.2.3",
+ "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-19.2.3.tgz",
+ "integrity": "sha512-jp2L/eY6fn+KgVVQAOqYItbF0VY/YApe5Mz2F0aykSO8gx31bYCZyvSeYxCHKvzHG5eZjc+zyaS5BrBWya2+kQ==",
+ "dev": true,
+ "license": "MIT",
+ "peerDependencies": {
+ "@types/react": "^19.2.0"
+ }
+ },
+ "node_modules/@vitejs/plugin-react": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/@vitejs/plugin-react/-/plugin-react-6.0.1.tgz",
+ "integrity": "sha512-l9X/E3cDb+xY3SWzlG1MOGt2usfEHGMNIaegaUGFsLkb3RCn/k8/TOXBcab+OndDI4TBtktT8/9BwwW8Vi9KUQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@rolldown/pluginutils": "1.0.0-rc.7"
+ },
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ },
+ "peerDependencies": {
+ "@rolldown/plugin-babel": "^0.1.7 || ^0.2.0",
+ "babel-plugin-react-compiler": "^1.0.0",
+ "vite": "^8.0.0"
+ },
+ "peerDependenciesMeta": {
+ "@rolldown/plugin-babel": {
+ "optional": true
+ },
+ "babel-plugin-react-compiler": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/acorn": {
+ "version": "8.16.0",
+ "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.16.0.tgz",
+ "integrity": "sha512-UVJyE9MttOsBQIDKw1skb9nAwQuR5wuGD3+82K6JgJlm/Y+KI92oNsMNGZCYdDsVtRHSak0pcV5Dno5+4jh9sw==",
+ "dev": true,
+ "license": "MIT",
+ "bin": {
+ "acorn": "bin/acorn"
+ },
+ "engines": {
+ "node": ">=0.4.0"
+ }
+ },
+ "node_modules/acorn-jsx": {
+ "version": "5.3.2",
+ "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz",
+ "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==",
+ "dev": true,
+ "license": "MIT",
+ "peerDependencies": {
+ "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0"
+ }
+ },
+ "node_modules/ajv": {
+ "version": "6.14.0",
+ "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.14.0.tgz",
+ "integrity": "sha512-IWrosm/yrn43eiKqkfkHis7QioDleaXQHdDVPKg0FSwwd/DuvyX79TZnFOnYpB7dcsFAMmtFztZuXPDvSePkFw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "fast-deep-equal": "^3.1.1",
+ "fast-json-stable-stringify": "^2.0.0",
+ "json-schema-traverse": "^0.4.1",
+ "uri-js": "^4.2.2"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/epoberezkin"
+ }
+ },
+ "node_modules/ansi-styles": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+ "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "color-convert": "^2.0.1"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/ansi-styles?sponsor=1"
+ }
+ },
+ "node_modules/argparse": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz",
+ "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==",
+ "dev": true,
+ "license": "Python-2.0"
+ },
+ "node_modules/balanced-match": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz",
+ "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/baseline-browser-mapping": {
+ "version": "2.10.14",
+ "resolved": "https://registry.npmjs.org/baseline-browser-mapping/-/baseline-browser-mapping-2.10.14.tgz",
+ "integrity": "sha512-fOVLPAsFTsQfuCkvahZkzq6nf8KvGWanlYoTh0SVA0A/PIUxQGU2AOZAoD95n2gFLVDW/jP6sbGLny95nmEuHA==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "bin": {
+ "baseline-browser-mapping": "dist/cli.cjs"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/brace-expansion": {
+ "version": "1.1.13",
+ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.13.tgz",
+ "integrity": "sha512-9ZLprWS6EENmhEOpjCYW2c8VkmOvckIJZfkr7rBW6dObmfgJ/L1GpSYW5Hpo9lDz4D1+n0Ckz8rU7FwHDQiG/w==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "balanced-match": "^1.0.0",
+ "concat-map": "0.0.1"
+ }
+ },
+ "node_modules/browserslist": {
+ "version": "4.28.2",
+ "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.28.2.tgz",
+ "integrity": "sha512-48xSriZYYg+8qXna9kwqjIVzuQxi+KYWp2+5nCYnYKPTr0LvD89Jqk2Or5ogxz0NUMfIjhh2lIUX/LyX9B4oIg==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "opencollective",
+ "url": "https://opencollective.com/browserslist"
+ },
+ {
+ "type": "tidelift",
+ "url": "https://tidelift.com/funding/github/npm/browserslist"
+ },
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/ai"
+ }
+ ],
+ "license": "MIT",
+ "dependencies": {
+ "baseline-browser-mapping": "^2.10.12",
+ "caniuse-lite": "^1.0.30001782",
+ "electron-to-chromium": "^1.5.328",
+ "node-releases": "^2.0.36",
+ "update-browserslist-db": "^1.2.3"
+ },
+ "bin": {
+ "browserslist": "cli.js"
+ },
+ "engines": {
+ "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7"
+ }
+ },
+ "node_modules/callsites": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz",
+ "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/caniuse-lite": {
+ "version": "1.0.30001785",
+ "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001785.tgz",
+ "integrity": "sha512-blhOL/WNR+Km1RI/LCVAvA73xplXA7ZbjzI4YkMK9pa6T/P3F2GxjNpEkyw5repTw9IvkyrjyHpwjnhZ5FOvYQ==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "opencollective",
+ "url": "https://opencollective.com/browserslist"
+ },
+ {
+ "type": "tidelift",
+ "url": "https://tidelift.com/funding/github/npm/caniuse-lite"
+ },
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/ai"
+ }
+ ],
+ "license": "CC-BY-4.0"
+ },
+ "node_modules/chalk": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+ "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/chalk/chalk?sponsor=1"
+ }
+ },
+ "node_modules/class-variance-authority": {
+ "version": "0.7.1",
+ "resolved": "https://registry.npmjs.org/class-variance-authority/-/class-variance-authority-0.7.1.tgz",
+ "integrity": "sha512-Ka+9Trutv7G8M6WT6SeiRWz792K5qEqIGEGzXKhAE6xOWAY6pPH8U+9IY3oCMv6kqTmLsv7Xh/2w2RigkePMsg==",
+ "license": "Apache-2.0",
+ "dependencies": {
+ "clsx": "^2.1.1"
+ },
+ "funding": {
+ "url": "https://polar.sh/cva"
+ }
+ },
+ "node_modules/clsx": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/clsx/-/clsx-2.1.1.tgz",
+ "integrity": "sha512-eYm0QWBtUrBWZWG0d386OGAw16Z995PiOVo2B7bjWSbHedGl5e0ZWaq65kOGgUSNesEIDkB9ISbTg/JK9dhCZA==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "color-name": "~1.1.4"
+ },
+ "engines": {
+ "node": ">=7.0.0"
+ }
+ },
+ "node_modules/color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/concat-map": {
+ "version": "0.0.1",
+ "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
+ "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/convert-source-map": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz",
+ "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/cross-spawn": {
+ "version": "7.0.6",
+ "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.6.tgz",
+ "integrity": "sha512-uV2QOWP2nWzsy2aMp8aRibhi9dlzF5Hgh5SHaB9OiTGEyDTiJJyx0uy51QXdyWbtAHNua4XJzUKca3OzKUd3vA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "path-key": "^3.1.0",
+ "shebang-command": "^2.0.0",
+ "which": "^2.0.1"
+ },
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/csstype": {
+ "version": "3.2.3",
+ "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.2.3.tgz",
+ "integrity": "sha512-z1HGKcYy2xA8AGQfwrn0PAy+PB7X/GSj3UVJW9qKyn43xWa+gl5nXmU4qqLMRzWVLFC8KusUX8T/0kCiOYpAIQ==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/debug": {
+ "version": "4.4.3",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz",
+ "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "ms": "^2.1.3"
+ },
+ "engines": {
+ "node": ">=6.0"
+ },
+ "peerDependenciesMeta": {
+ "supports-color": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/deep-is": {
+ "version": "0.1.4",
+ "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz",
+ "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/detect-libc": {
+ "version": "2.1.2",
+ "resolved": "https://registry.npmjs.org/detect-libc/-/detect-libc-2.1.2.tgz",
+ "integrity": "sha512-Btj2BOOO83o3WyH59e8MgXsxEQVcarkUOpEYrubB0urwnN10yQ364rsiByU11nZlqWYZm05i/of7io4mzihBtQ==",
+ "license": "Apache-2.0",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/electron-to-chromium": {
+ "version": "1.5.331",
+ "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.5.331.tgz",
+ "integrity": "sha512-IbxXrsTlD3hRodkLnbxAPP4OuJYdWCeM3IOdT+CpcMoIwIoDfCmRpEtSPfwBXxVkg9xmBeY7Lz2Eo2TDn/HC3Q==",
+ "dev": true,
+ "license": "ISC"
+ },
+ "node_modules/enhanced-resolve": {
+ "version": "5.20.1",
+ "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-5.20.1.tgz",
+ "integrity": "sha512-Qohcme7V1inbAfvjItgw0EaxVX5q2rdVEZHRBrEQdRZTssLDGsL8Lwrznl8oQ/6kuTJONLaDcGjkNP247XEhcA==",
+ "license": "MIT",
+ "dependencies": {
+ "graceful-fs": "^4.2.4",
+ "tapable": "^2.3.0"
+ },
+ "engines": {
+ "node": ">=10.13.0"
+ }
+ },
+ "node_modules/escalade": {
+ "version": "3.2.0",
+ "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.2.0.tgz",
+ "integrity": "sha512-WUj2qlxaQtO4g6Pq5c29GTcWGDyd8itL8zTlipgECz3JesAiiOKotd8JU6otB3PACgG6xkJUyVhboMS+bje/jA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/escape-string-regexp": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz",
+ "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/eslint": {
+ "version": "9.39.4",
+ "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.39.4.tgz",
+ "integrity": "sha512-XoMjdBOwe/esVgEvLmNsD3IRHkm7fbKIUGvrleloJXUZgDHig2IPWNniv+GwjyJXzuNqVjlr5+4yVUZjycJwfQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@eslint-community/eslint-utils": "^4.8.0",
+ "@eslint-community/regexpp": "^4.12.1",
+ "@eslint/config-array": "^0.21.2",
+ "@eslint/config-helpers": "^0.4.2",
+ "@eslint/core": "^0.17.0",
+ "@eslint/eslintrc": "^3.3.5",
+ "@eslint/js": "9.39.4",
+ "@eslint/plugin-kit": "^0.4.1",
+ "@humanfs/node": "^0.16.6",
+ "@humanwhocodes/module-importer": "^1.0.1",
+ "@humanwhocodes/retry": "^0.4.2",
+ "@types/estree": "^1.0.6",
+ "ajv": "^6.14.0",
+ "chalk": "^4.0.0",
+ "cross-spawn": "^7.0.6",
+ "debug": "^4.3.2",
+ "escape-string-regexp": "^4.0.0",
+ "eslint-scope": "^8.4.0",
+ "eslint-visitor-keys": "^4.2.1",
+ "espree": "^10.4.0",
+ "esquery": "^1.5.0",
+ "esutils": "^2.0.2",
+ "fast-deep-equal": "^3.1.3",
+ "file-entry-cache": "^8.0.0",
+ "find-up": "^5.0.0",
+ "glob-parent": "^6.0.2",
+ "ignore": "^5.2.0",
+ "imurmurhash": "^0.1.4",
+ "is-glob": "^4.0.0",
+ "json-stable-stringify-without-jsonify": "^1.0.1",
+ "lodash.merge": "^4.6.2",
+ "minimatch": "^3.1.5",
+ "natural-compare": "^1.4.0",
+ "optionator": "^0.9.3"
+ },
+ "bin": {
+ "eslint": "bin/eslint.js"
+ },
+ "engines": {
+ "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
+ },
+ "funding": {
+ "url": "https://eslint.org/donate"
+ },
+ "peerDependencies": {
+ "jiti": "*"
+ },
+ "peerDependenciesMeta": {
+ "jiti": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/eslint-plugin-react-hooks": {
+ "version": "7.0.1",
+ "resolved": "https://registry.npmjs.org/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-7.0.1.tgz",
+ "integrity": "sha512-O0d0m04evaNzEPoSW+59Mezf8Qt0InfgGIBJnpC0h3NH/WjUAR7BIKUfysC6todmtiZ/A0oUVS8Gce0WhBrHsA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/core": "^7.24.4",
+ "@babel/parser": "^7.24.4",
+ "hermes-parser": "^0.25.1",
+ "zod": "^3.25.0 || ^4.0.0",
+ "zod-validation-error": "^3.5.0 || ^4.0.0"
+ },
+ "engines": {
+ "node": ">=18"
+ },
+ "peerDependencies": {
+ "eslint": "^3.0.0 || ^4.0.0 || ^5.0.0 || ^6.0.0 || ^7.0.0 || ^8.0.0-0 || ^9.0.0"
+ }
+ },
+ "node_modules/eslint-plugin-react-refresh": {
+ "version": "0.5.2",
+ "resolved": "https://registry.npmjs.org/eslint-plugin-react-refresh/-/eslint-plugin-react-refresh-0.5.2.tgz",
+ "integrity": "sha512-hmgTH57GfzoTFjVN0yBwTggnsVUF2tcqi7RJZHqi9lIezSs4eFyAMktA68YD4r5kNw1mxyY4dmkyoFDb3FIqrA==",
+ "dev": true,
+ "license": "MIT",
+ "peerDependencies": {
+ "eslint": "^9 || ^10"
+ }
+ },
+ "node_modules/eslint-scope": {
+ "version": "8.4.0",
+ "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-8.4.0.tgz",
+ "integrity": "sha512-sNXOfKCn74rt8RICKMvJS7XKV/Xk9kA7DyJr8mJik3S7Cwgy3qlkkmyS2uQB3jiJg6VNdZd/pDBJu0nvG2NlTg==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "dependencies": {
+ "esrecurse": "^4.3.0",
+ "estraverse": "^5.2.0"
+ },
+ "engines": {
+ "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
+ },
+ "funding": {
+ "url": "https://opencollective.com/eslint"
+ }
+ },
+ "node_modules/eslint-visitor-keys": {
+ "version": "4.2.1",
+ "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-4.2.1.tgz",
+ "integrity": "sha512-Uhdk5sfqcee/9H/rCOJikYz67o0a2Tw2hGRPOG2Y1R2dg7brRe1uG0yaNQDHu+TO/uQPF/5eCapvYSmHUjt7JQ==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "engines": {
+ "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
+ },
+ "funding": {
+ "url": "https://opencollective.com/eslint"
+ }
+ },
+ "node_modules/espree": {
+ "version": "10.4.0",
+ "resolved": "https://registry.npmjs.org/espree/-/espree-10.4.0.tgz",
+ "integrity": "sha512-j6PAQ2uUr79PZhBjP5C5fhl8e39FmRnOjsD5lGnWrFU8i2G776tBK7+nP8KuQUTTyAZUwfQqXAgrVH5MbH9CYQ==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "dependencies": {
+ "acorn": "^8.15.0",
+ "acorn-jsx": "^5.3.2",
+ "eslint-visitor-keys": "^4.2.1"
+ },
+ "engines": {
+ "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
+ },
+ "funding": {
+ "url": "https://opencollective.com/eslint"
+ }
+ },
+ "node_modules/esquery": {
+ "version": "1.7.0",
+ "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.7.0.tgz",
+ "integrity": "sha512-Ap6G0WQwcU/LHsvLwON1fAQX9Zp0A2Y6Y/cJBl9r/JbW90Zyg4/zbG6zzKa2OTALELarYHmKu0GhpM5EO+7T0g==",
+ "dev": true,
+ "license": "BSD-3-Clause",
+ "dependencies": {
+ "estraverse": "^5.1.0"
+ },
+ "engines": {
+ "node": ">=0.10"
+ }
+ },
+ "node_modules/esrecurse": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz",
+ "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "dependencies": {
+ "estraverse": "^5.2.0"
+ },
+ "engines": {
+ "node": ">=4.0"
+ }
+ },
+ "node_modules/estraverse": {
+ "version": "5.3.0",
+ "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz",
+ "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "engines": {
+ "node": ">=4.0"
+ }
+ },
+ "node_modules/esutils": {
+ "version": "2.0.3",
+ "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz",
+ "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/fast-deep-equal": {
+ "version": "3.1.3",
+ "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz",
+ "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/fast-json-stable-stringify": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz",
+ "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/fast-levenshtein": {
+ "version": "2.0.6",
+ "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz",
+ "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/fdir": {
+ "version": "6.5.0",
+ "resolved": "https://registry.npmjs.org/fdir/-/fdir-6.5.0.tgz",
+ "integrity": "sha512-tIbYtZbucOs0BRGqPJkshJUYdL+SDH7dVM8gjy+ERp3WAUjLEFJE+02kanyHtwjWOnwrKYBiwAmM0p4kLJAnXg==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=12.0.0"
+ },
+ "peerDependencies": {
+ "picomatch": "^3 || ^4"
+ },
+ "peerDependenciesMeta": {
+ "picomatch": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/file-entry-cache": {
+ "version": "8.0.0",
+ "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-8.0.0.tgz",
+ "integrity": "sha512-XXTUwCvisa5oacNGRP9SfNtYBNAMi+RPwBFmblZEF7N7swHYQS6/Zfk7SRwx4D5j3CH211YNRco1DEMNVfZCnQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "flat-cache": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=16.0.0"
+ }
+ },
+ "node_modules/find-up": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz",
+ "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "locate-path": "^6.0.0",
+ "path-exists": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/flat-cache": {
+ "version": "4.0.1",
+ "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-4.0.1.tgz",
+ "integrity": "sha512-f7ccFPK3SXFHpx15UIGyRJ/FJQctuKZ0zVuN3frBo4HnK3cay9VEW0R6yPYFHC0AgqhukPzKjq22t5DmAyqGyw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "flatted": "^3.2.9",
+ "keyv": "^4.5.4"
+ },
+ "engines": {
+ "node": ">=16"
+ }
+ },
+ "node_modules/flatted": {
+ "version": "3.4.2",
+ "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.4.2.tgz",
+ "integrity": "sha512-PjDse7RzhcPkIJwy5t7KPWQSZ9cAbzQXcafsetQoD7sOJRQlGikNbx7yZp2OotDnJyrDcbyRq3Ttb18iYOqkxA==",
+ "dev": true,
+ "license": "ISC"
+ },
+ "node_modules/fsevents": {
+ "version": "2.3.3",
+ "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz",
+ "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==",
+ "hasInstallScript": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": "^8.16.0 || ^10.6.0 || >=11.0.0"
+ }
+ },
+ "node_modules/gensync": {
+ "version": "1.0.0-beta.2",
+ "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz",
+ "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/glob-parent": {
+ "version": "6.0.2",
+ "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz",
+ "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==",
+ "dev": true,
+ "license": "ISC",
+ "dependencies": {
+ "is-glob": "^4.0.3"
+ },
+ "engines": {
+ "node": ">=10.13.0"
+ }
+ },
+ "node_modules/globals": {
+ "version": "17.4.0",
+ "resolved": "https://registry.npmjs.org/globals/-/globals-17.4.0.tgz",
+ "integrity": "sha512-hjrNztw/VajQwOLsMNT1cbJiH2muO3OROCHnbehc8eY5JyD2gqz4AcMHPqgaOR59DjgUjYAYLeH699g/eWi2jw==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=18"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/graceful-fs": {
+ "version": "4.2.11",
+ "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz",
+ "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==",
+ "license": "ISC"
+ },
+ "node_modules/has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/hermes-estree": {
+ "version": "0.25.1",
+ "resolved": "https://registry.npmjs.org/hermes-estree/-/hermes-estree-0.25.1.tgz",
+ "integrity": "sha512-0wUoCcLp+5Ev5pDW2OriHC2MJCbwLwuRx+gAqMTOkGKJJiBCLjtrvy4PWUGn6MIVefecRpzoOZ/UV6iGdOr+Cw==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/hermes-parser": {
+ "version": "0.25.1",
+ "resolved": "https://registry.npmjs.org/hermes-parser/-/hermes-parser-0.25.1.tgz",
+ "integrity": "sha512-6pEjquH3rqaI6cYAXYPcz9MS4rY6R4ngRgrgfDshRptUZIc3lw0MCIJIGDj9++mfySOuPTHB4nrSW99BCvOPIA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "hermes-estree": "0.25.1"
+ }
+ },
+ "node_modules/ignore": {
+ "version": "5.3.2",
+ "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.2.tgz",
+ "integrity": "sha512-hsBTNUqQTDwkWtcdYI2i06Y/nUBEsNEDJKjWdigLvegy8kDuJAS8uRlpkkcQpyEXL0Z/pjDy5HBmMjRCJ2gq+g==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">= 4"
+ }
+ },
+ "node_modules/import-fresh": {
+ "version": "3.3.1",
+ "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.1.tgz",
+ "integrity": "sha512-TR3KfrTZTYLPB6jUjfx6MF9WcWrHL9su5TObK4ZkYgBdWKPOFoSoQIdEuTuR82pmtxH2spWG9h6etwfr1pLBqQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "parent-module": "^1.0.0",
+ "resolve-from": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=6"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/imurmurhash": {
+ "version": "0.1.4",
+ "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz",
+ "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=0.8.19"
+ }
+ },
+ "node_modules/is-extglob": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz",
+ "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/is-glob": {
+ "version": "4.0.3",
+ "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz",
+ "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "is-extglob": "^2.1.1"
+ },
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/isexe": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz",
+ "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==",
+ "dev": true,
+ "license": "ISC"
+ },
+ "node_modules/jiti": {
+ "version": "2.6.1",
+ "resolved": "https://registry.npmjs.org/jiti/-/jiti-2.6.1.tgz",
+ "integrity": "sha512-ekilCSN1jwRvIbgeg/57YFh8qQDNbwDb9xT/qu2DAHbFFZUicIl4ygVaAvzveMhMVr3LnpSKTNnwt8PoOfmKhQ==",
+ "license": "MIT",
+ "bin": {
+ "jiti": "lib/jiti-cli.mjs"
+ }
+ },
+ "node_modules/js-tokens": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz",
+ "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/js-yaml": {
+ "version": "4.1.1",
+ "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.1.tgz",
+ "integrity": "sha512-qQKT4zQxXl8lLwBtHMWwaTcGfFOZviOJet3Oy/xmGk2gZH677CJM9EvtfdSkgWcATZhj/55JZ0rmy3myCT5lsA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "argparse": "^2.0.1"
+ },
+ "bin": {
+ "js-yaml": "bin/js-yaml.js"
+ }
+ },
+ "node_modules/jsesc": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-3.1.0.tgz",
+ "integrity": "sha512-/sM3dO2FOzXjKQhJuo0Q173wf2KOo8t4I8vHy6lF9poUp7bKT0/NHE8fPX23PwfhnykfqnC2xRxOnVw5XuGIaA==",
+ "dev": true,
+ "license": "MIT",
+ "bin": {
+ "jsesc": "bin/jsesc"
+ },
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/json-buffer": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz",
+ "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/json-schema-traverse": {
+ "version": "0.4.1",
+ "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz",
+ "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/json-stable-stringify-without-jsonify": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz",
+ "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/json5": {
+ "version": "2.2.3",
+ "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz",
+ "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==",
+ "dev": true,
+ "license": "MIT",
+ "bin": {
+ "json5": "lib/cli.js"
+ },
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/keyv": {
+ "version": "4.5.4",
+ "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz",
+ "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "json-buffer": "3.0.1"
+ }
+ },
+ "node_modules/levn": {
+ "version": "0.4.1",
+ "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz",
+ "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "prelude-ls": "^1.2.1",
+ "type-check": "~0.4.0"
+ },
+ "engines": {
+ "node": ">= 0.8.0"
+ }
+ },
+ "node_modules/lightningcss": {
+ "version": "1.32.0",
+ "resolved": "https://registry.npmjs.org/lightningcss/-/lightningcss-1.32.0.tgz",
+ "integrity": "sha512-NXYBzinNrblfraPGyrbPoD19C1h9lfI/1mzgWYvXUTe414Gz/X1FD2XBZSZM7rRTrMA8JL3OtAaGifrIKhQ5yQ==",
+ "license": "MPL-2.0",
+ "dependencies": {
+ "detect-libc": "^2.0.3"
+ },
+ "engines": {
+ "node": ">= 12.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/parcel"
+ },
+ "optionalDependencies": {
+ "lightningcss-android-arm64": "1.32.0",
+ "lightningcss-darwin-arm64": "1.32.0",
+ "lightningcss-darwin-x64": "1.32.0",
+ "lightningcss-freebsd-x64": "1.32.0",
+ "lightningcss-linux-arm-gnueabihf": "1.32.0",
+ "lightningcss-linux-arm64-gnu": "1.32.0",
+ "lightningcss-linux-arm64-musl": "1.32.0",
+ "lightningcss-linux-x64-gnu": "1.32.0",
+ "lightningcss-linux-x64-musl": "1.32.0",
+ "lightningcss-win32-arm64-msvc": "1.32.0",
+ "lightningcss-win32-x64-msvc": "1.32.0"
+ }
+ },
+ "node_modules/lightningcss-android-arm64": {
+ "version": "1.32.0",
+ "resolved": "https://registry.npmjs.org/lightningcss-android-arm64/-/lightningcss-android-arm64-1.32.0.tgz",
+ "integrity": "sha512-YK7/ClTt4kAK0vo6w3X+Pnm0D2cf2vPHbhOXdoNti1Ga0al1P4TBZhwjATvjNwLEBCnKvjJc2jQgHXH0NEwlAg==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MPL-2.0",
+ "optional": true,
+ "os": [
+ "android"
+ ],
+ "engines": {
+ "node": ">= 12.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/parcel"
+ }
+ },
+ "node_modules/lightningcss-darwin-arm64": {
+ "version": "1.32.0",
+ "resolved": "https://registry.npmjs.org/lightningcss-darwin-arm64/-/lightningcss-darwin-arm64-1.32.0.tgz",
+ "integrity": "sha512-RzeG9Ju5bag2Bv1/lwlVJvBE3q6TtXskdZLLCyfg5pt+HLz9BqlICO7LZM7VHNTTn/5PRhHFBSjk5lc4cmscPQ==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MPL-2.0",
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": ">= 12.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/parcel"
+ }
+ },
+ "node_modules/lightningcss-darwin-x64": {
+ "version": "1.32.0",
+ "resolved": "https://registry.npmjs.org/lightningcss-darwin-x64/-/lightningcss-darwin-x64-1.32.0.tgz",
+ "integrity": "sha512-U+QsBp2m/s2wqpUYT/6wnlagdZbtZdndSmut/NJqlCcMLTWp5muCrID+K5UJ6jqD2BFshejCYXniPDbNh73V8w==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MPL-2.0",
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": ">= 12.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/parcel"
+ }
+ },
+ "node_modules/lightningcss-freebsd-x64": {
+ "version": "1.32.0",
+ "resolved": "https://registry.npmjs.org/lightningcss-freebsd-x64/-/lightningcss-freebsd-x64-1.32.0.tgz",
+ "integrity": "sha512-JCTigedEksZk3tHTTthnMdVfGf61Fky8Ji2E4YjUTEQX14xiy/lTzXnu1vwiZe3bYe0q+SpsSH/CTeDXK6WHig==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MPL-2.0",
+ "optional": true,
+ "os": [
+ "freebsd"
+ ],
+ "engines": {
+ "node": ">= 12.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/parcel"
+ }
+ },
+ "node_modules/lightningcss-linux-arm-gnueabihf": {
+ "version": "1.32.0",
+ "resolved": "https://registry.npmjs.org/lightningcss-linux-arm-gnueabihf/-/lightningcss-linux-arm-gnueabihf-1.32.0.tgz",
+ "integrity": "sha512-x6rnnpRa2GL0zQOkt6rts3YDPzduLpWvwAF6EMhXFVZXD4tPrBkEFqzGowzCsIWsPjqSK+tyNEODUBXeeVHSkw==",
+ "cpu": [
+ "arm"
+ ],
+ "license": "MPL-2.0",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">= 12.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/parcel"
+ }
+ },
+ "node_modules/lightningcss-linux-arm64-gnu": {
+ "version": "1.32.0",
+ "resolved": "https://registry.npmjs.org/lightningcss-linux-arm64-gnu/-/lightningcss-linux-arm64-gnu-1.32.0.tgz",
+ "integrity": "sha512-0nnMyoyOLRJXfbMOilaSRcLH3Jw5z9HDNGfT/gwCPgaDjnx0i8w7vBzFLFR1f6CMLKF8gVbebmkUN3fa/kQJpQ==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MPL-2.0",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">= 12.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/parcel"
+ }
+ },
+ "node_modules/lightningcss-linux-arm64-musl": {
+ "version": "1.32.0",
+ "resolved": "https://registry.npmjs.org/lightningcss-linux-arm64-musl/-/lightningcss-linux-arm64-musl-1.32.0.tgz",
+ "integrity": "sha512-UpQkoenr4UJEzgVIYpI80lDFvRmPVg6oqboNHfoH4CQIfNA+HOrZ7Mo7KZP02dC6LjghPQJeBsvXhJod/wnIBg==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MPL-2.0",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">= 12.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/parcel"
+ }
+ },
+ "node_modules/lightningcss-linux-x64-gnu": {
+ "version": "1.32.0",
+ "resolved": "https://registry.npmjs.org/lightningcss-linux-x64-gnu/-/lightningcss-linux-x64-gnu-1.32.0.tgz",
+ "integrity": "sha512-V7Qr52IhZmdKPVr+Vtw8o+WLsQJYCTd8loIfpDaMRWGUZfBOYEJeyJIkqGIDMZPwPx24pUMfwSxxI8phr/MbOA==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MPL-2.0",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">= 12.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/parcel"
+ }
+ },
+ "node_modules/lightningcss-linux-x64-musl": {
+ "version": "1.32.0",
+ "resolved": "https://registry.npmjs.org/lightningcss-linux-x64-musl/-/lightningcss-linux-x64-musl-1.32.0.tgz",
+ "integrity": "sha512-bYcLp+Vb0awsiXg/80uCRezCYHNg1/l3mt0gzHnWV9XP1W5sKa5/TCdGWaR/zBM2PeF/HbsQv/j2URNOiVuxWg==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MPL-2.0",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">= 12.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/parcel"
+ }
+ },
+ "node_modules/lightningcss-win32-arm64-msvc": {
+ "version": "1.32.0",
+ "resolved": "https://registry.npmjs.org/lightningcss-win32-arm64-msvc/-/lightningcss-win32-arm64-msvc-1.32.0.tgz",
+ "integrity": "sha512-8SbC8BR40pS6baCM8sbtYDSwEVQd4JlFTOlaD3gWGHfThTcABnNDBda6eTZeqbofalIJhFx0qKzgHJmcPTnGdw==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MPL-2.0",
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">= 12.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/parcel"
+ }
+ },
+ "node_modules/lightningcss-win32-x64-msvc": {
+ "version": "1.32.0",
+ "resolved": "https://registry.npmjs.org/lightningcss-win32-x64-msvc/-/lightningcss-win32-x64-msvc-1.32.0.tgz",
+ "integrity": "sha512-Amq9B/SoZYdDi1kFrojnoqPLxYhQ4Wo5XiL8EVJrVsB8ARoC1PWW6VGtT0WKCemjy8aC+louJnjS7U18x3b06Q==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MPL-2.0",
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">= 12.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/parcel"
+ }
+ },
+ "node_modules/locate-path": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz",
+ "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "p-locate": "^5.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/lodash.merge": {
+ "version": "4.6.2",
+ "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz",
+ "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/lru-cache": {
+ "version": "5.1.1",
+ "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz",
+ "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==",
+ "dev": true,
+ "license": "ISC",
+ "dependencies": {
+ "yallist": "^3.0.2"
+ }
+ },
+ "node_modules/lucide-react": {
+ "version": "1.7.0",
+ "resolved": "https://registry.npmjs.org/lucide-react/-/lucide-react-1.7.0.tgz",
+ "integrity": "sha512-yI7BeItCLZJTXikmK4KNUGCKoGzSvbKlfCvw44bU4fXAL6v3gYS4uHD1jzsLkfwODYwI6Drw5Tu9Z5ulDe0TSg==",
+ "license": "ISC",
+ "peerDependencies": {
+ "react": "^16.5.1 || ^17.0.0 || ^18.0.0 || ^19.0.0"
+ }
+ },
+ "node_modules/magic-string": {
+ "version": "0.30.21",
+ "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.30.21.tgz",
+ "integrity": "sha512-vd2F4YUyEXKGcLHoq+TEyCjxueSeHnFxyyjNp80yg0XV4vUhnDer/lvvlqM/arB5bXQN5K2/3oinyCRyx8T2CQ==",
+ "license": "MIT",
+ "dependencies": {
+ "@jridgewell/sourcemap-codec": "^1.5.5"
+ }
+ },
+ "node_modules/minimatch": {
+ "version": "3.1.5",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.5.tgz",
+ "integrity": "sha512-VgjWUsnnT6n+NUk6eZq77zeFdpW2LWDzP6zFGrCbHXiYNul5Dzqk2HHQ5uFH2DNW5Xbp8+jVzaeNt94ssEEl4w==",
+ "dev": true,
+ "license": "ISC",
+ "dependencies": {
+ "brace-expansion": "^1.1.7"
+ },
+ "engines": {
+ "node": "*"
+ }
+ },
+ "node_modules/ms": {
+ "version": "2.1.3",
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",
+ "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/nanoid": {
+ "version": "3.3.11",
+ "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.11.tgz",
+ "integrity": "sha512-N8SpfPUnUp1bK+PMYW8qSWdl9U+wwNWI4QKxOYDy9JAro3WMX7p2OeVRF9v+347pnakNevPmiHhNmZ2HbFA76w==",
+ "funding": [
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/ai"
+ }
+ ],
+ "license": "MIT",
+ "bin": {
+ "nanoid": "bin/nanoid.cjs"
+ },
+ "engines": {
+ "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1"
+ }
+ },
+ "node_modules/natural-compare": {
+ "version": "1.4.0",
+ "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz",
+ "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/node-releases": {
+ "version": "2.0.37",
+ "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.37.tgz",
+ "integrity": "sha512-1h5gKZCF+pO/o3Iqt5Jp7wc9rH3eJJ0+nh/CIoiRwjRxde/hAHyLPXYN4V3CqKAbiZPSeJFSWHmJsbkicta0Eg==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/optionator": {
+ "version": "0.9.4",
+ "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.4.tgz",
+ "integrity": "sha512-6IpQ7mKUxRcZNLIObR0hz7lxsapSSIYNZJwXPGeF0mTVqGKFIXj1DQcMoT22S3ROcLyY/rz0PWaWZ9ayWmad9g==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "deep-is": "^0.1.3",
+ "fast-levenshtein": "^2.0.6",
+ "levn": "^0.4.1",
+ "prelude-ls": "^1.2.1",
+ "type-check": "^0.4.0",
+ "word-wrap": "^1.2.5"
+ },
+ "engines": {
+ "node": ">= 0.8.0"
+ }
+ },
+ "node_modules/p-limit": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz",
+ "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "yocto-queue": "^0.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/p-locate": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz",
+ "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "p-limit": "^3.0.2"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/parent-module": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz",
+ "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "callsites": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/path-exists": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz",
+ "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/path-key": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz",
+ "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/picocolors": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.1.1.tgz",
+ "integrity": "sha512-xceH2snhtb5M9liqDsmEw56le376mTZkEX/jEb/RxNFyegNul7eNslCXP9FDj/Lcu0X8KEyMceP2ntpaHrDEVA==",
+ "license": "ISC"
+ },
+ "node_modules/picomatch": {
+ "version": "4.0.4",
+ "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-4.0.4.tgz",
+ "integrity": "sha512-QP88BAKvMam/3NxH6vj2o21R6MjxZUAd6nlwAS/pnGvN9IVLocLHxGYIzFhg6fUQ+5th6P4dv4eW9jX3DSIj7A==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=12"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/jonschlinkert"
+ }
+ },
+ "node_modules/postcss": {
+ "version": "8.5.8",
+ "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.5.8.tgz",
+ "integrity": "sha512-OW/rX8O/jXnm82Ey1k44pObPtdblfiuWnrd8X7GJ7emImCOstunGbXUpp7HdBrFQX6rJzn3sPT397Wp5aCwCHg==",
+ "funding": [
+ {
+ "type": "opencollective",
+ "url": "https://opencollective.com/postcss/"
+ },
+ {
+ "type": "tidelift",
+ "url": "https://tidelift.com/funding/github/npm/postcss"
+ },
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/ai"
+ }
+ ],
+ "license": "MIT",
+ "dependencies": {
+ "nanoid": "^3.3.11",
+ "picocolors": "^1.1.1",
+ "source-map-js": "^1.2.1"
+ },
+ "engines": {
+ "node": "^10 || ^12 || >=14"
+ }
+ },
+ "node_modules/prelude-ls": {
+ "version": "1.2.1",
+ "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz",
+ "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">= 0.8.0"
+ }
+ },
+ "node_modules/punycode": {
+ "version": "2.3.1",
+ "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz",
+ "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/react": {
+ "version": "19.2.4",
+ "resolved": "https://registry.npmjs.org/react/-/react-19.2.4.tgz",
+ "integrity": "sha512-9nfp2hYpCwOjAN+8TZFGhtWEwgvWHXqESH8qT89AT/lWklpLON22Lc8pEtnpsZz7VmawabSU0gCjnj8aC0euHQ==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/react-dom": {
+ "version": "19.2.4",
+ "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-19.2.4.tgz",
+ "integrity": "sha512-AXJdLo8kgMbimY95O2aKQqsz2iWi9jMgKJhRBAxECE4IFxfcazB2LmzloIoibJI3C12IlY20+KFaLv+71bUJeQ==",
+ "license": "MIT",
+ "dependencies": {
+ "scheduler": "^0.27.0"
+ },
+ "peerDependencies": {
+ "react": "^19.2.4"
+ }
+ },
+ "node_modules/resolve-from": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz",
+ "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "node_modules/rolldown": {
+ "version": "1.0.0-rc.12",
+ "resolved": "https://registry.npmjs.org/rolldown/-/rolldown-1.0.0-rc.12.tgz",
+ "integrity": "sha512-yP4USLIMYrwpPHEFB5JGH1uxhcslv6/hL0OyvTuY+3qlOSJvZ7ntYnoWpehBxufkgN0cvXxppuTu5hHa/zPh+A==",
+ "license": "MIT",
+ "dependencies": {
+ "@oxc-project/types": "=0.122.0",
+ "@rolldown/pluginutils": "1.0.0-rc.12"
+ },
+ "bin": {
+ "rolldown": "bin/cli.mjs"
+ },
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ },
+ "optionalDependencies": {
+ "@rolldown/binding-android-arm64": "1.0.0-rc.12",
+ "@rolldown/binding-darwin-arm64": "1.0.0-rc.12",
+ "@rolldown/binding-darwin-x64": "1.0.0-rc.12",
+ "@rolldown/binding-freebsd-x64": "1.0.0-rc.12",
+ "@rolldown/binding-linux-arm-gnueabihf": "1.0.0-rc.12",
+ "@rolldown/binding-linux-arm64-gnu": "1.0.0-rc.12",
+ "@rolldown/binding-linux-arm64-musl": "1.0.0-rc.12",
+ "@rolldown/binding-linux-ppc64-gnu": "1.0.0-rc.12",
+ "@rolldown/binding-linux-s390x-gnu": "1.0.0-rc.12",
+ "@rolldown/binding-linux-x64-gnu": "1.0.0-rc.12",
+ "@rolldown/binding-linux-x64-musl": "1.0.0-rc.12",
+ "@rolldown/binding-openharmony-arm64": "1.0.0-rc.12",
+ "@rolldown/binding-wasm32-wasi": "1.0.0-rc.12",
+ "@rolldown/binding-win32-arm64-msvc": "1.0.0-rc.12",
+ "@rolldown/binding-win32-x64-msvc": "1.0.0-rc.12"
+ }
+ },
+ "node_modules/rolldown/node_modules/@rolldown/pluginutils": {
+ "version": "1.0.0-rc.12",
+ "resolved": "https://registry.npmjs.org/@rolldown/pluginutils/-/pluginutils-1.0.0-rc.12.tgz",
+ "integrity": "sha512-HHMwmarRKvoFsJorqYlFeFRzXZqCt2ETQlEDOb9aqssrnVBB1/+xgTGtuTrIk5vzLNX1MjMtTf7W9z3tsSbrxw==",
+ "license": "MIT"
+ },
+ "node_modules/scheduler": {
+ "version": "0.27.0",
+ "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.27.0.tgz",
+ "integrity": "sha512-eNv+WrVbKu1f3vbYJT/xtiF5syA5HPIMtf9IgY/nKg0sWqzAUEvqY/xm7OcZc/qafLx/iO9FgOmeSAp4v5ti/Q==",
+ "license": "MIT"
+ },
+ "node_modules/semver": {
+ "version": "6.3.1",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz",
+ "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==",
+ "dev": true,
+ "license": "ISC",
+ "bin": {
+ "semver": "bin/semver.js"
+ }
+ },
+ "node_modules/shebang-command": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz",
+ "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "shebang-regex": "^3.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/shebang-regex": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz",
+ "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/source-map-js": {
+ "version": "1.2.1",
+ "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.2.1.tgz",
+ "integrity": "sha512-UXWMKhLOwVKb728IUtQPXxfYU+usdybtUrK/8uGE8CQMvrhOpwvzDBwj0QhSL7MQc7vIsISBG8VQ8+IDQxpfQA==",
+ "license": "BSD-3-Clause",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/strip-json-comments": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz",
+ "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/supports-color": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+ "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "has-flag": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/tailwind-merge": {
+ "version": "3.5.0",
+ "resolved": "https://registry.npmjs.org/tailwind-merge/-/tailwind-merge-3.5.0.tgz",
+ "integrity": "sha512-I8K9wewnVDkL1NTGoqWmVEIlUcB9gFriAEkXkfCjX5ib8ezGxtR3xD7iZIxrfArjEsH7F1CHD4RFUtxefdqV/A==",
+ "license": "MIT",
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/dcastil"
+ }
+ },
+ "node_modules/tailwindcss": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/tailwindcss/-/tailwindcss-4.2.2.tgz",
+ "integrity": "sha512-KWBIxs1Xb6NoLdMVqhbhgwZf2PGBpPEiwOqgI4pFIYbNTfBXiKYyWoTsXgBQ9WFg/OlhnvHaY+AEpW7wSmFo2Q==",
+ "license": "MIT"
+ },
+ "node_modules/tapable": {
+ "version": "2.3.2",
+ "resolved": "https://registry.npmjs.org/tapable/-/tapable-2.3.2.tgz",
+ "integrity": "sha512-1MOpMXuhGzGL5TTCZFItxCc0AARf1EZFQkGqMm7ERKj8+Hgr5oLvJOVFcC+lRmR8hCe2S3jC4T5D7Vg/d7/fhA==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=6"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/webpack"
+ }
+ },
+ "node_modules/tinyglobby": {
+ "version": "0.2.15",
+ "resolved": "https://registry.npmjs.org/tinyglobby/-/tinyglobby-0.2.15.tgz",
+ "integrity": "sha512-j2Zq4NyQYG5XMST4cbs02Ak8iJUdxRM0XI5QyxXuZOzKOINmWurp3smXu3y5wDcJrptwpSjgXHzIQxR0omXljQ==",
+ "license": "MIT",
+ "dependencies": {
+ "fdir": "^6.5.0",
+ "picomatch": "^4.0.3"
+ },
+ "engines": {
+ "node": ">=12.0.0"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/SuperchupuDev"
+ }
+ },
+ "node_modules/tslib": {
+ "version": "2.8.1",
+ "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.8.1.tgz",
+ "integrity": "sha512-oJFu94HQb+KVduSUQL7wnpmqnfmLsOA/nAh6b6EH0wCEoK0/mPeXU6c3wKDV83MkOuHPRHtSXKKU99IBazS/2w==",
+ "license": "0BSD",
+ "optional": true
+ },
+ "node_modules/type-check": {
+ "version": "0.4.0",
+ "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz",
+ "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "prelude-ls": "^1.2.1"
+ },
+ "engines": {
+ "node": ">= 0.8.0"
+ }
+ },
+ "node_modules/update-browserslist-db": {
+ "version": "1.2.3",
+ "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.2.3.tgz",
+ "integrity": "sha512-Js0m9cx+qOgDxo0eMiFGEueWztz+d4+M3rGlmKPT+T4IS/jP4ylw3Nwpu6cpTTP8R1MAC1kF4VbdLt3ARf209w==",
+ "dev": true,
+ "funding": [
+ {
+ "type": "opencollective",
+ "url": "https://opencollective.com/browserslist"
+ },
+ {
+ "type": "tidelift",
+ "url": "https://tidelift.com/funding/github/npm/browserslist"
+ },
+ {
+ "type": "github",
+ "url": "https://github.com/sponsors/ai"
+ }
+ ],
+ "license": "MIT",
+ "dependencies": {
+ "escalade": "^3.2.0",
+ "picocolors": "^1.1.1"
+ },
+ "bin": {
+ "update-browserslist-db": "cli.js"
+ },
+ "peerDependencies": {
+ "browserslist": ">= 4.21.0"
+ }
+ },
+ "node_modules/uri-js": {
+ "version": "4.4.1",
+ "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz",
+ "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "dependencies": {
+ "punycode": "^2.1.0"
+ }
+ },
+ "node_modules/vite": {
+ "version": "8.0.3",
+ "resolved": "https://registry.npmjs.org/vite/-/vite-8.0.3.tgz",
+ "integrity": "sha512-B9ifbFudT1TFhfltfaIPgjo9Z3mDynBTJSUYxTjOQruf/zHH+ezCQKcoqO+h7a9Pw9Nm/OtlXAiGT1axBgwqrQ==",
+ "license": "MIT",
+ "dependencies": {
+ "lightningcss": "^1.32.0",
+ "picomatch": "^4.0.4",
+ "postcss": "^8.5.8",
+ "rolldown": "1.0.0-rc.12",
+ "tinyglobby": "^0.2.15"
+ },
+ "bin": {
+ "vite": "bin/vite.js"
+ },
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ },
+ "funding": {
+ "url": "https://github.com/vitejs/vite?sponsor=1"
+ },
+ "optionalDependencies": {
+ "fsevents": "~2.3.3"
+ },
+ "peerDependencies": {
+ "@types/node": "^20.19.0 || >=22.12.0",
+ "@vitejs/devtools": "^0.1.0",
+ "esbuild": "^0.27.0",
+ "jiti": ">=1.21.0",
+ "less": "^4.0.0",
+ "sass": "^1.70.0",
+ "sass-embedded": "^1.70.0",
+ "stylus": ">=0.54.8",
+ "sugarss": "^5.0.0",
+ "terser": "^5.16.0",
+ "tsx": "^4.8.1",
+ "yaml": "^2.4.2"
+ },
+ "peerDependenciesMeta": {
+ "@types/node": {
+ "optional": true
+ },
+ "@vitejs/devtools": {
+ "optional": true
+ },
+ "esbuild": {
+ "optional": true
+ },
+ "jiti": {
+ "optional": true
+ },
+ "less": {
+ "optional": true
+ },
+ "sass": {
+ "optional": true
+ },
+ "sass-embedded": {
+ "optional": true
+ },
+ "stylus": {
+ "optional": true
+ },
+ "sugarss": {
+ "optional": true
+ },
+ "terser": {
+ "optional": true
+ },
+ "tsx": {
+ "optional": true
+ },
+ "yaml": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/which": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz",
+ "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==",
+ "dev": true,
+ "license": "ISC",
+ "dependencies": {
+ "isexe": "^2.0.0"
+ },
+ "bin": {
+ "node-which": "bin/node-which"
+ },
+ "engines": {
+ "node": ">= 8"
+ }
+ },
+ "node_modules/word-wrap": {
+ "version": "1.2.5",
+ "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.5.tgz",
+ "integrity": "sha512-BN22B5eaMMI9UMtjrGd5g5eCYPpCPDUy0FJXbYsaT5zYxjFOckS53SQDE3pWkVoWpHXVb3BrYcEN4Twa55B5cA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/yallist": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz",
+ "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==",
+ "dev": true,
+ "license": "ISC"
+ },
+ "node_modules/yocto-queue": {
+ "version": "0.1.0",
+ "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz",
+ "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/zod": {
+ "version": "4.3.6",
+ "resolved": "https://registry.npmjs.org/zod/-/zod-4.3.6.tgz",
+ "integrity": "sha512-rftlrkhHZOcjDwkGlnUtZZkvaPHCsDATp4pGpuOOMDaTdDDXF91wuVDJoWoPsKX/3YPQ5fHuF3STjcYyKr+Qhg==",
+ "dev": true,
+ "license": "MIT",
+ "funding": {
+ "url": "https://github.com/sponsors/colinhacks"
+ }
+ },
+ "node_modules/zod-validation-error": {
+ "version": "4.0.2",
+ "resolved": "https://registry.npmjs.org/zod-validation-error/-/zod-validation-error-4.0.2.tgz",
+ "integrity": "sha512-Q6/nZLe6jxuU80qb/4uJ4t5v2VEZ44lzQjPDhYJNztRQ4wyWc6VF3D3Kb/fAuPetZQnhS3hnajCf9CsWesghLQ==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=18.0.0"
+ },
+ "peerDependencies": {
+ "zod": "^3.25.0 || ^4.0.0"
+ }
+ }
+ }
+}
diff --git a/team-Krantikari/package.json b/team-Krantikari/package.json
new file mode 100644
index 000000000..6820b716c
--- /dev/null
+++ b/team-Krantikari/package.json
@@ -0,0 +1,33 @@
+{
+ "name": "team-krantikari",
+ "private": true,
+ "version": "0.0.0",
+ "type": "module",
+ "scripts": {
+ "dev": "vite",
+ "build": "vite build",
+ "lint": "eslint .",
+ "preview": "vite preview"
+ },
+ "dependencies": {
+ "@tailwindcss/vite": "^4.2.2",
+ "class-variance-authority": "^0.7.1",
+ "clsx": "^2.1.1",
+ "lucide-react": "^1.7.0",
+ "react": "^19.2.4",
+ "react-dom": "^19.2.4",
+ "tailwind-merge": "^3.5.0",
+ "tailwindcss": "^4.2.2"
+ },
+ "devDependencies": {
+ "@eslint/js": "^9.39.4",
+ "@types/react": "^19.2.14",
+ "@types/react-dom": "^19.2.3",
+ "@vitejs/plugin-react": "^6.0.1",
+ "eslint": "^9.39.4",
+ "eslint-plugin-react-hooks": "^7.0.1",
+ "eslint-plugin-react-refresh": "^0.5.2",
+ "globals": "^17.4.0",
+ "vite": "^8.0.1"
+ }
+}
diff --git a/team-Krantikari/plan.md b/team-Krantikari/plan.md
new file mode 100644
index 000000000..6bd18cd34
--- /dev/null
+++ b/team-Krantikari/plan.md
@@ -0,0 +1,165 @@
+# Pokedex Application — Development Plan
+
+> **Team Krantikari** | Sprint: 1 Week | Stack: Vite + React + Tailwind CSS + Shadcn UI
+
+---
+
+## 🎯 Objective
+
+Build a high-performance, visually stunning Pokedex application featuring 200+ Pokemon with type filtering, sorting, animated cards, and a glittery background aesthetic.
+
+---
+
+## 📅 1-Week SWE Cycle
+
+### Day 1 — Project Init, Architecture & Layout
+- [ ] Convert project to TypeScript for Shadcn compatibility
+- [ ] Install & configure Tailwind CSS v4 (`@tailwindcss/vite` plugin)
+- [ ] Install & initialize Shadcn UI (`npx shadcn@latest init`)
+- [ ] Install Lucide React icons
+- [ ] Set up directory structure: `/components`, `/hooks`, `/data`, `/lib`
+- [ ] Build sticky Navbar (glassmorphism, logo, nav links)
+- [ ] Build Footer (credits, social icons)
+
+### Day 2 — Data Layer & Type Filtering Logic
+- [ ] Create `pokemonData.ts` with 200+ Pokemon (Gen 1 focus: #1–151)
+- [ ] Define Pokemon interface & type color mapping
+- [ ] Build `usePokedex` hook (derived state with `useMemo`)
+- [ ] Implement Filter dropdown (Shadcn Select — filter by type)
+- [ ] Implement Sort dropdown (Shadcn Select — ID ↑↓, Name A–Z)
+
+### Day 3 — Grid View & Card Components
+- [ ] Install & customize Shadcn Card component
+- [ ] Build `PokemonCard` with official artwork sprites
+- [ ] Create responsive CSS Grid (1–5 columns across breakpoints)
+- [ ] Add lazy image loading with fade-in animation
+- [ ] Handle empty filter states
+
+### Day 4 — Pop-out Animation & Detail View
+- [ ] Implement card pop-out spring animation on click
+- [ ] Build detail modal/overlay with expanded Pokemon info
+- [ ] Add stats visualization (animated horizontal bars)
+- [ ] Handle close interactions (click outside, ESC, button)
+- [ ] Scroll lock when detail view is open
+
+### Day 5 — Glittery Background & Visual Polish
+- [ ] Create CSS-animated glittery background (gradient + shimmer particles)
+- [ ] Add twinkling stars effect
+- [ ] Apply glassmorphism to cards and navbar
+- [ ] Implement 3D tilt hover effect on cards
+- [ ] Add micro-animations (staggered entrance, filter transitions)
+- [ ] Import Google Font (Inter/Outfit)
+
+### Day 6 — Performance & Responsive Testing
+- [ ] Optimize image loading (preload, sizes, error fallbacks)
+- [ ] Prevent layout shifts (fixed aspect ratios, skeleton placeholders)
+- [ ] Test on mobile, tablet, and desktop breakpoints
+- [ ] A11y audit (focus management, ARIA labels, keyboard nav)
+
+### Day 7 — Final Walkthrough & Bug Fixes
+- [ ] Cross-browser testing (Chrome, Firefox, Safari)
+- [ ] Fix edge cases (rapid filtering, image errors)
+- [ ] Add SEO meta tags
+- [ ] Code cleanup & documentation
+- [ ] Final walkthrough recording
+
+---
+
+## 🏗️ Architecture
+
+### Data Flow
+```
+Static Mock Data (200+ Pokemon)
+ │
+ ▼
+ usePokedex Hook
+ ├── selectedType (state)
+ ├── sortBy (state)
+ └── filteredPokemon (useMemo derived)
+ │
+ ▼
+ PokemonGrid → PokemonCard[] → PokemonDetail (modal)
+```
+
+### Filtering Strategy
+- **Pattern:** Derived state with `useMemo`
+- **Why:** 200 items benefits from memoization for stable array references, preventing unnecessary re-renders of `React.memo`-wrapped card components
+- **Filter:** By primary Pokemon type (18 types + "All")
+- **Sort:** By ID (asc/desc) or Name (A-Z/Z-A)
+
+### Component Tree
+```
+App
+├── GlitterBackground (fixed, behind everything)
+├── Navbar (sticky)
+├── main
+│ ├── FilterBar
+│ │ ├── Select (Type Filter)
+│ │ └── Select (Sort)
+│ └── PokemonGrid
+│ └── PokemonCard × N
+│ └── onClick → PokemonDetail (modal overlay)
+│ ├── Type Badges
+│ └── StatsChart
+└── Footer
+```
+
+### Directory Structure
+```
+src/
+├── components/
+│ ├── ui/ # Shadcn (auto-generated)
+│ ├── Navbar.tsx
+│ ├── Footer.tsx
+│ ├── PokemonCard.tsx
+│ ├── PokemonDetail.tsx
+│ ├── PokemonGrid.tsx
+│ ├── FilterBar.tsx
+│ ├── StatsChart.tsx
+│ └── GlitterBackground.tsx
+├── hooks/
+│ └── usePokedex.ts
+├── data/
+│ ├── pokemonData.ts
+│ └── typeColors.ts
+├── lib/
+│ └── utils.ts
+├── App.tsx
+├── main.tsx
+└── index.css
+```
+
+---
+
+## 🎨 Design System
+
+| Property | Value |
+|----------|-------|
+| Theme | Modern Dark |
+| Background | Deep purple → midnight blue gradient |
+| Surface | Glassmorphism (blur + transparency) |
+| Font | Inter (Google Fonts) |
+| Accent | Purple-400 (`#c084fc`) |
+| Card Hover | 3D tilt + type-colored glow |
+| Animations | Spring pop-out, staggered entrance, shimmer particles |
+
+---
+
+## 📦 Dependencies to Install
+
+| Package | Purpose |
+|---------|---------|
+| `tailwindcss` | Utility-first CSS |
+| `@tailwindcss/vite` | Vite plugin for Tailwind v4 |
+| `lucide-react` | Icon library |
+| `class-variance-authority` | Shadcn styling utility |
+| `clsx` | Class merging |
+| `tailwind-merge` | Tailwind class conflict resolution |
+
+---
+
+## 🔗 Key Resources
+
+- **Sprites:** `https://raw.githubusercontent.com/PokeAPI/sprites/master/sprites/pokemon/other/official-artwork/{id}.png`
+- **Shadcn Docs:** https://ui.shadcn.com
+- **Tailwind v4:** https://tailwindcss.com
diff --git a/team-Krantikari/public/favicon.svg b/team-Krantikari/public/favicon.svg
new file mode 100644
index 000000000..6893eb132
--- /dev/null
+++ b/team-Krantikari/public/favicon.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/team-Krantikari/public/icons.svg b/team-Krantikari/public/icons.svg
new file mode 100644
index 000000000..e9522193d
--- /dev/null
+++ b/team-Krantikari/public/icons.svg
@@ -0,0 +1,24 @@
+
diff --git a/team-Krantikari/src/App.jsx b/team-Krantikari/src/App.jsx
new file mode 100644
index 000000000..1828a39f5
--- /dev/null
+++ b/team-Krantikari/src/App.jsx
@@ -0,0 +1,64 @@
+import GlitterBackground from '@/components/GlitterBackground'
+import Navbar, { Footer } from '@/components/Navbar'
+import FilterBar from '@/components/FilterBar'
+import PokemonGrid from '@/components/PokemonGrid'
+import PokemonDetail from '@/components/PokemonDetail'
+import { usePokedex } from '@/hooks/usePokedex'
+
+function App() {
+ const {
+ filteredPokemon,
+ selectedType,
+ setSelectedType,
+ sortBy,
+ setSortBy,
+ selectedPokemon,
+ setSelectedPokemon,
+ totalCount,
+ filteredCount,
+ } = usePokedex()
+
+ return (
+ <>
+
+
+
+
+ {/* Hero section */}
+
+
+ Pokédex
+
+
+ Explore {totalCount} Pokémon from across the regions. Filter by type, sort, and discover their stats.
+
+
+
+
+
+
+
+
+
+
+ {selectedPokemon && (
+ setSelectedPokemon(null)}
+ />
+ )}
+ >
+ )
+}
+
+export default App
diff --git a/team-Krantikari/src/assets/hero.png b/team-Krantikari/src/assets/hero.png
new file mode 100644
index 000000000..cc51a3d20
Binary files /dev/null and b/team-Krantikari/src/assets/hero.png differ
diff --git a/team-Krantikari/src/assets/react.svg b/team-Krantikari/src/assets/react.svg
new file mode 100644
index 000000000..6c87de9bb
--- /dev/null
+++ b/team-Krantikari/src/assets/react.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/team-Krantikari/src/assets/vite.svg b/team-Krantikari/src/assets/vite.svg
new file mode 100644
index 000000000..5101b674d
--- /dev/null
+++ b/team-Krantikari/src/assets/vite.svg
@@ -0,0 +1 @@
+
diff --git a/team-Krantikari/src/components/FilterBar.jsx b/team-Krantikari/src/components/FilterBar.jsx
new file mode 100644
index 000000000..f948e8c54
--- /dev/null
+++ b/team-Krantikari/src/components/FilterBar.jsx
@@ -0,0 +1,66 @@
+import { Select } from '@/components/ui/select'
+import { ALL_TYPES } from '@/data/typeColors'
+import { Filter, ArrowUpDown } from 'lucide-react'
+
+const typeOptions = [
+ { value: 'all', label: 'All Types' },
+ ...ALL_TYPES.map((type) => ({
+ value: type,
+ label: type.charAt(0).toUpperCase() + type.slice(1),
+ })),
+]
+
+const sortOptions = [
+ { value: 'id-asc', label: 'ID ↑ (Ascending)' },
+ { value: 'id-desc', label: 'ID ↓ (Descending)' },
+ { value: 'name-asc', label: 'Name (A → Z)' },
+ { value: 'name-desc', label: 'Name (Z → A)' },
+]
+
+export default function FilterBar({
+ selectedType,
+ onTypeChange,
+ sortBy,
+ onSortChange,
+ filteredCount,
+ totalCount,
+}) {
+ return (
+
+
+ {/* Type filter */}
+
+
+
+
+
+ {/* Sort */}
+
+
+
+ {/* Count */}
+
+ Showing{' '}
+ {filteredCount}{' '}
+ of{' '}
+ {totalCount}{' '}
+ Pokémon
+
+
+ )
+}
diff --git a/team-Krantikari/src/components/GlitterBackground.jsx b/team-Krantikari/src/components/GlitterBackground.jsx
new file mode 100644
index 000000000..d8bf75f25
--- /dev/null
+++ b/team-Krantikari/src/components/GlitterBackground.jsx
@@ -0,0 +1,39 @@
+export default function GlitterBackground() {
+ return (
+
+ {/* Base gradient */}
+
+
+ {/* Animated gradient overlay */}
+
+
+ {/* Star particles */}
+
+ {Array.from({ length: 80 }).map((_, i) => (
+
+ ))}
+
+
+ {/* Shimmer lines */}
+
+
+ {/* Subtle radial glow */}
+
+
+ )
+}
diff --git a/team-Krantikari/src/components/Navbar.jsx b/team-Krantikari/src/components/Navbar.jsx
new file mode 100644
index 000000000..585138ad2
--- /dev/null
+++ b/team-Krantikari/src/components/Navbar.jsx
@@ -0,0 +1,118 @@
+import { Zap, Code2, MessageCircle, Heart, ExternalLink } from 'lucide-react'
+
+export default function Navbar() {
+ return (
+
+ )
+}
+
+export function Footer() {
+ return (
+
+ )
+}
diff --git a/team-Krantikari/src/components/PokemonCard.jsx b/team-Krantikari/src/components/PokemonCard.jsx
new file mode 100644
index 000000000..1a8ae314e
--- /dev/null
+++ b/team-Krantikari/src/components/PokemonCard.jsx
@@ -0,0 +1,128 @@
+import { memo, useState, useCallback, useRef } from 'react'
+import { Card } from '@/components/ui/card'
+import { Badge } from '@/components/ui/badge'
+import { TYPE_COLORS } from '@/data/typeColors'
+import { getPokemonSprite } from '@/data/pokemonData'
+import { cn } from '@/lib/utils'
+
+const PokemonCard = memo(function PokemonCard({ pokemon, onClick, index }) {
+ const [imageLoaded, setImageLoaded] = useState(false)
+ const [imageError, setImageError] = useState(false)
+ const cardRef = useRef(null)
+
+ const handleMouseMove = useCallback((e) => {
+ if (!cardRef.current) return
+ const rect = cardRef.current.getBoundingClientRect()
+ const x = e.clientX - rect.left
+ const y = e.clientY - rect.top
+ const centerX = rect.width / 2
+ const centerY = rect.height / 2
+ const rotateX = ((y - centerY) / centerY) * -8
+ const rotateY = ((x - centerX) / centerX) * 8
+ cardRef.current.style.transform = `perspective(800px) rotateX(${rotateX}deg) rotateY(${rotateY}deg) scale3d(1.03, 1.03, 1.03)`
+ }, [])
+
+ const handleMouseLeave = useCallback(() => {
+ if (!cardRef.current) return
+ cardRef.current.style.transform = 'perspective(800px) rotateX(0deg) rotateY(0deg) scale3d(1, 1, 1)'
+ }, [])
+
+ const primaryType = pokemon.types[0]
+ const typeColor = TYPE_COLORS[primaryType] || TYPE_COLORS.normal
+
+ return (
+
+
onClick(pokemon)}
+ >
+ {/* Type glow background */}
+
+
+ {/* ID badge */}
+
+
+ #{String(pokemon.id).padStart(3, '0')}
+
+
+
+ {/* Image section */}
+
+ {/* Radial gradient behind pokemon */}
+
+
+ {!imageError ? (
+
})
setImageLoaded(true)}
+ onError={() => setImageError(true)}
+ />
+ ) : (
+
+ ?
+
+ )}
+
+ {/* Loading skeleton */}
+ {!imageLoaded && !imageError && (
+
+ )}
+
+
+ {/* Info section */}
+
+
+ {pokemon.name}
+
+
+ {pokemon.types.map((type) => {
+ const tc = TYPE_COLORS[type] || TYPE_COLORS.normal
+ return (
+
+ {type}
+
+ )
+ })}
+
+
+
+
+ )
+})
+
+export default PokemonCard
diff --git a/team-Krantikari/src/components/PokemonDetail.jsx b/team-Krantikari/src/components/PokemonDetail.jsx
new file mode 100644
index 000000000..d53922a4d
--- /dev/null
+++ b/team-Krantikari/src/components/PokemonDetail.jsx
@@ -0,0 +1,137 @@
+import { useEffect, useCallback } from 'react'
+import { Badge } from '@/components/ui/badge'
+import { TYPE_COLORS } from '@/data/typeColors'
+import { getPokemonSprite } from '@/data/pokemonData'
+import StatsChart from '@/components/StatsChart'
+import { X, Ruler, Weight, Sparkles } from 'lucide-react'
+import { cn } from '@/lib/utils'
+
+export default function PokemonDetail({ pokemon, onClose }) {
+ // Lock scroll
+ useEffect(() => {
+ document.body.style.overflow = 'hidden'
+ return () => {
+ document.body.style.overflow = ''
+ }
+ }, [])
+
+ // ESC to close
+ const handleKeyDown = useCallback(
+ (e) => {
+ if (e.key === 'Escape') onClose()
+ },
+ [onClose]
+ )
+
+ useEffect(() => {
+ window.addEventListener('keydown', handleKeyDown)
+ return () => window.removeEventListener('keydown', handleKeyDown)
+ }, [handleKeyDown])
+
+ if (!pokemon) return null
+
+ const primaryType = pokemon.types[0]
+ const typeColor = TYPE_COLORS[primaryType] || TYPE_COLORS.normal
+ const totalStats = Object.values(pokemon.stats).reduce((a, b) => a + b, 0)
+
+ return (
+
+ {/* Backdrop */}
+
+
+ {/* Modal */}
+
e.stopPropagation()}
+ >
+ {/* Type gradient header */}
+
+
+ {/* Close button */}
+
+
+ {/* Content */}
+
+ {/* Pokemon Image */}
+
+
+
})
+
+
+
+
+ {/* Name & ID */}
+
+
+ #{String(pokemon.id).padStart(3, '0')}
+
+
{pokemon.name}
+
+
+ {/* Types */}
+
+ {pokemon.types.map((type) => {
+ const tc = TYPE_COLORS[type] || TYPE_COLORS.normal
+ return (
+
+ {type}
+
+ )
+ })}
+
+
+ {/* Physical stats */}
+
+
+
+
{(pokemon.height / 10).toFixed(1)} m
+
Height
+
+
+
+
{(pokemon.weight / 10).toFixed(1)} kg
+
Weight
+
+
+
+
{totalStats}
+
Base Total
+
+
+
+ {/* Stats */}
+
+
+ Base Stats
+
+
+
+
+
+
+ )
+}
diff --git a/team-Krantikari/src/components/PokemonGrid.jsx b/team-Krantikari/src/components/PokemonGrid.jsx
new file mode 100644
index 000000000..0381e1b9f
--- /dev/null
+++ b/team-Krantikari/src/components/PokemonGrid.jsx
@@ -0,0 +1,31 @@
+import PokemonCard from '@/components/PokemonCard'
+import { SearchX } from 'lucide-react'
+
+export default function PokemonGrid({ pokemon, onSelectPokemon }) {
+ if (pokemon.length === 0) {
+ return (
+
+
+
+ No Pokémon found
+
+
+ Try adjusting your filter to see more results.
+
+
+ )
+ }
+
+ return (
+
+ {pokemon.map((p, i) => (
+
+ ))}
+
+ )
+}
diff --git a/team-Krantikari/src/components/StatsChart.jsx b/team-Krantikari/src/components/StatsChart.jsx
new file mode 100644
index 000000000..980062dab
--- /dev/null
+++ b/team-Krantikari/src/components/StatsChart.jsx
@@ -0,0 +1,45 @@
+import { TYPE_COLORS } from '@/data/typeColors'
+
+const STAT_LABELS = {
+ hp: 'HP',
+ attack: 'ATK',
+ defense: 'DEF',
+ spAtk: 'SP.ATK',
+ spDef: 'SP.DEF',
+ speed: 'SPD',
+}
+
+const MAX_STAT = 255
+
+export default function StatsChart({ stats, primaryType }) {
+ const typeColor = TYPE_COLORS[primaryType] || TYPE_COLORS.normal
+
+ return (
+
+ {Object.entries(stats).map(([key, value], i) => {
+ const percentage = (value / MAX_STAT) * 100
+ return (
+
+
+ {STAT_LABELS[key]}
+
+
+ {value}
+
+
+
+ )
+ })}
+
+ )
+}
diff --git a/team-Krantikari/src/components/ui/badge.jsx b/team-Krantikari/src/components/ui/badge.jsx
new file mode 100644
index 000000000..bd7a0d642
--- /dev/null
+++ b/team-Krantikari/src/components/ui/badge.jsx
@@ -0,0 +1,22 @@
+import { cn } from '@/lib/utils'
+
+const badgeVariants = {
+ default: 'bg-purple-500/20 text-purple-300 border-purple-500/30',
+ secondary: 'bg-white/10 text-gray-300 border-white/10',
+ outline: 'bg-transparent border-white/20 text-gray-300',
+}
+
+export function Badge({ className, variant = 'default', children, ...props }) {
+ return (
+
+ {children}
+
+ )
+}
diff --git a/team-Krantikari/src/components/ui/card.jsx b/team-Krantikari/src/components/ui/card.jsx
new file mode 100644
index 000000000..9cb922805
--- /dev/null
+++ b/team-Krantikari/src/components/ui/card.jsx
@@ -0,0 +1,42 @@
+import { cn } from '@/lib/utils'
+
+export function Card({ className, children, ...props }) {
+ return (
+
+ {children}
+
+ )
+}
+
+export function CardHeader({ className, children, ...props }) {
+ return (
+
+ {children}
+
+ )
+}
+
+export function CardContent({ className, children, ...props }) {
+ return (
+
+ {children}
+
+ )
+}
+
+export function CardTitle({ className, children, ...props }) {
+ return (
+
+ {children}
+
+ )
+}
diff --git a/team-Krantikari/src/components/ui/select.jsx b/team-Krantikari/src/components/ui/select.jsx
new file mode 100644
index 000000000..15c07e900
--- /dev/null
+++ b/team-Krantikari/src/components/ui/select.jsx
@@ -0,0 +1,72 @@
+import { useState, useRef, useEffect } from 'react'
+import { cn } from '@/lib/utils'
+import { ChevronDown } from 'lucide-react'
+
+export function Select({ value, onValueChange, options, placeholder = 'Select...', className }) {
+ const [open, setOpen] = useState(false)
+ const ref = useRef(null)
+
+ useEffect(() => {
+ function handleClickOutside(e) {
+ if (ref.current && !ref.current.contains(e.target)) {
+ setOpen(false)
+ }
+ }
+ document.addEventListener('mousedown', handleClickOutside)
+ return () => document.removeEventListener('mousedown', handleClickOutside)
+ }, [])
+
+ const selectedLabel = options.find((o) => o.value === value)?.label || placeholder
+
+ return (
+
+
+ {open && (
+
+ {options.map((option) => (
+
+ ))}
+
+ )}
+
+ )
+}
diff --git a/team-Krantikari/src/data/pokemonData.js b/team-Krantikari/src/data/pokemonData.js
new file mode 100644
index 000000000..b8bef1e63
--- /dev/null
+++ b/team-Krantikari/src/data/pokemonData.js
@@ -0,0 +1,201 @@
+// 200+ Pokemon data — All 151 Kanto (Gen 1) + select Gen 2-5 favorites
+// Stats, types, height, weight sourced from official Pokedex data
+// Sprite URL: https://raw.githubusercontent.com/PokeAPI/sprites/master/sprites/pokemon/other/official-artwork/{id}.png
+
+export const POKEMON_DATA = [
+ { id: 1, name: "Bulbasaur", types: ["grass", "poison"], stats: { hp: 45, attack: 49, defense: 49, spAtk: 65, spDef: 65, speed: 45 }, height: 7, weight: 69 },
+ { id: 2, name: "Ivysaur", types: ["grass", "poison"], stats: { hp: 60, attack: 62, defense: 63, spAtk: 80, spDef: 80, speed: 60 }, height: 10, weight: 130 },
+ { id: 3, name: "Venusaur", types: ["grass", "poison"], stats: { hp: 80, attack: 82, defense: 83, spAtk: 100, spDef: 100, speed: 80 }, height: 20, weight: 1000 },
+ { id: 4, name: "Charmander", types: ["fire"], stats: { hp: 39, attack: 52, defense: 43, spAtk: 60, spDef: 50, speed: 65 }, height: 6, weight: 85 },
+ { id: 5, name: "Charmeleon", types: ["fire"], stats: { hp: 58, attack: 64, defense: 58, spAtk: 80, spDef: 65, speed: 80 }, height: 11, weight: 190 },
+ { id: 6, name: "Charizard", types: ["fire", "flying"], stats: { hp: 78, attack: 84, defense: 78, spAtk: 109, spDef: 85, speed: 100 }, height: 17, weight: 905 },
+ { id: 7, name: "Squirtle", types: ["water"], stats: { hp: 44, attack: 48, defense: 65, spAtk: 50, spDef: 64, speed: 43 }, height: 5, weight: 90 },
+ { id: 8, name: "Wartortle", types: ["water"], stats: { hp: 59, attack: 63, defense: 80, spAtk: 65, spDef: 80, speed: 58 }, height: 10, weight: 225 },
+ { id: 9, name: "Blastoise", types: ["water"], stats: { hp: 79, attack: 83, defense: 100, spAtk: 85, spDef: 105, speed: 78 }, height: 16, weight: 855 },
+ { id: 10, name: "Caterpie", types: ["bug"], stats: { hp: 45, attack: 30, defense: 35, spAtk: 20, spDef: 20, speed: 45 }, height: 3, weight: 29 },
+ { id: 11, name: "Metapod", types: ["bug"], stats: { hp: 50, attack: 20, defense: 55, spAtk: 25, spDef: 25, speed: 30 }, height: 7, weight: 99 },
+ { id: 12, name: "Butterfree", types: ["bug", "flying"], stats: { hp: 60, attack: 45, defense: 50, spAtk: 90, spDef: 80, speed: 70 }, height: 11, weight: 320 },
+ { id: 13, name: "Weedle", types: ["bug", "poison"], stats: { hp: 40, attack: 35, defense: 30, spAtk: 20, spDef: 20, speed: 50 }, height: 3, weight: 32 },
+ { id: 14, name: "Kakuna", types: ["bug", "poison"], stats: { hp: 45, attack: 25, defense: 50, spAtk: 25, spDef: 25, speed: 35 }, height: 6, weight: 100 },
+ { id: 15, name: "Beedrill", types: ["bug", "poison"], stats: { hp: 65, attack: 90, defense: 40, spAtk: 45, spDef: 80, speed: 75 }, height: 10, weight: 295 },
+ { id: 16, name: "Pidgey", types: ["normal", "flying"], stats: { hp: 40, attack: 45, defense: 40, spAtk: 35, spDef: 35, speed: 56 }, height: 3, weight: 18 },
+ { id: 17, name: "Pidgeotto", types: ["normal", "flying"], stats: { hp: 63, attack: 60, defense: 55, spAtk: 50, spDef: 50, speed: 71 }, height: 11, weight: 300 },
+ { id: 18, name: "Pidgeot", types: ["normal", "flying"], stats: { hp: 83, attack: 80, defense: 75, spAtk: 70, spDef: 70, speed: 101 }, height: 15, weight: 395 },
+ { id: 19, name: "Rattata", types: ["normal"], stats: { hp: 30, attack: 56, defense: 35, spAtk: 25, spDef: 35, speed: 72 }, height: 3, weight: 35 },
+ { id: 20, name: "Raticate", types: ["normal"], stats: { hp: 55, attack: 81, defense: 60, spAtk: 50, spDef: 70, speed: 97 }, height: 7, weight: 185 },
+ { id: 21, name: "Spearow", types: ["normal", "flying"], stats: { hp: 40, attack: 60, defense: 30, spAtk: 31, spDef: 31, speed: 70 }, height: 3, weight: 20 },
+ { id: 22, name: "Fearow", types: ["normal", "flying"], stats: { hp: 65, attack: 90, defense: 65, spAtk: 61, spDef: 61, speed: 100 }, height: 12, weight: 380 },
+ { id: 23, name: "Ekans", types: ["poison"], stats: { hp: 35, attack: 60, defense: 44, spAtk: 40, spDef: 54, speed: 55 }, height: 20, weight: 69 },
+ { id: 24, name: "Arbok", types: ["poison"], stats: { hp: 60, attack: 95, defense: 69, spAtk: 65, spDef: 79, speed: 80 }, height: 35, weight: 650 },
+ { id: 25, name: "Pikachu", types: ["electric"], stats: { hp: 35, attack: 55, defense: 40, spAtk: 50, spDef: 50, speed: 90 }, height: 4, weight: 60 },
+ { id: 26, name: "Raichu", types: ["electric"], stats: { hp: 60, attack: 90, defense: 55, spAtk: 90, spDef: 80, speed: 110 }, height: 8, weight: 300 },
+ { id: 27, name: "Sandshrew", types: ["ground"], stats: { hp: 50, attack: 75, defense: 85, spAtk: 20, spDef: 30, speed: 40 }, height: 6, weight: 120 },
+ { id: 28, name: "Sandslash", types: ["ground"], stats: { hp: 75, attack: 100, defense: 110, spAtk: 45, spDef: 55, speed: 65 }, height: 10, weight: 295 },
+ { id: 29, name: "Nidoran♀", types: ["poison"], stats: { hp: 55, attack: 47, defense: 52, spAtk: 40, spDef: 40, speed: 41 }, height: 4, weight: 70 },
+ { id: 30, name: "Nidorina", types: ["poison"], stats: { hp: 70, attack: 62, defense: 67, spAtk: 55, spDef: 55, speed: 56 }, height: 8, weight: 200 },
+ { id: 31, name: "Nidoqueen", types: ["poison", "ground"], stats: { hp: 90, attack: 92, defense: 87, spAtk: 75, spDef: 85, speed: 76 }, height: 13, weight: 600 },
+ { id: 32, name: "Nidoran♂", types: ["poison"], stats: { hp: 46, attack: 57, defense: 40, spAtk: 40, spDef: 40, speed: 50 }, height: 5, weight: 90 },
+ { id: 33, name: "Nidorino", types: ["poison"], stats: { hp: 61, attack: 72, defense: 57, spAtk: 55, spDef: 55, speed: 65 }, height: 9, weight: 195 },
+ { id: 34, name: "Nidoking", types: ["poison", "ground"], stats: { hp: 81, attack: 102, defense: 77, spAtk: 85, spDef: 75, speed: 85 }, height: 14, weight: 620 },
+ { id: 35, name: "Clefairy", types: ["fairy"], stats: { hp: 70, attack: 45, defense: 48, spAtk: 60, spDef: 65, speed: 35 }, height: 6, weight: 75 },
+ { id: 36, name: "Clefable", types: ["fairy"], stats: { hp: 95, attack: 70, defense: 73, spAtk: 95, spDef: 90, speed: 60 }, height: 13, weight: 400 },
+ { id: 37, name: "Vulpix", types: ["fire"], stats: { hp: 38, attack: 41, defense: 40, spAtk: 50, spDef: 65, speed: 65 }, height: 6, weight: 99 },
+ { id: 38, name: "Ninetales", types: ["fire"], stats: { hp: 73, attack: 76, defense: 75, spAtk: 81, spDef: 100, speed: 100 }, height: 11, weight: 199 },
+ { id: 39, name: "Jigglypuff", types: ["normal", "fairy"], stats: { hp: 115, attack: 45, defense: 20, spAtk: 45, spDef: 25, speed: 20 }, height: 5, weight: 55 },
+ { id: 40, name: "Wigglytuff", types: ["normal", "fairy"], stats: { hp: 140, attack: 70, defense: 45, spAtk: 85, spDef: 50, speed: 45 }, height: 10, weight: 120 },
+ { id: 41, name: "Zubat", types: ["poison", "flying"], stats: { hp: 40, attack: 45, defense: 35, spAtk: 30, spDef: 40, speed: 55 }, height: 8, weight: 75 },
+ { id: 42, name: "Golbat", types: ["poison", "flying"], stats: { hp: 75, attack: 80, defense: 70, spAtk: 65, spDef: 75, speed: 90 }, height: 16, weight: 550 },
+ { id: 43, name: "Oddish", types: ["grass", "poison"], stats: { hp: 45, attack: 50, defense: 55, spAtk: 75, spDef: 65, speed: 30 }, height: 5, weight: 54 },
+ { id: 44, name: "Gloom", types: ["grass", "poison"], stats: { hp: 60, attack: 65, defense: 70, spAtk: 85, spDef: 75, speed: 40 }, height: 8, weight: 86 },
+ { id: 45, name: "Vileplume", types: ["grass", "poison"], stats: { hp: 75, attack: 80, defense: 85, spAtk: 110, spDef: 90, speed: 50 }, height: 12, weight: 186 },
+ { id: 46, name: "Paras", types: ["bug", "grass"], stats: { hp: 35, attack: 70, defense: 55, spAtk: 45, spDef: 55, speed: 25 }, height: 3, weight: 54 },
+ { id: 47, name: "Parasect", types: ["bug", "grass"], stats: { hp: 60, attack: 95, defense: 80, spAtk: 60, spDef: 80, speed: 30 }, height: 10, weight: 295 },
+ { id: 48, name: "Venonat", types: ["bug", "poison"], stats: { hp: 60, attack: 55, defense: 50, spAtk: 40, spDef: 55, speed: 45 }, height: 10, weight: 300 },
+ { id: 49, name: "Venomoth", types: ["bug", "poison"], stats: { hp: 70, attack: 65, defense: 60, spAtk: 90, spDef: 75, speed: 90 }, height: 15, weight: 125 },
+ { id: 50, name: "Diglett", types: ["ground"], stats: { hp: 10, attack: 55, defense: 25, spAtk: 35, spDef: 45, speed: 95 }, height: 2, weight: 8 },
+ { id: 51, name: "Dugtrio", types: ["ground"], stats: { hp: 35, attack: 100, defense: 50, spAtk: 50, spDef: 70, speed: 120 }, height: 7, weight: 333 },
+ { id: 52, name: "Meowth", types: ["normal"], stats: { hp: 40, attack: 45, defense: 35, spAtk: 40, spDef: 40, speed: 90 }, height: 4, weight: 42 },
+ { id: 53, name: "Persian", types: ["normal"], stats: { hp: 65, attack: 70, defense: 60, spAtk: 65, spDef: 65, speed: 115 }, height: 10, weight: 320 },
+ { id: 54, name: "Psyduck", types: ["water"], stats: { hp: 50, attack: 52, defense: 48, spAtk: 65, spDef: 50, speed: 55 }, height: 8, weight: 196 },
+ { id: 55, name: "Golduck", types: ["water"], stats: { hp: 80, attack: 82, defense: 78, spAtk: 95, spDef: 80, speed: 85 }, height: 17, weight: 766 },
+ { id: 56, name: "Mankey", types: ["fighting"], stats: { hp: 40, attack: 80, defense: 35, spAtk: 35, spDef: 45, speed: 70 }, height: 5, weight: 280 },
+ { id: 57, name: "Primeape", types: ["fighting"], stats: { hp: 65, attack: 105, defense: 60, spAtk: 60, spDef: 70, speed: 95 }, height: 10, weight: 320 },
+ { id: 58, name: "Growlithe", types: ["fire"], stats: { hp: 55, attack: 70, defense: 45, spAtk: 70, spDef: 50, speed: 60 }, height: 7, weight: 190 },
+ { id: 59, name: "Arcanine", types: ["fire"], stats: { hp: 90, attack: 110, defense: 80, spAtk: 100, spDef: 80, speed: 95 }, height: 19, weight: 1550 },
+ { id: 60, name: "Poliwag", types: ["water"], stats: { hp: 40, attack: 50, defense: 40, spAtk: 40, spDef: 40, speed: 90 }, height: 6, weight: 124 },
+ { id: 61, name: "Poliwhirl", types: ["water"], stats: { hp: 65, attack: 65, defense: 65, spAtk: 50, spDef: 50, speed: 90 }, height: 10, weight: 200 },
+ { id: 62, name: "Poliwrath", types: ["water", "fighting"], stats: { hp: 90, attack: 95, defense: 95, spAtk: 70, spDef: 90, speed: 70 }, height: 13, weight: 540 },
+ { id: 63, name: "Abra", types: ["psychic"], stats: { hp: 25, attack: 20, defense: 15, spAtk: 105, spDef: 55, speed: 90 }, height: 9, weight: 195 },
+ { id: 64, name: "Kadabra", types: ["psychic"], stats: { hp: 40, attack: 35, defense: 30, spAtk: 120, spDef: 70, speed: 105 }, height: 13, weight: 565 },
+ { id: 65, name: "Alakazam", types: ["psychic"], stats: { hp: 55, attack: 50, defense: 45, spAtk: 135, spDef: 95, speed: 120 }, height: 15, weight: 480 },
+ { id: 66, name: "Machop", types: ["fighting"], stats: { hp: 70, attack: 80, defense: 50, spAtk: 35, spDef: 35, speed: 35 }, height: 8, weight: 195 },
+ { id: 67, name: "Machoke", types: ["fighting"], stats: { hp: 80, attack: 100, defense: 70, spAtk: 50, spDef: 60, speed: 45 }, height: 15, weight: 705 },
+ { id: 68, name: "Machamp", types: ["fighting"], stats: { hp: 90, attack: 130, defense: 80, spAtk: 65, spDef: 85, speed: 55 }, height: 16, weight: 1300 },
+ { id: 69, name: "Bellsprout", types: ["grass", "poison"], stats: { hp: 50, attack: 75, defense: 35, spAtk: 70, spDef: 30, speed: 40 }, height: 7, weight: 40 },
+ { id: 70, name: "Weepinbell", types: ["grass", "poison"], stats: { hp: 65, attack: 90, defense: 50, spAtk: 85, spDef: 45, speed: 55 }, height: 10, weight: 64 },
+ { id: 71, name: "Victreebel", types: ["grass", "poison"], stats: { hp: 80, attack: 105, defense: 65, spAtk: 100, spDef: 70, speed: 70 }, height: 17, weight: 155 },
+ { id: 72, name: "Tentacool", types: ["water", "poison"], stats: { hp: 40, attack: 40, defense: 35, spAtk: 50, spDef: 100, speed: 70 }, height: 9, weight: 455 },
+ { id: 73, name: "Tentacruel", types: ["water", "poison"], stats: { hp: 80, attack: 70, defense: 65, spAtk: 80, spDef: 120, speed: 100 }, height: 16, weight: 550 },
+ { id: 74, name: "Geodude", types: ["rock", "ground"], stats: { hp: 40, attack: 80, defense: 100, spAtk: 30, spDef: 30, speed: 20 }, height: 4, weight: 200 },
+ { id: 75, name: "Graveler", types: ["rock", "ground"], stats: { hp: 55, attack: 95, defense: 115, spAtk: 45, spDef: 45, speed: 35 }, height: 10, weight: 1050 },
+ { id: 76, name: "Golem", types: ["rock", "ground"], stats: { hp: 80, attack: 120, defense: 130, spAtk: 55, spDef: 65, speed: 45 }, height: 14, weight: 3000 },
+ { id: 77, name: "Ponyta", types: ["fire"], stats: { hp: 50, attack: 85, defense: 55, spAtk: 65, spDef: 65, speed: 90 }, height: 10, weight: 300 },
+ { id: 78, name: "Rapidash", types: ["fire"], stats: { hp: 65, attack: 100, defense: 70, spAtk: 80, spDef: 80, speed: 105 }, height: 17, weight: 950 },
+ { id: 79, name: "Slowpoke", types: ["water", "psychic"], stats: { hp: 90, attack: 65, defense: 65, spAtk: 40, spDef: 40, speed: 15 }, height: 12, weight: 360 },
+ { id: 80, name: "Slowbro", types: ["water", "psychic"], stats: { hp: 95, attack: 75, defense: 110, spAtk: 100, spDef: 80, speed: 30 }, height: 16, weight: 785 },
+ { id: 81, name: "Magnemite", types: ["electric", "steel"], stats: { hp: 25, attack: 35, defense: 70, spAtk: 95, spDef: 55, speed: 45 }, height: 3, weight: 60 },
+ { id: 82, name: "Magneton", types: ["electric", "steel"], stats: { hp: 50, attack: 60, defense: 95, spAtk: 120, spDef: 70, speed: 70 }, height: 10, weight: 600 },
+ { id: 83, name: "Farfetch'd", types: ["normal", "flying"], stats: { hp: 52, attack: 90, defense: 55, spAtk: 58, spDef: 62, speed: 60 }, height: 8, weight: 150 },
+ { id: 84, name: "Doduo", types: ["normal", "flying"], stats: { hp: 35, attack: 85, defense: 45, spAtk: 35, spDef: 35, speed: 75 }, height: 14, weight: 392 },
+ { id: 85, name: "Dodrio", types: ["normal", "flying"], stats: { hp: 60, attack: 110, defense: 70, spAtk: 60, spDef: 60, speed: 110 }, height: 18, weight: 852 },
+ { id: 86, name: "Seel", types: ["water"], stats: { hp: 65, attack: 45, defense: 55, spAtk: 45, spDef: 70, speed: 45 }, height: 11, weight: 900 },
+ { id: 87, name: "Dewgong", types: ["water", "ice"], stats: { hp: 90, attack: 70, defense: 80, spAtk: 70, spDef: 95, speed: 70 }, height: 17, weight: 1200 },
+ { id: 88, name: "Grimer", types: ["poison"], stats: { hp: 80, attack: 80, defense: 50, spAtk: 40, spDef: 50, speed: 25 }, height: 9, weight: 300 },
+ { id: 89, name: "Muk", types: ["poison"], stats: { hp: 105, attack: 105, defense: 75, spAtk: 65, spDef: 100, speed: 50 }, height: 12, weight: 300 },
+ { id: 90, name: "Shellder", types: ["water"], stats: { hp: 30, attack: 65, defense: 100, spAtk: 45, spDef: 25, speed: 40 }, height: 3, weight: 40 },
+ { id: 91, name: "Cloyster", types: ["water", "ice"], stats: { hp: 50, attack: 95, defense: 180, spAtk: 85, spDef: 45, speed: 70 }, height: 15, weight: 1325 },
+ { id: 92, name: "Gastly", types: ["ghost", "poison"], stats: { hp: 30, attack: 35, defense: 30, spAtk: 100, spDef: 35, speed: 80 }, height: 13, weight: 1 },
+ { id: 93, name: "Haunter", types: ["ghost", "poison"], stats: { hp: 45, attack: 50, defense: 45, spAtk: 115, spDef: 55, speed: 95 }, height: 16, weight: 1 },
+ { id: 94, name: "Gengar", types: ["ghost", "poison"], stats: { hp: 60, attack: 65, defense: 60, spAtk: 130, spDef: 75, speed: 110 }, height: 15, weight: 405 },
+ { id: 95, name: "Onix", types: ["rock", "ground"], stats: { hp: 35, attack: 45, defense: 160, spAtk: 30, spDef: 45, speed: 70 }, height: 88, weight: 2100 },
+ { id: 96, name: "Drowzee", types: ["psychic"], stats: { hp: 60, attack: 48, defense: 45, spAtk: 43, spDef: 90, speed: 42 }, height: 10, weight: 324 },
+ { id: 97, name: "Hypno", types: ["psychic"], stats: { hp: 85, attack: 73, defense: 70, spAtk: 73, spDef: 115, speed: 67 }, height: 16, weight: 756 },
+ { id: 98, name: "Krabby", types: ["water"], stats: { hp: 30, attack: 105, defense: 90, spAtk: 25, spDef: 25, speed: 50 }, height: 4, weight: 65 },
+ { id: 99, name: "Kingler", types: ["water"], stats: { hp: 55, attack: 130, defense: 115, spAtk: 50, spDef: 50, speed: 75 }, height: 13, weight: 600 },
+ { id: 100, name: "Voltorb", types: ["electric"], stats: { hp: 40, attack: 30, defense: 50, spAtk: 55, spDef: 55, speed: 100 }, height: 5, weight: 104 },
+ { id: 101, name: "Electrode", types: ["electric"], stats: { hp: 60, attack: 50, defense: 70, spAtk: 80, spDef: 80, speed: 150 }, height: 12, weight: 666 },
+ { id: 102, name: "Exeggcute", types: ["grass", "psychic"], stats: { hp: 60, attack: 40, defense: 80, spAtk: 60, spDef: 45, speed: 40 }, height: 4, weight: 25 },
+ { id: 103, name: "Exeggutor", types: ["grass", "psychic"], stats: { hp: 95, attack: 95, defense: 85, spAtk: 125, spDef: 75, speed: 55 }, height: 20, weight: 1200 },
+ { id: 104, name: "Cubone", types: ["ground"], stats: { hp: 50, attack: 50, defense: 95, spAtk: 40, spDef: 50, speed: 35 }, height: 4, weight: 65 },
+ { id: 105, name: "Marowak", types: ["ground"], stats: { hp: 60, attack: 80, defense: 110, spAtk: 50, spDef: 80, speed: 45 }, height: 10, weight: 450 },
+ { id: 106, name: "Hitmonlee", types: ["fighting"], stats: { hp: 50, attack: 120, defense: 53, spAtk: 35, spDef: 110, speed: 87 }, height: 15, weight: 498 },
+ { id: 107, name: "Hitmonchan", types: ["fighting"], stats: { hp: 50, attack: 105, defense: 79, spAtk: 35, spDef: 110, speed: 76 }, height: 14, weight: 502 },
+ { id: 108, name: "Lickitung", types: ["normal"], stats: { hp: 90, attack: 55, defense: 75, spAtk: 60, spDef: 75, speed: 30 }, height: 12, weight: 655 },
+ { id: 109, name: "Koffing", types: ["poison"], stats: { hp: 40, attack: 65, defense: 95, spAtk: 60, spDef: 45, speed: 35 }, height: 6, weight: 10 },
+ { id: 110, name: "Weezing", types: ["poison"], stats: { hp: 65, attack: 90, defense: 120, spAtk: 85, spDef: 70, speed: 60 }, height: 12, weight: 95 },
+ { id: 111, name: "Rhyhorn", types: ["ground", "rock"], stats: { hp: 80, attack: 85, defense: 95, spAtk: 30, spDef: 30, speed: 25 }, height: 10, weight: 1150 },
+ { id: 112, name: "Rhydon", types: ["ground", "rock"], stats: { hp: 105, attack: 130, defense: 120, spAtk: 45, spDef: 45, speed: 40 }, height: 19, weight: 1200 },
+ { id: 113, name: "Chansey", types: ["normal"], stats: { hp: 250, attack: 5, defense: 5, spAtk: 35, spDef: 105, speed: 50 }, height: 11, weight: 346 },
+ { id: 114, name: "Tangela", types: ["grass"], stats: { hp: 65, attack: 55, defense: 115, spAtk: 100, spDef: 40, speed: 60 }, height: 10, weight: 350 },
+ { id: 115, name: "Kangaskhan", types: ["normal"], stats: { hp: 105, attack: 95, defense: 80, spAtk: 40, spDef: 80, speed: 90 }, height: 22, weight: 800 },
+ { id: 116, name: "Horsea", types: ["water"], stats: { hp: 30, attack: 40, defense: 70, spAtk: 70, spDef: 25, speed: 60 }, height: 4, weight: 80 },
+ { id: 117, name: "Seadra", types: ["water"], stats: { hp: 55, attack: 65, defense: 95, spAtk: 95, spDef: 45, speed: 85 }, height: 12, weight: 250 },
+ { id: 118, name: "Goldeen", types: ["water"], stats: { hp: 45, attack: 67, defense: 60, spAtk: 35, spDef: 50, speed: 63 }, height: 6, weight: 150 },
+ { id: 119, name: "Seaking", types: ["water"], stats: { hp: 80, attack: 92, defense: 65, spAtk: 65, spDef: 80, speed: 68 }, height: 13, weight: 390 },
+ { id: 120, name: "Staryu", types: ["water"], stats: { hp: 30, attack: 45, defense: 55, spAtk: 70, spDef: 55, speed: 85 }, height: 8, weight: 345 },
+ { id: 121, name: "Starmie", types: ["water", "psychic"], stats: { hp: 60, attack: 75, defense: 85, spAtk: 100, spDef: 85, speed: 115 }, height: 11, weight: 800 },
+ { id: 122, name: "Mr. Mime", types: ["psychic", "fairy"], stats: { hp: 40, attack: 45, defense: 65, spAtk: 100, spDef: 120, speed: 90 }, height: 13, weight: 545 },
+ { id: 123, name: "Scyther", types: ["bug", "flying"], stats: { hp: 70, attack: 110, defense: 80, spAtk: 55, spDef: 80, speed: 105 }, height: 15, weight: 560 },
+ { id: 124, name: "Jynx", types: ["ice", "psychic"], stats: { hp: 65, attack: 50, defense: 35, spAtk: 115, spDef: 95, speed: 95 }, height: 14, weight: 406 },
+ { id: 125, name: "Electabuzz", types: ["electric"], stats: { hp: 65, attack: 83, defense: 57, spAtk: 95, spDef: 85, speed: 105 }, height: 11, weight: 300 },
+ { id: 126, name: "Magmar", types: ["fire"], stats: { hp: 65, attack: 95, defense: 57, spAtk: 100, spDef: 85, speed: 93 }, height: 13, weight: 445 },
+ { id: 127, name: "Pinsir", types: ["bug"], stats: { hp: 65, attack: 125, defense: 100, spAtk: 55, spDef: 70, speed: 85 }, height: 15, weight: 550 },
+ { id: 128, name: "Tauros", types: ["normal"], stats: { hp: 75, attack: 100, defense: 95, spAtk: 40, spDef: 70, speed: 110 }, height: 14, weight: 884 },
+ { id: 129, name: "Magikarp", types: ["water"], stats: { hp: 20, attack: 10, defense: 55, spAtk: 15, spDef: 20, speed: 80 }, height: 9, weight: 100 },
+ { id: 130, name: "Gyarados", types: ["water", "flying"], stats: { hp: 95, attack: 125, defense: 79, spAtk: 60, spDef: 100, speed: 81 }, height: 65, weight: 2350 },
+ { id: 131, name: "Lapras", types: ["water", "ice"], stats: { hp: 130, attack: 85, defense: 80, spAtk: 85, spDef: 95, speed: 60 }, height: 25, weight: 2200 },
+ { id: 132, name: "Ditto", types: ["normal"], stats: { hp: 48, attack: 48, defense: 48, spAtk: 48, spDef: 48, speed: 48 }, height: 3, weight: 40 },
+ { id: 133, name: "Eevee", types: ["normal"], stats: { hp: 55, attack: 55, defense: 50, spAtk: 45, spDef: 65, speed: 55 }, height: 3, weight: 65 },
+ { id: 134, name: "Vaporeon", types: ["water"], stats: { hp: 130, attack: 65, defense: 60, spAtk: 110, spDef: 95, speed: 65 }, height: 10, weight: 290 },
+ { id: 135, name: "Jolteon", types: ["electric"], stats: { hp: 65, attack: 65, defense: 60, spAtk: 110, spDef: 95, speed: 130 }, height: 8, weight: 245 },
+ { id: 136, name: "Flareon", types: ["fire"], stats: { hp: 65, attack: 130, defense: 60, spAtk: 95, spDef: 110, speed: 65 }, height: 9, weight: 250 },
+ { id: 137, name: "Porygon", types: ["normal"], stats: { hp: 65, attack: 60, defense: 70, spAtk: 85, spDef: 75, speed: 40 }, height: 8, weight: 365 },
+ { id: 138, name: "Omanyte", types: ["rock", "water"], stats: { hp: 35, attack: 40, defense: 100, spAtk: 90, spDef: 55, speed: 35 }, height: 4, weight: 75 },
+ { id: 139, name: "Omastar", types: ["rock", "water"], stats: { hp: 70, attack: 60, defense: 125, spAtk: 115, spDef: 70, speed: 55 }, height: 10, weight: 350 },
+ { id: 140, name: "Kabuto", types: ["rock", "water"], stats: { hp: 30, attack: 80, defense: 90, spAtk: 55, spDef: 45, speed: 55 }, height: 5, weight: 115 },
+ { id: 141, name: "Kabutops", types: ["rock", "water"], stats: { hp: 60, attack: 115, defense: 105, spAtk: 65, spDef: 70, speed: 80 }, height: 13, weight: 405 },
+ { id: 142, name: "Aerodactyl", types: ["rock", "flying"], stats: { hp: 80, attack: 105, defense: 65, spAtk: 60, spDef: 75, speed: 130 }, height: 18, weight: 590 },
+ { id: 143, name: "Snorlax", types: ["normal"], stats: { hp: 160, attack: 110, defense: 65, spAtk: 65, spDef: 110, speed: 30 }, height: 21, weight: 4600 },
+ { id: 144, name: "Articuno", types: ["ice", "flying"], stats: { hp: 90, attack: 85, defense: 100, spAtk: 95, spDef: 125, speed: 85 }, height: 17, weight: 554 },
+ { id: 145, name: "Zapdos", types: ["electric", "flying"], stats: { hp: 90, attack: 90, defense: 85, spAtk: 125, spDef: 90, speed: 100 }, height: 16, weight: 526 },
+ { id: 146, name: "Moltres", types: ["fire", "flying"], stats: { hp: 90, attack: 100, defense: 90, spAtk: 125, spDef: 85, speed: 90 }, height: 20, weight: 600 },
+ { id: 147, name: "Dratini", types: ["dragon"], stats: { hp: 41, attack: 64, defense: 45, spAtk: 50, spDef: 50, speed: 50 }, height: 18, weight: 33 },
+ { id: 148, name: "Dragonair", types: ["dragon"], stats: { hp: 61, attack: 84, defense: 65, spAtk: 70, spDef: 70, speed: 70 }, height: 40, weight: 165 },
+ { id: 149, name: "Dragonite", types: ["dragon", "flying"], stats: { hp: 91, attack: 134, defense: 95, spAtk: 100, spDef: 100, speed: 80 }, height: 22, weight: 2100 },
+ { id: 150, name: "Mewtwo", types: ["psychic"], stats: { hp: 106, attack: 110, defense: 90, spAtk: 154, spDef: 90, speed: 130 }, height: 20, weight: 1220 },
+ { id: 151, name: "Mew", types: ["psychic"], stats: { hp: 100, attack: 100, defense: 100, spAtk: 100, spDef: 100, speed: 100 }, height: 4, weight: 40 },
+ // Gen 2 selections
+ { id: 152, name: "Chikorita", types: ["grass"], stats: { hp: 45, attack: 49, defense: 65, spAtk: 49, spDef: 65, speed: 45 }, height: 9, weight: 64 },
+ { id: 155, name: "Cyndaquil", types: ["fire"], stats: { hp: 39, attack: 52, defense: 43, spAtk: 60, spDef: 50, speed: 65 }, height: 5, weight: 79 },
+ { id: 158, name: "Totodile", types: ["water"], stats: { hp: 50, attack: 65, defense: 64, spAtk: 44, spDef: 48, speed: 43 }, height: 6, weight: 95 },
+ { id: 175, name: "Togepi", types: ["fairy"], stats: { hp: 35, attack: 20, defense: 65, spAtk: 40, spDef: 65, speed: 20 }, height: 3, weight: 15 },
+ { id: 176, name: "Togetic", types: ["fairy", "flying"], stats: { hp: 55, attack: 40, defense: 85, spAtk: 80, spDef: 105, speed: 40 }, height: 6, weight: 32 },
+ { id: 179, name: "Mareep", types: ["electric"], stats: { hp: 55, attack: 40, defense: 40, spAtk: 65, spDef: 45, speed: 35 }, height: 6, weight: 78 },
+ { id: 181, name: "Ampharos", types: ["electric"], stats: { hp: 90, attack: 75, defense: 85, spAtk: 115, spDef: 90, speed: 55 }, height: 14, weight: 615 },
+ { id: 196, name: "Espeon", types: ["psychic"], stats: { hp: 65, attack: 65, defense: 60, spAtk: 130, spDef: 95, speed: 110 }, height: 9, weight: 265 },
+ { id: 197, name: "Umbreon", types: ["dark"], stats: { hp: 95, attack: 65, defense: 110, spAtk: 60, spDef: 130, speed: 65 }, height: 10, weight: 270 },
+ { id: 212, name: "Scizor", types: ["bug", "steel"], stats: { hp: 70, attack: 130, defense: 100, spAtk: 55, spDef: 80, speed: 65 }, height: 18, weight: 1180 },
+ { id: 214, name: "Heracross", types: ["bug", "fighting"], stats: { hp: 80, attack: 125, defense: 75, spAtk: 40, spDef: 95, speed: 85 }, height: 15, weight: 540 },
+ { id: 228, name: "Houndour", types: ["dark", "fire"], stats: { hp: 45, attack: 60, defense: 30, spAtk: 80, spDef: 50, speed: 65 }, height: 6, weight: 108 },
+ { id: 229, name: "Houndoom", types: ["dark", "fire"], stats: { hp: 75, attack: 90, defense: 50, spAtk: 110, spDef: 80, speed: 95 }, height: 14, weight: 350 },
+ { id: 243, name: "Raikou", types: ["electric"], stats: { hp: 90, attack: 85, defense: 75, spAtk: 115, spDef: 100, speed: 115 }, height: 19, weight: 1780 },
+ { id: 244, name: "Entei", types: ["fire"], stats: { hp: 115, attack: 115, defense: 85, spAtk: 90, spDef: 75, speed: 100 }, height: 21, weight: 1980 },
+ { id: 245, name: "Suicune", types: ["water"], stats: { hp: 100, attack: 75, defense: 115, spAtk: 90, spDef: 115, speed: 85 }, height: 20, weight: 1870 },
+ { id: 248, name: "Tyranitar", types: ["rock", "dark"], stats: { hp: 100, attack: 134, defense: 110, spAtk: 95, spDef: 100, speed: 61 }, height: 20, weight: 2020 },
+ { id: 249, name: "Lugia", types: ["psychic", "flying"], stats: { hp: 106, attack: 90, defense: 130, spAtk: 90, spDef: 154, speed: 110 }, height: 52, weight: 2160 },
+ { id: 250, name: "Ho-Oh", types: ["fire", "flying"], stats: { hp: 106, attack: 130, defense: 90, spAtk: 110, spDef: 154, speed: 90 }, height: 38, weight: 1990 },
+ // Gen 3 selections
+ { id: 252, name: "Treecko", types: ["grass"], stats: { hp: 40, attack: 45, defense: 35, spAtk: 65, spDef: 55, speed: 70 }, height: 5, weight: 50 },
+ { id: 255, name: "Torchic", types: ["fire"], stats: { hp: 45, attack: 60, defense: 40, spAtk: 70, spDef: 50, speed: 45 }, height: 4, weight: 25 },
+ { id: 258, name: "Mudkip", types: ["water"], stats: { hp: 50, attack: 70, defense: 50, spAtk: 50, spDef: 50, speed: 40 }, height: 4, weight: 76 },
+ { id: 282, name: "Gardevoir", types: ["psychic", "fairy"], stats: { hp: 68, attack: 65, defense: 65, spAtk: 125, spDef: 115, speed: 80 }, height: 16, weight: 484 },
+ { id: 330, name: "Flygon", types: ["ground", "dragon"], stats: { hp: 80, attack: 100, defense: 80, spAtk: 80, spDef: 80, speed: 100 }, height: 20, weight: 820 },
+ { id: 359, name: "Absol", types: ["dark"], stats: { hp: 65, attack: 130, defense: 60, spAtk: 75, spDef: 60, speed: 75 }, height: 12, weight: 470 },
+ { id: 373, name: "Salamence", types: ["dragon", "flying"], stats: { hp: 95, attack: 135, defense: 80, spAtk: 110, spDef: 80, speed: 100 }, height: 15, weight: 1026 },
+ { id: 376, name: "Metagross", types: ["steel", "psychic"], stats: { hp: 80, attack: 135, defense: 130, spAtk: 95, spDef: 90, speed: 70 }, height: 16, weight: 5500 },
+ { id: 384, name: "Rayquaza", types: ["dragon", "flying"], stats: { hp: 105, attack: 150, defense: 90, spAtk: 150, spDef: 90, speed: 95 }, height: 70, weight: 2065 },
+ // Gen 4 selections
+ { id: 387, name: "Turtwig", types: ["grass"], stats: { hp: 55, attack: 68, defense: 64, spAtk: 45, spDef: 55, speed: 31 }, height: 4, weight: 102 },
+ { id: 390, name: "Chimchar", types: ["fire"], stats: { hp: 44, attack: 58, defense: 44, spAtk: 58, spDef: 44, speed: 61 }, height: 5, weight: 62 },
+ { id: 393, name: "Piplup", types: ["water"], stats: { hp: 53, attack: 51, defense: 53, spAtk: 61, spDef: 56, speed: 40 }, height: 4, weight: 52 },
+ { id: 445, name: "Garchomp", types: ["dragon", "ground"], stats: { hp: 108, attack: 130, defense: 95, spAtk: 80, spDef: 85, speed: 102 }, height: 19, weight: 950 },
+ { id: 448, name: "Lucario", types: ["fighting", "steel"], stats: { hp: 70, attack: 110, defense: 70, spAtk: 115, spDef: 70, speed: 90 }, height: 12, weight: 540 },
+ { id: 468, name: "Togekiss", types: ["fairy", "flying"], stats: { hp: 85, attack: 50, defense: 95, spAtk: 120, spDef: 115, speed: 80 }, height: 15, weight: 380 },
+ { id: 471, name: "Glaceon", types: ["ice"], stats: { hp: 65, attack: 60, defense: 110, spAtk: 130, spDef: 95, speed: 65 }, height: 8, weight: 259 },
+ { id: 470, name: "Leafeon", types: ["grass"], stats: { hp: 65, attack: 110, defense: 130, spAtk: 60, spDef: 65, speed: 95 }, height: 10, weight: 255 },
+ { id: 700, name: "Sylveon", types: ["fairy"], stats: { hp: 95, attack: 65, defense: 65, spAtk: 110, spDef: 130, speed: 60 }, height: 10, weight: 235 },
+]
+
+export function getPokemonSprite(id) {
+ return `https://raw.githubusercontent.com/PokeAPI/sprites/master/sprites/pokemon/other/official-artwork/${id}.png`
+}
diff --git a/team-Krantikari/src/data/typeColors.js b/team-Krantikari/src/data/typeColors.js
new file mode 100644
index 000000000..440772b5f
--- /dev/null
+++ b/team-Krantikari/src/data/typeColors.js
@@ -0,0 +1,26 @@
+export const TYPE_COLORS = {
+ normal: { bg: 'bg-stone-400/20', text: 'text-stone-300', border: 'border-stone-400/30', fill: '#a8a878', glow: 'shadow-stone-400/20' },
+ fire: { bg: 'bg-orange-500/20', text: 'text-orange-300', border: 'border-orange-500/30', fill: '#f08030', glow: 'shadow-orange-500/20' },
+ water: { bg: 'bg-blue-500/20', text: 'text-blue-300', border: 'border-blue-500/30', fill: '#6890f0', glow: 'shadow-blue-400/20' },
+ grass: { bg: 'bg-green-500/20', text: 'text-green-300', border: 'border-green-500/30', fill: '#78c850', glow: 'shadow-green-400/20' },
+ electric: { bg: 'bg-yellow-400/20', text: 'text-yellow-300', border: 'border-yellow-400/30', fill: '#f8d030', glow: 'shadow-yellow-400/20' },
+ ice: { bg: 'bg-cyan-400/20', text: 'text-cyan-300', border: 'border-cyan-400/30', fill: '#98d8d8', glow: 'shadow-cyan-400/20' },
+ fighting: { bg: 'bg-red-700/20', text: 'text-red-400', border: 'border-red-700/30', fill: '#c03028', glow: 'shadow-red-600/20' },
+ poison: { bg: 'bg-purple-500/20', text: 'text-purple-300', border: 'border-purple-500/30', fill: '#a040a0', glow: 'shadow-purple-500/20' },
+ ground: { bg: 'bg-amber-600/20', text: 'text-amber-300', border: 'border-amber-600/30', fill: '#e0c068', glow: 'shadow-amber-500/20' },
+ flying: { bg: 'bg-indigo-400/20', text: 'text-indigo-300', border: 'border-indigo-400/30', fill: '#a890f0', glow: 'shadow-indigo-400/20' },
+ psychic: { bg: 'bg-pink-500/20', text: 'text-pink-300', border: 'border-pink-500/30', fill: '#f85888', glow: 'shadow-pink-400/20' },
+ bug: { bg: 'bg-lime-500/20', text: 'text-lime-300', border: 'border-lime-500/30', fill: '#a8b820', glow: 'shadow-lime-400/20' },
+ rock: { bg: 'bg-yellow-700/20', text: 'text-yellow-400', border: 'border-yellow-700/30', fill: '#b8a038', glow: 'shadow-yellow-600/20' },
+ ghost: { bg: 'bg-violet-600/20', text: 'text-violet-300', border: 'border-violet-600/30', fill: '#705898', glow: 'shadow-violet-500/20' },
+ dragon: { bg: 'bg-indigo-600/20', text: 'text-indigo-300', border: 'border-indigo-600/30', fill: '#7038f8', glow: 'shadow-indigo-500/20' },
+ dark: { bg: 'bg-neutral-700/20', text: 'text-neutral-300', border: 'border-neutral-600/30', fill: '#705848', glow: 'shadow-neutral-500/20' },
+ steel: { bg: 'bg-slate-400/20', text: 'text-slate-300', border: 'border-slate-400/30', fill: '#b8b8d0', glow: 'shadow-slate-400/20' },
+ fairy: { bg: 'bg-pink-400/20', text: 'text-pink-300', border: 'border-pink-400/30', fill: '#ee99ac', glow: 'shadow-pink-300/20' },
+}
+
+export const ALL_TYPES = [
+ 'normal', 'fire', 'water', 'grass', 'electric', 'ice',
+ 'fighting', 'poison', 'ground', 'flying', 'psychic', 'bug',
+ 'rock', 'ghost', 'dragon', 'dark', 'steel', 'fairy',
+]
diff --git a/team-Krantikari/src/hooks/usePokedex.js b/team-Krantikari/src/hooks/usePokedex.js
new file mode 100644
index 000000000..7e0fcf9d6
--- /dev/null
+++ b/team-Krantikari/src/hooks/usePokedex.js
@@ -0,0 +1,49 @@
+import { useState, useMemo } from 'react'
+import { POKEMON_DATA } from '@/data/pokemonData'
+
+export function usePokedex() {
+ const [selectedType, setSelectedType] = useState('all')
+ const [sortBy, setSortBy] = useState('id-asc')
+ const [selectedPokemon, setSelectedPokemon] = useState(null)
+
+ const filteredPokemon = useMemo(() => {
+ let result = POKEMON_DATA
+
+ // Filter by type
+ if (selectedType !== 'all') {
+ result = result.filter((p) => p.types.includes(selectedType))
+ }
+
+ // Sort
+ switch (sortBy) {
+ case 'id-asc':
+ result = [...result].sort((a, b) => a.id - b.id)
+ break
+ case 'id-desc':
+ result = [...result].sort((a, b) => b.id - a.id)
+ break
+ case 'name-asc':
+ result = [...result].sort((a, b) => a.name.localeCompare(b.name))
+ break
+ case 'name-desc':
+ result = [...result].sort((a, b) => b.name.localeCompare(a.name))
+ break
+ default:
+ break
+ }
+
+ return result
+ }, [selectedType, sortBy])
+
+ return {
+ filteredPokemon,
+ selectedType,
+ setSelectedType,
+ sortBy,
+ setSortBy,
+ selectedPokemon,
+ setSelectedPokemon,
+ totalCount: POKEMON_DATA.length,
+ filteredCount: filteredPokemon.length,
+ }
+}
diff --git a/team-Krantikari/src/index.css b/team-Krantikari/src/index.css
new file mode 100644
index 000000000..0353b2eb6
--- /dev/null
+++ b/team-Krantikari/src/index.css
@@ -0,0 +1,144 @@
+@import "tailwindcss";
+@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');
+
+/* ===== Base Styles ===== */
+@theme {
+ --font-sans: 'Inter', system-ui, -apple-system, sans-serif;
+}
+
+/* ===== Star Twinkle Animation ===== */
+.star {
+ background: white;
+ animation: twinkle ease-in-out infinite alternate;
+}
+
+@keyframes twinkle {
+ 0% { opacity: 0; transform: scale(0.5); }
+ 50% { opacity: 1; transform: scale(1); }
+ 100% { opacity: 0.3; transform: scale(0.8); }
+}
+
+/* ===== Shimmer Lines ===== */
+@keyframes shimmer-1 {
+ 0% { transform: translateX(-50%); }
+ 100% { transform: translateX(50%); }
+}
+
+@keyframes shimmer-2 {
+ 0% { transform: translateX(50%); }
+ 100% { transform: translateX(-50%); }
+}
+
+@keyframes shimmer-3 {
+ 0% { transform: translateX(-30%); }
+ 100% { transform: translateX(30%); }
+}
+
+.animate-shimmer-1 { animation: shimmer-1 8s ease-in-out infinite; }
+.animate-shimmer-2 { animation: shimmer-2 12s ease-in-out infinite; }
+.animate-shimmer-3 { animation: shimmer-3 10s ease-in-out infinite; }
+
+/* ===== Gradient Shift ===== */
+@keyframes gradient-shift {
+ 0%, 100% { opacity: 0.3; transform: rotate(0deg) scale(1); }
+ 50% { opacity: 0.6; transform: rotate(3deg) scale(1.05); }
+}
+
+.animate-gradient-shift {
+ animation: gradient-shift 15s ease-in-out infinite;
+}
+
+/* ===== Card Entrance ===== */
+@keyframes card-enter {
+ 0% {
+ opacity: 0;
+ transform: translateY(20px) scale(0.95);
+ }
+ 100% {
+ opacity: 1;
+ transform: translateY(0) scale(1);
+ }
+}
+
+.card-entrance {
+ animation: card-enter 0.4s ease-out forwards;
+ opacity: 0;
+}
+
+/* ===== Pop-in Animation (Detail Modal) ===== */
+@keyframes pop-in {
+ 0% {
+ opacity: 0;
+ transform: scale(0.8) translateY(20px);
+ }
+ 50% {
+ transform: scale(1.02) translateY(-5px);
+ }
+ 100% {
+ opacity: 1;
+ transform: scale(1) translateY(0);
+ }
+}
+
+.animate-pop-in {
+ animation: pop-in 0.4s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
+}
+
+/* ===== Fade In ===== */
+@keyframes fade-in {
+ from { opacity: 0; }
+ to { opacity: 1; }
+}
+
+.animate-fade-in {
+ animation: fade-in 0.2s ease-out forwards;
+}
+
+/* ===== Float Animation ===== */
+@keyframes float {
+ 0%, 100% { transform: translateY(0); }
+ 50% { transform: translateY(-8px); }
+}
+
+.animate-float {
+ animation: float 3s ease-in-out infinite;
+}
+
+/* ===== Dropdown appear ===== */
+@keyframes animate-in-dropdown {
+ from { opacity: 0; transform: scale(0.95) translateY(-4px); }
+ to { opacity: 1; transform: scale(1) translateY(0); }
+}
+
+.animate-in {
+ animation: animate-in-dropdown 0.15s ease-out forwards;
+}
+
+/* ===== Scrollbar Styling ===== */
+.scrollbar-thin::-webkit-scrollbar {
+ width: 4px;
+}
+.scrollbar-thin::-webkit-scrollbar-track {
+ background: transparent;
+}
+.scrollbar-thin::-webkit-scrollbar-thumb {
+ background: rgba(255, 255, 255, 0.1);
+ border-radius: 4px;
+}
+.scrollbar-thin::-webkit-scrollbar-thumb:hover {
+ background: rgba(255, 255, 255, 0.2);
+}
+
+/* ===== Global resets ===== */
+body {
+ margin: 0;
+ font-family: 'Inter', system-ui, -apple-system, sans-serif;
+ -webkit-font-smoothing: antialiased;
+ -moz-osx-font-smoothing: grayscale;
+}
+
+#root {
+ min-height: 100vh;
+ display: flex;
+ flex-direction: column;
+}
diff --git a/team-Krantikari/src/lib/utils.js b/team-Krantikari/src/lib/utils.js
new file mode 100644
index 000000000..9d7d3ea7c
--- /dev/null
+++ b/team-Krantikari/src/lib/utils.js
@@ -0,0 +1,6 @@
+import { clsx } from 'clsx'
+import { twMerge } from 'tailwind-merge'
+
+export function cn(...inputs) {
+ return twMerge(clsx(inputs))
+}
diff --git a/team-Krantikari/src/main.jsx b/team-Krantikari/src/main.jsx
new file mode 100644
index 000000000..b9a1a6dea
--- /dev/null
+++ b/team-Krantikari/src/main.jsx
@@ -0,0 +1,10 @@
+import { StrictMode } from 'react'
+import { createRoot } from 'react-dom/client'
+import './index.css'
+import App from './App.jsx'
+
+createRoot(document.getElementById('root')).render(
+
+
+ ,
+)
diff --git a/team-Krantikari/vite.config.js b/team-Krantikari/vite.config.js
new file mode 100644
index 000000000..b60867617
--- /dev/null
+++ b/team-Krantikari/vite.config.js
@@ -0,0 +1,13 @@
+import { defineConfig } from 'vite'
+import react from '@vitejs/plugin-react'
+import tailwindcss from '@tailwindcss/vite'
+import path from 'path'
+
+export default defineConfig({
+ plugins: [react(), tailwindcss()],
+ resolve: {
+ alias: {
+ '@': path.resolve(__dirname, './src'),
+ },
+ },
+})