algocoach 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2025 AlgoCoach
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/README.md ADDED
@@ -0,0 +1,101 @@
1
+ # AlgoCoach
2
+
3
+ AI-powered LeetCode study planner that creates personalized roadmaps, daily problem sets, and tracks your progress.
4
+
5
+ ## Prerequisites
6
+
7
+ - [Bun](https://bun.sh) >= 1.3
8
+ - An AI provider API key (Google Gemini, Groq, or NVIDIA NIM)
9
+
10
+ ## Quick Start
11
+
12
+ ```bash
13
+ # Install globally
14
+ npm install -g algocoach
15
+
16
+ # Start (creates .env if missing)
17
+ algocoach start
18
+
19
+ # Open http://localhost:3000
20
+ ```
21
+
22
+ ## Setup
23
+
24
+ 1. Run `algocoach start` — creates `.env` in the current directory
25
+ 2. Edit `.env` — uncomment and set at least one API key:
26
+
27
+ ```env
28
+ AI_PROVIDER=google
29
+ GEMINI_API_KEY=your-key-here
30
+ ```
31
+
32
+ 3. Run `algocoach start` again — starts the server
33
+
34
+ ### Get an API Key
35
+
36
+ | Provider | Get Key |
37
+ |----------|---------|
38
+ | Google Gemini | https://aistudio.google.com |
39
+ | Groq | https://console.groq.com |
40
+ | NVIDIA NIM | https://build.nvidia.com |
41
+
42
+ ## Usage
43
+
44
+ 1. **Onboard** — Tell AlgoCoach your skill level, goals, and weak topics
45
+ 2. **Link LeetCode** — Enter your LeetCode username to auto-sync stats
46
+ 3. **Generate Roadmap** — AI creates a personalized multi-week study plan
47
+ 4. **Daily Plan** — Get 3 curated problems (Easy + Medium + Hard) each day
48
+ 5. **Track Progress** — Mark problems solved/tried/skipped, view streaks
49
+
50
+ ### Commands
51
+
52
+ | Command | Description |
53
+ |---------|-------------|
54
+ | `algocoach start` | Create .env if missing and start server (default) |
55
+ | `algocoach init` | Create .env only |
56
+ | `algocoach serve` | Start server (alias for `start`) |
57
+
58
+ ## Development
59
+
60
+ ```bash
61
+ git clone https://github.com/yourusername/algocoach
62
+ cd algocoach
63
+ bun install
64
+ bun run build # Build frontend
65
+ bun run dev # Dev mode with hot reload (Vite :5173 + server :3000)
66
+ bun test # Run tests
67
+ ```
68
+
69
+ ## Architecture
70
+
71
+ ```
72
+ cli/index.ts — CLI entry point (algocoach start/serve/init)
73
+ server/
74
+ index.ts — Hono HTTP server, static file serving
75
+ db/
76
+ schema.ts — Drizzle SQLite schema (11 tables)
77
+ setup.ts — CREATE TABLE SQL
78
+ index.ts — bun:sqlite connection at ~/.algocoach/data.db
79
+ auth/index.ts — Better Auth with local-dev bypass
80
+ routes/ — API route handlers (plan, leetcode, onboard, survey)
81
+ services/
82
+ ai.ts — AI provider wrapper + roadmap/daily-plan generation
83
+ ai-provider.ts — Google, Groq, NVIDIA provider implementations
84
+ leetcode-search.ts — LeetCode GraphQL search
85
+ src/ — React frontend (Vite + Tailwind)
86
+ ```
87
+
88
+ ## Data
89
+
90
+ - **Database**: `~/.algocoach/data.db` — SQLite, created on first use
91
+ - **Config**: `.env` in the working directory
92
+
93
+ ## AI Providers
94
+
95
+ AlgoCoach supports three AI backends for roadmap generation and daily plan selection:
96
+
97
+ - **Google Gemini** (default) — uses `@google/genai` SDK
98
+ - **Groq** — uses `groq-sdk` for fast inference
99
+ - **NVIDIA NIM** — uses `openai` SDK with NVIDIA's OpenAI-compatible API
100
+
101
+ Set `AI_PROVIDER=groq` or `AI_PROVIDER=nvidia` in `.env` to switch.
package/cli/index.ts ADDED
@@ -0,0 +1,97 @@
1
+ #!/usr/bin/env bun
2
+ import path from "path"
3
+ import fs from "fs"
4
+
5
+ const ENV_PATH = path.resolve(".env")
6
+
7
+ function envTemplate() {
8
+ return [
9
+ "# AlgoCoach Configuration",
10
+ "# Uncomment and fill in at least one AI provider API key.",
11
+ "",
12
+ "# AI provider: google, groq, or nvidia",
13
+ "AI_PROVIDER=google",
14
+ "",
15
+ "# API keys (get from https://aistudio.google.com, https://console.groq.com, https://build.nvidia.com)",
16
+ "# GEMINI_API_KEY=your-key-here",
17
+ "# GROQ_API_KEY=your-key-here",
18
+ "# NVIDIA_API_KEY=your-key-here",
19
+ "",
20
+ "# Optional overrides",
21
+ "# AI_MODEL=",
22
+ "# PORT=3000",
23
+ ].join("\n") + "\n"
24
+ }
25
+
26
+ function hasAnyKey(): boolean {
27
+ return !!(process.env.GEMINI_API_KEY || process.env.GROQ_API_KEY || process.env.NVIDIA_API_KEY)
28
+ }
29
+
30
+ async function cmdInit() {
31
+ if (!fs.existsSync(ENV_PATH)) {
32
+ fs.writeFileSync(ENV_PATH, envTemplate())
33
+ console.log(`Created ${ENV_PATH}`)
34
+ } else {
35
+ console.log(`${ENV_PATH} already exists`)
36
+ }
37
+
38
+ console.log(`
39
+ Edit .env to set at least one AI provider API key.
40
+ You can get API keys from:
41
+ - Google Gemini: https://aistudio.google.com
42
+ - Groq: https://console.groq.com
43
+ - NVIDIA NIM: https://build.nvidia.com
44
+
45
+ Then run: algocoach start
46
+ `)
47
+ }
48
+
49
+ async function cmdStart() {
50
+ if (!fs.existsSync(ENV_PATH)) {
51
+ console.log("No .env found. Creating one...")
52
+ fs.writeFileSync(ENV_PATH, envTemplate())
53
+ console.log(`Created ${ENV_PATH}`)
54
+ console.log("Edit it with your API keys, then run 'algocoach start' again.\n")
55
+ return
56
+ }
57
+
58
+ if (!hasAnyKey()) {
59
+ console.error("No AI API key configured in .env. Add at least one key and try again.")
60
+ process.exit(1)
61
+ }
62
+
63
+ const port = parseInt(process.env.PORT || "3000", 10)
64
+
65
+ process.env.LOCAL_DEV = "true"
66
+ process.env.LOCAL_USER_ID = "local-user"
67
+ process.env.BETTER_AUTH_URL = `http://localhost:${port}`
68
+ process.env.BETTER_AUTH_SECRET = "local-dev-secret-min-32-chars-long-for-better-auth"
69
+ process.env.CORS_ORIGIN = `http://localhost:${port}`
70
+
71
+ const { serve } = await import("../server/index")
72
+ serve(port)
73
+
74
+ console.log(`\n AlgoCoach running at http://localhost:${port}\n`)
75
+ }
76
+
77
+ const cmd = process.argv[2] || "start"
78
+
79
+ switch (cmd) {
80
+ case "init":
81
+ await cmdInit()
82
+ break
83
+ case "start":
84
+ case "serve":
85
+ await cmdStart()
86
+ break
87
+ default:
88
+ console.log(`
89
+ Usage: algocoach <command>
90
+
91
+ Commands:
92
+ start Create .env if needed and start the server
93
+ init Create .env in current directory
94
+
95
+ Run 'algocoach start' to get started.
96
+ `)
97
+ }
@@ -0,0 +1 @@
1
+ *,:before,:after,::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border:0 solid #e5e7eb}:before,:after{--tw-content:""}html,:host{-webkit-text-size-adjust:100%;tab-size:4;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.5}body{line-height:inherit;margin:0}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-feature-settings:normal;font-variation-settings:normal;font-family:JetBrains Mono,Fira Code,monospace;font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-feature-settings:inherit;font-variation-settings:inherit;font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:#0000;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{margin:0;padding:0;list-style:none}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder{opacity:1;color:#9ca3af}textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}:root{--surface-950:255 255 255;--surface-900:250 250 250;--surface-800:243 244 246;--surface-700:229 231 235;--surface-600:209 213 219;--surface-500:156 163 175;--surface-400:107 114 128;--surface-300:75 85 99;--surface-200:31 41 55;--surface-100:17 24 39;--surface-50:3 7 12;--accent-50:239 246 255;--accent-100:219 234 254;--accent-200:191 219 254;--accent-300:147 197 253;--accent-400:96 165 250;--accent-500:59 130 246;--accent-600:37 99 235;--accent-700:29 78 216;--accent-800:30 64 175;--accent-900:30 58 138;--accent-950:23 37 84}.dark{--surface-50:212 212 212;--surface-100:200 200 200;--surface-200:180 180 180;--surface-300:156 156 156;--surface-400:120 120 120;--surface-500:100 100 100;--surface-600:80 80 80;--surface-700:60 60 60;--surface-800:45 45 45;--surface-900:30 30 30;--surface-950:20 20 20;--accent-50:240 240 240;--accent-100:224 224 224;--accent-200:200 200 200;--accent-300:176 176 176;--accent-400:150 150 150;--accent-500:120 120 120;--accent-600:100 100 100;--accent-700:80 80 80;--accent-800:60 60 60;--accent-900:45 45 45;--accent-950:35 35 35}html{scroll-behavior:smooth}body{--tw-bg-opacity:1;background-color:rgb(var(--surface-950) / var(--tw-bg-opacity,1));--tw-text-opacity:1;color:rgb(var(--surface-200) / var(--tw-text-opacity,1));-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,system-ui,-apple-system,sans-serif}::selection{background-color:rgb(var(--accent-500) / .3);--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}::-webkit-scrollbar{width:.5rem}::-webkit-scrollbar-track{--tw-bg-opacity:1;background-color:rgb(var(--surface-800) / var(--tw-bg-opacity,1))}::-webkit-scrollbar-thumb{--tw-bg-opacity:1;background-color:rgb(var(--surface-600) / var(--tw-bg-opacity,1));border-radius:9999px}::-webkit-scrollbar-thumb:hover{--tw-bg-opacity:1;background-color:rgb(var(--surface-500) / var(--tw-bg-opacity,1))}.glass-card{border-width:1px;border-color:rgb(var(--surface-600) / .5);background-color:rgb(var(--surface-800) / .6);--tw-backdrop-blur:blur(24px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);border-radius:1rem}.glass-card-hover{border-width:1px;border-color:rgb(var(--surface-600) / .5);background-color:rgb(var(--surface-800) / .6);--tw-backdrop-blur:blur(24px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);border-radius:1rem;transition-property:all;transition-duration:.3s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.glass-card-hover:hover{border-color:rgb(var(--accent-500) / .3);--tw-shadow:var(--tw-shadow-colored);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow);--tw-shadow-color:rgb(var(--accent-500) / .05)}.gradient-text{background-image:linear-gradient(to right, var(--tw-gradient-stops));--tw-gradient-from:#fff var(--tw-gradient-from-position);--tw-gradient-to:rgb(var(--accent-400) / 1) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), rgb(var(--accent-200) / 1) var(--tw-gradient-via-position), var(--tw-gradient-to);color:#0000;-webkit-background-clip:text;background-clip:text}.pointer-events-none{pointer-events:none}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:0}.inset-4{inset:1rem}.-left-32{left:-8rem}.-right-32{right:-8rem}.bottom-1\/4{bottom:25%}.left-0{left:0}.left-3{left:.75rem}.right-0{right:0}.top-0{top:0}.top-1\/2{top:50%}.top-1\/4{top:25%}.z-40{z-index:40}.z-50{z-index:50}.mx-auto{margin-left:auto;margin-right:auto}.mb-1{margin-bottom:.25rem}.mb-12{margin-bottom:3rem}.mb-16{margin-bottom:4rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-1{margin-left:.25rem}.ml-1\.5{margin-left:.375rem}.ml-4{margin-left:1rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-1\.5{margin-top:.375rem}.mt-12{margin-top:3rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.block{display:block}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.h-0\.5{height:.125rem}.h-1\.5{height:.375rem}.h-10{height:2.5rem}.h-12{height:3rem}.h-14{height:3.5rem}.h-16{height:4rem}.h-2{height:.5rem}.h-2\.5{height:.625rem}.h-24{height:6rem}.h-3{height:.75rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-48{height:12rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-64{height:16rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-96{height:24rem}.h-full{height:100%}.max-h-32{max-height:8rem}.max-h-60{max-height:15rem}.max-h-80{max-height:20rem}.min-h-screen{min-height:100vh}.w-1\.5{width:.375rem}.w-10{width:2.5rem}.w-12{width:3rem}.w-14{width:3.5rem}.w-16{width:4rem}.w-2{width:.5rem}.w-2\.5{width:.625rem}.w-20{width:5rem}.w-24{width:6rem}.w-3{width:.75rem}.w-3\.5{width:.875rem}.w-32{width:8rem}.w-36{width:9rem}.w-4{width:1rem}.w-48{width:12rem}.w-5{width:1.25rem}.w-56{width:14rem}.w-6{width:1.5rem}.w-8{width:2rem}.w-9{width:2.25rem}.w-96{width:24rem}.w-full{width:100%}.min-w-0{min-width:0}.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}.max-w-7xl{max-width:80rem}.max-w-md{max-width:28rem}.max-w-xl{max-width:36rem}.flex-1{flex:1}.shrink-0{flex-shrink:0}.-translate-y-1\/2{--tw-translate-y:-50%;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-rotate-90{--tw-rotate:-90deg;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:2s cubic-bezier(.4,0,.6,1) infinite pulse}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:1s linear infinite spin}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.resize-none{resize:none}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.gap-0\.5{gap:.125rem}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-16{gap:4rem}.gap-2{gap:.5rem}.gap-2\.5{gap:.625rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.-space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(-.5rem * var(--tw-space-x-reverse));margin-left:calc(-.5rem * calc(1 - var(--tw-space-x-reverse)))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.space-y-8>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(2rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(2rem * var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.whitespace-pre-wrap{white-space:pre-wrap}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:1rem}.rounded-3xl{border-radius:1.5rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-accent-500{--tw-border-opacity:1;border-color:rgb(var(--accent-500) / var(--tw-border-opacity,1))}.border-accent-500\/20{border-color:rgb(var(--accent-500) / .2)}.border-accent-500\/40{border-color:rgb(var(--accent-500) / .4)}.border-accent-500\/50{border-color:rgb(var(--accent-500) / .5)}.border-amber-500\/20{border-color:#f59e0b33}.border-emerald-500\/20{border-color:#10b98133}.border-red-500\/20{border-color:#ef444433}.border-surface-500\/30{border-color:rgb(var(--surface-500) / .3)}.border-surface-600{--tw-border-opacity:1;border-color:rgb(var(--surface-600) / var(--tw-border-opacity,1))}.border-surface-600\/30{border-color:rgb(var(--surface-600) / .3)}.border-surface-700{--tw-border-opacity:1;border-color:rgb(var(--surface-700) / var(--tw-border-opacity,1))}.border-surface-700\/30{border-color:rgb(var(--surface-700) / .3)}.border-surface-700\/50{border-color:rgb(var(--surface-700) / .5)}.border-surface-800{--tw-border-opacity:1;border-color:rgb(var(--surface-800) / var(--tw-border-opacity,1))}.border-surface-800\/50{border-color:rgb(var(--surface-800) / .5)}.border-surface-950{--tw-border-opacity:1;border-color:rgb(var(--surface-950) / var(--tw-border-opacity,1))}.border-transparent{border-color:#0000}.bg-accent-400{--tw-bg-opacity:1;background-color:rgb(var(--accent-400) / var(--tw-bg-opacity,1))}.bg-accent-500{--tw-bg-opacity:1;background-color:rgb(var(--accent-500) / var(--tw-bg-opacity,1))}.bg-accent-500\/10{background-color:rgb(var(--accent-500) / .1)}.bg-accent-500\/20{background-color:rgb(var(--accent-500) / .2)}.bg-accent-500\/30{background-color:rgb(var(--accent-500) / .3)}.bg-accent-500\/5{background-color:rgb(var(--accent-500) / .05)}.bg-accent-600{--tw-bg-opacity:1;background-color:rgb(var(--accent-600) / var(--tw-bg-opacity,1))}.bg-amber-500{--tw-bg-opacity:1;background-color:rgb(245 158 11/var(--tw-bg-opacity,1))}.bg-amber-500\/10{background-color:#f59e0b1a}.bg-black\/60{background-color:#0009}.bg-emerald-500{--tw-bg-opacity:1;background-color:rgb(16 185 129/var(--tw-bg-opacity,1))}.bg-emerald-500\/10{background-color:#10b9811a}.bg-emerald-500\/5{background-color:#10b9810d}.bg-emerald-600{--tw-bg-opacity:1;background-color:rgb(5 150 105/var(--tw-bg-opacity,1))}.bg-green-500\/80{background-color:#22c55ecc}.bg-indigo-500\/10{background-color:#6366f11a}.bg-red-500{--tw-bg-opacity:1;background-color:rgb(239 68 68/var(--tw-bg-opacity,1))}.bg-red-500\/10{background-color:#ef44441a}.bg-red-500\/80{background-color:#ef4444cc}.bg-surface-500\/30{background-color:rgb(var(--surface-500) / .3)}.bg-surface-600\/30{background-color:rgb(var(--surface-600) / .3)}.bg-surface-700{--tw-bg-opacity:1;background-color:rgb(var(--surface-700) / var(--tw-bg-opacity,1))}.bg-surface-700\/30{background-color:rgb(var(--surface-700) / .3)}.bg-surface-700\/50{background-color:rgb(var(--surface-700) / .5)}.bg-surface-800{--tw-bg-opacity:1;background-color:rgb(var(--surface-800) / var(--tw-bg-opacity,1))}.bg-surface-800\/10{background-color:rgb(var(--surface-800) / .1)}.bg-surface-800\/20{background-color:rgb(var(--surface-800) / .2)}.bg-surface-800\/30{background-color:rgb(var(--surface-800) / .3)}.bg-surface-800\/50{background-color:rgb(var(--surface-800) / .5)}.bg-surface-900{--tw-bg-opacity:1;background-color:rgb(var(--surface-900) / var(--tw-bg-opacity,1))}.bg-surface-900\/30{background-color:rgb(var(--surface-900) / .3)}.bg-surface-900\/50{background-color:rgb(var(--surface-900) / .5)}.bg-surface-900\/80{background-color:rgb(var(--surface-900) / .8)}.bg-surface-950{--tw-bg-opacity:1;background-color:rgb(var(--surface-950) / var(--tw-bg-opacity,1))}.bg-surface-950\/80{background-color:rgb(var(--surface-950) / .8)}.bg-yellow-500\/80{background-color:#eab308cc}.bg-gradient-to-b{background-image:linear-gradient(to bottom, var(--tw-gradient-stops))}.bg-gradient-to-br{background-image:linear-gradient(to bottom right, var(--tw-gradient-stops))}.bg-gradient-to-r{background-image:linear-gradient(to right, var(--tw-gradient-stops))}.from-accent-400{--tw-gradient-from:rgb(var(--accent-400) / 1) var(--tw-gradient-from-position);--tw-gradient-to:rgb(var(--accent-400) / 0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.from-accent-500{--tw-gradient-from:rgb(var(--accent-500) / 1) var(--tw-gradient-from-position);--tw-gradient-to:rgb(var(--accent-500) / 0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.from-accent-500\/10{--tw-gradient-from:rgb(var(--accent-500) / .1) var(--tw-gradient-from-position);--tw-gradient-to:rgb(var(--accent-500) / 0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.from-accent-500\/20{--tw-gradient-from:rgb(var(--accent-500) / .2) var(--tw-gradient-from-position);--tw-gradient-to:rgb(var(--accent-500) / 0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.from-accent-500\/5{--tw-gradient-from:rgb(var(--accent-500) / .05) var(--tw-gradient-from-position);--tw-gradient-to:rgb(var(--accent-500) / 0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.from-surface-300{--tw-gradient-from:rgb(var(--surface-300) / 1) var(--tw-gradient-from-position);--tw-gradient-to:rgb(var(--surface-300) / 0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.from-surface-400{--tw-gradient-from:rgb(var(--surface-400) / 1) var(--tw-gradient-from-position);--tw-gradient-to:rgb(var(--surface-400) / 0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.from-surface-500{--tw-gradient-from:rgb(var(--surface-500) / 1) var(--tw-gradient-from-position);--tw-gradient-to:rgb(var(--surface-500) / 0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.from-surface-900\/30{--tw-gradient-from:rgb(var(--surface-900) / .3) var(--tw-gradient-from-position);--tw-gradient-to:rgb(var(--surface-900) / 0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.from-surface-900\/50{--tw-gradient-from:rgb(var(--surface-900) / .5) var(--tw-gradient-from-position);--tw-gradient-to:rgb(var(--surface-900) / 0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.from-transparent{--tw-gradient-from:transparent var(--tw-gradient-from-position);--tw-gradient-to:#0000 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.via-accent-500\/5{--tw-gradient-to:rgb(var(--accent-500) / 0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), rgb(var(--accent-500) / .05) var(--tw-gradient-via-position), var(--tw-gradient-to)}.via-transparent{--tw-gradient-to:#0000 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), transparent var(--tw-gradient-via-position), var(--tw-gradient-to)}.to-accent-600{--tw-gradient-to:rgb(var(--accent-600) / 1) var(--tw-gradient-to-position)}.to-accent-600\/10{--tw-gradient-to:rgb(var(--accent-600) / .1) var(--tw-gradient-to-position)}.to-accent-600\/20{--tw-gradient-to:rgb(var(--accent-600) / .2) var(--tw-gradient-to-position)}.to-accent-700{--tw-gradient-to:rgb(var(--accent-700) / 1) var(--tw-gradient-to-position)}.to-surface-100{--tw-gradient-to:rgb(var(--surface-100) / 1) var(--tw-gradient-to-position)}.to-surface-200{--tw-gradient-to:rgb(var(--surface-200) / 1) var(--tw-gradient-to-position)}.to-surface-300{--tw-gradient-to:rgb(var(--surface-300) / 1) var(--tw-gradient-to-position)}.to-surface-600{--tw-gradient-to:rgb(var(--surface-600) / 1) var(--tw-gradient-to-position)}.to-surface-700{--tw-gradient-to:rgb(var(--surface-700) / 1) var(--tw-gradient-to-position)}.to-surface-900\/30{--tw-gradient-to:rgb(var(--surface-900) / .3) var(--tw-gradient-to-position)}.to-surface-900\/50{--tw-gradient-to:rgb(var(--surface-900) / .5) var(--tw-gradient-to-position)}.to-transparent{--tw-gradient-to:transparent var(--tw-gradient-to-position)}.bg-clip-text{-webkit-background-clip:text;background-clip:text}.stroke-surface-100{stroke:rgb(var(--surface-100) / 1)}.stroke-surface-200{stroke:rgb(var(--surface-200) / 1)}.stroke-surface-300{stroke:rgb(var(--surface-300) / 1)}.p-1{padding:.25rem}.p-12{padding:3rem}.p-2{padding:.5rem}.p-2\.5{padding:.625rem}.p-3{padding:.75rem}.p-3\.5{padding:.875rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-8{padding-left:2rem;padding-right:2rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-24{padding-top:6rem;padding-bottom:6rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-3\.5{padding-top:.875rem;padding-bottom:.875rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pb-16{padding-bottom:4rem}.pl-10{padding-left:2.5rem}.pl-9{padding-left:2.25rem}.pr-3{padding-right:.75rem}.pr-4{padding-right:1rem}.pt-1{padding-top:.25rem}.pt-2{padding-top:.5rem}.pt-24{padding-top:6rem}.pt-3{padding-top:.75rem}.pt-4{padding-top:1rem}.pt-8{padding-top:2rem}.text-left{text-align:left}.text-center{text-align:center}.font-mono{font-family:JetBrains Mono,Fira Code,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-5xl{font-size:3rem;line-height:1}.text-6xl{font-size:3.75rem;line-height:1}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.capitalize{text-transform:capitalize}.leading-relaxed{line-height:1.625}.leading-tight{line-height:1.25}.text-accent-300{--tw-text-opacity:1;color:rgb(var(--accent-300) / var(--tw-text-opacity,1))}.text-accent-400{--tw-text-opacity:1;color:rgb(var(--accent-400) / var(--tw-text-opacity,1))}.text-amber-400{--tw-text-opacity:1;color:rgb(251 191 36/var(--tw-text-opacity,1))}.text-emerald-400{--tw-text-opacity:1;color:rgb(52 211 153/var(--tw-text-opacity,1))}.text-indigo-400{--tw-text-opacity:1;color:rgb(129 140 248/var(--tw-text-opacity,1))}.text-red-400{--tw-text-opacity:1;color:rgb(248 113 113/var(--tw-text-opacity,1))}.text-surface-100{--tw-text-opacity:1;color:rgb(var(--surface-100) / var(--tw-text-opacity,1))}.text-surface-200{--tw-text-opacity:1;color:rgb(var(--surface-200) / var(--tw-text-opacity,1))}.text-surface-300{--tw-text-opacity:1;color:rgb(var(--surface-300) / var(--tw-text-opacity,1))}.text-surface-400{--tw-text-opacity:1;color:rgb(var(--surface-400) / var(--tw-text-opacity,1))}.text-surface-50{--tw-text-opacity:1;color:rgb(var(--surface-50) / var(--tw-text-opacity,1))}.text-surface-500{--tw-text-opacity:1;color:rgb(var(--surface-500) / var(--tw-text-opacity,1))}.text-surface-600{--tw-text-opacity:1;color:rgb(var(--surface-600) / var(--tw-text-opacity,1))}.text-transparent{color:#0000}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.placeholder-surface-500::placeholder{--tw-placeholder-opacity:1;color:rgb(var(--surface-500) / var(--tw-placeholder-opacity,1))}.accent-accent-500{accent-color:rgb(var(--accent-500) / 1)}.opacity-0{opacity:0}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.shadow-lg{--tw-shadow:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow)}.shadow-xl{--tw-shadow:0 20px 25px -5px #0000001a, 0 8px 10px -6px #0000001a;--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow)}.shadow-accent-500\/20{--tw-shadow-color:rgb(var(--accent-500) / .2);--tw-shadow:var(--tw-shadow-colored)}.outline{outline-style:solid}.ring{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow,0 0 #0000)}.blur-2xl{--tw-blur:blur(40px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.blur-3xl{--tw-blur:blur(64px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.blur-xl{--tw-blur:blur(24px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur-sm{--tw-backdrop-blur:blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.backdrop-blur-xl{--tw-backdrop-blur:blur(24px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter,backdrop-filter;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-all{transition-property:all;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-opacity{transition-property:opacity;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-transform{transition-property:transform;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-200{transition-duration:.2s}.duration-500{transition-duration:.5s}.text-balance{text-wrap:balance}.hover\:scale-110:hover{--tw-scale-x:1.1;--tw-scale-y:1.1;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:border-accent-400:hover{--tw-border-opacity:1;border-color:rgb(var(--accent-400) / var(--tw-border-opacity,1))}.hover\:border-emerald-500:hover{--tw-border-opacity:1;border-color:rgb(16 185 129/var(--tw-border-opacity,1))}.hover\:border-surface-600:hover{--tw-border-opacity:1;border-color:rgb(var(--surface-600) / var(--tw-border-opacity,1))}.hover\:border-surface-600\/50:hover{border-color:rgb(var(--surface-600) / .5)}.hover\:border-surface-700\/60:hover{border-color:rgb(var(--surface-700) / .6)}.hover\:bg-accent-500:hover{--tw-bg-opacity:1;background-color:rgb(var(--accent-500) / var(--tw-bg-opacity,1))}.hover\:bg-accent-500\/10:hover{background-color:rgb(var(--accent-500) / .1)}.hover\:bg-amber-500\/20:hover{background-color:#f59e0b33}.hover\:bg-emerald-500\/20:hover{background-color:#10b98133}.hover\:bg-indigo-500\/20:hover{background-color:#6366f133}.hover\:bg-surface-700:hover{--tw-bg-opacity:1;background-color:rgb(var(--surface-700) / var(--tw-bg-opacity,1))}.hover\:bg-surface-800:hover{--tw-bg-opacity:1;background-color:rgb(var(--surface-800) / var(--tw-bg-opacity,1))}.hover\:bg-surface-800\/20:hover{background-color:rgb(var(--surface-800) / .2)}.hover\:bg-surface-800\/50:hover{background-color:rgb(var(--surface-800) / .5)}.hover\:text-accent-400:hover{--tw-text-opacity:1;color:rgb(var(--accent-400) / var(--tw-text-opacity,1))}.hover\:text-surface-200:hover{--tw-text-opacity:1;color:rgb(var(--surface-200) / var(--tw-text-opacity,1))}.hover\:text-surface-300:hover{--tw-text-opacity:1;color:rgb(var(--surface-300) / var(--tw-text-opacity,1))}.hover\:text-surface-50:hover{--tw-text-opacity:1;color:rgb(var(--surface-50) / var(--tw-text-opacity,1))}.hover\:text-white:hover{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.hover\:shadow-accent-500\/30:hover{--tw-shadow-color:rgb(var(--accent-500) / .3);--tw-shadow:var(--tw-shadow-colored)}.focus\:border-accent-500\/50:focus{border-color:rgb(var(--accent-500) / .5)}.focus\:outline-none:focus{outline-offset:2px;outline:2px solid #0000}.focus\:ring-1:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow,0 0 #0000)}.focus\:ring-accent-500\/20:focus{--tw-ring-color:rgb(var(--accent-500) / .2)}.disabled\:opacity-50:disabled{opacity:.5}.group:hover .group-hover\:opacity-100{opacity:1}@media (width>=640px){.sm\:inset-auto{inset:auto}.sm\:left-1\/2{left:50%}.sm\:top-1\/2{top:50%}.sm\:block{display:block}.sm\:inline{display:inline}.sm\:w-48{width:12rem}.sm\:w-auto{width:auto}.sm\:w-full{width:100%}.sm\:max-w-lg{max-width:32rem}.sm\:flex-initial{flex:0 auto}.sm\:-translate-x-1\/2{--tw-translate-x:-50%;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.sm\:-translate-y-1\/2{--tw-translate-y:-50%;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:items-center{align-items:center}.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}.sm\:text-3xl{font-size:1.875rem;line-height:2.25rem}.sm\:text-5xl{font-size:3rem;line-height:1}.sm\:text-6xl{font-size:3.75rem;line-height:1}.sm\:text-xl{font-size:1.25rem;line-height:1.75rem}}@media (width>=768px){.md\:col-span-4{grid-column:span 4/span 4}.md\:flex{display:flex}.md\:hidden{display:none}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:flex-row{flex-direction:row}}@media (width>=1024px){.lg\:col-span-2{grid-column:span 2/span 2}.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:p-8{padding:2rem}.lg\:px-8{padding-left:2rem;padding-right:2rem}.lg\:text-7xl{font-size:4.5rem;line-height:1}}